OpenEdv-开源电子网

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

W25Q64读 Read JEDEC ID失败

[复制链接]

9

主题

42

帖子

0

精华

初级会员

Rank: 2

积分
197
金钱
197
注册时间
2016-1-28
在线时间
37 小时
发表于 2016-11-17 22:18:15 | 显示全部楼层 |阅读模式
本帖最后由 yibiejiangtian 于 2016-11-17 22:38 编辑

有人尝试过读取W25Q64的JEDEC ID吗,也就是使用0x9f命令。我用0x90读取返回的ID正常,可使用0x9f命令返回的全是0,什么都读不到,有人遇到过吗
u32 SPIFlash_ReadID(void)
{
    u32  FlashID,t1,t2,t3;

    FlashID=0x00000000;
    CS_Enable;
    SPIFlash_SendReadByte(0x9F);
    t1|=SPIFlash_SendReadByte(0xFF);

    t2|=SPIFlash_SendReadByte(0xFF);

    t3|=SPIFlash_SendReadByte(0xFF);
    CS_Disable;
    FlashID=(t1<<16)|(t2<<8)|t2;
    return FlashID;
}

正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

9

主题

42

帖子

0

精华

初级会员

Rank: 2

积分
197
金钱
197
注册时间
2016-1-28
在线时间
37 小时
 楼主| 发表于 2016-11-19 22:44:16 | 显示全部楼层
本帖最后由 yibiejiangtian 于 2016-11-19 23:01 编辑

…………………………
回复 支持 反对

使用道具 举报

0

主题

24

帖子

0

精华

初级会员

Rank: 2

积分
64
金钱
64
注册时间
2016-12-22
在线时间
15 小时
发表于 2017-1-7 10:15:03 | 显示全部楼层
yibiejiangtian 发表于 2016-11-19 22:44
…………………………

请问能给我看看驱动W25Q64的程序和电路么~我自己做开发板上EN25Q64成功了,但是自己做W25Q64改了地址EF16后一直读不到地址,显示OXFF.....我怀疑是我吧NSS设置成软件模式后,把SPI2的NSS端口用来做CS了.....
回复 支持 反对

使用道具 举报

9

主题

42

帖子

0

精华

初级会员

Rank: 2

积分
197
金钱
197
注册时间
2016-1-28
在线时间
37 小时
 楼主| 发表于 2017-1-7 10:52:15 | 显示全部楼层
MoQinchuan 发表于 2017-1-7 10:15
请问能给我看看驱动W25Q64的程序和电路么~我自己做开发板上EN25Q64成功了,但是自己做W25Q64改了地址EF16 ...

[mw_shl_code=c,true]#include  "BSP_SPIFlash.h"


//static __IO uint32_t  SPITimeout = SPIT_LONG_TIMEOUT;     

//static uint32_t SPI_TIMEOUT_UserCallback(uint8_t errorCode);

u16 W25QXX_TYPE=W25Q128;        //默认是W25Q128

void SPIFlash_GPIOInit(void)
{
        GPIO_InitTypeDef  GPIO_SPIInitstructure;

        RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA,ENABLE);
       
        GPIO_SPIInitstructure.GPIO_Pin    =  GPIO_Pin_5|GPIO_Pin_7;
        GPIO_SPIInitstructure.GPIO_Mode   =  GPIO_Mode_AF_PP;
        GPIO_SPIInitstructure.GPIO_Speed  =  GPIO_Speed_50MHz;

        GPIO_Init(GPIOA,&GPIO_SPIInitstructure);
   
    GPIO_SPIInitstructure.GPIO_Pin    =  GPIO_Pin_4;
        GPIO_SPIInitstructure.GPIO_Mode   =  GPIO_Mode_Out_PP;
        GPIO_SPIInitstructure.GPIO_Speed  =  GPIO_Speed_50MHz;

        GPIO_Init(GPIOA,&GPIO_SPIInitstructure);
   
    GPIO_SPIInitstructure.GPIO_Pin    =  GPIO_Pin_6;
//        GPIO_SPIInitstructure.GPIO_Mode   =  GPIO_Mode_IPU;
        GPIO_SPIInitstructure.GPIO_Mode   =  GPIO_Mode_IN_FLOATING;//GPIO_Mode_IPU
        GPIO_SPIInitstructure.GPIO_Speed  =  GPIO_Speed_50MHz;

        GPIO_Init(GPIOA,&GPIO_SPIInitstructure);
   
    GPIO_SetBits(GPIOA,GPIO_Pin_4);
       
}

