软硬件协同设计 HW/SW Co-design By yuhong_hao 12.12.2002.

Slides:



Advertisements
Similar presentations
什么是SOPC: SOPC是英文System On a Programmable Chip的缩写,称为片上可编程系统。SOPC将传统的EDA技术、计算机系统、嵌入式系统、数字信号处理等融为一体,综合了各自的优势,且在结构上形成一块芯片。 为什么用SOPC:SOPC是现代电子技术和电子系统设计的发展趋势,建立了电子系统设计的新模式。用户利用SOPC开发平台,自行设计高速、高性能的DSP处理器、特定功能的CPU及其外围接口电路,创建结构最为简洁的电子系统。
Advertisements

SOPC技术 数字逻辑电路 主讲:刘昌华 嵌入式技术研究所
Recent Research Progresses in Zhejiang University
方案設計與評估.
(原Protel)Altium公司 中国大学计划推介
Ch02物件導向程式設計 物件導向系統分析與設計.
102-1 Under-Graduate Project FFT
第三章 版图设计.
第4章 VHDL设计初步.
集成电路与EDA技术的发展.
第10章 FPGA硬件设计 <EDA技术与应用> 课程讲义
Combinational Logic 組合邏輯
-Artificial Neural Network- Hopfield Neural Network(HNN) 朝陽科技大學 資訊管理系 李麗華 教授.
程設一.
為什麼要參加實習 接觸業界最新技術 了解職場技術所需 接近正職員工的薪資待遇 提前佈局自己的職場未來 投資自己的專業技術與人脈
大数据在医疗行业的应用.
云实践引导产业升级 沈寓实 博士 教授 MBA 中国云体系产业创新战略联盟秘书长 微软云计算中国区总监 WinHEC 2015
Operating System CPU Scheduing - 3 Monday, August 11, 2008.
Homework 4 an innovative design process model TEAM 7
电工电子实验中心.
EPF10K10TI144-4晶片燒錄.
形式语言与网络 计算环境构建 1.
異質計算教學課程內容 「異質計算」種子教師研習營 洪士灝 國立台灣大學資訊工程學系
軟體原型 (Software Prototyping)
从UNIX到Windows的 电信软件移植实践
版权所有,禁止未经授权的商业使用行为 何宾 Tel: 北京中教仪装备技术有限公司.
EDA技术实用教程 第1章 概 述.
嵌入式系统课程简介 宋健建 南京大学软件学院 2004/02/10.
單元3:軟體設計 3-2 順序圖(Sequence Diagrams)
HLA - Time Management 陳昱豪.
欢迎参加VHDL培训 VHDL培训教程 浙江大学电子信息技术研究所 电子设计自动化(EDA)培训中心
China Standardization activities of ITS
Verilog硬件描述语言基础.
SAP 架構及基本操作 SAP前端軟體安裝與登入 Logical View of the SAP System SAP登入 IDES
EDA 原理及应用 何宾
971研究方法課程第九次上課 認識、理解及選擇一項適當的研究策略
Visual Studio Team System 简介
Programmable Logic Architecture Verilog HDL FPGA Design
JTAG INTERFACE SRAM TESTER WITH C-LCM
邏輯設計 Logic Design 顧叔財, Room 9703, (037)381864,
时序电路设计 刘鹏 浙江大学信息与电子工程系 Apr. 24, 2011 EE141
第4章(1) 空间数据库 —数据库理论基础 北京建筑工程学院 王文宇.
DevDays ’99 The aim of this mission is knowledge..
Computing and SE II Chapter 4: Requirements Engineering
Instructions: Language of the Machine
IBM SWG Overall Introduction
Unit 11.Operating System 11.1 What’s OS 11.2 Related Courses
TinyOS 石万兵 2019/4/6 mice.
資料結構 Data Structures Fall 2006, 95學年第一學期 Instructor : 陳宗正.
第一次上机安排 第六周 第七周 周一晚(提高1、2,通信001~012) 周二上(通信014~085) 周四上(通信086~154)
梁文新 办公室:综合楼108 电 话: 软件工程导论 梁文新 办公室:综合楼108 电 话:
中国科学技术大学计算机系 陈香兰 2013Fall 第七讲 存储器管理 中国科学技术大学计算机系 陈香兰 2013Fall.
虚 拟 仪 器 virtual instrument
從 ER 到 Logical Schema ──兼談Schema Integration
數位邏輯設計 VHDL.
SoC 與微控制器的發展 朱亞民.
An organizational learning approach to information systems development
SAP 架構及基本操作 SAP前端軟體安裝與登入 Logical View of the SAP System SAP登入 IDES
临界区问题的硬件指令解决方案 (Synchronization Hardware)
醫工所碩士二年級 R 葉昱甫 電子所碩士一年級 R 謝博鈞 電信所碩士一年級 R 王欣平
陳慶瀚 機器智慧與自動化技術(MIAT)實驗室 國立中央大學資工系 2009年10月22日
Programmable Logic System Design
Progress Report Yuan-Hsin Liao 10/22/2014.
SAP 架構及前端軟體安裝 Logical View of the SAP System SAP Frontend 7.1安裝 SAP登入
Requirements for SPN Information Modeling
电气工程学院 “卓越工程师”计划 ADI(北京) 企业实习
Programmable Logic System Design
A Trie-based Approach to Fast Flow Recognition for OpenFlow
Section 1 Basic concepts of web page
Presentation transcript:

