地址总线定“找谁”,数据总线定“搬多少”

短文标题:地址总线定"找谁",数据总线定"搬多少"

你有没有想过一个问题:32位单片机的"32位"到底指什么?为什么它能访问4GB地址空间?"32位"指数据总线的宽度,但地址总线的宽度也影响寻址能力。这两个"宽度",决定了CPU的"视野"和"效率"。地址总线:能找多少个"门牌号"地址总线用于CPU输出要访问的地址。

• 32根地址线 → 每根线0或1 → 2^32 = 4,294,967,296种组合

• 每个组合对应一个字节地址 → 4GB寻址空间

16根地址线 → 2^16 = 64KB寻址空间。地址线越多,CPU能"看到"的内存越大。

STM32F103的地址总线是32位,但实际Flash 512KB、RAM 64KB,只用了地址空间的一小部分。地址映射:部分地址范围分配给外设寄存器(0x40000000开始),不是所有地址都对应物理内存。数据总线:一次能搬多少数据数据总线用于CPU和存储器之间传输数据。

• 8根数据线 → 一次传1字节

• 16根 → 一次传2字节

• 32根 → 一次传4字节

ARM32是32位CPU,数据总线32根。一次能搬4字节,效率是8位单片机的4倍。

取指令 vs 取数据,程序运行时,CPU交替做两件事:

  1. 取指令:从Flash读取机器码,通过数据总线传回CPU

  2. 存取数据:从RAM读写变量,通过同一条数据总线

指令和数据走同一条路(冯·诺依曼架构),分时复用。哈佛架构(如51单片机)指令和数据总线分开,可同时取指和取数,但引脚更多、封装更大。Cortex-M是改进型冯·诺依曼,内部有指令缓存和数据缓存优化。地址对齐与效率,ARM32一次读4字节,但要求地址是4的倍数(对齐访问)。地址0x20000001(不是4的倍数)→ CPU分两次读:

  1. 读0x20000000的4字节 → 取后3字节

  2. 读0x20000004的4字节 → 取前1字节

  3. 拼出需要的4字节

效率降低一半。 编译器默认对齐,但手动操作地址时需注意。地址译码:谁响应这个地址?CPU把地址放到地址总线上后,硬件译码电路判断:

• 地址在0x20000000~0x2000FFFF → SRAM响应该访问

• 地址在0x40000000~0x4000FFFF → 外设寄存器响应该访问

• 地址在0x08000000~0x0807FFFF → Flash响应该访问

地址决定目标,目标决定行为。这个故事的启示,地址总线定"找谁",数据总线定"搬多少"。32位地址总线 + 32位数据总线 = 大视野 + 高吞吐。理解总线,就理解了程序运行的根本机理。写在最后,CPU是"搬运工":从Flash搬指令,从RAM搬数据。地址总线和数据总线,是搬家的两条路。一条告诉你去哪搬,一条把东西搬回来。

(本文灵感源于于振南《新概念ARM32单片机》教程第1.7节"程序运行的机理与总线技术"。)

觉得有用?点赞、转发,让更多人看懂"地址总线"和"数据总线"的分工智慧。

相关推荐
yong99901 小时前
手机蓝牙发送指令STM32串口接收控制 LED 亮灭
stm32·单片机·智能手机
嵌入式小站10 小时前
STM32 零基础可移植教程 17:USART + DMA + IDLE,串口不定长接收怎么做
stm32·单片机·嵌入式硬件
史蒂芬_丁11 小时前
Cortex-M内核中断保护机制详解:PRIMASK寄存器的正确使用方法
单片机·嵌入式硬件
榴莲llll11 小时前
LED高亮数码管显示驱动芯片数显屏驱动器最大支持13×3的按键VK16K33A
单片机
崇山峻岭之间12 小时前
单片机传感器实验
单片机·嵌入式硬件
芯岭技术14 小时前
PY32F030国产32位MCU,应用场景广泛,宽工作电压、丰富外设
单片机·嵌入式硬件·物联网
FreakStudio18 小时前
大话电容传感器和电容SOC芯片,看这一篇就够了
python·单片机·嵌入式·面向对象·并行计算·电子diy·电子计算机
信看19 小时前
常见通信接口
单片机·嵌入式硬件
m0_3771081419 小时前
USART
stm32