OpenEdv-开源电子网

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

SPI1 配置 24L01问题

[复制链接]

1

主题

5

帖子

0

精华

新手上路

积分
34
金钱
34
注册时间
2014-1-16
在线时间
1 小时
发表于 2014-1-17 00:06:20 | 显示全部楼层 |阅读模式
也是在while(NRF24L01_Check()) 处无法通过 &nbsp; SPI1的设置检测过很多次,感觉没问题....不是用的原子板子,PB,D部分删了<br />
<span class="postbody" id="post_body_155272">SPI1接口的输出只有MOSI&nbsp;&nbsp;是高电平,其他都是低电平,而且</span><span class="postbody" id="post_body_155272"><span class="postbody" id="post_body_155272">MOSI会有周期性低电平脉冲,MISO会有周期性高电平脉冲</span>...</span><br />
<br />
spi.c<br />
<br />
void SPI1_Init(void)<br />
{<br />
&nbsp;&nbsp;&nbsp;&nbsp; GPIO_InitTypeDef GPIO_InitStructure;<br />
&nbsp; &nbsp;&nbsp;&nbsp; SPI_InitTypeDef&nbsp; SPI_InitStructure;<br />
&nbsp;&nbsp;&nbsp; RCC_APB2PeriphClockCmd(&nbsp;&nbsp;&nbsp; RCC_APB2Periph_GPIOA, ENABLE );//PORTB时钟使能 <br />
&nbsp;&nbsp;&nbsp; RCC_APB2PeriphClockCmd(&nbsp;&nbsp;&nbsp; RCC_APB2Periph_AFIO, ENABLE );<br />
&nbsp;&nbsp;&nbsp; RCC_APB2PeriphClockCmd(&nbsp;&nbsp;&nbsp; RCC_APB2Periph_SPI1,&nbsp; ENABLE );//SPI1时钟使能 &nbsp;&nbsp;&nbsp; <br />
&nbsp;<br />
&nbsp;&nbsp;&nbsp; GPIO_InitStructure.GPIO_Pin = GPIO_Pin_5 | GPIO_Pin_6 | GPIO_Pin_7 ;<br />
&nbsp;&nbsp;&nbsp; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;&nbsp; //PB13/14/15复用推挽输出 <br />
&nbsp;&nbsp;&nbsp; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;<br />
&nbsp;&nbsp;&nbsp; GPIO_Init(GPIOA, &amp;GPIO_InitStructure);//初始化GPIOB<br />
<br />
&nbsp;&nbsp;&nbsp; GPIO_SetBits(GPIOA,GPIO_Pin_5 | GPIO_Pin_6 | GPIO_Pin_7);&nbsp; //PB13/14/15上拉<br />
<br />
&nbsp;&nbsp;&nbsp; SPI_InitStructure.SPI_Direction = SPI_Direction_2Lines_FullDuplex;&nbsp; //设置SPI单向或者双向的数据模式:SPI设置为双线双向全双工<br />
&nbsp;&nbsp;&nbsp; SPI_InitStructure.SPI_Mode = SPI_Mode_Master;&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; //设置SPI工作模式:设置为主SPI<br />
&nbsp;&nbsp;&nbsp; SPI_InitStructure.SPI_DataSize = SPI_DataSize_8b;&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; //设置SPI的数据大小:SPI发送接收8位帧结构<br />
&nbsp;&nbsp;&nbsp; SPI_InitStructure.SPI_CPOL = SPI_CPOL_High;&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; //串行同步时钟的空闲状态为高电平<br />
&nbsp;&nbsp;&nbsp; SPI_InitStructure.SPI_CPHA = SPI_CPHA_2Edge;&nbsp;&nbsp;&nbsp; //串行同步时钟的第二个跳变沿(上升或下降)数据被采样<br />
&nbsp;&nbsp;&nbsp; SPI_InitStructure.SPI_NSS = SPI_NSS_Soft;&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; //NSS信号由硬件(NSS管脚)还是软件(使用SSI位)管理:内部NSS信号有SSI位控制<br />
&nbsp;&nbsp;&nbsp; SPI_InitStructure.SPI_BaudRatePrescaler = SPI_BaudRatePrescaler_256;&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; //定义波特率预分频的值:波特率预分频值为256<br />
&nbsp;&nbsp;&nbsp; SPI_InitStructure.SPI_FirstBit = SPI_FirstBit_MSB;&nbsp;&nbsp;&nbsp; //指定数据传输从MSB位还是LSB位开始:数据传输从MSB位开始<br />
&nbsp;&nbsp;&nbsp; SPI_InitStructure.SPI_CRCPolynomial = 7;&nbsp;&nbsp;&nbsp; //CRC值计算的多项式<br />
&nbsp;&nbsp;&nbsp; SPI_Init(SPI1, &amp;SPI_InitStructure);&nbsp; //根据SPI_InitStruct中指定的参数初始化外设SPIx寄存器<br />
&nbsp; <br />
&nbsp;&nbsp;&nbsp; SPI_Cmd(SPI1, ENABLE); //使能SPI外设<br />
&nbsp;&nbsp;&nbsp; <br />
&nbsp;&nbsp;&nbsp; SPI1_ReadWriteByte(0xff);//启动传输&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;<br />
&nbsp;<br />
<br />
}&nbsp;&nbsp; <br />
//SPI 速度设置函数<br />
//SpeedSet:<br />
//SPI_BaudRatePrescaler_2&nbsp;&nbsp; 2分频&nbsp;&nbsp; <br />
//SPI_BaudRatePrescaler_8&nbsp;&nbsp; 8分频&nbsp;&nbsp; <br />
//SPI_BaudRatePrescaler_16&nbsp; 16分频&nbsp; <br />
//SPI_BaudRatePrescaler_256 256分频 <br />
&nbsp; <br />
void SPI1_SetSpeed(u8 SPI_BaudRatePrescaler)<br />
{<br />
&nbsp; &nbsp;&nbsp;&nbsp; assert_param(IS_SPI_BAUDRATE_PRESCALER(SPI_BaudRatePrescaler));<br />
&nbsp;&nbsp;&nbsp; SPI1-&gt;CR1&amp;=0XFFC7;<br />
&nbsp;&nbsp;&nbsp; SPI1-&gt;CR1|=SPI_BaudRatePrescaler;&nbsp;&nbsp;&nbsp; //设置SPI2速度 <br />
&nbsp;&nbsp;&nbsp; SPI_Cmd(SPI1,ENABLE); <br />
<br />
} <br />
<br />
//SPIx 读写一个字节<br />
//TxData:要写入的字节<br />
//返回值:读取到的字节<br />
u8 SPI1_ReadWriteByte(u8 TxData)<br />
{&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; <br />
&nbsp;&nbsp;&nbsp; u8 retry=0;&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp;&nbsp; <br />
&nbsp;&nbsp;&nbsp; while (SPI_I2S_GetFlagStatus(SPI1, SPI_I2S_FLAG_TXE) == RESET) //检查指定的SPI标志位设置与否:发送缓存空标志位<br />
&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; {<br />
&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; retry++;<br />
&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; if(retry&gt;200)return 0;<br />
&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; }&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp; <br />
&nbsp;&nbsp;&nbsp; SPI_I2S_SendData(SPI1, TxData); //通过外设SPIx发送一个数据<br />
&nbsp;&nbsp;&nbsp; retry=0;<br />
<br />
&nbsp;&nbsp;&nbsp; while (SPI_I2S_GetFlagStatus(SPI1, SPI_I2S_FLAG_RXNE) == RESET)//检查指定的SPI标志位设置与否:接受缓存非空标志位<br />
&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; {<br />
&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; retry++;<br />
&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; if(retry&gt;200)return 0;<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;&nbsp;&nbsp; <br />
&nbsp;&nbsp;&nbsp; return SPI_I2S_ReceiveData(SPI1); //返回通过SPIx最近接收的数据&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; <br />
}<br />
<br />
<br />
NRF24L01.c<br />
&nbsp;&nbsp;&nbsp; <br />
<br />
const u8 TX_ADDRESS[TX_ADR_WIDTH]={0x34,0x43,0x10,0x10,0x01}; //发送地址<br />
const u8 RX_ADDRESS[RX_ADR_WIDTH]={0x34,0x43,0x10,0x10,0x01}; //发送地址<br />
<br />
//初始化24L01的IO口<br />
void NRF24L01_Init(void)<br />
{ &nbsp;&nbsp;&nbsp; <br />
&nbsp;&nbsp;&nbsp; GPIO_InitTypeDef GPIO_InitStructure;<br />
&nbsp; &nbsp;&nbsp;&nbsp; SPI_InitTypeDef&nbsp; SPI_InitStructure;<br />
<br />
&nbsp;&nbsp;&nbsp; RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC, ENABLE);&nbsp;&nbsp;&nbsp; &nbsp;//使能PB,D,G端口时钟<br />
&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; <br />
<br />
&nbsp;&nbsp;&nbsp; GPIO_InitStructure.GPIO_Pin = GPIO_Pin_1|GPIO_Pin_2;&nbsp;&nbsp;&nbsp; //PG6 7 推挽<br />
&nbsp;&nbsp;&nbsp; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;//推挽输出<br />
&nbsp;&nbsp;&nbsp;&nbsp; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;<br />
&nbsp;&nbsp;&nbsp;&nbsp; GPIO_Init(GPIOC, &amp;GPIO_InitStructure);//初始化指定IO<br />
&nbsp; <br />
&nbsp;&nbsp;&nbsp; GPIO_InitStructure.GPIO_Pin&nbsp; = GPIO_Pin_3;&nbsp;&nbsp; <br />
&nbsp;&nbsp;&nbsp; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPD; //PG8 输入&nbsp; <br />
&nbsp;&nbsp;&nbsp; GPIO_Init(GPIOC, &amp;GPIO_InitStructure);<br />
<br />
&nbsp;&nbsp;&nbsp; GPIO_ResetBits(GPIOC,GPIO_Pin_1|GPIO_Pin_2|GPIO_Pin_3);//PG6,7,8上拉&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;<br />
&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;<br />
&nbsp;&nbsp;&nbsp; SPI1_Init();&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; //初始化SPI&nbsp;&nbsp;&nbsp; &nbsp;<br />
&nbsp;<br />
&nbsp;&nbsp;&nbsp; SPI_Cmd(SPI1, DISABLE); // SPI外设不使能<br />
<br />
&nbsp;&nbsp;&nbsp; SPI_InitStructure.SPI_Direction = SPI_Direction_2Lines_FullDuplex;&nbsp; //SPI设置为双线双向全双工<br />
&nbsp;&nbsp;&nbsp; SPI_InitStructure.SPI_Mode = SPI_Mode_Master;&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; //SPI主机<br />
&nbsp;&nbsp;&nbsp; SPI_InitStructure.SPI_DataSize = SPI_DataSize_8b;&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; //发送接收8位帧结构<br />
&nbsp;&nbsp;&nbsp; SPI_InitStructure.SPI_CPOL = SPI_CPOL_Low;&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; //时钟悬空低<br />
&nbsp;&nbsp;&nbsp; SPI_InitStructure.SPI_CPHA = SPI_CPHA_1Edge;&nbsp;&nbsp;&nbsp; //数据捕获于第1个时钟沿<br />
&nbsp;&nbsp;&nbsp; SPI_InitStructure.SPI_NSS = SPI_NSS_Soft;&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; //NSS信号由软件控制<br />
&nbsp;&nbsp;&nbsp; SPI_InitStructure.SPI_BaudRatePrescaler = SPI_BaudRatePrescaler_8;&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; //定义波特率预分频的值:波特率预分频值为16<br />
&nbsp;&nbsp;&nbsp; SPI_InitStructure.SPI_FirstBit = SPI_FirstBit_MSB;&nbsp;&nbsp;&nbsp; //数据传输从MSB位开始<br />
&nbsp;&nbsp;&nbsp; SPI_InitStructure.SPI_CRCPolynomial = 7;&nbsp;&nbsp;&nbsp; //CRC值计算的多项式<br />
&nbsp;&nbsp;&nbsp; SPI_Init(SPI1, &amp;SPI_InitStructure);&nbsp; //根据SPI_InitStruct中指定的参数初始化外设SPIx寄存器<br />
&nbsp;// SPI_NSSInternalSoftwareConfig(SPI1, SPI_NSSInternalSoft_Set);<br />
&nbsp;&nbsp;&nbsp; SPI_Cmd(SPI1, ENABLE); //使能SPI外设<br />
&nbsp;&nbsp;&nbsp; <br />
<br />
<br />
&nbsp;&nbsp;&nbsp; NRF24L01_CE=0; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; //使能24L01<br />
&nbsp;&nbsp;&nbsp; NRF24L01_CSN=1;&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; //SPI片选取消&nbsp; <br />
&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp;&nbsp; &nbsp;<br />
}<br />
//检测24L01是否存在<br />
//返回值:0,成功;1,失败&nbsp;&nbsp;&nbsp; <br />
u8 NRF24L01_Check(void)<br />
{<br />
&nbsp;&nbsp;&nbsp; u8 buf[5]={0XA5,0XA5,0XA5,0XA5,0XA5};<br />
&nbsp;&nbsp;&nbsp; u8 i;<br />
&nbsp;&nbsp;&nbsp; SPI1_SetSpeed(SPI_BaudRatePrescaler_4); //spi速度为9Mhz(24L01的最大SPI时钟为10Mhz)&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;<br />
&nbsp;&nbsp;&nbsp; NRF24L01_Write_Buf(WRITE_REG_NRF+TX_ADDR,buf,5);//写入5个字节的地址.&nbsp;&nbsp;&nbsp; <br />
&nbsp;&nbsp;&nbsp; NRF24L01_Read_Buf(TX_ADDR,buf,5); //读出写入的地址&nbsp; <br />
&nbsp;&nbsp;&nbsp; for(i=0;i&lt;5;i++)if(buf!=0XA5)break;&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; <br />
&nbsp;&nbsp;&nbsp; if(i!=5)return 1;//检测24L01错误&nbsp;&nbsp;&nbsp; <br />
&nbsp;&nbsp;&nbsp; return 0;&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;//检测到24L01<br />
}&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp;&nbsp; &nbsp;<br />
//SPI写寄存器<br />
//reg:指定寄存器地址<br />
//value:写入的值<br />
u8 NRF24L01_Write_Reg(u8 reg,u8 value)<br />
{<br />
&nbsp;&nbsp;&nbsp; u8 status;&nbsp;&nbsp;&nbsp; <br />
&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; NRF24L01_CSN=0;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; //使能SPI传输<br />
&nbsp; &nbsp;&nbsp;&nbsp; status =SPI1_ReadWriteByte(reg);//发送寄存器号 <br />
&nbsp; &nbsp;&nbsp;&nbsp; SPI1_ReadWriteByte(value);&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; //写入寄存器的值<br />
&nbsp; &nbsp;&nbsp;&nbsp; NRF24L01_CSN=1;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; //禁止SPI传输&nbsp;&nbsp;&nbsp; &nbsp;&nbsp; <br />
&nbsp; &nbsp;&nbsp;&nbsp; return(status);&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; //返回状态值<br />
}<br />
//读取SPI寄存器值<br />
//reg:要读的寄存器<br />
u8 NRF24L01_Read_Reg(u8 reg)<br />
{<br />
&nbsp;&nbsp;&nbsp; u8 reg_val;&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; <br />
&nbsp;&nbsp;&nbsp;&nbsp; NRF24L01_CSN = 0;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; //使能SPI传输&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; <br />
&nbsp; &nbsp;&nbsp;&nbsp; SPI1_ReadWriteByte(reg);&nbsp;&nbsp; //发送寄存器号<br />
&nbsp; &nbsp;&nbsp;&nbsp; reg_val=SPI1_ReadWriteByte(0XFF);//读取寄存器内容<br />
&nbsp; &nbsp;&nbsp;&nbsp; NRF24L01_CSN = 1;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; //禁止SPI传输&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; <br />
&nbsp; &nbsp;&nbsp;&nbsp; return(reg_val);&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; //返回状态值<br />
}&nbsp;&nbsp;&nbsp; <br />
//在指定位置读出指定长度的数据<br />
//reg:寄存器(位置)<br />
//*pBuf:数据指针<br />
//len:数据长度<br />
//返回值,此次读到的状态寄存器值 <br />
u8 NRF24L01_Read_Buf(u8 reg,u8 *pBuf,u8 len)<br />
{<br />
&nbsp;&nbsp;&nbsp; u8 status,u8_ctr;&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <br />
&nbsp; &nbsp;&nbsp;&nbsp; NRF24L01_CSN = 0;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; //使能SPI传输<br />
&nbsp; &nbsp;&nbsp;&nbsp; status=SPI1_ReadWriteByte(reg);//发送寄存器值(位置),并读取状态值&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp; <br />
&nbsp;&nbsp;&nbsp;&nbsp; for(u8_ctr=0;u8_ctr&lt;len;u8_ctr++)pBuf[u8_ctr]=SPI1_ReadWriteByte(0XFF);//读出数据<br />
&nbsp; &nbsp;&nbsp;&nbsp; NRF24L01_CSN=1;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; //关闭SPI传输<br />
&nbsp; &nbsp;&nbsp;&nbsp; return status;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; //返回读到的状态值<br />
}<br />
//在指定位置写指定长度的数据<br />
//reg:寄存器(位置)<br />
//*pBuf:数据指针<br />
//len:数据长度<br />
//返回值,此次读到的状态寄存器值<br />
u8 NRF24L01_Write_Buf(u8 reg, u8 *pBuf, u8 len)<br />
{<br />
&nbsp;&nbsp;&nbsp; u8 status,u8_ctr;&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; <br />
&nbsp;&nbsp;&nbsp;&nbsp; NRF24L01_CSN = 0;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; //使能SPI传输<br />
&nbsp; &nbsp;&nbsp;&nbsp; status = SPI1_ReadWriteByte(reg);//发送寄存器值(位置),并读取状态值<br />
&nbsp; &nbsp;&nbsp;&nbsp; for(u8_ctr=0; u8_ctr&lt;len; u8_ctr++)SPI1_ReadWriteByte(*pBuf++); //写入数据&nbsp;&nbsp;&nbsp; &nbsp;<br />
&nbsp; &nbsp;&nbsp;&nbsp; NRF24L01_CSN = 1;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; //关闭SPI传输<br />
&nbsp; &nbsp;&nbsp;&nbsp; return status;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; //返回读到的状态值<br />
}&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp; <br />
//启动NRF24L01发送一次数据<br />
//txbuf:待发送数据首地址<br />
//返回值:发送完成状况<br />
u8 NRF24L01_TxPacket(u8 *txbuf)<br />
{<br />
&nbsp;&nbsp;&nbsp; u8 sta;<br />
&nbsp;&nbsp;&nbsp;&nbsp; SPI1_SetSpeed(SPI_BaudRatePrescaler_8);//spi速度为9Mhz(24L01的最大SPI时钟为10Mhz)&nbsp;&nbsp; <br />
&nbsp;&nbsp;&nbsp; NRF24L01_CE=0;<br />
&nbsp; &nbsp;&nbsp;&nbsp; NRF24L01_Write_Buf(WR_TX_PLOAD,txbuf,TX_PLOAD_WIDTH);//写数据到TX BUF&nbsp; 32个字节<br />
&nbsp;&nbsp;&nbsp;&nbsp; NRF24L01_CE=1;//启动发送&nbsp;&nbsp;&nbsp; &nbsp;&nbsp; <br />
&nbsp;&nbsp;&nbsp; while(NRF24L01_IRQ!=0);//等待发送完成<br />
&nbsp;&nbsp;&nbsp; sta=NRF24L01_Read_Reg(STATUS);&nbsp; //读取状态寄存器的值&nbsp;&nbsp;&nbsp; &nbsp;&nbsp; <br />
&nbsp;&nbsp;&nbsp; NRF24L01_Write_Reg(WRITE_REG_NRF+STATUS,sta); //清除TX_DS或MAX_RT中断标志<br />
&nbsp;&nbsp;&nbsp; if(sta&amp;MAX_TX)//达到最大重发次数<br />
&nbsp;&nbsp;&nbsp; {<br />
&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; NRF24L01_Write_Reg(FLUSH_TX,0xff);//清除TX FIFO寄存器 <br />
&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; return MAX_TX; <br />
&nbsp;&nbsp;&nbsp; }<br />
&nbsp;&nbsp;&nbsp; if(sta&amp;TX_OK)//发送完成<br />
&nbsp;&nbsp;&nbsp; {<br />
&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; return TX_OK;<br />
&nbsp;&nbsp;&nbsp; }<br />
&nbsp;&nbsp;&nbsp; return 0xff;//其他原因发送失败<br />
}<br />
//启动NRF24L01发送一次数据<br />
//txbuf:待发送数据首地址<br />
//返回值:0,接收完成;其他,错误代码<br />
u8 NRF24L01_RxPacket(u8 *rxbuf)<br />
{<br />
&nbsp;&nbsp;&nbsp; u8 sta;&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;&nbsp; &nbsp;&nbsp; <br />
&nbsp;&nbsp;&nbsp; SPI1_SetSpeed(SPI_BaudRatePrescaler_8); //spi速度为9Mhz(24L01的最大SPI时钟为10Mhz)&nbsp;&nbsp; <br />
&nbsp;&nbsp;&nbsp; sta=NRF24L01_Read_Reg(STATUS);&nbsp; //读取状态寄存器的值&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;<br />
&nbsp;&nbsp;&nbsp; NRF24L01_Write_Reg(WRITE_REG_NRF+STATUS,sta); //清除TX_DS或MAX_RT中断标志<br />
&nbsp;&nbsp;&nbsp; if(sta&amp;RX_OK)//接收到数据<br />
&nbsp;&nbsp;&nbsp; {<br />
&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; NRF24L01_Read_Buf(RD_RX_PLOAD,rxbuf,RX_PLOAD_WIDTH);//读取数据<br />
&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; NRF24L01_Write_Reg(FLUSH_RX,0xff);//清除RX FIFO寄存器 <br />
&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; return 0; <br />
&nbsp;&nbsp;&nbsp; }&nbsp;&nbsp;&nbsp; &nbsp;&nbsp; <br />
&nbsp;&nbsp;&nbsp; return 1;//没收到任何数据<br />
}&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; <br />
//该函数初始化NRF24L01到RX模式<br />
//设置RX地址,写RX数据宽度,选择RF频道,波特率和LNA HCURR<br />
//当CE变高后,即进入RX模式,并可以接收数据了&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp; <br />
void NRF24L01_RX_Mode(void)<br />
{<br />
&nbsp;&nbsp;&nbsp; NRF24L01_CE=0;&nbsp;&nbsp;&nbsp; &nbsp; <br />
&nbsp; &nbsp;&nbsp;&nbsp; NRF24L01_Write_Buf(WRITE_REG_NRF+RX_ADDR_P0,(u8*)RX_ADDRESS,RX_ADR_WIDTH);//写RX节点地址<br />
&nbsp;&nbsp;&nbsp; &nbsp; <br />
&nbsp; &nbsp;&nbsp;&nbsp; NRF24L01_Write_Reg(WRITE_REG_NRF+EN_AA,0x01);&nbsp;&nbsp;&nbsp; //使能通道0的自动应答&nbsp;&nbsp;&nbsp; <br />
&nbsp; &nbsp;&nbsp;&nbsp; NRF24L01_Write_Reg(WRITE_REG_NRF+EN_RXADDR,0x01);//使能通道0的接收地址&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;<br />
&nbsp; &nbsp;&nbsp;&nbsp; NRF24L01_Write_Reg(WRITE_REG_NRF+RF_CH,40);&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp;&nbsp; //设置RF通信频率&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp; <br />
&nbsp; &nbsp;&nbsp;&nbsp; NRF24L01_Write_Reg(WRITE_REG_NRF+RX_PW_P0,RX_PLOAD_WIDTH);//选择通道0的有效数据宽度 &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; <br />
&nbsp; &nbsp;&nbsp;&nbsp; NRF24L01_Write_Reg(WRITE_REG_NRF+RF_SETUP,0x0f);//设置TX发射参数,0db增益,2Mbps,低噪声增益开启&nbsp;&nbsp; <br />
&nbsp; &nbsp;&nbsp;&nbsp; NRF24L01_Write_Reg(WRITE_REG_NRF+CONFIG, 0x0f);//配置基本工作模式的参数WR_UP,EN_CRC,16BIT_CRC,接收模式 <br />
&nbsp; &nbsp;&nbsp;&nbsp; NRF24L01_CE = 1; //CE为高,进入接收模式 <br />
}&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &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;&nbsp;&nbsp; &nbsp;&nbsp; <br />
//CE为高大于10us,则启动发送.&nbsp;&nbsp;&nbsp; &nbsp;<br />
void NRF24L01_TX_Mode(void)<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;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;<br />
&nbsp;&nbsp;&nbsp; NRF24L01_CE=0;&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; <br />
&nbsp; &nbsp;&nbsp;&nbsp; NRF24L01_Write_Buf(WRITE_REG_NRF+TX_ADDR,(u8*)TX_ADDRESS,TX_ADR_WIDTH);//写TX节点地址 <br />
&nbsp; &nbsp;&nbsp;&nbsp; NRF24L01_Write_Buf(WRITE_REG_NRF+RX_ADDR_P0,(u8*)RX_ADDRESS,RX_ADR_WIDTH); //设置TX节点地址,主要为了使能ACK&nbsp;&nbsp;&nbsp; &nbsp; <br />
<br />
&nbsp; &nbsp;&nbsp;&nbsp; NRF24L01_Write_Reg(WRITE_REG_NRF+EN_AA,0x01);&nbsp;&nbsp;&nbsp;&nbsp; //使能通道0的自动应答&nbsp;&nbsp;&nbsp; <br />
&nbsp; &nbsp;&nbsp;&nbsp; NRF24L01_Write_Reg(WRITE_REG_NRF+EN_RXADDR,0x01); //使能通道0的接收地址&nbsp; <br />
&nbsp; &nbsp;&nbsp;&nbsp; NRF24L01_Write_Reg(WRITE_REG_NRF+SETUP_RETR,0x1a);//设置自动重发间隔时间:500us + 86us;最大自动重发次数:10次<br />
&nbsp; &nbsp;&nbsp;&nbsp; NRF24L01_Write_Reg(WRITE_REG_NRF+RF_CH,40);&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; //设置RF通道为40<br />
&nbsp; &nbsp;&nbsp;&nbsp; NRF24L01_Write_Reg(WRITE_REG_NRF+RF_SETUP,0x0f);&nbsp; //设置TX发射参数,0db增益,2Mbps,低噪声增益开启&nbsp;&nbsp; <br />
&nbsp; &nbsp;&nbsp;&nbsp; NRF24L01_Write_Reg(WRITE_REG_NRF+CONFIG,0x0e);&nbsp;&nbsp;&nbsp; //配置基本工作模式的参数WR_UP,EN_CRC,16BIT_CRC,接收模式,开启所有中断<br />
&nbsp;&nbsp;&nbsp; NRF24L01_CE=1;//CE为高,10us后启动发送<br />
}&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp; <br />
<br />
<br />
<br />
<br />
<br />
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

