CPU接口模塊完成了CPU指令的解讀與寄存器配置以及UART狀態讀取等功能。通過3位的地址線和8位的數據線,CPU可以對波特率發生器的波特率進行預先的設定,以使串口兩端的設備在同一波特率下完成接收和發送的工作。同時CPU接口接收來自CPU的需要發送的5∽8位數據,送人發送模塊,或者把接收模塊接收到的數據通過接口送給CPU進行數據處理。在此接口模塊里,設置了8個控制和狀態寄存器,包括RBR(Receiver Buffer Register)接收緩沖寄存器、THR(Transmit Hold Register)發送保持寄存器、IER(Interrupt Enable Register)中斷使能寄存器、IIR(Interrupt ID Register)中斷寄存器、LCR(Line Control Register)線控制寄存器、LSR(Line Status Register)線狀態寄存器、SCR(Scratchpad Register)暫存寄存器和FCR(FIFO Control Register)。在使用UART16550前,CPU必須要對控制寄存器進行配置,包括波特率、數據位數、奇偶校驗、停止位位數及FIFO的控制等。這也是16550區別于一般UART的具有可編程的特點。
發送模塊的核心是one hot編碼的狀態機。他可以讀人來自FIFO的數據,并根據配置寄存器里面的信息加入起始位、1,1.5或2位停止位和奇偶校驗位,然后把打包的數據通過移位寄存器把數據以標準的串口協議發送給串口接收設備。只要發送FIFO中有數據存在,發送模塊就會一直發送,直到FIFO空為止。在不選擇FIFO的情況下,發送模塊則直接接收來自THR(Transmit Hold Register)發送保持寄存器的數據,不經過緩存直接發送。