当前位置:首页 > 公众号精选 > 技术让梦想更伟大
[导读]关注、星标公众号,直达精彩内容文章来源:网络现如今,软件和硬件之间的界限已经越来越模糊了,那么处于这个灰色地带的,就是固件。于是,这就分成了三类工作者:一是,软件工程师一般指做图形界面的程序员,工作内容就是写C、JAVA、Web等。二是,硬件工程师当然是指玩电路板的,工作内容就是...


文章来源:网络


现如今,软件和硬件之间的界限已经越来越模糊了,那么处于这个灰色地带的,就是固件。于是,这就分成了三类工作者:
一是,软件工程师一般指做图形界面的程序员,工作内容就是写C 、JAVA、Web等。
二是,硬件工程师当然是指玩电路板的,工作内容就是画原理图、PCB等。
三是,固件工程师也叫单片机工程师,既写代码(主要是C语言、汇编)又要画电路图。
玩单片机的人,可能会有个疑问,为什么我写的C语言能操作到底层的硬件?其实在《计算机组成原理》已经有很详细的介绍了。
我这里粗略地介绍一下,这个原理。
首先,你可以搜索一下“从零开始造电脑”,这位叫Steve的大神,就告诉你,用晶体管可以做出CPU(单片机也是CPU)。
当然,我们现在可不会落后到需要到晶体管来制造电脑。
接下来,你可以看一部叫《乔布斯》的电影,剧中就给你展示苹果公司的第一台计算机。
嘿嘿,看到那些黑色的芯片没有?还有两个大大的变压器。这说明了在大学玩单片机的时代,就相当于回到苹果公司的初始时期!是不是很激动人心?
其实你可以用74系列的逻辑IC、单片机等,来搭建一个属于自己的计算机。这就是说人们把若干个晶体管集成为一块74系列的IC,如果集成度更高呢?那就是手机或者台式机用的多核CPU了。
好,介绍了这些古董之后,就让你有个认识,计算机本质上是N个晶体管的组合,也是数字逻辑芯片的组合,更高级的,就是一块数模混合的芯片,具体形式是由你的工艺决定的。现在回到正题,介绍一下数电的基础知识。
因为CPU主要功能是计算,也就是可以直接运用数学知识来解决问题,这里就举个例子介绍一下,CPU如何计算加法,也就是用数电里的门电路搭一个加法器。



怎样用晶体管搭这些与、或、非门就不说了,不懂的,可以翻书。上图就告诉你,可以用这些门电路搭一个加法器。
怎样输入Ai=0,Bi=1,Ci=0?用74系列的IC的话,可以直接把Ai,Ci接GND,Bi接VCC,就实现加法了。而在CPU内部也是一样可以这样做的,但是CPU可没那么死板,只算常数的加法。



上图中,蓝色箭头指向的1,就是接VCC的,而红色箭头,就是接GND。
在CPU内部,还有ROM,它可以把你要计算的加数和被加数存进去(ROM输出的高低电平,跟你接GND和VCC是一样的效果),而结果则存在寄存器(先暂存,以备后面使用)。
现在有个问题,如果加完之后还要计算乘法(在信号处理领域的卷积运算的核心单元就是乘加器),怎么办?谁来自动完成这个动作?幸好,CPU里面有个叫ALU(算术逻辑单元)来处理这件事情。



这里的控制单元,就把ROM里面的数据取出来,再用选择器,来调用加法器和乘法器,最终把结果存到寄存器中。
如果ROM里面只存数据,那是无法让控制单元知道,你要执行加法还是乘法,要解决这个问题,就需要在ROM里面再划分一个区域,存放指令码。
这个指令码,跟数据是一样,都是0、1的二进制数,只是用途不同,所以起了不同的名字。
其实这个指令码,对应在单片机里面的汇编语言,就是操作码(如:MOV);而操作数就是数据(如:01H)。具体的,可以看看单片机的教材。
根据指令码的设计方法来分,有四种,分别是CISC、RISC、VLIW、TTA,具体区别可以看计算机组成原理。
而PC(程序计数器)就是控制ROM的地址,现在你要知道PC是不能出错的,一旦出错,就意味着单片机不按照你的代码来工作。
现在,我在8位的CPU的ROM里面,第一个地址存了0x03这个指令码来代表加法,而在第二、三个地址存了加数和被加数,然后在第四个地址存了0x05代表乘法,在第五、六个地址存了乘数和被乘数。
那么,按照一定的规则来设计控制单元(这个规则可以自己定义的),它就知道0x03是要执行加法。
那么这个规则如何设计?最简单的,就是用与门了,然后输出一个使能信号,让加法器工作,就跟上面的74LS160差不多。
但是CPU可没那么简陋,它可以使用状态机、流水线等,来控制这些基本单元(如:加法器、乘法器),如下图所示:



