
LPC2138的串口帶有16字節(jié)的接收和發(fā)送FIFO,并且接收FIFO的觸發(fā)點可設為1,4,8,14字節(jié)。
1)接收
	當接收到的字節(jié)數(shù)達到設置的觸發(fā)點(通過FCR寄存器設置)時,就會產生接收中斷;而當接收到的字節(jié)數(shù)未能達到設置的觸發(fā)點(比如觸發(fā)點設置為14,但是只接收到了10個字節(jié)的數(shù)據(jù)),那么經過短暫的等待時間后會產生超時中斷。在這兩種情況下需要正確讀取RBR寄存器,妥善保存接收到的數(shù)據(jù)。
	      舉例來說,假設接收FIFO的觸發(fā)點設置為14,而要接收的數(shù)據(jù)一共有16字節(jié)。那么接收過程中會產生兩次中斷:第一次是當接收到第14個字節(jié)時產生的接收中斷;之后只剩2個字節(jié)要接收,達不到觸發(fā)點14,所以經過等待時間后會產生超時中斷。
	      中斷服務程序里,對于這兩種中斷可進行如下的處理(假設使用UART1):
	
	
	switch (U1IIR & 0x0E)
	      {
	      case 0x0C:            // 若為超時中斷(注意此處不要加break)
	      case 0x04:            // 若為接收中斷
	      while ((U1LSR & 0x01) == 1)             // 若U1RBR包含有效數(shù)據(jù)
	      Rec_Buffer[index++] = U1RBR;    // 保存接收到的數(shù)據(jù)
	      }
	      
	      2)發(fā)送
	發(fā)送FIFO并沒有觸發(fā)點的問題。要發(fā)送數(shù)據(jù)時,首先把數(shù)據(jù)寫入THR寄存器,之后MCU會將其移入發(fā)送FIFO緩沖區(qū)中,一旦THR寄存器被移空,就會產生發(fā)送中斷。換句話說,在使能了發(fā)送中斷的情況下,每向THR寄存器寫一個字節(jié)就會引起一次發(fā)送中斷。所以要發(fā)送一系列的數(shù)據(jù)時,只需要發(fā)送第一個字節(jié)來啟動發(fā)送過程,剩余的字節(jié)由中斷服務程序來完成就可以了。
	      假設Send_Length為要發(fā)送的總字節(jié)數(shù),程序中的處理如下:
	
	      U1THR = Txd_Buffer[0];
	      index = 1;
	      
	      void __irq Uart1_isp(void)                           // 中斷服務程序
	      {
	            if ((U1IIR & 0x0E) == 0x02)                   // 判斷是否為發(fā)送中斷
	            {
	                  if (index != Send_Length)
	                  {
	                        U1THR = Txd_Buffer[index];
	                        index ++;
	                  }
	            }
	      }
	
	      個人覺得,使能發(fā)送中斷會導致MCU的工作效率變低。因為一旦THR寄存器為空就會進入中斷服務程序,會出現(xiàn)連續(xù)的無效中斷。(如果理解有錯誤,還請指正)
	      在不使能發(fā)送中斷的情況下,可用查詢方式實現(xiàn)以上的發(fā)送過程:
	
	      int i;
	      for (i = 0; i < Send_Length; i++)
	     {
	           U1THR = Txd_Buffer[i];
	           while (!(U1LSR & 0x20));         // 等待當前字節(jié)發(fā)送完畢
	      }
	來源;電子工程網(wǎng)