📄 stm32f10x_flash.s79
字号:
//////////////////////////////////////////////////////////////////////////////
// /
// IAR ARM ANSI C/C++ Compiler V4.42A/W32 EVALUATION 10/Nov/2008 11:44:02 /
// Copyright 1999-2005 IAR Systems. All rights reserved. /
// /
// Cpu mode = thumb /
// Endian = little /
// Stack alignment = 4 /
// Source file = D:\资料\ST\ST\usb\FWLib\library\src\stm32f10x_flash /
// .c /
// Command line = D:\资料\ST\ST\usb\FWLib\library\src\stm32f10x_flash /
// .c -D VECT_TAB_FLASH -D USE_STM3210E_EVAL -lA /
// D:\资料\ST\ST\usb\USBLib\demos\Virtual_COM_Port\pro /
// ject\EWARMv4\STM3210E-EVAL\List\ -o /
// D:\资料\ST\ST\usb\USBLib\demos\Virtual_COM_Port\pro /
// ject\EWARMv4\STM3210E-EVAL\Obj\ -z9 --debug /
// --cpu_mode thumb --endian little --cpu cortex-M3 /
// --stack_align 4 --require_prototypes --fpu None /
// --dlib_config "C:\Program Files\IAR /
// Systems\Embedded Workbench 4.0 /
// Evaluation\arm\LIB\dl7mptnnl8f.h" -I /
// D:\资料\ST\ST\usb\USBLib\demos\Virtual_COM_Port\pro /
// ject\EWARMv4\..\..\include\ -I /
// D:\资料\ST\ST\usb\USBLib\demos\Virtual_COM_Port\pro /
// ject\EWARMv4\..\..\..\..\library\inc\ -I /
// D:\资料\ST\ST\usb\USBLib\demos\Virtual_COM_Port\pro /
// ject\EWARMv4\..\..\..\..\..\FWLib\library\inc\ -I /
// "C:\Program Files\IAR Systems\Embedded Workbench /
// 4.0 Evaluation\arm\INC\" --inline_threshold=2 /
// List file = D:\资料\ST\ST\usb\USBLib\demos\Virtual_COM_Port\pro /
// ject\EWARMv4\STM3210E-EVAL\List\stm32f10x_flash.s79 /
// /
// /
//////////////////////////////////////////////////////////////////////////////
NAME stm32f10x_flash
RTMODEL "StackAlign4", "USED"
RTMODEL "__cpu_mode", "__pcs__thumb"
RTMODEL "__data_model", "absolute"
RTMODEL "__endian", "little"
RTMODEL "__rt_version", "6"
RSEG CSTACK:DATA:NOROOT(2)
??DataTable0 EQU 0
??DataTable1 EQU 0
PUBLIC FLASH_HalfCycleAccessCmd
FUNCTION FLASH_HalfCycleAccessCmd,0203H
PUBLIC FLASH_PrefetchBufferCmd
FUNCTION FLASH_PrefetchBufferCmd,0203H
PUBLIC FLASH_SetLatency
FUNCTION FLASH_SetLatency,0203H
CFI Names cfiNames0
CFI StackFrame CFA R13 HUGEDATA
CFI Resource R0:32, R1:32, R2:32, R3:32, R4:32, R5:32, R6:32, R7:32
CFI Resource R8:32, R9:32, R10:32, R11:32, R12:32, R13:32, R14:32
CFI VirtualResource ?RET:32
CFI EndNames cfiNames0
CFI Common cfiCommon0 Using cfiNames0
CFI CodeAlign 2
CFI DataAlign 4
CFI ReturnAddress ?RET CODE
CFI CFA R13+0
CFI R0 Undefined
CFI R1 Undefined
CFI R2 Undefined
CFI R3 Undefined
CFI R4 SameValue
CFI R5 SameValue
CFI R6 SameValue
CFI R7 SameValue
CFI R8 SameValue
CFI R9 SameValue
CFI R10 SameValue
CFI R11 SameValue
CFI R12 Undefined
CFI R14 Undefined
CFI ?RET R14
CFI EndCommon cfiCommon0
// D:\资料\ST\ST\usb\FWLib\library\src\stm32f10x_flash.c
// 1 /******************** (C) COPYRIGHT 2008 STMicroelectronics ********************
// 2 * File Name : stm32f10x_flash.c
// 3 * Author : MCD Application Team
// 4 * Version : V2.0.1
// 5 * Date : 06/13/2008
// 6 * Description : This file provides all the FLASH firmware functions.
// 7 ********************************************************************************
// 8 * THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
// 9 * WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE TIME.
// 10 * AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY DIRECT,
// 11 * INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING FROM THE
// 12 * CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE CODING
// 13 * INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
// 14 *******************************************************************************/
// 15
// 16 /* Includes ------------------------------------------------------------------*/
// 17 #include "stm32f10x_flash.h"
// 18
// 19 /* Private typedef -----------------------------------------------------------*/
// 20 /* Private define ------------------------------------------------------------*/
// 21 /* Flash Access Control Register bits */
// 22 #define ACR_LATENCY_Mask ((u32)0x00000038)
// 23 #define ACR_HLFCYA_Mask ((u32)0xFFFFFFF7)
// 24 #define ACR_PRFTBE_Mask ((u32)0xFFFFFFEF)
// 25
// 26 #ifdef _FLASH_PROG
// 27 /* Flash Access Control Register bits */
// 28 #define ACR_PRFTBS_Mask ((u32)0x00000020)
// 29
// 30 /* Flash Control Register bits */
// 31 #define CR_PG_Set ((u32)0x00000001)
// 32 #define CR_PG_Reset ((u32)0x00001FFE)
// 33
// 34 #define CR_PER_Set ((u32)0x00000002)
// 35 #define CR_PER_Reset ((u32)0x00001FFD)
// 36
// 37 #define CR_MER_Set ((u32)0x00000004)
// 38 #define CR_MER_Reset ((u32)0x00001FFB)
// 39
// 40 #define CR_OPTPG_Set ((u32)0x00000010)
// 41 #define CR_OPTPG_Reset ((u32)0x00001FEF)
// 42
// 43 #define CR_OPTER_Set ((u32)0x00000020)
// 44 #define CR_OPTER_Reset ((u32)0x00001FDF)
// 45
// 46 #define CR_STRT_Set ((u32)0x00000040)
// 47
// 48 #define CR_LOCK_Set ((u32)0x00000080)
// 49
// 50 /* FLASH Mask */
// 51 #define RDPRT_Mask ((u32)0x00000002)
// 52 #define WRP0_Mask ((u32)0x000000FF)
// 53 #define WRP1_Mask ((u32)0x0000FF00)
// 54 #define WRP2_Mask ((u32)0x00FF0000)
// 55 #define WRP3_Mask ((u32)0xFF000000)
// 56
// 57 /* FLASH Keys */
// 58 #define RDP_Key ((u16)0x00A5)
// 59 #define FLASH_KEY1 ((u32)0x45670123)
// 60 #define FLASH_KEY2 ((u32)0xCDEF89AB)
// 61
// 62 /* Delay definition */
// 63 #define EraseTimeout ((u32)0x00000FFF)
// 64 #define ProgramTimeout ((u32)0x0000000F)
// 65 #endif
// 66
// 67 /* Private macro -------------------------------------------------------------*/
// 68 /* Private variables ---------------------------------------------------------*/
// 69 /* Private function prototypes -----------------------------------------------*/
// 70 #ifdef _FLASH_PROG
// 71 static void delay(void);
// 72 #endif
// 73
// 74 /* Private functions ---------------------------------------------------------*/
// 75 /*******************************************************************************
// 76 * Function Name : FLASH_SetLatency
// 77 * Description : Sets the code latency value.
// 78 * Input : - FLASH_Latency: specifies the FLASH Latency value.
// 79 * This parameter can be one of the following values:
// 80 * - FLASH_Latency_0: FLASH Zero Latency cycle
// 81 * - FLASH_Latency_1: FLASH One Latency cycle
// 82 * - FLASH_Latency_2: FLASH Two Latency cycles
// 83 * Output : None
// 84 * Return : None
// 85 *******************************************************************************/
RSEG CODE:CODE:NOROOT(2)
CFI Block cfiBlock0 Using cfiCommon0
CFI Function FLASH_SetLatency
THUMB
// 86 void FLASH_SetLatency(u32 FLASH_Latency)
// 87 {
// 88 /* Check the parameters */
// 89 assert_param(IS_FLASH_LATENCY(FLASH_Latency));
// 90
// 91 /* Sets the Latency value */
// 92 FLASH->ACR &= ACR_LATENCY_Mask;
FLASH_SetLatency:
LDR.N R1,??DataTable2 ;; 0x40022000
LDR R2,[R1, #+0]
ANDS R2,R2,#0x38
B.N ??Subroutine0_0
CFI EndBlock cfiBlock0
// 93 FLASH->ACR |= FLASH_Latency;
// 94 }
// 95
// 96 /*******************************************************************************
// 97 * Function Name : FLASH_HalfCycleAccessCmd
// 98 * Description : Enables or disables the Half cycle flash access.
// 99 * Input : - FLASH_HalfCycle: specifies the FLASH Half cycle Access mode.
// 100 * This parameter can be one of the following values:
// 101 * - FLASH_HalfCycleAccess_Enable: FLASH Half Cycle Enable
// 102 * - FLASH_HalfCycleAccess_Disable: FLASH Half Cycle Disable
// 103 * Output : None
// 104 * Return : None
// 105 *******************************************************************************/
RSEG CODE:CODE:NOROOT(2)
CFI Block cfiBlock1 Using cfiCommon0
CFI Function FLASH_HalfCycleAccessCmd
THUMB
// 106 void FLASH_HalfCycleAccessCmd(u32 FLASH_HalfCycleAccess)
// 107 {
// 108 /* Check the parameters */
// 109 assert_param(IS_FLASH_HALFCYCLEACCESS_STATE(FLASH_HalfCycleAccess));
// 110
// 111 /* Enable or disable the Half cycle access */
// 112 FLASH->ACR &= ACR_HLFCYA_Mask;
FLASH_HalfCycleAccessCmd:
LDR.N R1,??DataTable2 ;; 0x40022000
MOVS R3,#+8
B.N ?Subroutine0
CFI EndBlock cfiBlock1
// 113 FLASH->ACR |= FLASH_HalfCycleAccess;
// 114 }
// 115
// 116 /*******************************************************************************
// 117 * Function Name : FLASH_PrefetchBufferCmd
// 118 * Description : Enables or disables the Prefetch Buffer.
// 119 * Input : - FLASH_PrefetchBuffer: specifies the Prefetch buffer status.
// 120 * This parameter can be one of the following values:
// 121 * - FLASH_PrefetchBuffer_Enable: FLASH Prefetch Buffer Enable
// 122 * - FLASH_PrefetchBuffer_Disable: FLASH Prefetch Buffer Disable
// 123 * Output : None
// 124 * Return : None
// 125 *******************************************************************************/
RSEG CODE:CODE:NOROOT(2)
CFI Block cfiBlock2 Using cfiCommon0
CFI Function FLASH_PrefetchBufferCmd
THUMB
// 126 void FLASH_PrefetchBufferCmd(u32 FLASH_PrefetchBuffer)
// 127 {
// 128 /* Check the parameters */
// 129 assert_param(IS_FLASH_PREFETCHBUFFER_STATE(FLASH_PrefetchBuffer));
// 130
// 131 /* Enable or disable the Prefetch Buffer */
// 132 FLASH->ACR &= ACR_PRFTBE_Mask;
FLASH_PrefetchBufferCmd:
LDR.N R1,??DataTable2 ;; 0x40022000
MOVS R3,#+16
CFI EndBlock cfiBlock2
REQUIRE ?Subroutine0
;; // Fall through to label ?Subroutine0
// 133 FLASH->ACR |= FLASH_PrefetchBuffer;
// 134 }
RSEG CODE:CODE:NOROOT(2)
CFI Block cfiBlock3 Using cfiCommon0
CFI NoFunction
THUMB
?Subroutine0:
LDR R2,[R1, #+0]
BICS R2,R2,R3
??Subroutine0_0:
STR R2,[R1, #+0]
LDR R2,[R1, #+0]
ORRS R0,R0,R2
STR R0,[R1, #+0]
BX LR ;; return
CFI EndBlock cfiBlock3
RSEG CODE:CODE:NOROOT(2)
DATA
??DataTable2:
DC32 0x40022000
END
// 135
// 136 #ifdef _FLASH_PROG
// 137 /*******************************************************************************
// 138 * Function Name : FLASH_Unlock
// 139 * Description : Unlocks the FLASH Program Erase Controller.
// 140 * Input : None
// 141 * Output : None
// 142 * Return : None
// 143 *******************************************************************************/
// 144 void FLASH_Unlock(void)
// 145 {
// 146 /* Authorize the FPEC Access */
// 147 FLASH->KEYR = FLASH_KEY1;
// 148 FLASH->KEYR = FLASH_KEY2;
// 149 }
// 150
// 151 /*******************************************************************************
// 152 * Function Name : FLASH_Lock
// 153 * Description : Locks the FLASH Program Erase Controller.
// 154 * Input : None
// 155 * Output : None
// 156 * Return : None
// 157 *******************************************************************************/
// 158 void FLASH_Lock(void)
// 159 {
// 160 /* Set the Lock Bit to lock the FPEC and the FCR */
// 161 FLASH->CR |= CR_LOCK_Set;
// 162 }
// 163
// 164 /*******************************************************************************
// 165 * Function Name : FLASH_ErasePage
// 166 * Description : Erases a specified FLASH page.
// 167 * Input : - Page_Address: The page address to be erased.
// 168 * Output : None
// 169 * Return : FLASH Status: The returned value can be: FLASH_BUSY,
// 170 * FLASH_ERROR_PG, FLASH_ERROR_WRP, FLASH_COMPLETE or
// 171 * FLASH_TIMEOUT.
// 172 *******************************************************************************/
// 173 FLASH_Status FLASH_ErasePage(u32 Page_Address)
// 174 {
// 175 FLASH_Status status = FLASH_COMPLETE;
// 176
// 177 /* Check the parameters */
// 178 assert_param(IS_FLASH_ADDRESS(Page_Address));
// 179
// 180 /* Wait for last operation to be completed */
// 181 status = FLASH_WaitForLastOperation(EraseTimeout);
// 182
// 183 if(status == FLASH_COMPLETE)
// 184 {
// 185 /* if the previous operation is completed, proceed to erase the page */
// 186 FLASH->CR|= CR_PER_Set;
// 187 FLASH->AR = Page_Address;
// 188 FLASH->CR|= CR_STRT_Set;
// 189
// 190 /* Wait for last operation to be completed */
// 191 status = FLASH_WaitForLastOperation(EraseTimeout);
// 192
// 193 if(status != FLASH_BUSY)
// 194 {
// 195 /* if the erase operation is completed, disable the PER Bit */
// 196 FLASH->CR &= CR_PER_Reset;
// 197 }
// 198 }
// 199 /* Return the Erase Status */
// 200 return status;
// 201 }
// 202
// 203 /*******************************************************************************
// 204 * Function Name : FLASH_EraseAllPages
// 205 * Description : Erases all FLASH pages.
// 206 * Input : None
// 207 * Output : None
// 208 * Return : FLASH Status: The returned value can be: FLASH_BUSY,
// 209 * FLASH_ERROR_PG, FLASH_ERROR_WRP, FLASH_COMPLETE or
// 210 * FLASH_TIMEOUT.
// 211 *******************************************************************************/
// 212 FLASH_Status FLASH_EraseAllPages(void)
// 213 {
// 214 FLASH_Status status = FLASH_COMPLETE;
// 215
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -