本帖最后由 生无所息1 于 2013-10-28 20:58 编辑
UART: Uniersal Asynchronous Receiver/Transmitters
SCI:Serial Communication Interface
经常看到这两个缩写,只认识上面的那个,却不认识SCI(小样换了个马甲老子不认识你了!),而且也搞比清楚它们的全称,在这备注下。
关于串行通信的基本原理不想多说,直入主题——Uart模块的编程结构。
K60的UART模块总共有六个分别为UART0到UART5.它里面的各寄存器均是8位的。下图将给出UART0的各寄存器的地址以及复位值。其他UART模块的寄存器地址确定规则为:同名寄存器的地址相对于UART0的偏移量分别为0x0000_1000、0x0000_2000、0x0000_3000、0x0008_0000、0x0008_1000。例如,uART0的波特率高字节寄存器的地址为0x4006_A000则UART1的这个寄存器的地址为0x4006_A000 +0x0000_1000 =0x4006_B000,UART2的这各寄存器的地址为0x4006_A000 + 0x0000_1000= 0x4006_C000, UART3的这各寄存器的地址为 0x4006_A000 + 0x0000_3000 = 0x4006_D000,UART4的这各寄存器的地址为 0x4006_A000 + 0x0008_0000 = 0x400E_A000,UART5的这各寄存器的地址为 0x4006_A000 + 0x0008_1000 = 0x400E_B000,
这种地址相关联很方便**。。。。。
上图。。。
|