STM32F103C8T6——FLASH读写进入硬件错误

今天跑程序发现在FLASH读写过程中程序会跑死并跳转至HardFault_Handler,在网上查阅资料说有可能是首地址没有对齐4字节的问题,不过我stm32应该不存在这个问题,于是我打算改变一下读写宽度试试:
我之前用的是双字写入和读取,先将写入函数改为单字模式:FLASH_TYPEPROGRAM_DOUBLEWORD改为FLASH_TYPEPROGRAM_WORD,再将偏移量改为4,所有的uint64_t改为uint32_t,下面是修改后的读写函数。

uint8_t FLASH_EEPROM_Write(void)
{
	uint8_t	state;
	__HAL_FLASH_CLEAR_FLAG(FLASH_FLAG_OPTVERR);
	eraseFlash();
	HAL_FLASH_Unlock();
	for(uint8_t i = 0;i < sizeof(SysStatus);i+=4)
	{
		if(HAL_FLASH_Program(FLASH_TYPEPROGRAM_WORD, FLASH_BASE_ADDR+i,*((__IO uint32_t*)(&SysStatus.LockState[0]+i)))!= HAL_OK)//这里的数据由于是结构体,需要从里面取值,一定要以第一个成员的地址开始偏移,不能使用结构体自身的地址来偏移,否则数据会出错
		{
			HAL_FLASH_Lock();
			state =  1;//write success
		}
		else
		{
			HAL_FLASH_Lock();
			state =  2;//write fault
		}
	}
	HAL_FLASH_Lock();
	return state;
}
void FLASH_EEPROM_Read(void)
{
	for(uint8_t i = 0;i<sizeof(SysStatus);i+=4)
	{
		*((uint32_t *)(&SysStatus.LockState[0]+i)) = *(__IO uint32_t*)(FLASH_BASE_ADDR + i);//注意赋值的左边,必须要用结构体第一个成员的地址来偏移,双字偏移量是8
	}
}

经测试问题解决,毕竟stm32是32位处理器,可能处理64位数据可能会有问题。具体的问题原因之后如果有时间细究会更新上来。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: STM32F103C8T6是一款基于ARM Cortex-M3内核的微控制器,具有内置的Flash存储器。这款芯片内置了64KB的Flash存储器,可以用于存储程序代码和数据。 在STM32F103C8T6上进行内部Flash读写操作,首先需要初始化Flash模块。通过设置Flash时钟源、解锁Flash接口和使能Flash预取功能等步骤,可以确保正确读写Flash。 读取Flash存储器的数据,可以通过编程方式访问存储器地址并将数据读取到合适的数据类型中。读取过程需要注意数据的字节对齐、类型转换和读取大小等问题,以确保数据读取的正确性和准确性。 写入Flash存储器的数据,需要使用特定的Flash写函数。在编写数据之前,需要确保Flash存储器的页已经被擦除。然后,使用写入函数将数据写入指定地址的Flash存储器中。写操作完成后,需要进行数据校验或读取校验,以确保数据的正确写入。 注意,对于STM32F103C8T6Flash存储器,写入操作只能在已经擦除的页中进行。单次写入操作的字节长度应小于等于Flash存储器的页大小。如果需要写入超过一页的数据,需要以页为单位进行分页写入,同时注意页边界对齐和数据的正确传输。 总的来说,STM32F103C8T6内部Flash读写操作需要正确的初始化和合适的编程方法。合理管理内部Flash存储器的读写,可以实现数据存储和程序更新等功能。 ### 回答2: STM32F103C8T6是一款32位ARM Cortex-M3内核的微控制器,内置了64KB的Flash存储器。下面将通过以下几个方面来回答stm32f103c8t6内部Flash读写。 首先,内部Flash的读取。在STM32的开发环境中,我们可以使用标准库函数或者相关的驱动程序来读取内部Flash。我们可以使用函数如`HAL_FLASH_Read()`来读取指定地址的数据。我们需要提供要读取的地址和要读取的变量的指针。函数将会将指定地址的数据复制到指定的变量中。 其次,内部Flash写入。为了写入内部Flash,我们需要解锁Flash并擦除要写入的扇区。可以使用函数如`HAL_FLASH_Unlock()`解锁Flash。然后,使用函数如`FLASH_Erase_Sector()`来擦除指定的Flash扇区。接下来,我们可以使用函数如`HAL_FLASH_Program()`来对Flash进行编程。将要写入数据和要写入的地址传递给该函数,函数将会将数据编程到指定的地址。 需要注意的是,内部Flash写入和擦除操作会消耗一定的时间。为了确保Flash操作的完整性和正确性,需要在进行写入和擦除操作时禁用全局中断。另外,需要注意在编程Flash之前将Flash与其他外设(如闪存存储器或外部RAM)断开连接,以防止写入数据和相关的操作引起问题。 最后,我们需要注意到内部Flash的寿命。每个Flash单元具备一定的擦除次数和编程次数。因此,在设计中需要谨慎使用Flash的擦除和写入操作。我们可以通过参考产品手册和数据手册了解具体Flash的寿命,并根据实际需求来合理安排Flash的使用。 总结起来,STM32F103C8T6内部Flash读写操作可以使用相关的驱动程序或标准库函数来完成。读取操作可以通过提供要读取的地址和变量的指针来完成,而写入操作需要先解锁Flash、擦除指定的扇区,然后再编程指定的地址。在进行Flash操作时需要注意Flash的寿命和正确的编程步骤。 ### 回答3: STM32F103C8T6是一款基于ARM Cortex-M3内核的高性能微控制器。它内部集成了64KB的闪存(flash),可以用于存储程序代码和数据。 在STM32F103C8T6上进行内部flash读写操作,需要遵循以下步骤: 1. 配置内部flash:在进行读写操作之前,需要将flash解锁并配置为编程状态。通过对FLASH_CR寄存器写入相应的位值,可以进行解锁和配置操作。 2. 擦除flash扇区:在进行写操作之前,需要先擦除相应的flash扇区。每个flash扇区的大小一般为1KB或2KB,在擦除操作中,需要注意只能擦除整个扇区,不能对单个字节进行操作。 3. 写入数据:擦除flash扇区后,可以将数据写入flash。通过对FLASH_AR寄存器写入写入数据值,可以实现将数据写入flash。 4. 数据验证:在完成写入操作后,可以进行数据验证。通过将写入数据flash中对应位置的数据进行比较,可以确保写入操作的准确性。 需要注意的是,内部flash有一定的寿命,仅能进行有限次数的擦除和写入操作。因此,在进行内部flash读写操作时,需要合理规划擦除和写入的次数,以提高flash的使用寿命。 总结起来,STM32F103C8T6内部flash读写操作需要先配置flash,然后擦除相应扇区,然后写入数据,最后进行数据验证。需要注意合理规划擦除和写入的次数,以延长flash的使用寿命。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

食熊鱼

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值