OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 6258|回复: 9

菜鸟求助24L01无线通信

[复制链接]

1

主题

10

帖子

0

精华

新手上路

积分
34
金钱
34
注册时间
2013-1-12
在线时间
0 小时
发表于 2013-1-13 11:04:16 | 显示全部楼层 |阅读模式
<p>const u8 TX_ADDRESS[TX_ADR_WIDTH]={0xe7,0xe7,0xe7,0xe7,0xe7}; //发送地址</p>
<p>const u8 RX_ADDRESS [RX_ADR_WIDTH]={0x01,0x01,0xc2,0xc2,0xc2}; //接收0通道地址<br />
const u8 RX_ADDRESS1[RX_ADR_WIDTH]={0x02,0x01,0xc2,0xc2,0xc2}; //接收1通道地址</p>
<p>/*写入第2,3,4,5通道地址的时候,无论你写多少个进去,它只认最后一个*/<br />
const u8 RX_ADDRESS2[RX_ADR_WIDTH]={0x03}; //接收2通道地址<br />
const u8 RX_ADDRESS3[RX_ADR_WIDTH]={0x04}; //接收3通道地址<br />
const u8 RX_ADDRESS4[RX_ADR_WIDTH]={0x05}; //接收4通道地址<br />
const u8 RX_ADDRESS5[RX_ADR_WIDTH]={0x06}; //接收5通道地址</p>
<p>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <br />
//初始化24L01的IO口<br />
void NRF24L01_Init(void)<br />
&nbsp;{<br />
&nbsp;GPIO_InitTypeDef GPIO_InitStructure;<br />
&nbsp;//RCC-&gt;APB2ENR|=1&lt;&lt;2;&nbsp;&nbsp;&nbsp; //使能PORTA口时钟 <br />
&nbsp;//RCC-&gt;APB2ENR|=1&lt;&lt;4;&nbsp;&nbsp;&nbsp; //使能PORTC口时钟 <br />
&nbsp;RCC_APB2PeriphClockCmd(&nbsp;RCC_APB2Periph_GPIOA|RCC_APB2Periph_GPIOB|RCC_APB2Periph_GPIOC|RCC_APB2Periph_GPIOE, ENABLE );&nbsp;<br />
&nbsp;//GPIOA-&gt;CRL&amp;=0XFFF000FF;//PA4输出<br />
&nbsp;//GPIOA-&gt;CRL|=0X00033300; <br />
&nbsp;GPIO_InitStructure.GPIO_Pin = NRF24L01_CE_PIN;<br />
&nbsp;GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP ;&nbsp;&nbsp; //推挽输出<br />
&nbsp;GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;<br />
&nbsp;GPIO_Init(NRF24L01_CE_PORT, &amp;GPIO_InitStructure);<br />
&nbsp;GPIO_InitStructure.GPIO_Pin = GPIO_Pin_2|GPIO_Pin_3;<br />
&nbsp;GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP ;&nbsp;&nbsp; //推挽输出<br />
&nbsp;GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;<br />
&nbsp;GPIO_Init(GPIOA, &amp;GPIO_InitStructure);<br />
&nbsp;//GPIOA-&gt;ODR|=7&lt;&lt;2;&nbsp;&nbsp;&nbsp; //PA2.3.4 输出1&nbsp;<br />
&nbsp;Set_NRF24L01_CE;&nbsp; <br />
&nbsp;GPIO_SetBits(GPIOA,GPIO_Pin_2);<br />
&nbsp;GPIO_SetBits(GPIOA,GPIO_Pin_3);<br />
&nbsp;//GPIOC-&gt;CRL&amp;=0XFF00FFFF;//PC4输出 PC5输出<br />
&nbsp;//GPIOC-&gt;CRL|=0X00830000; <br />
&nbsp;//GPIOC-&gt;ODR|=3&lt;&lt;4;&nbsp;&nbsp;&nbsp; //上拉&nbsp; <br />
&nbsp;GPIO_InitStructure.GPIO_Pin = NRF24L01_CSN_PIN;<br />
&nbsp;GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP ;&nbsp;&nbsp; //推挽输出<br />
&nbsp;GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;<br />
&nbsp;GPIO_Init(NRF24L01_CSN_PORT, &amp;GPIO_InitStructure);<br />
&nbsp;Set_NRF24L01_CSN; <br />
&nbsp;GPIO_InitStructure.GPIO_Pin = NRF24L01_IRQ_PIN;<br />
&nbsp;GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPU&nbsp; ;&nbsp;&nbsp; //上拉输入<br />
&nbsp;GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;<br />
&nbsp;GPIO_Init(NRF24L01_IRQ_PORT, &amp;GPIO_InitStructure);</p>
<p>&nbsp;GPIO_ResetBits(GPIOA,GPIO_Pin_5);////时钟置底<br />
&nbsp;Clr_NRF24L01_CE; &nbsp;//使能24L01<br />
&nbsp;Set_NRF24L01_CSN;&nbsp;//SPI片选取消&nbsp;&nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp;&nbsp; <br />
&nbsp;}</p>
<p>//检测24L01是否存在<br />
//返回值:0,成功;1,失败&nbsp;<br />
u8 NRF24L01_Check(u8 value)<br />
&nbsp;{<br />
&nbsp;u8 buf[5]={0XA5,0XA5,0XA5,0XA5,0XA5};<br />
&nbsp;u8 i;<br />
&nbsp;SPIx_SetSpeed(SPI_SPEED_8); //spi速度为9Mhz(24L01的最大SPI时钟为10Mhz)&nbsp;&nbsp; &nbsp; <br />
&nbsp;NRF24L01_Write_Buf(NRF24L01_WRITE_REG+TX_ADDR,buf,5);//写入5个字节的地址.&nbsp;<br />
&nbsp;NRF24L01_Read_Buf(TX_ADDR,buf,5); //读出写入的地址&nbsp; <br />
&nbsp;for(i=0;i&lt;5;i++)<br />
&nbsp;{<br />
&nbsp;if(buf!=0XA5)break;&nbsp; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <br />
&nbsp;}<br />
&nbsp;if(i!=5)<br />
&nbsp;{<br />
&nbsp;&nbsp;value = 1;<br />
&nbsp;&nbsp;return(value);//检测24L01错误<br />
&nbsp;}<br />
&nbsp;else<br />
&nbsp;{<br />
&nbsp; value = 0;<br />
&nbsp; return(value);//检测到24L01<br />
&nbsp;}&nbsp;<br />
&nbsp;<br />
&nbsp;}&nbsp;<br />
&nbsp;&nbsp; <br />
//SPI写寄存器<br />
//reg:指定寄存器地址<br />
//value:写入的值<br />
u8 NRF24L01_Write_Reg(u8 reg,u8 value)<br />
&nbsp;{<br />
&nbsp;u8 status;&nbsp;<br />
&nbsp;Clr_NRF24L01_CSN;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; //使能SPI传输<br />
&nbsp;status =SPIx_ReadWriteByte(reg);//发送寄存器号 <br />
&nbsp;SPIx_ReadWriteByte(value);&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; //写入寄存器的值<br />
&nbsp;Set_NRF24L01_CSN;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; //禁止SPI传输&nbsp;&nbsp;&nbsp; <br />
&nbsp;return(status);&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp;//返回状态值<br />
&nbsp;}</p>
<p>//读取SPI寄存器值<br />
//reg:要读的寄存器<br />
u8 NRF24L01_Read_Reg(u8 reg)<br />
&nbsp;{<br />
&nbsp;u8 reg_val;&nbsp;&nbsp;&nbsp;&nbsp; <br />
&nbsp;Clr_NRF24L01_CSN;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; //使能SPI传输&nbsp;&nbsp;<br />
&nbsp;SPIx_ReadWriteByte(reg);&nbsp;&nbsp; //发送寄存器号<br />
&nbsp;reg_val=SPIx_ReadWriteByte(0x00);//读取寄存器内容<br />
&nbsp;Set_NRF24L01_CSN;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; //禁止SPI传输&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <br />
&nbsp;return(reg_val);&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; //返回状态值<br />
&nbsp;}&nbsp;</p>
<p>//在指定位置读出指定长度的数据<br />
//reg:寄存器(位置)<br />
//*pBuf:数据指针<br />
//len:数据长度<br />
//返回值,此次读到的状态寄存器值 <br />
u8 NRF24L01_Read_Buf(u8 reg,u8 *pBuf,u8 len)<br />
&nbsp;{<br />
&nbsp;u8 status,u8_ctr;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <br />
&nbsp;Clr_NRF24L01_CSN;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; //使能SPI传输<br />
&nbsp;status=SPIx_ReadWriteByte(reg);//发送寄存器值(位置),并读取状态值&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; <br />
&nbsp;for(u8_ctr=0;u8_ctr&lt;len;u8_ctr++)pBuf[u8_ctr]=SPIx_ReadWriteByte(0x00);//读出数据<br />
&nbsp;Set_NRF24L01_CSN;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; //关闭SPI传输<br />
&nbsp;return status;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; //返回读到的状态值<br />
&nbsp;}</p>
<p>//在指定位置写指定长度的数据<br />
//reg:寄存器(位置)<br />
//*pBuf:数据指针<br />
//len:数据长度<br />
//返回值,此次读到的状态寄存器值<br />
u8 NRF24L01_Write_Buf(u8 reg, u8 *pBuf, u8 len)<br />
&nbsp;{<br />
&nbsp;u8 status,u8_ctr;&nbsp;&nbsp;&nbsp;&nbsp; <br />
&nbsp;Clr_NRF24L01_CSN;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; //使能SPI传输<br />
&nbsp;status = SPIx_ReadWriteByte(reg);//发送寄存器值(位置),并读取状态值<br />
&nbsp;for(u8_ctr=0; u8_ctr&lt;len; u8_ctr++)SPIx_ReadWriteByte(*pBuf++); //写入数据&nbsp; <br />
&nbsp;Set_NRF24L01_CSN;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; //关闭SPI传输<br />
&nbsp;return status;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; //返回读到的状态值<br />
&nbsp;}<br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <br />
//启动NRF24L01发送一次数据<br />
//txbuf:待发送数据首地址<br />
//返回值:发送完成状况<br />
u8 NRF24L01_TxPacket(u8 *txbuf)<br />
&nbsp;{<br />
&nbsp;u8 sta;<br />
&nbsp;SPIx_SetSpeed(SPI_SPEED_8);//spi速度为9Mhz(24L01的最大SPI时钟为10Mhz)&nbsp;&nbsp; <br />
&nbsp;Clr_NRF24L01_CE;<br />
&nbsp;NRF24L01_Write_Buf(NRF24L01_WR_TX_PLOAD,txbuf,TX_PLOAD_WIDTH);//写数据到TX BUF&nbsp; 32个字节<br />
&nbsp;Set_NRF24L01_CE;//启动发送&nbsp;&nbsp;&nbsp; <br />
&nbsp;while(NRF24L01_IRQ!=0);//等待发送完成<br />
&nbsp;sta=NRF24L01_Read_Reg(STATUS);&nbsp; //读取状态寄存器的值&nbsp;&nbsp;&nbsp; <br />
&nbsp;NRF24L01_Write_Reg(NRF24L01_WRITE_REG+STATUS,sta); //清除TX_DS或MAX_RT中断标志<br />
&nbsp;if(sta&amp;MAX_TX)//达到最大重发次数<br />
&nbsp;&nbsp;{<br />
&nbsp;&nbsp;NRF24L01_Write_Reg(NRF24L01_FLUSH_TX,0xff);//清除TX FIFO寄存器 <br />
&nbsp;&nbsp;return MAX_TX; <br />
&nbsp;&nbsp;}<br />
&nbsp;if(sta&amp;TX_OK)//发送完成<br />
&nbsp;&nbsp;{<br />
&nbsp;&nbsp;&nbsp;return 0;<br />
&nbsp;&nbsp;}<br />
&nbsp;&nbsp;return 0xff;//其他原因发送失败</p>
<p>&nbsp;}</p>
<p>//启动NRF24L01发送一次数据<br />
//txbuf:待发送数据首地址<br />
//返回值:0,接收完成;其他,错误代码<br />
u8 NRF24L01_RxPacket(u8 *rxbuf)<br />
&nbsp;{<br />
&nbsp;u8 sta;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <br />
&nbsp;SPIx_SetSpeed(SPI_SPEED_8); //spi速度为9Mhz(24L01的最大SPI时钟为10Mhz)&nbsp;&nbsp; <br />
&nbsp;sta=NRF24L01_Read_Reg(STATUS);&nbsp; //读取状态寄存器的值&nbsp;&nbsp;&nbsp; &nbsp; <br />
&nbsp;NRF24L01_Write_Reg(NRF24L01_WRITE_REG+STATUS,sta); //清除TX_DS或MAX_RT中断标志<br />
&nbsp;if(sta&amp;RX_OK)//接收到数据<br />
&nbsp;&nbsp;{<br />
&nbsp;&nbsp;NRF24L01_Read_Buf(NRF24L01_RD_RX_PLOAD,rxbuf,RX_PLOAD_WIDTH);//读取数据<br />
&nbsp;&nbsp;NRF24L01_Write_Reg(NRF24L01_FLUSH_RX,0xff);//清除RX FIFO寄存器 <br />
&nbsp;&nbsp;return 0; <br />
&nbsp;&nbsp;}&nbsp;&nbsp;&nbsp; <br />
&nbsp;return 1;//没收到任何数据<br />
&nbsp;}&nbsp;<br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <br />
//该函数初始化NRF24L01到RX模式<br />
//设置RX地址,写RX数据宽度,选择RF频道,波特率和LNA HCURR<br />
//当CE变高后,即进入RX模式,并可以接收数据了&nbsp;&nbsp;&nbsp;&nbsp; <br />
void RX_Mode(void)<br />
&nbsp;{<br />
&nbsp;Clr_NRF24L01_CE;<br />
&nbsp;NRF24L01_Write_Reg(NRF24L01_FLUSH_RX,0xff);//清除TX FIFO寄存器<br />
&nbsp;NRF24L01_Write_Buf(NRF24L01_WRITE_REG+RX_ADDR_P0,(u8*)RX_ADDRESS,RX_ADR_WIDTH);//写RX节点地址<br />
&nbsp;NRF24L01_Write_Buf(NRF24L01_WRITE_REG+RX_ADDR_P1,(u8*)RX_ADDRESS1,RX_ADR_WIDTH);//写RX节点地址</p>
<p>&nbsp;&nbsp;&nbsp; NRF24L01_Write_Buf(NRF24L01_WRITE_REG+RX_ADDR_P2,(u8*)RX_ADDRESS2,1);//写RX节点地址<br />
&nbsp;NRF24L01_Write_Buf(NRF24L01_WRITE_REG+RX_ADDR_P3,(u8*)RX_ADDRESS3,1);//写RX节点地址<br />
&nbsp;NRF24L01_Write_Buf(NRF24L01_WRITE_REG+RX_ADDR_P4,(u8*)RX_ADDRESS4,1);//写RX节点地址<br />
&nbsp;NRF24L01_Write_Buf(NRF24L01_WRITE_REG+RX_ADDR_P5,(u8*)RX_ADDRESS5,1);//写RX节点地址<br />
&nbsp;<br />
&nbsp;NRF24L01_Write_Reg(NRF24L01_WRITE_REG+EN_AA,0x3f);&nbsp;&nbsp;&nbsp; //使能通道0的自动应答&nbsp;&nbsp;&nbsp; <br />
&nbsp;NRF24L01_Write_Reg(NRF24L01_WRITE_REG+EN_RXADDR,0x3f);//使能通道0的接收地址&nbsp; &nbsp; <br />
&nbsp;NRF24L01_Write_Reg(NRF24L01_WRITE_REG+RF_CH,40);&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; //设置RF通信频率&nbsp;<br />
&nbsp;&nbsp;&nbsp; <br />
&nbsp;NRF24L01_Write_Reg(NRF24L01_WRITE_REG+RX_PW_P0,RX_PLOAD_WIDTH);//选择通道0的有效数据宽度 &nbsp;&nbsp;&nbsp;&nbsp; <br />
&nbsp;NRF24L01_Write_Reg(NRF24L01_WRITE_REG+RX_PW_P1,RX_PLOAD_WIDTH);//选择通道0的有效数据宽度<br />
&nbsp;NRF24L01_Write_Reg(NRF24L01_WRITE_REG+RX_PW_P2,RX_PLOAD_WIDTH);//选择通道0的有效数据宽度<br />
&nbsp;NRF24L01_Write_Reg(NRF24L01_WRITE_REG+RX_PW_P3,RX_PLOAD_WIDTH);//选择通道0的有效数据宽度<br />
&nbsp;NRF24L01_Write_Reg(NRF24L01_WRITE_REG+RX_PW_P4,RX_PLOAD_WIDTH);//选择通道0的有效数据宽度<br />
&nbsp;NRF24L01_Write_Reg(NRF24L01_WRITE_REG+RX_PW_P5,RX_PLOAD_WIDTH);//选择通道0的有效数据宽度</p>
<p>&nbsp;NRF24L01_Write_Reg(NRF24L01_WRITE_REG+RF_SETUP,0x0f);//设置TX发射参数,0db增益,2Mbps,低噪声增益开启&nbsp;&nbsp; <br />
&nbsp;NRF24L01_Write_Reg(NRF24L01_WRITE_REG+CONFIG, 0x0f);//配置基本工作模式的参数WR_UP,EN_CRC,16BIT_CRC,接收模式 <br />
&nbsp;Set_NRF24L01_CE; //CE为高,进入接收模式 <br />
&nbsp;}<br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <br />
//该函数初始化NRF24L01到TX模式<br />
//设置TX地址,写TX数据宽度,设置RX自动应答的地址,填充TX发送数据,选择RF频道,波特率和LNA HCURR<br />
//PWR_UP,CRC使能<br />
//当CE变高后,即进入RX模式,并可以接收数据了&nbsp;&nbsp;&nbsp;&nbsp; <br />
//CE为高大于10us,则启动发送.&nbsp; <br />
void TX_Mode(void)<br />
&nbsp;{&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <br />
&nbsp;Clr_NRF24L01_CE;&nbsp;&nbsp;&nbsp;&nbsp; <br />
&nbsp;NRF24L01_Write_Reg(NRF24L01_FLUSH_TX,0xff);//清除TX FIFO寄存器</p>
<p>&nbsp;NRF24L01_Write_Buf(NRF24L01_WRITE_REG+TX_ADDR,(u8*)TX_ADDRESS,TX_ADR_WIDTH);//写TX节点地址 <br />
&nbsp;NRF24L01_Write_Buf(NRF24L01_WRITE_REG+RX_ADDR_P0,(u8*)RX_ADDRESS,RX_ADR_WIDTH); //设置TX节点地址,主要为了使能ACK&nbsp;&nbsp; <br />
&nbsp;<br />
&nbsp;NRF24L01_Write_Reg(NRF24L01_WRITE_REG+EN_AA,0x01);&nbsp;&nbsp;&nbsp;&nbsp; //使能通道0的自动应答&nbsp;&nbsp;&nbsp; <br />
&nbsp;NRF24L01_Write_Reg(NRF24L01_WRITE_REG+EN_RXADDR,0x01); //使能通道0的接收地址&nbsp; <br />
&nbsp;NRF24L01_Write_Reg(NRF24L01_WRITE_REG+SETUP_RETR,0x1a);//设置自动重发间隔时间:500us + 86us;最大自动重发次数:10次<br />
&nbsp;NRF24L01_Write_Reg(NRF24L01_WRITE_REG+RF_CH,40);&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; //设置RF通道为40<br />
&nbsp;NRF24L01_Write_Reg(NRF24L01_WRITE_REG+RF_SETUP,0x0f);&nbsp; //设置TX发射参数,0db增益,2Mbps,低噪声增益开启&nbsp;&nbsp; <br />
&nbsp;NRF24L01_Write_Reg(NRF24L01_WRITE_REG+CONFIG,0x0e);&nbsp;&nbsp;&nbsp; //配置基本工作模式的参数WR_UP,EN_CRC,16BIT_CRC,接收模式,开启所有中断<br />
&nbsp;Set_NRF24L01_CE;//CE为高,10us后启动发<br />
&nbsp;}<br />
<br />
<br />
<br />
//NRF24L01寄存器操作命令<br />
#define NRF24L01_READ_REG&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 0x00&nbsp; //读配置寄存器,低5位为寄存器地址<br />
#define NRF24L01_WRITE_REG&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 0x20&nbsp; //写配置寄存器,低5位为寄存器地址<br />
#define NRF24L01_RD_RX_PLOAD&nbsp;&nbsp;&nbsp;&nbsp; 0x61&nbsp; //读RX有效数据,1~32字节<br />
#define NRF24L01_WR_TX_PLOAD&nbsp;&nbsp;&nbsp;&nbsp; 0xA0&nbsp; //写TX有效数据,1~32字节<br />
#define NRF24L01_FLUSH_TX&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 0xE1&nbsp; //清除TX FIFO寄存器.发射模式下用<br />
#define NRF24L01_FLUSH_RX&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 0xE2&nbsp; //清除RX FIFO寄存器.接收模式下用<br />
#define NRF24L01_REUSE_TX_PL&nbsp;&nbsp;&nbsp;&nbsp; 0xE3&nbsp; //重新使用上一包数据,CE为高,数据包被不断发送.<br />
#define NRF24L01_NOP&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 0xFF&nbsp; //空操作,可以用来读状态寄存器&nbsp; <br />
//SPI(NRF24L01)寄存器地址<br />
#define CONFIG&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 0x00&nbsp; //配置寄存器地址;bit0:1接收模式,0发射模式;bit1:电选择;bit2:CRC模式;bit3:CRC使能;<br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; //bit4:中断MAX_RT(达到最大重发次数中断)使能;bit5:中断TX_DS使能;bit6:中断RX_DR使能<br />
#define EN_AA&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 0x01&nbsp; //使能自动应答功能&nbsp; bit0~5,对应通道0~5<br />
#define EN_RXADDR&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 0x02&nbsp; //接收地址允许,bit0~5,对应通道0~5<br />
#define SETUP_AW&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 0x03&nbsp; //设置地址宽度(所有数据通道):bit1,0:00,3字节;01,4字节;02,5字节;<br />
#define SETUP_RETR&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 0x04&nbsp; //建立自动重发;bit3:0,自动重发计数器;bit7:4,自动重发延时 250*x+86us<br />
#define RF_CH&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 0x05&nbsp; //RF通道,bit6:0,工作通道频率;<br />
#define RF_SETUP&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 0x06&nbsp; //RF寄存器;bit3:传输速率(0:1Mbps,1:2Mbps);bit2:1,发射功率;bit0:低噪声放大器增益<br />
#define STATUS&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 0x07&nbsp; //状态寄存器;bit0:TX FIFO满标志;bit3:1,接收数据通道号(最大:6);bit4,达到最多次重发<br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; //bit5:数据发送完成中断;bit6:接收数据中断;<br />
#define MAX_TX&nbsp; &nbsp;0x10&nbsp; //达到最大发送次数中断<br />
#define TX_OK&nbsp;&nbsp; &nbsp;0x20&nbsp; //TX发送完成中断<br />
#define RX_OK&nbsp;&nbsp; &nbsp;0x40&nbsp; //接收到数据中断</p>
<p>#define OBSERVE_TX&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 0x08&nbsp; //发送检测寄存器,bit7:4,数据包丢失计数器;bit3:0,重发计数器<br />
#define CD&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 0x09&nbsp; //载波检测寄存器,bit0,载波检测;<br />
#define RX_ADDR_P0&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 0x0A&nbsp; //数据通道0接收地址,最大长度5个字节,低字节在前<br />
#define RX_ADDR_P1&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 0x0B&nbsp; //数据通道1接收地址,最大长度5个字节,低字节在前<br />
#define RX_ADDR_P2&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 0x0C&nbsp; //数据通道2接收地址,最低字节可设置,高字节,必须同RX_ADDR_P1[39:8]相等;<br />
#define RX_ADDR_P3&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 0x0D&nbsp; //数据通道3接收地址,最低字节可设置,高字节,必须同RX_ADDR_P1[39:8]相等;<br />
#define RX_ADDR_P4&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 0x0E&nbsp; //数据通道4接收地址,最低字节可设置,高字节,必须同RX_ADDR_P1[39:8]相等;<br />
#define RX_ADDR_P5&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 0x0F&nbsp; //数据通道5接收地址,最低字节可设置,高字节,必须同RX_ADDR_P1[39:8]相等;<br />
#define TX_ADDR&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 0x10&nbsp; //发送地址(低字节在前),ShockBurstTM模式下,RX_ADDR_P0与此地址相等<br />
#define RX_PW_P0&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 0x11&nbsp; //接收数据通道0有效数据宽度(1~32字节),设置为0则非法<br />
#define RX_PW_P1&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 0x12&nbsp; //接收数据通道1有效数据宽度(1~32字节),设置为0则非法<br />
#define RX_PW_P2&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 0x13&nbsp; //接收数据通道2有效数据宽度(1~32字节),设置为0则非法<br />
#define RX_PW_P3&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 0x14&nbsp; //接收数据通道3有效数据宽度(1~32字节),设置为0则非法<br />
#define RX_PW_P4&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 0x15&nbsp; //接收数据通道4有效数据宽度(1~32字节),设置为0则非法<br />
#define RX_PW_P5&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 0x16&nbsp; //接收数据通道5有效数据宽度(1~32字节),设置为0则非法<br />
#define FIFO_STATUS&nbsp;&nbsp;&nbsp;&nbsp; 0x17&nbsp; //FIFO状态寄存器;bit0,RX FIFO寄存器空标志;bit1,RX FIFO满标志;bit2,3,保留<br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; //bit4,TX FIFO空标志;bit5,TX FIFO满标志;bit6,1,循环发送上一数据包.0,不循环;<br />
//////////////////////////////////////////////////////////////////////////////////////////////////////////<br />
//24L01操作线<br />
#define NRF24L01_CE_PORT&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; GPIOA<br />
#define NRF24L01_CE_CLK&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; RCC_APB2Periph_GPIOE&nbsp; <br />
#define NRF24L01_CE_PIN&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; GPIO_Pin_4<br />
#define Set_NRF24L01_CE&nbsp; {GPIO_SetBits(NRF24L01_CE_PORT,NRF24L01_CE_PIN);}<br />
#define Clr_NRF24L01_CE&nbsp; {GPIO_ResetBits(NRF24L01_CE_PORT,NRF24L01_CE_PIN);}<br />
//#define NRF24L01_CSN&nbsp; PCout(4) //SPI片选信号&nbsp; <br />
#define NRF24L01_CSN_PORT&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; GPIOC<br />
#define NRF24L01_CSN_CLK&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; RCC_APB2Periph_GPIOC&nbsp; <br />
#define NRF24L01_CSN_PIN&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; GPIO_Pin_4<br />
#define Set_NRF24L01_CSN&nbsp; {GPIO_SetBits(NRF24L01_CSN_PORT,NRF24L01_CSN_PIN);}<br />
#define Clr_NRF24L01_CSN&nbsp; {GPIO_ResetBits(NRF24L01_CSN_PORT,NRF24L01_CSN_PIN);}&nbsp; <br />
//#define NRF24L01_IRQ&nbsp; PCin(5)&nbsp; //IRQ主机数据输入<br />
#define NRF24L01_IRQ_PORT&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; GPIOE<br />
#define NRF24L01_IRQ_CLK&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; RCC_APB2Periph_GPIOE&nbsp; <br />
#define NRF24L01_IRQ_PIN&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; GPIO_Pin_0&nbsp;&nbsp;&nbsp;&nbsp; <br />
#define Set_NRF24L01_IRQ&nbsp; {GPIO_SetBits(NRF24L01_IRQ_PORT,NRF24L01_IRQ_PIN);}<br />
#define Clr_NRF24L01_IRQ&nbsp; {GPIO_ResetBits(NRF24L01_IRQ_PORT,NRF24L01_IRQ_PIN);} <br />
#define NRF24L01_IRQ&nbsp; (GPIO_ReadInputDataBit(NRF24L01_IRQ_PORT, NRF24L01_IRQ_PIN))<br />
//24L01发送接收数据宽度定义<br />
#define TX_ADR_WIDTH&nbsp;&nbsp;&nbsp; 5&nbsp;&nbsp; //5字节的地址宽度<br />
#define RX_ADR_WIDTH&nbsp;&nbsp;&nbsp; 5&nbsp;&nbsp; //5字节的地址宽度<br />
#define TX_PLOAD_WIDTH&nbsp; 32&nbsp; //20字节的用户数据宽度<br />
#define RX_PLOAD_WIDTH&nbsp; 32&nbsp; //20字节的用户数据宽度<br />
<br />
/**************************************main*****************/<br />
main()<br />
{<br />
&nbsp; &nbsp;SPIx_Init();<br />
&nbsp;NRF24L01_Init();</p>
<p>&nbsp; </p>
<p>&nbsp;</p>
<p>&nbsp;while(NRF24L01_Check(i) == 0 )//检测不到24L01<br />
&nbsp;&nbsp;{<br />
&nbsp;&nbsp; GPIO_SetBits(GPIOA, GPIO_Pin_3);//蜂鸣器关闭<br />
&nbsp;&nbsp;&nbsp; Delay_MS(1000);<br />
&nbsp;&nbsp; GPIO_ResetBits(GPIOA, GPIO_Pin_3);//蜂鸣器关闭<br />
<br />
&nbsp;&nbsp; Delay_MS(1000);<br />
&nbsp;&nbsp;} <br />
&nbsp;<br />
&nbsp;&nbsp;TX_Mode();//配置为发送模式 <br />
&nbsp;&nbsp;delay_us(10);<br />
&nbsp;&nbsp;while(1)<br />
&nbsp;&nbsp;{&nbsp;&nbsp; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp;&nbsp; <br />
&nbsp;&nbsp;&nbsp;&nbsp; &nbsp;if(NRF24L01_TxPacket(tmp_buf)==0);<br />
&nbsp;&nbsp;&nbsp;&nbsp;{<br />
&nbsp;&nbsp;&nbsp;&nbsp; GPIO_SetBits(GPIOA, GPIO_Pin_3);<br />
&nbsp;&nbsp;&nbsp; &nbsp; Delay_MS(1000);<br />
&nbsp;&nbsp;&nbsp;&nbsp; GPIO_ResetBits(GPIOA, GPIO_Pin_3);<br />
&nbsp;&nbsp;&nbsp;&nbsp; Delay_MS(1000);<br />
&nbsp;&nbsp;&nbsp;&nbsp;}&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &nbsp;<br />
&nbsp;&nbsp;}<br />
&nbsp;&nbsp;<br />
&nbsp;}<br />
}<br />
这是我根据chinafox修改后的代码在换成Cortex的程序(我用的是SPI的)<br />
在运行的时候检测函数中读取写入的地址读出来的不正确,在发送函数中老是卡在等待发送完成那里,IRQ引脚换过后还是一样<br />
请大神们指导我到底是什么问题<br />
</p>
希望遇到更多有相同兴趣的盆友来一起交流
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165186
金钱
165186
注册时间
2010-12-1
在线时间
2106 小时
发表于 2013-1-13 13:29:11 | 显示全部楼层
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复 支持 反对

使用道具 举报

1

主题

10

帖子

0

精华

新手上路

积分
34
金钱
34
注册时间
2013-1-12
在线时间
0 小时
 楼主| 发表于 2013-1-14 18:40:57 | 显示全部楼层
回复【2楼】正点原子:
<br>---------------------------------
<br>SPI&nbsp;就是从原子哥你发布的代码里拿的&nbsp;没问题啊&nbsp;
<br>void&nbsp;SPIx_Init(void)
<br>{
<br>
<br>        GPIO_InitTypeDef&nbsp;GPIO_InitStructure;
<br>&nbsp;&nbsp;
<br>        RCC_APB2PeriphClockCmd(        RCC_APB2Periph_GPIOA|RCC_APB2Periph_SPI1,&nbsp;ENABLE&nbsp;);       
<br>
<br>        GPIO_InitStructure.GPIO_Pin&nbsp;=&nbsp;GPIO_Pin_5&nbsp;|&nbsp;GPIO_Pin_6&nbsp;|&nbsp;GPIO_Pin_7;
<br>        GPIO_InitStructure.GPIO_Mode&nbsp;=&nbsp;GPIO_Mode_AF_PP;&nbsp;&nbsp;//复用推挽输出
<br>        GPIO_InitStructure.GPIO_Speed&nbsp;=&nbsp;GPIO_Speed_50MHz;
<br>        GPIO_Init(GPIOA,&nbsp;&GPIO_InitStructure);
<br>
<br>        GPIO_SetBits(GPIOA,GPIO_Pin_5|GPIO_Pin_6|GPIO_Pin_7);
<br>
<br>        SPI_InitStructure.SPI_Direction&nbsp;=&nbsp;SPI_Direction_2Lines_FullDuplex;&nbsp;&nbsp;//设置SPI单向或者双向的数据模式:SPI设置为双线双向全双工
<br>        SPI_InitStructure.SPI_Mode&nbsp;=&nbsp;SPI_Mode_Master;                //设置SPI工作模式:设置为主SPI
<br>        SPI_InitStructure.SPI_DataSize&nbsp;=&nbsp;SPI_DataSize_8b;                //设置SPI的数据大小:SPI发送接收8位帧结构
<br>        SPI_InitStructure.SPI_CPOL&nbsp;=&nbsp;SPI_CPOL_Low;                //选择了串行时钟的稳态:时钟悬空低电平
<br>        SPI_InitStructure.SPI_CPHA&nbsp;=&nbsp;SPI_CPHA_1Edge;        //数据捕获于第一个时钟沿
<br>        SPI_InitStructure.SPI_NSS&nbsp;=&nbsp;SPI_NSS_Soft;                //NSS信号由硬件(NSS管脚)还是软件(使用SSI位)管理:内部NSS信号有SSI位控制
<br>        SPI_InitStructure.SPI_BaudRatePrescaler&nbsp;=&nbsp;SPI_BaudRatePrescaler_256;                //定义波特率预分频的值:波特率预分频值为256
<br>        SPI_InitStructure.SPI_FirstBit&nbsp;=&nbsp;SPI_FirstBit_MSB;        //指定数据传输从MSB位还是LSB位开始:数据传输从MSB位开始
<br>        SPI_InitStructure.SPI_CRCPolynomial&nbsp;=&nbsp;7;        //CRC值计算的多项式
<br>        SPI_Init(SPI1,&nbsp;&SPI_InitStructure);&nbsp;&nbsp;//根据SPI_InitStruct中指定的参数初始化外设SPIx寄存器
<br>
<br>        SPI_Cmd(SPI1,&nbsp;ENABLE);&nbsp;//使能SPI外设
<br>       
<br>        SPIx_ReadWriteByte(0xff);//启动传输       
<br>}&nbsp;&nbsp;&nbsp;
<br>//SPI&nbsp;速度设置函数
<br>//SpeedSet:
<br>//SPI_BaudRatePrescaler_2&nbsp;&nbsp;&nbsp;2分频&nbsp;&nbsp;&nbsp;(SPI&nbsp;36M@sys&nbsp;72M)
<br>//SPI_BaudRatePrescaler_8&nbsp;&nbsp;&nbsp;8分频&nbsp;&nbsp;&nbsp;(SPI&nbsp;9M@sys&nbsp;72M)
<br>//SPI_BaudRatePrescaler_16&nbsp;&nbsp;16分频&nbsp;&nbsp;(SPI&nbsp;4.5M@sys&nbsp;72M)
<br>//SPI_BaudRatePrescaler_256&nbsp;256分频&nbsp;(SPI&nbsp;281.25K@sys&nbsp;72M)
<br>
<br>void&nbsp;SPIx_SetSpeed(u8&nbsp;SpeedSet)
<br>{
<br>        SPI_InitStructure.SPI_BaudRatePrescaler&nbsp;=&nbsp;SpeedSet&nbsp;;
<br>&nbsp;&nbsp;        SPI_Init(SPI1,&nbsp;&SPI_InitStructure);
<br>        SPI_Cmd(SPI1,ENABLE);
<br>}&nbsp;
<br>
<br>//SPIx&nbsp;读写一个字节
<br>//TxData:要写入的字节
<br>//返回值:读取到的字节
<br>u8&nbsp;SPIx_ReadWriteByte(u8&nbsp;TxData)
<br>{               
<br>        u8&nbsp;retry=0;                                &nbsp;
<br>        while&nbsp;(SPI_I2S_GetFlagStatus(SPI1,&nbsp;SPI_I2S_FLAG_TXE)&nbsp;==&nbsp;RESET)&nbsp;//检查指定的SPI标志位设置与否:发送缓存空标志位
<br>                {
<br>                retry++;
<br>                if(retry&gt;200)return&nbsp;0;
<br>                }                        &nbsp;&nbsp;
<br>        SPI_I2S_SendData(SPI1,&nbsp;TxData);&nbsp;//通过外设SPIx发送一个数据
<br>        retry=0;
<br>        while&nbsp;(SPI_I2S_GetFlagStatus(SPI1,&nbsp;SPI_I2S_FLAG_RXNE)&nbsp;==&nbsp;RESET);&nbsp;//检查指定的SPI标志位设置与否:接受缓存非空标志位
<br>                {
<br>                retry++;
<br>                if(retry&gt;200)return&nbsp;0;
<br>                }        &nbsp;&nbsp;                                                &nbsp;&nbsp;&nbsp;&nbsp;
<br>        return&nbsp;SPI_I2S_ReceiveData(SPI1);&nbsp;//返回通过SPIx最近接收的数据                                        &nbsp;&nbsp;&nbsp;&nbsp;
<br>}
<br>
希望遇到更多有相同兴趣的盆友来一起交流
回复 支持 反对