void SPIFlash_ModeConfig(void)
{
    SPI_InitTypeDef SPIFlash_InitStructure;

    RCC_APB2PeriphClockCmd(RCC_APB2Periph_SPI1,ENABLE);
   
    SPIFlash_InitStructure.SPI_BaudRatePrescaler  =  SPI_BaudRatePrescaler_2;
    SPIFlash_InitStructure.SPI_CPHA               =  SPI_CPHA_2Edge;
    SPIFlash_InitStructure.SPI_CPOL               =  SPI_CPOL_High;
    SPIFlash_InitStructure.SPI_CRCPolynomial      =  7;
    SPIFlash_InitStructure.SPI_DataSize           =  SPI_DataSize_8b;
    SPIFlash_InitStructure.SPI_Direction          =  SPI_Direction_2Lines_FullDuplex;
    SPIFlash_InitStructure.SPI_FirstBit           =  SPI_FirstBit_MSB;
    SPIFlash_InitStructure.SPI_Mode               =  SPI_Mode_Master;
    SPIFlash_InitStructure.SPI_NSS                =  SPI_NSS_Soft;
   
//    SPI_SSOutputCmd(SPI1,DISABLE);



    SPI_Init(SPI1,&SPIFlash_InitStructure);
    SPI_Cmd(SPI1,ENABLE);

}

//void SPIFlash_Init(void)
//{
//    SPIFlash_GPIOInit();
//    SPIFlash_ModeConfig();
//}

//void SPIFlash_NOP(void)   
//{
//    W25QXX_CS=0;                            //使能器件   
//        SPI1_ReadWriteByte(0x00);   
//       
//        W25QXX_CS=1;
//}

u8 SPI1_ReadWriteByte(u8 TxData)
{               
        u8 retry=0;                                        
        while (SPI_I2S_GetFlagStatus(SPI1, SPI_I2S_FLAG_TXE) == RESET) //检查指定的SPI标志位设置与否:发送缓存空标志位
                {
                retry++;
                if(retry>200)return 0;
                }                          
        SPI_I2S_SendData(SPI1, TxData); //通过外设SPIx发送一个数据
        retry=0;

        while (SPI_I2S_GetFlagStatus(SPI1, SPI_I2S_FLAG_RXNE) == RESET) //检查指定的SPI标志位设置与否:接受缓存非空标志位
                {
                retry++;
                if(retry>200)return 0;
                }                                                              
        return SPI_I2S_ReceiveData(SPI1); //返回通过SPIx最近接收的数据                                            
}


//4Kbytes为一个Sector
//16个扇区为1个Block
//W25Q128
//容量为16M字节,共有128个Block,4096个Sector
                                                                                                         
//初始化SPI FLASH的IO口
void W25QXX_Init(void)
{       
    SPIFlash_GPIOInit();
    SPIFlash_ModeConfig();


//        SPI1_SetSpeed(SPI_BaudRatePrescaler_2);//设置为18M时钟,高速模式
        W25QXX_TYPE=W25QXX_ReadID();//读取FLASH ID.  

}  