120

主题

7877

帖子

13

精华

资深版主

Rank: 8Rank: 8

积分
12010
金钱
12010
注册时间
2013-9-10
在线时间
427 小时
发表于 2014-1-17 08:14:50 | 显示全部楼层
看着没什么问题,jtag跟踪调试一下看下到哪里导致出问题的
现在,程序把烂铜烂铁变得智能化了,人呢,一旦离开了这烂铜烂铁就不知道干啥了
回复 支持 反对

使用道具 举报

17

主题

470

帖子

1

精华

高级会员

Rank: 4

积分
718
金钱
718
注册时间
2013-11-23
在线时间
0 小时
发表于 2014-1-17 13:20:43 | 显示全部楼层
读楼主的代码读到蛋疼,到处是SPI2初始化的“壳”,实际是在配置SPI1。SPI1配置应该没问题,硬件就位没有?
回复 支持 反对

使用道具 举报

4

主题

22

帖子

0

精华

初级会员

Rank: 2

积分
59
金钱
59
注册时间
2014-1-17
在线时间
0 小时
发表于 2014-1-17 14:56:57 | 显示全部楼层
回复【楼主位】95001933:
<br>---------------------------------
<br>你应该先测试一下STM32的SPI1输出是不是正常的!
回复 支持 反对