软硬件协同设计 HW/SW Co-design By yuhong_hao 12.12.2002

Contents: Part one : 软硬件协同设计的引入; Part two : 软硬件协同设计所涉及到的内容: 1. HW-SW Co-design Flow 2. Contemporary Co-design Framework 3. HW-SW partition 4. HW-SW Co-synthesis  5. HW-SW co-simulation  Part three : 目前支持软硬件协同设计的工具介绍。

Part One 软硬件协同设计的引入

1. 以软硬件协同设计(Software/Hardware Co-Design) 系统集成芯片设计方法学的内容 1. 以软硬件协同设计(Software/Hardware Co-Design) 2. 具有知识产权的内核(Intellectual Property Core简称IP核) 复用 3. 超深亚微米(Very Deep Sub-Micron,简称VDSM)技术为 支撑的系统集成芯片是国际超大规模集成电路的发 展趋势和新世纪集成电路的主流

Problems with Past Design Method 缺少统一的软硬件表示方法 划分依靠先验定义 不能够验证整个系统 通过 HW/SW 边界时很难发现不兼容问题 缺少成熟的设计流程 上市时间问题 描述更改变得困难 Need Hardware-Software Co-Design

软硬件协同设计理论体系 系统任务描述 (System Task Description ) 软硬件划分 (Hardware/Software Partition) 软硬件协同综合 (Hardware/Software Co-synthesis ) 软硬件协同仿真 (Hardware/Software Co-simulation ) 与系统设计相关的低压低功耗设计,可测性设计等等。

1. HW/SW Co-design 发展过程: 软硬件协同设计早期 主要是针对一个特定的硬件如何进行软件开发或根据一个 已有 的软件实现具体的硬件结构。 前者是一个经典的软件开发问题 软件性能的好坏不仅仅取决于软件开发人员的技术水平,更有 赖于所使用的硬件平台; 后者是一个软件固化的问题 实现的途径可以是采用一个与原有软件平台相同的硬件处理器, 并将软件代码存储于存储器当中,也可以是在充分理解软件的 内在功能之后完全用硬件来实现软件的功能。

2. 了解 HW-SW Co-design? HW-SW Co-design目的是为hardware和software的协同描述,验证和综合提供一种集成环境。 How can this be achieved? 涉及以下技术 嵌入式系统设计, 实时系统设计, 硬件设计, 软件设计.

Concurrent design(并行设计) Traditional design flow Concurrent (codesign) flow Start Start HW SW HW SW Designed by independent groups of experts Designed by Same group of experts with cooperation

3. Why co-design? 缩短开发周期 取得更好的设计效果 满足苛刻的设计限制 这种平台的推出将不仅包含芯片本身,还必须包含完整的开发系统和典型应用实例,而供应商提供的服务和技术支持也当然要成为产品不可分割的一部分。 可以充分根据每个描述的特点生成最优的软硬件划分方案和软件、硬件架构。 可再配置的系统集成芯片平台(Re-Configurable SOC Platform)将是一个可能的选择。 探索替代设计产品 好的设计一定是HW/SW平衡 功率, 大小, 时序, 和性能 安全性和可靠性 SOC设计方法学

