MSP430+nRF24L01程序

发布者:yunhui最新更新时间:2015-06-18 来源: 51hei关键字:MSP430  nRF24L01 手机看文章 扫描二维码
随时随地手机看文章
**************************************************
来源:网上
改写:bluefeel
时间:10-03-13
单位:桂林理工大学
/**************************************************/
#include
#include
#define uchar unsigned char
/***************************************************/
#define TX_ADR_WIDTH   5  // 5字节宽度的发送/接收地址
#define TX_PLOAD_WIDTH 4  // 数据通道有效数据宽度
#define LED P2
uchar code TX_ADDRESS[TX_ADR_WIDTH] = {0x34,0x43,0x10,0x10,0x01};  // 定义一个静态发送地址
uchar RX_BUF[TX_PLOAD_WIDTH];
uchar TX_BUF[TX_PLOAD_WIDTH];
uchar flag;
uchar DATA = 0x01;
uchar bdata sta;
sbit  RX_DR  = sta^6;
sbit  TX_DS  = sta^5;
sbit  MAX_RT = sta^4;
/**************************************************/
/**************************************************
函数: init_io()
描述:
    初始化IO
/**************************************************/
void init_io(void)
{
    CE  = 0;        // 待机
    CSN = 1;        // SPI禁止
    SCK = 0;        // SPI时钟置低
    IRQ = 1;        // 中断复位
    LED = 0xff;     // 关闭指示灯
}
/**************************************************/
/**************************************************
函数:delay_ms()
描述:
    延迟x毫秒
/**************************************************/
void delay_ms(uchar x)
{
    uchar i, j;
    i = 0;
    for(i=0; i     {
       j = 250;
       while(--j);
       j = 250;
       while(--j);
    }
}
/**************************************************/
/**************************************************
函数:SPI_RW()
描述:
    根据SPI协议,写一字节数据到nRF24L01,同时从nRF24L01
    读出一字节
/**************************************************/
uchar SPI_RW(uchar byte)
{
    uchar i;
    for(i=0; i<8; i++)          // 循环8次
    {
        MOSI = (byte & 0x80);   // byte最高位输出到MOSI
        byte <<= 1;             // 低一位移位到最高位
        SCK = 1;                // 拉高SCK,nRF24L01从MOSI读入1位数据,同时从MISO输出1位数据
        byte |= MISO;           // 读MISO到byte最低位
        SCK = 0;                // SCK置低
    }
    return(byte);               // 返回读出的一字节
}
/**************************************************/
/**************************************************
函数:SPI_RW_Reg()
描述:
    写数据value到reg寄存器
/**************************************************/
uchar SPI_RW_Reg(uchar reg, uchar value)
{
    uchar status;
    CSN = 0;                   // CSN置低,开始传输数据
    status = SPI_RW(reg);      // 选择寄存器,同时返回状态字
    SPI_RW(value);             // 然后写数据到该寄存器
    CSN = 1;                   // CSN拉高,结束数据传输
    return(status);            // 返回状态寄存器
}
/**************************************************/
/**************************************************
函数:SPI_Read()
描述:
    从reg寄存器读一字节
/**************************************************/
uchar SPI_Read(uchar reg)
{
    uchar reg_val;
    CSN = 0;                    // CSN置低,开始传输数据
    SPI_RW(reg);                // 选择寄存器
    reg_val = SPI_RW(0);        // 然后从该寄存器读数据
    CSN = 1;                    // CSN拉高,结束数据传输
    return(reg_val);            // 返回寄存器数据
}
/**************************************************/
/**************************************************
函数:SPI_Read_Buf()
描述:
    从reg寄存器读出bytes个字节,通常用来读取接收通道
    数据或接收/发送地址
/**************************************************/
uchar SPI_Read_Buf(uchar reg, uchar * pBuf, uchar bytes)
{
    uchar status, i;
    CSN = 0;                    // CSN置低,开始传输数据
    status = SPI_RW(reg);       // 选择寄存器,同时返回状态字
    for(i=0; i         pBuf[i] = SPI_RW(0);    // 逐个字节从nRF24L01读出
    CSN = 1;                    // CSN拉高,结束数据传输
    return(status);             // 返回状态寄存器
}[page]
/**************************************************/
/**************************************************
函数:SPI_Write_Buf()
描述:
    把pBuf缓存中的数据写入到nRF24L01,通常用来写入发
    射通道数据或接收/发送地址
/**************************************************/
uchar SPI_Write_Buf(uchar reg, uchar * pBuf, uchar bytes)
{
    uchar status, i;
    CSN = 0;                    // CSN置低,开始传输数据
    status = SPI_RW(reg);       // 选择寄存器,同时返回状态字
    for(i=0; i         SPI_RW(pBuf[i]);        // 逐个字节写入nRF24L01
    CSN = 1;                    // CSN拉高,结束数据传输
    return(status);             // 返回状态寄存器
}
/**************************************************/
/**************************************************
函数:RX_Mode()
描述:
    这个函数设置nRF24L01为接收模式,等待接收发送设备的数据包
/**************************************************/
void RX_Mode(void)
{
    CE = 0;
    SPI_Write_Buf(WRITE_REG + RX_ADDR_P0, TX_ADDRESS, TX_ADR_WIDTH);  // 接收设备接收通道0使用和发送设备相同的发送地址
    SPI_RW_Reg(WRITE_REG + EN_AA, 0x01);               // 使能接收通道0自动应答
    SPI_RW_Reg(WRITE_REG + EN_RXADDR, 0x01);           // 使能接收通道0
    SPI_RW_Reg(WRITE_REG + RF_CH, 40);                 // 选择射频通道0x40
    SPI_RW_Reg(WRITE_REG + RX_PW_P0, TX_PLOAD_WIDTH);  // 接收通道0选择和发送通道相同有效数据宽度
    SPI_RW_Reg(WRITE_REG + RF_SETUP, 0x07);            // 数据传输率1Mbps,发射功率0dBm,低噪声放大器增益
    SPI_RW_Reg(WRITE_REG + CONFIG, 0x0f);              // CRC使能,16位CRC校验,上电,接收模式
    CE = 1;                                            // 拉高CE启动接收设备
}
/**************************************************/
/**************************************************
函数:TX_Mode()
描述:
    这个函数设置nRF24L01为发送模式,(CE=1持续至少10us),
    130us后启动发射,数据发送结束后,发送模块自动转入接收
    模式等待应答信号。
/**************************************************/
void TX_Mode(uchar * BUF)
{
    CE = 0;
    SPI_Write_Buf(WRITE_REG + TX_ADDR, TX_ADDRESS, TX_ADR_WIDTH);     // 写入发送地址
    SPI_Write_Buf(WRITE_REG + RX_ADDR_P0, TX_ADDRESS, TX_ADR_WIDTH);  // 为了应答接收设备,接收通道0地址和发送地址相同
    SPI_Write_Buf(WR_TX_PLOAD, BUF, TX_PLOAD_WIDTH);                  // 写数据包到TX FIFO
    SPI_RW_Reg(WRITE_REG + EN_AA, 0x01);       // 使能接收通道0自动应答
    SPI_RW_Reg(WRITE_REG + EN_RXADDR, 0x01);   // 使能接收通道0
    SPI_RW_Reg(WRITE_REG + SETUP_RETR, 0x0a);  // 自动重发延时等待250us+86us,自动重发10次
    SPI_RW_Reg(WRITE_REG + RF_CH, 40);         // 选择射频通道0x40
    SPI_RW_Reg(WRITE_REG + RF_SETUP, 0x07);    // 数据传输率1Mbps,发射功率0dBm,低噪声放大器增益
    SPI_RW_Reg(WRITE_REG + CONFIG, 0x0e);      // CRC使能,16位CRC校验,上电
    CE = 1;
}
/**************************************************/
/**************************************************
函数:Check_ACK()
描述:
    检查接收设备有无接收到数据包,设定没有收到应答信
    号是否重发
/**************************************************/
uchar Check_ACK(bit clear)
{
    while(IRQ);
    sta = SPI_RW(NOP);                    // 返回状态寄存器
    if(MAX_RT)
        if(clear)                         // 是否清除TX FIFO,没有清除在复位MAX_RT中断标志后重发
            SPI_RW(FLUSH_TX);
    SPI_RW_Reg(WRITE_REG + STATUS, sta);  // 清除TX_DS或MAX_RT中断标志
    IRQ = 1;
    if(TX_DS)
        return(0x00);
    else
        return(0xff);
}
/**************************************************/
/**************************************************
函数:CheckButtons()
描述:
    检查按键是否按下,按下则发送一字节数据
/**************************************************/
void CheckButtons()
{
    P3 |= 0x00;
    if(!(P3 & 0x01))                    // 读取P3^0状态
    {
        delay_ms(20);
        if(!(P3 & 0x01))                // 读取P3^0状态
        {
            TX_BUF[0] = ~DATA;          // 数据送到缓存
            TX_Mode(TX_BUF);            // 把nRF24L01设置为发送模式并发送数据
            LED = ~DATA;                // 数据送到LED显示
            Check_ACK(1);               // 等待发送完毕,清除TX FIFO
            delay_ms(250);
            delay_ms(250);
            LED = 0xff;                 // 关闭LED
            RX_Mode();                  // 设置为接收模式
            while(!(P3 & 0x01));
            DATA <<= 1;
            if(!DATA)
                DATA = 0x01;
        }
    }
}
/**************************************************/
/**************************************************
函数:main()
描述:
    主函数
/**************************************************/
void main(void)
{
    init_io();                    // 初始化IO
    RX_Mode();                    // 设置为接收模式
    while(1)
    {
        CheckButtons();           // 按键扫描
        sta = SPI_Read(STATUS);   // 读状态寄存器
        if(RX_DR)                 // 判断是否接受到数据
        {
            SPI_Read_Buf(RD_RX_PLOAD, RX_BUF, TX_PLOAD_WIDTH);  // 从RX FIFO读出数据
            flag = 1;
        }
        SPI_RW_Reg(WRITE_REG + STATUS, sta);  // 清除RX_DS中断标志
        if(flag)                   // 接受完成
        {
            flag = 0;              // 清标志
            LED = RX_BUF[0];       // 数据送到LED显示
            delay_ms(250);
            delay_ms(250);
            LED = 0xff;            // 关闭LED
        }
    }
}
/**************************************************/
关键字:MSP430  nRF24L01 引用地址:MSP430+nRF24L01程序

上一篇:ATMEGA16驱动内部EEPROM程序
下一篇:AMPIRE12864驱动程序

推荐阅读最新更新时间:2024-03-16 14:04

MSP430f149使用XT2的8M晶振输出PWM
由于需要将PWM保持在20khz来控制BUCK电路降压,同时又需要步进改动占空比,故需要TA利用8M晶振输出PWM,经测试,最大占空比频率可达4M,将频率定为20khz时,有200个步进点,BUCK输入电压为18V,每次改变占空比输出电压约变化0.1V可达到要求。 系统版XT2IN与XT2O直接连接高频晶振8M晶振,TI官方例程所给程序无使用XT2的程序(但是有开启HF XTAL的:BCSCTL1 |= XTS;)由于我们的板子8M晶振被接在了XT2IN和XT2O上,所以只能使用(BCSCTL1 &= ~XT2OFF; //打开XT2高频晶体振荡器)来打开8M晶振,之后通过(BCSCTL2 |= SELM_2 + SELS;
[单片机]
基于MSP430系列单片机的CAN总线接口转换卡设计
MSP430系列单片机是一种超低功耗的混合信号控制器,具有丰富的片内外设,有极其广阔的应用范围。介绍基于MSP430系列单片机的RS232/RS485 CAN总线通信转换接口的设计与实现,重点讨论其硬件配置和软件功能,给出电气原理和软件流程。 关键词:MSP430;CAN总线;接口;转换卡;设计 1 引言 控制器局域网(Controller Area Network,简称CAN)是德国奔驰公司20世纪80年代为解决汽车众多控制设备与仪器仪表之间的数据交换开发的一种串行通信协议。它作为现场总线的一种广泛应用于各种工业现场,根据不同的需要或以主从方式、或以多主方式工作。CAN总线使用的通信介质为双绞线或其他电缆,传输速率可达lM
[单片机]
基于<font color='red'>MSP430</font>系列单片机的CAN总线接口转换卡设计
基于FRAM技术的MSP430微控制器能量采集
  对于很多人来说,第一次接触能量采集可能是在早期使用太阳能便携式计算器的时候,虽然如今这种类型的计算器已不再是主流,但是它所使用的技术和理念仍然应用于我们的日常生活中。目前,我们在许多的应用中都能看到能量采集的身影,例如传感器节点、风力涡轮机和室内供能应用等。不过,即使对于这项技术的讨论较之前已经有了很大的发展,当涉及到能量采集时,开发人员仍然面临着与数十年前一样的挑战。   为了在不带来负面影响的情况下产生出所需的能量,通常需要一块物理尺寸很大的太阳能板和一套巨大的热能采集装置,或者是通过设备发出不同频率范围的振动来获得能量,而一切都是由所使用的系统决定。因此,在很多情况下,这个系统的成本甚至会超过取代传统电源所带来的优势
[单片机]
基于FRAM技术的<font color='red'>MSP430</font>微控制器能量采集
MSP430单片机的ADC详解
ADC模数转化器是430单片机的重要的片上外设,而且在开发当中也常常需要用到ADC,下面根据使用手册结合我个人的学习感悟,总结一下430的ADC的使用要点。 430的ADC的特点: 1、是一个12位的逐次比较式的ADC,即转化结果为0-4096。 2、独立于CPU,可以通关软件配置自己的时钟源。 3、有8个转化通道,并且可以通关软件配置它的正负参考电压。 4、转化速率 =200KSPS,即每秒转化200K次。 5、有16个12位的转化结果存储单元。 6、转化结果为Nadc。 转化结果和VR+与VR-有关,因此,在使用ADC的时候要配置正确。 7、转化使用的时钟信号有四个: 分别是:MCLK
[单片机]
<font color='red'>MSP430</font>单片机的ADC详解
MSP430F5438学习笔记 DCO倍频至8MHZ
1.平台说明 MS430F5438 // 时钟默认情况 // FLL时钟 FLL选择 XT1 // 辅助时钟 ACLK选择 XT1 32768Hz // 主系统时钟 MCLK选择 DCOCLKDIV 1048576Hz // 子系统时钟 SMCLK选择 DCOCLKDIV 1048576Hz #include msp430.h void clock_config(void); void select_xt1(void); void dco_config(void); int main(void) { clock_config(); // 初始化时钟 P4DI
[单片机]
一种基于无线传感网的车位检测系统设计
引言 伴随着我国科技和经济的进步,汽车产业在近几年进入了迅猛发展阶段。根据统计数据,2013年,我国汽车保有量已达到1.37亿辆,是2003年汽车数量的5.7倍,占全部机动车的比率达到54.9%,比10年前提高了29.9%。汽车数量急剧增长,但相应的配套设施和监管等方面的相对滞后,车位资源稀缺,可以说 停车难 成为了中国乃至全球亟待解决的重大问题。而解决这一难题,一方面要增加城市停车位的数量,另一方面则是要提高停车的效率。 本文所设计的智能停车系统采用地磁检测机制并结合无线传感网技术,具有车位检测节点功耗低、系统部署维护方便、施工成本低等特点,检测节点和路由节点之间采用433 MHz传输,对环境无特殊要求,抗干扰能力强。车主能够通
[单片机]
一种基于无线传感网的车位检测系统设计
MSP430 PWM
就MSP430F149而言,内部有定时器A和B,称为TimerA3,TimerB7,因此,可以有8个PWM输出,即TA1,TA2,TB1,TB2,TB3,TB4,TB5,TB6,它们实现PWM占空比的调整和控制,输出的是希望的PWM信号。另外两个TA0,TB0用于PWM周期(或者称为频率)控制,不能输出PWM信号,这是由430的定时器工作模式所决定的。 PWM输出对应的引脚(MSP430X14X系列): TA0:P1.1,P1.5,P2.2,P2.7 TA1:P1.2,P1.6,P2.3 TA2:P1.3,P1.7,P2.4 TB0:P4.0 TB1:P4.1 TB2:P4.2 TB3:P
[单片机]
MSP430单片机中的WDT研究
引 言   软件的可靠性一直是一个关键问题。任何使用软件的人都可能会经历计算机死机或程序跑飞的问题,这种情况在嵌入式系统中也同样存在。由于单片机的抗干扰能力有限,在工业现场的仪器仪表中,常会由于电压不稳、电弧干扰等造成死机。在水表、电表等无人看守的情况下,也会因系统遭受干扰而无法重启。为了保证系统在干扰后能自动恢复正常,看门狗定时器(Watchdog Timer)的利用是很有价值的。 1 看门狗的作用   看门狗定时器是一个计数器,基本功能是在发生软件问题和程序跑飞后使系统重新启动。看门狗计数器正常工作时自动计数,程序流程定期将其复位清零,如果系统在某处卡死或跑飞,该定时器将溢出,并将进入中断。在定时器中断中执行一些复位操作,使
[单片机]
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

更多精选电路图
换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved