您的位置 首页 ADAS

stm32 Flash读写

通过对stm32内部的flash的读写可以实现对stm32的编程操作。stm32的内置可编程Flash在许多场合具有十分重要的意义。如其支持ICP特性使得开

经过对stm32内部的flash的读写能够完成对stm32的编程操作。

stm32 的内置可编程Flash在许多场合具有十分重要的含义。如其支撑ICP特性使得开发人员对stm32能够警醒调试开发,能够经过JTAG和SWD接口对stm32进行程序烧写;支撑IAP特性使得开发人员能够在stm32运转程序的时分对其内部程序进行更新操作。对一些对数据安全有要求的场合,可编程FLASH能够结合stm32内部仅有的身份标识完成各式各样的防破解计划。而且stm32的FLASH在一些轻量级的防掉电存储计划中也有立锥之地。
stm32的FLASH分为主存储块和信息块。主存储块用于保存详细的程序代码和用户数据,信息块用于担任由stm32出厂是放置2KB的发动程序(Bootloader)和512B的用户装备信息区。
主存储块是以页为单位区分的,一页巨细为1KB。规模为从地址0x08000000开端的128KB内。
对Flash 的写入操作要 “先擦除后写入”的准则;
stm32的内置flash 编程操作都是以页为单位写入的,而写入的操作有必要要以16位半字宽度数据位单位,答应跨页写,写入非16位数据时将导致stm32内部总线过错。
进行内置flash读写时,有必要要翻开内部Rc振荡器。
main.c:
001 #include “stm32f10x.h”
002 #include “stdio.h”
003
004 #define PRINTF_ON 1
005
006 void RCC_Configuration(void);
007 void GPIO_Configuration(void);
008 void USART_Configuration(void);
009
010 u32 count=0;
011
012 u16 data[5]={0x0001,0x0002,0x0003,0x0004,0x0005};
013
014 int main(void)
015 {
016 RCC_Configuration();
017 GPIO_Configuration();
018 USART_Configuration();
019
020 RCC_HSICmd(ENABLE);
021
022 FLASH_Unlock();
023
024 FLASH_ClearFlag(FLASH_FLAG_EOP|FLASH_FLAG_PGERR|FLASH_FLAG_WRPRTERR);
025
026 FLASH_ErasePage(0x8002000);
027
028 while(count < 5)
029 {
030 FLASH_ProgramHalfWord((0x8002000 +count*2),data[count]); //flash 为一个字节存储,16位数据有必要地址加2
031
032 count++;
033
034 }
035
036 FLASH_Lock();
037
038 count = 0;
039
040 printf(“The Five Data Is : “);
041
042 while(count < 5)
043 {
044
045 printf(“%d “,*(u8 *)(0x8002000 + count*2)); //读取办法
046
047 count++;
048
049
050 }
051
052 while(1);
053
054 }
055
056 void GPIO_Configuration(void)
057 {
058 GPIO_InitTypeDef GPIO_InitStructure;
059
060 GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
061
062 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9;
063 GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
064 GPIO_Init(GPIOA , &GPIO_InitStructure);
065
066 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;
067 GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;
068 GPIO_Init(GPIOA , &GPIO_InitStructure);
069 }
070
071 void RCC_Configuration(void)
072 {
073
074 ErrorStatus HSEStartUpStatus;
075
076
077 RCC_DeInit();
078
079 RCC_HSEConfig(RCC_HSE_ON);
080
081 HSEStartUpStatus = RCC_WaitForHSEStartUp();
082
083 if(HSEStartUpStatus == SUCCESS)
084 {
085
086 RCC_HCLKConfig(RCC_SYSCLK_Div1);
087
088 RCC_PCLK2Config(RCC_HCLK_Div1);
089
090 RCC_PCLK1Config(RCC_HCLK_Div2);
091
092 FLASH_SetLatency(FLASH_Latency_2);
093
094 FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable);
095
096 RCC_PLLConfig(RCC_PLLSource_HSE_Div1, RCC_PLLMul_9);
097
098 RCC_PLLCmd(ENABLE);
099
100 while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET);
101
102 RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);
103
104 while(RCC_GetSYSCLKSource() != 0x08);
105 }
106
107 RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA|RCC_APB2Periph_USART1, ENABLE);
108
109 //RCC_AHBPeriphClockCmd(RCC_AHBPeriph_DMA1, ENABLE);
110
111 //RCC_APB1PeriphClockCmd(RCC_APB1Periph_PWR,ENABLE);
112 //RCC_APB1PeriphClockCmd(RCC_APB1Periph_PWR|RCC_APB1Periph_BKP|RCC_APB1Periph_WWDG, ENABLE);
113
114 }
115
116
117 void USART_Configuration(void)
118 {
119 USART_InitTypeDef USART_InitStructure;
120 USART_ClockInitTypeDef USART_ClockInitStructure;
121
122 USART_ClockInitStructure.USART_Clock = USART_Clock_Disable;
123 USART_ClockInitStructure.USART_CPOL = USART_CPOL_Low;
124 USART_ClockInitStructure.USART_CPHA = USART_CPHA_2Edge;
125 USART_ClockInitStructure.USART_LastBit = USART_LastBit_Disable;
126 USART_ClockInit(USART1 , &USART_ClockInitStructure);
127
128 USART_InitStructure.USART_BaudRate = 9600;
129 USART_InitStructure.USART_WordLength = USART_WordLength_8b;
130 USART_InitStructure.USART_StopBits = USART_StopBits_1;
131 USART_InitStructure.USART_Parity = USART_Parity_No;
132 USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;
133 USART_InitStructure.USART_Mode = USART_Mode_Rx|USART_Mode_Tx;
134 USART_Init(USART1,&USART_InitStructure);
135
136 USART_Cmd(USART1,ENABLE);
137 }
138
139 #if PRINTF_ON
140
141 int fputc(int ch,FILE *f)
142 {
143 USART_SendData(USART1,(u8) ch);
144 while(USART_GetFlagStatus(USART1,USART_FLAG_TC) == RESET);
145 return ch;
146 }
147
148 #endif

声明:本文内容来自网络转载或用户投稿,文章版权归原作者和原出处所有。文中观点,不代表本站立场。若有侵权请联系本站删除(kf@86ic.com)https://www.86ic.net/qiche/adas/261655.html

为您推荐

联系我们

联系我们

在线咨询: QQ交谈

邮箱: kf@86ic.com

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

返回顶部