当前位置:首页 > 单片机 > 单片机
[导读]从开始接触,到驱动编写调试完成,前前后后花费10多天,网上浏览了一下,目前还没有找到硬件SPI控制NRF24L01的驱动程序,绝大多数都是软件SPI,但是软件SPI不好,不稳定,既然都写驱动程序了,肯定要用硬件SPI啦,这

从开始接触,到驱动编写调试完成,前前后后花费10多天,网上浏览了一下,目前还没有找到硬件SPI控制NRF24L01的驱动程序,绝大多数都是软件SPI,但是软件SPI不好,不稳定,既然都写驱动程序了,肯定要用硬件SPI啦,这样才能学到东西。学习的过程中,通过看韦东山的SPI视频,和参考他写的两个驱动程序。然后花费了四五天,终于将驱动写好了。这个驱动可以通过ioctl切换接收和发送模式,通过read,write选择接收数据还是发送数据,废话少说,上代码
#include#include#include#include#include#include#include#include#include#include#include#include#include#include#include#include#include#include#include#include"nrf.h"/*构造注册spi_driver*/#defineRX_MODE0xf1#defineTX_MODE0xf2staticintmajor;staticstructclass*class;staticintspi_NRF24L01_ce_pin;staticunsignedchar*ker_buf;staticstructspi_device*spi_NRF24L01_dev;staticunsignedcharopencount=0;staticvolatileintint_flag=0;staticDECLARE_WAIT_QUEUE_HEAD(nrf24l01_waitq);/*生成一个等待队列头wait_queue_head_t,名字为nrf24l01_waitq*/staticunsignedcharTX_ADDRESS[TX_ADR_WIDTH]={0x34,0x43,0x10,0x10,0x10};//本地地址staticunsignedcharRX_ADDRESS[RX_ADR_WIDTH]={0x34,0x43,0x10,0x10,0x10};//接收地址structpin_desc{unsignedintpin;unsignedintkey_val;};/*引脚描述结构体*/structpin_descpins_desc[2]={/*按下时:0x010x02...松开始0x810x82...*/{S3C2410_GPG(0),0x01},};staticuint8TxBuf[TxBufSize]={0x01,0x02,0x03,0x4,0x05,0x06,0x07,0x08,0x09,0x10,0x11,0x12,0x13,0x14,0x15,0x16,0x17,0x18,0x19,0x20,0x21,0x22,0x23,0x24,0x25,0x26,0x27,0x28,0x29,0x30,0x31,0x32,};staticuint8RxBuf[RxBufSize]={0};staticvoidNRF24L01_Set_CE(charval){s3c2410_gpio_setpin(spi_NRF24L01_ce_pin,val);}/*寄存器访问函数:用来设置24L01的寄存器的值。基本思路就是通过WRITE_REG命令(也就是0x20+寄存器地址)把要设定的值写到相应的寄存器地址里面去,并读取返回值。对于函数来说也就是把value值写到reg寄存器中*/staticunsignedcharSPI_RW_Reg(unsignedcharreg,unsignedcharvalue){unsignedcharstatus;unsignedchartx_buf[2];unsignedcharrx_buf[2];tx_buf[0]=reg;tx_buf[1]=value;spi_write(spi_NRF24L01_dev,tx_buf,2);status=rx_buf[0];return(status);}/*读取寄存器值的函数:基本思路就是通过READ_REG命令(也就是0x00+寄存器地址),把寄存器中的值读出来。对于函数来说也就是把reg寄存器的值读到reg_val中去*/staticvoidSPI_Read(int*pMID,int*pDID,unsignedcharreg){unsignedchartx_buf[2];unsignedcharrx_buf[2];tx_buf[0]=reg;tx_buf[1]=0x00;spi_write_then_read(spi_NRF24L01_dev,tx_buf,2,rx_buf,2);*pMID=rx_buf[0];*pDID=rx_buf[1];}/*接收缓冲区访问函数:主要用来在接收时读取FIFO缓冲区中的值。基本思路就是通过READ_REG命令把数据从接收FIFO(RD_RX_PLOAD)中读出并存到数组里面去*///staticunsignedcharSPI_Read_Buf(unsignedcharreg,unsignedchar*ker_buf,unsignedcharbytes)staticvoidSPI_Read_Buf(unsignedcharreg,unsignedchar*buf,intlen){/*spi_write_then_read规定了tx_cnt+rx_cnt<32*所以对于大量数据的读取,不能使用该函数*/unsignedchari=0;unsignedchartx_buf[1];unsignedchartx_buf1[len];structspi_transfert[]={{.tx_buf=tx_buf,.len=1,},{.tx_buf=tx_buf1,.rx_buf=buf,.len=len,},};structspi_messagem;for(i=0;i

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

USB摄像头是一种采用USB接口的视频采集设备,其优点在于即插即用、操作简便,无需额外驱动程序,支持笔记本电脑,并且成本较低,可以支持远程网络观看。

关键字: usb摄像头 驱动程序

与两相双极步进电机的驱动电路相比,两相单极步进电机的驱动电路在输入段配置、内部逻辑及控制电路和驱动电路使用双通道方面基本相同,但是输出段的配置不同。

关键字: 四相步进电机 驱动程序 程序电路

本文介绍了如何实现嵌入式MICREL网卡的驱动程序开发和设计。首先,我们介绍了MICREL网卡的概述和工作原理。然后,详细探讨了驱动程序的开发流程,包括硬件和软件的配置以及驱动程序的编写和测试。最后,总结了几点注意事项和...

关键字: 嵌入式 MICREL网卡 驱动程序

SPI 是英语Serial Peripheral interface的缩写,顾名思义就是串行外围设备接口。是Motorola(摩托罗拉)首先在其MC68HCXX系列处理器上定义的。SPI是一种单主机、高速的,全双工,同步...

关键字: spi spi通信原理

在这篇文章中,小编将对OLED的相关内容和情况加以介绍以帮助大家增进对它的了解程度,和小编一起来阅读以下内容吧。

关键字: OLED 驱动程序 无源驱动

近日,英特尔发布了锐炫显卡的新版驱动更新。本次驱动更新涵盖了锐炫A770、A750、A380以及移动端的锐炫GPU,这使得英特尔锐炫整个家族的DX9性能都实现了显著提升。

关键字: 英特尔 显卡 驱动程序

摘 要:从硬件与软件方面介绍了基于PXI技术的1553B总线通讯模块的设计,并对PXI总线接口设计、驱动程序的开发、 SDRAM存储器的控制和1553B总线通信协议实现等关键技术进行了详细的阐述,为航空领域测控系统开发P...

关键字: PXI技术 驱动程序 SDRAM存储器 1553B总线

PnP全称Plug-and-Play,译文为即插即用。PnP的作用是自动配置低层计算机中的板卡和其他设备,然后告诉对应设备都做了什么。PnP的任务是把物理设备和软件设备驱动程序相配合,并操作设备,在每个设备和它的驱动程序...

关键字: PnP 驱动程序 操作设备

作 者:道哥,10年嵌入式开发老兵,专注于:C/C、嵌入式、Linux。关注下方公众号,回复【书籍】,获取Linux、嵌入式领域经典书籍;回复【PDF】,获取所有原创文章(PDF格式)。目录kill命令和信号使用kill...

关键字: 信号 应用程序 驱动程序

驱动程序本质上是软件代码,主要作用是计算机系统与硬件设备之间完成数据传送的功能,只有借助驱动程序,两者才能通信并完成特定的功能。

关键字: 驱动程序 硬件设备 UNIX
关闭
关闭