前一段时间画了一个CC1101收发小板子,但是一直没有成功,最后发现把27nH的电感焊接成了27uH,最终导致失败.
现在更换之后可以覆盖我们公司所有的角落,已经够用了.
原理图:http://download.csdn.net/detail/cp1300/7496509
下面是STM8程序
CC1101.C
/*************************************************************************************************************
* 文件名: CC1101.c
* 功能: STM8 CC1101驱动函数
* 作者: [email protected]
* 创建时间: 2013-12-06 14:35
* 最后修改时间:2013-12-06
* 详细: 433MHZ收发芯片驱动
*************************************************************************************************************/
#include "system.h"
#include "delay.h"
#include "CC1101.h"
//CC1101命令掩码
#define WRITE_BURST 0x40 //连续写入
#define READ_SINGLE 0x80 //读
#define WRITE_SINGLE 0x00 //写
#define READ_BURST 0xC0
//连续读
#define BURST_READ_FIFO 0xff //突发读取RX FIFO
#define BYTE_READ_FIFO 0xBF //单字节读取 RX FIFO
#define BURST_WRITE_FIFO 0x7f //突发写TX FIFO
#define BYTE_WRITE_FIFO 0x3f //单字节写 TX FIFO
#define CC1101_DATA_LEN 64
//SPI接口
//底层接口宏定义
#define CC1101_CS_H() (GPIOA->ODR|=BIT3) //PA3=1
#define CC1101_CS_L() (GPIOA->ODR&=~BIT3) //PA3=0
#define CC1101_MOSI_H() (GPIOC->ODR|=BIT6) //PC6
#define CC1101_MOSI_L() (GPIOC->ODR&=~BIT6) //PC6
#define CC1101_SCLK_H() (GPIOC->ODR|=BIT5) //PC5
#define CC1101_SCLK_L() (GPIOC->ODR&=~BIT5) //PC5
#define CC1101_GetMISO() (GPIOC->IDR&BIT7) //PC7
//CC1101 SPI读写一字节
//不带片选
u8 CC1101_ReadWriteByte(u8 data)
{
u8 i;
u8 temp = 0;
for(i = 0;i < 8;i ++)
{
if(data & 0x80)
{
CC1101_MOSI_H();
}
else
{
CC1101_MOSI_L();
}
data <<= 1;nop;
CC1101_SCLK_H(); //时钟上升沿写入数据
temp <<= 1;nop;
if(CC1101_GetMISO()) temp ++;
CC1101_SCLK_L(); //时钟下降沿读取数据
}
return temp;
}
/*************************************************************************************************************************
* 函数 : u8 CC1101_Command(CC1101_CMD_TYPE Cmd)
* 功能 : 发送单字节命令
* 参数 : Cmd;命令,见CC1101_CMD_TYPE
* 返回 : 寄存器的值
* 依赖 : 底层宏定义
* 作者 : [email protected]
* 时间 : 2013-12-06
* 最后修改时间 : 2013-12-06
* 说明 : 以写的方式单直接访问将触发响应的命令
*************************************************************************************************************************/
u8 CC1101_Command(CC1101_CMD_TYPE Cmd)
{
u8 status;
CC1101_CS_L(); //片选有效
while(CC1101_GetMISO());
status = CC1101_ReadWriteByte((u8)Cmd); //发送命令
while(CC1101_GetMISO());
CC1101_CS_H(); //片选关闭
return status;
}
/*************************************************************************************************************************
* 函数 : u8 CC1101_ReadReg(CC1101_REG_TYPE RegAddr)
* 功能 : 读取CC1101通用寄存器
* 参数 : RegAddr:寄存器地址,见:CC1101_REG_TYPE
* 返回 : 寄存器的值
* 依赖 : 底层宏定义
* 作者 : [email protected]
* 时间 : 2013-12-06
* 最后修改时间 : 2013-12-06
* 说明 : 一次读取一个寄存器
*************************************************************************************************************************/
u8 CC1101_ReadReg(CC1101_REG_TYPE RegAddr)
{
u8 data;
CC1101_CS_L(); //片选有效
CC1101_ReadWriteByte((u8)READ_SINGLE|RegAddr); //发送读命令以及寄存器索引
data = CC1101_ReadWriteByte(0xff); //读取
CC1101_CS_H(); //片选关闭
return data;
}
/*************************************************************************************************************************
* 函数 : u8 CC1101_WriteReg(CC1101_REG_TYPE RegAddr, u8 data)
* 功能 : 写入CC1101通用寄存器
* 参数 : RegAddr:寄存器地址,见:CC1101_REG_TYPE,data:需要写入的数据
* 返回 : 状态寄存器的值
* 依赖 : 底层宏定义
* 作者 : [email protected]
* 时间 : 2013-12-06
* 最后修改时间 : 2013-12-06
* 说明 : 一次写入一个寄存器,并返回状态
不要对只读的寄存器进行写操作
*************************************************************************************************************************/
u8 CC1101_WriteReg(CC1101_REG_TYPE RegAddr, u8 data)
{
u8 status;
if(RegAddr > 0x80) return 0; //防止误操作,0x30以后的寄存器为只读状态寄存器
CC1101_CS_L(); //片选有效
while(CC1101_GetMISO());
status = CC1101_ReadWriteByte((u8)WRITE_SINGLE|RegAddr); //发送写命令以及寄存器索引
CC1101_ReadWriteByte(data); //写入数据
CC1101_CS_H(); //片选关闭
return status;
}
#include "LED.h"
void CC1101_Init(u8 Addr)
{
//初始化片选
GPIOx_Init(GPIOA, BIT3, OUT_PP_10M);
CC1101_CS_H();
//初始化SCLK
GPIOx_Init(GPIOC, BIT5, OUT_PP_10M);
CC1101_SCLK_H();
//初始化MOSI
GPIOx_Init(GPIOC, BIT6, OUT_PP_10M);
CC1101_MOSI_H();
//初始化MISO
GPIOx_Init(GPIOC, BIT7, IN_UP);
CC1101_SCLK_L();
CC1101_MOSI_L();
//初始化GDO0,GDO2对应PC3,PC4
GPIOx_Init(GPIOC, BIT3, IN_UP);
GPIOx_Init(GPIOC, BIT4, IN_UP);
//初始化寄存器
CC1101_Command(CC1101_CMD_SRES); //复位
Delay_MS(10);
while(CC1101_ReadReg(CC1101_REG_AGCTEST) != 0x3F) //检测通信
{
LED_ON();
Delay_MS(10);
LED_OFF();
Delay_MS(100);
}
LED_OFF();
CC1101_WriteReg(CC1101_REG_IOCFG0,0x06); //发送提示引脚
CC1101_WriteReg(CC1101_REG_IOCFG2,0x01); //接收提示引脚
CC1101_WriteReg(CC1101_REG_FIFOTHR,0x0f); //RX FIFO和TX FIFO门限
CC1101_WriteReg(CC1101_REG_SYNC1,0xD3); //同步词汇,高字节
CC1101_WriteReg(CC1101_REG_SYNC0,0x91); //同步词汇,低字节
CC1101_WriteReg(CC1101_REG_PKTLEN,CC1101_DATA_LEN); //数据包长度,255
CC1101_WriteReg(CC1101_REG_PKTCTRL1,0x04); //数据包自动控制
CC1101_WriteReg(CC1101_REG_PKTCTRL0,0x04); //数据包自动控制
CC1101_WriteReg(CC1101_REG_ADDR,0x00); //设备地址
CC1101_WriteReg(CC1101_REG_CHANNR,0x00); //信道
CC1101_WriteReg(CC1101_REG_FSCTRL1,0x06); //频率合成器控制,高字节
CC1101_WriteReg(CC1101_REG_FSCTRL0,0x00); //频率合成器控制,低字节
CC1101_WriteReg(CC1101_REG_FREQ2,0x10); //频率控制词汇,高字节
CC1101_WriteReg(CC1101_REG_FREQ1,0xb1); //频率控制词汇,中间字节
CC1101_WriteReg(CC1101_REG_FREQ0,0x3b); //频率控制词汇,低字节
//2.4KBPS
CC1101_WriteReg(CC1101_REG_MDMCFG4,0xF6); //调制器配置
CC1101_WriteReg(CC1101_REG_MDMCFG3,0x83); //调制器配置
CC1101_WriteReg(CC1101_REG_MDMCFG2,0x13); //调制器配置
CC1101_WriteReg(CC1101_REG_MDMCFG1,0x22); //调制器配置
CC1101_WriteReg(CC1101_REG_MDMCFG0,0xf8); //调制器配置
CC1101_WriteReg(CC1101_REG_DEVIATN,0x15); //调制器背离设置
CC1101_WriteReg(CC1101_REG_MCSM2,0x07); //主通信控制状态机配置
CC1101_WriteReg(CC1101_REG_MCSM1,0x30); //主通信控制状态机配置
CC1101_WriteReg(CC1101_REG_MCSM0,0x18); //主通信控制状态机配置
CC1101_WriteReg(CC1101_REG_FOCCFG,0x16); //频率偏移补偿配置
CC1101_WriteReg(CC1101_REG_BSCFG,0x6c); //位同步配置
CC1101_WriteReg(CC1101_REG_AGCTRL2,0x03); //AGC控制
CC1101_WriteReg(CC1101_REG_AGCTRL1,0x40); //AGC控制
CC1101_WriteReg(CC1101_REG_AGCTRL0,0x91); //AGC控制
CC1101_WriteReg(CC1101_REG_WOREVT1,0x87); //高字节时间0暂停
CC1101_WriteReg(CC1101_REG_WOREVT0,0x6b); //低字节时间0暂停
CC1101_WriteReg(CC1101_REG_WORCTRL,0xfb); //电磁波激活控制
CC1101_WriteReg(CC1101_REG_FREND1,0x56); //前末端RX配置
CC1101_WriteReg(CC1101_REG_FREND0,0x10); //前末端TX配置
CC1101_WriteReg(CC1101_REG_FSCAL3,0xe9); //频率合成器校准
CC1101_WriteReg(CC1101_REG_FSCAL2,0x2a); //频率合成器校准
CC1101_WriteReg(CC1101_REG_FSCAL1,0x00); //频率合成器校准
CC1101_WriteReg(CC1101_REG_FSCAL0,0x1f); //频率合成器校准
CC1101_WriteReg(CC1101_REG_RCCTRL1,0x41); //RC振荡器配置
CC1101_WriteReg(CC1101_REG_RCCTRL0,0x00); //RC振荡器配置
CC1101_WriteReg(CC1101_REG_FSTEST,0x59); //频率合成器校准控制
//10DB
//CC1101_WriteReg(CC1101_REG_PATABLE0,0xc0);
//CC1101_WriteReg(CC1101_REG_PATABLE1,0xc0);
/*CC1101_WriteReg(CC1101_REG_PATABLE2,0xc0);
CC1101_WriteReg(CC1101_REG_PATABLE3,0xc0);
CC1101_WriteReg(CC1101_REG_PATABLE4,0xc0);
CC1101_WriteReg(CC1101_REG_PATABLE5,0xc0);
CC1101_WriteReg(CC1101_REG_PATABLE6,0xc0);
CC1101_WriteReg(CC1101_REG_PATABLE7,0xc0); */
Delay_MS(10);
}
/*************************************************************************************************************************
* 函数 : void CC1101_WriteTxFIFO(u8 *pBuff,u8 len)
* 功能 : 写入数据到发送缓冲区
* 参数 : pBuff:需要写入的数据缓冲区指针,len:需要写入的数据长度
* 返回 : 无
* 依赖 : 底层宏定义
* 作者 : [email protected]
* 时间 : 2014-01-01
* 最后修改时间 : 2014-01-01
* 说明 : 写入数据到发送FIFO
*************************************************************************************************************************/
void CC1101_WriteTxFIFO(u8 *pBuff,u8 len)
{
u16 i;
CC1101_CS_L();
CC1101_ReadWriteByte(BURST_WRITE_FIFO);
for(i = 0;i < len;i ++)
{
CC1101_ReadWriteByte(pBuff[i]);
}
CC1101_CS_H();
}
/*************************************************************************************************************************
* 函数 : void CC1101_ReadRxFIFO(u8 *pBuff,u8 len)
* 功能 : 读取接收缓冲区
* 参数 : pBuff:需要读取的数据缓冲区指针,len:需要读取的数据长度
* 返回 : 无
* 依赖 : 底层宏定义
* 作者 : [email protected]
* 时间 : 2014-01-01
* 最后修改时间 : 2014-01-01
* 说明 : 从接收FIFO读取数据
*************************************************************************************************************************/
void CC1101_ReadRxFIFO(u8 *pBuff,u8 len)
{
u16 i;
CC1101_CS_L();
CC1101_ReadWriteByte(BURST_READ_FIFO);
for(i = 0;i < len;i ++)
{
pBuff[i] = CC1101_ReadWriteByte(0xff);
}
CC1101_CS_H();
}
//发送数据,将缓冲区数据全部发送出去
//一次最多64B,因为受到FIFO限制
void CC1101_RfDataSend(u8 *pBuff,u8 len)
{
CC1101_Command(CC1101_CMD_SIDLE); //退出当前模式
CC1101_Command(CC1101_CMD_SFTX); //清空发送缓冲区
CC1101_WriteTxFIFO(pBuff, len); //写入数据到发送缓冲区
CC1101_Command(CC1101_CMD_STX); //开始发送数据
while(!CC1101_GDO0);
while(CC1101_GDO0);
CC1101_Command(CC1101_CMD_SIDLE); //退出当前模式
}
//发送数据包
//每次发送最多65B,第一字节为长度,数据多将会重复发送
//可以发送任意大小
//CC1101PackSize有效数据包大小,0-64,也就是CC1101单次发送数据大小-1
void CC1101_RfDataSendPack(u8 *pBuff, u16 len)
{
u16 i,m,n,j;
m = len / (CC1101_DATA_LEN-1); //整数数据帧数量
n = len % (CC1101_DATA_LEN-1); //余数
//发送整数包
for(i = 0;i < m;i ++)
{
Delay_MS(1);
CC1101_Command(CC1101_CMD_SIDLE); //退出当前模式
CC1101_Command(CC1101_CMD_SFTX); //清空发送缓冲区
CC1101_CS_L();
CC1101_ReadWriteByte(BURST_WRITE_FIFO);
CC1101_ReadWriteByte(CC1101_DATA_LEN-1);//先写入包大小
for(j = 0;j < (CC1101_DATA_LEN-1);j ++)
{
CC1101_ReadWriteByte(*pBuff++); //写入数据到发送缓冲区
}
CC1101_CS_H();
CC1101_Command(CC1101_CMD_STX); //开始发送数据
while(!CC1101_GDO0);
while(CC1101_GDO0); //等待发送完成
}
//发送余数包
if(n!=0)
{
Delay_MS(1);
CC1101_Command(CC1101_CMD_SIDLE); //退出当前模式
CC1101_Command(CC1101_CMD_SFTX); //清空发送缓冲区
CC1101_CS_L();
CC1101_ReadWriteByte(BURST_WRITE_FIFO);
CC1101_ReadWriteByte(n); //先写入包大小
for(j = 0;j < n;j ++)
{
CC1101_ReadWriteByte(*pBuff++); //写入数据到发送缓冲区
}
CC1101_CS_H();
CC1101_Command(CC1101_CMD_STX); //开始发送数据
while(!CC1101_GDO0);
while(CC1101_GDO0); //等待发送完成
}
CC1101_Command(CC1101_CMD_SIDLE); //退出当前模式
}
//读取芯片状态
u8 CC1101_GetStatus(void)
{
return CC1101_WriteReg(CC1101_REG_TEST2, 0x98);
}
CC1101.H
/*************************************************************************************************************
* 文件名: CC1101.c
* 功能: STM8 CC1101驱动函数
* 作者: [email protected]
* 创建时间: 2013-12-06 14:35
* 最后修改时间:2013-12-06
* 详细: 433MHZ收发芯片驱动
*************************************************************************************************************/
#ifndef _CC1101_H_
#define _CC1101_H_
#include "system.h"
//CC1101 命令
//以写的方式单直接访问将触发响应的命令
typedef enum
{
CC1101_CMD_SRES = 0x30, //重启
CC1101_CMD_SFSTXON = 0x31, //开启和校准频率合成器(若MCSM0.FSAUTOCAL=1)
CC1101_CMD_SXOFF = 0x32, //关闭晶体振荡器
CC1101_CMD_SCAL = 0x33, //校准频率合成器并关断(开启快速启动)。在不设置手动校准模式(MCSM0.FS_AUTOCAL=0)的情况下,SCAL能从空闲模式滤波。
CC1101_CMD_SRX = 0x34, //启用RX。若上一状态为空闲且MCSM0.FS_AUTOCAL=1则首先运行校准。
CC1101_CMD_STX = 0x35, //空闲状态:启用TX。若MCSM0.FS_AUTOCAL=1首先运行校准。若在RX状态且CCA启用:若信道为空则进入TX
CC1101_CMD_SIDLE = 0x36, //离开RX/TX,关断频率合成器并离开电磁波激活模式若可用
CC1101_CMD_SAFC = 0x37, //运行22.1节列出的频率合成器的AFC调节
CC1101_CMD_SWOR = 0x38, //运行27.5节描述的自动RX选举序列(电磁波激活)
CC1101_CMD_SPWD = 0x39, //当CSn为高时进入功率降低模式。
CC1101_CMD_SFRX = 0x3a, //冲洗RX FIFO缓冲
CC1101_CMD_SFTX = 0x3b, //冲洗TX FIFO缓冲
CC1101_CMD_SWORRST = 0x3c, //重新设置真实时间时钟
CC1101_CMD_SNOP = 0x3d, //无操作。可能用来为更简单的软件将滤波命令变为2字节。
}CC1101_CMD_TYPE;
//CC1101寄存器定义
typedef enum
{
//可读写的寄存器
CC1101_REG_IOCFG2 = 0x00, //GDO2输出脚配置
CC1101_REG_IOCFG1 = 0x01, //GDO1输出脚配置
CC1101_REG_IOCFG0 = 0x02, //GDO0输出脚配置
CC1101_REG_FIFOTHR = 0x03, //RX FIFO和TX FIFO门限
CC1101_REG_SYNC1 = 0x04, //同步词汇,高字节
CC1101_REG_SYNC0 = 0x05, //同步词汇,低字节
CC1101_REG_PKTLEN = 0x06, //数据包长度
CC1101_REG_PKTCTRL1 = 0x07, //数据包自动控制
CC1101_REG_PKTCTRL0 = 0x08, //数据包自动控制
CC1101_REG_ADDR = 0x09, //设备地址
CC1101_REG_CHANNR = 0x0a, //信道数
CC1101_REG_FSCTRL1 = 0x0b, //频率合成器控制,高字节
CC1101_REG_FSCTRL0 = 0x0c, //频率合成器控制,低字节
CC1101_REG_FREQ2 = 0x0d, //频率控制词汇,高字节
CC1101_REG_FREQ1 = 0x0e, //频率控制词汇,中间字节
CC1101_REG_FREQ0 = 0x0f, //频率控制词汇,低字节
CC1101_REG_MDMCFG4 = 0x10, //调制器配置
CC1101_REG_MDMCFG3 = 0x11, //调制器配置
CC1101_REG_MDMCFG2 = 0x12, //调制器配置
CC1101_REG_MDMCFG1 = 0x13, //调制器配置
CC1101_REG_MDMCFG0 = 0x14, //调制器配置
CC1101_REG_DEVIATN = 0x15, //调制器背离设置
CC1101_REG_MCSM2 = 0x16, //主通信控制状态机配置
CC1101_REG_MCSM1 = 0x17, //主通信控制状态机配置
CC1101_REG_MCSM0 = 0x18, //主通信控制状态机配置
CC1101_REG_FOCCFG = 0x19, //频率偏移补偿配置
CC1101_REG_BSCFG = 0x1a, //位同步配置
CC1101_REG_AGCTRL2 = 0x1b, //AGC控制
CC1101_REG_AGCTRL1 = 0x1c, //AGC控制
CC1101_REG_AGCTRL0 = 0x1d, //AGC控制
CC1101_REG_WOREVT1 = 0x1e, //高字节时间0暂停
CC1101_REG_WOREVT0 = 0x1f, //低字节时间0暂停
CC1101_REG_WORCTRL = 0x20, //电磁波激活控制
CC1101_REG_FREND1 = 0x21, //前末端RX配置
CC1101_REG_FREND0 = 0x22, //前末端TX配置
CC1101_REG_FSCAL3 = 0x23, //频率合成器校准
CC1101_REG_FSCAL2 = 0x24, //频率合成器校准
CC1101_REG_FSCAL1 = 0x25, //频率合成器校准
CC1101_REG_FSCAL0 = 0x26, //频率合成器校准
CC1101_REG_RCCTRL1 = 0x27, //RC振荡器配置
CC1101_REG_RCCTRL0 = 0x28, //RC振荡器配置
CC1101_REG_FSTEST = 0x29, //频率合成器校准控制
CC1101_REG_PTEST = 0x2a, //产品测试
CC1101_REG_AGCTEST = 0x2b, //AGC测试
CC1101_REG_TEST2 = 0x2c, //不同的测试设置
CC1101_REG_TEST1 = 0x2d, //不同的测试设置
CC1101_REG_TEST0 = 0x2e, //不同的测试设置
//只读的状态寄存器,如果写入将导致命令滤波
CC1101_REG_PARTNUM = 0xf0, //CC2550的组成部分数目
CC1101_REG_VERSION = 0xf1, //当前版本数
CC1101_REG_FREQEST = 0xf2, //频率偏移估计
CC1101_REG_LQI = 0xf3, //连接质量的解调器估计
CC1101_REG_RSSI = 0xf4, //接收信号强度指示
CC1101_REG_MARCSTATE = 0xf5, //控制状态机状态
CC1101_REG_WORTIME1 = 0xf6, //WOR计时器高字节
CC1101_REG_WORTIME0 = 0xf7, //WOR计时器低字节
CC1101_REG_PKTSTATUS = 0xf8, //当前GDOx状态和数据包状态
CC1101_REG_VCOVCDAC = 0xf9, //PLL校准模块的当前设定
CC1101_REG_TXBYTES = 0xfA, //TX FIFO中的下溢和比特数
CC1101_REG_RXBYTES = 0xfB, //RX FIFO中的下溢和比特数
//手册上面没有的
CC1101_REG_STATUS1 = 0xfc, //
CC1101_REG_STATUS0 = 0xfd, //
//功率控制
CC1101_REG_PATABLE0 = 0x40,
CC1101_REG_PATABLE1 = 0x41,
CC1101_REG_PATABLE2 = 0x42,
CC1101_REG_PATABLE3 = 0x43,
CC1101_REG_PATABLE4 = 0x44,
CC1101_REG_PATABLE5 = 0x45,
CC1101_REG_PATABLE6 = 0x46,
CC1101_REG_PATABLE7 = 0x47,
}CC1101_REG_TYPE;
//IO
#define CC1101_GDO0 (GPIOC->IDR&BIT3) //PC3
#define CC1101_GDO2 (GPIOC->IDR&BIT4) //PC4
void CC1101_Init(u8 Addr); //初始化CC1101
u8 CC1101_ReadReg(CC1101_REG_TYPE RegAddr); //读取CC1101通用寄存器
u8 CC1101_WriteReg(CC1101_REG_TYPE RegAddr, u8 data);//写入CC1101通用寄存器
u8 CC1101_Command(CC1101_CMD_TYPE Cmd); //发送单字节命令
u8 CC1101_GetStatus(void);//读取芯片状态
void CC1101_RfDataSend(u8 *pBuff,u8 len);
void CC1101_ReadRxFIFO(u8 *pBuff,u8 len);
//CC1101PackSize有效数据包大小,0-64,也就是CC1101单次发送数据大小-1
void CC1101_RfDataSendPack(u8 *pBuff, u16 len);
#endif //CC1101
MAIN.C收发透传
#include "system.h"
#include "uart1.h"
#include "delay.h"
#include "main.h"
#include "LED.h"
#include "cc1101.h"
//串口缓冲区
#define UART_BUFF_SIZE 256 //串口接收缓冲区大小
u8 UartBuff[2][UART_BUFF_SIZE]; //串口接收缓冲区
u16 UartLen1 = 0; //串口接收数据长度
u16 UartLen2 = 0; //串口接收数据长度
//CC1101缓冲区
#define RF_BUFF_SIZE 64 //CC1101缓冲区大小
u8 RfBuff[RF_BUFF_SIZE]; //CC1101缓冲区
u8 RfLen = 0; //CC1101接收缓冲区大小
//缓冲区选择
u8 UART_RxNum = 0; //串口缓冲区选择
//主函数
void main(void)
{
u8 LastNum = 0;
u32 delay = 0;
SYS_ClockInit(); //初始化系统时钟为内部晶振, 16MHZ
//初始化LED
LED_Init();
//初始化串口
UART1_Init(115200, ENABLE); //初始化UART1,开启接收中断
UART1_SetRxBuff(UartBuff[UART_RxNum],UART_BUFF_SIZE); //设置串口1接收缓冲区
CC1101_Init(0Xaa);
//CC1101_WriteReg(CC1101_REG_PATABLE1,0xc0);
CC1101_WriteReg(CC1101_REG_PATABLE0,0x00);
CC1101_Command(CC1101_CMD_SIDLE); //退出当前模式
CC1101_Command(CC1101_CMD_SRX); //进入接收模式
SYS_EnableInterrupt(); //开启系统中断
while(1)
{
if(++delay == 120000)
{
delay = 0;
UartLen1 = UART1_GetRxCnt(); //获取接收数据数量
if(UartLen1>0)
{
SYS_DisableInterrupt(); //关闭中断
LED_ON();
LastNum = UART_RxNum; //记录上一次的缓冲区编号
UART_RxNum = (~UART_RxNum)&0x01;
UART1_SetRxBuff(UartBuff[UART_RxNum],UART_BUFF_SIZE); //切换串口接收缓冲区
//UART1_ClearRxCnt(); //清除接收计数器
SYS_EnableInterrupt(); //开启系统中断
CC1101_WriteReg(CC1101_REG_PATABLE0,0xc0);//开启天线增益
CC1101_RfDataSendPack(UartBuff[LastNum], UartLen1);//CC1101发送数据包
CC1101_WriteReg(CC1101_REG_PATABLE0,0); //关闭天线增益
CC1101_Command(CC1101_CMD_SIDLE); //退出当前模式
CC1101_Command(CC1101_CMD_SRX); //进入接收模式
LED_OFF();
}
}
//CC1101接收到数据
if(CC1101_GDO2)
{
LED_ON();
RfLen = CC1101_ReadReg(CC1101_REG_RXBYTES);
CC1101_ReadRxFIFO(RfBuff,RfLen);
UART1_SendData(&RfBuff[1], RfBuff[0]);//第0B为数据长度,后面的为有效数据
CC1101_Command(CC1101_CMD_SIDLE); //退出当前模式
CC1101_Command(CC1101_CMD_SFRX); //清除接收缓冲区
CC1101_Command(CC1101_CMD_SRX); //进入接收模式
LED_OFF();
}
}
}
实物图