我在用基于CC2530的zigbee套件,协调器和STM32板相连(通过串口的tx rx,共地),想通过PC端的上位机发送命令给STM32,由STM32发给协调器。现在是STM32可以发送数据给协调器,但是协调器不能发送数据给STM32板子。2530是用DMA方式发送接收的。
gaoyang9992006:
给你个串口发送接收的例子
/*描述:例以abc#方式发送,#为结束符, 返回abc。波特率:115200bps**************************************/
#include <ioCC2530.h>#include <string.h>
#define uint unsigned int#define uchar unsigned char
//定义控制LED灯的端口#define LED1 P1_0 //定义LED1为P10口控制#define LED2 P1_1
//函数声明void Delayms(uint xms); //延时函数void InitLed(void); //初始化P1口void InitUart(); //初始化串口void Uart_Send_String(char *Data,int len);
char Rxdata[50];uchar RXTXflag = 1; char temp; uchar datanumber = 0;
/**************************** 延时函数*****************************/void Delayms(uint xms) //i=xms 即延时i毫秒 (16M晶振时候大约数,32M需要修改,系统不修改默认使用内部16M){ uint i,j; for(i=xms;i>0;i–) for(j=587;j>0;j–);}
/****************************//初始化程序*****************************/void InitLed(void){ P1DIR |= 0x03; //P1_0、P1_1定义为输出 LED1 = 0; //LED1灯熄灭 LED2=0; }/**************************************************************** 串口初始化函数 ***********************************************************/void InitUart(){ CLKCONCMD &= ~0x40; // 设置系统时钟源为 32MHZ晶振 while(CLKCONSTA & 0x40); // 等待晶振稳定 CLKCONCMD &= ~0x47; // 设置系统主时钟频率为 32MHZ
PERCFG = 0x00; //位置1 P0口 P0SEL = 0x3c; //P0_2,P0_3,P0_4,P0_5用作串口,第二功能 P2DIR &= ~0XC0; //P0 优先作为UART0 ,优先级 U0CSR |= 0x80; //UART 方式 U0GCR |= 11; //U0GCR与U0BAUD配合 U0BAUD |= 216; // 波特率设为115200 UTX0IF = 0; //UART0 TX 中断标志初始置位1 (收发时候) U0CSR |= 0X40; //允许接收 IEN0 |= 0x84; // 开总中断,接收中断 }
/**************************************************************** 串口发送字符串函数 ****************************************************************/ void Uart_Send_String(char *Data,int len) { { int j; for(j=0;j<len;j++) { U0DBUF = *Data++; while(UTX0IF == 0); //发送完成标志位 UTX0IF = 0; } }}/***************************//主函数***************************/void main(void){ InitLed(); //调用初始化函数 InitUart(); while(1) { if(RXTXflag == 1) //接收状态 { LED1=1; //接收状态指示 if( temp != 0) { if((temp!='#')&&(datanumber<50)) //'#'被定义为结束字符,最多能接收50个字符 Rxdata[datanumber++] = temp; else { RXTXflag = 3; //进入发送状态 LED1=0; //关指示灯 } temp = 0; } } if(RXTXflag == 3) //发送状态 { LED2= 1; U0CSR &= ~0x40; //禁止接收 Uart_Send_String(Rxdata,datanumber); //发送已记录的字符串。 U0CSR |= 0x40; //允许接收 RXTXflag = 1; // 恢复到接收状态 datanumber = 0; //指针归0 LED2 = 0; //关发送指示 } }}
/**************************************************************** 串口接收一个字符: 一旦有数据从串口传至CC2530, 则进入中断,将接收到的数据赋值给变量temp. ****************************************************************/ #pragma vector = URX0_VECTOR __interrupt void UART0_ISR(void) { temp = U0DBUF; URX0IF = 0; // 清中断标志 }
gaoyang9992006:
再发一个类似的串口控制的例子
/*例程名称:串口控制LED *//*建立时间:2012/06/5 *//*描述:依次发送L1# L2# 指令分别控制 LED1、LED2亮灭,波特率:115200bps**************************************/
#include <ioCC2530.h>#include <string.h>
#define uint unsigned int#define uchar unsigned char
//定义控制LED灯的端口#define LED1 P1_0 //定义LED1为P10口控制#define LED2 P1_1
//函数声明void Delayms(uint xms); //延时函数void InitLed(void); //初始化P1口void InitUart(); //初始化串口void Uart_Send_String(char *Data,int len);
char Rxdata[3];uchar RXTXflag = 1; char temp; uchar datanumber = 0;
/****************************//延时函数*****************************/void Delayms(uint xms) //i=xms 即延时i毫秒 (16M晶振时候大约数,32M需要修改,系统不修改默认使用内部16M){ uint i,j; for(i=xms;i>0;i–) for(j=587;j>0;j–);}
/****************************//初始化程序*****************************/void InitLed(void){ P1DIR |= 0x03; //P1_0、P1_1定义为输出 LED1 = 1; //LED1、2灯熄灭 LED2 = 1; }
/**************************************************************** 串口初始化函数 ***********************************************************/void InitUart(){ CLKCONCMD &= ~0x40; // 设置系统时钟源为 32MHZ晶振 while(CLKCONSTA & 0x40); // 等待晶振稳定 CLKCONCMD &= ~0x47; // 设置系统主时钟频率为 32MHZ
PERCFG = 0x00; //位置1 P0口 P0SEL = 0x3c; //P0_2,P0_3,P0_4,P0_5用作串口,第二功能 P2DIR &= ~0XC0; //P0 优先作为UART0 ,优先级 U0CSR |= 0x80; //UART 方式 U0GCR |= 11; //U0GCR与U0BAUD配合 U0BAUD |= 216; // 波特率设为115200 UTX0IF = 1; //UART0 TX 中断标志初始置位1 (收发时候) U0CSR |= 0X40; //允许接收 IEN0 |= 0x84; // 开总中断,接收中断 }
/**************************************************************** 串口发送字符串函数 ****************************************************************/ void Uart_Send_String(char *Data,int len) { { int j; for(j=0;j<len;j++) { U0DBUF = *Data++; while(UTX0IF == 0); UTX0IF = 0; } }}/***************************//主函数***************************/void main(void){ InitLed(); //调用初始化函数 InitUart(); while(1) { if(RXTXflag == 1) //接收状态 { if( temp != 0) { if((temp!='#')&&(datanumber<3)) //'#'被定义为结束字符,最多能接收50个字符 Rxdata[datanumber++] = temp; else { RXTXflag = 3; //进入发送状态 } temp = 0; } } if(RXTXflag == 3) //检测接收到的数据 { if(Rxdata[0]=='L') switch(Rxdata[1]-48)//很重要,ASICC码转成数字,判断L后面第一个数 { case 1: { LED1=~LED1; //低电平点亮 break; } case 2: { LED2=~LED2; break; } } RXTXflag = 1; datanumber = 0; //指针归 0 } }}
/**************************************************************** 串口接收一个字符: 一旦有数据从串口传至CC2530, 则进入中断,将接收到的数据赋值给变量temp. ****************************************************************/ #pragma vector = URX0_VECTOR __interrupt void UART0_ISR(void) { URX0IF = 0; // 清中断标志 temp = U0DBUF; }
GUI XIE:
您好,我现在也在研究STM32和CC2530之间进行通信的问题,请问一下,您能不能把您的两个程序给我参考一下呢?谢谢了。然后硬件就是STM32的串口TX接CC2530的RX,STM32的RX接CC2530的TX,然后共地是吧?不需要分压电阻之类的电路?
chong huang:
回复 GUI XIE:
您好,请参考这个帖子的推荐答案(上一楼我的回答),主要是硬件流控问题以及CTS那两个引脚需要短接。。。