CC2530调试过程中遇到的问题们
应用场景描述:
多个发送端在不同的信道上发送信息(11~26)信道,接收端轮询所有信道(11~26),若有信号,则接收,若无信号则继续轮询。形成多个点对点的收发系统。
一、问题1
Ø 问题现象描述:
Zigbee接收端轮询信道,当发送端正常时
实验一:1.若发送端由A信道发,可正确接收;2.若发送端由A+4信道发,则不可正确接收。
实验二:1.若发送端由A信道发,可正确接收;2若发送端由A+2信道发,可正确接收;.3.若发送端由A+4信道发,可正确接收;
以上现象经确认与发送端无关,且接收端硬件复位无用。
Ø 问题分析
1.经过在接收中断中加入LED灯闪,发现切换信道后没有收到信息的原因是压根没有进入接收中断。
2.没有进入中断,说明在从天线接下信号后的处理中,没有正确分辨出信号。且切换信道主要是切换接收频率。所以问题可能频率有关。
3.点对点的情况下不会出现该问题。
4.在CC2530_userguide中找到frequency calibration相关的寄存器RFST的ISRXON指令。(在代码中为由light_switch.c调用的basicRfReceiveOn()。)其作用Enable and calibrate frequency synthesizerfor RX。所以加入basicRfReceiveOn()与basicRfReceiveOff(),便解决问题。
二、问题2
Ø 问题现象描述:
Zigbee发送正常,当加入了basicRfReceiveOn()后,可以接收到所有信道信息,但是个别信道上信息会发生错误。
Ø 问题分析
1.改为点对点,即接收端不轮询。因为加入了basicRfReceiveOn(),同样也会出现问题,所以问题是由basicRfReceiveOn()引起的,而非轮询等。
2.考虑到basicRfReceiveOn()有校正频偏的作用,所以需要一定的时间,加入Delay问题解决。
三、问题3
Ø 问题现象描述:
Zigbee接收端运行一段时间会接收不到数据,经在中断中加入LED灯闪和在接收while中加入打印,确定程序在运行,但没有收到数据。
Ø 问题分析
1.发送端连续发送数据55 55 BB BB BB BB BB BB BB BB BB BB BB BB BB AA AA。
通过MATLAB仿真Zigbee调制,确定问题为发送序列过于有规律的问题。
可知,其频谱如下:

当改为发送随机信号时,其频谱为

