新手上路
- 积分
- 37
- 金钱
- 37
- 注册时间
- 2013-8-27
- 在线时间
- 0 小时
|
楼主 |
发表于 2013-8-28 11:00:43
|
显示全部楼层
<img src="" alt="" /><br />
<br />
发送端main函数:<br />
TX_Mode();<br />
while(1)<br />
{<br />
for(ni=0; ni<3; ni++)<br />
{<br />
nRF24L01_TxPacket(nrf_buf + 4*ni);<br />
while(1)<br />
{<br />
status = SPI_Read(STATUS);<br />
if(TX_DS & status) //如果发送成功则清掉标志位,出去执行另外的发送<br />
{ <br />
SPI_RW_Reg(NRF_WRITE_REG+STATUS,0XFF);<br />
SPI_RW(FLUSH_TX);<br />
LED2_CROSS;<br />
break;<br />
}<br />
if(MAX_RT & status) //如果达到最大重传,则说明发送失败了,清掉寄存器,因为发送失败,发送缓冲区的东西还在里面 //需要手动清掉,本次发送失败,下次继续<br />
{<br />
SPI_RW_Reg(NRF_WRITE_REG+STATUS,0XFF);<br />
SPI_RW(FLUSH_TX); <br />
LED3_CROSS;<br />
break;<br />
}<br />
Delay_Us(100);<br />
}<br />
Delay_Ms(500);<br />
}<br />
<br />
<br />
接受main函数:<br />
RX_Mode();<br />
while(1)<br />
{<br />
status = nRF24L01_RxPacket(nrf_buf1); <br />
if(status)<br />
{<br />
LED2_CROSS;<br />
Show_Nrf(20, 80);<br />
memset(nrf_buf1, 0, 4); <br />
}<br />
<br />
LED1_CROSS;<br />
Delay_Ms(500);<br />
}<br />
<br />
<br />
发送函数:<br />
/****************发送函数***************************/<br />
void nRF24L01_TxPacket(unsigned char *tx_buf)<br />
{<br />
CE_Low; // CE=0;<br />
delay1us(10);<br />
SPI_RW_Reg(NRF_WRITE_REG+STATUS,0XFF);<br />
// SPI_Read(STATUS);<br />
<br />
//SPI_Write_Buf(NRF_WRITE_REG + TX_ADDR, TX_ADDRESS, TX_ADR_WIDTH); // WritesTX_Address to nRF24L01<br />
SPI_Write_Buf(NRF_WRITE_REG + RX_ADDR_P0, TX_ADDRESS, TX_ADR_WIDTH); //RX_Addr0 same as TX_Adr for Auto.Ack<br />
SPI_Write_Buf(WR_TX_PLOAD, tx_buf, TX_PLOAD_WIDTH); // Writes data to TX payload<br />
SPI_RW_Reg(NRF_WRITE_REG + CONFIG, 0x0e); // Set PWR_UP bit, enable CRC(2 bytes) &rim:TX. MAX_RT & TX_DS enabled..<br />
SPI_Read(CONFIG);<br />
<br />
CE_High; //CE=1启动发送<br />
delay1us(10);<br />
<br />
} <br />
<br />
<br />
接收函数:<br />
/*接收函数,返回1表示有数据收到,否则没有数据接收到**/<br />
unsigned char nRF24L01_RxPacket(unsigned char *rx_buf)<br />
{<br />
unsigned char sta,revale=0; <br />
SPI_RW_Reg(NRF_WRITE_REG + CONFIG, 0x0f); <br />
SPI_Read(CONFIG);<br />
<br />
sta = SPI_Read(STATUS); // read register STATUS's value<br />
if(sta&0x40) //if(RX_DS) // if receive data ready (RX_DR) interrupt<br />
{<br />
CE_Low; // stand by mode<br />
SPI_Read_Buf(RD_RX_PLOAD, rx_buf, WR_TX_PLOAD); // read receive payload from RX_FIFO buffer<br />
revale = 1;<br />
<br />
CSN_Low;<br />
SPI_RW(FLUSH_RX);<br />
CSN_High;<br />
}<br />
SPI_RW_Reg(NRF_WRITE_REG+STATUS,sta); // clear RX_DR or TX_DS or MAX_RT interrupt flag<br />
<br />
sta = SPI_Read(FIFO_STATUS); // read register STATUS's value<br />
<br />
return revale;<br />
<br />
}<br />
<br />
<br />
<br /> |
|