7ac923fe93fccfa4b86f034eba25a9189019cc36.svn-base 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524
  1. #include "NRF24L01_inte.H"
  2. #include <string.h>
  3. #define RF_CH_DEF 40
  4. #define RF_C_NUM_DEF 5 //0通道无法发送
  5. unsigned char RF_CH = RF_CH_DEF; //RF频道
  6. unsigned char RF_C_NUM = RF_C_NUM_DEF; //RF通道
  7. unsigned char NRF24L01_FLAG = 0; //NRF24L01当前状态标志
  8. //DB7; 1接收模式 0发射模式
  9. //DB6; 1有任务 0空闲
  10. //DB5; 1发送成功 0发送失败(配合DB6检测是否发送成功)
  11. //DB4; 1NRF正常连接 0 检测不到连接
  12. //DB3; 1接收到数据包 0 缓冲区无数据
  13. //DB2; 1 ACK模式 0 NOACK模式
  14. //DB1; 1发送完自动进入接收模式 0关闭自动切换模式
  15. unsigned char DYNPD_LEN = 0; //用于存放动态数据包长度
  16. //接收地址-- 接收有6个通道
  17. const unsigned char RX_ADD[NRF24L01_CH_NUM_MAX + 1][NRF24L01_ADR_LEN] =
  18. {
  19. {0x00, TR_ADDR_B1, TR_ADDR_B2, TR_ADDR_B3, TR_ADDR_B4}, //通道0
  20. {0x01, TR_ADDR_B1, TR_ADDR_B2, TR_ADDR_B3, TR_ADDR_B4}, //通道1
  21. {0x02, TR_ADDR_B1, TR_ADDR_B2, TR_ADDR_B3, TR_ADDR_B4}, //通道2
  22. {0x03, TR_ADDR_B1, TR_ADDR_B2, TR_ADDR_B3, TR_ADDR_B4}, //通道3
  23. {0x04, TR_ADDR_B1, TR_ADDR_B2, TR_ADDR_B3, TR_ADDR_B4}, //通道4
  24. {0x05, TR_ADDR_B1, TR_ADDR_B2, TR_ADDR_B3, TR_ADDR_B4} //通道5
  25. };
  26. //本地地址-- 发送只有1个通道
  27. const unsigned char TX_ADD[NRF24L01_CH_NUM_MAX + 1][NRF24L01_ADR_LEN] =
  28. {
  29. {0x00, TR_ADDR_B1, TR_ADDR_B2, TR_ADDR_B3, TR_ADDR_B4}, //对应通道0
  30. {0x01, TR_ADDR_B1, TR_ADDR_B2, TR_ADDR_B3, TR_ADDR_B4}, //对应通道1
  31. {0x02, TR_ADDR_B1, TR_ADDR_B2, TR_ADDR_B3, TR_ADDR_B4}, //对应通道2
  32. {0x03, TR_ADDR_B1, TR_ADDR_B2, TR_ADDR_B3, TR_ADDR_B4}, //对应通道3
  33. {0x04, TR_ADDR_B1, TR_ADDR_B2, TR_ADDR_B3, TR_ADDR_B4}, //对应通道4
  34. {0x05, TR_ADDR_B1, TR_ADDR_B2, TR_ADDR_B3, TR_ADDR_B4} //对应通道5
  35. };
  36. struct init_reg_data
  37. {
  38. unsigned char reg;
  39. unsigned char data1;
  40. unsigned char *data2;
  41. unsigned char len2;
  42. };
  43. const struct init_reg_data init_first[] =
  44. {
  45. //RX全部通道配置
  46. {NRF24L01_RX_ADDR_P0, 0, &RX_ADD[0], NRF24L01_ADR_LEN}, //P0接收地址
  47. {NRF24L01_RX_ADDR_P1, 0, &RX_ADD[1], NRF24L01_ADR_LEN}, //P1接收地址
  48. {NRF24L01_RX_ADDR_P2, 0, &RX_ADD[2], 1}, //P2接收地址
  49. {NRF24L01_RX_ADDR_P3, 0, &RX_ADD[3], 1}, //P3接收地址
  50. {NRF24L01_RX_ADDR_P4, 0, &RX_ADD[4], 1}, //P4接收地址
  51. {NRF24L01_RX_ADDR_P5, 0, &RX_ADD[5], 1}, //P5接收地址
  52. {NRF24L01_RX_PW_P0, NRF24L01_ADR_LEN, NULL, 0}, //P0接受通道有效宽度
  53. {NRF24L01_RX_PW_P1, NRF24L01_ADR_LEN, NULL, 0}, //P1接受通道有效宽度
  54. {NRF24L01_RX_PW_P2, NRF24L01_ADR_LEN, NULL, 0}, //P2接受通道有效宽度
  55. {NRF24L01_RX_PW_P3, NRF24L01_ADR_LEN, NULL, 0}, //P3接受通道有效宽度
  56. {NRF24L01_RX_PW_P4, NRF24L01_ADR_LEN, NULL, 0}, //P4接受通道有效宽度
  57. {NRF24L01_RX_PW_P5, NRF24L01_ADR_LEN, NULL, 0}, //P5接受通道有效宽度
  58. //其他配置
  59. {NRF24L01_SETUP_AW, NRF24L01_ADR_LEN - 2, NULL, 0}, //设置地址长度为 NRF24L01_ADR_LEN
  60. {NRF24L01_RF_SETUP, 0x07, NULL, 0}, //设置TX发射参数,7db增益,1Mbps,低噪声增益开启
  61. //RX模式配置
  62. {NRF24L01_FEATURE, 0x05, NULL, 0}, //使能动态数据包长度,AUTO_ACK模式
  63. {NRF24L01_DYNPD, 0X01, NULL, 0}, //选择通道0动态数据包长度
  64. //TX模式配置
  65. {NRF24L01_SETUP_RETR, 0x1a, NULL, 0}, //设置自动重发间隔时间:500us + 86us;重发次数:10次
  66. //通道/频段/TX地址配置
  67. {NRF24L01_RF_CH, RF_CH_DEF, NULL, 0}, //设置RF频道为RFCH [6:0]
  68. {NRF24L01_EN_AA, 1 << RF_C_NUM_DEF, NULL, 0}, //通道自动应答 : 0~5通道
  69. {NRF24L01_EN_RXADDR, 1 << RF_C_NUM_DEF, NULL, 0}, //接收通道使能 : 0~5通道
  70. {NRF24L01_TX_ADDR, 0, &TX_ADD[RF_C_NUM_DEF], NRF24L01_ADR_LEN}, //写TX节点地址
  71. };
  72. const struct init_reg_data init_recv_mod[] =
  73. {
  74. {NRF24L01_CONFIG, 0x0f, NULL, 0}, //bit0接收模式
  75. {NRF24L01_STATUS, 0x70, NULL, 0}, //清中断
  76. {NRF24L01_FLUSE_RX, NRF24L01_NOP, NULL, 0}, //清理接收FIFO
  77. };
  78. const struct init_reg_data init_send_mod[] =
  79. {
  80. {NRF24L01_CONFIG, 0x0e, NULL, 0}, //bit0发送模式
  81. {NRF24L01_STATUS, 0x70, NULL, 0}, //清中断
  82. {NRF24L01_FLUSE_TX, NRF24L01_NOP, NULL, 0}, //清理发送FIFO
  83. };
  84. void NRF24L01_Init_reg ( struct init_reg_data *addr, unsigned char len )
  85. {
  86. unsigned char i;
  87. for ( i = 0; i < len; i++ )
  88. {
  89. if ( addr[i].data2 == NULL )
  90. {
  91. NRF24L01_Write_Reg ( addr[i].reg, addr[i].data1 );
  92. }
  93. else
  94. {
  95. NRF24L01_Write_Buf ( addr[i].reg, addr[i].data2, addr[i].len2 );
  96. }
  97. }
  98. }
  99. unsigned char NRF24L01_check_reg ( struct init_reg_data *addr, unsigned char len )
  100. {
  101. unsigned char buff[5];
  102. unsigned char i, j;
  103. for ( i = 0; i < len; i++ )
  104. {
  105. if ( addr[i].data2 == NULL )
  106. {
  107. buff[0] = NRF24L01_Read_Reg ( addr[i].reg );
  108. if ( buff[0] != addr[i].data1 )
  109. {
  110. return 0;
  111. }
  112. }
  113. else
  114. {
  115. NRF24L01_Read_Buf ( addr[i].reg, buff, addr[i].len2 );
  116. for ( j = 0; j < 5; j++ )
  117. {
  118. if ( buff[j] != addr[i].data2[j] )
  119. {
  120. return 0;
  121. }
  122. }
  123. }
  124. }
  125. return 1;
  126. }
  127. //向从机发送一个字节数据并返回接收数据
  128. /**************************************************/
  129. #if 0
  130. unsigned char SPI_WriteRead ( unsigned char byte )
  131. {
  132. unsigned char bit_ctr;
  133. for ( bit_ctr = 0; bit_ctr < 8; bit_ctr++ ) // 输出8位
  134. {
  135. NRF_MOSI = ( byte & 0x80 ); // MSB TO MOSI
  136. byte = ( byte << 1 ); // shift next bit to MSB
  137. NRF_SCK = 1;
  138. byte |= NRF_MISO; // capture current MISO bit
  139. NRF_SCK = 0;
  140. }
  141. return byte;
  142. }
  143. #else
  144. unsigned char SPI_WriteRead ( unsigned char byte )
  145. {
  146. unsigned char i;
  147. SPDR = byte; //写寄存器
  148. for ( i = 0; i < 255; i++ )
  149. {
  150. if ( SPSR & SET_BIT7 )
  151. {
  152. break; //等待传输
  153. }
  154. }
  155. SPSR &= ~SET_BIT7;
  156. byte = SPDR; //读寄存器
  157. return byte;
  158. }
  159. #endif
  160. //写NRF24L01寄存器,返回状态值
  161. unsigned char NRF24L01_Write_Reg ( unsigned char reg, unsigned char value )
  162. {
  163. unsigned char BackDate;
  164. NRF_CE = 0; //在写寄存器之前一定要进入待机模式或掉电模式。
  165. NRF_CSN = 0;
  166. reg = NRF24L01_WRITE_REG | reg;
  167. SPI_WriteRead ( reg );
  168. BackDate = SPI_WriteRead ( value );
  169. NRF_CSN = 1;
  170. NRF_CE = 1; //恢复正常模式
  171. return ( BackDate );
  172. }
  173. //读NRF24L01寄存器,返回寄存器值
  174. unsigned char NRF24L01_Read_Reg ( unsigned char reg )
  175. {
  176. unsigned char BackDate;
  177. NRF_CSN = 0;
  178. reg = NRF24L01_READ_REG | reg;
  179. SPI_WriteRead ( reg );
  180. BackDate = SPI_WriteRead ( NRF24L01_NOP ); //NOP,无效值,用于读取
  181. NRF_CSN = 1;
  182. return ( BackDate );
  183. }
  184. //向缓冲区写入数据
  185. unsigned char NRF24L01_Write_Buf ( unsigned char reg, unsigned char *pBuf, unsigned char bytes )
  186. {
  187. unsigned char status, byte_ctr;
  188. NRF_CE = 0; //在写寄存器之前一定要进入待机模式或掉电模式。
  189. NRF_CSN = 0;
  190. reg = NRF24L01_WRITE_REG | reg;
  191. status = SPI_WriteRead ( reg );
  192. for ( byte_ctr = 0; byte_ctr < bytes; byte_ctr++ )
  193. {
  194. SPI_WriteRead ( *pBuf++ );
  195. }
  196. NRF_CSN = 1;
  197. NRF_CE = 1; //恢复正常模式
  198. return ( status );
  199. }
  200. //读取缓冲区数据
  201. void NRF24L01_Read_Buf ( unsigned char reg, unsigned char *pBuf, unsigned char bytes )
  202. {
  203. unsigned char byte_ctr;
  204. NRF_CSN = 0;
  205. reg = NRF24L01_READ_REG | reg;
  206. SPI_WriteRead ( reg );
  207. for ( byte_ctr = 0; byte_ctr < bytes; byte_ctr++ )
  208. {
  209. pBuf[byte_ctr] = SPI_WriteRead ( NRF24L01_NOP ); //NOP,无效值,用于读取
  210. }
  211. NRF_CSN = 1;
  212. }
  213. /*
  214. PIPEN 中断使能
  215. PINEN 正反向特性
  216. PICON 触发方式(电平或边沿检测)
  217. PIF 中断标志
  218. */
  219. void NRF24L01_Interrupt_P03 ( void )
  220. {
  221. //P0M1|=SET_BIT3;P0M2&=~SET_BIT3; //input
  222. PICON &= ~ ( SET_BIT0 | SET_BIT1 );
  223. PICON |= ( 0x00 ); //[1:0]=0.端口0
  224. PICON |= SET_BIT5; //通道3=1.边沿触发
  225. PINEN |= SET_BIT3; // 1 = 低电平/ 下降沿触发中断
  226. PIPEN &= ~SET_BIT3; //0 = 关闭中断(高电平/ 上升沿触发中断)
  227. EIE |= SET_BIT1; //管脚中断,最多8个,中断号7
  228. EA = 1; // 总中断
  229. }
  230. uint8 NRF24L01_Wait_Param ( void );
  231. //NRF24L01初始化函数
  232. void NRF24L01_Init ( void )
  233. {
  234. //uint8 i;
  235. #if BK2423
  236. //NRF_CE = 0; //在写寄存器之前一定要进入待机模式或掉电模式。
  237. NRF24L01_Write_Reg ( ACTIVATE_CMD, 0x73 );
  238. //NRF_CE = 1;
  239. #endif
  240. NRF_CSN = 1; // Spi disable
  241. NRF_SCK = 0; // Spi clock line init high
  242. //NRF_CE = 0; //在写寄存器之前一定要进入待机模式或掉电模式。
  243. //配置寄存器
  244. NRF24L01_FLAG |= NRF24L01_AUTO_ACK; //是否开启应答模式
  245. NRF24L01_FLAG |= NRF24L01_AUTO_RX; //发送完是否自动进入接收模式
  246. #if 0
  247. //0-5通道接收地址,长度配置
  248. for ( i = 0; i <= NRF24L01_CH_NUM_MAX; i++ )
  249. {
  250. NRF24L01_Write_Buf ( NRF24L01_RX_ADDR_P0 + i, RX_ADD[i], NRF24L01_ADR_LEN ); //设置接收地址
  251. NRF24L01_Write_Reg ( NRF24L01_RX_PW_P0 + i, NRF24L01_ADR_LEN ); //接受通道有效宽度
  252. }
  253. NRF24L01_Write_Reg ( NRF24L01_SETUP_AW, NRF24L01_ADR_LEN - 2 ); //设置地址长度为 NRF24L01_ADR_LEN
  254. NRF24L01_Write_Reg ( NRF24L01_RF_CH, RF_CH ); //设置RF通道为RFCH [6:0]
  255. NRF24L01_Write_Reg ( NRF24L01_RF_SETUP, 0x07 ); //设置TX发射参数,7db增益,1Mbps,低噪声增益开启
  256. NRF24L01_Write_Reg ( NRF24L01_EN_AA, 0x01 ); //使能通道0的自动应答
  257. NRF24L01_Write_Reg ( NRF24L01_EN_RXADDR, 0x01 ); //使能通道0的接收地址
  258. //RX模式配置
  259. //NRF24L01_Write_Buf ( NRF24L01_RX_ADDR_P0, RX_ADD[0], NRF24L01_ADR_LEN ); //写RX节点地址
  260. NRF24L01_Write_Reg ( NRF24L01_FEATURE, 0x05 ); //使能动态数据包长度,AUTO_ACK模式
  261. NRF24L01_Write_Reg ( NRF24L01_DYNPD, 0X01 ); //选择通道0动态数据包长度
  262. NRF24L01_Write_Reg ( NRF24L01_FLUSE_RX, NRF24L01_NOP ); //清除RX FIFO寄存器,写1清除
  263. //TX模式配置
  264. NRF24L01_Write_Buf ( NRF24L01_TX_ADDR , TX_ADD[RF_C_NUM], NRF24L01_ADR_LEN ); //写TX节点地址
  265. NRF24L01_Write_Reg ( NRF24L01_SETUP_RETR, 0x1f ); //设置自动重发间隔时间:500us + 86us;最大自动重发次数:15次
  266. NRF24L01_Write_Reg ( NRF24L01_FLUSE_TX, NRF24L01_NOP ); //清除TX FIFO寄存器,写1清除
  267. NRF24L01_RxMode(); //默认进入接收模式
  268. //NRF_CE = 1;
  269. NRF24L01_Change_Working_Frequency ( 0x64 );
  270. NRF24L01_Change_Data_Channel ( 2 );
  271. #else
  272. NRF24L01_Init_reg ( init_first, sizeof ( init_first ) / sizeof ( init_first[0] ) );
  273. #endif
  274. NRF24L01_RxMode();
  275. NRF24L01_Interrupt_P03();
  276. NRF24L01_Wait_Param();
  277. }
  278. //NRF24L01进入发送模式
  279. void NRF24L01_TxMode ( void )
  280. {
  281. //NRF_CE = 0; //在写寄存器之前一定要进入待机模式或掉电模式。
  282. #if 0
  283. NRF24L01_Write_Reg ( NRF24L01_CONFIG, 0x0e );
  284. NRF24L01_Write_Reg ( NRF24L01_STATUS, 0x70 ); //清除中断标志
  285. NRF24L01_Write_Reg ( NRF24L01_FLUSE_TX, NRF24L01_NOP ); //清除TX FIFO寄存器,写1清除
  286. #else
  287. NRF24L01_Init_reg ( init_send_mod, sizeof ( init_send_mod ) / sizeof ( init_send_mod[0] ) );
  288. #endif
  289. //NRF_CE = 1;
  290. NRF24L01_FLAG &= ~NRF24L01_MODE_RX; //修改状态标识为发射模式
  291. NRF24L01_FLAG &= ~NRF24L01_BUSY; //BUSY标志置0
  292. NRF24L01_FLAG &= ~NRF24L01_RECIVE;//清除有数据标志
  293. Timer3_Delay10us ( 1 );
  294. }
  295. //NRF24L01进入接收模式
  296. void NRF24L01_RxMode ( void )
  297. {
  298. //NRF_CE = 0; //在写寄存器之前一定要进入待机模式或掉电模式。
  299. #if 0
  300. NRF24L01_Write_Reg ( NRF24L01_CONFIG, 0x0f ); //配置基本工作模式的参数;PWR_UP,EN_CRC,16BIT_CRC,接收模式
  301. NRF24L01_Write_Reg ( NRF24L01_STATUS, 0x70 ); //清除中断标志
  302. NRF24L01_Write_Reg ( NRF24L01_FLUSE_RX, NRF24L01_NOP ); //清除RX FIFO寄存器,写1清除
  303. #else
  304. NRF24L01_Init_reg ( init_recv_mod, sizeof ( init_recv_mod ) / sizeof ( init_recv_mod[0] ) );
  305. #endif
  306. //NRF_CE = 1;
  307. NRF24L01_FLAG |= NRF24L01_MODE_RX; //修改状态标识为接收模式
  308. NRF24L01_FLAG &= ~NRF24L01_BUSY; //BUSY标志置0
  309. DYNPD_LEN = 0; //清0动态数据包长度
  310. NRF24L01_FLAG &= ~NRF24L01_RECIVE;//清除有数据标志
  311. Timer3_Delay10us ( 13 );
  312. }
  313. uint8 NRF24L01_Wait_Param ( void )
  314. {
  315. uint8 res = 1;
  316. #if 0
  317. uint8 i;
  318. unsigned char TX_Buff[5], RX_Buff[5], FRE, CH;
  319. NRF24L01_Read_Buf ( NRF24L01_TX_ADDR, TX_Buff, NRF24L01_ADR_LEN );
  320. NRF24L01_Read_Buf ( NRF24L01_RX_ADDR_P0 + RF_C_NUM, RX_Buff, NRF24L01_ADR_LEN );
  321. CH = NRF24L01_Read_Reg ( NRF24L01_EN_RXADDR );
  322. FRE = NRF24L01_Read_Reg ( NRF24L01_RF_CH );
  323. //接收/发送地址检查
  324. for ( i = 0; i < ( RF_C_NUM < 2 ? 5 : 1 ); i++ )
  325. {
  326. if ( TX_Buff[i] != TX_ADD[RF_C_NUM][i] || RX_Buff[i] != RX_ADD[RF_C_NUM][i] )
  327. {
  328. res = 0;
  329. break;
  330. }
  331. }
  332. //通道使能检查
  333. if ( ! ( CH & ( 1 << RF_C_NUM ) ) )
  334. {
  335. res = 0;
  336. }
  337. //频道检查
  338. if ( FRE != RF_CH )
  339. {
  340. res = 0;
  341. }
  342. #endif
  343. res = NRF24L01_check_reg ( init_first, sizeof ( init_first ) / sizeof ( init_first[0] ) );
  344. res ? ( NRF24L01_FLAG |= NRF24L01_CHECK ) : ( NRF24L01_FLAG &= ~NRF24L01_CHECK );
  345. return res;
  346. }
  347. //NRF24L01发送数据
  348. void NRF24L01_SendFrame ( unsigned char *temp, unsigned char len )
  349. {
  350. if ( NRF24L01_FLAG & NRF24L01_MODE_RX )
  351. {
  352. NRF24L01_TxMode();
  353. }
  354. NRF24L01_FLAG |= NRF24L01_BUSY; //BUSY标志置1
  355. NRF24L01_FLAG &= ~NRF24L01_TX_ACCESS;//清除发送成功标志
  356. //NRF_CE = 0;
  357. if ( NRF24L01_FLAG & NRF24L01_AUTO_ACK )
  358. {
  359. NRF24L01_Write_Buf ( NRF24L01_WR_TX_PLOAD, temp, len ); //写待发数据包,需要回应
  360. }
  361. else
  362. {
  363. NRF24L01_Write_Buf ( W_TX_PAYLOAD_NOACK_CMD, temp, len ); //写待发数据包,无须回应
  364. }
  365. //NRF_CE = 1;
  366. }
  367. //NRF24L01接收数据
  368. void NRF24L01_RecvFrame ( unsigned char *temp )
  369. {
  370. DYNPD_LEN = NRF24L01_Read_Reg ( R_RX_PL_WID_CMD );
  371. if ( DYNPD_LEN > 32 )
  372. {
  373. NRF24L01_RxMode(); //重新初始化接收模式
  374. }
  375. else
  376. {
  377. NRF24L01_Read_Buf ( NRF24L01_RD_RX_PLOAD, temp, DYNPD_LEN ); //读取缓冲区数据
  378. }
  379. NRF24L01_FLAG &= ~NRF24L01_RECIVE;//清除有数据标志
  380. }
  381. //更改工作频率0~7f
  382. void NRF24L01_Change_Working_Frequency ( unsigned char ch ) //0~7f
  383. {
  384. if ( ch > 0x7f )
  385. {
  386. return;
  387. }
  388. //NRF_CE = 0;
  389. NRF24L01_Write_Reg ( NRF24L01_RF_CH, ch & 0x7F ); //设置RF频道
  390. //NRF_CE = 1;
  391. RF_CH = ch & 0x7F; //同步设置到系统参数
  392. }
  393. //更改通道0~3f
  394. void NRF24L01_Change_Data_Channel ( unsigned char ch ) //0~5
  395. {
  396. if ( ch > NRF24L01_CH_NUM_MAX )
  397. {
  398. return;
  399. }
  400. RF_C_NUM = ch;
  401. NRF24L01_Write_Reg ( NRF24L01_EN_AA, 1 << RF_C_NUM ); //通道自动应答
  402. NRF24L01_Write_Reg ( NRF24L01_EN_RXADDR, 1 << RF_C_NUM ); //接收通道使能
  403. NRF24L01_Write_Buf ( NRF24L01_TX_ADDR , TX_ADD[RF_C_NUM], NRF24L01_ADR_LEN ); //写TX节点地址
  404. }
  405. //NRF24L01中断处理:当状态寄存器中 TX_DS、 RX_DR 或 MAX_RT 为高时触发中断。
  406. #ifdef N76E003_IAR
  407. #pragma vector=0x3B
  408. __interrupt void NRF24L01_Handler ( void )
  409. #else
  410. void NRF24L01_Handler ( void ) interrupt 7 //interrupt address is 0x001B
  411. #endif
  412. {
  413. unsigned char state, fifo_state, flag;
  414. clr_EPI; //关闭管脚中断7
  415. flag = PIF;
  416. PIF = 0x00; //清除全部标志
  417. state = NRF24L01_Read_Reg ( NRF24L01_STATUS ); //读NRF24L01状态寄存器
  418. fifo_state = NRF24L01_Read_Reg ( NRF24L01_FIFO_STATUS ); //读NRF24L01FIFO状态寄存器
  419. NRF24L01_Write_Reg ( NRF24L01_STATUS, state ); //清除中断,写1清除
  420. //发送成功中断
  421. if ( state & NRF24L01_STATUS_TX_DS )
  422. {
  423. NRF24L01_FLAG &= ~NRF24L01_BUSY; //BUSY标志置0
  424. NRF24L01_FLAG |= NRF24L01_TX_ACCESS;//发送成功标志置1
  425. if ( NRF24L01_FLAG & NRF24L01_AUTO_RX )
  426. {
  427. NRF24L01_RxMode(); //重新初始化接收模式
  428. }
  429. }
  430. //达到最大重发次数中断
  431. if ( state & NRF24L01_STATUS_MAX_RT )
  432. {
  433. NRF24L01_Write_Reg ( NRF24L01_FLUSE_TX, NRF24L01_NOP ); //清除TX FIFO寄存器,写1清除
  434. NRF24L01_FLAG &= ~NRF24L01_BUSY; //BUSY标志置0
  435. NRF24L01_FLAG &= ~NRF24L01_TX_ACCESS;//发送成功标志置0
  436. }
  437. //接收到数据中断
  438. if ( state & NRF24L01_STATUS_RX_DR )
  439. {
  440. NRF24L01_FLAG |= NRF24L01_RECIVE; //接收到数据标志位置1
  441. }
  442. //TX_FIFO满中断
  443. if ( state & NRF24L01_STATUS_TX_FULL )
  444. {
  445. NRF24L01_TxMode(); //重新初始化发射模式
  446. }
  447. //RX_FIFO满
  448. if ( fifo_state & NRF24L01_STATUS_RX_FULL )
  449. {
  450. NRF24L01_RxMode(); //重新初始化接收模式
  451. }
  452. state = NRF24L01_Read_Reg ( NRF24L01_CONFIG ); //读NRF24L01状态寄存器
  453. set_EPI; //开启管脚中断7
  454. }