upD79F8513A(NEC)或upD78F0511A(NEC)之串口0中斷髮送和接收數據




本篇博文最後修改時間: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;
}

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章