找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 3165|回复: 0
打印 上一主题 下一主题
收起左侧

NRF无线传输实验

[复制链接]
跳转到指定楼层
楼主
ID:75926 发表于 2015-4-10 17:21 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
  1. NRF的引脚有               IRQ:中断引脚 接收到数据或者发射数据完成的时候会被拉低 可以设置成引发中断
  2.                                        MOSI  :SPI总线的数据发射引脚
  3.                                     MISO :SPI 总线的数据接收引脚
  4.                                     CS:低电平有效 SPI的片选引脚
  5.                                     CE:NRF的发射或者接收选择引脚
  6.                                     SCK:SPI总线的时钟线
  7.     有硬件SPI功能的MCU 可以忽略这部分

  8.     typedef unsigned char uint8_t;
  9. uint8_t SPI_SR(uint8_t Data)
  10. {   
  11.     uint8_t i,buff=0;
  12.     SCK_L;
  13.     for(i=0;i<8;i++)
  14.     {
  15.         if(Data&0x80)
  16.             MOSI_H;
  17.         else
  18.             MOSI_L;
  19.         SCK_H;
  20.         Data<<=1;
  21.         buff++;
  22.         if(MISO)
  23.             buff++;
  24.         SCK_L;
  25.     }
  26.     return Status;
  27. }

  28. uint8_t NRF_WriteReg(uint8_t reg,uint8_t data)
  29. {
  30.     uint8_t Status;
  31.     CS_L;
  32.     CE_L;
  33.     Status=SPI_SR(reg);
  34.     SPI_SR(Data);
  35.     CS_H;
  36.     return Status;
  37. }

  38. uint8_t NRF_ReadReg(uint8_t reg)
  39. {
  40.     uint8_t val;
  41.     CS_L;
  42.     CE_L;
  43.     SPI_SR(reg);
  44.     val=SPI_SR(0xff);
  45.     CS_H;
  46.     return val;
  47. }

  48. uint8_t NRF_WriteBuff(uint8_t reg,uint8_t *buff,uint8_t Byte)
  49. {
  50.     uint8_t i,Status;
  51.     CE_L;
  52.     CS_L;
  53.     Status=NRF_SR(reg);
  54.     for(i=0;i<Byte;i++)
  55.         SPI_SR(buff[i]);   
  56.     CS_H;
  57.     return Status;
  58. }

  59. uint8_t NRF_ReadReg(uint8_t reg,uint8_t buff,uint8_t Byte)
  60. {
  61.     uint8_t i,Status;
  62.     CE_L;
  63.     CS_L;
  64.     Status=NRF_SR(reg);
  65.     for(i=0;i<Byte,i++)
  66.         buff[i]=SPI_SR(0xff);
  67.     CS_H;
  68.     return Status;
  69. }

  70. void NRF_SetMode(uint8_t flag)  //1:发射,0接收
  71. {
  72.     if(flag!=0)
  73.     {
  74.         NRF_CE_L;       

  75.    NRF_WriteBuff(NRF_WRITE_REG+RX_ADDR_P0,RX_ADDRESS,RX_ADR_WIDTH);//写RX节点地址      //寄存器地址               地址          地址宽度

  76.    NRF_WriteReg(NRF_WRITE_REG+EN_AA,0x01);    //使能通道0的自动应答   

  77.    NRF_WriteReg(NRF_WRITE_REG+EN_RXADDR,0x01);//使能通道0的接收地址   

  78.    NRF_WriteReg(NRF_WRITE_REG+RF_CH,CHANAL);      //设置RF通信频率   

  79.    NRF_WriteReg(NRF_WRITE_REG+RX_PW_P0,RX_PLOAD_WIDTH);//选择通道0的有效数据宽度      

  80.    NRF_WriteReg(NRF_WRITE_REG+RF_SETUP,0x0f); //设置TX发射参数,0db增益,2Mbps,低噪声增益开启   

  81.    NRF_WriteReg(NRF_WRITE_REG+CONFIG, 0x0f);  //配置基本工作模式的参数;PWR_UP,EN_CRC,16BIT_CRC,接收模式

  82. /*CE拉高,进入接收模式*/       
  83.   NRF_CE_H;
  84.     }
  85.     else
  86.     {
  87.           NRF_CE_L;       

  88.    NRF_WriteBuff(NRF_WRITE_REG+TX_ADDR,TX_ADDRESS,TX_ADR_WIDTH);    //写TX节点地址

  89.    NRF_WriteBuff(NRF_WRITE_REG+RX_ADDR_P0,RX_ADDRESS,RX_ADR_WIDTH); //设置TX节点地址,主要为了使能ACK   

  90.    NRF_WriteReg(NRF_WRITE_REG+EN_AA,0x01);     //使能通道0的自动应答   

  91.    NRF_WriteReg(NRF_WRITE_REG+EN_RXADDR,0x01); //使能通道0的接收地址  

  92.    NRF_WriteReg(NRF_WRITE_REG+SETUP_RETR,0x1a);//设置自动重发间隔时间:500us + 86us;最大自动重发次数:10次

  93.    NRF_WriteReg(NRF_WRITE_REG+RF_CH,CHANAL);       //设置RF通道为CHANAL

  94.    NRF_WriteReg(NRF_WRITE_REG+RF_SETUP,0x0f);  //设置TX发射参数,0db增益,2Mbps,低噪声增益开启   
  95.    NRF_WriteReg(NRF_WRITE_REG+CONFIG,0x0e);    //配置基本工作模式的参数;PWR_UP,EN_CRC,16BIT_CRC,发射模式,开启所有中断

  96. /*CE拉高,进入发送模式*/       
  97.   NRF_CE_H;
  98.     Delay(0xffff); //CE要拉高一段时间才进入发送模式
  99.     }
  100. }
