当前位置:首页 > > 充电吧
[导读]使用IAR驱动CC2530的串口0,串口1,实现数据发送以及printf,中断接收数据uart.c/**************************************************

使用IAR驱动CC2530的串口0,串口1,实现数据发送以及printf,中断接收数据



uart.c


/*************************************************************************************************************
 * 文件名:	uart.c
 * 功能:	CC2530 串口相关函数
 * 作者:	cp1300@139.com
* 创建时间:	2013-06-07 21:33
 * 最后修改时间:2013-06-07
 * 详细:	串口相关函数
			串口最大时钟为系统时钟的1/16
*************************************************************************************************************/
#include "system.h"
#include "uart.h"



//相关UART状态结构
typedef struct
{
	u8			BuffFull;	//接收Buff满
	u8 			*RxBuff;	//接收Buff指针
	u16			RxBuffSize;	//接收缓冲区大小,一帧数据大小
	u16 		UartRxCnt;	//接收数据计数器
} UartRx_TypeDef;

static UartRx_TypeDef	UART_RX[2];




static const u8 BAUD_M[11] = {59, 59, 59, 216, 59, 216, 59, 216, 59, 216, 216};		//32MHZ系统时钟对应的分频器小数部分
static const u8 BAUD_E[11] = {6, 7 ,8, 8, 9, 9, 10, 10, 11, 11, 12};                //32MHZ系统时钟对应的分频器指数部分


/*************************************************************************************************************************
*函数        :    	void UART_Init(UART_CH ch, USART_BAUD Baud, FunctionalState RxIntEn)
*功能        :		串口初始化
*参数        :    	ch:通道选择,UART_CH0,UART_CH1
					Baud:波特率控制,见USART_BAUD
					RxIntEn:ENABLE:使能串口接收中断
*返回        :	   无
*依赖        :		底层宏定义
*作者        :		cp1300@139.com
*时间        :		2013-05-20
*最后修改时间:		2013-06-11
*说明        :		一个起始位,8个数据位,一个停止位,无奇偶校验
					需要开启全局中断
*************************************************************************************************************************/
void UART_Init(UART_CH ch, USART_BAUD Baud, FunctionalState RxIntEn)
{
	switch(ch)
	{
		case UART_CH0:
		{
			U0CSR = BIT7 + BIT6;	//UART模式,使能接收	
			U0UCR = BIT1;			//无流控,无奇偶校验,8bit,1个停止位,停止位高电平,起始低电平
			U0GCR =  BAUD_E[Baud];	//波特率分频器指数部分
			U0BAUD =  BAUD_M[Baud];	//波特率分频器小数部分
			P0SEL |= BIT2 + BIT3; 	//P0.3 TXD,P0.2 RXD
			IEN2 &= ~(1 << 3);		//关闭发送中断
			URX0IF = 0;				//清除串口接收中断标志
			UTX0IF = 0;				//清除串口发送中断标志
			URX0IE = (RxIntEn == ENABLE) ? 1 : 0;  			//使能串口接收中断
		}break;
		case UART_CH1:
		{
			U1CSR = BIT7 + BIT6;	//UART模式,使能接收	
			U1UCR = BIT1;			//无流控,无奇偶校验,8bit,1个停止位,停止位高电平,起始低电平
			U1GCR =  BAUD_E[Baud];	//波特率分频器指数部分
			U1BAUD =  BAUD_M[Baud];	//波特率分频器小数部分
			P1SEL |= BIT4 + BIT5; 	//P0.5 TXD,P0.4 RXD
			URX1IF = 0;				//清除串口接收中断标志
			UTX1IF = 0;				//清除串口发送中断标志
			URX1IE = (RxIntEn == ENABLE) ? 1 : 0;  			//使能串口接收中断
		}break;
		default : return;
	}
	UART_SetRxBuff(ch, NULL, 0);	//初始化串口缓冲区无效
}



/*************************************************************************************************************************
*函数        	:	void UART_SendByte(UART_CH ch, u8 data)
*功能        	:	UART字节发送函数
*参数        	:	ch:通道选择,UART_CH0,UART_CH1
					data:需要发送的数据
*返回        	:	无
*依赖        	:	底层宏定义
*作者        	:	cp1300@139.com
*时间        	:	2013-06-11
*最后修改时间	:	2013-06-11
*说明        	:	无
*************************************************************************************************************************/
void UART_SendByte(UART_CH ch, u8 data)
{
	switch(ch)
	{
		case UART_CH0:
		{
			U0DBUF = data;        			//发送字节数据
			while(!(U0CSR & BIT1));			//等待发送数据寄存器为空				
			U0CSR &= ~BIT1;
		}break;
		case UART_CH1:
		{
			U1DBUF = data;        			//发送字节数据
			while(!(U1CSR & BIT1));			//等待发送数据寄存器为空				
			U1CSR &= ~BIT1;
		}break;
		default : break;
	}
}




/*************************************************************************************************************************
*函数        	:	void UART2_SendData(u8 *pbuff, u16 len)
*功能        	:	串口发送任意长度数据
*参数        	:	ch:通道选择,UART_CH0,UART_CH1
					pbuff:数据缓冲区指针,len:数据长度
*返回        	:	无
*依赖        	:	底层宏定义
*作者        	:	cp1300@139.com
*时间        	:	2013-06-11
*最后修改时间	:	2013-06-11
*说明        	:	无
*************************************************************************************************************************/
void UART_SendData(UART_CH ch, u8 *pbuff, u16 len)
{
	u16 i;
	
	switch(ch)
	{
		case UART_CH0:
		{
			for(i = 0;i < len;i ++)
			{
				U0DBUF = pbuff[i];        			//发送字节数据
				while(!(U0CSR & BIT1));			//等待发送数据寄存器为空				
				U0CSR &= ~BIT1;
			}
		}break;
		case UART_CH1:
		{
			for(i = 0;i < len;i ++)
			{
				U1DBUF = pbuff[i];        			//发送字节数据
				while(!(U1CSR & BIT1));			//等待发送数据寄存器为空				
				U1CSR &= ~BIT1;
			}
		}break;
		default : break;
	}
}



/*************************************************************************************************************************
* 函数			:	void UART2_SendString(UART_CH ch, const char *pStr)
* 功能			:	UART发送字符串
* 参数			:	ch:通道选择,UART_CH0,UART_CH1
					pStr:字符串指针
* 返回			:	无
* 依赖			:	底层宏定义
* 作者			:	cp1300@139.com
* 时间			:	2013-06-11
* 最后修改时间 	: 	2013-06-11
* 说明			: 	遇到'0'后停止发送
*************************************************************************************************************************/
void UART_SendString(UART_CH ch, const char *pStr)
{
	while(*pStr != '')
	{
		UART_SendByte(ch, *pStr ++);
	}
}


/*************************************************************************************************************************
* 函数			:	void UART_RxEnable(UART_CH ch, FunctionalState Enable)
* 功能			:	UART接收使能
* 参数			:	ch:通道选择,UART_CH0,UART_CH1
					Enable:ENABLE:使能接收,DISABLE:取消接收
* 返回			:	无
* 依赖			:	底层宏定义
* 作者			:	cp1300@139.com
* 时间			:	2013-06-11
* 最后修改时间 	: 	2013-06-11
* 说明			: 	无
*************************************************************************************************************************/
void UART_RxEnable(UART_CH ch, FunctionalState Enable)
{
	switch(ch)
	{
		case UART_CH0:
		{
			U0CSR = (Enable == ENABLE) ? (U0CSR|BIT6) : (U0CSR&(~BIT6));	//使能接收
		}break;
		case UART_CH1:
		{
			U1CSR = (Enable == ENABLE) ? (U1CSR|BIT6) : (U1CSR&(~BIT6));	//使能接收
		}break;
		default : break;
	}
}




//UART0中断服务程序
#pragma vector=URX0_VECTOR
__interrupt void UART0_IRQHandler(void)
{
	if(UART_RX[0].RxBuffSize > 0)										
	{
		UART_RX[0].RxBuff[UART_RX[0].UartRxCnt ++] = U0DBUF; 		
		if(UART_RX[0].UartRxCnt == UART_RX[0].RxBuffSize)				
		{
			 UART_RX[0].UartRxCnt = 0;							
			 UART_RX[0].BuffFull = 1;									
		}
	}
	else
	{
		URX0IF = 0;				//清除串口接收中断标志
	}
}




//UART1中断服务程序
#pragma vector=URX1_VECTOR
__interrupt void UART1_IRQHandler(void)
{
    if(UART_RX[1].RxBuffSize > 0)										
	{
		UART_RX[1].RxBuff[UART_RX[1].UartRxCnt ++] = U1DBUF; 		
		if(UART_RX[1].UartRxCnt == UART_RX[1].RxBuffSize)				
		{
			 UART_RX[1].UartRxCnt = 0;							
			 UART_RX[1].BuffFull = 1;									
		}
	}
	else
	{
		URX1IF = 0;				//清除串口接收中断标志
	}
}





