色婷婷AⅤ一区二区三区|亚洲精品第一国产综合亚AV|久久精品官方网视频|日本28视频香蕉

          新聞中心

          MCU_S3C2410之UART分析

          作者: 時(shí)間:2016-11-11 來源:網(wǎng)絡(luò) 收藏
          功能分析

          寄存器分析

          本文引用地址:http://cafeforensic.com/article/201611/316923.htm

          代碼分析

          ///////////////////////////////////////////////////////////////////////UART 初始化/////////////////////////////////////////////////////////////////////////////////////

          voidUart_Init(int pclk,int baud)
          {
          int i;
          if(pclk == 0)
          pclk = PCLK; //APB IS USED FOR APB
          rUFCON0 = 0x0;//關(guān)閉UART0的FIFO
          rUFCON1 = 0x0;//關(guān)閉UART1的FIFO
          rUFCON2 = 0x0;//關(guān)閉UART2的FIFO


          rUMCON0 = 0x0;//關(guān)閉UART0自動(dòng)流控制AFC (一般不進(jìn)行握手協(xié)議控制)
          rUMCON1 = 0x0;//關(guān)閉UART1自動(dòng)流控制AFC (UART2沒有自動(dòng)流控制功能)



          //UART0
          rULCON0 = 0x3; //Normal,No parity,1 stop bit,8 bits data基本協(xié)議控制


          rUCON0 = 0x245;

          Transmit MODE:發(fā)送模式有請(qǐng)求中斷發(fā)送和請(qǐng)求DMA發(fā)送

          TX interrupt Type :當(dāng)發(fā)送保持寄存器為空時(shí)(Non-FIFO MODE)或達(dá)到TX FIFO觸發(fā)水平時(shí)觸發(fā)中斷的電平類型

          (TX FIFO觸發(fā)水平:00 = Empty 01 = 4-byte 10 = 8-byte 11 = 12-byte in UFCONn)

          Receive MODE 接收模式有請(qǐng)求中斷讀取和請(qǐng)求DMA讀取

          RX interrupt Type :當(dāng)接收保持寄存器為空時(shí)(Non-FIFO MODE)或達(dá)到RX FIFO觸發(fā)水平時(shí)觸發(fā)中斷的電平類型(RX FIFO觸發(fā)水平:00 = 4-byte 01 = 8-byte 10 = 12-byte 11 = 16-byte in UFCONn)

          rUBRDIV0=( (int)(pclk/16/baud) -1 );



          //UART1
          rULCON1 = 0x3;
          rUCON1 = 0x245;
          rUBRDIV1=( (int)(pclk/16/baud) -1 );


          //UART2
          rULCON2 = 0x3;
          rUCON2 = 0x245;
          rUBRDIV2=( (int)(pclk/16/baud) -1 );

          for(i=0;i<100;i++);
          }

          總結(jié)UART的控制寄存器:有ULCON、UCON、UFCON、UMCON、UBRDIV

          ///////////////////////////////////////////////////////////////////////UART 初始化////////////////////////////////////////////////////////////////////////////////////

          ///////////////////////////////////////////////////////////////////////UART 發(fā)送////////////////////////////////////////////////////////////////////////////////////

          voidUart_SendByte(int data)
          {
          if(whichUart==0)
          {
          if(data== )
          {
          while(!(rUTRSTAT0 & 0x2));

          non FIFO=1 Byte BUFFER REGISTER(HOLDING REGISTER)+SHIFTER REGISTER

          FIFO mode = 16 Byte BUFFER REGISTER(FIFO REGISTER)+SHIFTER REGISTER


          Delay(10); //because the slow response of hyper_terminal
          WrUTXH0( );


          }
          while(!(rUTRSTAT0 & 0x2)); //Wait until THR is empty.
          Delay(10);
          WrUTXH0(data);
          }
          else if(whichUart==1)
          {
          if(data== )
          {
          while(!(rUTRSTAT1 & 0x2));
          Delay(10); //because the slow response of hyper_terminal
          rUTXH1 = ;
          }
          while(!(rUTRSTAT1 & 0x2)); //Wait until THR is empty.
          Delay(10);
          rUTXH1 = data;
          }
          else if(whichUart==2)
          {
          if(data== )
          {
          while(!(rUTRSTAT2 & 0x2));
          Delay(10); //because the slow response of hyper_terminal
          rUTXH2 = ;
          }
          while(!(rUTRSTAT2 & 0x2)); //Wait until THR is empty.
          Delay(10);
          rUTXH2 = data;
          }
          }

          ///////////////////////////////////////////////////////////////////////UART 發(fā)送////////////////////////////////////////////////////////////////////////////////////

          ///////////////////////////////////////////////////////////////////////UART 接收////////////////////////////////////////////////////////////////////////////////////

          charUart_Getch(void)

          {
          if(whichUart==0)
          {
          while(!(rUTRSTAT0 & 0x1)); //Receive data ready
          return RdURXH0();


          }
          else if(whichUart==1)
          {
          while(!(rUTRSTAT1 & 0x1)); //Receive data ready
          return RdURXH1();
          }
          else if(whichUart==2)
          {
          while(!(rUTRSTAT2 & 0x1)); //Receive data ready
          return RdURXH2();
          }
          }

          ///////////////////////////////////////////////////////////////////////UART 接收////////////////////////////////////////////////////////////////////////////////////

          總結(jié)UART有狀態(tài)寄存器UTRSTAT、UERSTAT、UFSTAT、UMSTAT

          有數(shù)據(jù)寄存器UTXH和URXH



          關(guān)鍵詞: MCUS3C2410UART分

          評(píng)論


          技術(shù)專區(qū)

          關(guān)閉