STM32G0B1CCT6是相对比较新的MCU,属于G系列,不支持标准库,所以下文用的是hal库或者ll库。
首先STM32G0B1CCT6是有256kflash的,每页2k,而规格书里面只提到0-63page,相当于128kflash。
对于后128k的flash其实需要切换bank2才能使用。
下图为STM32G0B1CCT6的flash构成
然后我们先看正常如果要擦除第一页的代码
- FLASH_EraseInitTypeDef My_Flash; //声明 FLASH_EraseInitTypeDef 结构体为 My_Flash
- uint32_t PageError = 0; //设置PageError,如果出现错误这个变量会被设置为出错的FLASH地址
- HAL_FLASH_Unlock();
- My_Flash.TypeErase = FLASH_TYPEERASE_PAGES; //标明Flash执行页面只做擦除操作
- My_Flash.Page = 0; //声明要擦除的页
- My_Flash.NbPages = 1; //说明要擦除的页数,此参数必须是Min_Data = 1和Max_Data =(最大页数-初始页的值)之间的值
- My_Flash.Banks = FLASH_BANK_1;
- //调用擦除函数
- if(HAL_FLASHEx_Erase(&My_Flash, &PageError) == HAL_OK)
- {
- //3、对FLASH烧写
- //MEM_WRITE(FLASH_SYSTEM_DATA_ADDR, buf, 5);
- }
- //4、锁住FLASH
- HAL_FLASH_Lock();
复制代码
当我们要擦除后128k的第一页的时候,即第64页时,需要把FLASH_BANK_1切换到FLASH_BANK_2
不能直接在FLASH_BANK_1声明擦除第64页,切换到FLASH_BANK_2后,相应的页数为总页数减64页。
- FLASH_EraseInitTypeDef My_Flash; //声明 FLASH_EraseInitTypeDef 结构体为 My_Flash
- uint32_t PageError = 0; //设置PageError,如果出现错误这个变量会被设置为出错的FLASH地址
- HAL_FLASH_Unlock();
- My_Flash.TypeErase = FLASH_TYPEERASE_PAGES; //标明Flash执行页面只做擦除操作
- My_Flash.Page = 0; //声明要擦除的页
- My_Flash.NbPages = 1; //说明要擦除的页数,此参数必须是Min_Data = 1和Max_Data =(最大页数-初始页的值)之间的值
- My_Flash.Banks = FLASH_BANK_2;
- //调用擦除函数
- if(HAL_FLASHEx_Erase(&My_Flash, &PageError) == HAL_OK)
- {
- //3、对FLASH烧写
- //MEM_WRITE(FLASH_SYSTEM_DATA_ADDR, buf, 5);
- }
- //4、锁住FLASH
- HAL_FLASH_Lock();
复制代码
最后再附上一个ST-programmer和iar的一个小bug。我将这些问题均已反馈到原厂了。
1、如果ST-programmer要单独擦除后128k是擦除失败的,因为软件本身没有切换bank2
2、IAR烧录时该次使用到了后128k,则也是擦除失败导致烧录失败。第一次烧录成功,但是从第二次开始需要擦除到相应flash时,擦除失败就无法下载了(keil应该也是一样)
|