新聞中心

        EEPW首頁 > 嵌入式系統 > 設計應用 > MCU_S3C2410之UART分析

        MCU_S3C2410之UART分析

        作者: 時間:2016-11-11 來源:網絡 收藏
        功能分析

        寄存器分析

        本文引用地址:http://www.104case.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;//關閉UART0的FIFO
        rUFCON1 = 0x0;//關閉UART1的FIFO
        rUFCON2 = 0x0;//關閉UART2的FIFO


        rUMCON0 = 0x0;//關閉UART0自動流控制AFC (一般不進行握手協議控制)
        rUMCON1 = 0x0;//關閉UART1自動流控制AFC (UART2沒有自動流控制功能)



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


        rUCON0 = 0x245;

        Transmit MODE:發送模式有請求中斷發送和請求DMA發送

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

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

        Receive MODE 接收模式有請求中斷讀取和請求DMA讀取

        RX interrupt Type :當接收保持寄存器為空時(Non-FIFO MODE)或達到RX FIFO觸發水平時觸發中斷的電平類型(RX FIFO觸發水平: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++);
        }

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

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

        ///////////////////////////////////////////////////////////////////////UART 發送////////////////////////////////////////////////////////////////////////////////////

        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 發送////////////////////////////////////////////////////////////////////////////////////

        ///////////////////////////////////////////////////////////////////////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 接收////////////////////////////////////////////////////////////////////////////////////

        總結UART有狀態寄存器UTRSTAT、UERSTAT、UFSTAT、UMSTAT

        有數據寄存器UTXH和URXH



        關鍵詞: MCUS3C2410UART分

        評論


        技術專區

        關閉
        主站蜘蛛池模板: 龙胜| 连南| 阿尔山市| 探索| 辽宁省| 友谊县| 前郭尔| 楚雄市| 云和县| 卢氏县| 绵竹市| 沙田区| 全椒县| 襄城县| 潮安县| 叶城县| 酉阳| 体育| 景谷| 陕西省| 阳春市| 进贤县| 三明市| 财经| 嘉黎县| 平原县| 辽中县| 石屏县| 梁山县| 汤原县| 聂拉木县| 兴安县| 宁化县| 墨竹工卡县| 九寨沟县| 安国市| 太康县| 银川市| 肇州县| 乐平市| 武冈市|