工作前、学校里一直搞单片机,工作后、公司里改成搞计算机。单片机对GPIO、串口等外设的访问,程序中直接写寄存器就可以了;计算机中有CPU(如intel、amd)、每个外设又都有自己的控制器,那CPU怎么能访问到每个外设的控制器里面的寄存器,以实现对外设的控制呢?
其实无论单片机还是计算机中CPU,都有自己的地址空间,CPU只能访问自己的地址空间(不是内存地址空间,内存地址空间只是CPU地址空间的一部分),而地址空间与存储器、外设控制器中寄存器存在一一对应的地址映射,当CPU访问某一个地址空间时,硬件上自动映射到对应的存储器存储单元或外设控制器中某个寄存器,从而实现CPU对存储器、外设的访问。
单片机中的CPU其实也是这个道理,只是系统简单,所有的外设控制器都集成到一个芯片中,学校里不求甚解,其实也是访问的自己的地址空间,和计算机中CPU访问独立的SATA控制器、USB控制器等方式是相同的。首先看一下PIC LF1825单片机内部框图,其实物是一个独立的物理芯片:
如下是ARM控制器中外设控制器、存储器地址空间分配