使用道具 举报

4

主题

22

帖子

0

精华

初级会员

Rank: 2

积分
59
金钱
59
注册时间
2014-1-17
在线时间
0 小时
发表于 2014-1-17 15:05:44 | 显示全部楼层
回复【楼主位】95001933:
<br>---------------------------------
<br>在“void&nbsp;SPI2_Init(void)”函数的结尾测试:
<br>while(1)
<br>{
<br>&nbsp;&nbsp;&nbsp;&nbsp;SPI2_ReadWriteByte(0xff);//启动传输&nbsp;
<br>}
<br>查看PA5时钟输出是不是正常的,还有PA7(MOSI)输出是不是正常的
回复 支持 反对

使用道具 举报

1

主题

5

帖子

0

精华

新手上路

积分
34
金钱
34
注册时间
2014-1-16
在线时间
1 小时
 楼主| 发表于 2014-1-17 23:47:43 | 显示全部楼层
回复【4楼】open_llw:
<br>---------------------------------
<br>你好,SPI1接口的输出只有MOSI&nbsp;&nbsp;是高电平,其他都是低电平...
回复 支持 反对

使用道具 举报

1

主题

5

帖子

0

精华

新手上路

积分
34
金钱
34
注册时间
2014-1-16
在线时间
1 小时
 楼主| 发表于 2014-1-17 23:49:47 | 显示全部楼层
