OpenEdv-开源电子网

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

STM32F0操作SPI FLASH,可以读不可以写、擦除---已经看了很多帖子都没找到原因

[复制链接]

2

主题

21

帖子

0

精华

新手上路

积分
46
金钱
46
注册时间
2016-4-8
在线时间
11 小时
发表于 2016-4-8 14:54:41 | 显示全部楼层 |阅读模式
5金钱
使用原子哥的参考代码移植的,读FLASH ID正常,读数据也能读出来,就是写数据、擦除都不成功(调用SPI_Flash_Erase_Chip()瞬间就跳过去了),打印状态寄存器一直都是0!看了好多帖子都解决到问题:
STM32F091+W25Q64

void SPI1_Init(void)
{
       
        GPIO_InitTypeDef GPIO_InitStructure;

          /* Enable the SPI periph */
          RCC_APB2PeriphClockCmd(RCC_APB2Periph_SPI1, ENABLE);

          /* Enable SCK, MOSI, MISO GPIO clocks */
          RCC_AHBPeriphClockCmd(RCC_AHBPeriph_GPIOA, ENABLE);

        /* Configure SPI1 pins: NSS, SCK, MISO and MOSI */
        GPIO_InitStructure.GPIO_Pin = GPIO_Pin_5 | GPIO_Pin_6 | GPIO_Pin_7;
        GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
        GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF;
        GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;
       GPIO_InitStructure.GPIO_PuPd  = GPIO_PuPd_UP;
        GPIO_Init(GPIOA, &GPIO_InitStructure);

        GPIO_PinAFConfig(SPIx_SCK_GPIO_PORT, SPIx_SCK_SOURCE, SPIx_SCK_AF);
          GPIO_PinAFConfig(SPIx_MOSI_GPIO_PORT, SPIx_MOSI_SOURCE, SPIx_MOSI_AF);
          GPIO_PinAFConfig(SPIx_MISO_GPIO_PORT, SPIx_MISO_SOURCE, SPIx_MISO_AF);
       
        //SPI1 NSS
           GPIO_InitStructure.GPIO_Pin = GPIO_Pin_4;
           GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
           GPIO_InitStructure.GPIO_Mode = GPIO_Mode_OUT;
           GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;
        GPIO_InitStructure.GPIO_PuPd  = GPIO_PuPd_UP;
           GPIO_Init(GPIOA, &GPIO_InitStructure);

           GPIO_SetBits(GPIOA, GPIO_Pin_4|GPIO_Pin_5|GPIO_Pin_6|GPIO_Pin_7);

        //SPI_I2S_DeInit(SPI1);
        SPI_InitStructure.SPI_Direction = SPI_Direction_2Lines_FullDuplex; //SPI1设置为两线全双工
        SPI_InitStructure.SPI_Mode = SPI_Mode_Master;                           //设置SPI1为主模式
        SPI_InitStructure.SPI_DataSize = SPI_DataSize_8b;                  //SPI发送接收8位帧结构
        SPI_InitStructure.SPI_CPOL = SPI_CPOL_High;                                        //串行时钟在不操作时,时钟为高电平
        SPI_InitStructure.SPI_CPHA = SPI_CPHA_2Edge;                               //第二个时钟沿开始采样数据
        SPI_InitStructure.SPI_NSS = SPI_NSS_Soft;                                       //NSS信号由软件(使用SSI位)管理
        SPI_InitStructure.SPI_BaudRatePrescaler = SPI_BaudRatePrescaler_2; //定义波特率预分频的值:波特率预分频值为8
        SPI_InitStructure.SPI_FirstBit = SPI_FirstBit_MSB;                                   //数据传输从MSB位开始
        SPI_InitStructure.SPI_CRCPolynomial = 7;                                                   //CRC值计算的多项式

        SPI_Init(SPI1, &SPI_InitStructure);
        //SPI_RxFIFOThresholdConfig(SPI1, SPI_RxFIFOThreshold_QF);//设置接收缓冲
        /* Enable SPI1  */
        SPI_Cmd(SPI1, ENABLE);
        //SPI1_ReadWriteByte(0xff);//启动传输       
       
}   


