“开源硬件”:描述如今基于嵌入式产品平台、基于硬件描述语言、以软件技术为主的智能硬件的开发模式。
一类是由用户板进化出的可二次开发的板级开源硬件(早期以树莓派为代表);
另一类是开源硬件描述语言(以Chisel为代表源代码开放的开源硬件);
还有一类是开源操作系统中的开源硬件数据结构(如ARM Device Tree)。
硬件描述语言HDL是一种用形式化方法描述数字电路和系统的语言。
硬件描述语言发展至今已有20多年的历史,它将硬件设计软件化,通过EDA工具(电子设计自动化)进行仿真验证,最终通过微电子的ASIC手段或半定制的FPGA来实现一个真实的硬件系统。这是一种非主流电子工程师的非传统硬件系统设计方法,成功地应用于硬件设计的各个阶段,如建模、仿真、验证与数字化模块的综合等。
随着系统级FPGA以及系统芯片的出现,软硬件协调设计和系统设计变得越来越重要。传统意义上的硬件设计越来越倾向于系统设计和软件设计结合。硬件描述语言为适应新的情况,迅速发展,出现了很多新的硬件描述语言。硬件描述语言从一开始就是一种用软件工具、在软件方法基础上实现的电路系统设计方法。
Chisel是加州大学伯克利分校研究人员设计并发布的一种新的开源硬件设计语言。他们认为现有的硬件描述语言VHDL、Verilog HDL等最初设计的目的是用来仿真的,所以有很多不可综合的语法,此外,VHDL、Verilog HDL缺少目前高级语言具备的一些特性,比如:对象、继承等,于是设计了Chisel,并将其开源。
Chisel建立在Scala语言之上,可以支持高级硬件设计。用户使用Chisel时,以编写Scala程序的方式来设计硬件电路。采用Chisel设计的电路,经过编译可以得到FPGA、ASIC的Verilog HDL的相关代码。目前国内外已有人使用Chisel语言成功地实现了多种开源处理器。有多个开源项目使用Chisel作为开发语言,包括:采用RISC-V架构的开源标量处理器Rocket、开源乱序执行处理器BOOM(Berkeley Out-of-Order Machine)等。
此外,Chisel的开源特性,也有助于用户了解硬件设计语言的内部实现机理,并在此基础上进行特定的优化与改进。
设备树是嵌入式操作系统中的一种开源硬件数据结构,是嵌入式操作系统中板级支持包(Board Support Package,BSP)的华丽转身,其源头是PowerPC的Device Tree技术。目前,最著名的是ARM Linux中的扁平设备树FDT(Flattened Device Tree)。
Device Tree是一种描述硬件的数据结构,基本上是一个描述电路板上CPU、总线、设备组成的树形结构,由一系列的结点(node)和属性(property)组成,结点本身可包含子结点,可用来描述原先kernel中的大量板级细节与硬件细节,直接透过它传递给Linux。Bootloader会将这棵树传递给内核,然后内核可以识别这棵树,并根据它展开出Linux内核中的众多设备,而这些设备用到的内存、IRQ等资源,也被传递给了内核,内核会将这些资源绑定给展开的相应设备。使用FDT后,Linux内核可以直接通过FDT获取硬件的细节信息。
由根结点、子结点、叶结点形成了硬件相关的树形结构,树结构将在节点之间创建父子关系,此父子关系是体系结构无关性的关键。当叶驱动程序或总线结点驱动程序本质上需要依赖于体系结构的服务时,该驱动程序会请求其父级节点提供该服务。采用此方法,不管计算机或处理器的体系结构是什么,驱动程序都可以正常运行。使用FDT后,Linux内核可以直接通过FDT获取硬件的细节信息,这使得ARM Linux内核中的冗余编码大大减少,同时也使得用一个内核镜像去引导同一类ARM芯片集的硬件平台成为可能。
2017年《单片机与嵌入式系统应用》第3期罗名驹等人的“扁平设备树FDT在ARM Linux中的应用研究”详细地介绍了ARM Linux中的FDT,以及如何通过FDT获取板级硬件的细节信息。
[1]: 什么是开源硬件? - https://opensource.com/resources/what-open-hardware?src=open_hardware_resources_menu
[2]: 什么是树莓派? - https://opensource.com/resources/what-raspberry-pi?src=open_hardware_resources_menu
[3]: 什么是 Arduino? - https://opensource.com/resources/what-arduino?src=open_hardware_resources_menu
[4]: Arduino - https://opensource.com/node/20751
[5]: BeagleBone - https://opensource.com/node/35211
[6]: C.H.I.P. - https://opensource.com/node/24891
[7]: Fritzing - http://fritzing.org/home/
[8]: gEDA - http://www.geda-project.org/
[9]: KiCad - http://kicad-pcb.org/
[10]: OSH Park - https://oshpark.com/
[11]: PCB Shopper - http://pcbshopper.com/
[12]: Flickr - https://www.flickr.com/photos/thomashawk/3048157616/in/photolist-5DmB4E-BzrZ4-5aUXCN-nvBWYa-qbkwAq-fEFeDm-fuZxgC-dufA8D-oi8Npd-b6FiBp-7ChGA3-aSn7xK-7NXMyh-a9bQQr-5NG9W7-agCY7E-4QD9zm-7HLTtj-4uCiHy-bYUUtG
[13]: CC BY-NC 2.0 - https://creativecommons.org/licenses/by-nc/2.0/
[14]: John 'Warthog9' Hawley - https://opensource.com/article/17/5/8-ways-get-started-open-source-hardware