回复【4楼】open_llw:
<br>---------------------------------
<br>而且MOSI会有周期性低电平脉冲
回复 支持 反对

使用道具 举报

1

主题

5

帖子

0

精华

新手上路

积分
34
金钱
34
注册时间
2014-1-16
在线时间
1 小时
 楼主| 发表于 2014-1-17 23:53:13 | 显示全部楼层
MISO会有周期性高电平脉冲
回复 支持 反对

使用道具 举报

1

主题

5

帖子

0

精华

新手上路

积分
34
金钱
34
注册时间
2014-1-16
在线时间
1 小时
 楼主| 发表于 2014-1-17 23:54:18 | 显示全部楼层
回复【5楼】open_llw:
<br>---------------------------------
<br>谢谢你的回复,我刚刚看了
<br>SPI1接口的输出只有MOSI&nbsp;&nbsp;是高电平,其他都是低电平,而且MOSI会有周期性低电平脉冲,MISO会有周期性高电平脉冲...
回复 支持 反对

使用道具 举报

4

主题

22

帖子

0

精华

初级会员

Rank: 2

积分
59
金钱
59
注册时间
2014-1-17
在线时间
0 小时
发表于 2014-1-19 15:40:31 | 显示全部楼层
回复【楼主位】95001933:
<br>---------------------------------
<br>唉,你的MISO配置成了推挽复用输出,你要STM32怎样帮你读数据啊。
<br>那个PA6(MISO)应该配置成浮空输入或者是上拉输入的
回复 支持 反对

