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

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

你有没有想过一个问题: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节"程序运行的机理与总线技术"。)

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

相关推荐
FreakStudio4 天前
W55MH32L-EVB 上手测评:硬件 TCP/IP 加持的以太网单片机,MicroPython 零门槛开发
python·单片机·嵌入式·大学生·面向对象·并行计算·电子diy·电子计算机
✎ ﹏梦醒͜ღ҉繁华落℘9 天前
单片机基础知识---stm32单片机的优先级
stm32·单片机·mongodb
zd8451015009 天前
RS485 总线详解
单片机·嵌入式硬件
牛根生同志9 天前
SPI数据收发的时候 TXE与RXNE标志位置位的时机
stm32·spi·transfer
goldenrolan9 天前
学习型红外控制系统稳定性挂测工装专项总结
软件测试·python·stm32·嵌入式·红外
✎ ﹏梦醒͜ღ҉繁华落℘9 天前
编程基础 --高内聚,低耦合
c语言·单片机
科芯创展9 天前
1A,1MHz,30VIN,XZ4115,降压恒流LED驱动芯片
单片机·嵌入式硬件
AndyHeee9 天前
【SVC、PendSV(系统异常) 与 外设 IRQ 、NVIC笔记】
arm开发
集芯微电科技有限公司9 天前
四通道2A输出集成功率电感降压模块专为紧凑型方案设计
人工智能·单片机·嵌入式硬件·生成对抗网络·计算机外设
踏着七彩祥云的小丑9 天前
嵌入式测试学习第 37 天:异常场景测试:断电、拔插、干扰、非法指令
单片机·嵌入式硬件·学习