您的位置:首页 > 其它

upD79F8513A(NEC)或upD78F0511A(NEC)之串口0中断发送和接收数据

2017-10-10 18:49 627 查看
本篇博文最后修改时间: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 :951795235@qq.com

懵懂之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;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  单片机