介绍软件编程思维与硬件建模思维的不同与相似之处。
 
 
1. 软件编程思维
 
编程,意指编写程序;
程序,即过程的顺序;
 
软件程序具有天然的串行特性:
a. 汇编级别需要等前一条指令执行完成,才能执行下一条指令;
b. 语言级别需要等前一条语句执行完成,才能执行下一条语句;
c. 语言级别需要等前一个函数调用完成,才能执行下一条语句;
 
原因在于软件程序最终都会被编译为一条条汇编指令,
汇编指令执行的载体是CPU核,而在单个CPU核中汇编指令的执行是串行的;
 
CPU核是活的,而软件程序是CPU核执行的指令。
 
 
2. 硬件建模思维
 
通电之后,硬件中的每一个模块都是活的,
每个模块都同时接收输入、执行处理、产生输出。
天然具有并行的特性。
 
 
3. 对比
 
硬件各个模块都是活的,建模时需要谨慎处理各个模块的状态。
软件编程天然的串行特性,使得软件编程思维更易于使用和理解。
 
 
4. 软件建模:多线程软件模型
 
软件编程中有没有并行性需要考虑呢?
有,那就是多线程编程。
 
多线程编程假设每个线程都有可能同时并行执行,需要考虑:
a. 每个线程的任务;
b. 线程之间的通信方式;
c. 线程之间的同步关系;
 
其过程如同软件建模,建立各个线程及其交互关系的模型。
 
 
5. 众核
 
在多线程软件模型中,每个线程都是活的,如同硬件模型中的每个模块。
但是线程只是一个抽象的概念,如果要让每一个线程真正的同时活着,需要为每一个线程分配一个CPU核。
 
假设可以为每个线程分配一个CPU核,这个多线程软件模型和硬件模型之间,还有哪些不同呢?
 
1) CPU核是一个完备的通用核,而硬件模块只实现特定的处理逻辑,可以认为是一个专用核;
2) 线程之间的通信或使用互斥锁或使用信号量,而硬件模块之间通信则是电信号直通、Ready/Valid简单控制接口、或者是FIFO传递数据等;
 
 
6. 裁剪
 
虽然CPU核是通用核,但是线程的任务是有限的逻辑,可以根据线程的任务,将其所需要的CPU核进行裁剪,所得即为硬件模块。
 
线程之间的通信可以在软件模型下,建立一个仿真层以提供与硬件模块间一致的同步、通信行为。
 
在这些基础上,软件模型与硬件模型是否可以统一了呢?
 
 
7. 统一:软件建模与硬件建模
 
在线程的层次上,可以。
 
然而线程的任务并非一个简单的输入、处理、输出的函数,而是可以再分为多个模块,每个模块有其独立的功能。
 
这也简单,那就把线程内部的每一个具有独立功能的模块,都转换为一个线程。
让这些模块在线程间通过线程同步和通信机制交互,而非在线程内部利用软件编程天然的串行特性,通过函数调用交互。
 
 
至此,基于仿真层,把软件程序中每一个独立的子功能拆分成为一个线程,
构建而成的多线程软件模型,与硬件模型可以统一在一起了。
 
PS. 这就是SystemC的系统级建模(System-level modeling)的思想。
 
 
8. 最终目标是硬件模型
 
无论使用何种思维、何种方法,最终目标都是要完成硬件模型的构建。
 
1) 直接构建硬件模型
 
Verilog/VHDL等直接通过硬件思维,完成硬件模型的构建。
 
2) Generator: 提高构建层次
 
使用硬件思维,构建硬件模型;
然后在这个模型层的基础上,添加一个构建层;
 
只要落实到模型层,构建层可以使用任何方法,拥有无穷无尽的自由。
 
Verilog的generate,和Chisel的circuit generator是这一类。
 
3) Vivado HLS:思维转换
 
Vivado HLS使用软件编程思维实现算法,然后把每个函数转换为硬件模块。
其中存在一个思维转换。
 
4) SystemC METHOD实现: 思维转换
 
SystemC中的METHOD,在SystemC的语汇中是一个Process,对应着多线程软件模型中的一个线程。
其实现使用的是软件思维,依赖于软件思维的串行特性,所以也需要进行思维转换。
 
5) SystemC系统级建模:模型统一
 
SystemC系统级建模实现了软件建模与硬件建模的统一。
既可以认为建立的是软件模型,也可以认为建立的是硬件模型。
无需进行思维转换。
 
 
9. 备注
 
以下内容这里没有讨论:
a. 硬件通信的速度;
b. 硬件控制信号的响应时间较短,响应很及时;
c. 硬件模块中顺序逻辑的长度不能超过一个时钟周期;
 
 

