色婷婷AⅤ一区二区三区|亚洲精品第一国产综合亚AV|久久精品官方网视频|日本28视频香蕉

          新聞中心

          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í)現(xiàn)各種各樣的防破解方案。并且stm32的FLASH在一些輕量級的防掉電存儲方案中也有立足之地。
          stm32的FLASH分為主存儲塊和信息塊。主存儲塊用于保存具體的程序代碼和用戶數(shù)據(jù),信息塊用于負(fù)責(zé)由stm32出廠是放置2KB的啟動(dòng)程序(Bootloader)和512B的用戶配置信息區(qū)。
          主存儲塊是以頁為單位劃分的,一頁大小為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é)存儲,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)閉