SOC系统内存储体系(FLASH、SRAM、DRAM等)

在这里插入图片描述
片内存储器:
1、寄存器:处理器内部的reg通常由十几个到几十个,读取速度最快,用来缓存程序运行时频繁使用的数据(局部变量,函数参数等)。
2、Cache:缓存由SRAM构成,速度仅次于寄存器,对指令和数据进行缓存,降低存储器与片外存储的交换频率。Cache通常分1、2、3级缓存。
3、ROM:用来存放SOC系统的启动程序(bootloader等),启动程序从外存(Flash等)读取系统程序和应用程序,送到主存。
片外存储器:
1、片外主存(DRAM):用于存放当前正在运行的系统程序、应用程序、数据、堆栈等关键信息。通常采用 DRAM(如SDRAM、DDR2、DDR3),掉电易失。
2、Flash:分NOR Flash、Nand Flash。Nor Flash可字节寻找,支持芯片内执行,这样应用程序可直接在flash内运行,不必再把代码读取到系统主存中,常用来存放系统引导启动程序bootloader等,可实现系统的片外启动。Nand Flash为块设备,通常一次读取512B的块,存储容量大,非易失,用来存放系统程序,如操作系统等。
在这里插入图片描述

  • 2
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是对ROM、RAM、SRAM、DRAMFLASH的介绍: 1. ROM(只读存储器):只读存储器是一种只能读取数据而不能写入数据的存储器。它通常用于存储固件、BIOS和其他需要在计算机启动时加载的程序。ROM的数据是在制造过程中被写入的,因此它的内容是固定的。 2. RAM(随机存储器):随机存储器是一种可以读取和写入数据的存储器。它通常用于存储正在运行的程序和数据。RAM是易失性存储器,这意味着当计算机关闭时,其中的数据将被清除。 3. SRAM(静态随机存储器):静态随机存储器是一种使用触发器来存储数据的RAM。它比动态随机存储器(DRAM)更快,但也更昂贵。SRAM通常用于高速缓存和其他需要快速访问的应用程序。 4. DRAM(动态随机存储器):动态随机存储器是一种使用电容器来存储数据的RAM。它比SRAM更便宜,但速度较慢。DRAM需要定期刷新以保持数据的完整性。 5. FLASH:闪存是一种非易失性存储器,可以读取和写入数据。它通常用于存储固件、操作系统和其他需要在计算机启动时加载的程序。闪存比传统的硬盘驱动器更快,更可靠,也更耐用。 以下是对ROM、RAM、SRAM、DRAMFLASH的演示: ```python # ROM # 由于ROM是只读存储器,因此我们无法在程序中演示写入操作。 # 我们可以使用Python的binascii库来读取ROM中的数据。 import binascii # 读取ROM中的数据 with open('rom.bin', 'rb') as f: data = f.read() # 将数据转换为十六进制字符串 hex_data = binascii.hexlify(data) # 输出数据 print(hex_data) # RAM # 在Python中,我们可以使用列表来模拟RAM。 # 我们可以使用索引来读取和写入RAM中的数据。 ram = [0] * 1024 # 创建一个大小为1024字节的RAM # 写入数据 ram[0] = 0x12 ram[1] = 0x34 # 读取数据 data = (ram[0] << 8) | ram[1] print(hex(data)) # SRAM # 在Python中,我们可以使用类来模拟SRAM。 # 我们可以使用类变量来存储数据。 class SRAM: data = [0] * 1024 # 创建一个大小为1024字节的SRAM @classmethod def write(cls, address, value): cls.data[address] = value @classmethod def read(cls, address): return cls.data[address] # 写入数据 SRAM.write(0, 0x12) SRAM.write(1, 0x34) # 读取数据 data = (SRAM.read(0) << 8) | SRAM.read(1) print(hex(data)) # DRAM # 在Python中,我们可以使用类来模拟DRAM。 # 我们可以使用字典来存储数据。 class DRAM: data = {} # 创建一个空的DRAM @classmethod def write(cls, address, value): cls.data[address] = value @classmethod def read(cls, address): return cls.data.get(address, 0) # 写入数据 DRAM.write(0, 0x12) DRAM.write(1, 0x34) # 读取数据 data = (DRAM.read(0) << 8) | DRAM.read(1) print(hex(data)) # FLASH # 由于FLASH是非易失性存储器,因此我们无法在程序中演示数据丢失。 # 我们可以使用Python的struct库来读取FLASH中的数据。 import struct # 读取FLASH中的数据 with open('flash.bin', 'rb') as f: data = f.read() # 将数据转换为整数 value = struct.unpack('>I', data)[0] # 输出数据 print(hex(value))) ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值