四、附:
A. light_switch.c最终版代码
/***********************************************************************************
Filename: light_switch.c Description: This application function either as a light or a
switch toggling the ligh. The role of the
application is chosen in the menu with the joystick at initialisation. Push S1 to enter the menu. Choose either switch or
light and confirm choice with S1.
Joystick Up: Sends data from switch to light ***********************************************************************************/ /***********************************************************************************
* INCLUDES
*/
#include <hal_lcd.h>
#include <hal_led.h>
#include <hal_joystick.h>
#include <hal_assert.h>
#include <hal_board.h>
#include <hal_int.h>
#include "hal_mcu.h"
#include "hal_button.h"
#include "hal_rf.h"
#include "util_lcd.h"
#include "basic_rf.h" /***********************************************************************************
* CONSTANTS
*/
// Application parameters
#define RF_CHANNEL 11 // 2.4 GHz RF channel // BasicRF address definitions
#define PAN_ID 0x2007
#define SWITCH_ADDR 0x2520
#define LIGHT_ADDR 0xBEEF
#define APP_PAYLOAD_LENGTH 18
//#define LIGHT_TOGGLE_CMD 0 // Application states
#define IDLE 0
#define SEND_CMD 1 // Application role
#define NONE 0
#define SWITCH 1
#define LIGHT 2
#define APP_MODES 2
#define LED P1_2 //定义LED为P12口控制
/***********************************************************************************
* LOCAL VARIABLES
*/
static uint8 pTxData[APP_PAYLOAD_LENGTH];
static uint8 pRxData[APP_PAYLOAD_LENGTH];
static basicRfCfg_t basicRfConfig; unsigned char Recdata[]="CHENGDU JIALI TECH.INC\r\n";
unsigned char Recdata_bak[]="CHENGDU JIALI TECH.INC\r\n";
unsigned char Recdata_consol[];
unsigned char Testdata[];
unsigned char RXTXflag = ;
unsigned char temp=;
unsigned int datanumber = ;
int flag=; #ifdef SECURITY_CCM
// Security key
static uint8 key[]= {
0xc0, 0xc1, 0xc2, 0xc3, 0xc4, 0xc5, 0xc6, 0xc7,
0xc8, 0xc9, 0xca, 0xcb, 0xcc, 0xcd, 0xce, 0xcf,
};
#endif /***********************************************************************************
* LOCAL FUNCTIONS
*/
static void appLight();
static void appSwitch(); void initUART_TX(void);//*************************
void initUART_RX(void);//**************************
void UartTX_Send_String(int8 *Data,int len);//********************** /****************************************************************
发送ZIGBEE,初始化串口0函数
****************************************************************/
void initUART_TX(void)
{
CLKCONCMD &= ~0x40; //设置系统时钟源为32MHZ晶振
while(CLKCONSTA & 0x40); //等待晶振稳定
CLKCONCMD &= ~0x47; //设置系统主时钟频率为32MHZ PERCFG = 0x00; //位置1 P0口
P0SEL = 0x0c; //P0用作串口
// P0SEL = 0x0c; //P0用作串口
P2DIR &= ~0XC0; //P0优先作为UART0
U0CSR |= 0x80; //串口设置为UART方式
U0GCR |= ;
U0BAUD |= ; //波特率设为115200
UTX0IF = ; //UART0 TX中断标志初始置位1
U0CSR |= 0X40; //允许接收
//IEN0 |= 0x84; //开总中断,接收中断
URX0IE=;
EA=;
} /****************************************************************
接收ZIGBEE,串口初始化函数
****************************************************************/
void initUART_RX(void)
{
PERCFG = 0x00; //位置1 P0口
P0SEL = 0x0c; //P0_2,P0_3用作串口(外部设备功能)
P2DIR &= ~0XC0; //P0优先作为UART0 U0CSR |= 0x80; //设置为UART方式
U0GCR |= ;
U0BAUD |= ; //波特率设为115200
UTX0IF = ; //UART0 TX中断标志初始置位0
}
/****************************************************************
串口发送字符串函数
****************************************************************/
void UartTX_Send_String(int8 *Data,int len)
{
int j;
for(j=;j<len;j++)
{
U0DBUF = *Data++;
while(UTX0IF == );
UTX0IF = ;
}
} void Delay(unsigned long n)
{
unsigned long tt;
for(tt = ;tt<n;tt++);
for(tt = ;tt<n;tt++);
for(tt = ;tt<n;tt++);
for(tt = ;tt<n;tt++);
for(tt = ;tt<n;tt++);
} /***********************************************************************************
* @fn appLight
*
* @brief Application code for light application. Puts MCU in endless
* loop waiting for user input from joystick. jiali
*
* @param basicRfConfig - file scope variable. Basic RF configuration data
* pRxData - file scope variable. Pointer to buffer for RX data
*
* @return none jaalee
*/
static void appLight()
{
unsigned int i=,j=;
int8 tmp;
#ifdef ASSY_EXP4618_CC2420
halLcdClearLine();
#endif // Initalise uart
initUART_RX();
UartTX_Send_String("Begin~!!\n",);
// Initialize BasicRF
basicRfConfig.myAddr = LIGHT_ADDR;
basicRfConfig.channel = RF_CHANNEL+i;
if(basicRfInit(&basicRfConfig)==FAILED) {
HAL_ASSERT(FALSE);
}
basicRfReceiveOn();
LED=;
// Main loop
while (TRUE) { basicRfConfig.myAddr = LIGHT_ADDR;
basicRfConfig.channel = RF_CHANNEL+i;
i=(i++)%;
if(basicRfInit(&basicRfConfig)==FAILED) {
HAL_ASSERT(FALSE);
}
basicRfReceiveOn();//////////问题1时无此句////////////////////////////
Delay();//////////问题1时无此句//////////////////////////// if(basicRfPacketIsReady()) if(basicRfReceive(pRxData, APP_PAYLOAD_LENGTH, NULL)>) { UartTX_Send_String(pRxData,APP_PAYLOAD_LENGTH);////////////////////////
}
basicRfReceiveOff();//////////问题1时无此句////////////////////////////
}
} /***********************************************************************************
* @fn appSwitch
*
* @brief Application code for switch application. Puts MCU in
* endless loop to wait for commands from from switch
*
* @param basicRfConfig - file scope variable. Basic RF configuration data
* pTxData - file scope variable. Pointer to buffer for TX
* payload
* appState - file scope variable. Holds application state
*
* @return none
*/
static void appSwitch()
{
// int flag=0;
unsigned int i=;
#ifdef ASSY_EXP4618_CC2420
halLcdClearLine();
#endif initUART_TX();
UartTX_Send_String("Begin~!!\n",); // Initialize BasicRF
basicRfConfig.channel = RF_CHANNEL+;
basicRfConfig.myAddr = SWITCH_ADDR;
if(basicRfInit(&basicRfConfig)==FAILED) {
HAL_ASSERT(FALSE);
} // Keep Receiver off when not needed to save power
basicRfReceiveOff();
datanumber=; RXTXflag = ; while()
{
/*
if(RXTXflag == 3) //发送状态
{
U0CSR &= ~0x40; // UartTX_Send_String(Recdata,datanumber);
U0CSR |= 0x40; //允许接收
RXTXflag = 1; //恢复到接收状态
datanumber = 0; //指针归0
LED=~LED;
Recdata_consol[0]=0xac;
UartTX_Send_String(Recdata_consol,1);//不能收数
flag=1;
for(i=0;i<17;i++)
{
Recdata_bak[i]=Recdata[i];
}
} */
if(flag==)
{
basicRfSendPacket(LIGHT_ADDR, Recdata_bak, );
}
} } /***********************************************************************************
* @fn main
*
* @brief This is the main entry of the "Light Switch" application.
* After the application modes are chosen the switch can
* send toggle commands to a light device.
*
* @param basicRfConfig - file scope variable. Basic RF configuration
* data
* appState - file scope variable. Holds application state
*
* @return none
*/
void main(void)
{
unsigned int i=;
// Config basicRF
basicRfConfig.panId = PAN_ID;
basicRfConfig.channel = RF_CHANNEL;
basicRfConfig.ackRequest = TRUE; #ifdef SECURITY_CCM
basicRfConfig.securityKey = key;
#endif // Initalise board peripherals
halBoardInit(); // Initalise hal_rf
if(halRfInit()==FAILED) {
HAL_ASSERT(FALSE);
} // Indicate that device is powered //appSwitch();
appLight(); } /****************************************************************
串口接收一个字符:一旦有数据从串口传至CC2530,则进入中断,将接收到的数据赋值给变量temp.
****************************************************************/
#pragma vector = URX0_VECTOR
__interrupt void UART0_ISR(void)
{
URX0IF = ; //清中断标志
temp = U0DBUF;
int i;
if(datanumber==)
{
if(temp==0x55)
Recdata[datanumber++] = temp;
else
{
datanumber=;
}
}
else if(datanumber==)
{
if(temp==0x55)
Recdata[datanumber++] = temp;
else
{
datanumber=;
} }
else if(datanumber==)
{
if(temp==0xaa)
Recdata[+datanumber++] = temp;
else
{
datanumber=;
}
}
else if(datanumber==)
{ if(temp==0xaa)
{
Recdata[+datanumber++] = temp;
Recdata[]=;
RXTXflag = ;
U0CSR &= ~0x40; // UartTX_Send_String(Recdata,datanumber);
U0CSR |= 0x40; //允许接收
RXTXflag = ; //恢复到接收状态
datanumber = ; //指针归0
LED=~LED;
flag=;
for(i=;i<;i++)
{
Recdata_bak[i]=Recdata[i];
}
}
else
{
datanumber=;
}
}
else
{
Recdata[+datanumber++] = temp;
} temp = ;
}
B. ZIGBEE_OQPSK调制MATLAB代码
clear all
% close all D=[];
Data=[];
% data_hex='5555CCCCCCCCCCCCCCCCCCCCCCCCCCAAAA';
% data_hex='5555BBBBBBBBBBBBBBBBBBBBBBBBBBAAAA';
data_hex='51555086F61C3CA2F7C71A4B4C046ADAAAA';
data_map=[
'';
'';
'';
'';
'';
'';
'';
'';
'';
'';
'';
'';
'';
'';
'';
''];
for i=:length(data_hex)
tmp=hex2dec(data_hex(i));
Data=[Data data_map(tmp+,:)];
end for i=::length(Data)
t=[Data(i) Data(i+)];
T2=bin2dec(t);
D=[D repmat(T2,,fs/fb)];
end modObj = modem.oqpskmod;
M1=modulate(modObj,D');
M=M1(:length(M1)); N1=:length(M)/-;
N2=-length(M)/:-;
N=[N1,N2];
figure,plot(N,abs(fft(M)));
figure,plot(real(M),imag(M),'*');
CC2530调试过程中遇到的问题们的更多相关文章
- 关于火狐浏览器在开发调试过程中,出现javascript:void(0)的状态
关于火狐浏览器在开发调试过程中,出现javascript:void(0)的状态 由于火狐浏览器没有安装 Adobe Flash Player 19 NPAPI这个插件 安装好了之后就可以直接运行了
- Android APP 调试过程中遇到的问题。
调试过过程中APP安装完启动后有的时候会异常退出,报这个错误.有的时候可以直接启动.查找不到原因.网上说把commit方法替换成commitAllowingStateLoss() 也无效. Andro ...
- 调试过程中发现按f5无法走进jdk源码
debug 模式 ,在fis=new FileInputStream(file); 行打断点 调试过程中发现按f5无法走进jdk源码 package com.lzl.spring.test; impo ...
- VS·调试过程中某个操作导致调试突然退出之解决方案
阅文时长 | 0.11分钟 字数统计 | 232字符 主要内容 | 1.引言&背景 2.声明与参考资料 『VS·调试过程中某个操作导致调试突然退出之解决方案』 编写人 | SCscHero 编 ...
- C语言调试过程中duplicate symbol错误分析
说明:在我们调试C语言的过程中,经常会遇到duplicate symbol错误(在Mac平台下利用Xcode集成开发环境).如下图: 一.简单分析一下C语言程序的开发步骤. 由上图我们可以看出C语言由 ...
- 【转】MFC中调试过程中查看输出信息 -- 不错
原文网址:http://blog.sina.com.cn/s/blog_4e24d9c501014o39.html 笔记&&方便查阅. ~~~~~~~~~~~~~~~~~~~~~~~~ ...
- Android Studio 调试过程中快捷查看断点处变量值(Ctrl+Shift+I无效)?
当你在做Keymap到Eclipse后,在debug过程中,在Eclipse中我们很喜欢用Ctrl+Shift+I去查看一个运算或者调用的结果,这样用起来很方便.但是keymap到Eclipse后,你 ...
- [ISE调试] 在ISE调试过程中,遇到过的warning以及消除办法
1.在generate的过程中,在Map环节遇到了下面这个warning 意思:告诉你是黑盒子,而且他本来在设计里面就是黑盒子. 解决办法:点击图中的,会弹出一个代码文件,是声明这个IP核的文件,代码 ...
- 代码调试过程中easy遇到的问题
前两天身体有些不舒服,也没写啥新文章,昨天下了一天的雨.今天阳光明媚,空气也非常新奇.心情大好. 继翻译为什么输出是String而不是Object,今天先写一下调试方面的东西.java中自带的函数调试 ...
随机推荐
- python3 获取日期时间
#!/usr/bin/python3 import time # 格式化成2016-- ::39形式 print (time.strftime("%Y-%m-%d %H:%M:%S" ...
- [Gamma阶段]测试报告
[Gamma阶段]测试报告 博客目录 测试方法及过程 在正式发布前,为检验后端各接口功能的正确性,后端服务器对压力的耐受程度,以及前端各页面.功能的运行情况,我们对我们的服务器及小程序进行了多种测试. ...
- Kubernetes集群之清除集群
清除K8s集群的Etcd集群 操作服务器为:192.168.1.175/192.168.1.176/192.168.1.177,即etcd集群的三台服务器.以下以192.168.1.175为例子. 暂 ...
- Asp.Net 服务器控件下使用Jquery.validate.js
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- Python3.7 - Argparse模块的用法
argparse 是一个命令行参数解析模块. argparse 是python自带的命令行参数解析包,可以用来方便地读取命令行参数,当你的代码需要频繁地修改参数的时候,使用这个工具可以将参数和代码分离 ...
- Android实时打印内核log
由于访问的是/proc/kmsg,因此需要先获取root权限: adb root adb shell "while true; do cat; sleep 1; done < /pro ...
- Symbol 小妙处
input 框输入后发送异步请求,页面拿到响应进行渲染.但偶尔会遇到问题:响应内容和输入结果不一致.因为 http 无法保证响应到达的顺序. 如何解决呢?提供一个小思路. myRequest.js i ...
- spring boot 源码解析52-actuate中MVCEndPoint解析
今天有个别项目的jolokia的endpoint不能访问,调试源码发现:endpoint.enabled的开关导致的. 关于Endpoint, <Springboot Endpoint之二:En ...
- 构造 + 离散数学、重言式 - POJ 3295 Tautology
Tautology Description WFF 'N PROOF is a logic game played with dice. Each die has six faces represen ...
- Scala Operators, File & RegExp
Operators Thread.`yield`() 反引号除了用于命名标识符,还可以在调用方法时避免冲突(yield 为 Scala 关键字,但也是 Thread 的方法) 中缀运算符(infix ...