0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

软件跟硬件之间的灰色地带:固件

GReq_mcu168 来源:玩转单片机 作者:玩转单片机 2020-10-13 17:39 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

软件跟硬件之间的界限已经越来越模糊了,那么处于这个灰色地带的,就是固件了。这就分成三类工作者。

1、软件工程师一般指做图形界面的程序员,工作内容就是写C++JAVA、Web等。 2、硬件工程师当然是指玩电路板的,工作内容就是画原理图、PCB等。 3、固件工程师也叫单片机工程师,既写代码(主要是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的这种结构,导致了两种不同类型的工作者,我们称他们为软件工程师和硬件工程师。而单片机程序员写的代码,跟硬件密切相关,而且一旦完成之后,很少需要修改的(不像软件工程师修改的那么频繁),我们称之为固件。

责任编辑:xj

原文标题:软硬件之间其实还有一个固件! 你知道吗?

文章出处:【微信公众号:玩转单片机】欢迎添加关注!文章转载请注明出处。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 硬件
    +关注

    关注

    13

    文章

    3692

    浏览量

    69261
  • 软件
    +关注

    关注

    69

    文章

    5395

    浏览量

    92112
  • 固件
    +关注

    关注

    11

    文章

    576

    浏览量

    25509

原文标题:软硬件之间其实还有一个固件! 你知道吗?

文章出处:【微信号:mcu168,微信公众号:硬件攻城狮】欢迎添加关注!文章转载请注明出处。

收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    探索TLE4999线性霍尔评估套件:从硬件软件的全方位解析

    软件使用,为你详细介绍如何充分发挥这个套件的功能。 文件下载: Infineon Technologies TLE4999X程序套件.pdf 一、硬件组成 PGSISI盒 PGSISI盒是整个评估套件的核心枢纽,它通过USB接口与计算机相连,同时还需要连接电源,为传感器
    的头像 发表于 12-18 15:45 977次阅读

    固件版本错配:一个让老工程师都栽过跟头的“低级错误”

    :使用“final_v2_new.hex”等模糊命名,无法从文件名追溯其对应的硬件基准与软件变更。2.变更同步失效:硬件工程师进行设计变更后,未通过正式流程(如变更通知单)更新受影响的固件
    发表于 12-18 10:31

    智能双卡设计实战指南:硬件电路与软件配置详解!

    在智能双卡设计中,硬件电路的可靠性与软件配置的精准性直接决定双卡功能的稳定性。本文基于实际项目经验,详细拆解硬件设计中SIM卡供电电路、时钟信号匹配及卡槽复用设计的实现细节,并同步讲解软件
    的头像 发表于 12-16 15:13 750次阅读
    智能双卡设计实战指南:<b class='flag-5'>硬件</b>电路与<b class='flag-5'>软件</b>配置详解!

    ADC模数转换实战:硬件设计与软件开发要点指南!

    为实现高精度、高稳定性的ADC模数转换,硬件软件设计均需遵循特定原则。硬件层面需优化信号调理、参考电压及抗干扰设计;软件层面需合理配置采样参数、实现数据滤波及异常处理。本文将结合实际
    的头像 发表于 12-16 13:25 652次阅读
    ADC模数转换实战:<b class='flag-5'>硬件</b>设计与<b class='flag-5'>软件</b>开发要点指南!

    嵌入式系统profinet转devicenet固件硬件接口的连接案例

    与货物信息采集。核心需求是基于网关的嵌入式固件,实现硬件接口的适配与数据的高效处理。 Profinet从站(网关)与西门子PLC的博图组态步骤 硬件接口与固件版本确认:打开TIAPor
    的头像 发表于 11-18 14:11 1204次阅读
    嵌入式系统profinet转devicenet<b class='flag-5'>固件</b>与<b class='flag-5'>硬件</b>接口的连接案例

    广凌智慧教室建设内容:硬件软件介绍

    广凌科技(广凌股份)凭借“硬件+平台+数据”的深度融合,推出智慧教室整体解决方案,全面覆盖智慧教室建设的硬件配置、软件平台、数据驱动及场景适配需求,一起来看看广凌智慧教室建设需要搭建什么硬件
    的头像 发表于 11-11 16:17 1573次阅读
    广凌智慧教室建设内容:<b class='flag-5'>硬件</b>与<b class='flag-5'>软件</b>介绍

    SGTOOLS为什么这些功能是灰色的,没法用?

    SGTOOLS功能栏别的都可以用,为什么上面这几个都是灰色的不能用?是起什么特殊用途的吗? 我想做一个可以滑动的轨迹条,可以做得到吗?
    发表于 10-13 12:05

    为什么studio 仿真 restart 按钮是灰色

    版本是2.2.9当前是最新版 ,仿真器 stlink , 仿真时restart按钮是灰色,不能使用
    发表于 10-09 07:38

    硬件融合拼接器与软件融合拼接的区别?

    硬件融合拼接器和软件融合拼接是两种不同的图像拼接技术,它们在实现方式、效果和应用场景等方面存在一些区别。 1、实现方式 硬件融合拼接器通常是通过硬件设备来实现图像的拼接,这种设备通常由
    的头像 发表于 09-28 14:33 714次阅读

    硬件为DC890B+DC2222A-A,PSCOPE软件闪退的原因?如何解决?

    软件,并给硬件系统正确供电,PSCOPE 软件 闪退,换不同电脑情况一样。 对PSCOPE软件闪退录屏幕,可以看 PSCOPE
    发表于 07-11 08:16

    芯盾时代解决方案助力企业阻断数据泄密风险

    与内部员工相比,外包人员的管理存在天然的“灰色地带”,其数据泄密风险更具隐蔽性和突发性。
    的头像 发表于 07-07 14:49 1386次阅读

    求助,CYBT-243053-02 EZ固件问题求解

    我们正在尝试将 CYBT-243053-02 作为我们新硬件的潜在蓝牙模块,我们对 CYBT-243053-02 的 EZ 固件和一般模块几乎没有疑问. 1)。 我们一直在尝试通过 Cypress
    发表于 07-04 07:50

    请问EZ-Serial固件是否使用任何OSS(开源软件)库或软件

    EZ-Serial 固件是否使用任何 OSS(开源软件)库或软件
    发表于 07-02 08:14

    Vector MICROSAR HSM固件通过ISO/SAE 21434认证

    Vector针对汽车ECU硬件安全模块(HSM)的固件产品——MICROSAR HSM,已正式通过 ISO/SAE 21434认证。作为一家国际软件供应商,此次认证彰显Vector致力于提供符合最高国际标准信息安全解决方案的承诺
    的头像 发表于 06-12 17:33 1710次阅读
    Vector MICROSAR HSM<b class='flag-5'>固件</b>通过ISO/SAE 21434认证

    CYPD5235的CC Pin功能异常,还可能会什么有关?

    /VSYS/VDDD/V5V_P1的电都是正常的。 请教问题: 1。CYPD5235的CC Pin功能异常,还可能会什么有关? 2。去掉的MP8859,会影响CYPD5235的软件代码执行吗?如果会
    发表于 05-30 07:04