4. Hardware/Software Co-Design Goals and Requirements 统一的设计方法 执行独立 设计/执行验证 自动生成Hardware and Software 综合 Facilitates system specification Easy HW-SW trade-off evaluation Flexible HW-SW partitioning Stress system design issues Allow different hardware and software styles Formal Verification Simulation

5. Co-design 环境: Commercial(商业) Research(研究) CADLab, SIR/CASTLE (Germany), Chinook, COSMOS, COSYMA, CoWare, DICE, COMET, LYCOS (Denmark), POLIS, Ptolemy, Riley, TOSCA, AKKA, CODES, VIOOL, COOL… Commercial(商业) ArchGen (Synergy System Design, Inc.), Mentor Graphics, Synopsys, Synthesia->Cadence, Co-design Automation->Synopsys, Celoxica, CoWare, etc.

到目前为止,商业系统的限制: 1. 典型的手动划分 2. 固定应用领域(carefully very specialized) 3. 逐渐增长的评估需求支持很弱(no abstract models) 4. 主要强调性能 5. 模型的连贯性在设计重用中不被支持 商业系统更强调协同验证(co-verification)方面(more achievable goal)

Part two 软硬件协同设计所涉及到的内容: 1. HW-SW Co-design Flow 2. Contemporary Co-design Framework 3. HW-SW partition 4. HW-SW Co-synthesis  5. HW-SW co-simulation 

引子 SW/HW开发模型: 数据/控制流思想在两个领域都很普遍。

面临的问题 SW 设计师 have to 懂得 HW 语义 HW设计师 have to 懂得 SW 语义 Break the wall today! SW 设计师 have to 懂得 HW 语义 HW设计师 have to 懂得 SW 语义

1. 软件硬件协同设计的设计流程 用HDL语言和C语言进行系统描述并进行模拟仿真和系统功能验证; 对软硬件实现进行功能划分,分别用语言进行设计并将其综合起来进行功能验证和性能预测等仿真确认(协调模拟仿真); 如无问题则进行软件和硬件详细设计; 最后进行系统测试。

典型的 co-design 流程: 划分: 手动/自动/半自动

2. Contemporary Co-design Framework System Specification Validation Front end Compiler Behavior Description of Modules Performance Estimation Partitioning Synthesis S/W Common H/W For precise specification, we need to - think the system to be a collection of simpler subsystems - a method (rules) to compose these pieces Functions specify only a relation between two sets of variables (input and output) Computation describe how the output variables can be derived from the value of input variable Integration Co-Simulation Constraint Verification Implementation CPU ASIC Memory

3. 软硬件划分 (HW/SW Partition) 是SOC设计中的一个重要课题 其基本原则应该遵循高速、低功耗由硬件实现; 多品种、小批量由软件对应; 处理器和专用硬件并用以提高处理速度和降低功耗。

Partitioning(划分) 方法 面向SW : 从SW to HW 满足时序要求 面向HW: 从HW to SW 降低成本 规模大小 任务级 操作级, 基本模块级 系统级 焦点问题 固定目标体系结构和未知目标体系结构 IPC 高层考虑 带有时序安排的划分 流水线 and/or 并行

Hardware - Software Architecture 一个或多个微控制器 ASICs, DSPs.... Software: concurrent tasks 调度程序集合 定制操作系统 Interfaces: Hardware 模块 Software 程序(polling, interrupt handlers, ...)

开发领域 3.1 Hardware synthesis 商业工具 抽象等级: 行为级综合: algorithmic synthesis RTL综合: VHDL, Verilog 逻辑级综合: netlist 值得考虑的问题: reuse of hardware (Core)

3.2 Software synthesis 估算困难 对于嵌入式系统来说,会有更多的限制: 简单的算法 协同任务描述 no swapping devices no stacks only polling and static variables 简单的算法 Translating FSMs to programs especially simple 协同任务描述 Problem: How do we find a linear execution order that satisfies the timing constraints? Use scheduling theory.

3.3 Interface synthesis processor and ASIC接口 synthesis of software synthesis of “glue logic” 总线接口的自动生成 PCI, VME, …… sensors and actuators接口 挑战: SoC with many cores!

All Interfaces for HW/SW Co-Design Company Name Member Product Connections Interface Cadence Products CoWare N2C Integrator HDLI Nc-Sim Mentor Graphics Detail in web station Synopsys