hdl - 软件编程与硬件建模的更多相关文章

  1. 中兴软件编程规范C/C++

    Q/ZX 深圳市中兴通讯股份有限公司企业标准 (设计技术标准) Q/ZX 04.302.1–2003      软件编程规范C/C++                               20 ...

  2. Jlink 软件断点和硬件断点

    调试2440 RAM拷贝至SDRAM遇到的问题 汇编代码主要是初始化一些寄存器,关狗,初始化时钟,初始化存储管理器以便访问内存,然后将SoC上4k RAM数据拷贝至SDRAM,然后在SRAM里面运行, ...

  3. Atitit.互联网 软件编程 数据库方面 架构 大牛 牛人 attilax总结

    Atitit.互联网 软件编程 数据库方面 架构 大牛 牛人 attilax总结 Coolshell 称号.理论与c++ 阮一峰:: 理论高手与js高手 王银:理论高手 赵劼,网名老赵,c#高手 与理 ...

  4. php用什么软件编程

    准备好好学习学习PHP了吗?那么你首先应该考虑用什么开发工具(IDE).市面上有很多这类工具,收费的有,免费的也有,选择起来并不轻松. 如果你说PHP编程用基础的文本编辑软件就可以了,比如用记事本.是 ...

  5. AI:用软件逻辑做硬件爆款

    "我们的野心不止那么一点点." 百度集团副总裁.百度智能生活事业群组(SLG)总经理.小度CEO景鲲曾多次对外表达过这样的观点. 在2021年百度世界大会上,小度又一口气发布了四款 ...

  6. 联盛德 HLK-W806 (四): 软件SPI和硬件SPI驱动ST7735液晶LCD

    目录 联盛德 HLK-W806 (一): Ubuntu20.04下的开发环境配置, 编译和烧录说明 联盛德 HLK-W806 (二): Win10下的开发环境配置, 编译和烧录说明 联盛德 HLK-W ...

  7. 联盛德 HLK-W806 (九): 软件SPI和硬件SPI驱动ST7789V液晶LCD

    目录 联盛德 HLK-W806 (一): Ubuntu20.04下的开发环境配置, 编译和烧录说明 联盛德 HLK-W806 (二): Win10下的开发环境配置, 编译和烧录说明 联盛德 HLK-W ...

  8. 联盛德 HLK-W806 (十一): 软件SPI和硬件SPI驱动ST7567液晶LCD

    目录 联盛德 HLK-W806 (一): Ubuntu20.04下的开发环境配置, 编译和烧录说明 联盛德 HLK-W806 (二): Win10下的开发环境配置, 编译和烧录说明 联盛德 HLK-W ...

  9. [py]软件编程知识骨架+py常见数据结构

    认识算法的重要性 - 遇到问题? 学完语言,接到需求,没思路? 1.学会了语言,能读懂别人的代码, 但是自己没解决问题的能力,不能够把实际问题转换为代码,自己写出来.(这是只是学会一门语言的后果),不 ...

随机推荐

  1. Uncaught DOMException: Failed to set the 'value' property on 'HTMLInputElement': This input element accepts a filename, which may only be programmatically set to the empty string.

    今天上传图片遇到这个报错 百度了下,网上说是input标签type=file所以导致的问题,可是我的type=hidden 解决办法: 把上面的代码改成如下问题就解决了

  2. http协议跟tcp协议的简单理解

    在说明这两个协议之前,我们先简单说一下网络的分层. 1)应用层 支持网络应用,应用协议仅仅是网络应用的一个组成部分,运行在不同主机上的进程则使用应用层协议进行通信.主要的协议有:http.ftp.te ...

  3. Java语言简介、基础组成、封装、继承、多态、抽象类、内部类、接口

    目录 Java简介 Java语言基础组成 面向对象 对象 封装 构造函数 this关键字 static(静态关键字) 主函数 静态什么时候用呢? 面向对象(数组工具对象建立) 设计模式 继承 成员变量 ...

  4. python语法学习第六天--集合

    集合(set)是一个无序的不重复元素序列. 可以使用大括号 { } 或者 set() 函数创建集合,注意:创建一个空集合必须用 set() 而不是 { },因为 { } 是用来创建一个空字典. 创建格 ...

  5. 数据库-第八章 数据库编程-8.1 嵌入式SQL

    嵌入式SQL 一.嵌入式SQL的处理过程 1.嵌入式SQL语句的基本格式 2.嵌入式SQL的处理过程 3.主语言访问数据库的基本步骤 ⅰ建立数据库连接 ⅱ定义必要的主变量和数据通信区 ⅲ访问数据库并返 ...

  6. 基于 abp vNext 和 .NET Core 开发博客项目

    项目介绍 此个人博客项目底层基于 ABP Framework (不完全依赖)搭建项目 和免费开源跨平台的 .NET Core 3.1 开发,可作为 .NET Core 入门项目进行学习,支持各种主流数 ...

  7. android 压缩图片大小,防止OOM

    android开发中,图片的处理是非常普遍的,经常是需要将用户选择的图片上传到服务器,但是现在手机的分辨率越来越好了,随便一张照片都是2M或以上,如果直接显示到ImageView中,是会出现OOM的, ...

  8. (mysql)数据库笔记

    一.数据库的特点: a.实现数据共享  b.采用特定的数据类型. c.具有较高的数据独立性 d.具有统一的数据控制功能. 二.mysql的优势: a.速度:运行速度快 b.价格:mysql对多数个人来 ...

  9. elasticsearch 小总结

    elasticsearch 小总结 0. 起因 距离初次写关于es的文章 https://blog.csdn.net/aca_jingru/article/details/44488703 已经过去4 ...

  10. 「雕爷学编程」Arduino动手做(28)——RGB全彩LED模块

    37款传感器与模块的提法,在网络上广泛流传,其实Arduino能够兼容的传感器模块肯定是不止37种的.鉴于本人手头积累了一些传感器和模块,依照实践出真知(一定要动手做)的理念,以学习和交流为目的,这里 ...