nRF24L01 AVR 发送接收驱动程序

发布者:WhisperingSong最新更新时间:2015-09-08 来源: eefocus关键字:nRF24L01  AVR  发送接收  驱动程序 手机看文章 扫描二维码
随时随地手机看文章
#include  
#include  
#include "12864.h"  
  智芯锐电子技术社区:http://www.zhixinrui.com
//------------------------------------------------------------------------------  
//spi标志  
#define DDR_SPI DDRB  
#define DD_MOSI 5  
#define DD_MISO 6  
#define DD_SCK 7  
#define DD_SS 4  
#define CE PB3  
#define IRQ PB2  
//--------------------------------NRF24L01接口定义--------------------------------  
//------------------------------------------------------------------------------  
//#define NRF24L01_MISO          PB6  //输入0   
#define   Hign_24L01_MISO    PORTB|=(1 << PB6)  
#define   Low_24L01_MISO     PORTB &= ~(1 << PB6)  
#define   Read_24L01_MISO    PINB & (1 << PB6)  
  
//#define NRF24L01_MOSI         PB5       //输出1  
#define   Hign_24L01_MOSI    PORTB |= (1 << PB5)   
#define   Low_24L01_MOSI     PORTB &= ~(1 << PB5)  
#define   Read_24L01_MOSI    PINB & (1 << PB5)  
  
//#define NRF24L01_SCK    PB7      //输出1  
#define   Hign_24L01_SCK    PORTB |= (1 << PB7)    
#define   Low_24L01_SCK     PORTB &= ~(1 << PB7)     
#define   Read_24L01_SCK    PINB & (1 << PB7);  
  
//#define NRF24L01_CSN       PB4       //输出1  
#define   Low_24L01_CSN     PORTB &= ~(1 << PB4)  
#define   Hign_24L01_CSN    PORTB |= (1 << PB4)  
  
//#define NRF24L01_CE         PB3       //输出1  
#define   Hign_24L01_CE    PORTB |= (1 << PB3)   
#define   Low_24L01_CE     PORTB &= ~(1 << PB3)    
#define   Read_24L01_CE    PINB & (1 << PB3)  
  
  
  
//*********************************************NRF24L01*************************************  
#define TX_ADR_WIDTH    5       // 发送地址长度,最大长度为5 5*8=40 bit  
#define RX_ADR_WIDTH    5       // 接收地址长度  
#define TX_PLOAD_WIDTH  32      // 发送字节长度,  
#define RX_PLOAD_WIDTH  32      // 接收字节长度  
 uchar TX_ADDRESS[TX_ADR_WIDTH]={0x34,0x43,0x10,0x10,0x01};  //发送地址  
 uchar RX_ADDRESS[RX_ADR_WIDTH]={0x34,0x43,0x10,0x10,0x01}; //接收地址  