4. HW-SW co-simulation? 基本定义: 用软件控制硬件的仿真 目标: 把运行在一个可编程的处理器硬件上的虚弱的可 编程(or 固定)硬件子系统和仿真软件联结 In the Past: co-simulation was adopted late in the process, after hardware is deemed to be working and stable. Software developers were often left to develop code for months with severely limited ability to test. Painful integration process, design flaw and could re-spin the silicon Now: Behavioral model simulation has matured, and simulation tools in general have improved to allow better simulation throughout the development cycle Co-design tools provide project architects with a simulation environment at a very high level of abstraction.

4.1 Co-simulation Requirements 速度 在不同结构下能够快速测试输入的不同激励 交互式 快速改变结构参数 容易分析结果和调试 (graphical interface) 正确性 hardly compatible with speed and interactivity

5. 现有工具: 大学: 商业: --POLIS: U.C. --Arexys: SDL.VHDL.C 大学: 商业: --POLIS: U.C. --Arexys: SDL.VHDL.C Berkeley --Coware: C/C++ --PTOLEMY: U.C. --LavalLogic: Java to Berkeley Verilog --VULCAN: Stanford U. --Cynlib: C++ to Verilog (Hardware C) --Art, Algorithm to --CHINOOK:U. of RT: C++ to RTL Washington (VHDL) --SUPERLOG: System --COSYMA: U. of level description Braunschweig (C*)

Available tools Cadance (basic and VCC) INRIA CADP Xtensa from Tensilica VxWorks, Montavista RTOS IBM PowerPC development platform Xilinx’s FPGA Express Ptolemy, Polis environment Code Composer from TI

6. Introduction to POLIS 高级语言翻译 形式验证 系统协同仿真 设计划分 硬件综合 软件综合 接口连接执行领域

Continued 描述: FSM-based languages (Esterel, ...) 内部表示法: CFSM network Validation: high-level co-simulation FSM-based formal verification 划分: by hand, based on co-simulation estimates 时序安排: classical RT algorithms 综合: S-graph-based code synthesis for software logic synthesis for hardware Main emphasis on unbiased verifiable specification

Part Three 目前支持软硬件协同设计的工具介绍

1. 什么是SystemC? SystemC是一个开发硬件的面向对象的新型建模方法,建立在C++基础上,是为了方便系统级设计和IP交换。 System C是一个开放的标准,由13家EDA和电子行业的公司共同控制。 包括: ARM Ltd. Cadence Design Systems, Inc. CoWare Fujitsu Mentor Graphics Motorola NEC Synopsys System C的源码可以从http://www.systemc.org/网站上免费下载。

Continued CoCentric System C Compiler (Synopsys®) 可以使用System C源码来综合硬件 可以把用System C写的硬件描综合成门级网表以便IC实现或综合成一个Verilog或VHDL的RTL描述以便FPGA综合。

硬件描述能力 Processes Ports Signals Rich set of port and signal types Modules Processes Ports Signals Rich set of port and signal types Rich set of data types Clocks Cycle-based simulation Multiple abstraction levels Communication Protocols Debugging Supports Waveform Tracing

SystemC是由一些C++的类库组成

Continued 用System C开发的硬件模型可以用标准的C++编译器来编译: Unix/Solaris: bcc,gcc Windows: MSVC 经编译后形成一个可执行的应用程序,设计人员可以通过console来观察系统的行为,验证系统功能和结构.

System C的建模方法 System C #include “systemc.h” SC_MODULE(dff) { sc_in<bool> din; sc_in<bool> clock; sc_out<bool> dout; void doit(); // Member function SC_CTOR(dff) { SC_METHOD(doit); // Process sensitive_pos << clock; // Sensitize to } }; void dff::doit() { // Member function as Process body dout = din; VHDL entity dff is port ( din, clock : in bit; dout : out bit ); end dff; architecture dff of dff is begin doit : process(clock) – Sensitivity List if (clock’event and clock=‘1’) then dout <= din; end if; end process;

SystemC的建模实例

2. CADENCE VIRTUAL COMPONENT CO-DESIGN (VCC) Cadence® Virtual Component Co-design (VCC) 是第一个为IP复用所设计的工业系统级 HW/SW co-design开发平台环境。 Cadence VCC使设计师在早期设计第一代产品和相关产品时,就可以确认 HW/SW划分的临界体系结构。 Cadence VCC 为 system houses and SOC providers,通过the electronic supply chain进行交流和交换设计信息,提供必要的框架。 http://www.cadence.com/datasheets/vcc.html

Thanks The end!