標題:
stc單片機雙串口中斷收發(fā)源程序
[打印本頁]
作者:
wjm1978
時間:
2017-4-7 18:22
標題:
stc單片機雙串口中斷收發(fā)源程序
雙串口中斷收發(fā)源代碼:
0.png
(49.38 KB, 下載次數(shù): 133)
下載附件
2017-4-7 21:35 上傳
/*---------------------------------------------------------------------*/
/* --- STC MCU International Limited ----------------------------------*/
/* --- STC 1T Series MCU Demo Programme -------------------------------*/
/* --- Mobile: (86)13922805190 ----------------------------------------*/
/* --- Fax: 86-0513-55012956,55012947,55012969 ------------------------*/
/* --- Tel: 86-0513-55012928,55012929,55012966 ------------------------*/
/* --- QQ: 800003751 -------------------------------------------------*/
/* 如果要在程序中使用此代碼,請在程序中注明使用了宏晶科技的資料及程序 */
/*---------------------------------------------------------------------*/
#define MAIN_Fosc 22118400L //定義主時鐘
#include "STC15Fxxxx.H"
#define Baudrate1 115200UL
#define Baudrate2 115200UL
/************* 功能說明 **************
雙串口全雙工中斷方式收發(fā)通訊程序。
通過PC向MCU發(fā)送數(shù)據(jù), MCU收到后通過串口把收到的數(shù)據(jù)原樣返回.
******************************************/
#define UART1_BUF_LENGTH 32
#define UART2_BUF_LENGTH 32
u8 TX1_Cnt; //發(fā)送計數(shù)
u8 RX1_Cnt; //接收計數(shù)
u8 TX2_Cnt; //發(fā)送計數(shù)
u8 RX2_Cnt; //接收計數(shù)
bit B_TX1_Busy; //發(fā)送忙標志
bit B_TX2_Busy; //發(fā)送忙標志
u8 idata RX1_Buffer[UART1_BUF_LENGTH]; //接收緩沖
u8 idata RX2_Buffer[UART2_BUF_LENGTH]; //接收緩沖
void UART1_config(u8 brt); // 選擇波特率, 2: 使用Timer2做波特率, 其它值: 使用Timer1做波特率.
void UART2_config(u8 brt); // 選擇波特率, 2: 使用Timer2做波特率, 其它值: 無效.
void PrintString1(u8 *puts);
void PrintString2(u8 *puts);
//========================================================================
// 函數(shù): void main(void)
// 描述: 主函數(shù)。
// 參數(shù): none.
// 返回: none.
// 版本: VER1.0
// 日期: 2014-11-28
// 備注:
//========================================================================
void main(void)
{
P0M1 = 0; P0M0 = 0; //設(shè)置為準雙向口
P1M1 = 0; P1M0 = 0; //設(shè)置為準雙向口
P2M1 = 0; P2M0 = 0; //設(shè)置為準雙向口
P3M1 = 0; P3M0 = 0; //設(shè)置為準雙向口
P4M1 = 0; P4M0 = 0; //設(shè)置為準雙向口
P5M1 = 0; P5M0 = 0; //設(shè)置為準雙向口
P6M1 = 0; P6M0 = 0; //設(shè)置為準雙向口
P7M1 = 0; P7M0 = 0; //設(shè)置為準雙向口
UART1_config(1); // 選擇波特率, 2: 使用Timer2做波特率, 其它值: 使用Timer1做波特率.
UART2_config(2); // 選擇波特率, 2: 使用Timer2做波特率, 其它值: 無效.
EA = 1; //允許全局中斷
PrintString1("STC15F2K60S2 UART1 Test Prgramme!\r\n"); //SUART1發(fā)送一個字符串
PrintString2("STC15F2K60S2 UART2 Test Prgramme!\r\n"); //SUART2發(fā)送一個字符串
while (1)
{
if((TX1_Cnt != RX1_Cnt) && (!B_TX1_Busy)) //收到數(shù)據(jù), 發(fā)送空閑
{
SBUF = RX1_Buffer[TX1_Cnt];
B_TX1_Busy = 1;
if(++TX1_Cnt >= UART1_BUF_LENGTH) TX1_Cnt = 0;
}
if((TX2_Cnt != RX2_Cnt) && (!B_TX2_Busy)) //收到數(shù)據(jù), 發(fā)送空閑
{
S2BUF = RX2_Buffer[TX2_Cnt];
B_TX2_Busy = 1;
if(++TX2_Cnt >= UART2_BUF_LENGTH) TX2_Cnt = 0;
}
}
}
//========================================================================
// 函數(shù): void PrintString1(u8 *puts)
// 描述: 串口1發(fā)送字符串函數(shù)。
// 參數(shù): puts: 字符串指針.
// 返回: none.
// 版本: VER1.0
// 日期: 2014-11-28
// 備注:
//========================================================================
void PrintString1(u8 *puts)
{
for (; *puts != 0; puts++) //遇到停止符0結(jié)束
{
SBUF = *puts;
B_TX1_Busy = 1;
while(B_TX1_Busy);
}
}
//========================================================================
// 函數(shù): void PrintString2(u8 *puts)
// 描述: 串口2發(fā)送字符串函數(shù)。
// 參數(shù): puts: 字符串指針.
// 返回: none.
// 版本: VER1.0
// 日期: 2014-11-28
// 備注:
//========================================================================
void PrintString2(u8 *puts)
{
for (; *puts != 0; puts++) //遇到停止符0結(jié)束
{
S2BUF = *puts;
B_TX2_Busy = 1;
while(B_TX2_Busy);
}
}
//========================================================================
// 函數(shù): SetTimer2Baudraye(u16 dat)
// 描述: 設(shè)置Timer2做波特率發(fā)生器。
// 參數(shù): dat: Timer2的重裝值.
// 返回: none.
// 版本: VER1.0
// 日期: 2014-11-28
// 備注:
//========================================================================
void SetTimer2Baudraye(u16 dat)
{
AUXR &= ~(1<<4); //Timer stop
AUXR &= ~(1<<3); //Timer2 set As Timer
AUXR |= (1<<2); //Timer2 set as 1T mode
TH2 = dat / 256;
TL2 = dat % 256;
IE2 &= ~(1<<2); //禁止中斷
AUXR |= (1<<4); //Timer run enable
}
//========================================================================
// 函數(shù): void UART1_config(u8 brt)
// 描述: UART1初始化函數(shù)。
// 參數(shù): brt: 選擇波特率, 2: 使用Timer2做波特率, 其它值: 使用Timer1做波特率.
// 返回: none.
// 版本: VER1.0
// 日期: 2014-11-28
// 備注:
//========================================================================
void UART1_config(u8 brt)
{
/*********** 波特率使用定時器2 *****************/
if(brt == 2)
{
AUXR |= 0x01; //S1 BRT Use Timer2;
SetTimer2Baudraye(65536UL - (MAIN_Fosc / 4) / Baudrate1);
}
/*********** 波特率使用定時器1 *****************/
else
{
TR1 = 0;
AUXR &= ~0x01; //S1 BRT Use Timer1;
AUXR |= (1<<6); //Timer1 set as 1T mode
TMOD &= ~(1<<6); //Timer1 set As Timer
TMOD &= ~0x30; //Timer1_16bitAutoReload;
TH1 = (u8)((65536UL - (MAIN_Fosc / 4) / Baudrate1) / 256);
TL1 = (u8)((65536UL - (MAIN_Fosc / 4) / Baudrate1) % 256);
ET1 = 0; //禁止中斷
INT_CLKO &= ~0x02; //不輸出時鐘
TR1 = 1;
}
/*************************************************/
SCON = (SCON & 0x3f) | 0x40; //UART1模式, 0x00: 同步移位輸出, 0x40: 8位數(shù)據(jù),可變波特率, 0x80: 9位數(shù)據(jù),固定波特率, 0xc0: 9位數(shù)據(jù),可變波特率
// PS = 1; //高優(yōu)先級中斷
ES = 1; //允許中斷
REN = 1; //允許接收
P_SW1 &= 0x3f;
P_SW1 |= 0x80; //UART1 switch to, 0x00: P3.0 P3.1, 0x40: P3.6 P3.7, 0x80: P1.6 P1.7 (必須使用內(nèi)部時鐘)
// PCON2 |= (1<<4); //內(nèi)部短路RXD與TXD, 做中繼, ENABLE,DISABLE
B_TX1_Busy = 0;
TX1_Cnt = 0;
RX1_Cnt = 0;
}
//========================================================================
// 函數(shù): void UART2_config(u8 brt)
// 描述: UART2初始化函數(shù)。
// 參數(shù): brt: 選擇波特率, 2: 使用Timer2做波特率, 其它值: 無效.
// 返回: none.
// 版本: VER1.0
// 日期: 2014-11-28
// 備注:
//========================================================================
void UART2_config(u8 brt) // 選擇波特率, 2: 使用Timer2做波特率, 其它值: 無效.
{
if(brt == 2)
{
SetTimer2Baudraye(65536UL - (MAIN_Fosc / 4) / Baudrate2);
S2CON &= ~(1<<7); // 8位數(shù)據(jù), 1位起始位, 1位停止位, 無校驗
IE2 |= 1; //允許中斷
S2CON |= (1<<4); //允許接收
P_SW2 &= ~0x01;
P_SW2 |= 1; //UART2 switch to: 0: P1.0 P1.1, 1: P4.6 P4.7
B_TX2_Busy = 0;
TX2_Cnt = 0;
RX2_Cnt = 0;
}
}
//========================================================================
// 函數(shù): void UART1_int (void) interrupt UART1_VECTOR
// 描述: UART1中斷函數(shù)。
// 參數(shù): nine.
// 返回: none.
// 版本: VER1.0
// 日期: 2014-11-28
// 備注:
//========================================================================
void UART1_int (void) interrupt UART1_VECTOR
{
if(RI)
{
RI = 0;
RX1_Buffer[RX1_Cnt] = SBUF;
if(++RX1_Cnt >= UART1_BUF_LENGTH) RX1_Cnt = 0;
}
if(TI)
{
TI = 0;
B_TX1_Busy = 0;
}
}
//========================================================================
// 函數(shù): void UART2_int (void) interrupt UART2_VECTOR
// 描述: UART2中斷函數(shù)。
// 參數(shù): nine.
// 返回: none.
// 版本: VER1.0
// 日期: 2014-11-28
// 備注:
//========================================================================
void UART2_int (void) interrupt UART2_VECTOR
{
if((S2CON & 1) != 0)
{
S2CON &= ~1; //Clear Rx flag
RX2_Buffer[RX2_Cnt] = S2BUF;
if(++RX2_Cnt >= UART2_BUF_LENGTH) RX2_Cnt = 0;
}
…………限于本文篇幅 余下代碼請從51黑下載附件…………
復(fù)制代碼
下載:
C語言.rar
(20.45 KB, 下載次數(shù): 117)
2017-4-7 18:21 上傳
點擊文件名下載附件
雙串口中斷收發(fā)
下載積分: 黑幣 -5
作者:
koenlee93
時間:
2017-12-27 11:00
標記謝謝分享
作者:
koenlee93
時間:
2017-12-27 11:03
我要測試下這個可不可以用
作者:
ylg9988
時間:
2017-12-28 15:31
謝謝!謝謝!非常感謝!
作者:
ylg9988
時間:
2017-12-28 15:31
我正要找 這個,可不可以用?
作者:
ylg9988
時間:
2017-12-28 15:32
謝謝謝謝!非常感謝!!
作者:
shui0419
時間:
2018-5-7 16:29
謝謝謝謝!非常感謝!
作者:
無常
時間:
2018-5-8 15:24
謝謝分享,初學(xué)很懵逼
作者:
lisgo
時間:
2018-5-29 19:50
無常 發(fā)表于 2018-5-8 15:24
謝謝分享,初學(xué)很懵逼
要測試下這個可不可以用
作者:
aking991
時間:
2018-7-12 08:51
謝謝分享,幫助很大,謝謝
作者:
Gredicer
時間:
2018-7-31 09:52
謝謝分享
作者:
bhjyqjs
時間:
2018-8-1 10:40
學(xué)習(xí)了,謝謝分享!
作者:
aj8714523
時間:
2018-9-29 18:19
謝謝分享,正在找相關(guān)資料呢!
作者:
stonenb
時間:
2018-11-27 10:44
謝謝提供,測試看看...
作者:
ghbwxt
時間:
2019-5-24 09:38
謝謝分享,收獲很大
作者:
nishuideyu45
時間:
2019-5-26 16:24
謝謝,學(xué)習(xí)了
作者:
optiplex
時間:
2019-7-1 08:27
非常感謝,正在被這個串口2收發(fā)問題困擾,趕緊下下來測試。
作者:
二名
時間:
2019-8-7 11:39
標記,下載測試下
作者:
wangfubin
時間:
2022-9-12 14:47
#include "UART.h"
#include "Key.h"
#include "Record.h"
uint8_t Rcv_Buf[RCV_LENGTH];
uint8_t Snd_Buf[SND_LENGTH];
volatile uint8_t recvbyte=0;
uint8_t RcvFlag = 0;
volatile uint16_t ScanTimeMs;
volatile uint16_t SysOverTime;
uint8_t InitStartEnable;
uint8_t SendAdd;
uint16_t SysCallStatus1=0;
uint16_t SysCallStatus2=0;
uint16_t SysCallStatus1Bak=0;
uint16_t SysCallStatus2Bak=0;
uint16_t alarm = 0;
bit MyAddStart;
bit Over1min;
bit OverTimeFlag;
bit OtherMaster;
bit OtherMasterChecked;
volatile uint16_t DisableSendTimeMs;
volatile uint16_t u16_OverTimeMs;
void UART1_ISR() interrupt 4 using 1
{
if(RI)
{
RI = 0;
SysOverTime = 0;
UartErr = 0;
Rcv_Buf[recvbyte] = SBUF; //接收數(shù)據(jù)
if(Rcv_Buf[0] == 0x53)
{
recvbyte++;
}
if((Rcv_Buf[recvbyte-1]==0x0a) && (Rcv_Buf[recvbyte-2]==0x0d)) //接收到幀尾
{
RcvFlag = 1; //置位接收標志
recvbyte = 0; //接收下標清零
}
}
}
void Uart1_Init(void)
{
// SCON = 0x50;
// TMOD &= 0x0f;
//
// TH1 = BAUD>>8;
// TL1 = BAUD;
//
// TR1 = 1;
// AUXR |= 0x40;
// ES = 1;
// EA = 1;
//
//
// RS485_RcevEnable();
TR1 = 0;
AUXR &= ~0x01; //S1 BRT Use Timer1;
AUXR |= (1<<6); //Timer1 set as 1T mode
TMOD &= ~(1<<6); //Timer1 set As Timer
TMOD &= ~0x30; //Timer1_16bitAutoReload;
TH1 = (uint8_t)(BAUD >> 8);
TL1 = (uint8_t)BAUD;
ET1 = 0; // 禁止Timer1中斷
// INT_CLKO &= ~0x02; // Timer1不輸出高速時鐘
// INT_CLKO |= 0x02; // Timer1輸出高速時鐘
TR1 = 1; // 運行Timer1
SCON = (SCON & 0x3f) | (1<<6); // 8位數(shù)據(jù), 1位起始位, 1位停止位, 無校驗
// PS = 1; //高優(yōu)先級中斷
ES = 1; //允許中斷
REN = 1; //允許接收
// if(MasterAdd !=0)
// {
// MyAddStart = 0;
// }
OtherMaster = 1;
OtherMasterChecked = 0;
DisableSendTimeMs = 0;
SysOverTime = 0;
Over1min = 0;
RS485_RcevEnable();
}
void UART1_Send_Char(unsigned char c)
{
RS485_SendEnable();
_nop_();
_nop_();
_nop_();
SBUF = c;
while(!TI);
TI = 0;
_nop_();
_nop_();
_nop_();
RS485_RcevEnable();
}
void UART1_Send_String(unsigned char *s)
{
while(*s)
{
UART1_Send_Char(*s++);
}
}
void UART1_Send_Int(unsigned int c)
{
UART1_Send_Char(c/10000+0x30);
UART1_Send_Char(c%10000/1000+0x30);
UART1_Send_Char(c%1000/100+0x30);
UART1_Send_Char(c%100/10+0x30);
UART1_Send_Char(c%10+0x30);
UART1_Send_Char(0x0d);
UART1_Send_Char(0x0a);
}
void UART1_Send_Buf(unsigned char *s,unsigned char len)
{
unsigned char i;
for(i=0;i<len;i++)
{
UART1_Send_Char(s[i]);
}
}
void UART_Timer_Ms(void)
{
SysOverTime++;
if(SysOverTime > 10000)
{
UartErr = 1;
MyAddStart = InitStartEnable;
ScanTimeMs = 0;
}
if(MyAddStart)
{
ScanTimeMs++;
請教一下,這個程序中初始波特率是多少呢
歡迎光臨 (http://www.torrancerestoration.com/bbs/)
Powered by Discuz! X3.1