標(biāo)題: 請(qǐng)教RTX51TINY串口發(fā)送接收不正常 [打印本頁(yè)]

作者: ZHAOBAO511    時(shí)間: 2024-5-29 14:57
標(biāo)題: 請(qǐng)教RTX51TINY串口發(fā)送接收不正常
RTX51_LED_9_STC3chuankou.rar (267.06 KB, 下載次數(shù): 1)
把接收到的數(shù)+頭+尾發(fā)出去。收到數(shù)據(jù)就死機(jī),代碼如下:
void job0 (void) _task_ 0
{

        P0M1 = 0;
        P0M0 = 0; //設(shè)置為準(zhǔn)雙向口
        P1M1 = 0;
        P1M0 = 0; //設(shè)置為準(zhǔn)雙向口
        P3M1 = 0;
        P3M0 = 0; //設(shè)置為準(zhǔn)雙向口
        P5n_standard(0xff);        //設(shè)置為準(zhǔn)雙向口
        LED1=0;
        LED2=1;
  LED3=1;
        LED4=1;
        LED5=1;
  LED6=1;
        LED7=1;
  LED8=1;
        
        UART4_config(4);        // 選擇波特率, 2: 使用Timer2做波特率, 其它值: 使用Timer4做波特率.
        
        EA = 1;
        youshuju=0;
        
        os_create_task (1);
        os_create_task (2);
        os_create_task (3);
        os_create_task (4);
        os_create_task (5);
        os_create_task (6);
        os_create_task (7);
  os_delete_task (0);
        while(1)
        {

                                 os_wait(K_IVL,2,0);
                         LED1=!LED1;

        }
}

void job1 (void) _task_ 1
{

        
        
        //1602顯示

        while(1)
        {

                                 LED2=!LED2;
               
                        delay_ms(1);
               
                                if(youshuju==1)//收到數(shù)據(jù)標(biāo)志
        {

                send_UART4(0XFF);//加頭發(fā)送
                send_UART4(RX4_Buffer[0]);

                send_UART4(RX4_Buffer[1]);

                send_UART4(RX4_Buffer[2]);

                send_UART4(RX4_Buffer[3]);
                send_UART4(0XEE);//加尾發(fā)送
                youshuju=0;
                RX4_write = 0;
                B_TX4_Busy = 0;                //標(biāo)志發(fā)送忙
        }
        
        
                }        
        
}
void job2 (void) _task_ 2
{

        while(1)
        {
                os_wait(K_IVL,2,0);

                         LED3=!LED3;
               
               
                 }

        
}

void send_UART4(u8 dat)
{
        u8 temp = 0;
  B_TX4_Busy = 1;                //標(biāo)志發(fā)送忙
        S4BUF = dat; //寫數(shù)據(jù)到UART數(shù)據(jù)寄存器
        while (!TI4)
                ; //不忙后發(fā)送數(shù)據(jù)
        CLR_TI4();
        B_TX4_Busy = 0;                //標(biāo)志發(fā)送忙
}




/********************* UART4中斷函數(shù)************************/
void UART4_int (void) interrupt UART4_VECTOR
{
        if(RI4)
        {
                CLR_RI4();
                RX4_Buffer[RX4_write] = S4BUF;
                if(++RX4_write >= RX4_Length)        
                        youshuju=1;
                else
                {
                        youshuju=0;
                }
                        //RX4_write = 0;
        }

        if(TI4)
        {
                CLR_TI4();
                B_TX4_Busy = 0;
        }

}





作者: yzwzfyz    時(shí)間: 2024-5-30 09:56
在串行通訊中,串出一個(gè)字節(jié)通常需要幾個(gè)ms。而程序送出一個(gè)字節(jié)在us級(jí),相差在千倍的速度。
當(dāng)你的程序發(fā)完一個(gè)字節(jié)后,下一個(gè)字節(jié)是無(wú)法立即發(fā)出的,要等幾個(gè)ms,你做到了嗎?
想想,當(dāng)你等不到TI標(biāo)記時(shí),是如何處理的呢?
死等,則CPU在此時(shí)間內(nèi)其它活就不干了,如同死機(jī)一樣。
跳過(guò),則漏發(fā)下個(gè)字節(jié)。
不等,則當(dāng)下發(fā)出的字節(jié)沖毀正在串行而未串行完成的在發(fā)字節(jié)。

正確地做法時(shí),將需要發(fā)送的所有數(shù)據(jù)送入一個(gè)緩沖區(qū)中。如此就不需要考慮發(fā)送時(shí)序速度了,依序存放就行了。
發(fā)送程序:每次TI中斷后,從緩沖區(qū)中取出一個(gè)字節(jié)串出去。
當(dāng)然需要你思考:如何開始、結(jié)束發(fā)送!以及緩沖區(qū)的設(shè)置。就不在此細(xì)述了。
作者: ZHAOBAO511    時(shí)間: 2024-5-30 14:28
yzwzfyz 發(fā)表于 2024-5-30 09:56
在串行通訊中,串出一個(gè)字節(jié)通常需要幾個(gè)ms。而程序送出一個(gè)字節(jié)在us級(jí),相差在千倍的速度。
當(dāng)你的程序發(fā) ...

謝謝,應(yīng)改是串口設(shè)置問(wèn)題,換為串口1就可以了。




歡迎光臨 (http://www.torrancerestoration.com/bbs/) Powered by Discuz! X3.1