新聞中心

stm32 Flash讀寫

作者: 時(shí)間:2016-11-23 來源:網(wǎng)絡(luò) 收藏
通過對stm32內(nèi)部的flash的讀寫可以實(shí)現(xiàn)對stm32的編程操作。
stm32 的內(nèi)置可編程Flash在許多場合具有十分重要的意義。如其支持ICP特性使得開發(fā)人員對stm32可以警醒調(diào)試開發(fā),可以通過JTAG和SWD接口對stm32進(jìn)行程序燒寫;支持IAP特性使得開發(fā)人員可以在stm32運(yùn)行程序的時(shí)候?qū)ζ鋬?nèi)部程序進(jìn)行更新操作。對一些對數(shù)據(jù)安全有要求的場合,可編程FLASH可以結(jié)合stm32內(nèi)部唯一的身份標(biāo)識(shí)實(shí)現(xiàn)各種各樣的防破解方案。并且stm32的FLASH在一些輕量級的防掉電存儲(chǔ)方案中也有立足之地。
stm32的FLASH分為主存儲(chǔ)塊和信息塊。主存儲(chǔ)塊用于保存具體的程序代碼和用戶數(shù)據(jù),信息塊用于負(fù)責(zé)由stm32出廠是放置2KB的啟動(dòng)程序(Bootloader)和512B的用戶配置信息區(qū)。
主存儲(chǔ)塊是以頁為單位劃分的,一頁大小為1KB。范圍為從地址0x08000000開始的128KB內(nèi)。
對Flash 的寫入操作要 “先擦除后寫入”的原則;
stm32的內(nèi)置flash 編程操作都是以頁為單位寫入的,而寫入的操作必須要以16位半字寬度數(shù)據(jù)位單位,允許跨頁寫,寫入非16位數(shù)據(jù)時(shí)將導(dǎo)致stm32內(nèi)部總線錯(cuò)誤。
進(jìn)行內(nèi)置flash讀寫時(shí),必須要打開內(nèi)部Rc振蕩器。
main.c:
001#include "stm32f10x.h"
002#include "stdio.h"
003
004#define PRINTF_ON 1
005
006void RCC_Configuration(void);
007void GPIO_Configuration(void);
008void USART_Configuration(void);
009
010u32 count=0;
011
012u16 data[5]={0x0001,0x0002,0x0003,0x0004,0x0005};
013
014int main(void)
015{
016RCC_Configuration();
017GPIO_Configuration();
018USART_Configuration();
019
020RCC_HSICmd(ENABLE);
021
022FLASH_Unlock();
023
024FLASH_ClearFlag(FLASH_FLAG_EOP|FLASH_FLAG_PGERR|FLASH_FLAG_WRPRTERR);
025
026FLASH_ErasePage(0x8002000);
027
028while(count < 5)
029{
030FLASH_ProgramHalfWord((0x8002000 +count*2),data[count]); //flash 為一個(gè)字節(jié)存儲(chǔ),16位數(shù)據(jù)必須地址加2
031
032count++;
033
034}
035
036FLASH_Lock();
037
038count = 0;
039
040printf("The Five Data Is : ");
041
042while(count < 5)
043{
044
045printf("%d ",*(u8 *)(0x8002000 + count*2)); //讀取方法
046
047count++;
048
049
050}
051
052while(1);
053
054}
055
056void GPIO_Configuration(void)
057{
058GPIO_InitTypeDef GPIO_InitStructure;
059
060GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
061
062GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9;
063GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
064GPIO_Init(GPIOA , &GPIO_InitStructure);
065
066GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;
067GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;
068GPIO_Init(GPIOA , &GPIO_InitStructure);
069}
070
071void RCC_Configuration(void)
072{
073
074ErrorStatus HSEStartUpStatus;
075
076
077RCC_DeInit();
078
079RCC_HSEConfig(RCC_HSE_ON);
080
081HSEStartUpStatus = RCC_WaitForHSEStartUp();
082
083if(HSEStartUpStatus == SUCCESS)
084{
085
086RCC_HCLKConfig(RCC_SYSCLK_Div1);
087
088RCC_PCLK2Config(RCC_HCLK_Div1);
089
090RCC_PCLK1Config(RCC_HCLK_Div2);
091
092FLASH_SetLatency(FLASH_Latency_2);
093
094FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable);
095
096RCC_PLLConfig(RCC_PLLSource_HSE_Div1, RCC_PLLMul_9);
097
098RCC_PLLCmd(ENABLE);
099
100while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET);
101
102RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);
103
104while(RCC_GetSYSCLKSource() != 0x08);
105}
106
107RCC_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
117void USART_Configuration(void)
118{
119USART_InitTypeDef USART_InitStructure;
120USART_ClockInitTypeDef USART_ClockInitStructure;
121
122USART_ClockInitStructure.USART_Clock = USART_Clock_Disable;
123USART_ClockInitStructure.USART_CPOL = USART_CPOL_Low;
124USART_ClockInitStructure.USART_CPHA = USART_CPHA_2Edge;
125USART_ClockInitStructure.USART_LastBit = USART_LastBit_Disable;
126USART_ClockInit(USART1 , &USART_ClockInitStructure);
127
128USART_InitStructure.USART_BaudRate = 9600;
129USART_InitStructure.USART_WordLength = USART_WordLength_8b;
130USART_InitStructure.USART_StopBits = USART_StopBits_1;
131USART_InitStructure.USART_Parity = USART_Parity_No;
132USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;
133USART_InitStructure.USART_Mode = USART_Mode_Rx|USART_Mode_Tx;
134USART_Init(USART1,&USART_InitStructure);
135
136USART_Cmd(USART1,ENABLE);
137}
138
139#if PRINTF_ON
140
141int fputc(int ch,FILE *f)
142{
143USART_SendData(USART1,(u8) ch);
144while(USART_GetFlagStatus(USART1,USART_FLAG_TC) == RESET);
145return ch;
146}
147
148#endif



關(guān)鍵詞: stm32Flash讀

評論


技術(shù)專區(qū)

關(guān)閉