/*************************************************************************************************************************
* 函数			:	bool UART_GetNewData(UART_CH ch, u8 *pData)
* 功能			:	获取串口新数据
* 参数			:	ch:通道选择,UART_CH0,UART_CH1
					pData:数据缓冲区指针
* 返回			:	TRUE:有新数据,FALSE:无新数据
* 依赖			:	底层宏定义
* 作者			:	cp1300@139.com
* 时间			:	2013-06-11
* 最后修改时间 	: 	2013-06-11
* 说明			: 	用于非中断模式下获取串口新数据
*************************************************************************************************************************/
bool UART_GetNewData(UART_CH ch, u8 *pData)
{
	switch(ch)
	{
		case UART_CH0:
		{
			if(U0CSR & BIT2)
			{
				*pData = U0DBUF;
				return TRUE;
			}
			return FALSE;
		}break;
		case UART_CH1:
		{
			if(U1CSR & BIT2)
			{
				*pData = U1DBUF;
				return TRUE;
			}
			return FALSE;
		}break;
		default : return FALSE;
	}
}


/*************************************************************************************************************************
* 函数			:	bool UART_GetRxBuffFullFlag(UART_CH ch)
* 功能			:	获取串口接收缓冲区满标志
* 参数			:	ch:通道选择,UART_CH0,UART_CH1
* 返回			:	TRUE:满,FALSE:没有满
* 依赖			:	底层宏定义
* 作者			:	cp1300@139.com
* 时间			:	2013-06-11
* 最后修改时间 	:	2013-06-11
* 说明	: 			用于判断接收缓冲区是否满,会清除标志
*************************************************************************************************************************/
bool UART_GetRxBuffFullFlag(UART_CH ch)
{
	if(UART_RX[ch].BuffFull)				//缓冲区已满
	{
	 	UART_RX[ch].BuffFull = 0;			//清除满标志
		return TRUE;
	}
	return FALSE;
}




/*************************************************************************************************************************
* 函数			:	void UART_SetRxBuff(UART_CH ch, u8 *pRxBuff, u16 BuffSize)
* 功能			:	设置串口接收缓冲区
* 参数			:	ch:通道选择,UART_CH0,UART_CH1
					pRxBuff:缓冲区指针,BuffSize:缓冲区大小
* 返回			:	无
* 依赖			:	底层宏定义
* 作者			:	cp1300@139.com
* 时间			:	2013-06-11
* 最后修改时间 	: 	2013-06-11
* 说明			: 	用于中断接收
*************************************************************************************************************************/
void UART_SetRxBuff(UART_CH ch, u8 *pRxBuff, u16 BuffSize)
{
	UART_RX[ch].RxBuffSize = BuffSize; 				//设置缓冲区大小
	UART_RX[ch].RxBuff = pRxBuff;					//设置缓冲区指针
	UART_RX[ch].UartRxCnt = 0;						//计数器清零
}





/*************************************************************************************************************************
* 函数			:	u16 UART_GetRxCnt(UART_CH ch)
* 功能			:	获取串口接收数据计数器
* 参数			:	ch:通道选择,UART_CH0,UART_CH1
* 返回			:	接收到的数据数量
* 依赖			:	底层宏定义
* 作者			:	cp1300@139.com
* 时间			:	2013-06-11
* 最后修改时间 	: 	2013-06-11
* 说明			: 	无
*************************************************************************************************************************/
u16 UART_GetRxCnt(UART_CH ch)
{
	return UART_RX[ch].UartRxCnt;				//返回计数值
}




/*************************************************************************************************************************
* 函数			:	void UART_ClearRxCnt(UART_CH ch)
* 功能			:	清除串口接收数据计数器
* 参数			:	ch:通道选择,UART_CH0,UART_CH1
* 返回			:	无
* 依赖			:	底层宏定义
* 作者			:	cp1300@139.com
* 时间			:	2013-06-11
* 最后修改时间 	: 	2013-06-11
* 说明			: 	无
*************************************************************************************************************************/
void UART_ClearRxCnt(UART_CH ch)
{
	UART_RX[ch].UartRxCnt = 0;				//计数器清零
}





uart.h


/*************************************************************************************************************
 * 文件名:	uart.h
 * 功能:	CC2530 串口相关函数
 * 作者:	cp1300@139.com
* 创建时间:	2013-06-07 21:33
 * 最后修改时间:2013-06-07
 * 详细:	串口相关函数
*************************************************************************************************************/
#ifndef _UART_H_
#define _UART_H_

#include "system.h"
#include "stdio.h"

//串口波特率定义
typedef enum
{
	BAUD_2400 	= 0,		//2400
	BAUD_4800 	= 1,		//4800
	BAUD_9600 	= 2,		//9600
	BAUD_14400 	= 3,		//14400
	BAUD_19200 	= 4,		//19200
	BAUD_28800 	= 5,		//28800
	BAUD_38400 	= 6,		//38400
	BAUD_57600 	= 7,		//57600
	BAUD_76800 	= 8,		//76800
	BAUD_115200 = 9,		//115200
	BAUD_230400 = 10,		//230400
} USART_BAUD;




