本篇博文最后修改时间: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
懵懂之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;
}