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

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

3天内不再提示

带大家详细认识一下固件是干什么的

STM32嵌入式开发 来源:EDA365电子论坛 作者:EDA365电子论坛 2021-10-13 10:28 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

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

一是,软件工程师一般指做图形界面的程序员,工作内容就是写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的这种结构,导致了两种不同类型的工作者,我们称他们为软件工程师和硬件工程师。而单片机程序员写的代码,跟硬件密切相关,而且一旦完成之后,很少需要修改的(不像软件工程师修改的那么频繁),我们称之为固件。

编辑:jq

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

    关注

    4417

    文章

    23959

    浏览量

    426034
  • cpu
    cpu
    +关注

    关注

    68

    文章

    11326

    浏览量

    225837
  • ROM
    ROM
    +关注

    关注

    4

    文章

    579

    浏览量

    89364
  • 软件
    +关注

    关注

    69

    文章

    5351

    浏览量

    91867
  • C++
    C++
    +关注

    关注

    22

    文章

    2127

    浏览量

    77358

原文标题:认识固件是干什么的?

文章出处:【微信号:c-stm32,微信公众号:STM32嵌入式开发】欢迎添加关注!文章转载请注明出处。

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

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    【飞凌嵌入式RV1126B开发板试用体验】初识飞凌嵌入式RV1126B开发板试

    这几天刚收到飞凌嵌入式RV1126B开发板,带大家认识一下这块开发板,收到的开发板如下图。 开发板有主板和核心板组成,开发板布局非常合理,元件排列的整齐漂亮,做工非常的精致,接口也非常丰富,接口
    发表于 04-13 17:27

    认识一下广州爱智德工控体机的整机结构

    爱智德工控体机的结构与选型秘诀:从坚固耐用的金属外壳到灵敏的触摸屏,再到高性能主板和稳定电源,了解这些关键部件如何适应不同工业场景,助您做出精准选择。
    的头像 发表于 03-24 17:11 656次阅读

    不间断电源是干什么用的?优比施文讲透

    ……这些令人懊恼甚至带来损失的瞬间,都与个词有关——电力中断。而不间断电源,正是为解决这些问题而生。今天,优比施电源用最通俗易懂的方式,为您讲清楚不间断电源到底是干什
    的头像 发表于 03-03 08:48 305次阅读
    不间断电源是<b class='flag-5'>干什么</b>用的?优比施<b class='flag-5'>一</b>文讲透

    lora无线数传电台能干什么?5KM数据传输,代替有线485

    双向通信,是工业物联网、智慧农业、智慧城市等场景的“无线串口线”。 、核心功能(能干什么) 1. 基础通信能力 - 点对点透明传输:两个电台配对,串口数据原样无线转发,替代长距离RS485/232线缆,无需改协议。 - 点对多点/主从组网:
    的头像 发表于 02-28 16:37 742次阅读

    保姆级教程!RK3588 Linux6.1 固件签名完整实现方案(不含rootfs)

    内核)上实操固件签名时,踩了不少官方文档的坑,经过反复调试终于打通全流程。今天就把这份实战经验整理成保姆级教程,从配置到问题排查,步步带大家搞定 RK3588 的固件签名!
    的头像 发表于 01-14 17:21 2259次阅读
    保姆级教程!RK3588 Linux6.1 <b class='flag-5'>固件</b>签名完整实现方案(不含rootfs)

    划片机是干什么用的

    划片机是干什么用的?在晶圆加工场景中,它也常被称为晶圆切割机,是半导体制造后道工艺中的核心设备,其核心用途是将完成前道电路制造(如光刻、刻蚀、沉积等)的整片晶圆,沿预设的空白切割道
    的头像 发表于 01-12 16:33 815次阅读
    划片机是<b class='flag-5'>干什么</b>用的

    能否详细介绍一下MOSFET在电机控制中的作用是什么?

    能否详细介绍一下MOSFET在电机控制中的作用?
    发表于 12-22 13:11

    请教大家一下DP致性测试问题

    请教大家一下,DP的Vbios中已经固定了预加重和Swing的值,DP的TX信号致性测试项中Non Pre-Emphasis Level Test(Swing2/Swing0)-PLTPAT,这个测试项意思是Swing2与Sw
    发表于 11-12 15:57

    闪灯程序的构建与调试

    在上篇文章中我们成功了搭建了环境,那么接下来就用闪灯程序来认识一下编译和调试工具吧!
    的头像 发表于 11-05 14:52 4434次阅读
    闪灯程序的构建与调试

    RT1180 FlexSPI Follower模块简介

    该模块在外部SPI主设备和RT1180芯片之间架起了座通信的桥梁。今天就来正式认识一下吧!
    的头像 发表于 10-07 11:09 1652次阅读
    RT1180 FlexSPI Follower模块简介

    大家帮忙看一下这个电路图哪里有问题??谢谢

    大家帮忙看一下这个电路哪里有问题
    发表于 09-26 15:56

    加固计算机是用来干什么的

    加固计算机是种专门为复杂环境和特殊行业应用设计的高性能设备。它不仅具备常规电脑的数据处理和运算功能,更在结构设计、防护等级和硬件配置方面做了全面优化。例如,它的外壳通常采用镁铝合金或高强度复合材料
    的头像 发表于 08-22 09:55 656次阅读

    大家都在用什么AI软件?有没有好用的免费的AI软件推荐一下

    大家都在用什么AI软件?有没有好用的免费的AI软件推荐一下?直接发个安装包,谢谢。比如deepseek、Chatgpt、豆包、阿里AI、百度AI、腾讯AI,哪个能用、好用?没找到安装包,都是在线搜索?想要Windows版本和IOS版本或者安卓版本
    发表于 07-09 18:30

    “碰一下”支付终端应用在酒店:智能无卡入住与客房控制

    “碰一下”支付终端和“碰一下”支付机具今年已在各种餐饮零售门店推广应用。就连天波小编家附近的村口小超市也用上了“碰一下”支付终端。近日,卤味龙头企业绝味食品宣布,全国门店将接入“支付宝碰一下
    的头像 发表于 07-04 09:57 978次阅读
    “碰<b class='flag-5'>一下</b>”支付终端应用在酒店:智能无卡入住与客房控制

    钳形表是干什么用的?点开看看就知道了

    在电工领域和电气设备维护中,难免会用到各种各样的工具,其中之就是钳形表。对于普通人而言,可能都不知道钳形表到底是什么。更不知道它的用处。实际上,钳形表的作用很大,今天就来带大家探究竟。钳形表,从
    发表于 05-06 15:34