예제 #1
0
// Send data packet
// input:
//   pBuf - buffer with data to send
// return:
//   nRF24_MASK_MAX_RT - if transmit failed with maximum auto retransmit count
//   nRF24_MAX_TX_DS - if transmit succeed
//   contents of STATUS register otherwise
uint8_t nRF24_TXPacket(uint8_t * pBuf, uint8_t TX_PAYLOAD) {
    uint8_t status;

    CE_L();
    nRF24_WriteBuf(nRF24_CMD_WREG | nRF24_REG_TX_ADDR,nRF24_TX_addr,nRF24_TX_ADDR_WIDTH); // Set static TX address
    nRF24_WriteBuf(nRF24_CMD_WREG | nRF24_REG_RX_ADDR_P0,nRF24_RX_addr,nRF24_RX_ADDR_WIDTH); // Set static RX address for auto ack
    nRF24_RWReg(nRF24_CMD_WREG | nRF24_REG_EN_AA,0x01); // Enable auto acknowledgement for data pipe 0
    nRF24_RWReg(nRF24_CMD_WREG | nRF24_REG_SETUP_RETR,0x1A); // Automatic retransmission: wait 500us, 10 retries
	  nRF24_RWReg(nRF24_CMD_WREG | nRF24_REG_RF_CH,0x6E); // Set frequency channel 110 (2.510MHz)
    nRF24_RWReg(nRF24_CMD_WREG | nRF24_REG_RF_SETUP,0x07); // Setup: 1Mbps, 0dBm, LNA on
    nRF24_WriteBuf(nRF24_CMD_W_TX_PAYLOAD,pBuf,TX_PAYLOAD); // Write specified buffer to FIFO
    nRF24_RWReg(nRF24_CMD_WREG | nRF24_REG_CONFIG,0x0E); // Config: CRC on (2 bytes), Power UP, RX/TX ctl = PTX
    CE_H(); // CE pin high => Start transmit
    // Delay_us(10); // Must hold CE at least 10us
    //while(PB_IDR_bit.IDR2 != 0); // Wait for IRQ from nRF24L01
    CE_L();
    status = nRF24_ReadReg(nRF24_REG_STATUS); // Read status register
	nRF24_RWReg(nRF24_CMD_WREG | nRF24_REG_STATUS,status | 0x70); // Clear RX_DR, TX_DS, MAX_RT flags
    if (status & nRF24_MASK_MAX_RT) {
        // Auto retransmit counter exceeds the programmed maximum limit. FIFO is not removed.
        nRF24_RWReg(nRF24_CMD_FLUSH_TX,0xFF); // Flush TX FIFO buffer
        return nRF24_MASK_MAX_RT;
    };
    if (status & nRF24_MASK_TX_DS) {
        // Transmit ok
        nRF24_RWReg(nRF24_CMD_FLUSH_TX,0xFF); // Flush TX FIFO buffer
        return nRF24_MASK_TX_DS;
    }

    // Some banana happens
    return status;
}
예제 #2
0
u8 ANO_NRF::NRF_Tx_Dat(u8 *txbuf,u8 *AckPacket)
{
	u8 state;  
 
	 /*ce为低,进入待机模式1*/
	CE_L();

	/*写数据到TX BUF 最大 32个字节*/						
   Write_Buf(WR_TX_PLOAD,txbuf,TX_PLOAD_WIDTH);

      /*CE为高,txbuf非空,发送数据包 */   
 	 CE_H();
	  	
	  /*等待发送完成中断 */                            
	while(NRF_Read_IRQ()!=0);

	 state = Read_Reg(NRFRegSTATUS);/*读取状态寄存器的值 */  
	 Write_Reg(NRF_WRITE_REG+NRFRegSTATUS,state); 	
	 
   if(state&RX_DR)
	 {
		 
		 Read_Buf(RD_RX_PLOAD, AckPacket, 32);
	 }
	 Write_Reg(FLUSH_TX,NOP);//清除TX FIFO寄存器 
	 
	 
	return state;   	 


} 
예제 #3
0
파일: nrf.c 프로젝트: NakarinTalikan/stm32
void vNrfSend(uint8_t * addr, uint8_t *data, uint8_t len)
 {
	uint8_t status;

	while (g_uNrfTx)	// this should be never executed code!
	{
		status = uNrfReadReg(STATUS);
		if (status & ( (1 << TX_DS) | (1 << MAX_RT) ) )
		{
			uNrfWriteReg(STATUS, (1 << TX_DS) | (1 << MAX_RT));
			g_uNrfTx=0;
			break;
		}
	}

	uNrfWriteBuf(TX_ADDR, addr, NRF_ADR_LEN);
	uNrfWriteBuf(RX_ADDR_P0, addr, NRF_ADR_LEN);

	CE_L();
	vNrfPowerUpTx();
	vNrfFlushTx();
	uNrfWriteBuf(W_TX_PAYLOAD, data, len);
	CE_H();
//	vTimerDelayUs(20);
//	CE_L();
}
void ANO_NRF::TxPacket(uint8_t * tx_buf, uint8_t len)
{	
	CE_L();		 //StandBy I模式	
	
	Write_Buf(NRF_WRITE_REG + RX_ADDR_P0, TX_ADDRESS, TX_ADR_WIDTH); // 装载接收端地址
	Write_Buf(WR_TX_PLOAD, tx_buf, len); 			 // 装载数据	
	CE_H();		 //置高CE,激发数据发送
}
예제 #5
0
파일: nrf.c 프로젝트: NakarinTalikan/stm32
void vNrfPowerUpRx(void)
{
	g_uNrfTx = 0;
	CE_L();
	uNrfWriteReg(CONFIG, NRF_CONFIG | ((1<<PWR_UP) | (1<<PRIM_RX)));
	uNrfWriteReg(EN_RXADDR, (0<<ERX_P0) | (1<<ERX_P1));
	CE_H();
	uNrfWriteReg(STATUS, (1 << TX_DS) | (1 << MAX_RT));
	// need delay!!! but inside interrupt!!
}
예제 #6
0
파일: nRF24.c 프로젝트: aczid/jxd393_dev
// Put nRF24L01 in RX mode
void nRF24_RXMode(uint8_t RX_PAYLOAD) {
    CE_L();
    nRF24_RWReg(nRF24_CMD_WREG | nRF24_REG_EN_AA,0x01); // Enable ShockBurst for data pipe 0
    nRF24_RWReg(nRF24_CMD_WREG | nRF24_REG_EN_RXADDR,0x01); // Enable data pipe 0
    nRF24_RWReg(nRF24_CMD_WREG | nRF24_REG_RF_CH,0x6E); // Set frequency channel 110 (2.510MHz)
    nRF24_RWReg(nRF24_CMD_WREG | nRF24_REG_RX_PW_P0,RX_PAYLOAD); // Set RX payload length
    nRF24_RWReg(nRF24_CMD_WREG | nRF24_REG_RF_SETUP,0x06); // Setup: 1Mbps, 0dBm, LNA off
    nRF24_RWReg(nRF24_CMD_WREG | nRF24_REG_CONFIG,0x0F); // Config: CRC on (2 bytes), Power UP, RX/TX ctl = PRX
    nRF24_WriteBuf(nRF24_CMD_WREG | nRF24_REG_RX_ADDR_P0,nRF24_RX_addr,nRF24_RX_ADDR_WIDTH); // Set static RX address
    CE_H();
    // Delay_us(10); // Hold CE high at least 10us
}
예제 #7
0
파일: NRF_func.c 프로젝트: liuwwei3/sizhou
void RX_Mode(void)
{
	CE_L();  
	NRF24L01_Write_Buf(WRITE_REG+RX_ADDR_P0,(u8*)RX_ADDRESS,RX_ADR_WIDTH);//写RX节点地址
 
	NRF24L01_Write_Reg(WRITE_REG+EN_AA,0x01);             //使能通道0的自动应答    
	NRF24L01_Write_Reg(WRITE_REG+EN_RXADDR,0x01);         //使能通道0的接收地址    
	NRF24L01_Write_Reg(WRITE_REG+RF_CH,40);              //设置RF通信频率  
	NRF24L01_Write_Reg(WRITE_REG+RX_PW_P0,RX_PLOAD_WIDTH);//选择通道0的有效数据宽度    
	NRF24L01_Write_Reg(WRITE_REG+RF_SETUP,0x0f);          //设置TX发射参数,0db增益,2Mbps,低噪声增益开启  ?
	NRF24L01_Write_Reg(WRITE_REG+CONFIG, 0x0f);           //配置基本工作模式的参数;PWR_UP,EN_CRC,16BIT_CRC,接收模式 
	CE_H();    //CE为高,进入接收模式 
}  
예제 #8
0
파일: NRF_func.c 프로젝트: liuwwei3/sizhou
void TX_Mode(void)
{  
	CE_L();    
	NRF24L01_Write_Buf(WRITE_REG+TX_ADDR,(u8*)TX_ADDRESS,TX_ADR_WIDTH);//写TX节点地址 
	NRF24L01_Write_Buf(WRITE_REG+RX_ADDR_P0,(u8*)RX_ADDRESS,RX_ADR_WIDTH); //设置TX节点地址,主要为了使能ACK  

	NRF24L01_Write_Reg(WRITE_REG+EN_AA,0x01);     //使能通道0的自动应答    
	NRF24L01_Write_Reg(WRITE_REG+EN_RXADDR,0x01); //使能通道0的接收地址  
	NRF24L01_Write_Reg(WRITE_REG+SETUP_RETR,0x1a);//设置自动重发间隔时间:500us + 86us;最大自动重发次数:10次
	NRF24L01_Write_Reg(WRITE_REG+RF_CH,40);       //设置RF通道为40
	NRF24L01_Write_Reg(WRITE_REG+RF_SETUP,0x0f);  //设置TX发射参数,0db增益,2Mbps,低噪声增益开启  ?
	NRF24L01_Write_Reg(WRITE_REG+CONFIG,0x0e);    //配置基本工作模式的参数;PWR_UP,EN_CRC,16BIT_CRC,接收模式,开启所有中断
	CE_H(); //CE为高,10us后启动发送
}  
예제 #9
0
void ANO_NRF::Init(u8 model, u8 ch)
{
	CE_L();

	Write_Buf(NRF_WRITE_REG+RX_ADDR_P0,RX_ADDRESS,RX_ADR_WIDTH);	//写RX节点地址 
	Write_Buf(NRF_WRITE_REG+TX_ADDR,TX_ADDRESS,TX_ADR_WIDTH); 		//写TX节点地址  
	Write_Reg(NRF_WRITE_REG+EN_AA,0x01); 													//使能通道0的自动应答 
	Write_Reg(NRF_WRITE_REG+EN_RXADDR,0x01);											//使能通道0的接收地址 
	Write_Reg(NRF_WRITE_REG+SETUP_RETR,0x1a);											//设置自动重发间隔时间:500us;最大自动重发次数:10次 2M波特率下
	Write_Reg(NRF_WRITE_REG+RF_CH,ch);														//设置RF通道为CHANAL
	Write_Reg(NRF_WRITE_REG+RF_SETUP,0x0f); 												//设置TX发射参数,0db增益,2Mbps,低噪声增益开启
	//Write_Reg(NRF_WRITE_REG+RF_SETUP,0x07); 												//设置TX发射参数,0db增益,1Mbps,低噪声增益开启
/////////////////////////////////////////////////////////
	if(model==1)				//RX
	{
		Write_Reg(NRF_WRITE_REG+RX_PW_P0,RX_PLOAD_WIDTH);								//选择通道0的有效数据宽度 
		Write_Reg(NRF_WRITE_REG + CONFIG, 0x0f);   		 // IRQ收发完成中断开启,16位CRC,主接收
	}
	else if(model==2)		//TX
	{
		Write_Reg(NRF_WRITE_REG+RX_PW_P0,RX_PLOAD_WIDTH);								//选择通道0的有效数据宽度 
		Write_Reg(NRF_WRITE_REG + CONFIG, 0x0e);   		 // IRQ收发完成中断开启,16位CRC,主发送
	}
	else if(model==3)		//RX2
	{
		Write_Reg(FLUSH_TX,0xff);
		Write_Reg(FLUSH_RX,0xff);
		Write_Reg(NRF_WRITE_REG + CONFIG, 0x0f);   		 // IRQ收发完成中断开启,16位CRC,主接收
		
		RW(0x50);
		RW(0x73);
		Write_Reg(NRF_WRITE_REG+0x1c,0x01);
		Write_Reg(NRF_WRITE_REG+0x1d,0x06);
	}
	else								//TX2
	{
		Write_Reg(NRF_WRITE_REG + CONFIG, 0x0e);   		 // IRQ收发完成中断开启,16位CRC,主发送
		Write_Reg(FLUSH_TX,0xff);
		Write_Reg(FLUSH_RX,0xff);
		
		RW(0x50);
		RW(0x73);
		Write_Reg(NRF_WRITE_REG+0x1c,0x01);
		Write_Reg(NRF_WRITE_REG+0x1d,0x06);
	}
	CE_H();
		delayms(50);
	
}
예제 #10
0
파일: nrf.c 프로젝트: NakarinTalikan/stm32
void vNrfInit(uint8_t channel, uint8_t * rx_addr)
{
	//		memcpy(g_RxAddr, rx_addr, NRF_ADR_LEN);
	CE_L();
	uNrfWriteBuf(RX_ADDR_P1, rx_addr, NRF_ADR_LEN);
	CE_H();

	uNrfWriteReg(RF_CH, channel); // Select RF channel

	uNrfWriteReg(RX_PW_P0, 4);
	uNrfWriteReg(RX_PW_P1, 4);

	uNrfWriteReg(SETUP_RETR, 0x1F); // 15 retries
	//	uNrfWriteReg(RF_SETUP, 0xF);		// 2 mbps + max gain + LNA

	vNrfSetDynamicPayload();

	vNrfPowerUpRx();
	vNrfFlushRx();
}
void RX_Mode(void)
{
	 CE_L();
	SPI2_writeBuf(WRITE_REG + RX_ADDR_P0, TX_ADDRESS, TX_ADR_WIDTH);
	SPI2_writeReg(WRITE_REG + EN_AA, 0x01);
	// Enable Auto.Ack:Pipe0
	SPI2_writeReg(WRITE_REG + EN_RXADDR, 0x01); // Enable Pipe0
	SPI2_writeReg(WRITE_REG + RF_CH, 40);
	// Select RF channel 40
	SPI2_writeReg(WRITE_REG + RX_PW_P0, TX_PLOAD_WIDTH);
	SPI2_writeReg(WRITE_REG + RF_SETUP, 0x07);
	SPI2_writeReg(WRITE_REG + CONFIG, 0x0f);
	// Set PWR_UP bit, enable CRC(2 bytes)
	//& Prim:RX. RX_DR enabled..
	 CE_H(); // Set CE pin high to enable RX device
	// This device is now ready to receive one packet of 16 bytes payload from a TX device
	//sending to address
	// '3443101001', with auto acknowledgment, retransmit count of 10, RF channel 40 and
	//datarate = 2Mbps.
}
예제 #12
0
파일: NRF_func.c 프로젝트: liuwwei3/sizhou
u8 NRF24L01_TxPacket(u8 *txbuf)
{
	u8 sta;
	CE_L();
	NRF24L01_Write_Buf(WR_TX_PLOAD,txbuf,TX_PLOAD_WIDTH);//写数据到TX BUF  32个字节
	CE_H();                 //启动发送  ?
//	while(GPIOC->IDR&1<<5); //等待发送完成
	Delay(0xEFFFF);
	sta=NRF24L01_Read_Reg(STATUS);  //读取状态寄存器的值  ?
	NRF24L01_Write_Reg(WRITE_REG+STATUS,sta); //清除TX_DS或MAX_RT中断标志
	if(sta&MAX_TX)//达到最大重发次数
	{
		NRF24L01_Write_Reg(FLUSH_TX,0xff);//清除TX FIFO寄存器 
		return MAX_TX; 
	}
	if(sta&TX_OK)//发送完成
	{
		return TX_OK;
	}
	return 0xff;//其他原因发送失败
}
void ANO_NRF::TxPacket_AP(uint8_t * tx_buf, uint8_t len)
{	
	CE_L();		 //StandBy I模式	
	Write_Buf(0xa8, tx_buf, len); 			 // 装载数据
	CE_H();		 //置高CE
}