新聞中心

        EEPW首頁 > 嵌入式系統 > 設計應用 > stm32 Flash讀寫

        stm32 Flash讀寫

        作者: 時間:2016-11-23 來源:網絡 收藏
        通過對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
        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 為一個字節存儲,16位數據必須地址加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



        關鍵詞: stm32Flash讀

        評論


        技術專區

        關閉
        主站蜘蛛池模板: 莎车县| 贵南县| 唐河县| 镇赉县| 灯塔市| 丰台区| 宕昌县| 丰城市| 淅川县| 普定县| 临西县| 林芝县| 尚志市| 鹤山市| 望谟县| 肥城市| 东方市| 大方县| 忻城县| 渝北区| 东港市| 本溪市| 广宗县| 巴林右旗| 额济纳旗| 建平县| 湾仔区| 阿拉尔市| 平南县| 大石桥市| 南召县| 云龙县| 绥滨县| 固原市| 通山县| 西和县| 龙胜| 沽源县| 建宁县| 板桥市| 商河县|