使用道具 举报

4

主题

22

帖子

0

精华

初级会员

Rank: 2

积分
59
金钱
59
注册时间
2014-1-17
在线时间
0 小时
发表于 2014-1-19 15:42:19 | 显示全部楼层
回复【楼主位】95001933:
<br>---------------------------------
<br>&nbsp;GPIO_SetBits(GPIOA,GPIO_Pin_5&nbsp;|&nbsp;GPIO_Pin_6&nbsp;|&nbsp;GPIO_Pin_7);&nbsp;
<br>这句话有必要的吗?我看了原子的代码都有这个,可是我不用也可以啊??求指教
回复 支持 反对

使用道具 举报

13

主题

225

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
289
金钱
289
注册时间
2013-11-12
在线时间
29 小时
发表于 2014-7-7 17:13:03 | 显示全部楼层
回复【10楼】open_llw:
<br>---------------------------------回复【10楼】open_llw:
<br>---------------------------------
<br>你好,我发现很多例程都是这样设置的给,这样到底行不行啊!
<br>还有就是我的也是像这样平配置的,但是spi的时钟都没有输出给,这个是怎么回事啊?
回复 支持 反对

使用道具 举报

13

主题

225

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
289
金钱
289
注册时间
2013-11-12
在线时间
29 小时
发表于 2014-7-7 17:14:26 | 显示全部楼层
回复【3楼】hechao3225:
<br>---------------------------------
<br>
<br>你好,我也是这样配置的给,但是连输出都没有,你说的硬件就位是没事意思啊?
回复 支持 反对