//读取芯片ID W25X16的ID:0XEF14
u16 SPI_Flash_ReadID(void)
{
        u16 Temp = 0;          
        //SPI_FLASH_CS=0;               
        GPIO_ResetBits(GPIOA, GPIO_Pin_4);
        SPI1_ReadWriteByte(W25X_ManufactDeviceID);//发送读取ID命令            
        SPI1_ReadWriteByte(0x00);             
        SPI1_ReadWriteByte(0x00);             
        SPI1_ReadWriteByte(0x00);                                    
        Temp|=SPI1_ReadWriteByte(0xFF)<<8;  
        Temp|=SPI1_ReadWriteByte(0xFF);         
        //SPI_FLASH_CS=1;               
        GPIO_SetBits(GPIOA, GPIO_Pin_4);
        return Temp;
}                  


//读取SPI FLASH  
//在指定地址开始读取指定长度的数据
//pBuffer:数据存储区
//ReadAddr:开始读取的地址(24bit)
//NumByteToRead:要读取的字节数(最大65535)
void SPI_Flash_Read(u8* pBuffer,u32 ReadAddr,u16 NumByteToRead)   
{
        u16 i;                                                                                                        
        //SPI_FLASH_CS=0;                            //使能器件   
        GPIO_ResetBits(GPIOA, GPIO_Pin_4);
            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[i]=SPI1_ReadWriteByte(0XFF);   //循环读数  
    }
        //SPI_FLASH_CS=1;                            //取消片选                  
        GPIO_SetBits(GPIOA, GPIO_Pin_4);
}  


//擦除整个芯片
//整片擦除时间:
//W25X16:25s
//W25X32:40s
//W25X64:40s
//等待时间超长...
void SPI_Flash_Erase_Chip(void)   
{                                             
    SPI_FLASH_Write_Enable();                  //SET WEL
    SPI_Flash_Wait_Busy();   
          //SPI_FLASH_CS=0;                            //使能器件   
          GPIO_ResetBits(GPIOA, GPIO_Pin_4);
    SPI1_ReadWriteByte(W25X_ChipErase);        //发送片擦除命令  
        //SPI_FLASH_CS=1;                            //取消片选                  
        GPIO_SetBits(GPIOA, GPIO_Pin_4);
        SPI_Flash_Wait_Busy();                                      //等待芯片擦除结束
}   
//擦除一个扇区
//Dst_Addr:扇区地址 0~2047 for W25Q64
//擦除一个山区的最少时间:150ms
void SPI_Flash_Erase_Sector(u32 Dst_Addr)   
{   
        Dst_Addr*=4096;
    SPI_FLASH_Write_Enable();                  //SET WEL          
    SPI_Flash_Wait_Busy();   
    //SPI_FLASH_CS=0;                            //使能器件   
    GPIO_ResetBits(GPIOA, GPIO_Pin_4);
    SPI1_ReadWriteByte(W25X_SectorErase);      //发送扇区擦除指令
    SPI1_ReadWriteByte((u8)((Dst_Addr)>>16));  //发送24bit地址   
    SPI1_ReadWriteByte((u8)((Dst_Addr)>>8));   
    SPI1_ReadWriteByte((u8)Dst_Addr);  
        //SPI_FLASH_CS=1;                            //取消片选                  
        GPIO_SetBits(GPIOA, GPIO_Pin_4);
    SPI_Flash_Wait_Busy();                                      //等待擦除完成
}  


//等待空闲
void SPI_Flash_Wait_Busy(void)   
{   
        while ((SPI_Flash_ReadSR()&0x01)==0x01);   // 等待BUSY位清空
}  


