本篇博文最後修改時間:2017年10月10日 18:49。
一、簡介
本文以upD79F8513A(NEC)或upD78F0511A(NEC)編程爲例,介紹upD79F8513A(NEC)或upD78F0511A(NEC)之串口0接收發送數據。
二、實驗平臺
電腦平臺:Windows7 64位旗艦
編譯軟件:IAR
硬件平臺:upD79F8513A(NEC)或upD78F0511A(NEC)
三、版權聲明
博主:_懵懂
聲明:此博客僅供參考不做任何商業用途,最終解釋權歸原博主所有。
原文地址:http://blog.csdn.NET/qq_18842031
QQ:951795235
E-mail :[email protected]
懵懂之MCU交流羣:136384801
四、實驗前提
1、在進行本文步驟前,請先安裝IAR4.70.1.50025版本;準備好upD79F8513A(NEC)或upD78F0511A(NEC)硬件平臺。
五、基礎知識
暫無
六、源碼地址
暫無
七、關聯文章
系統時鐘鏈接:http://blog.csdn.net/qq_18842031/article/details/77984026
電源檢測鏈接:http://blog.csdn.net/qq_18842031/article/details/78185589
八、實驗內容
1.初始化串口0
/*********************************************************************
* @fn Init_Uart0()
*
* @brief 初始化串口 偶校驗 8位 停止位 1 起始位 1 ASIM0=0x1D; 波特率:4800 BRGC0=0xDA 波特率:9600 BRGC0=0xCD
*
* @param None.
*
* @return None.
********************************************************************/
void Init_Uart0(void)
{
PM1 |= 0x02;
P1 |= 0x01;
PM1 &= ~0x01;
ASIM0 = 0x01;
BRGC0 = 0xCD; // K 4.9152M 16 0xD0 \ 8M 26 0xDA
ASIM0 = 0x05; // 無校驗位 8位 停止1位
POWER0= 1; //允許內部時鐘操作
W5NOP();W5NOP();W5NOP();W5NOP();W5NOP();
STIF0 = 0;
TXE0 = 1; //允許發送
SRIF0 = 0;
RXE0 = 1; //允許接收
SRMK0 = 0; //中斷屏蔽標誌 1:屏蔽中斷,0:允許中斷
STMK0 = 1;
W5NOP();
}
2.單字節發送函數
/*********************************************************************
* @fn Send_UartByte0()
*
* @brief 串口0中斷髮送數據位
*
* @param data.
*
* @return None.
********************************************************************/
static void Send_UartByte0(uint8 data)
{
TXS0 = data; //
}
3.中斷髮送函數
/*********************************************************************
* @fn Set_InterruptUart0Str()
*
* @brief 串口中斷髮送
*
* @param data len.
*
* @return None.
********************************************************************/
void Set_InterruptUart0Str(unsigned char *data,unsigned char len)
{
uint8 i;
TxdLen0 = len; //記錄發送數據長度
for(i = 0; i < len; i++) //記錄數據
{
TxdData0[i] = data[1+i];
}
RXE0 = 0; //禁止接收數據
SRMK0 = 1;
TXE0 = 1; //允許發送數據
STMK0 = 0;
P1 |= 0x01; //發送引腳拉高電頻
DeleyMs(1);
TXS0 = data[0]; //發送一個數據頭 啓動發送
}
4.編寫主函數
#include <io78f0511_44.h>
#include <intrinsics.h>
#define DI() __disable_interrupt() /*關中斷*/
#define EI() __enable_interrupt() /*開中斷*/
#define NOP() __no_operation() /*空指令*/
#define W5NOP() NOP();NOP();NOP();NOP();NOP() /*5個空指令*/
unsigned char TxdData0[200];
unsigned char TxdLen0;
void main(void)
{
Init_OST(); /*初始化系統時鐘*/
Init_LVI(); /*低電壓檢測*/
Init_Uart0(); /*初始化串口0*/
Send_UartByte0(5);/*查詢發送*/
Set_InterruptUart0Str("Hi",2);/*中斷髮送*/
while(1)
{
WDTE = 0xAC; /*clear and start watchdog timer */
}
}
5.編寫中斷髮送服務
/*********************************************************************
* @fn INT_ST0()
*
* @brief 串口0發送中斷
*
* @param 隱輸入.
*
* @return None.
********************************************************************/
#pragma vector=INTST0_vect
__interrupt void INT_ST0(void)
{
static uint8 count;
Send_UartByte0(TxdData0[count++]);
if(count > TxdLen0) //發送數據的長度和需要發送數據的長度相等 就關閉發送中斷
{
count = 0;
VOID memset(TxdData0,0,TxdLen0);
TxdLen0 = 0;
RXE0 = 1;
SRMK0 = 0;
TXE0 = 0; //禁止 發送
STMK0 = 1;
P1 &= ~0x01;
}
return;
}
6.編寫中斷接收服務函數
/*********************************************************************
* @fn INT_SR0()
*
* @brief 串口0接收中斷
*
* @param None.
*
* @return 隱輸出.
********************************************************************/
#pragma vector=INTSR0_vect
__interrupt void INT_SR0(void)
{
uint8 byte;//當次數據
if(ASIS0 != 0)
byte = ASIS0;
byte = RXB0;
}