//读取W25QXX的状态寄存器
//BIT7  6   5   4   3   2   1   0
//SPR   RV  TB BP2 BP1 BP0 WEL BUSY
//SPR:默认0,状态寄存器保护位,配合WP使用
//TB,BP2,BP1,BP0:FLASH区域写保护设置
//WEL:写使能锁定
//BUSY:忙标记位(1,忙;0,空闲)
//默认:0x00
u8 W25QXX_ReadSR(void)   
{  
        u8 byte=0;   
        W25QXX_CS=0;                            //使能器件   
        SPI1_ReadWriteByte(W25X_ReadStatusReg); //发送读取状态寄存器命令   
        byte=SPI1_ReadWriteByte(0Xff);          //读取一个字节  
        W25QXX_CS=1;                            //取消片选     
        return byte;   
}
//写W25QXX状态寄存器
//只有SPR,TB,BP2,BP1,BP0(bit 7,5,4,3,2)可以写!!!
void W25QXX_Write_SR(u8 sr)   
{   
        W25QXX_CS=0;                            //使能器件   
        SPI1_ReadWriteByte(W25X_WriteStatusReg);//发送写取状态寄存器命令   
        SPI1_ReadWriteByte(sr);                       //写入一个字节  
        W25QXX_CS=1;                            //取消片选                  
}   
//W25QXX写使能       
//将WEL置位   
void W25QXX_Write_Enable(void)   
{
        W25QXX_CS=0;                                  //使能器件   
    SPI1_ReadWriteByte(W25X_WriteEnable);         //发送写使能  
        W25QXX_CS=1;                                   //取消片选                  
}
//W25QXX写禁止       
//将WEL清零  
void W25QXX_Write_Disable(void)   
{  
        W25QXX_CS=0;                            //使能器件   
    SPI1_ReadWriteByte(W25X_WriteDisable);  //发送写禁止指令   
        W25QXX_CS=1;                            //取消片选                  
}                
//读取芯片ID
//返回值如下:                                  
//0XEF13,表示芯片型号为W25Q80  
//0XEF14,表示芯片型号为W25Q16   
//0XEF15,表示芯片型号为W25Q32  
//0XEF16,表示芯片型号为W25Q64
//0XEF17,表示芯片型号为W25Q128           
u16 W25QXX_ReadID(void)
{
        u16 Temp = 0;          
        W25QXX_CS=0;
   
        SPI1_ReadWriteByte(0x90);//发送读取ID命令            
        SPI1_ReadWriteByte(0x00);             
        SPI1_ReadWriteByte(0x00);             
        SPI1_ReadWriteByte(0x00);                                    
        Temp|=SPI1_ReadWriteByte(0xFF)<<8;

        Temp|=SPI1_ReadWriteByte(0xFF);         
        W25QXX_CS=1;
   
        return Temp;
}                       
//读取SPI FLASH  
//在指定地址开始读取指定长度的数据
//pBuffer:数据存储区
//ReadAddr:开始读取的地址(24bit)
//NumByteToRead:要读取的字节数(最大65535)
void W25QXX_Read(u8* pBuffer,u32 ReadAddr,u16 NumByteToRead)   
{
        u16 i;                                                                                       
        W25QXX_CS=0;                                    //使能器件   
    SPI1_ReadWriteByte(W25X_ReadData);                 //发送读取命令   
    SPI1_ReadWriteByte((u8)((ReadAddr)>>16));          //发送24bit地址   
    SPI1_ReadWriteByte((u8)((ReadAddr)>>8));   
    SPI1_ReadWriteByte((u8)ReadAddr);   
    for(i=0;i<NumByteToRead;i++)
        {
        pBuffer=SPI1_ReadWriteByte(0XFF);           //循环读数  
    }
        W25QXX_CS=1;                                                   
}  
//SPI在一页(0~65535)内写入少于256个字节的数据
//在指定地址开始写入最大256字节的数据
//pBuffer:数据存储区
//WriteAddr:开始写入的地址(24bit)
//NumByteToWrite:要写入的字节数(最大256),该数不应该超过该页的剩余字节数!!!         
void W25QXX_Write_Page(u8* pBuffer,u32 WriteAddr,u16 NumByteToWrite)
{
        u16 i;  
    W25QXX_Write_Enable();                          //SET WEL
        W25QXX_CS=0;                                    //使能器件   
    SPI1_ReadWriteByte(W25X_PageProgram);              //发送写页命令   
    SPI1_ReadWriteByte((u8)((WriteAddr)>>16));         //发送24bit地址   
    SPI1_ReadWriteByte((u8)((WriteAddr)>>8));   
    SPI1_ReadWriteByte((u8)WriteAddr);   
    for(i=0;i<NumByteToWrite;i++)SPI1_ReadWriteByte(pBuffer);//循环写数  
        W25QXX_CS=1;                                    //取消片选
        W25QXX_Wait_Busy();                                                           //等待写入结束
}
//无检验写SPI FLASH
//必须确保所写的地址范围内的数据全部为0XFF,否则在非0XFF处写入的数据将失败!
//具有自动换页功能
//在指定地址开始写入指定长度的数据,但是要确保地址不越界!
//pBuffer:数据存储区
//WriteAddr:开始写入的地址(24bit)
//NumByteToWrite:要写入的字节数(最大65535)
//CHECK OK
void W25QXX_Write_NoCheck(u8* pBuffer,u32 WriteAddr,u16 NumByteToWrite)   
{                                           
        u16 pageremain;          
        pageremain=256-WriteAddr%256; //单页剩余的字节数                             
        if(NumByteToWrite<=pageremain)pageremain=NumByteToWrite;//不大于256个字节
        while(1)
        {          
                W25QXX_Write_Page(pBuffer,WriteAddr,pageremain);
                if(NumByteToWrite==pageremain)break;//写入结束了
                 else //NumByteToWrite>pageremain
                {
                        pBuffer+=pageremain;
                        WriteAddr+=pageremain;       

                        NumByteToWrite-=pageremain;                          //减去已经写入了的字节数
                        if(NumByteToWrite>256)pageremain=256; //一次可以写入256个字节
                        else pageremain=NumByteToWrite;           //不够256个字节了
                }
        };            
}
//写SPI FLASH  
//在指定地址开始写入指定长度的数据
//该函数带擦除操作!
//pBuffer:数据存储区
//WriteAddr:开始写入的地址(24bit)                                               
//NumByteToWrite:要写入的字节数(最大65535)   
u8 W25QXX_BUFFER[4096];                 
void W25QXX_Write(u8* pBuffer,u32 WriteAddr,u16 NumByteToWrite)   
{
        u32 secpos;
        u16 secoff;
        u16 secremain;          
        u16 i;   
        u8 * W25QXX_BUF;          
           W25QXX_BUF=W25QXX_BUFFER;             
        secpos=WriteAddr/4096;//扇区地址  
        secoff=WriteAddr%4096;//在扇区内的偏移
        secremain=4096-secoff;//扇区剩余空间大小   
        //printf("ad:%X,nb:%X\r\n",WriteAddr,NumByteToWrite);//测试用
        if(NumByteToWrite<=secremain)secremain=NumByteToWrite;//不大于4096个字节
        while(1)
        {       
                W25QXX_Read(W25QXX_BUF,secpos*4096,4096);//读出整个扇区的内容
                for(i=0;i<secremain;i++)//校验数据
                {
                        if(W25QXX_BUF[secoff+i]!=0XFF)break;//需要擦除            
                }
                if(i<secremain)//需要擦除
                {
                        W25QXX_Erase_Sector(secpos);                //擦除这个扇区
                        for(i=0;i<secremain;i++)                           //复制
                        {
                                W25QXX_BUF[i+secoff]=pBuffer;          
                        }
                        W25QXX_Write_NoCheck(W25QXX_BUF,secpos*4096,4096);//写入整个扇区  

                }else W25QXX_Write_NoCheck(pBuffer,WriteAddr,secremain);//写已经擦除了的,直接写入扇区剩余区间.                                   
                if(NumByteToWrite==secremain)break;//写入结束了
                else//写入未结束
                {
                        secpos++;//扇区地址增1
                        secoff=0;//偏移位置为0          

                           pBuffer+=secremain;                                  //指针偏移
                        WriteAddr+=secremain;                                //写地址偏移          
                           NumByteToWrite-=secremain;                        //字节数递减
                        if(NumByteToWrite>4096)secremain=4096;//下一个扇区还是写不完
                        else secremain=NumByteToWrite;                //下一个扇区可以写完了
                }         
        };         
}
//擦除整个芯片                  
//等待时间超长...
void W25QXX_Erase_Chip(void)   
{                                   
    W25QXX_Write_Enable();                                  //SET WEL
    W25QXX_Wait_Busy();   
          W25QXX_CS=0;                                    //使能器件   
    SPI1_ReadWriteByte(W25X_ChipErase);                //发送片擦除命令  
        W25QXX_CS=1;                                    //取消片选                  
        W25QXX_Wait_Busy();                                                      //等待芯片擦除结束
}   
//擦除一个扇区
//Dst_Addr:扇区地址 根据实际容量设置
//擦除一个山区的最少时间:150ms
void W25QXX_Erase_Sector(u32 Dst_Addr)   
{  
        //监视falsh擦除情况,测试用   
        printf("fe:%x\r\n",Dst_Addr);          
        Dst_Addr*=4096;
    W25QXX_Write_Enable();                          //SET WEL          
    W25QXX_Wait_Busy();   
          W25QXX_CS=0;                                    //使能器件   
    SPI1_ReadWriteByte(W25X_SectorErase);              //发送扇区擦除指令
    SPI1_ReadWriteByte((u8)((Dst_Addr)>>16));          //发送24bit地址   
    SPI1_ReadWriteByte((u8)((Dst_Addr)>>8));   
    SPI1_ReadWriteByte((u8)Dst_Addr);  
        W25QXX_CS=1;                                    //取消片选                  
    W25QXX_Wait_Busy();                                                      //等待擦除完成
}  
//等待空闲
void W25QXX_Wait_Busy(void)   
{   
        while((W25QXX_ReadSR()&0x01)==0x01);                  // 等待BUSY位清空
}  
//进入掉电模式
void W25QXX_PowerDown(void)   
{
          W25QXX_CS=0;                                            //使能器件   
    SPI1_ReadWriteByte(W25X_PowerDown);        //发送掉电命令  
        W25QXX_CS=1;                                    //取消片选                  
    delay_us(3);                               //等待TPD  
}   
//唤醒
void W25QXX_WAKEUP(void)   
{  
          W25QXX_CS=0;                                    //使能器件   
    SPI1_ReadWriteByte(W25X_ReleasePowerDown);        //  send W25X_PowerDown command 0xAB   
        W25QXX_CS=1;                                    //取消片选                  
    delay_us(3);                                    //等待TRES1
}   