//SPI在一页(0~65535)内写入少于256个字节的数据
//在指定地址开始写入最大256字节的数据
//pBuffer:数据存储区
//WriteAddr:开始写入的地址(24bit)
//NumByteToWrite:要写入的字节数(最大256),该数不应该超过该页的剩余字节数!!!         
void SPI_Flash_Write_Page(u8* pBuffer,u32 WriteAddr,u16 NumByteToWrite)
{
        u16 i;  
            SPI_FLASH_Write_Enable();                  //SET WEL
        //SPI_FLASH_CS=0;                            //使能器件   
        GPIO_ResetBits(GPIOA, GPIO_Pin_4);
    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[i]);//循环写数  
        //SPI_FLASH_CS=1;                            //取消片选
        GPIO_SetBits(GPIOA, GPIO_Pin_4);
        SPI_Flash_Wait_Busy();                                           //等待写入结束
}
//无检验写SPI FLASH
//必须确保所写的地址范围内的数据全部为0XFF,否则在非0XFF处写入的数据将失败!
//具有自动换页功能
//在指定地址开始写入指定长度的数据,但是要确保地址不越界!
//pBuffer:数据存储区
//WriteAddr:开始写入的地址(24bit)
//NumByteToWrite:要写入的字节数(最大65535)
//CHECK OK
void SPI_Flash_Write_NoCheck(u8* pBuffer,u32 WriteAddr,u16 NumByteToWrite)   
{                                           
        u16 pageremain;          
        pageremain=256-WriteAddr%256; //单页剩余的字节数                             
        if(NumByteToWrite<=pageremain)pageremain=NumByteToWrite;//不大于256个字节
        while(1)
        {          
                SPI_Flash_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)                    
//#define MEM_ALLOC_TABLE_SIZE
#ifndef MEM_ALLOC_TABLE_SIZE
u8 SPI_FLASH_BUFFER[4096];
#endif
//u8 SPI_FLASH_BUFFER[4096];
void SPI_Flash_Write(u8* pBuffer,u32 WriteAddr,u16 NumByteToWrite)   
{
        u32 secpos;
        u16 secoff;
        u16 secremain;          
        u16 i;
        u8 * SPI_FLASH_BUF;          
#ifdef MEM_ALLOC_TABLE_SIZE                       
        SPI_FLASH_BUF=mymalloc(4096);        //使用内存管理
        if(SPI_FLASH_BUF==NULL)return;        //申请失败
#else
        SPI_FLASH_BUF=SPI_FLASH_BUFFER;        //不使用内存管理
#endif         
        secpos=WriteAddr/4096;//扇区地址 0~511 for w25x16
        secoff=WriteAddr%4096;//在扇区内的偏移
        secremain=4096-secoff;//扇区剩余空间大小   
        if(NumByteToWrite<=secremain)secremain=NumByteToWrite;//不大于4096个字节
        while(1)
        {       
                SPI_Flash_Read(SPI_FLASH_BUF,secpos*4096,4096);//读出整个扇区的内容
                for(i=0;i<secremain;i++)//校验数据
                {
                        if(SPI_FLASH_BUF[secoff+i]!=0XFF)break;//需要擦除            
                }
                if(i<secremain)//需要擦除
                {
                        SPI_Flash_Erase_Sector(secpos);//擦除这个扇区
                        for(i=0;i<secremain;i++)           //复制
                        {
                                SPI_FLASH_BUF[i+secoff]=pBuffer[i];          
                        }
                        SPI_Flash_Write_NoCheck(SPI_FLASH_BUF,secpos*4096,4096);//写入整个扇区  

                }else SPI_Flash_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;                        //下一个扇区可以写完了
                }         
        };         
#ifdef MEM_ALLOC_TABLE_SIZE                       
        myfree(SPI_FLASH_BUF);                //释放内存                  
#endif
}


最佳答案