//***************************************NRF24L01寄存器指令*******************************************************  
#define READ_REG        0x00    // 读寄存器指令  
#define WRITE_REG       0x20    // 写寄存器指令  
#define RD_RX_PLOAD     0x61    // 读取接收数据指令  
#define WR_TX_PLOAD     0xA0    // 写待发数据指令  
#define FLUSH_TX        0xE1    // 冲洗发送 FIFO指令  
#define FLUSH_RX        0xE2    // 冲洗接收 FIFO指令  
#define REUSE_TX_PL     0xE3    // 定义重复装载数据指令  
#define NOP             0xFF    // 保留  
//*************************************SPI(nRF24L01)寄存器地址****************************************************  
#define CONFIG          0x00  // 配置收发状态,CRC校验模式以及收发状态响应方式  
#define EN_AA           0x01  // 自动应答功能设置  
#define EN_RXADDR       0x02  // 可用信道设置  
#define SETUP_AW        0x03  // 收发地址宽度设置  
#define SETUP_RETR      0x04  // 自动重发功能设置  
#define RF_CH           0x05  // 工作频率设置  
#define RF_SETUP        0x06  // 发射速率、功耗功能设置  
#define STATUS          0x07  // 状态寄存器  
#define OBSERVE_TX      0x08  // 发送监测功能  
#define CD              0x09  // 地址检测             
#define RX_ADDR_P0      0x0A  // 频道0接收数据地址  
#define RX_ADDR_P1      0x0B  // 频道1接收数据地址  
#define RX_ADDR_P2      0x0C  // 频道2接收数据地址  
#define RX_ADDR_P3      0x0D  // 频道3接收数据地址  
#define RX_ADDR_P4      0x0E  // 频道4接收数据地址  
#define RX_ADDR_P5      0x0F  // 频道5接收数据地址  
#define TX_ADDR         0x10  // 发送地址寄存器  
#define RX_PW_P0        0x11  // 接收频道0接收数据长度  
#define RX_PW_P1        0x12  // 接收频道0接收数据长度  
#define RX_PW_P2        0x13  // 接收频道0接收数据长度  
#define RX_PW_P3        0x14  // 接收频道0接收数据长度  
#define RX_PW_P4        0x15  // 接收频道0接收数据长度  
#define RX_PW_P5        0x16  // 接收频道0接收数据长度  
#define FIFO_STATUS     0x17  // FIFO栈入栈出状态寄存器设置  
//*************************************************************  
  
  
//*************************************************  
//*******  void spi_init()  初始化SPI  
//**************************************************  
void spi_init()  
{  
 Hign_24L01_CSN;  
 DDR_SPI = (1<
 DDR_SPI&=~((1<
 SPCR=(1<
 SPSR=0;  
}  
  
  
//**************************************************  
//*******  uchar SPI_RW(uchar date)  读写SPI  
//**************************************************  
uchar SPI_RW(uchar date)  
{  
 SPDR=date;  
    while(!(SPSR&(1<
    return SPDR;  
}  
   
//**************************************************  
//*******uchar SPI_Read(uchar reg)  读24L01寄存器  
//**************************************************  
uchar SPI_Read(uchar reg)  
{  
 uchar reg_val;  
   
 Low_24L01_CSN;                 
 SPI_RW(reg);              
 reg_val = SPI_RW(0);      
 Hign_24L01_CSN;                 
   
 return(reg_val);         
}  
  
//**************************************************  
//*******  uchar SPI_RW_Reg(uchar reg, uchar value)   
//          写24L01寄存器  
//**************************************************  
  
uchar SPI_RW_Reg(uchar reg, uchar value)  
{  
 uchar status;  
   
 Low_24L01_CSN;                   
 status = SPI_RW(reg);       
 SPI_RW(value);              
 Hign_24L01_CSN;                     
   
 return(status);             
}  
  
//**************************************************  
//*******  uchar SPI_Read_Buf(uchar reg, uchar *pBuf, uchar bites)   
//          读24L01 寄存器BUFF  
//**************************************************  
uchar SPI_Read_Buf(uchar reg, uchar *pBuf, uchar bites)  
{  
 uint status1,uchar_ctr;  
   
 Low_24L01_CSN;                       
 status1 = SPI_RW(reg);           
   
 for(uchar_ctr=0;uchar_ctr
  pBuf[uchar_ctr] = SPI_RW(0);     
   
 Hign_24L01_CSN;                            
   
 return(status1);                      
}  
  
//**************************************************  
//*******  uchar SPI_Write_Buf(uchar reg, uchar *pBuf, uchar bites)  
//          写24L01 寄存器BUFF  
//**************************************************  
uchar SPI_Write_Buf(uchar reg, uchar *pBuf, uchar bites)  
{  
 uchar status1,uchar_ctr;  
   
 Low_24L01_CSN;             //SPI使能        
 status1 = SPI_RW(reg);    
 for(uchar_ctr=0; uchar_ctr
 SPI_RW(*pBuf++);  
 Hign_24L01_CSN;           //关闭SPI  
 return(status1);        //  
}  
  
//**************************************************  
//*******  void SetRX_Mode(void)  
//          接收模式设置  
//**************************************************  
void SetRX_Mode(void)  
{  
 Low_24L01_CE;  
  
  
 SPI_Write_Buf(WRITE_REG + RX_ADDR_P0, RX_ADDRESS, RX_ADR_WIDTH); //写接收地址  
 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,0);        //射频通道  
 SPI_RW_Reg(WRITE_REG + RX_PW_P0, RX_PLOAD_WIDTH);//写通道0 接受数据长度  
 SPI_RW_Reg(WRITE_REG + RF_SETUP, 0x07); //0db 1M   
 SPI_RW_Reg(WRITE_REG + CONFIG, 0x0f); //接收模式  
 Hign_24L01_CE;        //开始接收  
 delayus(200);//注意不能太小  
}  
  
//**************************************************  
//*******  uchar nRF24L01_RxPacket(uchar* rx_buf)  
//          接收数据包  
//**************************************************  
uchar nRF24L01_RxPacket(uchar* rx_buf)  
{  
    uchar sta,flag=0;  
    sta=SPI_Read(STATUS);      // 读取状态寄存其来判断数据接收状况    
    if(sta&0x40)                 // 判断是否接收到数据RX_DR==1?  
    {  
       Low_24L01_CE;   // StandBy I模式  
       SPI_Read_Buf(RD_RX_PLOAD,rx_buf,TX_PLOAD_WIDTH);// read receive payload from RX_FIFO buffer  
       flag =1;   //读取数据完成标志  
    }  
    SPI_RW_Reg(WRITE_REG+STATUS,sta);   //接收到数据后RX_DR,TX_DS,MAX_PT都置高为1,通过写1来清楚中断标志  
    return (flag);  
}  
  
//**************************************************  
//*******  void nRF24L01_TxPacket(uchar * tx_buf)  
//          发送数据包  
//**************************************************  
void nRF24L01_TxPacket(  uchar * tx_buf)  
{   
   uchar sta=0;  
   uchar flag=0;  
   Low_24L01_CE;   //StandBy I模式   
   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); // 装载接收端地址  
   SPI_Write_Buf(WR_TX_PLOAD, tx_buf, TX_PLOAD_WIDTH);     // 装载数据   
   SPI_RW_Reg(WRITE_REG + EN_AA, 0x01);      //  
   SPI_RW_Reg(WRITE_REG + EN_RXADDR, 0x01);  //  
   SPI_RW_Reg(WRITE_REG + SETUP_RETR, 0x1f); //500+86us  
   SPI_RW_Reg(WRITE_REG + RF_CH, 0);        //  
   SPI_RW_Reg(WRITE_REG + RF_SETUP, 0x07);   //  
   SPI_RW_Reg(WRITE_REG + CONFIG, 0x0e);      // IRQ收发完成中断响应,16位CRC,主发送  
   delayms(2);  
   Hign_24L01_CE;   //置高CE,激发数据发送  
   delayus(10);  
   Low_24L01_CE;  
}  
  
void init_NRF24L01(void)  
{  
  spi_init();  
  Low_24L01_CE;    // 空闲模式  
  Hign_24L01_CSN;   // SPI 关闭  
  Low_24L01_SCK;   // 关闭时钟  
}  
关键字:nRF24L01  AVR  发送接收  驱动程序 引用地址:nRF24L01 AVR 发送接收驱动程序

上一篇:ATmega16熔丝位设定
下一篇:AVR单片机的DS18B20 C语言程序

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

122x32液晶1520控制器驱动程序(C51)
简介:本文主要介绍了122x32液晶1520控制器驱动程序(C51)。 #include reg51.h #include intrins.h #include absacc.h #include .incASCII816.h //标准ASCII码库 #include .incHZTable.h //自制的汉字库 #include .incmenu.h //自制的菜单库 sbit LCD12232_A0=P3^3; sbit LCD12232_RW=P3^1; //读写 sbit LCD12232_E1=P3^5; //片选1(Master) sbit LCD12232_E2=P3^4; /
[单片机]
具有双向接收发送功能的双向串行收发器S2067
    摘要: S2067是AMCC公司生产的具有双向接收和发送功能的高速串行数据传输芯片。它内含两个独立的收发器,可用于高速数据传输系统、工作站、数据广播和所有点对点的数据传输方面。文中介绍了S2067的主要特点以及片内发送器和接收器的工作原理,并给出了S2067用于背板电路的应用框图。     关键词: 数据传输 收发器 双向 S2067 1 概述 S2067是AMCC公司生产的具有双向接收和发送功能的高速串行数据传输芯片。该芯片内含两个独立的收发器,每一个收发器均能以2G/s的速率单独处理来自接收或发送地址的独立数据。S2067有两个用于接收和发送的串行I/O口,这两个串行I/O口是利用光信号或电
[应用]
micro2440 按键驱动程序
my_buttons.c文件: #include linux/fs.h #include linux/poll.h #include linux/irq.h #include linux/interrupt.h #include mach/regs-gpio.h #include mach/hardware.h #include linux/miscdevice.h #define DEVICE_NAME mybuttons struct button_irq_desc { int irq; int pin; int pin_setting; int number; char *na
[单片机]
DIY AVR串口下载器
原理图如下: 焊接好了的板子: 背面:
[单片机]
DIY <font color='red'>AVR</font>串口下载器
BASCOM-AVR 驱动数码管简洁代码
'''''''''''''''''''''' BASCOM-AVR 驱动一个数码管显示数字 0-9 下载附件查看原理图 代码 实物照片 ''''''''''''''''''''''''''''''''
[单片机]
BASCOM-<font color='red'>AVR</font> 驱动数码管简洁代码
STM32开发笔记84: SX1268驱动程序设计(SPI总线)
单片机型号:STM32L053R8T6 本系列开发日志,将详述SX1268驱动程序的整个设计过程,本篇介绍SPI总线驱动程序。 一、数据手册 1、关键点: 全双工SPI CPOL=0,CPHA=0 从器件 写操作:地址字节+数据字节 读操作:直接发送地址字节,就可返回一个数据字节 NSS在整个帧传输过程保持低电平 MISO在NSS为高时为高阻态 SCK最大时钟16M 2、几个时序图,t10是指从睡眠状态唤醒,NSS下降沿到SCK上升沿的时间,数据手册表明最短时间为100us。 3、芯片离开sleep模式的方法 可以通过NSS的下降沿使得芯片从sleep模式唤醒。下降沿发生后,芯片内部的稳压器都将打开。芯片
[单片机]
STM32开发笔记84: SX1268<font color='red'>驱动程序</font>设计(SPI总线)
AVR128的程序——12864时钟
#include iom128v.h #include macros.h #define uint unsigned int #define uchar unsigned char #define psbset DDRB |= (1 4) #define psbset PORTB |= (1 4) #define psbclr PORTB &=~(1 4) #define rsout DDRB |= (1 5) #define rsset PORTB |=(1 5) #define rsclr PORTB &=~(1 5) #define rwout DDRB |= (1 6) #
[单片机]
使用高速AVR单片机实现振动/温度信号采集和存储
铅酸电池具有价格低廉、供电可靠、电压稳定等优点,广泛应用于通信、铁路、交通、电力、石油、国防、工农业生产部门。在传统的充电技术中,常用的恒压充电、恒压限流充电、恒流充电等模式,都是由工人控制充电过程,由于充电技术不能适应免维护电池的特殊要求,严重影响电池的寿命,大量的免维护电池用几年后即报废,造成巨大的经济损失。本文所介绍的新型智能充电机系统,解决了动态跟踪电池可接受充电电流曲线的技术关键,形成了独具特色的智能充电机系列,提高了充电质量和效率,充电工人只担任辅助性工作,为充电技术和充电设备闯出了一条崭新的路。 1硬件部分 电池充放电过程中,可进行恒流、恒压、涓流、充放电时间以及终止电压等多种控制规律选择。整个系统分2
[单片机]
使用高速<font color='red'>AVR</font>单片机实现振动/温度信号采集和存储
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

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

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

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