完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
本帖最后由 一只耳朵怪 于 2018-5-24 15:21 编辑
我在用基于CC2530的zigbee套件,协调器和STM32板相连(通过串口的tx rx,共地),想通过PC端的上位机发送命令给STM32,由STM32发给协调器。现在是STM32可以发送数据给协调器,但是协调器不能发送数据给STM32板子。2530是用DMA方式发送接收的。 |
|
相关推荐
5个回答
|
|
给你个串口发送接收的例子
/*描述:例以abc#方式发送,#为结束符, 返回abc。波特率:115200bps **************************************/ #include #include #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 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; // 清中断标志 ] |
|
|
|
再发一个类似的串口控制的例子
/*例程名称:串口控制LED */ /*建立时间:2012/06/5 */ /*描述:依次发送L1# L2# 指令分别控制 LED1、LED2亮灭,波特率:115200bps **************************************/ #include #include #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 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; ] |
|
|
|
您好,我的问题已经解决了。原来是串口的硬件控制流的问题,我把2530的CTS和RTS短接就没有问题了。对了我的是在z-stack上开发的。谢谢了! |
|
|
|
您好,我现在也在研究STM32和CC2530之间进行通信的问题,请问一下,您能不能把您的两个程序给我参考一下呢?谢谢了。然后硬件就是STM32的串口TX接CC2530的RX,STM32的RX接CC2530的TX,然后共地是吧?不需要分压电阻之类的电路?
|
|
|
|
www037 发表于 2018-5-22 08:23 您好,请参考这个帖子的推荐答案(上一楼我的回答),主要是硬件流控问题以及CTS那两个引脚需要短接。。。 |
|
|
|
只有小组成员才能发言,加入小组>>
793 浏览 0 评论
TMS320F28377D:新做了以377d为芯片的板子,上电后芯片复位引脚出现方波请问如何解决?
1991 浏览 0 评论
TPS55340通电后输入端保险丝烧断,芯片输入和GND之间短路
3743 浏览 4 评论
5105 浏览 0 评论
请问如何用DM368对RGB格式的图片数据进行编码生成JPEG格式图片?
1805 浏览 1 评论
CC3100BOOST使用CC3200lunchXL进行烧录
784浏览 2评论
835浏览 1评论
TMS320F28034: 利用C2prog通过SCI给TMS320F28034烧录程序,出现错误提示:Bootloading... failed (invalid echo)!
819浏览 1评论
求DLPC350 Programmer’s Guide User's Guide 中文版说明书
1287浏览 1评论
1881浏览 1评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-7-19 10:48 , Processed in 0.787933 second(s), Total 54, Slave 49 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号