天线|RF射频
直播中

杨桂英

7年用户 201经验值
私信 关注
[问答]

NRF24L01说明书很含糊,有关IRQ的理解不知道是否正确?

以原子老师的接收数据函数为例,我的注释是否正确,请指教!谢谢!



u8 NRF24L01_TxPacket(u8 *txbuf)

{

u8 sta;

  SPI2_SetSpeed(SPI_SPEED_8) ;//spi速度为9Mhz(24L01的最大SPI时钟为10Mhz)   

NRF24L01_CE=0;  //空闲时CE为0,

   NRF24L01_Write_Buf(WR_TX_PLOAD,txbuf,TX_PLOAD_WIDTH);//写数据到TX BUF  32个字节

  NRF24L01_CE=1;  //启动发送,根据NRF24L01时序CE上升沿发送   

while(NRF24L01_IRQ!=0);    //等待发送完成,“#define NRF24L01_IRQ  PGin(8)”;“NRF24L01_IRQ!=0”等价于“NRF24L01_IRQ=1”

/* 如果IRQ为高电平,说明没有产生中断。反之,如果IRQ为低电平,说明已经产生中断。通过向STATUS寄存器的TX_DS或MAX_RT位写1可以清除中断即IRQ恢复为高电平。

IRQ 引脚会在以下三种情况变低(即产生中断):

Tx FIFO(发送缓存buf) 发完并且收到ACK(使能ACK 情况下)

Rx FIFO(接收缓存buf) 收到数据,Rx FIFO已满

达到最大重发次数(对应STATUS寄存器的MAX_RT位),将MAX_RT位置1则清除中断。将IRQ接到外部中断输入引脚,通过中断程序进行处理。IRQ为低电平时说明已经产生了相应的中断,空闲时为高电平。

所以,如果发生了中断,则STATUS寄存器的TX_DS或MAX_RT位会置1,再次向STATUS寄存器的TX_DS或MAX_RT位写1

会使IRQ恢复为高电平

*/

sta=NRF24L01_Read_Reg(STATUS);  //读取状态寄存器的值,根据状态寄存器的状态值来操作

/*

#define STATUS       0x07  //状态寄存器;bit0:TX FIFO满标志;bit3:1,接收数据通道号(最大:6);bit4,达到最多次重发,0x07是FIFO_STATUS的寄存器地址;本句中:读寄存器STATUS,将状态寄存器的值赋给sta

#define FIFO_STATUS    0x17  //FIFO状态寄存器;bit0,RX FIFO寄存器空标志;

//bit1,RX FIFO满标志;bit2,3,保留bit4,TX FIFO空标志;bit5,TX FIFO满标志;

//bit6,1,循环发送上一数据包.0,不循环;

*/   

NRF24L01_Write_Reg(WRITE_REG+STATUS,sta); //清除TX_DS或MAX_RT中断标志

/*

要写入的值是sta,“WRITE_REG+STATUS”是要写入的值的地址,

“WRITE_REG”:#define WRITE_REG    0x20  //写配置寄存器,低5位为寄存器地址

如果发生了中断,则STATUS寄存器的TX_DS或MAX_RT位会置1,再次向STATUS寄存器的TX_DS或MAX_RT位写1

会使IRQ恢复为高电平即清除中断

*/

if(sta&MAX_TX)//达到最大重发次数,本程序头文件将MAX_TX定义为0x10,如果达到最大重发次数,硬件会自动将MAX_RT位置1

{  //“0001 0000”与STATUS寄存器的bit4(MAX_RT位)做与运算,如果MAX_RT位为1说明没有产生中断,即没有达到最大重发次数,

  NRF24L01_Write_Reg(FLUSH_TX,0xff);//清除TX FIFO寄存器

  return MAX_TX;      //没有达到最大重发次数

}

if(sta&TX_OK)    //头文件将TX_OK定义为0x20,对应STATUS的bit5位即TX_DS,若数据发送完成且收到应答信号后,硬件会自动将TX_DS位置1,

{//根据说明书如果TX_DS为高电平,说明数据发送完成。数据发送完成则会产生中断向该位写1清除中断。

  return TX_OK;//数据发送完成!

}

return 0xff;//其他原因发送失败

}

回帖(1)

李作健

2020-5-27 10:20:58
实践下吧
举报

更多回帖

发帖
×
20
完善资料,
赚取积分