uint32_t sf_ReadID(void)
{
        uint32_t uiID;
        uint8_t id1, id2, id3;

        W25QXX_CS=0;                                                                        /* 使能片选 */
        SPI1_ReadWriteByte(0x9F);                                                                /* 发送读ID命令 */
        id1 = SPI1_ReadWriteByte(0x00);                                        /* 读ID的第1个字节 */
        id2 = SPI1_ReadWriteByte(0x00);                                        /* 读ID的第2个字节 */
        id3 = SPI1_ReadWriteByte(0x00);                                        /* 读ID的第3个字节 */
        W25QXX_CS=1;                                                                        /* 禁能片选 */

        uiID = ((uint32_t)id1 << 16) | ((uint32_t)id2 << 8) | id3;

        return uiID;
}
[/mw_shl_code]
回复 支持 反对

使用道具 举报

9

主题

42

帖子

0

精华

初级会员

Rank: 2

积分
197
金钱
197
注册时间
2016-1-28
在线时间
37 小时
 楼主| 发表于 2017-1-7 10:58:42 | 显示全部楼层
就驱动自己写的,其他全部移植的,读JEDEC ID是好像最后那个函数,不太记得了,我的开始是引脚配置有问题,后面没问题了,片选也是软模式
QQ截图20170107105413.jpg
回复 支持 反对

