单片机中都有FLASH还需要EEROM吗?

单片机中有FLASH为啥还需要EEROM?

///插播一条:我自己在今年年初录制了一套还比较系统的入门单片机教程,想要的同学找我拿就行了免費的,私信我就可以哦~点我头像黑色字体加我地球呺也能领取哦。最近比较闲,带做毕设,带学生参加省级或以上比赛///单片机中都有FLASH还需要EEROM吗?_第1张图片单片机中都有FLASH还需要EEROM吗?_第2张图片

既然打算学,基础的东西元件的得知道是什么,这样写代码的时候才能知道自己在干什么!

ROM和Flash断电后都能储存数据,RAM则不能

其实闪存(flash)是ROM的一种它的全名---FLASH EEPROM

EEPROM---电可擦除可编程只读存储器

Flash

Flash是⼀种⾮易失性存储器,即断电之后数据也不会丢失,这个存储器的特点是不能以字节的方式擦除信息,它按扇区(block)操作

32的芯片有些参数说 Flash的大小256k,64k,512k,它可以用于存储代码,也可以用于存储数据。

我们编译好的程序就放在这个地方。内核通过 ICode总线来取里面的指令。

也存放常量  const修饰的

SRAM

静态随机存取存储器(SRAM)是随机存取存储器的⼀种。所谓的“静态”,是指这种存储器只要保持通电,⾥⾯储存的数据就可以恒常保持。

相对之下,动态随机存取存储器(DRAM)⾥⾯所储存的数据就需要周期性地更新

程序的变量,堆栈等的开销都是基于内部的SRAM。内核通过DCode总线来访问它。

单片机中有FLASH为啥还需要EEROM?

flash可以一个字节一个字节写,但是删除的话,得一整个扇区删除。

目前常见的flash一个扇区是4k的大小。如果你只要删改一个哪怕一个字节的数据。都要先把flash的至少一个扇区的数据读到ram里。然后修改。改好了后再把这个扇区的数据再存回去。如果只是小数据量的修改。则这样一折腾,操作复杂。而且mega328才2k的RAM。存不下一个扇区的数据。所以内置了EEPROM,可以按字节删改。

stm32 F10xxx系统结构,图下面是每个名词的介绍,结合着看

系统构架

●四个驱动单元:

.CortexTM-M3内核DCode总线(D-bus)和系统总线(S-bus)

.通用DMA1和通用DMA2

●四个被动单元

.内部SRAM

.内部闪存存储器

.FSMC

.AHB到APB的桥(AHB2APBx),它连接所有的APB设备

我们可以把驱动单元理解成是CPU部分,被动单元都理解成外设。下面我们简单介绍下驱动单元和被动单元的各个部件

这些都是通过一个多级的AHB总线构架相互连接的,如下图所示:

从AHB总线延伸出来的两条(APB1和APB2)总线,上面挂载着STM32各种各样的特色外设。我们经常说的GPIO、串口、I2C、SPI这些外设就挂载在这两条总线上,这个是我们学习STM32的重点,就是要学会编程这些外设去驱动外部的各种设备。

单片机中都有FLASH还需要EEROM吗?_第3张图片

ICode总线

该总线将CortexTM-M3内核的指令总线与闪存指令接口相连接。指令预取在此总线上完成。

ICode中的I表示Instruction,即指令。程序编译之后生成的二进制文件都是一条条指令,烧录后寄存在FLASH中,内核要读取这些指令来执行程序就必需通过ICode总线,它简直每时每刻都须要被使用,它是专门用来取指的。

由上图也可看出ICode连接M3内核与Flash接口

DCode总线

该总线将CortexTM-M3内核的DCode总线与闪存存储器的数据接口相连接(常量加载和调试访

问)。

DCode中的D表示Data,即数据,那说明这条总线是用来取数的。我们在写程序的时候,数据有常量和变量两种,常量就是固定不变的,用C语言中的const关键字修饰,是放到内部的FLASH?当中的,变量是可变的,不管是全局变量还是局部变量都放在内部的SRAM。由于数据能够被Dcode总线和DMA总线访问,所以为了避免访问冲突,在取数的时候须要经过一个总线矩阵来仲裁,决定哪个总线在取数。

系统总线

此总线连接CortexTM-M3内核的系统总线(外设总线)到总线矩阵,总线矩阵协调着内核和DMA间

的访问。

DMA总线

此总线将 DMA的AHB主控接口与总线矩阵相联 ,总线矩阵协调着 CPU的 DCode和 DMA到SRAM、闪存和外设的访问。

总线矩阵

总线矩阵协调内核系统总线和DMA主控总线之间的访问仲裁,仲裁利用轮换算法。在互联型产品中,总线矩阵包含5个驱动部件(CPU的DCode、系统总线、以太网DMA、DMA1总线和DMA2总线)和3个从部件(闪存存储器接口(FLITF)、SRAM和AHB2APB桥)。在其它产品中总线矩阵包含4个驱动部件(CPU的DCode、系统总线、DMA1总线和DMA2总线)和4个被动部件(闪存存储器接口(FLITF)、SRAM、FSMC和AHB2APB桥)。

AHB外设通过总线矩阵与系统总线相连,允许DMA访问。

首先,说点不靠谱的,APB和AHB总线,我个人感觉这个类似于个人PC系统里的北桥和南桥总线。

南桥总线上挂接的都是鼠标、键盘这些慢速的设备,北桥上挂接显卡等高速设备。南桥频次低,北桥频次高。另外,南桥最后也要接到北桥上。

这些感觉都类似于APB和AHB。

一定要看图,比照着看!

从AHB总线延伸出来的两条(APB1和APB2)总线,上面挂载着STM32各种各样的特色外设。我们经常说的GPIO、串口、I2C、SPI这些外设就挂载在这两条总线上,这个

你可能感兴趣的:(硬件工程师,自动化,智能,单片机,单元测试,单例模式,单一职责原则)