查看完整内容[请看2#楼]

问题已经解决,F0跟F1的SPI初始化不一样,需要设置缓冲区!
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

2

主题

21

帖子

0

精华

新手上路

积分
46
金钱
46
注册时间
2016-4-8
在线时间
11 小时
 楼主| 发表于 2016-4-8 14:54:42 | 显示全部楼层
问题已经解决,F0跟F1的SPI初始化不一样,需要设置缓冲区!
回复

使用道具 举报

2

主题

21

帖子

0

精华

新手上路

积分
46
金钱
46
注册时间
2016-4-8
在线时间
11 小时
 楼主| 发表于 2016-4-9 09:25:04 | 显示全部楼层
呼唤原子哥~~~~~
回复

使用道具 举报

15

主题

317

帖子

0

精华

高级会员

Rank: 4

积分
862
金钱
862
注册时间
2015-2-12
在线时间
354 小时
发表于 2016-4-9 10:12:19 | 显示全部楼层
注意:请查看是否有写保护。
回复

使用道具 举报

2

主题

21

帖子

0

精华

新手上路

积分
46
金钱
46
注册时间
2016-4-8
在线时间
11 小时
 楼主| 发表于 2016-4-9 10:43:58 | 显示全部楼层
是指硬件上的WP脚吗?还是软件上要设置一下?硬件上WP脚直接10K电阻上拉的
QQ图片20160409104128.png
回复

使用道具 举报

2

主题

21

帖子

0

精华

新手上路

积分
46
金钱
46
注册时间
2016-4-8
在线时间
11 小时
 楼主| 发表于 2016-4-9 14:49:45 | 显示全部楼层
发现调用SPI_FLASH_Write_Enable()、SPI_FLASH_Write_Disable() 似乎不成功,读出状态寄存器1的值一直为0,WEL位并没有变化;
但调用SPI_Flash_ReadID()却可以读到正确的ID值!!!!
芯片也换过了,还是一样,不解!!!!
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165524
金钱
165524
注册时间
2010-12-1
在线时间
2116 小时
发表于 2016-4-9 21:11:35 | 显示全部楼层
可能SPI的配置有问题。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

2

主题

21

帖子

0

精华

新手上路

积分
46
金钱
46
注册时间
2016-4-8
在线时间
11 小时
 楼主| 发表于 2016-4-11 17:22:19 | 显示全部楼层
原子哥,是指STM32F091  SPI的配置吗?下面是配置代码,帮忙看一下哪里出问题了,这个问题已经困扰了两个星期了,感谢!

                                                  
//SPI口初始化
//这里针是对SPI1的初始化

SPI_InitTypeDef  SPI_InitStructure;

void SPI1_Init(void)
{
        #if 0
        GPIO_InitTypeDef GPIO_InitStructure;
  
        RCC_APB2PeriphClockCmd(        RCC_APB2Periph_GPIOA|RCC_APB2Periph_SPI1, ENABLE );       

        GPIO_InitStructure.GPIO_Pin = GPIO_Pin_5 | GPIO_Pin_6 | GPIO_Pin_7;
        GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;  //复用推挽输出
        GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
        GPIO_Init(GPIOA, &GPIO_InitStructure);

        GPIO_SetBits(GPIOA,GPIO_Pin_5|GPIO_Pin_6|GPIO_Pin_7);

        SPI_InitStructure.SPI_Direction = SPI_Direction_2Lines_FullDuplex;  //设置SPI单向或者双向的数据模式:SPI设置为双线双向全双工
        SPI_InitStructure.SPI_Mode = SPI_Mode_Master;                //设置SPI工作模式:设置为主SPI
        SPI_InitStructure.SPI_DataSize = SPI_DataSize_8b;                //设置SPI的数据大小:SPI发送接收8位帧结构
        SPI_InitStructure.SPI_CPOL = SPI_CPOL_High;                //选择了串行时钟的稳态:时钟悬空高
        SPI_InitStructure.SPI_CPHA = SPI_CPHA_2Edge;        //数据捕获于第二个时钟沿
        SPI_InitStructure.SPI_NSS = SPI_NSS_Soft;                //NSS信号由硬件(NSS管脚)还是软件(使用SSI位)管理:内部NSS信号有SSI位控制
        SPI_InitStructure.SPI_BaudRatePrescaler = SPI_BaudRatePrescaler_256;                //定义波特率预分频的值:波特率预分频值为256
        SPI_InitStructure.SPI_FirstBit = SPI_FirstBit_MSB;        //指定数据传输从MSB位还是LSB位开始:数据传输从MSB位开始
        SPI_InitStructure.SPI_CRCPolynomial = 7;        //CRC值计算的多项式
        SPI_Init(SPI1, &SPI_InitStructure);  //根据SPI_InitStruct中指定的参数初始化外设SPIx寄存器

        SPI_Cmd(SPI1, ENABLE); //使能SPI外设
       
        SPI1_ReadWriteByte(0xff);//启动传输       
        #endif

        GPIO_InitTypeDef GPIO_InitStructure;
  
          /* Enable the SPI periph */
          RCC_APB2PeriphClockCmd(RCC_APB2Periph_SPI1, ENABLE);
  
          /* Enable SCK, MOSI, MISO GPIO clocks */
          RCC_AHBPeriphClockCmd(RCC_AHBPeriph_GPIOA, ENABLE);

        /* Configure SPI1 pins: NSS, SCK, MISO and MOSI */
        GPIO_InitStructure.GPIO_Pin = GPIO_Pin_5 | GPIO_Pin_6 | GPIO_Pin_7;
        GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
        GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF;
        GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;
       GPIO_InitStructure.GPIO_PuPd  = GPIO_PuPd_UP;
        GPIO_Init(GPIOA, &GPIO_InitStructure);

        GPIO_PinAFConfig(SPIx_SCK_GPIO_PORT, SPIx_SCK_SOURCE, SPIx_SCK_AF);
          GPIO_PinAFConfig(SPIx_MOSI_GPIO_PORT, SPIx_MOSI_SOURCE, SPIx_MOSI_AF);
          GPIO_PinAFConfig(SPIx_MISO_GPIO_PORT, SPIx_MISO_SOURCE, SPIx_MISO_AF);
       
        //SPI1 NSS
           GPIO_InitStructure.GPIO_Pin = GPIO_Pin_4;
           GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
           GPIO_InitStructure.GPIO_Mode = GPIO_Mode_OUT;
           GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;
        GPIO_InitStructure.GPIO_PuPd  = GPIO_PuPd_UP;
           GPIO_Init(GPIOA, &GPIO_InitStructure);

           GPIO_SetBits(GPIOA, GPIO_Pin_4);

        //SPI_I2S_DeInit(SPI1);
        SPI_InitStructure.SPI_Direction = SPI_Direction_2Lines_FullDuplex; //SPI1设置为两线全双工
        SPI_InitStructure.SPI_Mode = SPI_Mode_Master;                           //设置SPI1为主模式
        SPI_InitStructure.SPI_DataSize = SPI_DataSize_8b;                  //SPI发送接收8位帧结构
        SPI_InitStructure.SPI_CPOL = SPI_CPOL_High;                                        //串行时钟在不操作时,时钟为高电平
        SPI_InitStructure.SPI_CPHA = SPI_CPHA_2Edge;                               //第二个时钟沿开始采样数据
        SPI_InitStructure.SPI_NSS = SPI_NSS_Soft;                                       //NSS信号由软件(使用SSI位)管理
        SPI_InitStructure.SPI_BaudRatePrescaler = SPI_BaudRatePrescaler_2; //定义波特率预分频的值:波特率预分频值为8
        SPI_InitStructure.SPI_FirstBit = SPI_FirstBit_MSB;                                   //数据传输从MSB位开始
        SPI_InitStructure.SPI_CRCPolynomial = 7;                                                   //CRC值计算的多项式

        SPI_Init(SPI1, &SPI_InitStructure);
        //SPI_RxFIFOThresholdConfig(SPI1, SPI_RxFIFOThreshold_QF);//设置接收缓冲
        /* Enable SPI1  */
        SPI_Cmd(SPI1, ENABLE);
        //SPI1_ReadWriteByte(0xff);//启动传输       
       
}   
//SPI 速度设置函数
//SpeedSet:
//SPI_BaudRatePrescaler_2   2分频   (SPI 36M@sys 72M)
//SPI_BaudRatePrescaler_8   8分频   (SPI 9M@sys 72M)
//SPI_BaudRatePrescaler_16  16分频  (SPI 4.5M@sys 72M)
//SPI_BaudRatePrescaler_256 256分频 (SPI 281.25K@sys 72M)
  
void SPI1_SetSpeed(u8 SpeedSet)
{
        /*SPI_InitStructure.SPI_BaudRatePrescaler = SpeedSet ;
  SPI_Init(SPI1, &SPI_InitStructure);
        SPI_Cmd(SPI1,ENABLE);
*/
        SPI1->CR1&=0XFFC7;
        SPI1->CR1|=SpeedSet;        //   
        SPI1->CR1|=1<<6;                 //
        }
回复

使用道具 举报

2

主题

21

帖子

0

精华

新手上路

积分
46
金钱
46
注册时间
2016-4-8
在线时间
11 小时
 楼主| 发表于 2016-4-13 14:49:59 | 显示全部楼层
再顶一下,新手,谁能指点迷津呀~~~~
回复

使用道具 举报

2

主题

21

帖子

0

精华

新手上路

积分
46
金钱
46
注册时间
2016-4-8
在线时间
11 小时
 楼主| 发表于 2016-4-13 19:17:10 | 显示全部楼层
哪位有stm32f0的读写spi flash的参考代码,分享参考一下!!!!
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165524
金钱
165524
注册时间
2010-12-1
在线时间
2116 小时
发表于 2016-4-13 21:04:03 | 显示全部楼层
没有搞过f0,参考着移植应该不难啊。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

1

主题

5

帖子

0

精华

初级会员

Rank: 2

积分
129
金钱
129
注册时间
2014-10-21
在线时间
29 小时
发表于 2017-3-21 09:04:20 | 显示全部楼层
我也遇到一模一样的问题了,现在也是解决不了。
回复

使用道具 举报

24

主题

157

帖子

0

精华

高级会员

Rank: 4

积分
523
金钱
523
注册时间
2016-1-7
在线时间
131 小时
发表于 2018-1-26 16:07:06 | 显示全部楼层
正点原子 发表于 2016-4-13 21:04
没有搞过f0,参考着移植应该不难啊。

兄弟,你的STM32F0的芯片读写W25Q32的调试成功了吗?能发个程序嘛QQ1964439971
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-6-8 18:03

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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