使用道具 举报

0

主题

24

帖子

0

精华

初级会员

Rank: 2

积分
64
金钱
64
注册时间
2016-12-22
在线时间
15 小时
发表于 2017-1-8 02:14:21 | 显示全部楼层
yibiejiangtian 发表于 2017-1-7 10:58
就驱动自己写的,其他全部移植的,读JEDEC ID是好像最后那个函数,不太记得了,我的开始是引脚配置有问题, ...

我的图跟你几乎一样,就是CS没有上拉!搬用了你的程序,结果你的程序跟我之前写的一样,在FLASH写入数据 W25QXX_Write(Lux_HL,FlashAdd,2); 的时候,无限循环在W25QXX_Write里面的W25QXX_Wait_Busy......
回复 支持 反对

使用道具 举报

0

主题

24

帖子

0

精华

初级会员

Rank: 2

积分
64
金钱
64
注册时间
2016-12-22
在线时间
15 小时
发表于 2017-1-8 02:17:37 | 显示全部楼层
yibiejiangtian 发表于 2017-1-7 10:58
就驱动自己写的,其他全部移植的,读JEDEC ID是好像最后那个函数,不太记得了,我的开始是引脚配置有问题, ...

开发板的图 NSS没有接任何外设,但是它的CS则是跟NSS分开的。所以它Flash芯片的图的CS端没有上拉。

你我的NSS和CS连在一起了,NSS用了软模式。也许这样用CS就要上拉.....你觉得呢.....
回复 支持 反对

使用道具 举报

0

主题

24

帖子

0

精华

初级会员

Rank: 2

积分
64
金钱
64
注册时间
2016-12-22
在线时间
15 小时
发表于 2017-1-8 02:34:23 | 显示全部楼层
yibiejiangtian 发表于 2017-1-7 10:58
就驱动自己写的,其他全部移植的,读JEDEC ID是好像最后那个函数,不太记得了,我的开始是引脚配置有问题, ...

