小白我前几天做NRF24L01+模块的无线调试,想先调通,就修改别人现有的程序,但是不管怎样调都调不通,也不知道到底是收发方哪边的问题,以为模块烧坏啦,就重新在某宝上买了两个,依旧还是调不通。没办法,就到此求大神用这个程序试一下,我想到底是程序的问题还是模块又坏了的原因,小白不甚感激!!!
现程序如下:
【发射方】
#include <reg52.h>
#include <intrins.h>
typedef unsigned char uchar;
typedef unsigned char uint;
//****************************************IOカヒソレカィメ・**************************************
//****************************************NRF24L01カヒソレカィメ・**************************************
sbit CE=P2^2;
sbit CSN =P2^3;
sbit SCK =P2^4;
sbit MOSI =P2^5;
sbit MISO =P2^6;
sbit IRQ =P2^7;
//************************************ーエシ・**************************************************
sbit KEY1=P1^4;
//************************************キ菘・**************************************************
sbit LED=P1^6;
//*********************************************NRF24L01*************************************
#define TX_ADR_WIDTH 5 // 5 uints TX address width
#define RX_ADR_WIDTH 5 // 5 uints RX address width
#define TX_PLOAD_WIDTH 20 // 20 uints TX payload
#define RX_PLOAD_WIDTH 20 // 20 uints TX payload
uint const TX_ADDRESS[TX_ADR_WIDTH]= {0x34,0x43,0x10,0x10,0x01}; //アセオリオリヨキ
uint const RX_ADDRESS[RX_ADR_WIDTH]= {0x34,0x43,0x10,0x10,0x01}; //スモハユオリヨキ
//***************************************NRF24L01シトエ貳クチ・******************************************************
#define READ_REG 0x00 // カチシトエ貳クチ・
#define WRITE_REG 0x20 // ミエシトエ貳クチ・
#define RD_RX_PLOAD 0x61 // カチネ。スモハユハセンヨクチ・
#define WR_TX_PLOAD 0xA0 // ミエエキ「ハセンヨクチ・
#define FLUSH_TX 0xE1 // ウ袞エキ「ヒヘ FIFOヨクチ・
#define FLUSH_RX 0xE2 // ウ袞エスモハユ FIFOヨクチ・
#define REUSE_TX_PL 0xE3 // カィメ袒リクエラーヤリハセンヨクチ・
#define NOP 0xFF // ア」チ・
//*************************************SPI(nRF24L01)シトエ貳リヨキ****************************************************
#define CONFIG 0x00 // ナ葷テハユキ「ラエフャ」ャCRCミ」ム鯑」ハスメヤシーハユキ「ラエフャマ・ヲキスハス
#define EN_AA 0x01 // ラヤカッモヲエヲトワノ靹テ
#define EN_RXADDR 0x02 // ソノモテミナオタノ靹テ
#define SETUP_AW 0x03 // ハユキ「オリヨキソ昮ネノ靹テ
#define SETUP_RETR 0x04 // ラヤカッヨリキ「ケヲトワノ靹テ
#define RF_CH 0x05 // ケ、ラオツハノ靹テ
#define RF_SETUP 0x06 // キ「ノ萢ルツハ。「ケヲコトケヲトワノ靹テ
#define STATUS 0x07 // ラエフャシトエ貳・
#define OBSERVE_TX 0x08 // キ「ヒヘシ犂篁ヲトワ
#define CD 0x09 // オリヨキシ・・
#define RX_ADDR_P0 0x0A // ニオオタ0スモハユハセンオリヨキ
#define RX_ADDR_P1 0x0B // ニオオタ1スモハユハセンオリヨキ
#define RX_ADDR_P2 0x0C // ニオオタ2スモハユハセンオリヨキ
#define RX_ADDR_P3 0x0D // ニオオタ3スモハユハセンオリヨキ
#define RX_ADDR_P4 0x0E // ニオオタ4スモハユハセンオリヨキ
#define RX_ADDR_P5 0x0F // ニオオタ5スモハユハセンオリヨキ
#define TX_ADDR 0x10 // キ「ヒヘオリヨキシトエ貳・
#define RX_PW_P0 0x11 // スモハユニオオタ0スモハユハセンウ、カネ
#define RX_PW_P1 0x12 // スモハユニオオタ0スモハユハセンウ、カネ
#define RX_PW_P2 0x13 // スモハユニオオタ0スモハユハセンウ、カネ
#define RX_PW_P3 0x14 // スモハユニオオタ0スモハユハセンウ、カネ
#define RX_PW_P4 0x15 // スモハユニオオタ0スモハユハセンウ、カネ
#define RX_PW_P5 0x16 // スモハユニオオタ0スモハユハセンウ、カネ
#define FIFO_STATUS 0x17 // FIFOユサネ・サウエフャシトエ貳靹テ
//**************************************************************************************
void Delay(unsigned int s);
void inerDelay_us(unsigned char n);
void init_NRF24L01(void);
uint SPI_RW(uint uchar);
uchar SPI_Read(uchar reg);
void SetRX_Mode(void);
uint SPI_RW_Reg(uchar reg, uchar value);
uint SPI_Read_Buf(uchar reg, uchar *pBuf, uchar uchars);
uint SPI_Write_Buf(uchar reg, uchar *pBuf, uchar uchars);
unsigned char nRF24L01_RxPacket(unsigned char* rx_buf);
void nRF24L01_TxPacket(unsigned char * tx_buf);
//*****************************************ウ、ムモハア*****************************************
void Delay(unsigned int s)
{
unsigned int i;
for(i=0; i<s; i++);
for(i=0; i<s; i++);
}
//******************************************************************************************
uint bdata sta; //ラエフャア・セ
sbit RX_DR =sta^6;
sbit TX_DS =sta^5;
sbit MAX_RT =sta^4;
/******************************************************************************************
/*ムモハアコッハ
/******************************************************************************************/
void inerDelay_us(unsigned char n)
{
for(;n>0;n--)
_nop_();
}
//****************************************************************************************
/*NRF24L01ウシサッ
//***************************************************************************************/
void init_NRF24L01(void)
{
inerDelay_us(100);
CE=0; // chip enable
CSN=1; // Spi disable
SCK=0; // Spi clock line init high
SPI_Write_Buf(WRITE_REG + TX_ADDR, TX_ADDRESS, TX_ADR_WIDTH); // ミエアセオリオリヨキ
SPI_Write_Buf(WRITE_REG + RX_ADDR_P0, RX_ADDRESS, RX_ADR_WIDTH); // ミエスモハユカヒオリヨキ
SPI_RW_Reg(WRITE_REG + EN_AA, 0x01); // ニオオタ0ラヤカッ ACKモヲエハミ・
SPI_RW_Reg(WRITE_REG + EN_RXADDR, 0x01); // ヤハミ晳モハユオリヨキヨサモミニオオタ0」ャネ郢鋗靨ェカ猗オオタソノメヤイホソシPage21
SPI_RW_Reg(WRITE_REG + RF_CH, 0); // ノ靹テミナオタケ、ラェ2.4GHZ」ャハユキ「アリミ・サヨツ
SPI_RW_Reg(WRITE_REG + RX_PW_P0, RX_PLOAD_WIDTH); //ノ靹テスモハユハセンウ、カネ」ャアセエホノ靹テホェ20ラヨスレ
SPI_RW_Reg(WRITE_REG + RF_SETUP, 0x07); //ノ靹テキ「ノ萢ルツハホェ1MHZ」ャキ「ノ荵ヲツハホェラ鋗オ0dB
}
/****************************************************************************************************
/*コッハ」コuint SPI_RW(uint uchar)
/*ケヲトワ」コNRF24L01オトSPIミエハアミ・
/****************************************************************************************************/
uint SPI_RW(uint uchar)
{
uint bit_ctr;
for(bit_ctr=0;bit_ctr<8;bit_ctr++) // output 8-bit
{
MOSI = (uchar & 0x80); // output 'uchar', MSB to MOSI
uchar = (uchar << 1); // shift next bit into MSB..
SCK = 1; // Set SCK high..
uchar |= MISO; // capture current MISO bit
SCK = 0; // ..then set SCK low again
}
return(uchar); // return read uchar
}
/****************************************************************************************************
/*コッハ」コuchar SPI_Read(uchar reg)
/*ケヲトワ」コNRF24L01オトSPIハアミ・
/****************************************************************************************************/
uchar SPI_Read(uchar reg)
{
uchar reg_val;
CSN = 0; // CSN low, initialize SPI communication...
SPI_RW(reg); // Select register to read from..
reg_val = SPI_RW(0); // ..then read registervalue
CSN = 1; // CSN high, terminate SPI communication
return(reg_val); // return register value
}
/****************************************************************************************************/
/*ケヲトワ」コNRF24L01カチミエシトエ貳ッハ
/****************************************************************************************************/
uint SPI_RW_Reg(uchar reg, uchar value)
{
uint status;
CSN = 0; // CSN low, init SPI transaction
status = SPI_RW(reg); // select register
SPI_RW(value); // ..and write value to it..
CSN = 1; // CSN high again
return(status); // return nRF24L01 status uchar
}
/****************************************************************************************************/
/*コッハ」コuint SPI_Read_Buf(uchar reg, uchar *pBuf, uchar uchars)
/*ケヲトワ: モテモレカチハセン」ャreg」コホェシトエ貳リヨキ」ャpBuf」コホェエカチウセンオリヨキ」ャuchars」コカチウセンオトク
/****************************************************************************************************/
uint SPI_Read_Buf(uchar reg, uchar *pBuf, uchar uchars)
{
uint status,uchar_ctr;
CSN = 0; // Set CSN low, init SPI tranaction
status = SPI_RW(reg); // Select register to write to and read status uchar
for(uchar_ctr=0;uchar_ctr<uchars;uchar_ctr++)
pBuf[uchar_ctr] = SPI_RW(0); //
CSN = 1;
return(status); // return nRF24L01 status uchar
}
/*********************************************************************************************************
/*コッハ」コuint SPI_Write_Buf(uchar reg, uchar *pBuf, uchar uchars)
/*ケヲトワ: モテモレミエハセン」コホェシトエ貳リヨキ」ャpBuf」コホェエミエネ・センオリヨキ」ャuchars」コミエネ・センオトク
/*********************************************************************************************************/
uint SPI_Write_Buf(uchar reg, uchar *pBuf, uchar uchars)
{
uint status,uchar_ctr;
CSN = 0; //SPIハケトワ
status = SPI_RW(reg);
for(uchar_ctr=0; uchar_ctr<uchars; uchar_ctr++) //
SPI_RW(*pBuf++);
CSN = 1; //ケリアユSPI
return(status); //
}
/****************************************************************************************************/
/*コッハ」コvoid SetRX_Mode(void)
/*ケヲトワ」コハセンスモハユナ葷テ
/****************************************************************************************************/
void SetRX_Mode(void)
{
CE=0;
SPI_RW_Reg(WRITE_REG + CONFIG, 0x0f); // IRQハユキ「ヘ・ノヨミカママ・ヲ」ャ16ホサCRC 」ャヨモハユ
CE = 1;
inerDelay_us(130);
}
/******************************************************************************************************/
/*コッハ」コunsigned char nRF24L01_RxPacket(unsigned char* rx_buf)
/*ケヲトワ」コハセンカチネ。コナネ輦x_bufスモハユサコウ衂ミ
/******************************************************************************************************/
unsigned char nRF24L01_RxPacket(unsigned char* rx_buf)
{
unsigned char revale=0;
sta=SPI_Read(STATUS); // カチネ。ラエフャシトエ貳菎エナミカマハセンスモハユラエソ・
if(RX_DR) // ナミカマハヌキモハユオスハセン
{
CE = 0; //SPIハケトワ
SPI_Read_Buf(RD_RX_PLOAD,rx_buf,TX_PLOAD_WIDTH);// read receive payload from RX_FIFO buffer
revale =1; //カチネ。ハセンヘ・ノア・セ
}
SPI_RW_Reg(WRITE_REG+STATUS,sta); //スモハユオスハセンコX_DR,TX_DS,MAX_PTカシヨテク゚ホェ1」ャヘィケミエ1タエヌ蟲ヨミカマア・セ
return revale;
}
/***********************************************************************************************************
/*コッハ」コvoid nRF24L01_TxPacket(unsigned char * tx_buf)
/*ケヲトワ」コキ「ヒヘ tx_bufヨミハセン
/**********************************************************************************************************/
void nRF24L01_TxPacket(unsigned char * tx_buf)
{
CE=0; //StandBy Iト」ハス
SPI_Write_Buf(WRITE_REG + RX_ADDR_P0, TX_ADDRESS, TX_ADR_WIDTH); // ラーヤリスモハユカヒオリヨキ
SPI_Write_Buf(WR_TX_PLOAD, tx_buf, TX_PLOAD_WIDTH); // ラーヤリハセン
SPI_RW_Reg(WRITE_REG + CONFIG, 0x0e); // IRQハユキ「ヘ・ノヨミカママ・ヲ」ャ16ホサCRC」ャヨ「ヒヘ
CE=1; //ヨテク゚CE」ャシ、キ「ハセンキ「ヒヘ
inerDelay_us(10);
}
//************************************ヨッハ************************************************************
void main(void)
{
unsigned char tf =0;
unsigned char TxBuf[20]={0}; //
unsigned char RxBuf[20]={0};
init_NRF24L01() ;
TxBuf[1] = 1 ;
TxBuf[2] = 1 ;
nRF24L01_TxPacket(TxBuf); // Transmit Tx buffer data
Delay(6000);
while(1)
{
if(KEY1 ==0 )
{
TxBuf[1] = 1 ;
tf = 1 ; LED=0;
}
if (tf==1)
{
nRF24L01_TxPacket(TxBuf); // Transmit Tx buffer data
TxBuf[1] = 0x00;
TxBuf[2] = 0x00;
tf=0;
Delay(1000);LED=1;
}
}
}
【接收方】
#include <reg52.h>
#include <intrins.h>
typedef unsigned char uchar;
typedef unsigned char uint;
//****************************************IOカヒソレカィメ・**************************************
//****************************************NRF24L01カヒソレカィメ・**************************************
sbit CE=P0^1;
sbit CSN =P0^0;
sbit SCK =P0^3;
sbit MOSI =P0^2;
sbit MISO =P0^5;
sbit IRQ =P0^4;
//************************************ーエシ・**************************************************
sbit KEY1=P3^4;
//************************************キ菘・**************************************************
sbit LED=P3^2;
//*********************************************NRF24L01*************************************
#define TX_ADR_WIDTH 5 // 5 uints TX address width
#define RX_ADR_WIDTH 5 // 5 uints RX address width
#define TX_PLOAD_WIDTH 20 // 20 uints TX payload
#define RX_PLOAD_WIDTH 20 // 20 uints TX payload
uint const TX_ADDRESS[TX_ADR_WIDTH]= {0x34,0x43,0x10,0x10,0x01}; //アセオリオリヨキ
uint const RX_ADDRESS[RX_ADR_WIDTH]= {0x34,0x43,0x10,0x10,0x01}; //スモハユオリヨキ
//***************************************NRF24L01シトエ貳クチ・******************************************************
#define READ_REG 0x00 // カチシトエ貳クチ・
#define WRITE_REG 0x20 // ミエシトエ貳クチ・
#define RD_RX_PLOAD 0x61 // カチネ。スモハユハセンヨクチ・
#define WR_TX_PLOAD 0xA0 // ミエエキ「ハセンヨクチ・
#define FLUSH_TX 0xE1 // ウ袞エキ「ヒヘ FIFOヨクチ・
#define FLUSH_RX 0xE2 // ウ袞エスモハユ FIFOヨクチ・
#define REUSE_TX_PL 0xE3 // カィメ袒リクエラーヤリハセンヨクチ・
#define NOP 0xFF // ア」チ・
//*************************************SPI(nRF24L01)シトエ貳リヨキ****************************************************
#define CONFIG 0x00 // ナ葷テハユキ「ラエフャ」ャCRCミ」ム鯑」ハスメヤシーハユキ「ラエフャマ・ヲキスハス
#define EN_AA 0x01 // ラヤカッモヲエヲトワノ靹テ
#define EN_RXADDR 0x02 // ソノモテミナオタノ靹テ
#define SETUP_AW 0x03 // ハユキ「オリヨキソ昮ネノ靹テ
#define SETUP_RETR 0x04 // ラヤカッヨリキ「ケヲトワノ靹テ
#define RF_CH 0x05 // ケ、ラオツハノ靹テ
#define RF_SETUP 0x06 // キ「ノ萢ルツハ。「ケヲコトケヲトワノ靹テ
#define STATUS 0x07 // ラエフャシトエ貳・
#define OBSERVE_TX 0x08 // キ「ヒヘシ犂篁ヲトワ
#define CD 0x09 // オリヨキシ・・
#define RX_ADDR_P0 0x0A // ニオオタ0スモハユハセンオリヨキ
#define RX_ADDR_P1 0x0B // ニオオタ1スモハユハセンオリヨキ
#define RX_ADDR_P2 0x0C // ニオオタ2スモハユハセンオリヨキ
#define RX_ADDR_P3 0x0D // ニオオタ3スモハユハセンオリヨキ
#define RX_ADDR_P4 0x0E // ニオオタ4スモハユハセンオリヨキ
#define RX_ADDR_P5 0x0F // ニオオタ5スモハユハセンオリヨキ
#define TX_ADDR 0x10 // キ「ヒヘオリヨキシトエ貳・
#define RX_PW_P0 0x11 // スモハユニオオタ0スモハユハセンウ、カネ
#define RX_PW_P1 0x12 // スモハユニオオタ0スモハユハセンウ、カネ
#define RX_PW_P2 0x13 // スモハユニオオタ0スモハユハセンウ、カネ
#define RX_PW_P3 0x14 // スモハユニオオタ0スモハユハセンウ、カネ
#define RX_PW_P4 0x15 // スモハユニオオタ0スモハユハセンウ、カネ
#define RX_PW_P5 0x16 // スモハユニオオタ0スモハユハセンウ、カネ
#define FIFO_STATUS 0x17 // FIFOユサネ・サウエフャシトエ貳靹テ
//**************************************************************************************
void Delay(unsigned int s);
void inerDelay_us(unsigned char n);
void init_NRF24L01(void);
uint SPI_RW(uint uchar);
uchar SPI_Read(uchar reg);
void SetRX_Mode(void);
uint SPI_RW_Reg(uchar reg, uchar value);
uint SPI_Read_Buf(uchar reg, uchar *pBuf, uchar uchars);
uint SPI_Write_Buf(uchar reg, uchar *pBuf, uchar uchars);
unsigned char nRF24L01_RxPacket(unsigned char* rx_buf);
void nRF24L01_TxPacket(unsigned char * tx_buf);
//*****************************************ウ、ムモハア*****************************************
void Delay(unsigned int s)
{
unsigned int i;
for(i=0; i<s; i++);
for(i=0; i<s; i++);
}
//******************************************************************************************
uint bdata sta; //ラエフャア・セ
sbit RX_DR =sta^6;
sbit TX_DS =sta^5;
sbit MAX_RT =sta^4;
/******************************************************************************************
/*ムモハアコッハ
/******************************************************************************************/
void inerDelay_us(unsigned char n)
{
for(;n>0;n--)
_nop_();
}
//****************************************************************************************
/*NRF24L01ウシサッ
//***************************************************************************************/
void init_NRF24L01(void)
{
inerDelay_us(100);
CE=0; // chip enable
CSN=1; // Spi disable
SCK=0; // Spi clock line init high
SPI_Write_Buf(WRITE_REG + TX_ADDR, TX_ADDRESS, TX_ADR_WIDTH); // ミエアセオリオリヨキ
SPI_Write_Buf(WRITE_REG + RX_ADDR_P0, RX_ADDRESS, RX_ADR_WIDTH); // ミエスモハユカヒオリヨキ
SPI_RW_Reg(WRITE_REG + EN_AA, 0x01); // ニオオタ0ラヤカッ ACKモヲエハミ・
SPI_RW_Reg(WRITE_REG + EN_RXADDR, 0x01); // ヤハミ晳モハユオリヨキヨサモミニオオタ0」ャネ郢鋗靨ェカ猗オオタソノメヤイホソシPage21
SPI_RW_Reg(WRITE_REG + RF_CH, 0); // ノ靹テミナオタケ、ラェ2.4GHZ」ャハユキ「アリミ・サヨツ
SPI_RW_Reg(WRITE_REG + RX_PW_P0, RX_PLOAD_WIDTH); //ノ靹テスモハユハセンウ、カネ」ャアセエホノ靹テホェ20ラヨスレ
SPI_RW_Reg(WRITE_REG + RF_SETUP, 0x07); //ノ靹テキ「ノ萢ルツハホェ1MHZ」ャキ「ノ荵ヲツハホェラ鋗オ0dB
}
/****************************************************************************************************
/*コッハ」コuint SPI_RW(uint uchar)
/*ケヲトワ」コNRF24L01オトSPIミエハアミ・
/****************************************************************************************************/
uint SPI_RW(uint uchar)
{
uint bit_ctr;
for(bit_ctr=0;bit_ctr<8;bit_ctr++) // output 8-bit
{
MOSI = (uchar & 0x80); // output 'uchar', MSB to MOSI
uchar = (uchar << 1); // shift next bit into MSB..
SCK = 1; // Set SCK high..
uchar |= MISO; // capture current MISO bit
SCK = 0; // ..then set SCK low again
}
return(uchar); // return read uchar
}
/****************************************************************************************************
/*コッハ」コuchar SPI_Read(uchar reg)
/*ケヲトワ」コNRF24L01オトSPIハアミ・
/****************************************************************************************************/
uchar SPI_Read(uchar reg)
{
uchar reg_val;
CSN = 0; // CSN low, initialize SPI communication...
SPI_RW(reg); // Select register to read from..
reg_val = SPI_RW(0); // ..then read registervalue
CSN = 1; // CSN high, terminate SPI communication
return(reg_val); // return register value
}
/****************************************************************************************************/
/*ケヲトワ」コNRF24L01カチミエシトエ貳ッハ
/****************************************************************************************************/
uint SPI_RW_Reg(uchar reg, uchar value)
{
uint status;
CSN = 0; // CSN low, init SPI transaction
status = SPI_RW(reg); // select register
SPI_RW(value); // ..and write value to it..
CSN = 1; // CSN high again
return(status); // return nRF24L01 status uchar
}
/****************************************************************************************************/
/*コッハ」コuint SPI_Read_Buf(uchar reg, uchar *pBuf, uchar uchars)
/*ケヲトワ: モテモレカチハセン」ャreg」コホェシトエ貳リヨキ」ャpBuf」コホェエカチウセンオリヨキ」ャuchars」コカチウセンオトク
/****************************************************************************************************/
uint SPI_Read_Buf(uchar reg, uchar *pBuf, uchar uchars)
{
uint status,uchar_ctr;
CSN = 0; // Set CSN low, init SPI tranaction
status = SPI_RW(reg); // Select register to write to and read status uchar
for(uchar_ctr=0;uchar_ctr<uchars;uchar_ctr++)
pBuf[uchar_ctr] = SPI_RW(0); //
CSN = 1;
return(status); // return nRF24L01 status uchar
}
/*********************************************************************************************************
/*コッハ」コuint SPI_Write_Buf(uchar reg, uchar *pBuf, uchar uchars)
/*ケヲトワ: モテモレミエハセン」コホェシトエ貳リヨキ」ャpBuf」コホェエミエネ・センオリヨキ」ャuchars」コミエネ・センオトク
/*********************************************************************************************************/
uint SPI_Write_Buf(uchar reg, uchar *pBuf, uchar uchars)
{
uint status,uchar_ctr;
CSN = 0; //SPIハケトワ
status = SPI_RW(reg);
for(uchar_ctr=0; uchar_ctr<uchars; uchar_ctr++) //
SPI_RW(*pBuf++);
CSN = 1; //ケリアユSPI
return(status); //
}
/****************************************************************************************************/
/*コッハ」コvoid SetRX_Mode(void)
/*ケヲトワ」コハセンスモハユナ葷テ
/****************************************************************************************************/
void SetRX_Mode(void)
{
CE=0;
SPI_RW_Reg(WRITE_REG + CONFIG, 0x0f); // IRQハユキ「ヘ・ノヨミカママ・ヲ」ャ16ホサCRC 」ャヨモハユ
CE = 1;
inerDelay_us(130);
}
/******************************************************************************************************/
/*コッハ」コunsigned char nRF24L01_RxPacket(unsigned char* rx_buf)
/*ケヲトワ」コハセンカチネ。コナネ輦x_bufスモハユサコウ衂ミ
/******************************************************************************************************/
unsigned char nRF24L01_RxPacket(unsigned char* rx_buf)
{
unsigned char revale=0;
sta=SPI_Read(STATUS); // カチネ。ラエフャシトエ貳菎エナミカマハセンスモハユラエソ・
if(RX_DR) // ナミカマハヌキモハユオスハセン
{
CE = 0; //SPIハケトワ
SPI_Read_Buf(RD_RX_PLOAD,rx_buf,TX_PLOAD_WIDTH);// read receive payload from RX_FIFO buffer
revale =1; //カチネ。ハセンヘ・ノア・セ
}
SPI_RW_Reg(WRITE_REG+STATUS,sta); //スモハユオスハセンコX_DR,TX_DS,MAX_PTカシヨテク゚ホェ1」ャヘィケミエ1タエヌ蟲ヨミカマア・セ
return revale;
}
/***********************************************************************************************************
/*コッハ」コvoid nRF24L01_TxPacket(unsigned char * tx_buf)
/*ケヲトワ」コキ「ヒヘ tx_bufヨミハセン
/**********************************************************************************************************/
void nRF24L01_TxPacket(unsigned char * tx_buf)
{
CE=0; //StandBy Iト」ハス
SPI_Write_Buf(WRITE_REG + RX_ADDR_P0, TX_ADDRESS, TX_ADR_WIDTH); // ラーヤリスモハユカヒオリヨキ
SPI_Write_Buf(WR_TX_PLOAD, tx_buf, TX_PLOAD_WIDTH); // ラーヤリハセン
SPI_RW_Reg(WRITE_REG + CONFIG, 0x0e); // IRQハユキ「ヘ・ノヨミカママ・ヲ」ャ16ホサCRC」ャヨ「ヒヘ
CE=1; //ヨテク゚CE」ャシ、キ「ハセンキ「ヒヘ
inerDelay_us(10);
}
//************************************ヨッハ************************************************************
void main(void)
{
unsigned char tf =0;
unsigned char TxBuf[20]={0}; //
unsigned char RxBuf[20]={0};
init_NRF24L01() ;
TxBuf[1] = 1 ;
TxBuf[2] = 1 ;
nRF24L01_TxPacket(TxBuf); // Transmit Tx buffer data
Delay(6000);
while(1)
{
SetRX_Mode();
nRF24L01_RxPacket(RxBuf);
if( RxBuf[1]==1)
{
LED=0;
}
Delay(1000);LED=1;
RxBuf[1] = 0x00;
RxBuf[2] = 0x00;
}
}
|