说到这里,你至少应该知道,我们只要改变ROM的内容,就可以操作CPU内部的ALU,从而操作CPU的各个硬件单元了。
下面给出相对完整一点的ALU内部结构图:



ROM的内容本质上是一些电荷量(电容上有、无电荷,代表二进制的1和0),也就是固件、软件工程师写的代码。而硬件,就是由晶体管搭建的数字、模拟电路(如:单片机内部的比较器、ADC等)。
所以硬件是物理器件,不容易更改;而ROM的内容完全可以用烧录器就轻松改变它,修改成本非常低,而且很灵活。
在这里,你很难表述,这些电荷量是软件还是硬件,但是CPU的这种结构,导致了两种不同类型的工作者,我们称他们为软件工程师和硬件工程师。而单片机程序员写的代码,跟硬件密切相关,而且一旦完成之后,很少需要修改的(不像软件工程师修改的那么频繁),我们称之为固件
来源:网络版权归原作者所有,如有侵权,请联系删除。‧‧‧‧‧‧‧‧‧‧‧‧‧‧‧‧  END  ‧‧‧‧‧‧‧‧‧‧‧‧‧‧‧‧

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

一般从事互联网工作,尤其是软件类岗位,通常加班现象都是比较严重的。那么,做硬件的就没有加班了吗?

关键字: 互联网 程序员 工程师

麦格纳(MAGNA)正在进行一项1.2亿美元的投资,在印度班加罗尔建立和运营一座全新工程中心,旨在为出行电动化提供支持。该设施占地约2.2万平方米,预计将于2023年第一季度开业,届时该中心将聘请众多经验丰富的工程师和技...

关键字: 工程师 仿真 电动汽车 软件

深圳2022年9月26日 /美通社/ -- 9月24日,知行「科技X商业」研习院在深圳举行了2022级科创大本营开学典礼。参与典礼发言环节的嘉宾包括XbotPark联合创始人李泽湘、深圳天使投资引导基金董事长姚小雄以及往...

关键字: 创始人 半导体 工程师 TI

荷兰ASML公司 (全称: Advanced Semiconductor Material Lithography,该全称已经不作为公司标识使用,公司的注册标识为ASML Holding N.V),中文名称为阿斯麦尔(中...

关键字: ASML 工程师 芯片

(全球TMT2022年9月20日讯)9月19日,华为全联接大会2022在泰国开幕,以"创新无限,一切皆服务"为主题的华为云峰会成功举办,华为云亚太地区部总裁曾兴云、华为云首席产品官方国伟以及多位客户伙伴发表主旨演讲。会...

关键字: 并联 华为云 数字化 工程师

(全球TMT2022年9月16日讯)今日要点:腾讯游戏海外投资额达千亿元;阿斯麦今年将在台湾招募1100名工程师;荣耀X40发布售价1499元起;华为云未来3年将支持10000家初创企业。 腾讯游戏海外投...

关键字: 腾讯 华为云 荣耀 工程师

以前都是等着,家里电器坏了赶紧拆解一下,这回实在是等不及了,找个便宜的下手吧。这个遥控器用了好多年,感觉还是不错,起码电池挺禁用的。古人云,三人行必有我师焉。那么对于每一个设备,也都有我们可以学习的地方。

关键字: 嵌入式 工程师

福建莆田2022年9月1日 /美通社/ -- 8月30日,武大靖携手央视网共同走进三棵树醉美园区,与央视网主持人常婷、黄鹤,一起开启“寻绿之旅”,从绿色理念、绿色园区、绿色产品、绿色生产、绿色服务,看三棵树用绿色涂料涂刷...

关键字: 智能化 工程师 调试 研发中心

据悉,苹果公司前工程师张小浪(Xiaolang Zhang)在加州圣何塞联邦法院就跳槽小鹏汽车前涉嫌窃取苹果汽车部门商业秘密案进行了刑事指控并认罪。之前,张小浪被苹果指控在跳槽小鹏汽车前窃取了苹果的自动驾驶部门的商业机密...

关键字: 小鹏汽车 苹果 工程师 自动驾驶

北京2022年8月16日 /美通社/ -- "一只南美洲亚马逊河流域热带雨林中的蝴蝶,偶尔扇动几下翅膀,可以在两周以后引起美国得克萨斯州的一场龙卷风。" -- 这便是著名的"蝴蝶效...

关键字: 噪音 读写 工程师 音频

技术让梦想更伟大

257 篇文章

关注

发布文章

编辑精选

技术子站

关闭