具体是W25QXX_Write里面的W25QXX_Write_NoCheck里面的W25QXX_Write_Page里面的那个Busy程序,死在那里.....
回复 支持 反对

使用道具 举报

9

主题

42

帖子

0

精华

初级会员

Rank: 2

积分
197
金钱
197
注册时间
2016-1-28
在线时间
37 小时
 楼主| 发表于 2017-1-8 16:25:33 | 显示全部楼层
本帖最后由 yibiejiangtian 于 2017-1-8 16:27 编辑
MoQinchuan 发表于 2017-1-8 02:34
具体是W25QXX_Write里面的W25QXX_Write_NoCheck里面的W25QXX_Write_Page里面的那个Busy程序,死在那里... ...

跟上拉没得太大关系吧,只要把电平设置正确就可以,实在不放心用个直插电阻引根线上拉试下。等待空闲一直出不来有应该是你读出来的数据根本不对,可能你的IO口配置本来就是错误的,移植往往一个地方没改过来就全错。你先读ID试试,把几个ID全部读一遍,看看读到的数据正确不,如果ID都读不正确,你进行写操作也没得什么意义。首先得保证你的硬件连接和端口模式配置完全对应的上,再就是时序。如果读ID正确再试着写一个数据进去,然后读出来比较下
回复 支持 反对

使用道具 举报

54

主题

1008

帖子

1

精华

金牌会员

Rank: 6Rank: 6

积分
2384
金钱
2384
注册时间
2012-11-22
在线时间
403 小时
发表于 2017-1-9 13:14:56 | 显示全部楼层
读之前执行一下w25qxx_wake_up();试试。
void w25qxx_wake_up(void)   
{  
        W25QXX_CS_PIN_WRITE(0);       
                           
        spi_read_write_byte(W25X_WAKE_UP);

        W25QXX_CS_PIN_WRITE(1);  
        delay_us(1);
}
我们公司采购的FLASH,不先wake_up的话就不行。
态度决定一切
回复 支持 反对

使用道具 举报

0

主题

24

帖子

0

精华

初级会员

Rank: 2

积分
64
金钱
64
注册时间
2016-12-22
在线时间
15 小时
发表于 2017-1-9 19:14:12 | 显示全部楼层
冰封嗜魔 发表于 2017-1-9 13:14
读之前执行一下w25qxx_wake_up();试试。
void w25qxx_wake_up(void)   
{  

你是说我的问题么?我自己在开发板上面很顺利,NSS和CS独立,NSS没有接任何的东西.....我为了验证我的问题,我把开发板上面的CS跟NSS接起来,立马Flash就不运行了.....
回复 支持 反对

使用道具 举报

0

主题

24

帖子

0

精华

初级会员

Rank: 2

积分
64
金钱
64
注册时间
2016-12-22
在线时间
15 小时
发表于 2017-1-9 19:16:11 | 显示全部楼层
yibiejiangtian 发表于 2017-1-8 16:25
跟上拉没得太大关系吧,只要把电平设置正确就可以,实在不放心用个直插电阻引根线上拉试下。等待空闲一直 ...

天啊,我在开发板上成功实验了你的程序,和我自己的程序。这个时候,我把PG13 CS口跟PB12接起来,马上无法读写.....
回复 支持 反对

使用道具 举报

0

主题

24

帖子

0

精华

初级会员

Rank: 2

积分
64
金钱
64
注册时间
2016-12-22
在线时间
15 小时
发表于 2017-1-9 19:23:57 | 显示全部楼层
yibiejiangtian 发表于 2017-1-8 16:25
跟上拉没得太大关系吧,只要把电平设置正确就可以,实在不放心用个直插电阻引根线上拉试下。等待空闲一直 ...

而最后,我把开发板上NSS和CS都强行接地,发现就可以了......读写数据很正常,能不能读出ID我不知道.....
回复 支持 反对

使用道具 举报

0

主题

13

帖子

0

精华

新手上路

积分
37
金钱
37
注册时间
2018-8-15
在线时间
6 小时
发表于 2018-8-15 04:29:14 | 显示全部楼层
同样的问题,顶帖求助
回复 支持 反对

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-6-2 20:18

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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