C51 COMPILER V9.59.0.0 UART 03/09/2021 14:07:07 PAGE 1 C51 COMPILER V9.59.0.0, COMPILATION OF MODULE UART OBJECT MODULE PLACED IN .\list\UART.obj COMPILER INVOKED BY: C:\Keil_v5\C51\BIN\C51.EXE UART.C OPTIMIZE(8,SPEED) BROWSE DEBUG OBJECTEXTEND PRINT(.\list\UART.lst -) TABS(2) OBJECT(.\list\UART.obj) line level source 1 /*---------------------------------------------------------------------*/ 2 /* --- STC MCU Limited ------------------------------------------------*/ 3 /* --- STC 1T Series MCU Demo Programme -------------------------------*/ 4 /* --- Mobile: (86)13922805190 ----------------------------------------*/ 5 /* --- Fax: 86-0513-55012956,55012947,55012969 ------------------------*/ 6 /* --- Tel: 86-0513-55012928,55012929,55012966 ------------------------*/ 7 /* --- Web: www.STCMCU.com --------------------------------------------*/ 8 /* --- Web: www.STCMCUDATA.com ---------------------------------------*/ 9 /* --- QQ: 800003751 -------------------------------------------------*/ 10 /* 如果要在程序中使用此代码,请在程序中注明使用了STC的资料及程序 */ 11 /*---------------------------------------------------------------------*/ 12 13 #include "UART.h" 14 15 16 #ifdef UART1 17 COMx_Define COM1; 18 u8 xdata TX1_Buffer[COM_TX1_Lenth]; //发送缓冲 19 u8 xdata RX1_Buffer[COM_RX1_Lenth]; //接收缓冲 20 #endif 21 #ifdef UART2 COMx_Define COM2; u8 xdata TX2_Buffer[COM_TX2_Lenth]; //发送缓冲 u8 xdata RX2_Buffer[COM_RX2_Lenth]; //接收缓冲 #endif 26 #ifdef UART3 COMx_Define COM3; u8 xdata TX3_Buffer[COM_TX3_Lenth]; //发送缓冲 u8 xdata RX3_Buffer[COM_RX3_Lenth]; //接收缓冲 #endif 31 #ifdef UART4 COMx_Define COM4; u8 xdata TX4_Buffer[COM_TX4_Lenth]; //发送缓冲 u8 xdata RX4_Buffer[COM_RX4_Lenth]; //接收缓冲 #endif 36 37 u8 UART_Configuration(u8 UARTx, COMx_InitDefine *COMx) 38 { 39 1 u8 i; 40 1 u32 j; 41 1 42 1 #ifdef UART1 43 1 if(UARTx == UART1) 44 1 { 45 2 COM1.id = 1; 46 2 COM1.TX_read = 0; 47 2 COM1.TX_write = 0; 48 2 COM1.B_TX_busy = 0; 49 2 COM1.RX_Cnt = 0; 50 2 COM1.RX_TimeOut = 0; 51 2 COM1.B_RX_OK = 0; 52 2 for(i=0; iUART_Polity > Polity_3) return 2; //错误 56 2 UART1_Polity(COMx->UART_Polity); //指定中断优先级(低到高) Polity_0,Polity_1,Polity_2,Polity_3 57 2 if(COMx->UART_Mode > UART_9bit_BRTx) return 2; //模式错误 58 2 SCON = (SCON & 0x3f) | COMx->UART_Mode; 59 2 if((COMx->UART_Mode == UART_9bit_BRTx) || (COMx->UART_Mode == UART_8bit_BRTx)) //可变波特率 60 2 { 61 3 j = (MAIN_Fosc / 4) / COMx->UART_BaudRate; //按1T计算 62 3 if(j >= 65536UL) return 2; //错误 63 3 j = 65536UL - j; 64 3 if(COMx->UART_BRT_Use == BRT_Timer1) 65 3 { 66 4 TR1 = 0; 67 4 AUXR &= ~0x01; //S1 BRT Use Timer1; 68 4 TMOD &= ~(1<<6); //Timer1 set As Timer 69 4 TMOD &= ~0x30; //Timer1_16bitAutoReload; 70 4 AUXR |= (1<<6); //Timer1 set as 1T mode 71 4 TH1 = (u8)(j>>8); 72 4 TL1 = (u8)j; 73 4 ET1 = 0; //禁止中断 74 4 TMOD &= ~0x40; //定时 75 4 INT_CLKO &= ~0x02; //不输出时钟 76 4 TR1 = 1; 77 4 } 78 3 else if(COMx->UART_BRT_Use == BRT_Timer2) 79 3 { 80 4 AUXR &= ~(1<<4); //Timer stop 81 4 AUXR |= 0x01; //S1 BRT Use Timer2; 82 4 AUXR &= ~(1<<3); //Timer2 set As Timer 83 4 AUXR |= (1<<2); //Timer2 set as 1T mode 84 4 TH2 = (u8)(j>>8); 85 4 TL2 = (u8)j; 86 4 IE2 &= ~(1<<2); //禁止中断 87 4 AUXR |= (1<<4); //Timer run enable 88 4 } 89 3 else return 2; //错误 90 3 } 91 2 else if(COMx->UART_Mode == UART_ShiftRight) 92 2 { 93 3 if(COMx->BaudRateDouble == ENABLE) AUXR |= (1<<5); //固定波特率SysClk/2 94 3 else AUXR &= ~(1<<5); //固定波特率SysClk/12 95 3 } 96 2 else if(COMx->UART_Mode == UART_9bit) //固定波特率SysClk*2^SMOD/64 97 2 { 98 3 if(COMx->BaudRateDouble == ENABLE) PCON |= (1<<7); //固定波特率SysClk/32 99 3 else PCON &= ~(1<<7); //固定波特率SysClk/64 100 3 } 101 2 if(COMx->UART_Interrupt == ENABLE) ES = 1; //允许中断 102 2 else ES = 0; //禁止中断 103 2 if(COMx->UART_RxEnable == ENABLE) REN = 1; //允许接收 104 2 else REN = 0; //禁止接收 105 2 P_SW1 = (P_SW1 & 0x3f) | (COMx->UART_P_SW & 0xc0); //切换IO 106 2 return 0; 107 2 } 108 1 #endif 109 1 #ifdef UART2 if(UARTx == UART2) { COM2.id = 2; COM2.TX_read = 0; COM2.TX_write = 0; COM2.B_TX_busy = 0; COM2.RX_Cnt = 0; C51 COMPILER V9.59.0.0 UART 03/09/2021 14:07:07 PAGE 3 COM2.RX_TimeOut = 0; COM2.B_RX_OK = 0; for(i=0; iUART_Mode == UART_9bit_BRTx) ||(COMx->UART_Mode == UART_8bit_BRTx)) //可变波特率 { if(COMx->UART_Polity > Polity_3) return 2; //错误 UART2_Polity(COMx->UART_Polity); //指定中断优先级(低到高) Polity_0,Polity_1,Polity_2,Polity_3 if(COMx->UART_Mode == UART_9bit_BRTx) S2CON |= (1<<7); //9bit else S2CON &= ~(1<<7); //8bit j = (MAIN_Fosc / 4) / COMx->UART_BaudRate; //按1T计算 if(j >= 65536UL) return 2; //错误 j = 65536UL - j; AUXR &= ~(1<<4); //Timer stop AUXR &= ~(1<<3); //Timer2 set As Timer AUXR |= (1<<2); //Timer2 set as 1T mode TH2 = (u8)(j>>8); TL2 = (u8)j; IE2 &= ~(1<<2); //禁止中断 AUXR |= (1<<4); //Timer run enable } else return 2; //模式错误 if(COMx->UART_Interrupt == ENABLE) IE2 |= 1; //允许中断 else IE2 &= ~1; //禁止中断 if(COMx->UART_RxEnable == ENABLE) S2CON |= (1<<4); //允许接收 else S2CON &= ~(1<<4); //禁止接收 P_SW2 = (P_SW2 & ~1) | (COMx->UART_P_SW & 0x01); //切换IO return 0; } #endif 148 1 #ifdef UART3 if(UARTx == UART3) { COM3.id = 3; COM3.TX_read = 0; COM3.TX_write = 0; COM3.B_TX_busy = 0; COM3.RX_Cnt = 0; COM3.RX_TimeOut = 0; COM3.B_RX_OK = 0; for(i=0; iUART_Mode == UART_9bit_BRTx) || (COMx->UART_Mode == UART_8bit_BRTx)) //可变波特率 { if(COMx->UART_Polity > Polity_3) return 2; //错误 UART3_Polity(COMx->UART_Polity); //指定中断优先级(低到高) Polity_0,Polity_1,Polity_2,Polity_3 if(COMx->UART_Mode == UART_9bit_BRTx) S3_9bit(); //9bit else S3_8bit(); //8bit j = (MAIN_Fosc / 4) / COMx->UART_BaudRate; //按1T计算 if(j >= 65536UL) return 2; //错误 j = 65536UL - j; if(COMx->UART_BRT_Use == BRT_Timer3) { S3_BRT_UseTimer3(); //S3 BRT Use Timer3; TH3 = (u8)(j>>8); TL3 = (u8)j; T4T3M &= 0xf0; T4T3M |= 0x0a; //Timer3 set As Timer, 1T mode, Start timer3 } else if(COMx->UART_BRT_Use == BRT_Timer2) C51 COMPILER V9.59.0.0 UART 03/09/2021 14:07:07 PAGE 4 { AUXR &= ~(1<<4); //Timer stop S3_BRT_UseTimer2(); //S3 BRT Use Timer2; AUXR &= ~(1<<3); //Timer2 set As Timer AUXR |= (1<<2); //Timer2 set as 1T mode TH2 = (u8)(j>>8); TL2 = (u8)j; IE2 &= ~(1<<2); //禁止中断 AUXR |= (1<<4); //Timer run enable } else return 2; //错误 } else return 2; //模式错误 if(COMx->UART_Interrupt == ENABLE) S3_Int_Enable(); //允许中断 else S3_Int_Disable(); //禁止中断 if(COMx->UART_RxEnable == ENABLE) S3_RX_Enable(); //允许接收 else S3_RX_Disable(); //禁止接收 P_SW2 = (P_SW2 & ~2) | (COMx->UART_P_SW & 0x02); //切换IO return 0; } #endif 200 1 #ifdef UART4 if(UARTx == UART4) { COM4.id = 3; COM4.TX_read = 0; COM4.TX_write = 0; COM4.B_TX_busy = 0; COM4.RX_Cnt = 0; COM4.RX_TimeOut = 0; COM4.B_RX_OK = 0; for(i=0; iUART_Mode == UART_9bit_BRTx) || (COMx->UART_Mode == UART_8bit_BRTx)) //可变波特率 { if(COMx->UART_Polity > Polity_3) return 2; //错误 UART4_Polity(COMx->UART_Polity); //指定中断优先级(低到高) Polity_0,Polity_1,Polity_2,Polity_3 if(COMx->UART_Mode == UART_9bit_BRTx) S4_9bit(); //9bit else S4_8bit(); //8bit j = (MAIN_Fosc / 4) / COMx->UART_BaudRate; //按1T计算 if(j >= 65536UL) return 2; //错误 j = 65536UL - j; if(COMx->UART_BRT_Use == BRT_Timer4) { S4_BRT_UseTimer4(); //S4 BRT Use Timer4; TH4 = (u8)(j>>8); TL4 = (u8)j; T4T3M &= 0x0f; T4T3M |= 0xa0; //Timer4 set As Timer, 1T mode, Start timer4 } else if(COMx->UART_BRT_Use == BRT_Timer2) { AUXR &= ~(1<<4); //Timer stop S4_BRT_UseTimer2(); //S4 BRT Use Timer2; AUXR &= ~(1<<3); //Timer2 set As Timer AUXR |= (1<<2); //Timer2 set as 1T mode TH2 = (u8)(j>>8); TL2 = (u8)j; IE2 &= ~(1<<2); //禁止中断 AUXR |= (1<<4); //Timer run enable } C51 COMPILER V9.59.0.0 UART 03/09/2021 14:07:07 PAGE 5 else return 2; //错误 } else return 2; //模式错误 if(COMx->UART_Interrupt == ENABLE) S4_Int_Enable(); //允许中断 else S4_Int_Disable(); //禁止中断 if(COMx->UART_RxEnable == ENABLE) S4_RX_Enable(); //允许接收 else S4_RX_Disable(); //禁止接收 P_SW2 = (P_SW2 & ~4) | (COMx->UART_P_SW & 0x04); //切换IO return 0; } #endif 252 1 return 2; //错误 253 1 } 254 255 /*********************************************************/ 256 257 /********************* UART1 函数 ************************/ 258 #ifdef UART1 259 void TX1_write2buff(u8 dat) //写入发送缓冲,指针+1 260 { 261 1 TX1_Buffer[COM1.TX_write] = dat; //装发送缓冲 262 1 if(++COM1.TX_write >= COM_TX1_Lenth) COM1.TX_write = 0; 263 1 264 1 if(COM1.B_TX_busy == 0) //空闲 265 1 { 266 2 COM1.B_TX_busy = 1; //标志忙 267 2 TI = 1; //触发发送中断 268 2 } 269 1 } 270 271 void PrintString1(u8 *puts) 272 { 273 1 for (; *puts != 0; puts++) TX1_write2buff(*puts); //遇到停止符0结束 274 1 } 275 276 void UART1_int (void) interrupt UART1_VECTOR 277 { 278 1 if(RI) 279 1 { 280 2 RI = 0; 281 2 if(COM1.B_RX_OK == 0) 282 2 { 283 3 if(COM1.RX_Cnt >= COM_RX1_Lenth) COM1.RX_Cnt = 0; 284 3 RX1_Buffer[COM1.RX_Cnt++] = SBUF; 285 3 COM1.RX_TimeOut = TimeOutSet1; 286 3 } 287 2 } 288 1 289 1 if(TI) 290 1 { 291 2 TI = 0; 292 2 if(COM1.TX_read != COM1.TX_write) 293 2 { 294 3 SBUF = TX1_Buffer[COM1.TX_read]; 295 3 if(++COM1.TX_read >= COM_TX1_Lenth) COM1.TX_read = 0; 296 3 } 297 2 else COM1.B_TX_busy = 0; 298 2 } 299 1 } 300 #endif 301 302 /********************* UART2 函数 ************************/ C51 COMPILER V9.59.0.0 UART 03/09/2021 14:07:07 PAGE 6 303 #ifdef UART2 void TX2_write2buff(u8 dat) //写入发送缓冲,指针+1 { TX2_Buffer[COM2.TX_write] = dat; //装发送缓冲 if(++COM2.TX_write >= COM_TX2_Lenth) COM2.TX_write = 0; if(COM2.B_TX_busy == 0) //空闲 { COM2.B_TX_busy = 1; //标志忙 SET_TI2(); //触发发送中断 } } void PrintString2(u8 *puts) { for (; *puts != 0; puts++) TX2_write2buff(*puts); //遇到停止符0结束 } void UART2_int (void) interrupt UART2_VECTOR { if(RI2) { CLR_RI2(); if(COM2.B_RX_OK == 0) { if(COM2.RX_Cnt >= COM_RX2_Lenth) COM2.RX_Cnt = 0; RX2_Buffer[COM2.RX_Cnt++] = S2BUF; COM2.RX_TimeOut = TimeOutSet2; } } if(TI2) { CLR_TI2(); if(COM2.TX_read != COM2.TX_write) { S2BUF = TX2_Buffer[COM2.TX_read]; if(++COM2.TX_read >= COM_TX2_Lenth) COM2.TX_read = 0; } else COM2.B_TX_busy = 0; } } #endif 346 347 /********************* UART3 函数 ************************/ 348 #ifdef UART3 void TX3_write2buff(u8 dat) //写入发送缓冲,指针+1 { TX3_Buffer[COM3.TX_write] = dat; //装发送缓冲 if(++COM3.TX_write >= COM_TX3_Lenth) COM3.TX_write = 0; if(COM3.B_TX_busy == 0) //空闲 { COM3.B_TX_busy = 1; //标志忙 SET_TI3(); //触发发送中断 } } void PrintString3(u8 *puts) { for (; *puts != 0; puts++) TX3_write2buff(*puts); //遇到停止符0结束 } C51 COMPILER V9.59.0.0 UART 03/09/2021 14:07:07 PAGE 7 void UART3_int (void) interrupt UART3_VECTOR { if(RI3) { CLR_RI3(); if(COM3.B_RX_OK == 0) { if(COM3.RX_Cnt >= COM_RX3_Lenth) COM3.RX_Cnt = 0; RX3_Buffer[COM3.RX_Cnt++] = S3BUF; COM3.RX_TimeOut = TimeOutSet3; } } if(TI3) { CLR_TI3(); if(COM3.TX_read != COM3.TX_write) { S3BUF = TX3_Buffer[COM3.TX_read]; if(++COM3.TX_read >= COM_TX3_Lenth) COM3.TX_read = 0; } else COM3.B_TX_busy = 0; } } #endif 391 392 /********************* UART4 函数 ************************/ 393 #ifdef UART4 void TX4_write2buff(u8 dat) //写入发送缓冲,指针+1 { TX4_Buffer[COM4.TX_write] = dat; //装发送缓冲 if(++COM4.TX_write >= COM_TX4_Lenth) COM4.TX_write = 0; if(COM4.B_TX_busy == 0) //空闲 { COM4.B_TX_busy = 1; //标志忙 SET_TI4(); //触发发送中断 } } void PrintString4(u8 *puts) { for (; *puts != 0; puts++) TX4_write2buff(*puts); //遇到停止符0结束 } void UART4_int (void) interrupt UART4_VECTOR { if(RI4) { CLR_RI4(); if(COM4.B_RX_OK == 0) { if(COM4.RX_Cnt >= COM_RX4_Lenth) COM4.RX_Cnt = 0; RX4_Buffer[COM4.RX_Cnt++] = S4BUF; COM4.RX_TimeOut = TimeOutSet4; } } if(TI4) { CLR_TI4(); C51 COMPILER V9.59.0.0 UART 03/09/2021 14:07:07 PAGE 8 if(COM4.TX_read != COM4.TX_write) { S4BUF = TX4_Buffer[COM4.TX_read]; if(++COM4.TX_read >= COM_TX4_Lenth) COM4.TX_read = 0; } else COM4.B_TX_busy = 0; } } #endif 436 437 /*********************************************************/ 438 /* 439 void COMx_write2buff(COMx_Define *COMx, u8 dat) //写入发送缓冲,指针+1 440 { 441 if(COMx->id == 1) TX1_write2buff(dat); 442 if(COMx->id == 2) TX2_write2buff(dat); 443 if(COMx->id == 3) TX3_write2buff(dat); 444 if(COMx->id == 4) TX4_write2buff(dat); 445 } 446 447 void PrintString(COMx_Define *COMx, u8 *puts) 448 { 449 for (; *puts != 0; puts++) COMx_write2buff(COMx,*puts); //遇到停止符0结束 450 } 451 */ MODULE INFORMATION: STATIC OVERLAYABLE CODE SIZE = 680 ---- CONSTANT SIZE = ---- ---- XDATA SIZE = 256 ---- PDATA SIZE = ---- ---- DATA SIZE = 7 7 IDATA SIZE = ---- ---- BIT SIZE = ---- ---- END OF MODULE INFORMATION. C51 COMPILATION COMPLETE. 0 WARNING(S), 0 ERROR(S)