以下是我剛改的程序編譯成功了
創(chuàng)新互聯(lián)建站-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設、高性價比黃山區(qū)網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式黃山區(qū)網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設找我們,業(yè)務覆蓋黃山區(qū)地區(qū)。費用合理售后完善,十余年實體公司更值得信賴。
請參考
#include"reg51.h"
//定義全局變量
unsigned char data_10[10]={0,0,0,0,0,0,0,0,0,0};
unsigned char Time_50ms,count;
bit flag=0;
bit data_flag=0;
/*********************************************************************************************
函數(shù)名:UART串口初始化函數(shù)
調(diào) 用:UART_init();
參 數(shù):無
返回值:無
結 果:啟動UART串口接收中斷,允許串口接收,啟動T/C1產(chǎn)生波特率(占用)
備 注:振蕩晶體為12MHz,PC串口端設置 [ 4800,8,無,1,無 ]
/**********************************************************************************************/
void UART_init (void){
EA = 1; //允許總中斷(如不使用中斷,可用//屏蔽)
ES = 1; //允許UART串口的中斷
TMOD |= 0x20;//定時器T/C1工作方式2
SCON = 0x50;//串口工作方式1,允許串口接收(SCON = 0x40 時禁止串口接收)
TH1 = 0xF3;//定時器初值高8位設置
TL1 = 0xF3;//定時器初值低8位設置
PCON = 0x80;//波特率倍頻(屏蔽本句波特率為2400)
TR1 = 1;//定時器啟動
}
/**********************************************************************************************/
/*********************************************************************************************
函數(shù)名:UART串口接收中斷處理函數(shù)
調(diào) 用:[SBUF收到數(shù)據(jù)后中斷處理]
參 數(shù):無
返回值:無
結 果:UART串口接收到數(shù)據(jù)時產(chǎn)生中斷,用戶對數(shù)據(jù)進行處理(并發(fā)送回去)
備 注:過長的處理程序會影響后面數(shù)據(jù)的接收
/**********************************************************************************************/
void UART_R (void) interrupt 4 using 1{ //切換寄存器組到1
TR0=1; //打開定時器開始計時
RI = 0;//令接收中斷標志位為0(軟件清零)
data_10[count] = SBUF;//將接收到的數(shù)據(jù)送入變量 UART_data
count++;//接收到一個字節(jié)數(shù)據(jù)計數(shù)+1
if(count=10) //如果接收到10個數(shù)據(jù)
{
TR0=0; //停止定時器
TH0 = 0x3C; //給定時器賦初值
TL0 = 0xB0; //給定時器賦初值
count=0;//清零數(shù)據(jù)計數(shù)
//data_flag=1; //數(shù)據(jù)有效標志位
SBUF = 0x55;//返回數(shù)據(jù) 55H
while(TI == 0);//檢查發(fā)送中斷標志位
TI = 0;//令發(fā)送中斷標志位為0(軟件清零)
}
if(flag)
{
TR0=0; //停止定時器
TH0 = 0x3C; //給定時器賦初值
TL0 = 0xB0; //給定時器賦初值
count=0;//清零數(shù)據(jù)計數(shù)
SBUF = 0xff;//返回數(shù)據(jù) ffH
while(TI == 0);//檢查發(fā)送中斷標志位
TI = 0;//令發(fā)送中斷標志位為0(軟件清零)
}
}
/**********************************************************************************************/
/*********************************************************************************************
函數(shù)名:定時/計數(shù)器初始化函數(shù)
調(diào) 用:T_C_init();
參 數(shù):無
返回值:無
結 果:設置SFR中T/C1和(或)T/C0相關參數(shù)
備 注:本函數(shù)控制T/C1和T/C0,不需要使用的部分可用//屏蔽
/**********************************************************************************************/
void T_C_init (void){
TMOD |= 0x01; //高4位控制T/C1 [ GATE,C/T,M1,M0,GATE,C/T,M1,M0 ]
EA = 1;//中斷總開關
TH0 = 0x3C; //16位計數(shù)寄存器T0高8位
TL0 = 0xB0; //16位計數(shù)寄存器T0低8位(0x3CB0 = 50mS延時)
ET0 = 1; //T/C0中斷開關
TR0 = 0; //T/C0開關
}
/**********************************************************************************************/
/*********************************************************************************************
函數(shù)名:定時/計數(shù)器0中斷處理函數(shù)
調(diào) 用:[T/C0溢出后中斷處理]
參 數(shù):無
返回值:無
結 果:重新寫入16位計數(shù)寄存器初始值,處理用戶程序
備 注:必須允許中斷并啟動T/C本函數(shù)方可有效,重新寫入初值需和T_C_init函數(shù)一致
/**********************************************************************************************/
void T_C0 (void) interrupt 1 using 1{ //切換寄存器組到1
TH0 = 0x3C; //16位計數(shù)寄存器T0高8位(重新寫入初值)
TL0 = 0xB0; //16位計數(shù)寄存器T0低8位(0x3CB0 = 50mS延時)
Time_50ms++; //50ms到 計數(shù)+1
if(Time_50ms=100)
{
Time_50ms=0;// 清零50ms計數(shù)
flag=1; //5s時間 標志置位
TR0=0;//關閉計時器
}
}
/**********************************************************************************************/
main()
{
IP = 0x10; //中斷優(yōu)先級設置(串口中斷最高優(yōu)先級)
UART_init();//初始化串口
T_C_init(); // 初始化計數(shù)器
while(1);// 空循環(huán)
}
我寫的串口通信代碼比較長,給幾個關鍵函數(shù)你吧,可實現(xiàn)PC與單片機的雙工通信
/*串口通訊 單片機晶振:11.0592MHz
T1工作于方式2 波特率=2^smod*fosc/32/12/(256-X)*/
#includecommon.h
void do_uart(void); //串口接收執(zhí)字符時的操作
/*串口發(fā)送字符串 */
void sendstr(uchar *p)
{
while(*p!='\0')
{ SBUF=*p; //待發(fā)送的數(shù)據(jù)寫入緩沖區(qū)
while(!TI); //等待發(fā)送完成
TI=0; //清零發(fā)送標志位
p++; //指針加1
cnt_s++; //發(fā)送計數(shù)
}
}
/*串口接收中斷函數(shù)*/
void int_rec(void) interrupt 4 using 2
{
if(RI) //查詢接收標志位(有數(shù)據(jù)發(fā)送過來時置為1)
{
RI = 0; //接收標志位清零
// sendchar(SBUF);//讓從電腦上傳到單片機的數(shù)據(jù),傳回的電腦顯示
do_uart();//對接受到得字符操作
}
}
/*串口初始化*/
void com_init(uint baud)
{
SCON = 0x50; //串口工作方式為1,串行允許接受
TMOD = 0x21; //定時器1工作在方式2 定時器0工作在方式1
//PCON = 0x80; //SMOD = 1; 波特率加倍
TH1=256-fosc/32/12/baud;
TL1=TH1;
ES = 1; //開串口中斷
TR1 = 1; //允許定時器1工作
EA = 1; //開總中斷
}
void sendchar(uchar uart_dat) //串口發(fā)送字符函數(shù)
{
SBUF = uart_dat; //待發(fā)送的數(shù)據(jù)寫入緩沖區(qū)
while(!TI); //等待發(fā)送完成
TI = 0; //清零發(fā)送標志位
cnt_s++; //發(fā)送計數(shù)
}
PIC的還真沒用過,不過從C的角度講 buffer 在沒有初始化的情況下貌似就被使用了,如果編譯器使用固定地址分配給局部變量 buffer 就會出事了。把
while(buffer != 'P')
{
buffer = RCREG;
}
改為
do
{
buffer = RCREG;
}
while(buffer != 'P');
可以避免這類BUG;但愿能有點幫助 :)
你看看接收并回傳給串口助手的數(shù)據(jù)是否正確
if(Rev_Data == "t")
{
Sector_erase(0x2000); //扇區(qū)擦除。。。。把這一句注釋掉,再看看結果
P1 = 0x55;
delay(5);
flag = 1;
i = 0;
}
編程原理
程序1為查詢通信方式接口程序,為一典型的數(shù)據(jù)采集例程。其中bioscom()函數(shù)初始化COM1(此函數(shù)實際調(diào)用BIOS
INT
14H中斷0號功能)。這樣在程序中就避免了具體設置波特率因子等繁瑣工作,只需直接訪問發(fā)送/接收寄存器(3F8H)和線路狀態(tài)寄存
網(wǎng)站欄目:串口通信函數(shù)c語言 串口通信函數(shù)c語言編譯
網(wǎng)站鏈接:http://www.chinadenli.net/article8/doocsop.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供ChatGPT、網(wǎng)站收錄、云服務器、全網(wǎng)營銷推廣、網(wǎng)頁設計公司、網(wǎng)站導航
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)