使用道具 举报

1

主题

10

帖子

0

精华

新手上路

积分
34
金钱
34
注册时间
2013-1-12
在线时间
0 小时
 楼主| 发表于 2013-1-14 18:43:05 | 显示全部楼层
检测函数在读取写进去的数据后
<br>读出来的数据老是不对啊
<br>这是哪方面的问题啊&nbsp;
希望遇到更多有相同兴趣的盆友来一起交流
回复 支持 反对

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165186
金钱
165186
注册时间
2010-12-1
在线时间
2106 小时
发表于 2013-1-14 23:12:35 | 显示全部楼层
你的实验平台呢?
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复 支持 反对

使用道具 举报

1

主题

10

帖子

0

精华

新手上路

积分
34
金钱
34
注册时间
2013-1-12
在线时间
0 小时
 楼主| 发表于 2013-1-15 12:00:22 | 显示全部楼层
回复【5楼】正点原子:
<br>--------------------------------
<br>Keil&nbsp;uVision4的实验平台
希望遇到更多有相同兴趣的盆友来一起交流
回复 支持 反对

使用道具 举报

1

主题

10

帖子

0

精华

新手上路

积分
34
金钱
34
注册时间
2013-1-12
在线时间
0 小时
 楼主| 发表于 2013-1-15 12:01:56 | 显示全部楼层
板子是Cortex的&nbsp;芯片是STM32F103VC的
<br>
希望遇到更多有相同兴趣的盆友来一起交流
回复 支持 反对

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165186
金钱
165186
注册时间
2010-12-1
在线时间
2106 小时
发表于 2013-1-15 12:42:10 | 显示全部楼层
那就不清楚了,我们的代码都是在我们开发板上通过验证了的。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复 支持 反对

使用道具 举报

1

主题

10

帖子

0

精华

新手上路

积分
34
金钱
34
注册时间
2013-1-12
在线时间
0 小时
 楼主| 发表于 2013-1-15 12:55:53 | 显示全部楼层
算了&nbsp;反正我已经在网上订了一套你们的板子&nbsp;到时候在试试
希望遇到更多有相同兴趣的盆友来一起交流
回复 支持 反对

使用道具 举报

0

主题

3

帖子

0

精华

新手入门

积分
23
金钱
23
注册时间
2014-12-15
在线时间
0 小时
发表于 2014-12-15 13:48:05 | 显示全部楼层
SPIx_ReadWriteByte(0xff);//启动传输
<br>
<br>这句有什么用?去掉吧。
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2024-10-1 12:14

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表