复制代码

  1. /**
  2.   * @brief   用于向NRF的发送缓冲区中写入数据
  3.   * @param   
  4.   *        @arg txBuf:存储了将要发送的数据的数组,外部定义       
  5.   * @retval  发送结果,成功返回TXDS,失败返回MAXRT或ERROR
  6.   */
  7. uint8_t NRF_Tx_Data(uint8_t *txbuf)
  8. {
  9. uint8_t State;  

  10. /*ce为低,进入待机模式1*/
  11. NRF_CE_L;

  12. /*写数据到TX BUF 最大 32个字节*/       
  13.    NRF_WriteBuff(WR_TX_PLOAD,txbuf,TX_PLOAD_WIDTH);

  14.       /*CE为高,txbuf非空,发送数据包 */   
  15.         NRF_CE_H;
  16.        
  17. /*等待发送完成中断 */                           
  18. while(NRF_IRQ!=0);
  19. /*读取状态寄存器的值 */                              
  20. State = NRF_ReadReg(STATUS);

  21. /*清除TX_DS或MAX_RT中断标志*/                  
  22. NRF_WriteReg(NRF_WRITE_REG+STATUS,State);

  23. NRF_WriteReg(FLUSH_TX,NOP);    //清除TX FIFO寄存器

  24. /*判断中断类型*/   
  25. if(State&MAX_RT)                     //达到最大重发次数
  26. return MAX_RT;

  27. else if(State&TX_DS)                  //发送完成
  28. return TX_DS;
  29. else         
  30. return ERROR;                 //其他原因发送失败
  31. }

  32. /**
  33.   * @brief   用于从NRF的接收缓冲区中读出数据
  34.   * @param   
  35.   *        @arg rxBuf :用于接收该数据的数组,外部定义       
  36.   * @retval
  37.   *        @arg 接收结果
  38.   */
  39. uint8_t NRF_Rx_Dat(uint8_t *rxbuf)
  40. {
  41. uint8_t State;
  42. NRF_CE_H;        //进入接收状态
  43. /*等待接收中断*/
  44. while(NRF_IRQ!=0);
  45. NRF_CE_L;          //进入待机状态
  46. /*读取status寄存器的值  */               
  47. State=NRF_ReadReg(STATUS);

  48. /* 清除中断标志*/      
  49. NRF_WriteReg(NRF_WRITE_REG+STATUS,State);

  50. /*判断是否接收到数据*/
  51. if(State&RX_DR)                                 //接收到数据
  52. {
  53. NRF_ReadBuff(RD_RX_PLOAD,rxbuf,RX_PLOAD_WIDTH);//读取数据
  54.     NRF_WriteReg(FLUSH_RX,NOP);          //清除RX FIFO寄存器
  55. return RX_DR;
  56. }
  57. else   
  58. return ERROR;                    //没收到任何数据
  59. }


  60. #define TX_ADR_WIDTH 5          //发射地址宽度
  61. #define TX_PLOAD_WIDTH  4   //发射数据通道有效数据宽度0~32Byte

  62. #define RX_ADR_WIDTH    5
  63. #define RX_PLOAD_WIDTH  4



  64. #define CHANAL 40        //频道选择

  65. // SPI(nRF24L01) commands ,        NRF的SPI命令宏定义,详见NRF功能使用文档
  66. #define NRF_READ_REG    0x00  // Define read command to register
  67. #define NRF_WRITE_REG   0x20  // Define write command to register
  68. #define RD_RX_PLOAD 0x61  // Define RX payload register address
  69. #define WR_TX_PLOAD 0xA0  // Define TX payload register address
  70. #define FLUSH_TX    0xE1  // Define flush TX register command
  71. #define FLUSH_RX    0xE2  // Define flush RX register command
  72. #define REUSE_TX_PL 0xE3  // Define reuse TX payload register command
  73. #define NOP         0xFF  // Define No Operation, might be used to read status register

  74. // SPI(nRF24L01) registers(addresses) ,NRF24L01 相关寄存器地址的宏定义
  75. #define CONFIG      0x00  // 'Config' register address
  76. #define EN_AA       0x01  // 'Enable Auto Acknowledgment' register address
  77. #define EN_RXADDR   0x02  // 'Enabled RX addresses' register address
  78. #define SETUP_AW    0x03  // 'Setup address width' register address
  79. #define SETUP_RETR  0x04  // 'Setup Auto. Retrans' register address
  80. #define RF_CH       0x05  // 'RF channel' register address
  81. #define RF_SETUP    0x06  // 'RF setup' register address
  82. #define STATUS      0x07  // 'Status' register address
  83. #define OBSERVE_TX  0x08  // 'Observe TX' register address
  84. #define CD          0x09  // 'Carrier Detect' register address
  85. #define RX_ADDR_P0  0x0A  // 'RX address pipe0' register address
  86. #define RX_ADDR_P1  0x0B  // 'RX address pipe1' register address
  87. #define RX_ADDR_P2  0x0C  // 'RX address pipe2' register address
  88. #define RX_ADDR_P3  0x0D  // 'RX address pipe3' register address
  89. #define RX_ADDR_P4  0x0E  // 'RX address pipe4' register address
  90. #define RX_ADDR_P5  0x0F  // 'RX address pipe5' register address
  91. #define TX_ADDR     0x10  // 'TX address' register address
  92. #define RX_PW_P0    0x11  // 'RX payload width, pipe0' register address
  93. #define RX_PW_P1    0x12  // 'RX payload width, pipe1' register address
  94. #define RX_PW_P2    0x13  // 'RX payload width, pipe2' register address
  95. #define RX_PW_P3    0x14  // 'RX payload width, pipe3' register address
  96. #define RX_PW_P4    0x15  // 'RX payload width, pipe4' register address
  97. #define RX_PW_P5    0x16  // 'RX payload width, pipe5' register address
  98. #define FIFO_STATUS 0x17  // 'FIFO Status Register' register address

  99. #define MAX_RT      0x10 //达到最大重发次数中断标志位
  100. #define TX_DS        0x20 //发送完成中断标志位         //

  101. #define RX_DR        0x40 //接收到数据中断标志位
复制代码



分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖 顶 踩
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表