使用道具 举报

4

主题

50

帖子

0

精华

初级会员

Rank: 2

积分
99
金钱
99
注册时间
2014-5-30
在线时间
4 小时
发表于 2015-7-29 22:05:21 | 显示全部楼层
我也是这个没有调通啊,,&nbsp;一天了,,&nbsp;蛋疼,,,
也许似乎大概是,然而未必不见得。
回复 支持 反对

使用道具 举报

1

主题

5

帖子

0

精华

新手上路

积分
29
金钱
29
注册时间
2015-11-2
在线时间
0 小时
发表于 2015-11-24 22:18:51 | 显示全部楼层
我也是把例程的改成SPI1的,也调不通,用的ENC28J60网络模块,求大神啊
回复 支持 反对

使用道具 举报

7

主题

24

帖子

0

精华

初级会员

Rank: 2

积分
82
金钱
82
注册时间
2014-11-9
在线时间
6 小时
发表于 2015-12-7 13:34:38 | 显示全部楼层
请问大家现在调通了吗
回复 支持 反对

使用道具 举报

55

主题

474

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
2374
金钱
2374
注册时间
2017-8-7
在线时间
207 小时
发表于 2017-10-29 00:30:08 | 显示全部楼层
2017-10-29-00:27 刚刚遇到这个问题,百度了一下到这个帖子,尝试了帖子红一位层主的方式,把MISO换成了浮空输入,即PA6改成GPIO_Mode_IN_FLOATING,就ok啦附上SPI1 init()的代码;;;;void SPI1_Init(void)
{
        GPIO_InitTypeDef GPIO_InitStructure;
          SPI_InitTypeDef  SPI_InitStructure;

        RCC_APB2PeriphClockCmd(        RCC_APB2Periph_GPIOA|RCC_APB2Periph_SPI1, ENABLE );//PORTBê±&#214;óê1&#196;ü    SPI1 ê&#199;&#196;ü
//        RCC_APB1PeriphClockCmd(        RCC_APB2Periph_SPI1,  ENABLE );//SPI2ê±&#214;óê1&#196;ü        

        GPIO_InitStructure.GPIO_Pin = GPIO_Pin_5  | GPIO_Pin_7;
        GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;  //PB13/14/15&#184;′ó&#195;í&#198;íìê&#228;3&#246;
        GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
        GPIO_Init(GPIOA, &GPIO_InitStructure);//3&#245;ê&#188;&#187;ˉGPIOB
       
  GPIO_InitStructure.GPIO_Pin =  GPIO_Pin_6 ;
        GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;  //PB13/14/15&#184;′ó&#195;í&#198;íìê&#228;3&#246;
        GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
        GPIO_Init(GPIOA, &GPIO_InitStructure);//3&#245;ê&#188;&#187;ˉGPIOB
       
        GPIO_SetBits(GPIOA,GPIO_Pin_5|GPIO_Pin_6|GPIO_Pin_7);  //PB13/14/15é&#207;à-

        SPI_InitStructure.SPI_Direction = SPI_Direction_2Lines_FullDuplex;  //éè&#214;&#195;SPIμ¥&#207;ò&#187;ò&#213;&#223;&#203;&#171;&#207;òμ&#196;êy&#190;Y&#196;£ê&#189;:SPIéè&#214;&#195;&#206;a&#203;&#171;&#207;&#223;&#203;&#171;&#207;òè&#171;&#203;&#171;1¤
        SPI_InitStructure.SPI_Mode = SPI_Mode_Master;                //éè&#214;&#195;SPI1¤×÷&#196;£ê&#189;:éè&#214;&#195;&#206;a&#214;÷SPI
        SPI_InitStructure.SPI_DataSize = SPI_DataSize_8b;                //éè&#214;&#195;SPIμ&#196;êy&#190;Y′óD&#161;:SPI·¢&#203;í&#189;óê&#213;8&#206;&#187;&#214;&#161;&#189;á11
        SPI_InitStructure.SPI_CPOL = SPI_CPOL_High;                //′&#174;DDí&#172;2&#189;ê±&#214;óμ&#196;&#191;&#213;&#207;D×′ì&#172;&#206;a&#184;&#223;μ&#231;&#198;&#189;
        SPI_InitStructure.SPI_CPHA = SPI_CPHA_2Edge;        //′&#174;DDí&#172;2&#189;ê±&#214;óμ&#196;μú&#182;t&#184;&#246;ì&#248;±&#228;&#209;&#216;£¨é&#207;éy&#187;ò&#207;&#194;&#189;μ£&#169;êy&#190;Y±&#187;2é&#209;ù
        SPI_InitStructure.SPI_NSS = SPI_NSS_Soft;                //NSSD&#197;o&#197;óéó2&#188;t£¨NSS1ü&#189;&#197;£&#169;&#187;1ê&#199;èí&#188;t£¨ê1ó&#195;SSI&#206;&#187;£&#169;1üàí:&#196;ú2&#191;NSSD&#197;o&#197;óDSSI&#206;&#187;&#191;&#216;&#214;&#198;
        SPI_InitStructure.SPI_BaudRatePrescaler = SPI_BaudRatePrescaler_256;                //&#182;¨ò&#229;2¨ì&#216;&#194;ê&#212;¤·&#214;&#198;μμ&#196;&#214;μ:2¨ì&#216;&#194;ê&#212;¤·&#214;&#198;μ&#214;μ&#206;a256
        SPI_InitStructure.SPI_FirstBit = SPI_FirstBit_MSB;        //&#214;&#184;&#182;¨êy&#190;Y′&#171;ê&#228;′óMSB&#206;&#187;&#187;1ê&#199;LSB&#206;&#187;&#191;aê&#188;:êy&#190;Y′&#171;ê&#228;′óMSB&#206;&#187;&#191;aê&#188;
        SPI_InitStructure.SPI_CRCPolynomial = 7;        //CRC&#214;μ&#188;&#198;&#203;&#227;μ&#196;&#182;à&#207;&#238;ê&#189;
        SPI_Init(SPI1, &SPI_InitStructure);  //&#184;ù&#190;YSPI_InitStruct&#214;D&#214;&#184;&#182;¨μ&#196;2&#206;êy3&#245;ê&#188;&#187;ˉíaéèSPIx&#188;&#196;′&#230;&#198;÷

        SPI_Cmd(SPI1, ENABLE); //ê1&#196;üSPIíaéè
       
        SPI1_ReadWriteByte(0xff);//&#198;&#244;&#182;ˉ′&#171;ê&#228;                 


}
qq1950361006,互帮互助,共同进步。
回复 支持 反对

使用道具 举报

0

主题

4

帖子

0

精华

新手上路

积分
45
金钱
45
注册时间
2018-5-10
在线时间
9 小时
发表于 2018-5-10 23:19:48 | 显示全部楼层
代码没问题,看一下你的2401.h文件里面的 IO 宏定义
回复 支持 反对

使用道具 举报

3

主题

25

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
205
金钱
205
注册时间
2018-3-28
在线时间
82 小时
发表于 2018-5-12 20:34:41 | 显示全部楼层
我也是  卡死在检测nrf24l1里面
回复 支持 反对

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2024-11-23 03:19

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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