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

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

3天内不再提示

为什么我写的C语言能操作到底层的硬件?

Q4MP_gh_c472c21 来源:嵌入式ARM 作者:嵌入式ARM 2020-11-16 16:34 次阅读

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

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

责任编辑:lq

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

    关注

    5990

    文章

    43904

    浏览量

    619600
  • cpu
    cpu
    +关注

    关注

    68

    文章

    10335

    浏览量

    206224
  • 软件
    +关注

    关注

    67

    文章

    4321

    浏览量

    85409

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

文章出处:【微信号:gh_c472c2199c88,微信公众号:嵌入式微处理器】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    H743用FMC扩展内存一次操作出现4次使是为什么?

    H74XI的SRAM扩展内存16位的数据位,执行一次操作,观察电平发现使了4次使,求解为什么? 如何修改?
    发表于 03-28 07:04

    STM32H7使用硬件I2C进行读写操作失败的原因?

    想使用硬件I2C实现如下操作: 写入设备地址(8位地址)——写入寄存器地址(不产生STOP)——写入设备地址(8位从地址)——读取多个寄
    发表于 03-11 08:12

    在做simulink+tasking自动代码生成时,编译找不到底层文件是为什么?

    在做simulink+tasking自动代码生成时,编译找不到底层文件,将文件添加进去后,会出现RT或NRT等重复定义
    发表于 02-20 08:06

    c语言,c++,java,python区别

    C语言、C++、Java和Python是四种常见的编程语言,各有优点和特点。 C语言: C语言是一种面向过程的编程语言。它具有
    的头像 发表于 02-05 14:11 394次阅读

    TC275操作I2C操作时陷入while循环无法退出怎么解决?

    写入TXD寄存器时,触发了SPB总线故障。 触发SPB总线故障的原因应该是手册里的,FIFO还处于接收状态时写入TXD寄存器。 最终排查发现,由于在操作I2C时已经使了CPU中断
    发表于 02-02 06:52

    自己c代码怎么转变成sigmastudio识别的图像语言

    自己c代码怎么转变成sigmastudio识别的图像语言
    发表于 11-30 08:01

    单片机C语言操作的编程实现:置位和清零

    前面介绍了C语言编程的6种位操作,分别是按位与“&”、按位“或|”、按位取反“~”、异或“^”、左移“”。按位操作的定义介绍请查看这篇文章《单片机C语言编程,位
    的头像 发表于 11-28 09:35 1618次阅读
    单片机C<b class='flag-5'>语言</b>位<b class='flag-5'>操作</b>的编程实现:置位和清零

    嵌入式C语言的结构特点

    嵌入式开发中既有底层硬件的开发又涉及上层应用的开发,即涉及系统的硬件和软件,C语言既具有汇编语言操作
    的头像 发表于 11-24 16:16 294次阅读
    嵌入式C<b class='flag-5'>语言</b>的结构特点

    C语言中链表的作用是什么?

    C语言中指针用的很少,链表、文件操作几乎没用过,所以也不能理解到底有什么作用。各位有经常在做程序时会用到这些吗。
    发表于 11-06 06:23

    C语言怎样处理json文件?

    获取到的JSON文件,怎样通过C语言进行处理,因为单片机里面只能用C语言,有没有C语言处理起来比
    发表于 11-01 06:16

    到底啥是实时操作系统呢?它到底实时不实时呢?

    到底啥是实时操作系统呢?它到底实时不实时呢? 实时操作系统(Real Time Operating System,RTOS)是一种特殊类型的操作
    的头像 发表于 10-29 16:33 651次阅读

    verilog移位操作和C语言的移位操作的异同点有哪些?

    C语言的移位操作和Verilog语言的移位操作在某些方面具有相似之处,但也存在一些显著的不同点。下面我们将通过代码示例来阐述这两种语言的移位
    的头像 发表于 08-28 09:43 370次阅读

    到底什么是硬件工程师?

    但软件和硬件又有明显的区分,至少工作内容区别很大。按照行业内描述硬件属于底层(一般称为底层硬件),软件称为上层(软件又分为:
    的头像 发表于 06-08 15:54 6389次阅读
    <b class='flag-5'>到底</b>什么是<b class='flag-5'>硬件</b>工程师?

    底层铺铜对PCB是否有帮助?到底有没有必要?

    在PCB设计的过程中,有些工程师为了节省时间不想进行表底层整板铺铜。这样做到底对不对呢?表底层铺铜对PCB来说是否有必要?
    的头像 发表于 04-18 12:45 1151次阅读

    一套支持中文C语言编程的鸿蒙Hi3861智能硬件开发套件

    由于目前学习和开发开源鸿蒙Hi3861难度比较大,整了一套支持中文C语言编程的鸿蒙Hi3861智能硬件开发套件,难度直接从专业级降到入门级,主要在开源鸿蒙开发环境基础上做了如下修改:1、使编译器支持
    发表于 04-10 20:34