//串口通道选择
typedef enum
{
	UART_CH0	=	0,		//通道0,串口0
	UART_CH1	=	1,		//通道1,串口1
} UART_CH;



//UAR
void UART_Init(UART_CH ch, USART_BAUD Baud, FunctionalState RxIntEn);	//UART初始化
void UART_SendByte(UART_CH ch, u8 data);
void UART_SendData(UART_CH ch, u8 *pbuff, u16 len);						//串口发送任意长度数据
void UART_SendString(UART_CH ch, const char *pStr); 					//UART发送字符串
void UART_RxEnable(UART_CH ch, FunctionalState Enable);					//UART接收使能
bool UART_GetNewData(UART_CH ch, u8 *pData);							//获取串口新数据
bool UART_GetRxBuffFullFlag(UART_CH ch);								//获取串口接收缓冲区满标志
void UART_SetRxBuff(UART_CH ch, u8 *pRxBuff, u16 BuffSize);				//设置串口接收缓冲区
u16 UART_GetRxCnt(UART_CH ch);											//获取串口接收数据计数器
void UART_ClearRxCnt(UART_CH ch);										//清除串口接收数据计数器

  






#endif //_UART_H_



//重定义printf到串口


#if _PRINTF_EN_
#include "uart.h"
#include "stdio.h"
//#define __CODE_MODEL__ = __CM_BANKED__
__near_func int putchar(int ch)
{
	UART_SendByte(UART_CH0, ch);
	return ch;
}
#endif




初始化


//主函数
int main(void)
{
    SYS_ClockInit();
    UART_Init(UART_CH0, BAUD_115200,ENABLE);
    LED_Init();
    clock_init();
    SYS_EnableInt();
    process_init();
	process_start(&etimer_process, NULL);
	autostart_start(autostart_processes);
	printf("Processes runningn");
	while(1)
	{
		do
		{

		} while(process_run()> 0);
		SYS_PowerIdle();            //空闲模式
	}
}





本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

LED驱动电源的输入包括高压工频交流(即市电)、低压直流、高压直流、低压高频交流(如电子变压器的输出)等。

关键字: 驱动电源

在工业自动化蓬勃发展的当下,工业电机作为核心动力设备,其驱动电源的性能直接关系到整个系统的稳定性和可靠性。其中,反电动势抑制与过流保护是驱动电源设计中至关重要的两个环节,集成化方案的设计成为提升电机驱动性能的关键。

关键字: 工业电机 驱动电源

LED 驱动电源作为 LED 照明系统的 “心脏”,其稳定性直接决定了整个照明设备的使用寿命。然而,在实际应用中,LED 驱动电源易损坏的问题却十分常见,不仅增加了维护成本,还影响了用户体验。要解决这一问题,需从设计、生...

关键字: 驱动电源 照明系统 散热

根据LED驱动电源的公式,电感内电流波动大小和电感值成反比,输出纹波和输出电容值成反比。所以加大电感值和输出电容值可以减小纹波。

关键字: LED 设计 驱动电源

电动汽车(EV)作为新能源汽车的重要代表,正逐渐成为全球汽车产业的重要发展方向。电动汽车的核心技术之一是电机驱动控制系统,而绝缘栅双极型晶体管(IGBT)作为电机驱动系统中的关键元件,其性能直接影响到电动汽车的动力性能和...

关键字: 电动汽车 新能源 驱动电源

在现代城市建设中,街道及停车场照明作为基础设施的重要组成部分,其质量和效率直接关系到城市的公共安全、居民生活质量和能源利用效率。随着科技的进步,高亮度白光发光二极管(LED)因其独特的优势逐渐取代传统光源,成为大功率区域...

关键字: 发光二极管 驱动电源 LED

LED通用照明设计工程师会遇到许多挑战,如功率密度、功率因数校正(PFC)、空间受限和可靠性等。

关键字: LED 驱动电源 功率因数校正

在LED照明技术日益普及的今天,LED驱动电源的电磁干扰(EMI)问题成为了一个不可忽视的挑战。电磁干扰不仅会影响LED灯具的正常工作,还可能对周围电子设备造成不利影响,甚至引发系统故障。因此,采取有效的硬件措施来解决L...

关键字: LED照明技术 电磁干扰 驱动电源

开关电源具有效率高的特性,而且开关电源的变压器体积比串联稳压型电源的要小得多,电源电路比较整洁,整机重量也有所下降,所以,现在的LED驱动电源

关键字: LED 驱动电源 开关电源

LED驱动电源是把电源供应转换为特定的电压电流以驱动LED发光的电压转换器,通常情况下:LED驱动电源的输入包括高压工频交流(即市电)、低压直流、高压直流、低压高频交流(如电子变压器的输出)等。

关键字: LED 隧道灯 驱动电源
关闭