3887 lines
250 KiB
Plaintext
3887 lines
250 KiB
Plaintext
|
ARM GAS /tmp/ccCw6Rev.s page 1
|
|||
|
|
|||
|
|
|||
|
1 .cpu cortex-m7
|
|||
|
2 .eabi_attribute 28, 1
|
|||
|
3 .eabi_attribute 20, 1
|
|||
|
4 .eabi_attribute 21, 1
|
|||
|
5 .eabi_attribute 23, 3
|
|||
|
6 .eabi_attribute 24, 1
|
|||
|
7 .eabi_attribute 25, 1
|
|||
|
8 .eabi_attribute 26, 1
|
|||
|
9 .eabi_attribute 30, 1
|
|||
|
10 .eabi_attribute 34, 1
|
|||
|
11 .eabi_attribute 18, 4
|
|||
|
12 .file "stm32h7xx_hal_flash.c"
|
|||
|
13 .text
|
|||
|
14 .Ltext0:
|
|||
|
15 .cfi_sections .debug_frame
|
|||
|
16 .section .text.HAL_FLASH_EndOfOperationCallback,"ax",%progbits
|
|||
|
17 .align 1
|
|||
|
18 .weak HAL_FLASH_EndOfOperationCallback
|
|||
|
19 .arch armv7e-m
|
|||
|
20 .syntax unified
|
|||
|
21 .thumb
|
|||
|
22 .thumb_func
|
|||
|
23 .fpu fpv5-d16
|
|||
|
25 HAL_FLASH_EndOfOperationCallback:
|
|||
|
26 .LVL0:
|
|||
|
27 .LFB144:
|
|||
|
28 .file 1 "Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c"
|
|||
|
1:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /**
|
|||
|
2:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** ******************************************************************************
|
|||
|
3:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @file stm32h7xx_hal_flash.c
|
|||
|
4:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @author MCD Application Team
|
|||
|
5:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @brief FLASH HAL module driver.
|
|||
|
6:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * This file provides firmware functions to manage the following
|
|||
|
7:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * functionalities of the internal FLASH memory:
|
|||
|
8:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * + Program operations functions
|
|||
|
9:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * + Memory Control functions
|
|||
|
10:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * + Peripheral Errors functions
|
|||
|
11:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** *
|
|||
|
12:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** @verbatim
|
|||
|
13:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** ==============================================================================
|
|||
|
14:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** ##### FLASH peripheral features #####
|
|||
|
15:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** ==============================================================================
|
|||
|
16:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
17:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** [..] The Flash memory interface manages CPU AXI I-Code and D-Code accesses
|
|||
|
18:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** to the Flash memory. It implements the erase and program Flash memory operations
|
|||
|
19:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** and the read and write protection mechanisms.
|
|||
|
20:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
21:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** [..] The FLASH main features are:
|
|||
|
22:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** (+) Flash memory read operations
|
|||
|
23:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** (+) Flash memory program/erase operations
|
|||
|
24:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** (+) Read / write protections
|
|||
|
25:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** (+) Option bytes programming
|
|||
|
26:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** (+) Error code correction (ECC) : Data in flash are 266-bits word
|
|||
|
27:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** (10 bits added per flash word)
|
|||
|
28:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
29:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** ##### How to use this driver #####
|
|||
|
30:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** ==============================================================================
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 2
|
|||
|
|
|||
|
|
|||
|
31:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** [..]
|
|||
|
32:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** This driver provides functions and macros to configure and program the FLASH
|
|||
|
33:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** memory of all STM32H7xx devices.
|
|||
|
34:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
35:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** (#) FLASH Memory IO Programming functions:
|
|||
|
36:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** (++) Lock and Unlock the FLASH interface using HAL_FLASH_Unlock() and
|
|||
|
37:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** HAL_FLASH_Lock() functions
|
|||
|
38:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** (++) Program functions: 256-bit word only
|
|||
|
39:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** (++) There Two modes of programming :
|
|||
|
40:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** (+++) Polling mode using HAL_FLASH_Program() function
|
|||
|
41:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** (+++) Interrupt mode using HAL_FLASH_Program_IT() function
|
|||
|
42:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
43:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** (#) Interrupts and flags management functions :
|
|||
|
44:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** (++) Handle FLASH interrupts by calling HAL_FLASH_IRQHandler()
|
|||
|
45:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** (++) Callback functions are called when the flash operations are finished :
|
|||
|
46:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** HAL_FLASH_EndOfOperationCallback() when everything is ok, otherwise
|
|||
|
47:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** HAL_FLASH_OperationErrorCallback()
|
|||
|
48:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** (++) Get error flag status by calling HAL_FLASH_GetError()
|
|||
|
49:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
50:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** (#) Option bytes management functions :
|
|||
|
51:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** (++) Lock and Unlock the option bytes using HAL_FLASH_OB_Unlock() and
|
|||
|
52:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** HAL_FLASH_OB_Lock() functions
|
|||
|
53:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** (++) Launch the reload of the option bytes using HAL_FLASH_OB_Launch() function.
|
|||
|
54:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** In this case, a reset is generated
|
|||
|
55:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** [..]
|
|||
|
56:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** In addition to these functions, this driver includes a set of macros allowing
|
|||
|
57:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** to handle the following operations:
|
|||
|
58:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** (+) Set the latency
|
|||
|
59:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** (+) Enable/Disable the FLASH interrupts
|
|||
|
60:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** (+) Monitor the FLASH flags status
|
|||
|
61:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** [..]
|
|||
|
62:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** (@) For any Flash memory program operation (erase or program), the CPU clock frequency
|
|||
|
63:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** (HCLK) must be at least 1MHz.
|
|||
|
64:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** (@) The contents of the Flash memory are not guaranteed if a device reset occurs during
|
|||
|
65:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** a Flash memory operation.
|
|||
|
66:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** (@) The application can simultaneously request a read and a write operation through each AXI
|
|||
|
67:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** interface.
|
|||
|
68:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** As the Flash memory is divided into two independent banks, the embedded Flash
|
|||
|
69:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** memory interface can drive different operations at the same time on each bank. For
|
|||
|
70:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** example a read, write or erase operation can be executed on bank 1 while another read,
|
|||
|
71:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** write or erase operation is executed on bank 2.
|
|||
|
72:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
73:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** @endverbatim
|
|||
|
74:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** ******************************************************************************
|
|||
|
75:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @attention
|
|||
|
76:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** *
|
|||
|
77:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * <h2><center>© COPYRIGHT(c) 2017 STMicroelectronics.
|
|||
|
78:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * All rights reserved.</center></h2>
|
|||
|
79:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** *
|
|||
|
80:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * This software component is licensed by ST under BSD 3-Clause license,
|
|||
|
81:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * the "License"; You may not use this file except in compliance with the
|
|||
|
82:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * License. You may obtain a copy of the License at:
|
|||
|
83:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * opensource.org/licenses/BSD-3-Clause
|
|||
|
84:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** *
|
|||
|
85:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** ******************************************************************************
|
|||
|
86:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** */
|
|||
|
87:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 3
|
|||
|
|
|||
|
|
|||
|
88:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Includes ------------------------------------------------------------------*/
|
|||
|
89:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #include "stm32h7xx_hal.h"
|
|||
|
90:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
91:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /** @addtogroup STM32H7xx_HAL_Driver
|
|||
|
92:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @{
|
|||
|
93:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** */
|
|||
|
94:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
95:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /** @defgroup FLASH FLASH
|
|||
|
96:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @brief FLASH HAL module driver
|
|||
|
97:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @{
|
|||
|
98:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** */
|
|||
|
99:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
100:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #ifdef HAL_FLASH_MODULE_ENABLED
|
|||
|
101:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
102:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Private typedef -----------------------------------------------------------*/
|
|||
|
103:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Private define ------------------------------------------------------------*/
|
|||
|
104:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /** @addtogroup FLASH_Private_Constants
|
|||
|
105:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @{
|
|||
|
106:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** */
|
|||
|
107:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #define FLASH_TIMEOUT_VALUE 50000U /* 50 s */
|
|||
|
108:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /**
|
|||
|
109:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @}
|
|||
|
110:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** */
|
|||
|
111:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Private macro -------------------------------------------------------------*/
|
|||
|
112:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Private variables ---------------------------------------------------------*/
|
|||
|
113:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** FLASH_ProcessTypeDef pFlash;
|
|||
|
114:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Private function prototypes -----------------------------------------------*/
|
|||
|
115:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Exported functions ---------------------------------------------------------*/
|
|||
|
116:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
117:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /** @defgroup FLASH_Exported_Functions FLASH Exported functions
|
|||
|
118:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @{
|
|||
|
119:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** */
|
|||
|
120:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
121:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /** @defgroup FLASH_Exported_Functions_Group1 Programming operation functions
|
|||
|
122:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @brief Programming operation functions
|
|||
|
123:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** *
|
|||
|
124:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** @verbatim
|
|||
|
125:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** ===============================================================================
|
|||
|
126:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** ##### Programming operation functions #####
|
|||
|
127:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** ===============================================================================
|
|||
|
128:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** [..]
|
|||
|
129:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** This subsection provides a set of functions allowing to manage the FLASH
|
|||
|
130:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** program operations.
|
|||
|
131:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
132:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** @endverbatim
|
|||
|
133:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @{
|
|||
|
134:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** */
|
|||
|
135:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
136:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /**
|
|||
|
137:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @brief Program flash word at a specified address
|
|||
|
138:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @param TypeProgram Indicate the way to program at a specified address.
|
|||
|
139:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * This parameter can be a value of @ref FLASH_Type_Program
|
|||
|
140:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @param FlashAddress specifies the address to be programmed.
|
|||
|
141:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @param DataAddress specifies the address of data to be programmed
|
|||
|
142:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** *
|
|||
|
143:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @retval HAL_StatusTypeDef HAL Status
|
|||
|
144:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** */
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 4
|
|||
|
|
|||
|
|
|||
|
145:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** HAL_StatusTypeDef HAL_FLASH_Program(uint32_t TypeProgram, uint32_t FlashAddress, uint32_t DataAddre
|
|||
|
146:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
147:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** HAL_StatusTypeDef status;
|
|||
|
148:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** __IO uint32_t *dest_addr = (__IO uint32_t *)FlashAddress;
|
|||
|
149:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** __IO uint32_t *src_addr = (__IO uint32_t*)DataAddress;
|
|||
|
150:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** uint32_t bank;
|
|||
|
151:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** uint8_t row_index = FLASH_NB_32BITWORD_IN_FLASHWORD;
|
|||
|
152:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
153:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Check the parameters */
|
|||
|
154:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** assert_param(IS_FLASH_TYPEPROGRAM(TypeProgram));
|
|||
|
155:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** assert_param(IS_FLASH_PROGRAM_ADDRESS(FlashAddress));
|
|||
|
156:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
157:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Process Locked */
|
|||
|
158:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** __HAL_LOCK(&pFlash);
|
|||
|
159:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
160:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #if defined (FLASH_OPTCR_PG_OTP)
|
|||
|
161:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if((IS_FLASH_PROGRAM_ADDRESS_BANK1(FlashAddress)) || (IS_FLASH_PROGRAM_ADDRESS_OTP(FlashAddress))
|
|||
|
162:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #else
|
|||
|
163:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if(IS_FLASH_PROGRAM_ADDRESS_BANK1(FlashAddress))
|
|||
|
164:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #endif /* FLASH_OPTCR_PG_OTP */
|
|||
|
165:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
166:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** bank = FLASH_BANK_1;
|
|||
|
167:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
168:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #if defined (DUAL_BANK)
|
|||
|
169:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** else if(IS_FLASH_PROGRAM_ADDRESS_BANK2(FlashAddress))
|
|||
|
170:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
171:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** bank = FLASH_BANK_2;
|
|||
|
172:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
173:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #endif /* DUAL_BANK */
|
|||
|
174:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** else
|
|||
|
175:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
176:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** return HAL_ERROR;
|
|||
|
177:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
178:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
179:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Reset error code */
|
|||
|
180:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** pFlash.ErrorCode = HAL_FLASH_ERROR_NONE;
|
|||
|
181:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
182:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Wait for last operation to be completed */
|
|||
|
183:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** status = FLASH_WaitForLastOperation((uint32_t)FLASH_TIMEOUT_VALUE, bank);
|
|||
|
184:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
185:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if(status == HAL_OK)
|
|||
|
186:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
187:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #if defined (DUAL_BANK)
|
|||
|
188:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if(bank == FLASH_BANK_1)
|
|||
|
189:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
190:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #if defined (FLASH_OPTCR_PG_OTP)
|
|||
|
191:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if (TypeProgram == FLASH_TYPEPROGRAM_OTPWORD)
|
|||
|
192:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
193:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Set OTP_PG bit */
|
|||
|
194:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** SET_BIT(FLASH->OPTCR, FLASH_OPTCR_PG_OTP);
|
|||
|
195:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
196:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** else
|
|||
|
197:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #endif /* FLASH_OPTCR_PG_OTP */
|
|||
|
198:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
199:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Set PG bit */
|
|||
|
200:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** SET_BIT(FLASH->CR1, FLASH_CR_PG);
|
|||
|
201:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 5
|
|||
|
|
|||
|
|
|||
|
202:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
203:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** else
|
|||
|
204:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
205:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Set PG bit */
|
|||
|
206:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** SET_BIT(FLASH->CR2, FLASH_CR_PG);
|
|||
|
207:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
208:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #else /* Single Bank */
|
|||
|
209:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #if defined (FLASH_OPTCR_PG_OTP)
|
|||
|
210:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if (TypeProgram == FLASH_TYPEPROGRAM_OTPWORD)
|
|||
|
211:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
212:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Set OTP_PG bit */
|
|||
|
213:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** SET_BIT(FLASH->OPTCR, FLASH_OPTCR_PG_OTP);
|
|||
|
214:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
215:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** else
|
|||
|
216:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #endif /* FLASH_OPTCR_PG_OTP */
|
|||
|
217:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
218:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Set PG bit */
|
|||
|
219:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** SET_BIT(FLASH->CR1, FLASH_CR_PG);
|
|||
|
220:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
221:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #endif /* DUAL_BANK */
|
|||
|
222:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
223:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** __ISB();
|
|||
|
224:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** __DSB();
|
|||
|
225:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
226:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #if defined (FLASH_OPTCR_PG_OTP)
|
|||
|
227:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if (TypeProgram == FLASH_TYPEPROGRAM_OTPWORD)
|
|||
|
228:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
229:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Program an OTP word (16 bits) */
|
|||
|
230:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** *(__IO uint16_t *)FlashAddress = *(__IO uint16_t*)DataAddress;
|
|||
|
231:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
232:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** else
|
|||
|
233:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #endif /* FLASH_OPTCR_PG_OTP */
|
|||
|
234:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
235:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Program the flash word */
|
|||
|
236:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** do
|
|||
|
237:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
238:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** *dest_addr = *src_addr;
|
|||
|
239:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** dest_addr++;
|
|||
|
240:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** src_addr++;
|
|||
|
241:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** row_index--;
|
|||
|
242:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** } while (row_index != 0U);
|
|||
|
243:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
244:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
245:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** __ISB();
|
|||
|
246:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** __DSB();
|
|||
|
247:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
248:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Wait for last operation to be completed */
|
|||
|
249:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** status = FLASH_WaitForLastOperation((uint32_t)FLASH_TIMEOUT_VALUE, bank);
|
|||
|
250:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
251:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #if defined (DUAL_BANK)
|
|||
|
252:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #if defined (FLASH_OPTCR_PG_OTP)
|
|||
|
253:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if (TypeProgram == FLASH_TYPEPROGRAM_OTPWORD)
|
|||
|
254:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
255:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* If the program operation is completed, disable the OTP_PG */
|
|||
|
256:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** CLEAR_BIT(FLASH->OPTCR, FLASH_OPTCR_PG_OTP);
|
|||
|
257:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
258:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** else
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 6
|
|||
|
|
|||
|
|
|||
|
259:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #endif /* FLASH_OPTCR_PG_OTP */
|
|||
|
260:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
261:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if(bank == FLASH_BANK_1)
|
|||
|
262:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
263:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* If the program operation is completed, disable the PG */
|
|||
|
264:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** CLEAR_BIT(FLASH->CR1, FLASH_CR_PG);
|
|||
|
265:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
266:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** else
|
|||
|
267:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
268:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* If the program operation is completed, disable the PG */
|
|||
|
269:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** CLEAR_BIT(FLASH->CR2, FLASH_CR_PG);
|
|||
|
270:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
271:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
272:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #else /* Single Bank */
|
|||
|
273:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #if defined (FLASH_OPTCR_PG_OTP)
|
|||
|
274:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if (TypeProgram == FLASH_TYPEPROGRAM_OTPWORD)
|
|||
|
275:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
276:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* If the program operation is completed, disable the OTP_PG */
|
|||
|
277:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** CLEAR_BIT(FLASH->OPTCR, FLASH_OPTCR_PG_OTP);
|
|||
|
278:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
279:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** else
|
|||
|
280:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #endif /* FLASH_OPTCR_PG_OTP */
|
|||
|
281:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
282:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* If the program operation is completed, disable the PG */
|
|||
|
283:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** CLEAR_BIT(FLASH->CR1, FLASH_CR_PG);
|
|||
|
284:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
285:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #endif /* DUAL_BANK */
|
|||
|
286:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
287:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
288:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Process Unlocked */
|
|||
|
289:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** __HAL_UNLOCK(&pFlash);
|
|||
|
290:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
291:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** return status;
|
|||
|
292:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
293:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
294:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /**
|
|||
|
295:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @brief Program flash words of 256 bits at a specified address with interrupt enabled.
|
|||
|
296:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @param TypeProgram Indicate the way to program at a specified address.
|
|||
|
297:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * This parameter can be a value of @ref FLASH_Type_Program
|
|||
|
298:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @param FlashAddress specifies the address to be programmed.
|
|||
|
299:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @param DataAddress specifies the address of data (256 bits) to be programmed
|
|||
|
300:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** *
|
|||
|
301:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @retval HAL Status
|
|||
|
302:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** */
|
|||
|
303:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** HAL_StatusTypeDef HAL_FLASH_Program_IT(uint32_t TypeProgram, uint32_t FlashAddress, uint32_t DataAd
|
|||
|
304:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
305:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** HAL_StatusTypeDef status;
|
|||
|
306:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** __IO uint32_t *dest_addr = (__IO uint32_t*)FlashAddress;
|
|||
|
307:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** __IO uint32_t *src_addr = (__IO uint32_t*)DataAddress;
|
|||
|
308:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** uint32_t bank;
|
|||
|
309:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** uint8_t row_index = FLASH_NB_32BITWORD_IN_FLASHWORD;
|
|||
|
310:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
311:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Check the parameters */
|
|||
|
312:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** assert_param(IS_FLASH_TYPEPROGRAM(TypeProgram));
|
|||
|
313:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** assert_param(IS_FLASH_PROGRAM_ADDRESS(FlashAddress));
|
|||
|
314:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
315:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Process Locked */
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 7
|
|||
|
|
|||
|
|
|||
|
316:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** __HAL_LOCK(&pFlash);
|
|||
|
317:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
318:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Reset error code */
|
|||
|
319:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** pFlash.ErrorCode = HAL_FLASH_ERROR_NONE;
|
|||
|
320:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
321:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #if defined (FLASH_OPTCR_PG_OTP)
|
|||
|
322:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if((IS_FLASH_PROGRAM_ADDRESS_BANK1(FlashAddress)) || (IS_FLASH_PROGRAM_ADDRESS_OTP(FlashAddress))
|
|||
|
323:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #else
|
|||
|
324:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if(IS_FLASH_PROGRAM_ADDRESS_BANK1(FlashAddress))
|
|||
|
325:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #endif /* FLASH_OPTCR_PG_OTP */
|
|||
|
326:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
327:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** bank = FLASH_BANK_1;
|
|||
|
328:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
329:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #if defined (DUAL_BANK)
|
|||
|
330:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** else if(IS_FLASH_PROGRAM_ADDRESS_BANK2(FlashAddress))
|
|||
|
331:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
332:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** bank = FLASH_BANK_2;
|
|||
|
333:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
334:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #endif /* DUAL_BANK */
|
|||
|
335:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** else
|
|||
|
336:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
337:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** return HAL_ERROR;
|
|||
|
338:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
339:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
340:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Wait for last operation to be completed */
|
|||
|
341:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** status = FLASH_WaitForLastOperation((uint32_t)FLASH_TIMEOUT_VALUE, bank);
|
|||
|
342:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
343:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if (status != HAL_OK)
|
|||
|
344:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
345:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Process Unlocked */
|
|||
|
346:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** __HAL_UNLOCK(&pFlash);
|
|||
|
347:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
348:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** else
|
|||
|
349:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
350:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** pFlash.Address = FlashAddress;
|
|||
|
351:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
352:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #if defined (DUAL_BANK)
|
|||
|
353:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if(bank == FLASH_BANK_1)
|
|||
|
354:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
355:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Set internal variables used by the IRQ handler */
|
|||
|
356:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** pFlash.ProcedureOnGoing = FLASH_PROC_PROGRAM_BANK1;
|
|||
|
357:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
358:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #if defined (FLASH_OPTCR_PG_OTP)
|
|||
|
359:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if (TypeProgram == FLASH_TYPEPROGRAM_OTPWORD)
|
|||
|
360:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
361:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Set OTP_PG bit */
|
|||
|
362:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** SET_BIT(FLASH->OPTCR, FLASH_OPTCR_PG_OTP);
|
|||
|
363:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
364:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** else
|
|||
|
365:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #endif /* FLASH_OPTCR_PG_OTP */
|
|||
|
366:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
367:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Set PG bit */
|
|||
|
368:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** SET_BIT(FLASH->CR1, FLASH_CR_PG);
|
|||
|
369:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
370:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
371:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Enable End of Operation and Error interrupts for Bank 1 */
|
|||
|
372:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #if defined (FLASH_CR_OPERRIE)
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 8
|
|||
|
|
|||
|
|
|||
|
373:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** __HAL_FLASH_ENABLE_IT_BANK1(FLASH_IT_EOP_BANK1 | FLASH_IT_WRPERR_BANK1 | FLASH_IT_PGSERR_
|
|||
|
374:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** FLASH_IT_STRBERR_BANK1 | FLASH_IT_INCERR_BANK1 | FLASH_IT_OPERR_B
|
|||
|
375:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #else
|
|||
|
376:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** __HAL_FLASH_ENABLE_IT_BANK1(FLASH_IT_EOP_BANK1 | FLASH_IT_WRPERR_BANK1 | FLASH_IT_PGSERR_
|
|||
|
377:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** FLASH_IT_STRBERR_BANK1 | FLASH_IT_INCERR_BANK1);
|
|||
|
378:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #endif /* FLASH_CR_OPERRIE */
|
|||
|
379:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
380:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** else
|
|||
|
381:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
382:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Set internal variables used by the IRQ handler */
|
|||
|
383:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** pFlash.ProcedureOnGoing = FLASH_PROC_PROGRAM_BANK2;
|
|||
|
384:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
385:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Set PG bit */
|
|||
|
386:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** SET_BIT(FLASH->CR2, FLASH_CR_PG);
|
|||
|
387:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
388:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Enable End of Operation and Error interrupts for Bank2 */
|
|||
|
389:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #if defined (FLASH_CR_OPERRIE)
|
|||
|
390:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** __HAL_FLASH_ENABLE_IT_BANK2(FLASH_IT_EOP_BANK2 | FLASH_IT_WRPERR_BANK2 | FLASH_IT_PGSERR_
|
|||
|
391:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** FLASH_IT_STRBERR_BANK2 | FLASH_IT_INCERR_BANK2 | FLASH_IT_OPERR_B
|
|||
|
392:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #else
|
|||
|
393:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** __HAL_FLASH_ENABLE_IT_BANK2(FLASH_IT_EOP_BANK2 | FLASH_IT_WRPERR_BANK2 | FLASH_IT_PGSERR_
|
|||
|
394:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** FLASH_IT_STRBERR_BANK2 | FLASH_IT_INCERR_BANK2);
|
|||
|
395:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #endif /* FLASH_CR_OPERRIE */
|
|||
|
396:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
397:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #else /* Single Bank */
|
|||
|
398:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Set internal variables used by the IRQ handler */
|
|||
|
399:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** pFlash.ProcedureOnGoing = FLASH_PROC_PROGRAM_BANK1;
|
|||
|
400:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
401:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #if defined (FLASH_OPTCR_PG_OTP)
|
|||
|
402:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if (TypeProgram == FLASH_TYPEPROGRAM_OTPWORD)
|
|||
|
403:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
404:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Set OTP_PG bit */
|
|||
|
405:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** SET_BIT(FLASH->OPTCR, FLASH_OPTCR_PG_OTP);
|
|||
|
406:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
407:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** else
|
|||
|
408:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #endif /* FLASH_OPTCR_PG_OTP */
|
|||
|
409:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
410:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Set PG bit */
|
|||
|
411:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** SET_BIT(FLASH->CR1, FLASH_CR_PG);
|
|||
|
412:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
413:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
414:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Enable End of Operation and Error interrupts for Bank 1 */
|
|||
|
415:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #if defined (FLASH_CR_OPERRIE)
|
|||
|
416:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** __HAL_FLASH_ENABLE_IT_BANK1(FLASH_IT_EOP_BANK1 | FLASH_IT_WRPERR_BANK1 | FLASH_IT_PGSERR_
|
|||
|
417:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** FLASH_IT_STRBERR_BANK1 | FLASH_IT_INCERR_BANK1 | FLASH_IT_OPERR_B
|
|||
|
418:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #else
|
|||
|
419:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** __HAL_FLASH_ENABLE_IT_BANK1(FLASH_IT_EOP_BANK1 | FLASH_IT_WRPERR_BANK1 | FLASH_IT_PGSERR_
|
|||
|
420:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** FLASH_IT_STRBERR_BANK1 | FLASH_IT_INCERR_BANK1);
|
|||
|
421:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #endif /* FLASH_CR_OPERRIE */
|
|||
|
422:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #endif /* DUAL_BANK */
|
|||
|
423:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
424:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** __ISB();
|
|||
|
425:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** __DSB();
|
|||
|
426:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
427:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #if defined (FLASH_OPTCR_PG_OTP)
|
|||
|
428:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if (TypeProgram == FLASH_TYPEPROGRAM_OTPWORD)
|
|||
|
429:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 9
|
|||
|
|
|||
|
|
|||
|
430:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Program an OTP word (16 bits) */
|
|||
|
431:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** *(__IO uint16_t *)FlashAddress = *(__IO uint16_t*)DataAddress;
|
|||
|
432:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
433:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** else
|
|||
|
434:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #endif /* FLASH_OPTCR_PG_OTP */
|
|||
|
435:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
436:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Program the flash word */
|
|||
|
437:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** do
|
|||
|
438:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
439:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** *dest_addr = *src_addr;
|
|||
|
440:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** dest_addr++;
|
|||
|
441:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** src_addr++;
|
|||
|
442:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** row_index--;
|
|||
|
443:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** } while (row_index != 0U);
|
|||
|
444:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
445:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
446:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** __ISB();
|
|||
|
447:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** __DSB();
|
|||
|
448:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
449:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
450:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** return status;
|
|||
|
451:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
452:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
453:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /**
|
|||
|
454:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @brief This function handles FLASH interrupt request.
|
|||
|
455:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @retval None
|
|||
|
456:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** */
|
|||
|
457:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** void HAL_FLASH_IRQHandler(void)
|
|||
|
458:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
459:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** uint32_t temp;
|
|||
|
460:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** uint32_t errorflag;
|
|||
|
461:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** FLASH_ProcedureTypeDef procedure;
|
|||
|
462:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
463:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Check FLASH Bank1 End of Operation flag */
|
|||
|
464:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if(__HAL_FLASH_GET_FLAG_BANK1(FLASH_SR_EOP) != RESET)
|
|||
|
465:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
466:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if(pFlash.ProcedureOnGoing == FLASH_PROC_SECTERASE_BANK1)
|
|||
|
467:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
468:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Nb of sector to erased can be decreased */
|
|||
|
469:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** pFlash.NbSectorsToErase--;
|
|||
|
470:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
471:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Check if there are still sectors to erase */
|
|||
|
472:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if(pFlash.NbSectorsToErase != 0U)
|
|||
|
473:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
474:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Indicate user which sector has been erased */
|
|||
|
475:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** HAL_FLASH_EndOfOperationCallback(pFlash.Sector);
|
|||
|
476:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
477:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Clear bank 1 End of Operation pending bit */
|
|||
|
478:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** __HAL_FLASH_CLEAR_FLAG_BANK1(FLASH_FLAG_EOP_BANK1);
|
|||
|
479:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
480:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Increment sector number */
|
|||
|
481:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** pFlash.Sector++;
|
|||
|
482:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** temp = pFlash.Sector;
|
|||
|
483:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** FLASH_Erase_Sector(temp, FLASH_BANK_1, pFlash.VoltageForErase);
|
|||
|
484:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
485:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** else
|
|||
|
486:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 10
|
|||
|
|
|||
|
|
|||
|
487:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* No more sectors to Erase, user callback can be called */
|
|||
|
488:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Reset Sector and stop Erase sectors procedure */
|
|||
|
489:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** pFlash.Sector = 0xFFFFFFFFU;
|
|||
|
490:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** pFlash.ProcedureOnGoing = FLASH_PROC_NONE;
|
|||
|
491:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
492:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* FLASH EOP interrupt user callback */
|
|||
|
493:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** HAL_FLASH_EndOfOperationCallback(pFlash.Sector);
|
|||
|
494:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
495:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Clear FLASH End of Operation pending bit */
|
|||
|
496:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** __HAL_FLASH_CLEAR_FLAG_BANK1(FLASH_FLAG_EOP_BANK1);
|
|||
|
497:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
498:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
499:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** else
|
|||
|
500:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
501:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** procedure = pFlash.ProcedureOnGoing;
|
|||
|
502:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
503:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if((procedure == FLASH_PROC_MASSERASE_BANK1) || (procedure == FLASH_PROC_ALLBANK_MASSERASE))
|
|||
|
504:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
505:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* MassErase ended. Return the selected bank */
|
|||
|
506:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* FLASH EOP interrupt user callback */
|
|||
|
507:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** HAL_FLASH_EndOfOperationCallback(FLASH_BANK_1);
|
|||
|
508:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
509:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** else if(procedure == FLASH_PROC_PROGRAM_BANK1)
|
|||
|
510:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
511:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Program ended. Return the selected address */
|
|||
|
512:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* FLASH EOP interrupt user callback */
|
|||
|
513:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** HAL_FLASH_EndOfOperationCallback(pFlash.Address);
|
|||
|
514:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
515:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** else
|
|||
|
516:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
517:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Nothing to do */
|
|||
|
518:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
519:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
520:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if((procedure != FLASH_PROC_SECTERASE_BANK2) && \
|
|||
|
521:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** (procedure != FLASH_PROC_MASSERASE_BANK2) && \
|
|||
|
522:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** (procedure != FLASH_PROC_PROGRAM_BANK2))
|
|||
|
523:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
524:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** pFlash.ProcedureOnGoing = FLASH_PROC_NONE;
|
|||
|
525:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Clear FLASH End of Operation pending bit */
|
|||
|
526:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** __HAL_FLASH_CLEAR_FLAG_BANK1(FLASH_FLAG_EOP_BANK1);
|
|||
|
527:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
528:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
529:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
530:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
531:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #if defined (DUAL_BANK)
|
|||
|
532:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Check FLASH Bank2 End of Operation flag */
|
|||
|
533:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if(__HAL_FLASH_GET_FLAG_BANK2(FLASH_SR_EOP) != RESET)
|
|||
|
534:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
535:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if(pFlash.ProcedureOnGoing == FLASH_PROC_SECTERASE_BANK2)
|
|||
|
536:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
537:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /*Nb of sector to erased can be decreased*/
|
|||
|
538:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** pFlash.NbSectorsToErase--;
|
|||
|
539:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
540:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Check if there are still sectors to erase*/
|
|||
|
541:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if(pFlash.NbSectorsToErase != 0U)
|
|||
|
542:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
543:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /*Indicate user which sector has been erased*/
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 11
|
|||
|
|
|||
|
|
|||
|
544:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** HAL_FLASH_EndOfOperationCallback(pFlash.Sector);
|
|||
|
545:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
546:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Clear bank 2 End of Operation pending bit */
|
|||
|
547:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** __HAL_FLASH_CLEAR_FLAG_BANK2(FLASH_FLAG_EOP_BANK2);
|
|||
|
548:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
549:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /*Increment sector number*/
|
|||
|
550:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** pFlash.Sector++;
|
|||
|
551:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** temp = pFlash.Sector;
|
|||
|
552:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** FLASH_Erase_Sector(temp, FLASH_BANK_2, pFlash.VoltageForErase);
|
|||
|
553:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
554:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** else
|
|||
|
555:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
556:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* No more sectors to Erase, user callback can be called */
|
|||
|
557:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Reset Sector and stop Erase sectors procedure */
|
|||
|
558:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** pFlash.Sector = 0xFFFFFFFFU;
|
|||
|
559:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** pFlash.ProcedureOnGoing = FLASH_PROC_NONE;
|
|||
|
560:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
561:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* FLASH EOP interrupt user callback */
|
|||
|
562:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** HAL_FLASH_EndOfOperationCallback(pFlash.Sector);
|
|||
|
563:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
564:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Clear FLASH End of Operation pending bit */
|
|||
|
565:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** __HAL_FLASH_CLEAR_FLAG_BANK2(FLASH_FLAG_EOP_BANK2);
|
|||
|
566:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
567:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
568:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** else
|
|||
|
569:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
570:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** procedure = pFlash.ProcedureOnGoing;
|
|||
|
571:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
572:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if((procedure == FLASH_PROC_MASSERASE_BANK2) || (procedure == FLASH_PROC_ALLBANK_MASSERASE))
|
|||
|
573:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
574:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /*MassErase ended. Return the selected bank*/
|
|||
|
575:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* FLASH EOP interrupt user callback */
|
|||
|
576:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** HAL_FLASH_EndOfOperationCallback(FLASH_BANK_2);
|
|||
|
577:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
578:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** else if(procedure == FLASH_PROC_PROGRAM_BANK2)
|
|||
|
579:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
580:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Program ended. Return the selected address */
|
|||
|
581:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* FLASH EOP interrupt user callback */
|
|||
|
582:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** HAL_FLASH_EndOfOperationCallback(pFlash.Address);
|
|||
|
583:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
584:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** else
|
|||
|
585:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
586:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Nothing to do */
|
|||
|
587:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
588:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
589:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if((procedure != FLASH_PROC_SECTERASE_BANK1) && \
|
|||
|
590:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** (procedure != FLASH_PROC_MASSERASE_BANK1) && \
|
|||
|
591:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** (procedure != FLASH_PROC_PROGRAM_BANK1))
|
|||
|
592:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
593:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** pFlash.ProcedureOnGoing = FLASH_PROC_NONE;
|
|||
|
594:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Clear FLASH End of Operation pending bit */
|
|||
|
595:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** __HAL_FLASH_CLEAR_FLAG_BANK2(FLASH_FLAG_EOP_BANK2);
|
|||
|
596:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
597:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
598:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
599:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #endif /* DUAL_BANK */
|
|||
|
600:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 12
|
|||
|
|
|||
|
|
|||
|
601:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Check FLASH Bank1 operation error flags */
|
|||
|
602:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #if defined (FLASH_SR_OPERR)
|
|||
|
603:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** errorflag = FLASH->SR1 & (FLASH_FLAG_WRPERR_BANK1 | FLASH_FLAG_PGSERR_BANK1 | FLASH_FLAG_STRBERR_
|
|||
|
604:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** FLASH_FLAG_INCERR_BANK1 | FLASH_FLAG_OPERR_BANK1);
|
|||
|
605:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #else
|
|||
|
606:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** errorflag = FLASH->SR1 & (FLASH_FLAG_WRPERR_BANK1 | FLASH_FLAG_PGSERR_BANK1 | FLASH_FLAG_STRBERR_
|
|||
|
607:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** FLASH_FLAG_INCERR_BANK1);
|
|||
|
608:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #endif /* FLASH_SR_OPERR */
|
|||
|
609:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
610:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if(errorflag != 0U)
|
|||
|
611:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
612:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Save the error code */
|
|||
|
613:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** pFlash.ErrorCode |= errorflag;
|
|||
|
614:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
615:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Clear error programming flags */
|
|||
|
616:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** __HAL_FLASH_CLEAR_FLAG_BANK1(errorflag);
|
|||
|
617:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
618:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** procedure = pFlash.ProcedureOnGoing;
|
|||
|
619:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
620:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if(procedure == FLASH_PROC_SECTERASE_BANK1)
|
|||
|
621:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
622:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Return the faulty sector */
|
|||
|
623:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** temp = pFlash.Sector;
|
|||
|
624:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** pFlash.Sector = 0xFFFFFFFFU;
|
|||
|
625:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
626:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** else if((procedure == FLASH_PROC_MASSERASE_BANK1) || (procedure == FLASH_PROC_ALLBANK_MASSERASE
|
|||
|
627:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
628:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Return the faulty bank */
|
|||
|
629:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** temp = FLASH_BANK_1;
|
|||
|
630:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
631:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** else
|
|||
|
632:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
633:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Return the faulty address */
|
|||
|
634:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** temp = pFlash.Address;
|
|||
|
635:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
636:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
637:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Stop the procedure ongoing*/
|
|||
|
638:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** pFlash.ProcedureOnGoing = FLASH_PROC_NONE;
|
|||
|
639:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
640:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* FLASH error interrupt user callback */
|
|||
|
641:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** HAL_FLASH_OperationErrorCallback(temp);
|
|||
|
642:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
643:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
644:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #if defined (DUAL_BANK)
|
|||
|
645:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Check FLASH Bank2 operation error flags */
|
|||
|
646:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #if defined (FLASH_SR_OPERR)
|
|||
|
647:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** errorflag = FLASH->SR2 & ((FLASH_FLAG_WRPERR_BANK2 | FLASH_FLAG_PGSERR_BANK2 | FLASH_FLAG_STRBERR
|
|||
|
648:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** FLASH_FLAG_INCERR_BANK2 | FLASH_FLAG_OPERR_BANK2) & 0x7FFFFFFFU);
|
|||
|
649:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #else
|
|||
|
650:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** errorflag = FLASH->SR2 & ((FLASH_FLAG_WRPERR_BANK2 | FLASH_FLAG_PGSERR_BANK2 | FLASH_FLAG_STRBERR
|
|||
|
651:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** FLASH_FLAG_INCERR_BANK2) & 0x7FFFFFFFU);
|
|||
|
652:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #endif /* FLASH_SR_OPERR */
|
|||
|
653:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
654:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if(errorflag != 0U)
|
|||
|
655:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
656:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Save the error code */
|
|||
|
657:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** pFlash.ErrorCode |= (errorflag | 0x80000000U);
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 13
|
|||
|
|
|||
|
|
|||
|
658:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
659:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Clear error programming flags */
|
|||
|
660:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** __HAL_FLASH_CLEAR_FLAG_BANK2(errorflag);
|
|||
|
661:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
662:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** procedure = pFlash.ProcedureOnGoing;
|
|||
|
663:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
664:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if(procedure== FLASH_PROC_SECTERASE_BANK2)
|
|||
|
665:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
666:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /*return the faulty sector*/
|
|||
|
667:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** temp = pFlash.Sector;
|
|||
|
668:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** pFlash.Sector = 0xFFFFFFFFU;
|
|||
|
669:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
670:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** else if((procedure == FLASH_PROC_MASSERASE_BANK2) || (procedure == FLASH_PROC_ALLBANK_MASSERASE
|
|||
|
671:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
672:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /*return the faulty bank*/
|
|||
|
673:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** temp = FLASH_BANK_2;
|
|||
|
674:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
675:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** else
|
|||
|
676:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
677:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /*return the faulty address*/
|
|||
|
678:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** temp = pFlash.Address;
|
|||
|
679:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
680:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
681:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /*Stop the procedure ongoing*/
|
|||
|
682:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** pFlash.ProcedureOnGoing = FLASH_PROC_NONE;
|
|||
|
683:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
684:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* FLASH error interrupt user callback */
|
|||
|
685:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** HAL_FLASH_OperationErrorCallback(temp);
|
|||
|
686:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
687:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #endif /* DUAL_BANK */
|
|||
|
688:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
689:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if(pFlash.ProcedureOnGoing == FLASH_PROC_NONE)
|
|||
|
690:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
691:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #if defined (FLASH_CR_OPERRIE)
|
|||
|
692:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Disable Bank1 Operation and Error source interrupt */
|
|||
|
693:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** __HAL_FLASH_DISABLE_IT_BANK1(FLASH_IT_EOP_BANK1 | FLASH_IT_WRPERR_BANK1 | FLASH_IT_PGSERR_BA
|
|||
|
694:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** FLASH_IT_STRBERR_BANK1 | FLASH_IT_INCERR_BANK1 | FLASH_IT_OPERR_BA
|
|||
|
695:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
696:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #if defined (DUAL_BANK)
|
|||
|
697:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Disable Bank2 Operation and Error source interrupt */
|
|||
|
698:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** __HAL_FLASH_DISABLE_IT_BANK2(FLASH_IT_EOP_BANK2 | FLASH_IT_WRPERR_BANK2 | FLASH_IT_PGSERR_BA
|
|||
|
699:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** FLASH_IT_STRBERR_BANK2 | FLASH_IT_INCERR_BANK2 | FLASH_IT_OPERR_BA
|
|||
|
700:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #endif /* DUAL_BANK */
|
|||
|
701:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #else
|
|||
|
702:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Disable Bank1 Operation and Error source interrupt */
|
|||
|
703:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** __HAL_FLASH_DISABLE_IT_BANK1(FLASH_IT_EOP_BANK1 | FLASH_IT_WRPERR_BANK1 | FLASH_IT_PGSERR_BA
|
|||
|
704:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** FLASH_IT_STRBERR_BANK1 | FLASH_IT_INCERR_BANK1);
|
|||
|
705:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
706:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #if defined (DUAL_BANK)
|
|||
|
707:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Disable Bank2 Operation and Error source interrupt */
|
|||
|
708:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** __HAL_FLASH_DISABLE_IT_BANK2(FLASH_IT_EOP_BANK2 | FLASH_IT_WRPERR_BANK2 | FLASH_IT_PGSERR_BA
|
|||
|
709:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** FLASH_IT_STRBERR_BANK2 | FLASH_IT_INCERR_BANK2);
|
|||
|
710:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #endif /* DUAL_BANK */
|
|||
|
711:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #endif /* FLASH_CR_OPERRIE */
|
|||
|
712:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
713:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Process Unlocked */
|
|||
|
714:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** __HAL_UNLOCK(&pFlash);
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 14
|
|||
|
|
|||
|
|
|||
|
715:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
716:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
717:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
718:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /**
|
|||
|
719:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @brief FLASH end of operation interrupt callback
|
|||
|
720:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @param ReturnValue The value saved in this parameter depends on the ongoing procedure
|
|||
|
721:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * Mass Erase: Bank number which has been requested to erase
|
|||
|
722:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * Sectors Erase: Sector which has been erased
|
|||
|
723:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * (if 0xFFFFFFFF, it means that all the selected sectors have been erased)
|
|||
|
724:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * Program: Address which was selected for data program
|
|||
|
725:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @retval None
|
|||
|
726:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** */
|
|||
|
727:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** __weak void HAL_FLASH_EndOfOperationCallback(uint32_t ReturnValue)
|
|||
|
728:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
29 .loc 1 728 1 view -0
|
|||
|
30 .cfi_startproc
|
|||
|
31 @ args = 0, pretend = 0, frame = 0
|
|||
|
32 @ frame_needed = 0, uses_anonymous_args = 0
|
|||
|
33 @ link register save eliminated.
|
|||
|
729:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Prevent unused argument(s) compilation warning */
|
|||
|
730:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** UNUSED(ReturnValue);
|
|||
|
34 .loc 1 730 3 view .LVU1
|
|||
|
731:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
732:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* NOTE : This function Should not be modified, when the callback is needed,
|
|||
|
733:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** the HAL_FLASH_EndOfOperationCallback could be implemented in the user file
|
|||
|
734:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** */
|
|||
|
735:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
35 .loc 1 735 1 is_stmt 0 view .LVU2
|
|||
|
36 0000 7047 bx lr
|
|||
|
37 .cfi_endproc
|
|||
|
38 .LFE144:
|
|||
|
40 .section .text.HAL_FLASH_OperationErrorCallback,"ax",%progbits
|
|||
|
41 .align 1
|
|||
|
42 .weak HAL_FLASH_OperationErrorCallback
|
|||
|
43 .syntax unified
|
|||
|
44 .thumb
|
|||
|
45 .thumb_func
|
|||
|
46 .fpu fpv5-d16
|
|||
|
48 HAL_FLASH_OperationErrorCallback:
|
|||
|
49 .LVL1:
|
|||
|
50 .LFB145:
|
|||
|
736:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
737:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /**
|
|||
|
738:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @brief FLASH operation error interrupt callback
|
|||
|
739:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @param ReturnValue The value saved in this parameter depends on the ongoing procedure
|
|||
|
740:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * Mass Erase: Bank number which has been requested to erase
|
|||
|
741:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * Sectors Erase: Sector number which returned an error
|
|||
|
742:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * Program: Address which was selected for data program
|
|||
|
743:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @retval None
|
|||
|
744:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** */
|
|||
|
745:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** __weak void HAL_FLASH_OperationErrorCallback(uint32_t ReturnValue)
|
|||
|
746:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
51 .loc 1 746 1 is_stmt 1 view -0
|
|||
|
52 .cfi_startproc
|
|||
|
53 @ args = 0, pretend = 0, frame = 0
|
|||
|
54 @ frame_needed = 0, uses_anonymous_args = 0
|
|||
|
55 @ link register save eliminated.
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 15
|
|||
|
|
|||
|
|
|||
|
747:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Prevent unused argument(s) compilation warning */
|
|||
|
748:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** UNUSED(ReturnValue);
|
|||
|
56 .loc 1 748 3 view .LVU4
|
|||
|
749:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
750:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* NOTE : This function Should not be modified, when the callback is needed,
|
|||
|
751:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** the HAL_FLASH_OperationErrorCallback could be implemented in the user file
|
|||
|
752:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** */
|
|||
|
753:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
57 .loc 1 753 1 is_stmt 0 view .LVU5
|
|||
|
58 0000 7047 bx lr
|
|||
|
59 .cfi_endproc
|
|||
|
60 .LFE145:
|
|||
|
62 .section .text.HAL_FLASH_IRQHandler,"ax",%progbits
|
|||
|
63 .align 1
|
|||
|
64 .global HAL_FLASH_IRQHandler
|
|||
|
65 .syntax unified
|
|||
|
66 .thumb
|
|||
|
67 .thumb_func
|
|||
|
68 .fpu fpv5-d16
|
|||
|
70 HAL_FLASH_IRQHandler:
|
|||
|
71 .LFB143:
|
|||
|
458:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** uint32_t temp;
|
|||
|
72 .loc 1 458 1 is_stmt 1 view -0
|
|||
|
73 .cfi_startproc
|
|||
|
74 @ args = 0, pretend = 0, frame = 0
|
|||
|
75 @ frame_needed = 0, uses_anonymous_args = 0
|
|||
|
76 0000 10B5 push {r4, lr}
|
|||
|
77 .LCFI0:
|
|||
|
78 .cfi_def_cfa_offset 8
|
|||
|
79 .cfi_offset 4, -8
|
|||
|
80 .cfi_offset 14, -4
|
|||
|
459:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** uint32_t errorflag;
|
|||
|
81 .loc 1 459 3 view .LVU7
|
|||
|
460:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** FLASH_ProcedureTypeDef procedure;
|
|||
|
82 .loc 1 460 3 view .LVU8
|
|||
|
461:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
83 .loc 1 461 3 view .LVU9
|
|||
|
464:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
84 .loc 1 464 3 view .LVU10
|
|||
|
464:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
85 .loc 1 464 6 is_stmt 0 view .LVU11
|
|||
|
86 0002 3D4B ldr r3, .L19
|
|||
|
87 0004 1B69 ldr r3, [r3, #16]
|
|||
|
464:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
88 .loc 1 464 5 view .LVU12
|
|||
|
89 0006 13F4803F tst r3, #65536
|
|||
|
90 000a 18D0 beq .L4
|
|||
|
466:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
91 .loc 1 466 5 is_stmt 1 view .LVU13
|
|||
|
466:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
92 .loc 1 466 14 is_stmt 0 view .LVU14
|
|||
|
93 000c 3B4B ldr r3, .L19+4
|
|||
|
94 000e 1B78 ldrb r3, [r3] @ zero_extendqisi2
|
|||
|
95 0010 DBB2 uxtb r3, r3
|
|||
|
466:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
96 .loc 1 466 7 view .LVU15
|
|||
|
97 0012 012B cmp r3, #1
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 16
|
|||
|
|
|||
|
|
|||
|
98 0014 29D0 beq .L15
|
|||
|
501:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
99 .loc 1 501 7 is_stmt 1 view .LVU16
|
|||
|
501:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
100 .loc 1 501 17 is_stmt 0 view .LVU17
|
|||
|
101 0016 394B ldr r3, .L19+4
|
|||
|
102 0018 1C78 ldrb r4, [r3] @ zero_extendqisi2
|
|||
|
103 001a E4B2 uxtb r4, r4
|
|||
|
104 .LVL2:
|
|||
|
503:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
105 .loc 1 503 7 is_stmt 1 view .LVU18
|
|||
|
503:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
106 .loc 1 503 9 is_stmt 0 view .LVU19
|
|||
|
107 001c 072C cmp r4, #7
|
|||
|
108 001e 18BF it ne
|
|||
|
109 0020 022C cmpne r4, #2
|
|||
|
110 0022 47D0 beq .L16
|
|||
|
509:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
111 .loc 1 509 12 is_stmt 1 view .LVU20
|
|||
|
509:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
112 .loc 1 509 14 is_stmt 0 view .LVU21
|
|||
|
113 0024 032C cmp r4, #3
|
|||
|
114 0026 49D0 beq .L17
|
|||
|
115 .L8:
|
|||
|
518:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
116 .loc 1 518 7 is_stmt 1 view .LVU22
|
|||
|
520:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** (procedure != FLASH_PROC_MASSERASE_BANK2) && \
|
|||
|
117 .loc 1 520 7 view .LVU23
|
|||
|
521:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** (procedure != FLASH_PROC_PROGRAM_BANK2))
|
|||
|
118 .loc 1 521 52 is_stmt 0 view .LVU24
|
|||
|
119 0028 043C subs r4, r4, #4
|
|||
|
120 .LVL3:
|
|||
|
521:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** (procedure != FLASH_PROC_PROGRAM_BANK2))
|
|||
|
121 .loc 1 521 52 view .LVU25
|
|||
|
122 002a E4B2 uxtb r4, r4
|
|||
|
123 .LVL4:
|
|||
|
520:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** (procedure != FLASH_PROC_MASSERASE_BANK2) && \
|
|||
|
124 .loc 1 520 9 view .LVU26
|
|||
|
125 002c 022C cmp r4, #2
|
|||
|
126 002e 06D9 bls .L4
|
|||
|
524:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Clear FLASH End of Operation pending bit */
|
|||
|
127 .loc 1 524 9 is_stmt 1 view .LVU27
|
|||
|
524:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Clear FLASH End of Operation pending bit */
|
|||
|
128 .loc 1 524 33 is_stmt 0 view .LVU28
|
|||
|
129 0030 324B ldr r3, .L19+4
|
|||
|
130 0032 0022 movs r2, #0
|
|||
|
131 0034 1A70 strb r2, [r3]
|
|||
|
526:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
132 .loc 1 526 9 is_stmt 1 view .LVU29
|
|||
|
133 0036 304B ldr r3, .L19
|
|||
|
134 0038 4FF48032 mov r2, #65536
|
|||
|
135 003c 5A61 str r2, [r3, #20]
|
|||
|
136 .L4:
|
|||
|
603:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** FLASH_FLAG_INCERR_BANK1 | FLASH_FLAG_OPERR_BANK1);
|
|||
|
137 .loc 1 603 3 view .LVU30
|
|||
|
603:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** FLASH_FLAG_INCERR_BANK1 | FLASH_FLAG_OPERR_BANK1);
|
|||
|
138 .loc 1 603 20 is_stmt 0 view .LVU31
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 17
|
|||
|
|
|||
|
|
|||
|
139 003e 2E4B ldr r3, .L19
|
|||
|
140 0040 1B69 ldr r3, [r3, #16]
|
|||
|
141 .LVL5:
|
|||
|
610:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
142 .loc 1 610 3 is_stmt 1 view .LVU32
|
|||
|
610:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
143 .loc 1 610 5 is_stmt 0 view .LVU33
|
|||
|
144 0042 13F4DC03 ands r3, r3, #7208960
|
|||
|
145 .LVL6:
|
|||
|
610:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
146 .loc 1 610 5 view .LVU34
|
|||
|
147 0046 48D0 beq .L9
|
|||
|
613:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
148 .loc 1 613 5 is_stmt 1 view .LVU35
|
|||
|
613:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
149 .loc 1 613 22 is_stmt 0 view .LVU36
|
|||
|
150 0048 2C4A ldr r2, .L19+4
|
|||
|
151 004a 9169 ldr r1, [r2, #24]
|
|||
|
152 004c 1943 orrs r1, r1, r3
|
|||
|
153 004e 9161 str r1, [r2, #24]
|
|||
|
616:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
154 .loc 1 616 5 is_stmt 1 view .LVU37
|
|||
|
155 0050 2949 ldr r1, .L19
|
|||
|
156 0052 4B61 str r3, [r1, #20]
|
|||
|
618:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
157 .loc 1 618 5 view .LVU38
|
|||
|
618:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
158 .loc 1 618 15 is_stmt 0 view .LVU39
|
|||
|
159 0054 1378 ldrb r3, [r2] @ zero_extendqisi2
|
|||
|
160 .LVL7:
|
|||
|
618:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
161 .loc 1 618 15 view .LVU40
|
|||
|
162 0056 DBB2 uxtb r3, r3
|
|||
|
163 .LVL8:
|
|||
|
620:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
164 .loc 1 620 5 is_stmt 1 view .LVU41
|
|||
|
620:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
165 .loc 1 620 7 is_stmt 0 view .LVU42
|
|||
|
166 0058 012B cmp r3, #1
|
|||
|
167 005a 34D0 beq .L18
|
|||
|
626:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
168 .loc 1 626 10 is_stmt 1 view .LVU43
|
|||
|
626:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
169 .loc 1 626 12 is_stmt 0 view .LVU44
|
|||
|
170 005c 072B cmp r3, #7
|
|||
|
171 005e 18BF it ne
|
|||
|
172 0060 022B cmpne r3, #2
|
|||
|
173 0062 46D0 beq .L13
|
|||
|
634:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
174 .loc 1 634 7 is_stmt 1 view .LVU45
|
|||
|
634:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
175 .loc 1 634 12 is_stmt 0 view .LVU46
|
|||
|
176 0064 254B ldr r3, .L19+4
|
|||
|
177 .LVL9:
|
|||
|
634:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
178 .loc 1 634 12 view .LVU47
|
|||
|
179 0066 1869 ldr r0, [r3, #16]
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 18
|
|||
|
|
|||
|
|
|||
|
180 .LVL10:
|
|||
|
634:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
181 .loc 1 634 12 view .LVU48
|
|||
|
182 0068 32E0 b .L11
|
|||
|
183 .LVL11:
|
|||
|
184 .L15:
|
|||
|
469:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
185 .loc 1 469 7 is_stmt 1 view .LVU49
|
|||
|
469:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
186 .loc 1 469 13 is_stmt 0 view .LVU50
|
|||
|
187 006a 244B ldr r3, .L19+4
|
|||
|
188 006c 5A68 ldr r2, [r3, #4]
|
|||
|
469:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
189 .loc 1 469 30 view .LVU51
|
|||
|
190 006e 013A subs r2, r2, #1
|
|||
|
191 0070 5A60 str r2, [r3, #4]
|
|||
|
472:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
192 .loc 1 472 7 is_stmt 1 view .LVU52
|
|||
|
472:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
193 .loc 1 472 16 is_stmt 0 view .LVU53
|
|||
|
194 0072 5B68 ldr r3, [r3, #4]
|
|||
|
472:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
195 .loc 1 472 9 view .LVU54
|
|||
|
196 0074 83B1 cbz r3, .L6
|
|||
|
475:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
197 .loc 1 475 9 is_stmt 1 view .LVU55
|
|||
|
198 0076 214C ldr r4, .L19+4
|
|||
|
199 0078 E068 ldr r0, [r4, #12]
|
|||
|
200 007a FFF7FEFF bl HAL_FLASH_EndOfOperationCallback
|
|||
|
201 .LVL12:
|
|||
|
478:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
202 .loc 1 478 9 view .LVU56
|
|||
|
203 007e 1E4B ldr r3, .L19
|
|||
|
204 0080 4FF48032 mov r2, #65536
|
|||
|
205 0084 5A61 str r2, [r3, #20]
|
|||
|
481:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** temp = pFlash.Sector;
|
|||
|
206 .loc 1 481 9 view .LVU57
|
|||
|
481:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** temp = pFlash.Sector;
|
|||
|
207 .loc 1 481 15 is_stmt 0 view .LVU58
|
|||
|
208 0086 E368 ldr r3, [r4, #12]
|
|||
|
481:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** temp = pFlash.Sector;
|
|||
|
209 .loc 1 481 22 view .LVU59
|
|||
|
210 0088 0133 adds r3, r3, #1
|
|||
|
211 008a E360 str r3, [r4, #12]
|
|||
|
482:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** FLASH_Erase_Sector(temp, FLASH_BANK_1, pFlash.VoltageForErase);
|
|||
|
212 .loc 1 482 9 is_stmt 1 view .LVU60
|
|||
|
482:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** FLASH_Erase_Sector(temp, FLASH_BANK_1, pFlash.VoltageForErase);
|
|||
|
213 .loc 1 482 14 is_stmt 0 view .LVU61
|
|||
|
214 008c E068 ldr r0, [r4, #12]
|
|||
|
215 .LVL13:
|
|||
|
483:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
216 .loc 1 483 9 is_stmt 1 view .LVU62
|
|||
|
217 008e A268 ldr r2, [r4, #8]
|
|||
|
218 0090 0121 movs r1, #1
|
|||
|
219 0092 FFF7FEFF bl FLASH_Erase_Sector
|
|||
|
220 .LVL14:
|
|||
|
483:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 19
|
|||
|
|
|||
|
|
|||
|
221 .loc 1 483 9 is_stmt 0 view .LVU63
|
|||
|
222 0096 D2E7 b .L4
|
|||
|
223 .L6:
|
|||
|
489:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** pFlash.ProcedureOnGoing = FLASH_PROC_NONE;
|
|||
|
224 .loc 1 489 9 is_stmt 1 view .LVU64
|
|||
|
489:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** pFlash.ProcedureOnGoing = FLASH_PROC_NONE;
|
|||
|
225 .loc 1 489 23 is_stmt 0 view .LVU65
|
|||
|
226 0098 184B ldr r3, .L19+4
|
|||
|
227 009a 4FF0FF32 mov r2, #-1
|
|||
|
228 009e DA60 str r2, [r3, #12]
|
|||
|
490:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
229 .loc 1 490 9 is_stmt 1 view .LVU66
|
|||
|
490:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
230 .loc 1 490 33 is_stmt 0 view .LVU67
|
|||
|
231 00a0 0022 movs r2, #0
|
|||
|
232 00a2 1A70 strb r2, [r3]
|
|||
|
493:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
233 .loc 1 493 9 is_stmt 1 view .LVU68
|
|||
|
234 00a4 D868 ldr r0, [r3, #12]
|
|||
|
235 00a6 FFF7FEFF bl HAL_FLASH_EndOfOperationCallback
|
|||
|
236 .LVL15:
|
|||
|
496:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
237 .loc 1 496 9 view .LVU69
|
|||
|
238 00aa 134B ldr r3, .L19
|
|||
|
239 00ac 4FF48032 mov r2, #65536
|
|||
|
240 00b0 5A61 str r2, [r3, #20]
|
|||
|
241 00b2 C4E7 b .L4
|
|||
|
242 .LVL16:
|
|||
|
243 .L16:
|
|||
|
507:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
244 .loc 1 507 9 view .LVU70
|
|||
|
245 00b4 0120 movs r0, #1
|
|||
|
246 00b6 FFF7FEFF bl HAL_FLASH_EndOfOperationCallback
|
|||
|
247 .LVL17:
|
|||
|
248 00ba B5E7 b .L8
|
|||
|
249 .L17:
|
|||
|
513:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
250 .loc 1 513 9 view .LVU71
|
|||
|
251 00bc 0F4B ldr r3, .L19+4
|
|||
|
252 00be 1869 ldr r0, [r3, #16]
|
|||
|
253 00c0 FFF7FEFF bl HAL_FLASH_EndOfOperationCallback
|
|||
|
254 .LVL18:
|
|||
|
255 00c4 B0E7 b .L8
|
|||
|
256 .LVL19:
|
|||
|
257 .L18:
|
|||
|
623:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** pFlash.Sector = 0xFFFFFFFFU;
|
|||
|
258 .loc 1 623 7 view .LVU72
|
|||
|
623:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** pFlash.Sector = 0xFFFFFFFFU;
|
|||
|
259 .loc 1 623 12 is_stmt 0 view .LVU73
|
|||
|
260 00c6 1346 mov r3, r2
|
|||
|
261 .LVL20:
|
|||
|
623:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** pFlash.Sector = 0xFFFFFFFFU;
|
|||
|
262 .loc 1 623 12 view .LVU74
|
|||
|
263 00c8 D068 ldr r0, [r2, #12]
|
|||
|
264 .LVL21:
|
|||
|
624:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
265 .loc 1 624 7 is_stmt 1 view .LVU75
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 20
|
|||
|
|
|||
|
|
|||
|
624:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
266 .loc 1 624 21 is_stmt 0 view .LVU76
|
|||
|
267 00ca 4FF0FF32 mov r2, #-1
|
|||
|
268 00ce DA60 str r2, [r3, #12]
|
|||
|
269 .LVL22:
|
|||
|
270 .L11:
|
|||
|
638:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
271 .loc 1 638 5 is_stmt 1 view .LVU77
|
|||
|
638:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
272 .loc 1 638 29 is_stmt 0 view .LVU78
|
|||
|
273 00d0 0A4B ldr r3, .L19+4
|
|||
|
274 00d2 0022 movs r2, #0
|
|||
|
275 00d4 1A70 strb r2, [r3]
|
|||
|
276 .LVL23:
|
|||
|
641:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
277 .loc 1 641 5 is_stmt 1 view .LVU79
|
|||
|
278 00d6 FFF7FEFF bl HAL_FLASH_OperationErrorCallback
|
|||
|
279 .LVL24:
|
|||
|
280 .L9:
|
|||
|
689:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
281 .loc 1 689 3 view .LVU80
|
|||
|
689:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
282 .loc 1 689 12 is_stmt 0 view .LVU81
|
|||
|
283 00da 084B ldr r3, .L19+4
|
|||
|
284 00dc 1B78 ldrb r3, [r3] @ zero_extendqisi2
|
|||
|
689:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
285 .loc 1 689 5 view .LVU82
|
|||
|
286 00de 3BB9 cbnz r3, .L3
|
|||
|
693:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** FLASH_IT_STRBERR_BANK1 | FLASH_IT_INCERR_BANK1 | FLASH_IT_OPERR_BA
|
|||
|
287 .loc 1 693 5 is_stmt 1 view .LVU83
|
|||
|
288 00e0 054A ldr r2, .L19
|
|||
|
289 00e2 D368 ldr r3, [r2, #12]
|
|||
|
290 00e4 23F4DE03 bic r3, r3, #7274496
|
|||
|
291 00e8 D360 str r3, [r2, #12]
|
|||
|
714:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
292 .loc 1 714 5 view .LVU84
|
|||
|
714:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
293 .loc 1 714 5 view .LVU85
|
|||
|
294 00ea 044B ldr r3, .L19+4
|
|||
|
295 00ec 0022 movs r2, #0
|
|||
|
296 00ee 1A75 strb r2, [r3, #20]
|
|||
|
714:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
297 .loc 1 714 5 view .LVU86
|
|||
|
298 .L3:
|
|||
|
716:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
299 .loc 1 716 1 is_stmt 0 view .LVU87
|
|||
|
300 00f0 10BD pop {r4, pc}
|
|||
|
301 .LVL25:
|
|||
|
302 .L13:
|
|||
|
629:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
303 .loc 1 629 12 view .LVU88
|
|||
|
304 00f2 0120 movs r0, #1
|
|||
|
305 00f4 ECE7 b .L11
|
|||
|
306 .L20:
|
|||
|
307 00f6 00BF .align 2
|
|||
|
308 .L19:
|
|||
|
309 00f8 00200052 .word 1375739904
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 21
|
|||
|
|
|||
|
|
|||
|
310 00fc 00000000 .word .LANCHOR0
|
|||
|
311 .cfi_endproc
|
|||
|
312 .LFE143:
|
|||
|
314 .section .text.HAL_FLASH_Unlock,"ax",%progbits
|
|||
|
315 .align 1
|
|||
|
316 .global HAL_FLASH_Unlock
|
|||
|
317 .syntax unified
|
|||
|
318 .thumb
|
|||
|
319 .thumb_func
|
|||
|
320 .fpu fpv5-d16
|
|||
|
322 HAL_FLASH_Unlock:
|
|||
|
323 .LFB146:
|
|||
|
754:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
755:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /**
|
|||
|
756:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @}
|
|||
|
757:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** */
|
|||
|
758:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
759:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /** @defgroup FLASH_Exported_Functions_Group2 Peripheral Control functions
|
|||
|
760:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @brief Management functions
|
|||
|
761:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** *
|
|||
|
762:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** @verbatim
|
|||
|
763:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** ===============================================================================
|
|||
|
764:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** ##### Peripheral Control functions #####
|
|||
|
765:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** ===============================================================================
|
|||
|
766:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** [..]
|
|||
|
767:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** This subsection provides a set of functions allowing to control the FLASH
|
|||
|
768:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** memory operations.
|
|||
|
769:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
770:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** @endverbatim
|
|||
|
771:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @{
|
|||
|
772:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** */
|
|||
|
773:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
774:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /**
|
|||
|
775:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @brief Unlock the FLASH control registers access
|
|||
|
776:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @retval HAL Status
|
|||
|
777:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** */
|
|||
|
778:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** HAL_StatusTypeDef HAL_FLASH_Unlock(void)
|
|||
|
779:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
324 .loc 1 779 1 is_stmt 1 view -0
|
|||
|
325 .cfi_startproc
|
|||
|
326 @ args = 0, pretend = 0, frame = 0
|
|||
|
327 @ frame_needed = 0, uses_anonymous_args = 0
|
|||
|
328 @ link register save eliminated.
|
|||
|
780:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if(READ_BIT(FLASH->CR1, FLASH_CR_LOCK) != 0U)
|
|||
|
329 .loc 1 780 3 view .LVU90
|
|||
|
330 .loc 1 780 6 is_stmt 0 view .LVU91
|
|||
|
331 0000 0A4B ldr r3, .L25
|
|||
|
332 0002 DB68 ldr r3, [r3, #12]
|
|||
|
333 .loc 1 780 5 view .LVU92
|
|||
|
334 0004 13F0010F tst r3, #1
|
|||
|
335 0008 0BD0 beq .L23
|
|||
|
781:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
782:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Authorize the FLASH Bank1 Registers access */
|
|||
|
783:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** WRITE_REG(FLASH->KEYR1, FLASH_KEY1);
|
|||
|
336 .loc 1 783 5 is_stmt 1 view .LVU93
|
|||
|
337 000a 084B ldr r3, .L25
|
|||
|
338 000c 084A ldr r2, .L25+4
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 22
|
|||
|
|
|||
|
|
|||
|
339 000e 5A60 str r2, [r3, #4]
|
|||
|
784:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** WRITE_REG(FLASH->KEYR1, FLASH_KEY2);
|
|||
|
340 .loc 1 784 5 view .LVU94
|
|||
|
341 0010 02F18832 add r2, r2, #-2004318072
|
|||
|
342 0014 5A60 str r2, [r3, #4]
|
|||
|
785:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
786:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Verify Flash Bank1 is unlocked */
|
|||
|
787:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if (READ_BIT(FLASH->CR1, FLASH_CR_LOCK) != 0U)
|
|||
|
343 .loc 1 787 5 view .LVU95
|
|||
|
344 .loc 1 787 9 is_stmt 0 view .LVU96
|
|||
|
345 0016 DB68 ldr r3, [r3, #12]
|
|||
|
346 .loc 1 787 8 view .LVU97
|
|||
|
347 0018 13F0010F tst r3, #1
|
|||
|
348 001c 03D1 bne .L24
|
|||
|
788:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
789:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** return HAL_ERROR;
|
|||
|
790:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
791:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
792:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
793:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #if defined (DUAL_BANK)
|
|||
|
794:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if(READ_BIT(FLASH->CR2, FLASH_CR_LOCK) != 0U)
|
|||
|
795:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
796:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Authorize the FLASH Bank2 Registers access */
|
|||
|
797:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** WRITE_REG(FLASH->KEYR2, FLASH_KEY1);
|
|||
|
798:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** WRITE_REG(FLASH->KEYR2, FLASH_KEY2);
|
|||
|
799:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
800:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Verify Flash Bank2 is unlocked */
|
|||
|
801:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if (READ_BIT(FLASH->CR2, FLASH_CR_LOCK) != 0U)
|
|||
|
802:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
803:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** return HAL_ERROR;
|
|||
|
804:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
805:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
806:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #endif /* DUAL_BANK */
|
|||
|
807:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
808:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** return HAL_OK;
|
|||
|
349 .loc 1 808 10 view .LVU98
|
|||
|
350 001e 0020 movs r0, #0
|
|||
|
351 0020 7047 bx lr
|
|||
|
352 .L23:
|
|||
|
353 0022 0020 movs r0, #0
|
|||
|
354 0024 7047 bx lr
|
|||
|
355 .L24:
|
|||
|
789:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
356 .loc 1 789 14 view .LVU99
|
|||
|
357 0026 0120 movs r0, #1
|
|||
|
809:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
358 .loc 1 809 1 view .LVU100
|
|||
|
359 0028 7047 bx lr
|
|||
|
360 .L26:
|
|||
|
361 002a 00BF .align 2
|
|||
|
362 .L25:
|
|||
|
363 002c 00200052 .word 1375739904
|
|||
|
364 0030 23016745 .word 1164378403
|
|||
|
365 .cfi_endproc
|
|||
|
366 .LFE146:
|
|||
|
368 .section .text.HAL_FLASH_Lock,"ax",%progbits
|
|||
|
369 .align 1
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 23
|
|||
|
|
|||
|
|
|||
|
370 .global HAL_FLASH_Lock
|
|||
|
371 .syntax unified
|
|||
|
372 .thumb
|
|||
|
373 .thumb_func
|
|||
|
374 .fpu fpv5-d16
|
|||
|
376 HAL_FLASH_Lock:
|
|||
|
377 .LFB147:
|
|||
|
810:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
811:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /**
|
|||
|
812:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @brief Locks the FLASH control registers access
|
|||
|
813:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @retval HAL Status
|
|||
|
814:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** */
|
|||
|
815:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** HAL_StatusTypeDef HAL_FLASH_Lock(void)
|
|||
|
816:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
378 .loc 1 816 1 is_stmt 1 view -0
|
|||
|
379 .cfi_startproc
|
|||
|
380 @ args = 0, pretend = 0, frame = 0
|
|||
|
381 @ frame_needed = 0, uses_anonymous_args = 0
|
|||
|
382 @ link register save eliminated.
|
|||
|
817:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Set the LOCK Bit to lock the FLASH Bank1 Control Register access */
|
|||
|
818:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** SET_BIT(FLASH->CR1, FLASH_CR_LOCK);
|
|||
|
383 .loc 1 818 3 view .LVU102
|
|||
|
384 0000 064B ldr r3, .L30
|
|||
|
385 0002 DA68 ldr r2, [r3, #12]
|
|||
|
386 0004 42F00102 orr r2, r2, #1
|
|||
|
387 0008 DA60 str r2, [r3, #12]
|
|||
|
819:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
820:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Verify Flash Bank1 is locked */
|
|||
|
821:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if (READ_BIT(FLASH->CR1, FLASH_CR_LOCK) == 0U)
|
|||
|
388 .loc 1 821 3 view .LVU103
|
|||
|
389 .loc 1 821 7 is_stmt 0 view .LVU104
|
|||
|
390 000a DB68 ldr r3, [r3, #12]
|
|||
|
391 .loc 1 821 6 view .LVU105
|
|||
|
392 000c 13F0010F tst r3, #1
|
|||
|
393 0010 01D0 beq .L29
|
|||
|
822:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
823:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** return HAL_ERROR;
|
|||
|
824:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
825:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
826:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #if defined (DUAL_BANK)
|
|||
|
827:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Set the LOCK Bit to lock the FLASH Bank2 Control Register access */
|
|||
|
828:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** SET_BIT(FLASH->CR2, FLASH_CR_LOCK);
|
|||
|
829:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
830:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Verify Flash Bank2 is locked */
|
|||
|
831:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if (READ_BIT(FLASH->CR2, FLASH_CR_LOCK) == 0U)
|
|||
|
832:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
833:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** return HAL_ERROR;
|
|||
|
834:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
835:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #endif /* DUAL_BANK */
|
|||
|
836:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
837:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** return HAL_OK;
|
|||
|
394 .loc 1 837 10 view .LVU106
|
|||
|
395 0012 0020 movs r0, #0
|
|||
|
396 0014 7047 bx lr
|
|||
|
397 .L29:
|
|||
|
823:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
398 .loc 1 823 12 view .LVU107
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 24
|
|||
|
|
|||
|
|
|||
|
399 0016 0120 movs r0, #1
|
|||
|
838:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
400 .loc 1 838 1 view .LVU108
|
|||
|
401 0018 7047 bx lr
|
|||
|
402 .L31:
|
|||
|
403 001a 00BF .align 2
|
|||
|
404 .L30:
|
|||
|
405 001c 00200052 .word 1375739904
|
|||
|
406 .cfi_endproc
|
|||
|
407 .LFE147:
|
|||
|
409 .section .text.HAL_FLASH_OB_Unlock,"ax",%progbits
|
|||
|
410 .align 1
|
|||
|
411 .global HAL_FLASH_OB_Unlock
|
|||
|
412 .syntax unified
|
|||
|
413 .thumb
|
|||
|
414 .thumb_func
|
|||
|
415 .fpu fpv5-d16
|
|||
|
417 HAL_FLASH_OB_Unlock:
|
|||
|
418 .LFB148:
|
|||
|
839:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
840:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /**
|
|||
|
841:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @brief Unlock the FLASH Option Control Registers access.
|
|||
|
842:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @retval HAL Status
|
|||
|
843:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** */
|
|||
|
844:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** HAL_StatusTypeDef HAL_FLASH_OB_Unlock(void)
|
|||
|
845:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
419 .loc 1 845 1 is_stmt 1 view -0
|
|||
|
420 .cfi_startproc
|
|||
|
421 @ args = 0, pretend = 0, frame = 0
|
|||
|
422 @ frame_needed = 0, uses_anonymous_args = 0
|
|||
|
423 @ link register save eliminated.
|
|||
|
846:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if(READ_BIT(FLASH->OPTCR, FLASH_OPTCR_OPTLOCK) != 0U)
|
|||
|
424 .loc 1 846 3 view .LVU110
|
|||
|
425 .loc 1 846 6 is_stmt 0 view .LVU111
|
|||
|
426 0000 0A4B ldr r3, .L36
|
|||
|
427 0002 9B69 ldr r3, [r3, #24]
|
|||
|
428 .loc 1 846 5 view .LVU112
|
|||
|
429 0004 13F0010F tst r3, #1
|
|||
|
430 0008 0BD0 beq .L34
|
|||
|
847:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
848:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Authorizes the Option Byte registers programming */
|
|||
|
849:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** WRITE_REG(FLASH->OPTKEYR, FLASH_OPT_KEY1);
|
|||
|
431 .loc 1 849 5 is_stmt 1 view .LVU113
|
|||
|
432 000a 084B ldr r3, .L36
|
|||
|
433 000c 084A ldr r2, .L36+4
|
|||
|
434 000e 9A60 str r2, [r3, #8]
|
|||
|
850:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** WRITE_REG(FLASH->OPTKEYR, FLASH_OPT_KEY2);
|
|||
|
435 .loc 1 850 5 view .LVU114
|
|||
|
436 0010 02F14432 add r2, r2, #1145324612
|
|||
|
437 0014 9A60 str r2, [r3, #8]
|
|||
|
851:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
852:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Verify that the Option Bytes are unlocked */
|
|||
|
853:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if (READ_BIT(FLASH->OPTCR, FLASH_OPTCR_OPTLOCK) != 0U)
|
|||
|
438 .loc 1 853 5 view .LVU115
|
|||
|
439 .loc 1 853 9 is_stmt 0 view .LVU116
|
|||
|
440 0016 9B69 ldr r3, [r3, #24]
|
|||
|
441 .loc 1 853 8 view .LVU117
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 25
|
|||
|
|
|||
|
|
|||
|
442 0018 13F0010F tst r3, #1
|
|||
|
443 001c 03D1 bne .L35
|
|||
|
854:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
855:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** return HAL_ERROR;
|
|||
|
856:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
857:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
858:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
859:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** return HAL_OK;
|
|||
|
444 .loc 1 859 10 view .LVU118
|
|||
|
445 001e 0020 movs r0, #0
|
|||
|
446 0020 7047 bx lr
|
|||
|
447 .L34:
|
|||
|
448 0022 0020 movs r0, #0
|
|||
|
449 0024 7047 bx lr
|
|||
|
450 .L35:
|
|||
|
855:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
451 .loc 1 855 14 view .LVU119
|
|||
|
452 0026 0120 movs r0, #1
|
|||
|
860:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
453 .loc 1 860 1 view .LVU120
|
|||
|
454 0028 7047 bx lr
|
|||
|
455 .L37:
|
|||
|
456 002a 00BF .align 2
|
|||
|
457 .L36:
|
|||
|
458 002c 00200052 .word 1375739904
|
|||
|
459 0030 3B2A1908 .word 135866939
|
|||
|
460 .cfi_endproc
|
|||
|
461 .LFE148:
|
|||
|
463 .section .text.HAL_FLASH_OB_Lock,"ax",%progbits
|
|||
|
464 .align 1
|
|||
|
465 .global HAL_FLASH_OB_Lock
|
|||
|
466 .syntax unified
|
|||
|
467 .thumb
|
|||
|
468 .thumb_func
|
|||
|
469 .fpu fpv5-d16
|
|||
|
471 HAL_FLASH_OB_Lock:
|
|||
|
472 .LFB149:
|
|||
|
861:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
862:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /**
|
|||
|
863:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @brief Lock the FLASH Option Control Registers access.
|
|||
|
864:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @retval HAL Status
|
|||
|
865:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** */
|
|||
|
866:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** HAL_StatusTypeDef HAL_FLASH_OB_Lock(void)
|
|||
|
867:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
473 .loc 1 867 1 is_stmt 1 view -0
|
|||
|
474 .cfi_startproc
|
|||
|
475 @ args = 0, pretend = 0, frame = 0
|
|||
|
476 @ frame_needed = 0, uses_anonymous_args = 0
|
|||
|
477 @ link register save eliminated.
|
|||
|
868:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Set the OPTLOCK Bit to lock the FLASH Option Byte Registers access */
|
|||
|
869:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** SET_BIT(FLASH->OPTCR, FLASH_OPTCR_OPTLOCK);
|
|||
|
478 .loc 1 869 3 view .LVU122
|
|||
|
479 0000 064B ldr r3, .L41
|
|||
|
480 0002 9A69 ldr r2, [r3, #24]
|
|||
|
481 0004 42F00102 orr r2, r2, #1
|
|||
|
482 0008 9A61 str r2, [r3, #24]
|
|||
|
870:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 26
|
|||
|
|
|||
|
|
|||
|
871:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Verify that the Option Bytes are locked */
|
|||
|
872:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if (READ_BIT(FLASH->OPTCR, FLASH_OPTCR_OPTLOCK) == 0U)
|
|||
|
483 .loc 1 872 3 view .LVU123
|
|||
|
484 .loc 1 872 7 is_stmt 0 view .LVU124
|
|||
|
485 000a 9B69 ldr r3, [r3, #24]
|
|||
|
486 .loc 1 872 6 view .LVU125
|
|||
|
487 000c 13F0010F tst r3, #1
|
|||
|
488 0010 01D0 beq .L40
|
|||
|
873:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
874:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** return HAL_ERROR;
|
|||
|
875:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
876:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
877:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** return HAL_OK;
|
|||
|
489 .loc 1 877 10 view .LVU126
|
|||
|
490 0012 0020 movs r0, #0
|
|||
|
491 0014 7047 bx lr
|
|||
|
492 .L40:
|
|||
|
874:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
493 .loc 1 874 12 view .LVU127
|
|||
|
494 0016 0120 movs r0, #1
|
|||
|
878:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
495 .loc 1 878 1 view .LVU128
|
|||
|
496 0018 7047 bx lr
|
|||
|
497 .L42:
|
|||
|
498 001a 00BF .align 2
|
|||
|
499 .L41:
|
|||
|
500 001c 00200052 .word 1375739904
|
|||
|
501 .cfi_endproc
|
|||
|
502 .LFE149:
|
|||
|
504 .section .text.HAL_FLASH_GetError,"ax",%progbits
|
|||
|
505 .align 1
|
|||
|
506 .global HAL_FLASH_GetError
|
|||
|
507 .syntax unified
|
|||
|
508 .thumb
|
|||
|
509 .thumb_func
|
|||
|
510 .fpu fpv5-d16
|
|||
|
512 HAL_FLASH_GetError:
|
|||
|
513 .LFB151:
|
|||
|
879:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
880:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /**
|
|||
|
881:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @brief Launch the option bytes loading.
|
|||
|
882:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @retval HAL Status
|
|||
|
883:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** */
|
|||
|
884:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** HAL_StatusTypeDef HAL_FLASH_OB_Launch(void)
|
|||
|
885:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
886:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** HAL_StatusTypeDef status;
|
|||
|
887:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
888:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Wait for CRC computation to be completed */
|
|||
|
889:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if (FLASH_CRC_WaitForLastOperation((uint32_t)FLASH_TIMEOUT_VALUE, FLASH_BANK_1) != HAL_OK)
|
|||
|
890:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
891:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** status = HAL_ERROR;
|
|||
|
892:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
893:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #if defined (DUAL_BANK)
|
|||
|
894:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** else if (FLASH_CRC_WaitForLastOperation((uint32_t)FLASH_TIMEOUT_VALUE, FLASH_BANK_2) != HAL_OK)
|
|||
|
895:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
896:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** status = HAL_ERROR;
|
|||
|
897:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 27
|
|||
|
|
|||
|
|
|||
|
898:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #endif /* DUAL_BANK */
|
|||
|
899:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** else
|
|||
|
900:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
901:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** status = HAL_OK;
|
|||
|
902:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
903:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
904:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if (status == HAL_OK)
|
|||
|
905:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
906:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Set OPTSTRT Bit */
|
|||
|
907:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** SET_BIT(FLASH->OPTCR, FLASH_OPTCR_OPTSTART);
|
|||
|
908:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
909:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Wait for OB change operation to be completed */
|
|||
|
910:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** status = FLASH_OB_WaitForLastOperation((uint32_t)FLASH_TIMEOUT_VALUE);
|
|||
|
911:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
912:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
913:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** return status;
|
|||
|
914:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
915:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
916:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /**
|
|||
|
917:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @}
|
|||
|
918:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** */
|
|||
|
919:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
920:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /** @defgroup FLASH_Exported_Functions_Group3 Peripheral State and Errors functions
|
|||
|
921:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @brief Peripheral Errors functions
|
|||
|
922:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** *
|
|||
|
923:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** @verbatim
|
|||
|
924:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** ===============================================================================
|
|||
|
925:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** ##### Peripheral Errors functions #####
|
|||
|
926:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** ===============================================================================
|
|||
|
927:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** [..]
|
|||
|
928:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** This subsection permits to get in run-time Errors of the FLASH peripheral.
|
|||
|
929:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
930:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** @endverbatim
|
|||
|
931:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @{
|
|||
|
932:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** */
|
|||
|
933:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
934:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /**
|
|||
|
935:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @brief Get the specific FLASH error flag.
|
|||
|
936:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @retval HAL_FLASH_ERRORCode The returned value can be:
|
|||
|
937:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @arg HAL_FLASH_ERROR_NONE : No error set
|
|||
|
938:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** *
|
|||
|
939:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @arg HAL_FLASH_ERROR_WRP_BANK1 : Write Protection Error on Bank 1
|
|||
|
940:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @arg HAL_FLASH_ERROR_PGS_BANK1 : Program Sequence Error on Bank 1
|
|||
|
941:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @arg HAL_FLASH_ERROR_STRB_BANK1 : Strobe Error on Bank 1
|
|||
|
942:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @arg HAL_FLASH_ERROR_INC_BANK1 : Inconsistency Error on Bank 1
|
|||
|
943:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @arg HAL_FLASH_ERROR_OPE_BANK1 : Operation Error on Bank 1
|
|||
|
944:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @arg HAL_FLASH_ERROR_RDP_BANK1 : Read Protection Error on Bank 1
|
|||
|
945:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @arg HAL_FLASH_ERROR_RDS_BANK1 : Read Secured Error on Bank 1
|
|||
|
946:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @arg HAL_FLASH_ERROR_SNECC_BANK1: ECC Single Correction Error on Bank 1
|
|||
|
947:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @arg HAL_FLASH_ERROR_DBECC_BANK1: ECC Double Detection Error on Bank 1
|
|||
|
948:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @arg HAL_FLASH_ERROR_CRCRD_BANK1: CRC Read Error on Bank 1
|
|||
|
949:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** *
|
|||
|
950:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @arg HAL_FLASH_ERROR_WRP_BANK2 : Write Protection Error on Bank 2
|
|||
|
951:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @arg HAL_FLASH_ERROR_PGS_BANK2 : Program Sequence Error on Bank 2
|
|||
|
952:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @arg HAL_FLASH_ERROR_STRB_BANK2 : Strobe Error on Bank 2
|
|||
|
953:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @arg HAL_FLASH_ERROR_INC_BANK2 : Inconsistency Error on Bank 2
|
|||
|
954:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @arg HAL_FLASH_ERROR_OPE_BANK2 : Operation Error on Bank 2
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 28
|
|||
|
|
|||
|
|
|||
|
955:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @arg HAL_FLASH_ERROR_RDP_BANK2 : Read Protection Error on Bank 2
|
|||
|
956:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @arg HAL_FLASH_ERROR_RDS_BANK2 : Read Secured Error on Bank 2
|
|||
|
957:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @arg HAL_FLASH_ERROR_SNECC_BANK2: SNECC Error on Bank 2
|
|||
|
958:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @arg HAL_FLASH_ERROR_DBECC_BANK2: Double Detection ECC on Bank 2
|
|||
|
959:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @arg HAL_FLASH_ERROR_CRCRD_BANK2: CRC Read Error on Bank 2
|
|||
|
960:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** */
|
|||
|
961:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
962:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** uint32_t HAL_FLASH_GetError(void)
|
|||
|
963:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
514 .loc 1 963 1 is_stmt 1 view -0
|
|||
|
515 .cfi_startproc
|
|||
|
516 @ args = 0, pretend = 0, frame = 0
|
|||
|
517 @ frame_needed = 0, uses_anonymous_args = 0
|
|||
|
518 @ link register save eliminated.
|
|||
|
964:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** return pFlash.ErrorCode;
|
|||
|
519 .loc 1 964 4 view .LVU130
|
|||
|
520 .loc 1 964 17 is_stmt 0 view .LVU131
|
|||
|
521 0000 014B ldr r3, .L44
|
|||
|
522 0002 9869 ldr r0, [r3, #24]
|
|||
|
965:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
523 .loc 1 965 1 view .LVU132
|
|||
|
524 0004 7047 bx lr
|
|||
|
525 .L45:
|
|||
|
526 0006 00BF .align 2
|
|||
|
527 .L44:
|
|||
|
528 0008 00000000 .word .LANCHOR0
|
|||
|
529 .cfi_endproc
|
|||
|
530 .LFE151:
|
|||
|
532 .section .text.FLASH_WaitForLastOperation,"ax",%progbits
|
|||
|
533 .align 1
|
|||
|
534 .global FLASH_WaitForLastOperation
|
|||
|
535 .syntax unified
|
|||
|
536 .thumb
|
|||
|
537 .thumb_func
|
|||
|
538 .fpu fpv5-d16
|
|||
|
540 FLASH_WaitForLastOperation:
|
|||
|
541 .LVL26:
|
|||
|
542 .LFB152:
|
|||
|
966:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
967:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /**
|
|||
|
968:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @}
|
|||
|
969:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** */
|
|||
|
970:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
971:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /**
|
|||
|
972:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @}
|
|||
|
973:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** */
|
|||
|
974:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
975:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Private functions ---------------------------------------------------------*/
|
|||
|
976:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
977:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /** @addtogroup FLASH_Private_Functions
|
|||
|
978:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @{
|
|||
|
979:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** */
|
|||
|
980:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
981:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /**
|
|||
|
982:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @brief Wait for a FLASH operation to complete.
|
|||
|
983:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @param Timeout maximum flash operation timeout
|
|||
|
984:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @param Bank flash FLASH_BANK_1 or FLASH_BANK_2
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 29
|
|||
|
|
|||
|
|
|||
|
985:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @retval HAL_StatusTypeDef HAL Status
|
|||
|
986:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** */
|
|||
|
987:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** HAL_StatusTypeDef FLASH_WaitForLastOperation(uint32_t Timeout, uint32_t Bank)
|
|||
|
988:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
543 .loc 1 988 1 is_stmt 1 view -0
|
|||
|
544 .cfi_startproc
|
|||
|
545 @ args = 0, pretend = 0, frame = 0
|
|||
|
546 @ frame_needed = 0, uses_anonymous_args = 0
|
|||
|
547 .loc 1 988 1 is_stmt 0 view .LVU134
|
|||
|
548 0000 F8B5 push {r3, r4, r5, r6, r7, lr}
|
|||
|
549 .LCFI1:
|
|||
|
550 .cfi_def_cfa_offset 24
|
|||
|
551 .cfi_offset 3, -24
|
|||
|
552 .cfi_offset 4, -20
|
|||
|
553 .cfi_offset 5, -16
|
|||
|
554 .cfi_offset 6, -12
|
|||
|
555 .cfi_offset 7, -8
|
|||
|
556 .cfi_offset 14, -4
|
|||
|
557 0002 0446 mov r4, r0
|
|||
|
558 0004 0F46 mov r7, r1
|
|||
|
989:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Wait for the FLASH operation to complete by polling on QW flag to be reset.
|
|||
|
990:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** Even if the FLASH operation fails, the QW flag will be reset and an error
|
|||
|
991:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** flag will be set */
|
|||
|
992:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
993:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** uint32_t bsyflag = FLASH_FLAG_QW_BANK1;
|
|||
|
559 .loc 1 993 3 is_stmt 1 view .LVU135
|
|||
|
560 .LVL27:
|
|||
|
994:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** uint32_t errorflag = FLASH->SR1 & FLASH_FLAG_ALL_ERRORS_BANK1;
|
|||
|
561 .loc 1 994 3 view .LVU136
|
|||
|
562 .loc 1 994 29 is_stmt 0 view .LVU137
|
|||
|
563 0006 1C4B ldr r3, .L60
|
|||
|
564 0008 1D69 ldr r5, [r3, #16]
|
|||
|
565 .loc 1 994 12 view .LVU138
|
|||
|
566 000a 25F06845 bic r5, r5, #-402653184
|
|||
|
567 000e 25F48015 bic r5, r5, #1048576
|
|||
|
568 0012 6D0C lsrs r5, r5, #17
|
|||
|
569 0014 6D04 lsls r5, r5, #17
|
|||
|
570 .LVL28:
|
|||
|
995:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** uint32_t tickstart = HAL_GetTick();
|
|||
|
571 .loc 1 995 3 is_stmt 1 view .LVU139
|
|||
|
572 .loc 1 995 24 is_stmt 0 view .LVU140
|
|||
|
573 0016 FFF7FEFF bl HAL_GetTick
|
|||
|
574 .LVL29:
|
|||
|
575 .loc 1 995 24 view .LVU141
|
|||
|
576 001a 0646 mov r6, r0
|
|||
|
577 .LVL30:
|
|||
|
996:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
997:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** assert_param(IS_FLASH_BANK_EXCLUSIVE(Bank));
|
|||
|
578 .loc 1 997 3 is_stmt 1 view .LVU142
|
|||
|
998:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
999:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #if defined (DUAL_BANK)
|
|||
|
1000:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
1001:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if (Bank == FLASH_BANK_2)
|
|||
|
1002:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
1003:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Get Error Flags */
|
|||
|
1004:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** errorflag = (FLASH->SR2 & FLASH_FLAG_ALL_ERRORS_BANK2) | 0x80000000U;
|
|||
|
1005:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Select bsyflag depending on Bank */
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 30
|
|||
|
|
|||
|
|
|||
|
1006:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** bsyflag = FLASH_FLAG_QW_BANK2;
|
|||
|
1007:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
1008:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #endif /* DUAL_BANK */
|
|||
|
1009:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
1010:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** while(__HAL_FLASH_GET_FLAG(bsyflag))
|
|||
|
579 .loc 1 1010 3 view .LVU143
|
|||
|
580 .L48:
|
|||
|
581 .loc 1 1010 8 view .LVU144
|
|||
|
582 .loc 1 1010 9 is_stmt 0 view .LVU145
|
|||
|
583 001c 164B ldr r3, .L60
|
|||
|
584 001e 1B69 ldr r3, [r3, #16]
|
|||
|
585 .loc 1 1010 8 view .LVU146
|
|||
|
586 0020 13F0040F tst r3, #4
|
|||
|
587 0024 0BD0 beq .L57
|
|||
|
1011:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
1012:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if(Timeout != HAL_MAX_DELAY)
|
|||
|
588 .loc 1 1012 5 is_stmt 1 view .LVU147
|
|||
|
589 .loc 1 1012 7 is_stmt 0 view .LVU148
|
|||
|
590 0026 B4F1FF3F cmp r4, #-1
|
|||
|
591 002a F7D0 beq .L48
|
|||
|
1013:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
1014:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if(((HAL_GetTick() - tickstart) > Timeout) || (Timeout == 0U))
|
|||
|
592 .loc 1 1014 7 is_stmt 1 view .LVU149
|
|||
|
593 .loc 1 1014 12 is_stmt 0 view .LVU150
|
|||
|
594 002c FFF7FEFF bl HAL_GetTick
|
|||
|
595 .LVL31:
|
|||
|
596 .loc 1 1014 26 view .LVU151
|
|||
|
597 0030 801B subs r0, r0, r6
|
|||
|
598 .loc 1 1014 9 view .LVU152
|
|||
|
599 0032 A042 cmp r0, r4
|
|||
|
600 0034 1BD8 bhi .L52
|
|||
|
601 .loc 1 1014 50 discriminator 1 view .LVU153
|
|||
|
602 0036 002C cmp r4, #0
|
|||
|
603 0038 F0D1 bne .L48
|
|||
|
1015:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
1016:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** return HAL_TIMEOUT;
|
|||
|
604 .loc 1 1016 16 view .LVU154
|
|||
|
605 003a 0320 movs r0, #3
|
|||
|
606 003c 03E0 b .L49
|
|||
|
607 .L57:
|
|||
|
1017:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
1018:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
1019:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
1020:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
1021:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* In case of error reported in Flash SR1 or SR2 register */
|
|||
|
1022:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if((errorflag & 0x7FFFFFFFU) != 0U)
|
|||
|
608 .loc 1 1022 3 is_stmt 1 view .LVU155
|
|||
|
609 .loc 1 1022 5 is_stmt 0 view .LVU156
|
|||
|
610 003e 1DB9 cbnz r5, .L58
|
|||
|
1023:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
1024:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /*Save the error code*/
|
|||
|
1025:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** pFlash.ErrorCode |= errorflag;
|
|||
|
1026:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
1027:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Clear error programming flags */
|
|||
|
1028:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** __HAL_FLASH_CLEAR_FLAG(errorflag);
|
|||
|
1029:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
1030:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** return HAL_ERROR;
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 31
|
|||
|
|
|||
|
|
|||
|
1031:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
1032:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
1033:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Check FLASH End of Operation flag */
|
|||
|
1034:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if(Bank == FLASH_BANK_1)
|
|||
|
611 .loc 1 1034 3 is_stmt 1 view .LVU157
|
|||
|
612 .loc 1 1034 5 is_stmt 0 view .LVU158
|
|||
|
613 0040 012F cmp r7, #1
|
|||
|
614 0042 09D0 beq .L59
|
|||
|
1035:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
1036:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if (__HAL_FLASH_GET_FLAG_BANK1(FLASH_FLAG_EOP_BANK1))
|
|||
|
1037:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
1038:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Clear FLASH End of Operation pending bit */
|
|||
|
1039:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** __HAL_FLASH_CLEAR_FLAG_BANK1(FLASH_FLAG_EOP_BANK1);
|
|||
|
1040:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
1041:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
1042:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #if defined (DUAL_BANK)
|
|||
|
1043:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** else
|
|||
|
1044:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
1045:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if (__HAL_FLASH_GET_FLAG_BANK2(FLASH_FLAG_EOP_BANK2))
|
|||
|
1046:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
1047:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Clear FLASH End of Operation pending bit */
|
|||
|
1048:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** __HAL_FLASH_CLEAR_FLAG_BANK2(FLASH_FLAG_EOP_BANK2);
|
|||
|
1049:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
1050:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
1051:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #endif /* DUAL_BANK */
|
|||
|
1052:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
1053:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** return HAL_OK;
|
|||
|
615 .loc 1 1053 10 view .LVU159
|
|||
|
616 0044 0020 movs r0, #0
|
|||
|
617 .L49:
|
|||
|
1054:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
618 .loc 1 1054 1 view .LVU160
|
|||
|
619 0046 F8BD pop {r3, r4, r5, r6, r7, pc}
|
|||
|
620 .LVL32:
|
|||
|
621 .L58:
|
|||
|
1025:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
622 .loc 1 1025 5 is_stmt 1 view .LVU161
|
|||
|
1025:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
623 .loc 1 1025 22 is_stmt 0 view .LVU162
|
|||
|
624 0048 0C4A ldr r2, .L60+4
|
|||
|
625 004a 9369 ldr r3, [r2, #24]
|
|||
|
626 004c 2B43 orrs r3, r3, r5
|
|||
|
627 004e 9361 str r3, [r2, #24]
|
|||
|
1028:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
628 .loc 1 1028 5 is_stmt 1 view .LVU163
|
|||
|
629 0050 094B ldr r3, .L60
|
|||
|
630 0052 5D61 str r5, [r3, #20]
|
|||
|
1030:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
631 .loc 1 1030 5 view .LVU164
|
|||
|
1030:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
632 .loc 1 1030 12 is_stmt 0 view .LVU165
|
|||
|
633 0054 0120 movs r0, #1
|
|||
|
634 0056 F6E7 b .L49
|
|||
|
635 .L59:
|
|||
|
1036:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
636 .loc 1 1036 5 is_stmt 1 view .LVU166
|
|||
|
1036:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 32
|
|||
|
|
|||
|
|
|||
|
637 .loc 1 1036 9 is_stmt 0 view .LVU167
|
|||
|
638 0058 074B ldr r3, .L60
|
|||
|
639 005a 1B69 ldr r3, [r3, #16]
|
|||
|
1036:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
640 .loc 1 1036 8 view .LVU168
|
|||
|
641 005c 13F4803F tst r3, #65536
|
|||
|
642 0060 07D0 beq .L55
|
|||
|
1039:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
643 .loc 1 1039 7 is_stmt 1 view .LVU169
|
|||
|
644 0062 054B ldr r3, .L60
|
|||
|
645 0064 4FF48032 mov r2, #65536
|
|||
|
646 0068 5A61 str r2, [r3, #20]
|
|||
|
1053:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
647 .loc 1 1053 10 is_stmt 0 view .LVU170
|
|||
|
648 006a 0020 movs r0, #0
|
|||
|
649 006c EBE7 b .L49
|
|||
|
650 .L52:
|
|||
|
1016:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
651 .loc 1 1016 16 view .LVU171
|
|||
|
652 006e 0320 movs r0, #3
|
|||
|
653 0070 E9E7 b .L49
|
|||
|
654 .L55:
|
|||
|
1053:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
655 .loc 1 1053 10 view .LVU172
|
|||
|
656 0072 0020 movs r0, #0
|
|||
|
657 0074 E7E7 b .L49
|
|||
|
658 .L61:
|
|||
|
659 0076 00BF .align 2
|
|||
|
660 .L60:
|
|||
|
661 0078 00200052 .word 1375739904
|
|||
|
662 007c 00000000 .word .LANCHOR0
|
|||
|
663 .cfi_endproc
|
|||
|
664 .LFE152:
|
|||
|
666 .section .text.HAL_FLASH_Program,"ax",%progbits
|
|||
|
667 .align 1
|
|||
|
668 .global HAL_FLASH_Program
|
|||
|
669 .syntax unified
|
|||
|
670 .thumb
|
|||
|
671 .thumb_func
|
|||
|
672 .fpu fpv5-d16
|
|||
|
674 HAL_FLASH_Program:
|
|||
|
675 .LVL33:
|
|||
|
676 .LFB141:
|
|||
|
146:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** HAL_StatusTypeDef status;
|
|||
|
677 .loc 1 146 1 is_stmt 1 view -0
|
|||
|
678 .cfi_startproc
|
|||
|
679 @ args = 0, pretend = 0, frame = 0
|
|||
|
680 @ frame_needed = 0, uses_anonymous_args = 0
|
|||
|
146:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** HAL_StatusTypeDef status;
|
|||
|
681 .loc 1 146 1 is_stmt 0 view .LVU174
|
|||
|
682 0000 38B5 push {r3, r4, r5, lr}
|
|||
|
683 .LCFI2:
|
|||
|
684 .cfi_def_cfa_offset 16
|
|||
|
685 .cfi_offset 3, -16
|
|||
|
686 .cfi_offset 4, -12
|
|||
|
687 .cfi_offset 5, -8
|
|||
|
688 .cfi_offset 14, -4
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 33
|
|||
|
|
|||
|
|
|||
|
147:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** __IO uint32_t *dest_addr = (__IO uint32_t *)FlashAddress;
|
|||
|
689 .loc 1 147 3 is_stmt 1 view .LVU175
|
|||
|
148:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** __IO uint32_t *src_addr = (__IO uint32_t*)DataAddress;
|
|||
|
690 .loc 1 148 3 view .LVU176
|
|||
|
691 .LVL34:
|
|||
|
149:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** uint32_t bank;
|
|||
|
692 .loc 1 149 3 view .LVU177
|
|||
|
150:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** uint8_t row_index = FLASH_NB_32BITWORD_IN_FLASHWORD;
|
|||
|
693 .loc 1 150 3 view .LVU178
|
|||
|
151:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
694 .loc 1 151 3 view .LVU179
|
|||
|
154:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** assert_param(IS_FLASH_PROGRAM_ADDRESS(FlashAddress));
|
|||
|
695 .loc 1 154 3 view .LVU180
|
|||
|
155:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
696 .loc 1 155 3 view .LVU181
|
|||
|
158:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
697 .loc 1 158 3 view .LVU182
|
|||
|
158:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
698 .loc 1 158 3 view .LVU183
|
|||
|
699 0002 1F4B ldr r3, .L70
|
|||
|
700 0004 1B7D ldrb r3, [r3, #20] @ zero_extendqisi2
|
|||
|
701 0006 012B cmp r3, #1
|
|||
|
702 0008 37D0 beq .L66
|
|||
|
703 000a 0D46 mov r5, r1
|
|||
|
704 000c 1446 mov r4, r2
|
|||
|
158:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
705 .loc 1 158 3 discriminator 2 view .LVU184
|
|||
|
706 000e 1C4B ldr r3, .L70
|
|||
|
707 0010 0122 movs r2, #1
|
|||
|
708 .LVL35:
|
|||
|
158:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
709 .loc 1 158 3 is_stmt 0 discriminator 2 view .LVU185
|
|||
|
710 0012 1A75 strb r2, [r3, #20]
|
|||
|
158:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
711 .loc 1 158 3 is_stmt 1 discriminator 2 view .LVU186
|
|||
|
163:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #endif /* FLASH_OPTCR_PG_OTP */
|
|||
|
712 .loc 1 163 3 discriminator 2 view .LVU187
|
|||
|
163:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #endif /* FLASH_OPTCR_PG_OTP */
|
|||
|
713 .loc 1 163 6 is_stmt 0 discriminator 2 view .LVU188
|
|||
|
714 0014 01F17841 add r1, r1, #-134217728
|
|||
|
715 .LVL36:
|
|||
|
163:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #endif /* FLASH_OPTCR_PG_OTP */
|
|||
|
716 .loc 1 163 5 discriminator 2 view .LVU189
|
|||
|
717 0018 B1F5003F cmp r1, #131072
|
|||
|
718 001c 01D3 bcc .L69
|
|||
|
176:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
719 .loc 1 176 12 view .LVU190
|
|||
|
720 001e 0120 movs r0, #1
|
|||
|
721 .LVL37:
|
|||
|
722 .L63:
|
|||
|
292:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
723 .loc 1 292 1 view .LVU191
|
|||
|
724 0020 38BD pop {r3, r4, r5, pc}
|
|||
|
725 .LVL38:
|
|||
|
726 .L69:
|
|||
|
166:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
727 .loc 1 166 5 is_stmt 1 view .LVU192
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 34
|
|||
|
|
|||
|
|
|||
|
180:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
728 .loc 1 180 3 view .LVU193
|
|||
|
180:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
729 .loc 1 180 20 is_stmt 0 view .LVU194
|
|||
|
730 0022 0022 movs r2, #0
|
|||
|
731 0024 9A61 str r2, [r3, #24]
|
|||
|
183:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
732 .loc 1 183 3 is_stmt 1 view .LVU195
|
|||
|
183:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
733 .loc 1 183 12 is_stmt 0 view .LVU196
|
|||
|
734 0026 0121 movs r1, #1
|
|||
|
735 0028 4CF25030 movw r0, #50000
|
|||
|
736 .LVL39:
|
|||
|
183:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
737 .loc 1 183 12 view .LVU197
|
|||
|
738 002c FFF7FEFF bl FLASH_WaitForLastOperation
|
|||
|
739 .LVL40:
|
|||
|
185:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
740 .loc 1 185 3 is_stmt 1 view .LVU198
|
|||
|
185:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
741 .loc 1 185 5 is_stmt 0 view .LVU199
|
|||
|
742 0030 F8B9 cbnz r0, .L64
|
|||
|
219:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
743 .loc 1 219 9 is_stmt 1 view .LVU200
|
|||
|
744 0032 144A ldr r2, .L70+4
|
|||
|
745 0034 D368 ldr r3, [r2, #12]
|
|||
|
746 0036 43F00203 orr r3, r3, #2
|
|||
|
747 003a D360 str r3, [r2, #12]
|
|||
|
223:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** __DSB();
|
|||
|
748 .loc 1 223 5 view .LVU201
|
|||
|
749 .LBB18:
|
|||
|
750 .LBI18:
|
|||
|
751 .file 2 "Drivers/CMSIS/Include/cmsis_gcc.h"
|
|||
|
1:Drivers/CMSIS/Include/cmsis_gcc.h **** /**************************************************************************//**
|
|||
|
2:Drivers/CMSIS/Include/cmsis_gcc.h **** * @file cmsis_gcc.h
|
|||
|
3:Drivers/CMSIS/Include/cmsis_gcc.h **** * @brief CMSIS compiler GCC header file
|
|||
|
4:Drivers/CMSIS/Include/cmsis_gcc.h **** * @version V5.0.4
|
|||
|
5:Drivers/CMSIS/Include/cmsis_gcc.h **** * @date 09. April 2018
|
|||
|
6:Drivers/CMSIS/Include/cmsis_gcc.h **** ******************************************************************************/
|
|||
|
7:Drivers/CMSIS/Include/cmsis_gcc.h **** /*
|
|||
|
8:Drivers/CMSIS/Include/cmsis_gcc.h **** * Copyright (c) 2009-2018 Arm Limited. All rights reserved.
|
|||
|
9:Drivers/CMSIS/Include/cmsis_gcc.h **** *
|
|||
|
10:Drivers/CMSIS/Include/cmsis_gcc.h **** * SPDX-License-Identifier: Apache-2.0
|
|||
|
11:Drivers/CMSIS/Include/cmsis_gcc.h **** *
|
|||
|
12:Drivers/CMSIS/Include/cmsis_gcc.h **** * Licensed under the Apache License, Version 2.0 (the License); you may
|
|||
|
13:Drivers/CMSIS/Include/cmsis_gcc.h **** * not use this file except in compliance with the License.
|
|||
|
14:Drivers/CMSIS/Include/cmsis_gcc.h **** * You may obtain a copy of the License at
|
|||
|
15:Drivers/CMSIS/Include/cmsis_gcc.h **** *
|
|||
|
16:Drivers/CMSIS/Include/cmsis_gcc.h **** * www.apache.org/licenses/LICENSE-2.0
|
|||
|
17:Drivers/CMSIS/Include/cmsis_gcc.h **** *
|
|||
|
18:Drivers/CMSIS/Include/cmsis_gcc.h **** * Unless required by applicable law or agreed to in writing, software
|
|||
|
19:Drivers/CMSIS/Include/cmsis_gcc.h **** * distributed under the License is distributed on an AS IS BASIS, WITHOUT
|
|||
|
20:Drivers/CMSIS/Include/cmsis_gcc.h **** * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|||
|
21:Drivers/CMSIS/Include/cmsis_gcc.h **** * See the License for the specific language governing permissions and
|
|||
|
22:Drivers/CMSIS/Include/cmsis_gcc.h **** * limitations under the License.
|
|||
|
23:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
24:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 35
|
|||
|
|
|||
|
|
|||
|
25:Drivers/CMSIS/Include/cmsis_gcc.h **** #ifndef __CMSIS_GCC_H
|
|||
|
26:Drivers/CMSIS/Include/cmsis_gcc.h **** #define __CMSIS_GCC_H
|
|||
|
27:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
28:Drivers/CMSIS/Include/cmsis_gcc.h **** /* ignore some GCC warnings */
|
|||
|
29:Drivers/CMSIS/Include/cmsis_gcc.h **** #pragma GCC diagnostic push
|
|||
|
30:Drivers/CMSIS/Include/cmsis_gcc.h **** #pragma GCC diagnostic ignored "-Wsign-conversion"
|
|||
|
31:Drivers/CMSIS/Include/cmsis_gcc.h **** #pragma GCC diagnostic ignored "-Wconversion"
|
|||
|
32:Drivers/CMSIS/Include/cmsis_gcc.h **** #pragma GCC diagnostic ignored "-Wunused-parameter"
|
|||
|
33:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
34:Drivers/CMSIS/Include/cmsis_gcc.h **** /* Fallback for __has_builtin */
|
|||
|
35:Drivers/CMSIS/Include/cmsis_gcc.h **** #ifndef __has_builtin
|
|||
|
36:Drivers/CMSIS/Include/cmsis_gcc.h **** #define __has_builtin(x) (0)
|
|||
|
37:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
|
|||
|
38:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
39:Drivers/CMSIS/Include/cmsis_gcc.h **** /* CMSIS compiler specific defines */
|
|||
|
40:Drivers/CMSIS/Include/cmsis_gcc.h **** #ifndef __ASM
|
|||
|
41:Drivers/CMSIS/Include/cmsis_gcc.h **** #define __ASM __asm
|
|||
|
42:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
|
|||
|
43:Drivers/CMSIS/Include/cmsis_gcc.h **** #ifndef __INLINE
|
|||
|
44:Drivers/CMSIS/Include/cmsis_gcc.h **** #define __INLINE inline
|
|||
|
45:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
|
|||
|
46:Drivers/CMSIS/Include/cmsis_gcc.h **** #ifndef __STATIC_INLINE
|
|||
|
47:Drivers/CMSIS/Include/cmsis_gcc.h **** #define __STATIC_INLINE static inline
|
|||
|
48:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
|
|||
|
49:Drivers/CMSIS/Include/cmsis_gcc.h **** #ifndef __STATIC_FORCEINLINE
|
|||
|
50:Drivers/CMSIS/Include/cmsis_gcc.h **** #define __STATIC_FORCEINLINE __attribute__((always_inline)) static inline
|
|||
|
51:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
|
|||
|
52:Drivers/CMSIS/Include/cmsis_gcc.h **** #ifndef __NO_RETURN
|
|||
|
53:Drivers/CMSIS/Include/cmsis_gcc.h **** #define __NO_RETURN __attribute__((__noreturn__))
|
|||
|
54:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
|
|||
|
55:Drivers/CMSIS/Include/cmsis_gcc.h **** #ifndef __USED
|
|||
|
56:Drivers/CMSIS/Include/cmsis_gcc.h **** #define __USED __attribute__((used))
|
|||
|
57:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
|
|||
|
58:Drivers/CMSIS/Include/cmsis_gcc.h **** #ifndef __WEAK
|
|||
|
59:Drivers/CMSIS/Include/cmsis_gcc.h **** #define __WEAK __attribute__((weak))
|
|||
|
60:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
|
|||
|
61:Drivers/CMSIS/Include/cmsis_gcc.h **** #ifndef __PACKED
|
|||
|
62:Drivers/CMSIS/Include/cmsis_gcc.h **** #define __PACKED __attribute__((packed, aligned(1)))
|
|||
|
63:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
|
|||
|
64:Drivers/CMSIS/Include/cmsis_gcc.h **** #ifndef __PACKED_STRUCT
|
|||
|
65:Drivers/CMSIS/Include/cmsis_gcc.h **** #define __PACKED_STRUCT struct __attribute__((packed, aligned(1)))
|
|||
|
66:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
|
|||
|
67:Drivers/CMSIS/Include/cmsis_gcc.h **** #ifndef __PACKED_UNION
|
|||
|
68:Drivers/CMSIS/Include/cmsis_gcc.h **** #define __PACKED_UNION union __attribute__((packed, aligned(1)))
|
|||
|
69:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
|
|||
|
70:Drivers/CMSIS/Include/cmsis_gcc.h **** #ifndef __UNALIGNED_UINT32 /* deprecated */
|
|||
|
71:Drivers/CMSIS/Include/cmsis_gcc.h **** #pragma GCC diagnostic push
|
|||
|
72:Drivers/CMSIS/Include/cmsis_gcc.h **** #pragma GCC diagnostic ignored "-Wpacked"
|
|||
|
73:Drivers/CMSIS/Include/cmsis_gcc.h **** #pragma GCC diagnostic ignored "-Wattributes"
|
|||
|
74:Drivers/CMSIS/Include/cmsis_gcc.h **** struct __attribute__((packed)) T_UINT32 { uint32_t v; };
|
|||
|
75:Drivers/CMSIS/Include/cmsis_gcc.h **** #pragma GCC diagnostic pop
|
|||
|
76:Drivers/CMSIS/Include/cmsis_gcc.h **** #define __UNALIGNED_UINT32(x) (((struct T_UINT32 *)(x))->v)
|
|||
|
77:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
|
|||
|
78:Drivers/CMSIS/Include/cmsis_gcc.h **** #ifndef __UNALIGNED_UINT16_WRITE
|
|||
|
79:Drivers/CMSIS/Include/cmsis_gcc.h **** #pragma GCC diagnostic push
|
|||
|
80:Drivers/CMSIS/Include/cmsis_gcc.h **** #pragma GCC diagnostic ignored "-Wpacked"
|
|||
|
81:Drivers/CMSIS/Include/cmsis_gcc.h **** #pragma GCC diagnostic ignored "-Wattributes"
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 36
|
|||
|
|
|||
|
|
|||
|
82:Drivers/CMSIS/Include/cmsis_gcc.h **** __PACKED_STRUCT T_UINT16_WRITE { uint16_t v; };
|
|||
|
83:Drivers/CMSIS/Include/cmsis_gcc.h **** #pragma GCC diagnostic pop
|
|||
|
84:Drivers/CMSIS/Include/cmsis_gcc.h **** #define __UNALIGNED_UINT16_WRITE(addr, val) (void)((((struct T_UINT16_WRITE *)(void *)(addr))-
|
|||
|
85:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
|
|||
|
86:Drivers/CMSIS/Include/cmsis_gcc.h **** #ifndef __UNALIGNED_UINT16_READ
|
|||
|
87:Drivers/CMSIS/Include/cmsis_gcc.h **** #pragma GCC diagnostic push
|
|||
|
88:Drivers/CMSIS/Include/cmsis_gcc.h **** #pragma GCC diagnostic ignored "-Wpacked"
|
|||
|
89:Drivers/CMSIS/Include/cmsis_gcc.h **** #pragma GCC diagnostic ignored "-Wattributes"
|
|||
|
90:Drivers/CMSIS/Include/cmsis_gcc.h **** __PACKED_STRUCT T_UINT16_READ { uint16_t v; };
|
|||
|
91:Drivers/CMSIS/Include/cmsis_gcc.h **** #pragma GCC diagnostic pop
|
|||
|
92:Drivers/CMSIS/Include/cmsis_gcc.h **** #define __UNALIGNED_UINT16_READ(addr) (((const struct T_UINT16_READ *)(const void *)(add
|
|||
|
93:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
|
|||
|
94:Drivers/CMSIS/Include/cmsis_gcc.h **** #ifndef __UNALIGNED_UINT32_WRITE
|
|||
|
95:Drivers/CMSIS/Include/cmsis_gcc.h **** #pragma GCC diagnostic push
|
|||
|
96:Drivers/CMSIS/Include/cmsis_gcc.h **** #pragma GCC diagnostic ignored "-Wpacked"
|
|||
|
97:Drivers/CMSIS/Include/cmsis_gcc.h **** #pragma GCC diagnostic ignored "-Wattributes"
|
|||
|
98:Drivers/CMSIS/Include/cmsis_gcc.h **** __PACKED_STRUCT T_UINT32_WRITE { uint32_t v; };
|
|||
|
99:Drivers/CMSIS/Include/cmsis_gcc.h **** #pragma GCC diagnostic pop
|
|||
|
100:Drivers/CMSIS/Include/cmsis_gcc.h **** #define __UNALIGNED_UINT32_WRITE(addr, val) (void)((((struct T_UINT32_WRITE *)(void *)(addr))-
|
|||
|
101:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
|
|||
|
102:Drivers/CMSIS/Include/cmsis_gcc.h **** #ifndef __UNALIGNED_UINT32_READ
|
|||
|
103:Drivers/CMSIS/Include/cmsis_gcc.h **** #pragma GCC diagnostic push
|
|||
|
104:Drivers/CMSIS/Include/cmsis_gcc.h **** #pragma GCC diagnostic ignored "-Wpacked"
|
|||
|
105:Drivers/CMSIS/Include/cmsis_gcc.h **** #pragma GCC diagnostic ignored "-Wattributes"
|
|||
|
106:Drivers/CMSIS/Include/cmsis_gcc.h **** __PACKED_STRUCT T_UINT32_READ { uint32_t v; };
|
|||
|
107:Drivers/CMSIS/Include/cmsis_gcc.h **** #pragma GCC diagnostic pop
|
|||
|
108:Drivers/CMSIS/Include/cmsis_gcc.h **** #define __UNALIGNED_UINT32_READ(addr) (((const struct T_UINT32_READ *)(const void *)(add
|
|||
|
109:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
|
|||
|
110:Drivers/CMSIS/Include/cmsis_gcc.h **** #ifndef __ALIGNED
|
|||
|
111:Drivers/CMSIS/Include/cmsis_gcc.h **** #define __ALIGNED(x) __attribute__((aligned(x)))
|
|||
|
112:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
|
|||
|
113:Drivers/CMSIS/Include/cmsis_gcc.h **** #ifndef __RESTRICT
|
|||
|
114:Drivers/CMSIS/Include/cmsis_gcc.h **** #define __RESTRICT __restrict
|
|||
|
115:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
|
|||
|
116:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
117:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
118:Drivers/CMSIS/Include/cmsis_gcc.h **** /* ########################### Core Function Access ########################### */
|
|||
|
119:Drivers/CMSIS/Include/cmsis_gcc.h **** /** \ingroup CMSIS_Core_FunctionInterface
|
|||
|
120:Drivers/CMSIS/Include/cmsis_gcc.h **** \defgroup CMSIS_Core_RegAccFunctions CMSIS Core Register Access Functions
|
|||
|
121:Drivers/CMSIS/Include/cmsis_gcc.h **** @{
|
|||
|
122:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
123:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
124:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
|
|||
|
125:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Enable IRQ Interrupts
|
|||
|
126:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Enables IRQ interrupts by clearing the I-bit in the CPSR.
|
|||
|
127:Drivers/CMSIS/Include/cmsis_gcc.h **** Can only be executed in Privileged modes.
|
|||
|
128:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
129:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE void __enable_irq(void)
|
|||
|
130:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
131:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("cpsie i" : : : "memory");
|
|||
|
132:Drivers/CMSIS/Include/cmsis_gcc.h **** }
|
|||
|
133:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
134:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
135:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
|
|||
|
136:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Disable IRQ Interrupts
|
|||
|
137:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Disables IRQ interrupts by setting the I-bit in the CPSR.
|
|||
|
138:Drivers/CMSIS/Include/cmsis_gcc.h **** Can only be executed in Privileged modes.
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 37
|
|||
|
|
|||
|
|
|||
|
139:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
140:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE void __disable_irq(void)
|
|||
|
141:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
142:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("cpsid i" : : : "memory");
|
|||
|
143:Drivers/CMSIS/Include/cmsis_gcc.h **** }
|
|||
|
144:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
145:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
146:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
|
|||
|
147:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Get Control Register
|
|||
|
148:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Returns the content of the Control Register.
|
|||
|
149:Drivers/CMSIS/Include/cmsis_gcc.h **** \return Control Register value
|
|||
|
150:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
151:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE uint32_t __get_CONTROL(void)
|
|||
|
152:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
153:Drivers/CMSIS/Include/cmsis_gcc.h **** uint32_t result;
|
|||
|
154:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
155:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("MRS %0, control" : "=r" (result) );
|
|||
|
156:Drivers/CMSIS/Include/cmsis_gcc.h **** return(result);
|
|||
|
157:Drivers/CMSIS/Include/cmsis_gcc.h **** }
|
|||
|
158:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
159:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
160:Drivers/CMSIS/Include/cmsis_gcc.h **** #if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3))
|
|||
|
161:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
|
|||
|
162:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Get Control Register (non-secure)
|
|||
|
163:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Returns the content of the non-secure Control Register when in secure mode.
|
|||
|
164:Drivers/CMSIS/Include/cmsis_gcc.h **** \return non-secure Control Register value
|
|||
|
165:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
166:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE uint32_t __TZ_get_CONTROL_NS(void)
|
|||
|
167:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
168:Drivers/CMSIS/Include/cmsis_gcc.h **** uint32_t result;
|
|||
|
169:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
170:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("MRS %0, control_ns" : "=r" (result) );
|
|||
|
171:Drivers/CMSIS/Include/cmsis_gcc.h **** return(result);
|
|||
|
172:Drivers/CMSIS/Include/cmsis_gcc.h **** }
|
|||
|
173:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
|
|||
|
174:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
175:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
176:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
|
|||
|
177:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Set Control Register
|
|||
|
178:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Writes the given value to the Control Register.
|
|||
|
179:Drivers/CMSIS/Include/cmsis_gcc.h **** \param [in] control Control Register value to set
|
|||
|
180:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
181:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE void __set_CONTROL(uint32_t control)
|
|||
|
182:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
183:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("MSR control, %0" : : "r" (control) : "memory");
|
|||
|
184:Drivers/CMSIS/Include/cmsis_gcc.h **** }
|
|||
|
185:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
186:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
187:Drivers/CMSIS/Include/cmsis_gcc.h **** #if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3))
|
|||
|
188:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
|
|||
|
189:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Set Control Register (non-secure)
|
|||
|
190:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Writes the given value to the non-secure Control Register when in secure state.
|
|||
|
191:Drivers/CMSIS/Include/cmsis_gcc.h **** \param [in] control Control Register value to set
|
|||
|
192:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
193:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE void __TZ_set_CONTROL_NS(uint32_t control)
|
|||
|
194:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
195:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("MSR control_ns, %0" : : "r" (control) : "memory");
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 38
|
|||
|
|
|||
|
|
|||
|
196:Drivers/CMSIS/Include/cmsis_gcc.h **** }
|
|||
|
197:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
|
|||
|
198:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
199:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
200:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
|
|||
|
201:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Get IPSR Register
|
|||
|
202:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Returns the content of the IPSR Register.
|
|||
|
203:Drivers/CMSIS/Include/cmsis_gcc.h **** \return IPSR Register value
|
|||
|
204:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
205:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE uint32_t __get_IPSR(void)
|
|||
|
206:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
207:Drivers/CMSIS/Include/cmsis_gcc.h **** uint32_t result;
|
|||
|
208:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
209:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("MRS %0, ipsr" : "=r" (result) );
|
|||
|
210:Drivers/CMSIS/Include/cmsis_gcc.h **** return(result);
|
|||
|
211:Drivers/CMSIS/Include/cmsis_gcc.h **** }
|
|||
|
212:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
213:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
214:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
|
|||
|
215:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Get APSR Register
|
|||
|
216:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Returns the content of the APSR Register.
|
|||
|
217:Drivers/CMSIS/Include/cmsis_gcc.h **** \return APSR Register value
|
|||
|
218:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
219:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE uint32_t __get_APSR(void)
|
|||
|
220:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
221:Drivers/CMSIS/Include/cmsis_gcc.h **** uint32_t result;
|
|||
|
222:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
223:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("MRS %0, apsr" : "=r" (result) );
|
|||
|
224:Drivers/CMSIS/Include/cmsis_gcc.h **** return(result);
|
|||
|
225:Drivers/CMSIS/Include/cmsis_gcc.h **** }
|
|||
|
226:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
227:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
228:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
|
|||
|
229:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Get xPSR Register
|
|||
|
230:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Returns the content of the xPSR Register.
|
|||
|
231:Drivers/CMSIS/Include/cmsis_gcc.h **** \return xPSR Register value
|
|||
|
232:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
233:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE uint32_t __get_xPSR(void)
|
|||
|
234:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
235:Drivers/CMSIS/Include/cmsis_gcc.h **** uint32_t result;
|
|||
|
236:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
237:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("MRS %0, xpsr" : "=r" (result) );
|
|||
|
238:Drivers/CMSIS/Include/cmsis_gcc.h **** return(result);
|
|||
|
239:Drivers/CMSIS/Include/cmsis_gcc.h **** }
|
|||
|
240:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
241:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
242:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
|
|||
|
243:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Get Process Stack Pointer
|
|||
|
244:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Returns the current value of the Process Stack Pointer (PSP).
|
|||
|
245:Drivers/CMSIS/Include/cmsis_gcc.h **** \return PSP Register value
|
|||
|
246:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
247:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE uint32_t __get_PSP(void)
|
|||
|
248:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
249:Drivers/CMSIS/Include/cmsis_gcc.h **** uint32_t result;
|
|||
|
250:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
251:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("MRS %0, psp" : "=r" (result) );
|
|||
|
252:Drivers/CMSIS/Include/cmsis_gcc.h **** return(result);
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 39
|
|||
|
|
|||
|
|
|||
|
253:Drivers/CMSIS/Include/cmsis_gcc.h **** }
|
|||
|
254:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
255:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
256:Drivers/CMSIS/Include/cmsis_gcc.h **** #if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3))
|
|||
|
257:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
|
|||
|
258:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Get Process Stack Pointer (non-secure)
|
|||
|
259:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Returns the current value of the non-secure Process Stack Pointer (PSP) when in secure s
|
|||
|
260:Drivers/CMSIS/Include/cmsis_gcc.h **** \return PSP Register value
|
|||
|
261:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
262:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE uint32_t __TZ_get_PSP_NS(void)
|
|||
|
263:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
264:Drivers/CMSIS/Include/cmsis_gcc.h **** uint32_t result;
|
|||
|
265:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
266:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("MRS %0, psp_ns" : "=r" (result) );
|
|||
|
267:Drivers/CMSIS/Include/cmsis_gcc.h **** return(result);
|
|||
|
268:Drivers/CMSIS/Include/cmsis_gcc.h **** }
|
|||
|
269:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
|
|||
|
270:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
271:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
272:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
|
|||
|
273:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Set Process Stack Pointer
|
|||
|
274:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Assigns the given value to the Process Stack Pointer (PSP).
|
|||
|
275:Drivers/CMSIS/Include/cmsis_gcc.h **** \param [in] topOfProcStack Process Stack Pointer value to set
|
|||
|
276:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
277:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE void __set_PSP(uint32_t topOfProcStack)
|
|||
|
278:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
279:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("MSR psp, %0" : : "r" (topOfProcStack) : );
|
|||
|
280:Drivers/CMSIS/Include/cmsis_gcc.h **** }
|
|||
|
281:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
282:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
283:Drivers/CMSIS/Include/cmsis_gcc.h **** #if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3))
|
|||
|
284:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
|
|||
|
285:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Set Process Stack Pointer (non-secure)
|
|||
|
286:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Assigns the given value to the non-secure Process Stack Pointer (PSP) when in secure sta
|
|||
|
287:Drivers/CMSIS/Include/cmsis_gcc.h **** \param [in] topOfProcStack Process Stack Pointer value to set
|
|||
|
288:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
289:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE void __TZ_set_PSP_NS(uint32_t topOfProcStack)
|
|||
|
290:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
291:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("MSR psp_ns, %0" : : "r" (topOfProcStack) : );
|
|||
|
292:Drivers/CMSIS/Include/cmsis_gcc.h **** }
|
|||
|
293:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
|
|||
|
294:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
295:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
296:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
|
|||
|
297:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Get Main Stack Pointer
|
|||
|
298:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Returns the current value of the Main Stack Pointer (MSP).
|
|||
|
299:Drivers/CMSIS/Include/cmsis_gcc.h **** \return MSP Register value
|
|||
|
300:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
301:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE uint32_t __get_MSP(void)
|
|||
|
302:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
303:Drivers/CMSIS/Include/cmsis_gcc.h **** uint32_t result;
|
|||
|
304:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
305:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("MRS %0, msp" : "=r" (result) );
|
|||
|
306:Drivers/CMSIS/Include/cmsis_gcc.h **** return(result);
|
|||
|
307:Drivers/CMSIS/Include/cmsis_gcc.h **** }
|
|||
|
308:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
309:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 40
|
|||
|
|
|||
|
|
|||
|
310:Drivers/CMSIS/Include/cmsis_gcc.h **** #if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3))
|
|||
|
311:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
|
|||
|
312:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Get Main Stack Pointer (non-secure)
|
|||
|
313:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Returns the current value of the non-secure Main Stack Pointer (MSP) when in secure stat
|
|||
|
314:Drivers/CMSIS/Include/cmsis_gcc.h **** \return MSP Register value
|
|||
|
315:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
316:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE uint32_t __TZ_get_MSP_NS(void)
|
|||
|
317:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
318:Drivers/CMSIS/Include/cmsis_gcc.h **** uint32_t result;
|
|||
|
319:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
320:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("MRS %0, msp_ns" : "=r" (result) );
|
|||
|
321:Drivers/CMSIS/Include/cmsis_gcc.h **** return(result);
|
|||
|
322:Drivers/CMSIS/Include/cmsis_gcc.h **** }
|
|||
|
323:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
|
|||
|
324:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
325:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
326:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
|
|||
|
327:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Set Main Stack Pointer
|
|||
|
328:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Assigns the given value to the Main Stack Pointer (MSP).
|
|||
|
329:Drivers/CMSIS/Include/cmsis_gcc.h **** \param [in] topOfMainStack Main Stack Pointer value to set
|
|||
|
330:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
331:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE void __set_MSP(uint32_t topOfMainStack)
|
|||
|
332:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
333:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("MSR msp, %0" : : "r" (topOfMainStack) : );
|
|||
|
334:Drivers/CMSIS/Include/cmsis_gcc.h **** }
|
|||
|
335:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
336:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
337:Drivers/CMSIS/Include/cmsis_gcc.h **** #if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3))
|
|||
|
338:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
|
|||
|
339:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Set Main Stack Pointer (non-secure)
|
|||
|
340:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Assigns the given value to the non-secure Main Stack Pointer (MSP) when in secure state.
|
|||
|
341:Drivers/CMSIS/Include/cmsis_gcc.h **** \param [in] topOfMainStack Main Stack Pointer value to set
|
|||
|
342:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
343:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE void __TZ_set_MSP_NS(uint32_t topOfMainStack)
|
|||
|
344:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
345:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("MSR msp_ns, %0" : : "r" (topOfMainStack) : );
|
|||
|
346:Drivers/CMSIS/Include/cmsis_gcc.h **** }
|
|||
|
347:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
|
|||
|
348:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
349:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
350:Drivers/CMSIS/Include/cmsis_gcc.h **** #if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3))
|
|||
|
351:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
|
|||
|
352:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Get Stack Pointer (non-secure)
|
|||
|
353:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Returns the current value of the non-secure Stack Pointer (SP) when in secure state.
|
|||
|
354:Drivers/CMSIS/Include/cmsis_gcc.h **** \return SP Register value
|
|||
|
355:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
356:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE uint32_t __TZ_get_SP_NS(void)
|
|||
|
357:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
358:Drivers/CMSIS/Include/cmsis_gcc.h **** uint32_t result;
|
|||
|
359:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
360:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("MRS %0, sp_ns" : "=r" (result) );
|
|||
|
361:Drivers/CMSIS/Include/cmsis_gcc.h **** return(result);
|
|||
|
362:Drivers/CMSIS/Include/cmsis_gcc.h **** }
|
|||
|
363:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
364:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
365:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
|
|||
|
366:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Set Stack Pointer (non-secure)
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 41
|
|||
|
|
|||
|
|
|||
|
367:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Assigns the given value to the non-secure Stack Pointer (SP) when in secure state.
|
|||
|
368:Drivers/CMSIS/Include/cmsis_gcc.h **** \param [in] topOfStack Stack Pointer value to set
|
|||
|
369:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
370:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE void __TZ_set_SP_NS(uint32_t topOfStack)
|
|||
|
371:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
372:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("MSR sp_ns, %0" : : "r" (topOfStack) : );
|
|||
|
373:Drivers/CMSIS/Include/cmsis_gcc.h **** }
|
|||
|
374:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
|
|||
|
375:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
376:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
377:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
|
|||
|
378:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Get Priority Mask
|
|||
|
379:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Returns the current state of the priority mask bit from the Priority Mask Register.
|
|||
|
380:Drivers/CMSIS/Include/cmsis_gcc.h **** \return Priority Mask value
|
|||
|
381:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
382:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE uint32_t __get_PRIMASK(void)
|
|||
|
383:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
384:Drivers/CMSIS/Include/cmsis_gcc.h **** uint32_t result;
|
|||
|
385:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
386:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("MRS %0, primask" : "=r" (result) :: "memory");
|
|||
|
387:Drivers/CMSIS/Include/cmsis_gcc.h **** return(result);
|
|||
|
388:Drivers/CMSIS/Include/cmsis_gcc.h **** }
|
|||
|
389:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
390:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
391:Drivers/CMSIS/Include/cmsis_gcc.h **** #if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3))
|
|||
|
392:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
|
|||
|
393:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Get Priority Mask (non-secure)
|
|||
|
394:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Returns the current state of the non-secure priority mask bit from the Priority Mask Reg
|
|||
|
395:Drivers/CMSIS/Include/cmsis_gcc.h **** \return Priority Mask value
|
|||
|
396:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
397:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE uint32_t __TZ_get_PRIMASK_NS(void)
|
|||
|
398:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
399:Drivers/CMSIS/Include/cmsis_gcc.h **** uint32_t result;
|
|||
|
400:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
401:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("MRS %0, primask_ns" : "=r" (result) :: "memory");
|
|||
|
402:Drivers/CMSIS/Include/cmsis_gcc.h **** return(result);
|
|||
|
403:Drivers/CMSIS/Include/cmsis_gcc.h **** }
|
|||
|
404:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
|
|||
|
405:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
406:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
407:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
|
|||
|
408:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Set Priority Mask
|
|||
|
409:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Assigns the given value to the Priority Mask Register.
|
|||
|
410:Drivers/CMSIS/Include/cmsis_gcc.h **** \param [in] priMask Priority Mask
|
|||
|
411:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
412:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE void __set_PRIMASK(uint32_t priMask)
|
|||
|
413:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
414:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("MSR primask, %0" : : "r" (priMask) : "memory");
|
|||
|
415:Drivers/CMSIS/Include/cmsis_gcc.h **** }
|
|||
|
416:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
417:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
418:Drivers/CMSIS/Include/cmsis_gcc.h **** #if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3))
|
|||
|
419:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
|
|||
|
420:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Set Priority Mask (non-secure)
|
|||
|
421:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Assigns the given value to the non-secure Priority Mask Register when in secure state.
|
|||
|
422:Drivers/CMSIS/Include/cmsis_gcc.h **** \param [in] priMask Priority Mask
|
|||
|
423:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 42
|
|||
|
|
|||
|
|
|||
|
424:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE void __TZ_set_PRIMASK_NS(uint32_t priMask)
|
|||
|
425:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
426:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("MSR primask_ns, %0" : : "r" (priMask) : "memory");
|
|||
|
427:Drivers/CMSIS/Include/cmsis_gcc.h **** }
|
|||
|
428:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
|
|||
|
429:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
430:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
431:Drivers/CMSIS/Include/cmsis_gcc.h **** #if ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \
|
|||
|
432:Drivers/CMSIS/Include/cmsis_gcc.h **** (defined (__ARM_ARCH_7EM__ ) && (__ARM_ARCH_7EM__ == 1)) || \
|
|||
|
433:Drivers/CMSIS/Include/cmsis_gcc.h **** (defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) )
|
|||
|
434:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
|
|||
|
435:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Enable FIQ
|
|||
|
436:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Enables FIQ interrupts by clearing the F-bit in the CPSR.
|
|||
|
437:Drivers/CMSIS/Include/cmsis_gcc.h **** Can only be executed in Privileged modes.
|
|||
|
438:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
439:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE void __enable_fault_irq(void)
|
|||
|
440:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
441:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("cpsie f" : : : "memory");
|
|||
|
442:Drivers/CMSIS/Include/cmsis_gcc.h **** }
|
|||
|
443:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
444:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
445:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
|
|||
|
446:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Disable FIQ
|
|||
|
447:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Disables FIQ interrupts by setting the F-bit in the CPSR.
|
|||
|
448:Drivers/CMSIS/Include/cmsis_gcc.h **** Can only be executed in Privileged modes.
|
|||
|
449:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
450:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE void __disable_fault_irq(void)
|
|||
|
451:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
452:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("cpsid f" : : : "memory");
|
|||
|
453:Drivers/CMSIS/Include/cmsis_gcc.h **** }
|
|||
|
454:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
455:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
456:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
|
|||
|
457:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Get Base Priority
|
|||
|
458:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Returns the current value of the Base Priority register.
|
|||
|
459:Drivers/CMSIS/Include/cmsis_gcc.h **** \return Base Priority register value
|
|||
|
460:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
461:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE uint32_t __get_BASEPRI(void)
|
|||
|
462:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
463:Drivers/CMSIS/Include/cmsis_gcc.h **** uint32_t result;
|
|||
|
464:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
465:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("MRS %0, basepri" : "=r" (result) );
|
|||
|
466:Drivers/CMSIS/Include/cmsis_gcc.h **** return(result);
|
|||
|
467:Drivers/CMSIS/Include/cmsis_gcc.h **** }
|
|||
|
468:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
469:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
470:Drivers/CMSIS/Include/cmsis_gcc.h **** #if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3))
|
|||
|
471:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
|
|||
|
472:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Get Base Priority (non-secure)
|
|||
|
473:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Returns the current value of the non-secure Base Priority register when in secure state.
|
|||
|
474:Drivers/CMSIS/Include/cmsis_gcc.h **** \return Base Priority register value
|
|||
|
475:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
476:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE uint32_t __TZ_get_BASEPRI_NS(void)
|
|||
|
477:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
478:Drivers/CMSIS/Include/cmsis_gcc.h **** uint32_t result;
|
|||
|
479:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
480:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("MRS %0, basepri_ns" : "=r" (result) );
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 43
|
|||
|
|
|||
|
|
|||
|
481:Drivers/CMSIS/Include/cmsis_gcc.h **** return(result);
|
|||
|
482:Drivers/CMSIS/Include/cmsis_gcc.h **** }
|
|||
|
483:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
|
|||
|
484:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
485:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
486:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
|
|||
|
487:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Set Base Priority
|
|||
|
488:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Assigns the given value to the Base Priority register.
|
|||
|
489:Drivers/CMSIS/Include/cmsis_gcc.h **** \param [in] basePri Base Priority value to set
|
|||
|
490:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
491:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE void __set_BASEPRI(uint32_t basePri)
|
|||
|
492:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
493:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("MSR basepri, %0" : : "r" (basePri) : "memory");
|
|||
|
494:Drivers/CMSIS/Include/cmsis_gcc.h **** }
|
|||
|
495:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
496:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
497:Drivers/CMSIS/Include/cmsis_gcc.h **** #if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3))
|
|||
|
498:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
|
|||
|
499:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Set Base Priority (non-secure)
|
|||
|
500:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Assigns the given value to the non-secure Base Priority register when in secure state.
|
|||
|
501:Drivers/CMSIS/Include/cmsis_gcc.h **** \param [in] basePri Base Priority value to set
|
|||
|
502:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
503:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE void __TZ_set_BASEPRI_NS(uint32_t basePri)
|
|||
|
504:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
505:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("MSR basepri_ns, %0" : : "r" (basePri) : "memory");
|
|||
|
506:Drivers/CMSIS/Include/cmsis_gcc.h **** }
|
|||
|
507:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
|
|||
|
508:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
509:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
510:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
|
|||
|
511:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Set Base Priority with condition
|
|||
|
512:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Assigns the given value to the Base Priority register only if BASEPRI masking is disable
|
|||
|
513:Drivers/CMSIS/Include/cmsis_gcc.h **** or the new value increases the BASEPRI priority level.
|
|||
|
514:Drivers/CMSIS/Include/cmsis_gcc.h **** \param [in] basePri Base Priority value to set
|
|||
|
515:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
516:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE void __set_BASEPRI_MAX(uint32_t basePri)
|
|||
|
517:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
518:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("MSR basepri_max, %0" : : "r" (basePri) : "memory");
|
|||
|
519:Drivers/CMSIS/Include/cmsis_gcc.h **** }
|
|||
|
520:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
521:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
522:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
|
|||
|
523:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Get Fault Mask
|
|||
|
524:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Returns the current value of the Fault Mask register.
|
|||
|
525:Drivers/CMSIS/Include/cmsis_gcc.h **** \return Fault Mask register value
|
|||
|
526:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
527:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE uint32_t __get_FAULTMASK(void)
|
|||
|
528:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
529:Drivers/CMSIS/Include/cmsis_gcc.h **** uint32_t result;
|
|||
|
530:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
531:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("MRS %0, faultmask" : "=r" (result) );
|
|||
|
532:Drivers/CMSIS/Include/cmsis_gcc.h **** return(result);
|
|||
|
533:Drivers/CMSIS/Include/cmsis_gcc.h **** }
|
|||
|
534:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
535:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
536:Drivers/CMSIS/Include/cmsis_gcc.h **** #if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3))
|
|||
|
537:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 44
|
|||
|
|
|||
|
|
|||
|
538:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Get Fault Mask (non-secure)
|
|||
|
539:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Returns the current value of the non-secure Fault Mask register when in secure state.
|
|||
|
540:Drivers/CMSIS/Include/cmsis_gcc.h **** \return Fault Mask register value
|
|||
|
541:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
542:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE uint32_t __TZ_get_FAULTMASK_NS(void)
|
|||
|
543:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
544:Drivers/CMSIS/Include/cmsis_gcc.h **** uint32_t result;
|
|||
|
545:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
546:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("MRS %0, faultmask_ns" : "=r" (result) );
|
|||
|
547:Drivers/CMSIS/Include/cmsis_gcc.h **** return(result);
|
|||
|
548:Drivers/CMSIS/Include/cmsis_gcc.h **** }
|
|||
|
549:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
|
|||
|
550:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
551:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
552:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
|
|||
|
553:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Set Fault Mask
|
|||
|
554:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Assigns the given value to the Fault Mask register.
|
|||
|
555:Drivers/CMSIS/Include/cmsis_gcc.h **** \param [in] faultMask Fault Mask value to set
|
|||
|
556:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
557:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE void __set_FAULTMASK(uint32_t faultMask)
|
|||
|
558:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
559:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("MSR faultmask, %0" : : "r" (faultMask) : "memory");
|
|||
|
560:Drivers/CMSIS/Include/cmsis_gcc.h **** }
|
|||
|
561:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
562:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
563:Drivers/CMSIS/Include/cmsis_gcc.h **** #if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3))
|
|||
|
564:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
|
|||
|
565:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Set Fault Mask (non-secure)
|
|||
|
566:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Assigns the given value to the non-secure Fault Mask register when in secure state.
|
|||
|
567:Drivers/CMSIS/Include/cmsis_gcc.h **** \param [in] faultMask Fault Mask value to set
|
|||
|
568:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
569:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE void __TZ_set_FAULTMASK_NS(uint32_t faultMask)
|
|||
|
570:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
571:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("MSR faultmask_ns, %0" : : "r" (faultMask) : "memory");
|
|||
|
572:Drivers/CMSIS/Include/cmsis_gcc.h **** }
|
|||
|
573:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
|
|||
|
574:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
575:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif /* ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \
|
|||
|
576:Drivers/CMSIS/Include/cmsis_gcc.h **** (defined (__ARM_ARCH_7EM__ ) && (__ARM_ARCH_7EM__ == 1)) || \
|
|||
|
577:Drivers/CMSIS/Include/cmsis_gcc.h **** (defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) ) */
|
|||
|
578:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
579:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
580:Drivers/CMSIS/Include/cmsis_gcc.h **** #if ((defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) || \
|
|||
|
581:Drivers/CMSIS/Include/cmsis_gcc.h **** (defined (__ARM_ARCH_8M_BASE__ ) && (__ARM_ARCH_8M_BASE__ == 1)) )
|
|||
|
582:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
583:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
|
|||
|
584:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Get Process Stack Pointer Limit
|
|||
|
585:Drivers/CMSIS/Include/cmsis_gcc.h **** Devices without ARMv8-M Main Extensions (i.e. Cortex-M23) lack the non-secure
|
|||
|
586:Drivers/CMSIS/Include/cmsis_gcc.h **** Stack Pointer Limit register hence zero is returned always in non-secure
|
|||
|
587:Drivers/CMSIS/Include/cmsis_gcc.h **** mode.
|
|||
|
588:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
589:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Returns the current value of the Process Stack Pointer Limit (PSPLIM).
|
|||
|
590:Drivers/CMSIS/Include/cmsis_gcc.h **** \return PSPLIM Register value
|
|||
|
591:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
592:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE uint32_t __get_PSPLIM(void)
|
|||
|
593:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
594:Drivers/CMSIS/Include/cmsis_gcc.h **** #if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 45
|
|||
|
|
|||
|
|
|||
|
595:Drivers/CMSIS/Include/cmsis_gcc.h **** (!defined (__ARM_FEATURE_CMSE) || (__ARM_FEATURE_CMSE < 3)))
|
|||
|
596:Drivers/CMSIS/Include/cmsis_gcc.h **** // without main extensions, the non-secure PSPLIM is RAZ/WI
|
|||
|
597:Drivers/CMSIS/Include/cmsis_gcc.h **** return 0U;
|
|||
|
598:Drivers/CMSIS/Include/cmsis_gcc.h **** #else
|
|||
|
599:Drivers/CMSIS/Include/cmsis_gcc.h **** uint32_t result;
|
|||
|
600:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("MRS %0, psplim" : "=r" (result) );
|
|||
|
601:Drivers/CMSIS/Include/cmsis_gcc.h **** return result;
|
|||
|
602:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
|
|||
|
603:Drivers/CMSIS/Include/cmsis_gcc.h **** }
|
|||
|
604:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
605:Drivers/CMSIS/Include/cmsis_gcc.h **** #if (defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3))
|
|||
|
606:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
|
|||
|
607:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Get Process Stack Pointer Limit (non-secure)
|
|||
|
608:Drivers/CMSIS/Include/cmsis_gcc.h **** Devices without ARMv8-M Main Extensions (i.e. Cortex-M23) lack the non-secure
|
|||
|
609:Drivers/CMSIS/Include/cmsis_gcc.h **** Stack Pointer Limit register hence zero is returned always.
|
|||
|
610:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
611:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Returns the current value of the non-secure Process Stack Pointer Limit (PSPLIM) when in
|
|||
|
612:Drivers/CMSIS/Include/cmsis_gcc.h **** \return PSPLIM Register value
|
|||
|
613:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
614:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE uint32_t __TZ_get_PSPLIM_NS(void)
|
|||
|
615:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
616:Drivers/CMSIS/Include/cmsis_gcc.h **** #if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)))
|
|||
|
617:Drivers/CMSIS/Include/cmsis_gcc.h **** // without main extensions, the non-secure PSPLIM is RAZ/WI
|
|||
|
618:Drivers/CMSIS/Include/cmsis_gcc.h **** return 0U;
|
|||
|
619:Drivers/CMSIS/Include/cmsis_gcc.h **** #else
|
|||
|
620:Drivers/CMSIS/Include/cmsis_gcc.h **** uint32_t result;
|
|||
|
621:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("MRS %0, psplim_ns" : "=r" (result) );
|
|||
|
622:Drivers/CMSIS/Include/cmsis_gcc.h **** return result;
|
|||
|
623:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
|
|||
|
624:Drivers/CMSIS/Include/cmsis_gcc.h **** }
|
|||
|
625:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
|
|||
|
626:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
627:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
628:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
|
|||
|
629:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Set Process Stack Pointer Limit
|
|||
|
630:Drivers/CMSIS/Include/cmsis_gcc.h **** Devices without ARMv8-M Main Extensions (i.e. Cortex-M23) lack the non-secure
|
|||
|
631:Drivers/CMSIS/Include/cmsis_gcc.h **** Stack Pointer Limit register hence the write is silently ignored in non-secure
|
|||
|
632:Drivers/CMSIS/Include/cmsis_gcc.h **** mode.
|
|||
|
633:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
634:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Assigns the given value to the Process Stack Pointer Limit (PSPLIM).
|
|||
|
635:Drivers/CMSIS/Include/cmsis_gcc.h **** \param [in] ProcStackPtrLimit Process Stack Pointer Limit value to set
|
|||
|
636:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
637:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE void __set_PSPLIM(uint32_t ProcStackPtrLimit)
|
|||
|
638:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
639:Drivers/CMSIS/Include/cmsis_gcc.h **** #if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \
|
|||
|
640:Drivers/CMSIS/Include/cmsis_gcc.h **** (!defined (__ARM_FEATURE_CMSE) || (__ARM_FEATURE_CMSE < 3)))
|
|||
|
641:Drivers/CMSIS/Include/cmsis_gcc.h **** // without main extensions, the non-secure PSPLIM is RAZ/WI
|
|||
|
642:Drivers/CMSIS/Include/cmsis_gcc.h **** (void)ProcStackPtrLimit;
|
|||
|
643:Drivers/CMSIS/Include/cmsis_gcc.h **** #else
|
|||
|
644:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("MSR psplim, %0" : : "r" (ProcStackPtrLimit));
|
|||
|
645:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
|
|||
|
646:Drivers/CMSIS/Include/cmsis_gcc.h **** }
|
|||
|
647:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
648:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
649:Drivers/CMSIS/Include/cmsis_gcc.h **** #if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3))
|
|||
|
650:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
|
|||
|
651:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Set Process Stack Pointer (non-secure)
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 46
|
|||
|
|
|||
|
|
|||
|
652:Drivers/CMSIS/Include/cmsis_gcc.h **** Devices without ARMv8-M Main Extensions (i.e. Cortex-M23) lack the non-secure
|
|||
|
653:Drivers/CMSIS/Include/cmsis_gcc.h **** Stack Pointer Limit register hence the write is silently ignored.
|
|||
|
654:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
655:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Assigns the given value to the non-secure Process Stack Pointer Limit (PSPLIM) when in s
|
|||
|
656:Drivers/CMSIS/Include/cmsis_gcc.h **** \param [in] ProcStackPtrLimit Process Stack Pointer Limit value to set
|
|||
|
657:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
658:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE void __TZ_set_PSPLIM_NS(uint32_t ProcStackPtrLimit)
|
|||
|
659:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
660:Drivers/CMSIS/Include/cmsis_gcc.h **** #if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)))
|
|||
|
661:Drivers/CMSIS/Include/cmsis_gcc.h **** // without main extensions, the non-secure PSPLIM is RAZ/WI
|
|||
|
662:Drivers/CMSIS/Include/cmsis_gcc.h **** (void)ProcStackPtrLimit;
|
|||
|
663:Drivers/CMSIS/Include/cmsis_gcc.h **** #else
|
|||
|
664:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("MSR psplim_ns, %0\n" : : "r" (ProcStackPtrLimit));
|
|||
|
665:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
|
|||
|
666:Drivers/CMSIS/Include/cmsis_gcc.h **** }
|
|||
|
667:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
|
|||
|
668:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
669:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
670:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
|
|||
|
671:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Get Main Stack Pointer Limit
|
|||
|
672:Drivers/CMSIS/Include/cmsis_gcc.h **** Devices without ARMv8-M Main Extensions (i.e. Cortex-M23) lack the non-secure
|
|||
|
673:Drivers/CMSIS/Include/cmsis_gcc.h **** Stack Pointer Limit register hence zero is returned always in non-secure
|
|||
|
674:Drivers/CMSIS/Include/cmsis_gcc.h **** mode.
|
|||
|
675:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
676:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Returns the current value of the Main Stack Pointer Limit (MSPLIM).
|
|||
|
677:Drivers/CMSIS/Include/cmsis_gcc.h **** \return MSPLIM Register value
|
|||
|
678:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
679:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE uint32_t __get_MSPLIM(void)
|
|||
|
680:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
681:Drivers/CMSIS/Include/cmsis_gcc.h **** #if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \
|
|||
|
682:Drivers/CMSIS/Include/cmsis_gcc.h **** (!defined (__ARM_FEATURE_CMSE) || (__ARM_FEATURE_CMSE < 3)))
|
|||
|
683:Drivers/CMSIS/Include/cmsis_gcc.h **** // without main extensions, the non-secure MSPLIM is RAZ/WI
|
|||
|
684:Drivers/CMSIS/Include/cmsis_gcc.h **** return 0U;
|
|||
|
685:Drivers/CMSIS/Include/cmsis_gcc.h **** #else
|
|||
|
686:Drivers/CMSIS/Include/cmsis_gcc.h **** uint32_t result;
|
|||
|
687:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("MRS %0, msplim" : "=r" (result) );
|
|||
|
688:Drivers/CMSIS/Include/cmsis_gcc.h **** return result;
|
|||
|
689:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
|
|||
|
690:Drivers/CMSIS/Include/cmsis_gcc.h **** }
|
|||
|
691:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
692:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
693:Drivers/CMSIS/Include/cmsis_gcc.h **** #if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3))
|
|||
|
694:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
|
|||
|
695:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Get Main Stack Pointer Limit (non-secure)
|
|||
|
696:Drivers/CMSIS/Include/cmsis_gcc.h **** Devices without ARMv8-M Main Extensions (i.e. Cortex-M23) lack the non-secure
|
|||
|
697:Drivers/CMSIS/Include/cmsis_gcc.h **** Stack Pointer Limit register hence zero is returned always.
|
|||
|
698:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
699:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Returns the current value of the non-secure Main Stack Pointer Limit(MSPLIM) when in sec
|
|||
|
700:Drivers/CMSIS/Include/cmsis_gcc.h **** \return MSPLIM Register value
|
|||
|
701:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
702:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE uint32_t __TZ_get_MSPLIM_NS(void)
|
|||
|
703:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
704:Drivers/CMSIS/Include/cmsis_gcc.h **** #if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)))
|
|||
|
705:Drivers/CMSIS/Include/cmsis_gcc.h **** // without main extensions, the non-secure MSPLIM is RAZ/WI
|
|||
|
706:Drivers/CMSIS/Include/cmsis_gcc.h **** return 0U;
|
|||
|
707:Drivers/CMSIS/Include/cmsis_gcc.h **** #else
|
|||
|
708:Drivers/CMSIS/Include/cmsis_gcc.h **** uint32_t result;
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 47
|
|||
|
|
|||
|
|
|||
|
709:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("MRS %0, msplim_ns" : "=r" (result) );
|
|||
|
710:Drivers/CMSIS/Include/cmsis_gcc.h **** return result;
|
|||
|
711:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
|
|||
|
712:Drivers/CMSIS/Include/cmsis_gcc.h **** }
|
|||
|
713:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
|
|||
|
714:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
715:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
716:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
|
|||
|
717:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Set Main Stack Pointer Limit
|
|||
|
718:Drivers/CMSIS/Include/cmsis_gcc.h **** Devices without ARMv8-M Main Extensions (i.e. Cortex-M23) lack the non-secure
|
|||
|
719:Drivers/CMSIS/Include/cmsis_gcc.h **** Stack Pointer Limit register hence the write is silently ignored in non-secure
|
|||
|
720:Drivers/CMSIS/Include/cmsis_gcc.h **** mode.
|
|||
|
721:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
722:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Assigns the given value to the Main Stack Pointer Limit (MSPLIM).
|
|||
|
723:Drivers/CMSIS/Include/cmsis_gcc.h **** \param [in] MainStackPtrLimit Main Stack Pointer Limit value to set
|
|||
|
724:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
725:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE void __set_MSPLIM(uint32_t MainStackPtrLimit)
|
|||
|
726:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
727:Drivers/CMSIS/Include/cmsis_gcc.h **** #if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \
|
|||
|
728:Drivers/CMSIS/Include/cmsis_gcc.h **** (!defined (__ARM_FEATURE_CMSE) || (__ARM_FEATURE_CMSE < 3)))
|
|||
|
729:Drivers/CMSIS/Include/cmsis_gcc.h **** // without main extensions, the non-secure MSPLIM is RAZ/WI
|
|||
|
730:Drivers/CMSIS/Include/cmsis_gcc.h **** (void)MainStackPtrLimit;
|
|||
|
731:Drivers/CMSIS/Include/cmsis_gcc.h **** #else
|
|||
|
732:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("MSR msplim, %0" : : "r" (MainStackPtrLimit));
|
|||
|
733:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
|
|||
|
734:Drivers/CMSIS/Include/cmsis_gcc.h **** }
|
|||
|
735:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
736:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
737:Drivers/CMSIS/Include/cmsis_gcc.h **** #if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3))
|
|||
|
738:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
|
|||
|
739:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Set Main Stack Pointer Limit (non-secure)
|
|||
|
740:Drivers/CMSIS/Include/cmsis_gcc.h **** Devices without ARMv8-M Main Extensions (i.e. Cortex-M23) lack the non-secure
|
|||
|
741:Drivers/CMSIS/Include/cmsis_gcc.h **** Stack Pointer Limit register hence the write is silently ignored.
|
|||
|
742:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
743:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Assigns the given value to the non-secure Main Stack Pointer Limit (MSPLIM) when in secu
|
|||
|
744:Drivers/CMSIS/Include/cmsis_gcc.h **** \param [in] MainStackPtrLimit Main Stack Pointer value to set
|
|||
|
745:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
746:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE void __TZ_set_MSPLIM_NS(uint32_t MainStackPtrLimit)
|
|||
|
747:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
748:Drivers/CMSIS/Include/cmsis_gcc.h **** #if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)))
|
|||
|
749:Drivers/CMSIS/Include/cmsis_gcc.h **** // without main extensions, the non-secure MSPLIM is RAZ/WI
|
|||
|
750:Drivers/CMSIS/Include/cmsis_gcc.h **** (void)MainStackPtrLimit;
|
|||
|
751:Drivers/CMSIS/Include/cmsis_gcc.h **** #else
|
|||
|
752:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("MSR msplim_ns, %0" : : "r" (MainStackPtrLimit));
|
|||
|
753:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
|
|||
|
754:Drivers/CMSIS/Include/cmsis_gcc.h **** }
|
|||
|
755:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
|
|||
|
756:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
757:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif /* ((defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) || \
|
|||
|
758:Drivers/CMSIS/Include/cmsis_gcc.h **** (defined (__ARM_ARCH_8M_BASE__ ) && (__ARM_ARCH_8M_BASE__ == 1)) ) */
|
|||
|
759:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
760:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
761:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
|
|||
|
762:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Get FPSCR
|
|||
|
763:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Returns the current value of the Floating Point Status/Control register.
|
|||
|
764:Drivers/CMSIS/Include/cmsis_gcc.h **** \return Floating Point Status/Control register value
|
|||
|
765:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 48
|
|||
|
|
|||
|
|
|||
|
766:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE uint32_t __get_FPSCR(void)
|
|||
|
767:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
768:Drivers/CMSIS/Include/cmsis_gcc.h **** #if ((defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U)) && \
|
|||
|
769:Drivers/CMSIS/Include/cmsis_gcc.h **** (defined (__FPU_USED ) && (__FPU_USED == 1U)) )
|
|||
|
770:Drivers/CMSIS/Include/cmsis_gcc.h **** #if __has_builtin(__builtin_arm_get_fpscr)
|
|||
|
771:Drivers/CMSIS/Include/cmsis_gcc.h **** // Re-enable using built-in when GCC has been fixed
|
|||
|
772:Drivers/CMSIS/Include/cmsis_gcc.h **** // || (__GNUC__ > 7) || (__GNUC__ == 7 && __GNUC_MINOR__ >= 2)
|
|||
|
773:Drivers/CMSIS/Include/cmsis_gcc.h **** /* see https://gcc.gnu.org/ml/gcc-patches/2017-04/msg00443.html */
|
|||
|
774:Drivers/CMSIS/Include/cmsis_gcc.h **** return __builtin_arm_get_fpscr();
|
|||
|
775:Drivers/CMSIS/Include/cmsis_gcc.h **** #else
|
|||
|
776:Drivers/CMSIS/Include/cmsis_gcc.h **** uint32_t result;
|
|||
|
777:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
778:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("VMRS %0, fpscr" : "=r" (result) );
|
|||
|
779:Drivers/CMSIS/Include/cmsis_gcc.h **** return(result);
|
|||
|
780:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
|
|||
|
781:Drivers/CMSIS/Include/cmsis_gcc.h **** #else
|
|||
|
782:Drivers/CMSIS/Include/cmsis_gcc.h **** return(0U);
|
|||
|
783:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
|
|||
|
784:Drivers/CMSIS/Include/cmsis_gcc.h **** }
|
|||
|
785:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
786:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
787:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
|
|||
|
788:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Set FPSCR
|
|||
|
789:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Assigns the given value to the Floating Point Status/Control register.
|
|||
|
790:Drivers/CMSIS/Include/cmsis_gcc.h **** \param [in] fpscr Floating Point Status/Control value to set
|
|||
|
791:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
792:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE void __set_FPSCR(uint32_t fpscr)
|
|||
|
793:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
794:Drivers/CMSIS/Include/cmsis_gcc.h **** #if ((defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U)) && \
|
|||
|
795:Drivers/CMSIS/Include/cmsis_gcc.h **** (defined (__FPU_USED ) && (__FPU_USED == 1U)) )
|
|||
|
796:Drivers/CMSIS/Include/cmsis_gcc.h **** #if __has_builtin(__builtin_arm_set_fpscr)
|
|||
|
797:Drivers/CMSIS/Include/cmsis_gcc.h **** // Re-enable using built-in when GCC has been fixed
|
|||
|
798:Drivers/CMSIS/Include/cmsis_gcc.h **** // || (__GNUC__ > 7) || (__GNUC__ == 7 && __GNUC_MINOR__ >= 2)
|
|||
|
799:Drivers/CMSIS/Include/cmsis_gcc.h **** /* see https://gcc.gnu.org/ml/gcc-patches/2017-04/msg00443.html */
|
|||
|
800:Drivers/CMSIS/Include/cmsis_gcc.h **** __builtin_arm_set_fpscr(fpscr);
|
|||
|
801:Drivers/CMSIS/Include/cmsis_gcc.h **** #else
|
|||
|
802:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("VMSR fpscr, %0" : : "r" (fpscr) : "vfpcc", "memory");
|
|||
|
803:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
|
|||
|
804:Drivers/CMSIS/Include/cmsis_gcc.h **** #else
|
|||
|
805:Drivers/CMSIS/Include/cmsis_gcc.h **** (void)fpscr;
|
|||
|
806:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
|
|||
|
807:Drivers/CMSIS/Include/cmsis_gcc.h **** }
|
|||
|
808:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
809:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
810:Drivers/CMSIS/Include/cmsis_gcc.h **** /*@} end of CMSIS_Core_RegAccFunctions */
|
|||
|
811:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
812:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
813:Drivers/CMSIS/Include/cmsis_gcc.h **** /* ########################## Core Instruction Access ######################### */
|
|||
|
814:Drivers/CMSIS/Include/cmsis_gcc.h **** /** \defgroup CMSIS_Core_InstructionInterface CMSIS Core Instruction Interface
|
|||
|
815:Drivers/CMSIS/Include/cmsis_gcc.h **** Access to dedicated instructions
|
|||
|
816:Drivers/CMSIS/Include/cmsis_gcc.h **** @{
|
|||
|
817:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
818:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
819:Drivers/CMSIS/Include/cmsis_gcc.h **** /* Define macros for porting to both thumb1 and thumb2.
|
|||
|
820:Drivers/CMSIS/Include/cmsis_gcc.h **** * For thumb1, use low register (r0-r7), specified by constraint "l"
|
|||
|
821:Drivers/CMSIS/Include/cmsis_gcc.h **** * Otherwise, use general registers, specified by constraint "r" */
|
|||
|
822:Drivers/CMSIS/Include/cmsis_gcc.h **** #if defined (__thumb__) && !defined (__thumb2__)
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 49
|
|||
|
|
|||
|
|
|||
|
823:Drivers/CMSIS/Include/cmsis_gcc.h **** #define __CMSIS_GCC_OUT_REG(r) "=l" (r)
|
|||
|
824:Drivers/CMSIS/Include/cmsis_gcc.h **** #define __CMSIS_GCC_RW_REG(r) "+l" (r)
|
|||
|
825:Drivers/CMSIS/Include/cmsis_gcc.h **** #define __CMSIS_GCC_USE_REG(r) "l" (r)
|
|||
|
826:Drivers/CMSIS/Include/cmsis_gcc.h **** #else
|
|||
|
827:Drivers/CMSIS/Include/cmsis_gcc.h **** #define __CMSIS_GCC_OUT_REG(r) "=r" (r)
|
|||
|
828:Drivers/CMSIS/Include/cmsis_gcc.h **** #define __CMSIS_GCC_RW_REG(r) "+r" (r)
|
|||
|
829:Drivers/CMSIS/Include/cmsis_gcc.h **** #define __CMSIS_GCC_USE_REG(r) "r" (r)
|
|||
|
830:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
|
|||
|
831:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
832:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
|
|||
|
833:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief No Operation
|
|||
|
834:Drivers/CMSIS/Include/cmsis_gcc.h **** \details No Operation does nothing. This instruction can be used for code alignment purposes.
|
|||
|
835:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
836:Drivers/CMSIS/Include/cmsis_gcc.h **** #define __NOP() __ASM volatile ("nop")
|
|||
|
837:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
838:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
|
|||
|
839:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Wait For Interrupt
|
|||
|
840:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Wait For Interrupt is a hint instruction that suspends execution until one of a number o
|
|||
|
841:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
842:Drivers/CMSIS/Include/cmsis_gcc.h **** #define __WFI() __ASM volatile ("wfi")
|
|||
|
843:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
844:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
845:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
|
|||
|
846:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Wait For Event
|
|||
|
847:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Wait For Event is a hint instruction that permits the processor to enter
|
|||
|
848:Drivers/CMSIS/Include/cmsis_gcc.h **** a low-power state until one of a number of events occurs.
|
|||
|
849:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
850:Drivers/CMSIS/Include/cmsis_gcc.h **** #define __WFE() __ASM volatile ("wfe")
|
|||
|
851:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
852:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
853:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
|
|||
|
854:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Send Event
|
|||
|
855:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Send Event is a hint instruction. It causes an event to be signaled to the CPU.
|
|||
|
856:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
857:Drivers/CMSIS/Include/cmsis_gcc.h **** #define __SEV() __ASM volatile ("sev")
|
|||
|
858:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
859:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
860:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
|
|||
|
861:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Instruction Synchronization Barrier
|
|||
|
862:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Instruction Synchronization Barrier flushes the pipeline in the processor,
|
|||
|
863:Drivers/CMSIS/Include/cmsis_gcc.h **** so that all instructions following the ISB are fetched from cache or memory,
|
|||
|
864:Drivers/CMSIS/Include/cmsis_gcc.h **** after the instruction has been completed.
|
|||
|
865:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
866:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE void __ISB(void)
|
|||
|
752 .loc 2 866 27 view .LVU202
|
|||
|
753 .LBB19:
|
|||
|
867:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
868:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("isb 0xF":::"memory");
|
|||
|
754 .loc 2 868 3 view .LVU203
|
|||
|
755 .syntax unified
|
|||
|
756 @ 868 "Drivers/CMSIS/Include/cmsis_gcc.h" 1
|
|||
|
757 003c BFF36F8F isb 0xF
|
|||
|
758 @ 0 "" 2
|
|||
|
759 .thumb
|
|||
|
760 .syntax unified
|
|||
|
761 .LBE19:
|
|||
|
762 .LBE18:
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 50
|
|||
|
|
|||
|
|
|||
|
224:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
763 .loc 1 224 5 view .LVU204
|
|||
|
764 .LBB20:
|
|||
|
765 .LBI20:
|
|||
|
869:Drivers/CMSIS/Include/cmsis_gcc.h **** }
|
|||
|
870:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
871:Drivers/CMSIS/Include/cmsis_gcc.h ****
|
|||
|
872:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
|
|||
|
873:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Data Synchronization Barrier
|
|||
|
874:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Acts as a special kind of Data Memory Barrier.
|
|||
|
875:Drivers/CMSIS/Include/cmsis_gcc.h **** It completes when all explicit memory accesses before this instruction complete.
|
|||
|
876:Drivers/CMSIS/Include/cmsis_gcc.h **** */
|
|||
|
877:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE void __DSB(void)
|
|||
|
766 .loc 2 877 27 view .LVU205
|
|||
|
767 .LBB21:
|
|||
|
878:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
879:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("dsb 0xF":::"memory");
|
|||
|
768 .loc 2 879 3 view .LVU206
|
|||
|
769 .syntax unified
|
|||
|
770 @ 879 "Drivers/CMSIS/Include/cmsis_gcc.h" 1
|
|||
|
771 0040 BFF34F8F dsb 0xF
|
|||
|
772 @ 0 "" 2
|
|||
|
773 .thumb
|
|||
|
774 .syntax unified
|
|||
|
775 .LBE21:
|
|||
|
776 .LBE20:
|
|||
|
151:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
777 .loc 1 151 11 is_stmt 0 view .LVU207
|
|||
|
778 0044 0823 movs r3, #8
|
|||
|
779 .LVL41:
|
|||
|
780 .L65:
|
|||
|
236:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
781 .loc 1 236 7 is_stmt 1 discriminator 1 view .LVU208
|
|||
|
238:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** dest_addr++;
|
|||
|
782 .loc 1 238 9 discriminator 1 view .LVU209
|
|||
|
238:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** dest_addr++;
|
|||
|
783 .loc 1 238 22 is_stmt 0 discriminator 1 view .LVU210
|
|||
|
784 0046 54F8042B ldr r2, [r4], #4
|
|||
|
785 .LVL42:
|
|||
|
238:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** dest_addr++;
|
|||
|
786 .loc 1 238 20 discriminator 1 view .LVU211
|
|||
|
787 004a 45F8042B str r2, [r5], #4
|
|||
|
788 .LVL43:
|
|||
|
239:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** src_addr++;
|
|||
|
789 .loc 1 239 9 is_stmt 1 discriminator 1 view .LVU212
|
|||
|
240:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** row_index--;
|
|||
|
790 .loc 1 240 9 discriminator 1 view .LVU213
|
|||
|
241:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** } while (row_index != 0U);
|
|||
|
791 .loc 1 241 9 discriminator 1 view .LVU214
|
|||
|
241:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** } while (row_index != 0U);
|
|||
|
792 .loc 1 241 18 is_stmt 0 discriminator 1 view .LVU215
|
|||
|
793 004e 013B subs r3, r3, #1
|
|||
|
794 .LVL44:
|
|||
|
242:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
795 .loc 1 242 14 is_stmt 1 discriminator 1 view .LVU216
|
|||
|
242:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
796 .loc 1 242 6 is_stmt 0 discriminator 1 view .LVU217
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 51
|
|||
|
|
|||
|
|
|||
|
797 0050 13F0FF03 ands r3, r3, #255
|
|||
|
798 .LVL45:
|
|||
|
242:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
799 .loc 1 242 6 discriminator 1 view .LVU218
|
|||
|
800 0054 F7D1 bne .L65
|
|||
|
245:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** __DSB();
|
|||
|
801 .loc 1 245 5 is_stmt 1 view .LVU219
|
|||
|
802 .LBB22:
|
|||
|
803 .LBI22:
|
|||
|
866:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
804 .loc 2 866 27 view .LVU220
|
|||
|
805 .LBB23:
|
|||
|
868:Drivers/CMSIS/Include/cmsis_gcc.h **** }
|
|||
|
806 .loc 2 868 3 view .LVU221
|
|||
|
807 .syntax unified
|
|||
|
808 @ 868 "Drivers/CMSIS/Include/cmsis_gcc.h" 1
|
|||
|
809 0056 BFF36F8F isb 0xF
|
|||
|
810 @ 0 "" 2
|
|||
|
811 .thumb
|
|||
|
812 .syntax unified
|
|||
|
813 .LBE23:
|
|||
|
814 .LBE22:
|
|||
|
246:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
815 .loc 1 246 5 view .LVU222
|
|||
|
816 .LBB24:
|
|||
|
817 .LBI24:
|
|||
|
877:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
818 .loc 2 877 27 view .LVU223
|
|||
|
819 .LBB25:
|
|||
|
820 .loc 2 879 3 view .LVU224
|
|||
|
821 .syntax unified
|
|||
|
822 @ 879 "Drivers/CMSIS/Include/cmsis_gcc.h" 1
|
|||
|
823 005a BFF34F8F dsb 0xF
|
|||
|
824 @ 0 "" 2
|
|||
|
825 .thumb
|
|||
|
826 .syntax unified
|
|||
|
827 .LBE25:
|
|||
|
828 .LBE24:
|
|||
|
249:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
829 .loc 1 249 5 view .LVU225
|
|||
|
249:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
830 .loc 1 249 14 is_stmt 0 view .LVU226
|
|||
|
831 005e 0121 movs r1, #1
|
|||
|
832 0060 4CF25030 movw r0, #50000
|
|||
|
833 .LVL46:
|
|||
|
249:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
834 .loc 1 249 14 view .LVU227
|
|||
|
835 0064 FFF7FEFF bl FLASH_WaitForLastOperation
|
|||
|
836 .LVL47:
|
|||
|
283:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
837 .loc 1 283 7 is_stmt 1 view .LVU228
|
|||
|
838 0068 064A ldr r2, .L70+4
|
|||
|
839 006a D368 ldr r3, [r2, #12]
|
|||
|
840 006c 23F00203 bic r3, r3, #2
|
|||
|
841 0070 D360 str r3, [r2, #12]
|
|||
|
842 .LVL48:
|
|||
|
843 .L64:
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 52
|
|||
|
|
|||
|
|
|||
|
289:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
844 .loc 1 289 3 view .LVU229
|
|||
|
289:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
845 .loc 1 289 3 view .LVU230
|
|||
|
846 0072 034B ldr r3, .L70
|
|||
|
847 0074 0022 movs r2, #0
|
|||
|
848 0076 1A75 strb r2, [r3, #20]
|
|||
|
289:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
849 .loc 1 289 3 view .LVU231
|
|||
|
291:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
850 .loc 1 291 3 view .LVU232
|
|||
|
291:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
851 .loc 1 291 10 is_stmt 0 view .LVU233
|
|||
|
852 0078 D2E7 b .L63
|
|||
|
853 .LVL49:
|
|||
|
854 .L66:
|
|||
|
158:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
855 .loc 1 158 3 view .LVU234
|
|||
|
856 007a 0220 movs r0, #2
|
|||
|
857 .LVL50:
|
|||
|
158:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
858 .loc 1 158 3 view .LVU235
|
|||
|
859 007c D0E7 b .L63
|
|||
|
860 .L71:
|
|||
|
861 007e 00BF .align 2
|
|||
|
862 .L70:
|
|||
|
863 0080 00000000 .word .LANCHOR0
|
|||
|
864 0084 00200052 .word 1375739904
|
|||
|
865 .cfi_endproc
|
|||
|
866 .LFE141:
|
|||
|
868 .section .text.HAL_FLASH_Program_IT,"ax",%progbits
|
|||
|
869 .align 1
|
|||
|
870 .global HAL_FLASH_Program_IT
|
|||
|
871 .syntax unified
|
|||
|
872 .thumb
|
|||
|
873 .thumb_func
|
|||
|
874 .fpu fpv5-d16
|
|||
|
876 HAL_FLASH_Program_IT:
|
|||
|
877 .LVL51:
|
|||
|
878 .LFB142:
|
|||
|
304:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** HAL_StatusTypeDef status;
|
|||
|
879 .loc 1 304 1 is_stmt 1 view -0
|
|||
|
880 .cfi_startproc
|
|||
|
881 @ args = 0, pretend = 0, frame = 0
|
|||
|
882 @ frame_needed = 0, uses_anonymous_args = 0
|
|||
|
305:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** __IO uint32_t *dest_addr = (__IO uint32_t*)FlashAddress;
|
|||
|
883 .loc 1 305 3 view .LVU237
|
|||
|
306:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** __IO uint32_t *src_addr = (__IO uint32_t*)DataAddress;
|
|||
|
884 .loc 1 306 3 view .LVU238
|
|||
|
307:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** uint32_t bank;
|
|||
|
885 .loc 1 307 3 view .LVU239
|
|||
|
308:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** uint8_t row_index = FLASH_NB_32BITWORD_IN_FLASHWORD;
|
|||
|
886 .loc 1 308 3 view .LVU240
|
|||
|
309:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
887 .loc 1 309 3 view .LVU241
|
|||
|
312:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** assert_param(IS_FLASH_PROGRAM_ADDRESS(FlashAddress));
|
|||
|
888 .loc 1 312 3 view .LVU242
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 53
|
|||
|
|
|||
|
|
|||
|
313:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
889 .loc 1 313 3 view .LVU243
|
|||
|
316:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
890 .loc 1 316 3 view .LVU244
|
|||
|
316:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
891 .loc 1 316 3 view .LVU245
|
|||
|
892 0000 1F4B ldr r3, .L83
|
|||
|
893 0002 1B7D ldrb r3, [r3, #20] @ zero_extendqisi2
|
|||
|
894 0004 012B cmp r3, #1
|
|||
|
895 0006 38D0 beq .L76
|
|||
|
304:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** HAL_StatusTypeDef status;
|
|||
|
896 .loc 1 304 1 is_stmt 0 discriminator 2 view .LVU246
|
|||
|
897 0008 70B5 push {r4, r5, r6, lr}
|
|||
|
898 .LCFI3:
|
|||
|
899 .cfi_def_cfa_offset 16
|
|||
|
900 .cfi_offset 4, -16
|
|||
|
901 .cfi_offset 5, -12
|
|||
|
902 .cfi_offset 6, -8
|
|||
|
903 .cfi_offset 14, -4
|
|||
|
904 000a 0D46 mov r5, r1
|
|||
|
905 000c 0E46 mov r6, r1
|
|||
|
906 000e 1446 mov r4, r2
|
|||
|
316:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
907 .loc 1 316 3 is_stmt 1 discriminator 2 view .LVU247
|
|||
|
908 0010 1B4B ldr r3, .L83
|
|||
|
909 0012 0122 movs r2, #1
|
|||
|
910 .LVL52:
|
|||
|
316:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
911 .loc 1 316 3 is_stmt 0 discriminator 2 view .LVU248
|
|||
|
912 0014 1A75 strb r2, [r3, #20]
|
|||
|
316:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
913 .loc 1 316 3 is_stmt 1 discriminator 2 view .LVU249
|
|||
|
319:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
914 .loc 1 319 3 discriminator 2 view .LVU250
|
|||
|
319:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
915 .loc 1 319 20 is_stmt 0 discriminator 2 view .LVU251
|
|||
|
916 0016 0022 movs r2, #0
|
|||
|
917 0018 9A61 str r2, [r3, #24]
|
|||
|
324:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #endif /* FLASH_OPTCR_PG_OTP */
|
|||
|
918 .loc 1 324 3 is_stmt 1 discriminator 2 view .LVU252
|
|||
|
324:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #endif /* FLASH_OPTCR_PG_OTP */
|
|||
|
919 .loc 1 324 6 is_stmt 0 discriminator 2 view .LVU253
|
|||
|
920 001a 01F17843 add r3, r1, #-134217728
|
|||
|
324:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #endif /* FLASH_OPTCR_PG_OTP */
|
|||
|
921 .loc 1 324 5 discriminator 2 view .LVU254
|
|||
|
922 001e B3F5003F cmp r3, #131072
|
|||
|
923 0022 01D3 bcc .L82
|
|||
|
337:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
924 .loc 1 337 12 view .LVU255
|
|||
|
925 0024 0120 movs r0, #1
|
|||
|
926 .LVL53:
|
|||
|
927 .L73:
|
|||
|
451:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
928 .loc 1 451 1 view .LVU256
|
|||
|
929 0026 70BD pop {r4, r5, r6, pc}
|
|||
|
930 .LVL54:
|
|||
|
931 .L82:
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 54
|
|||
|
|
|||
|
|
|||
|
327:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
932 .loc 1 327 5 is_stmt 1 view .LVU257
|
|||
|
341:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
933 .loc 1 341 3 view .LVU258
|
|||
|
341:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
934 .loc 1 341 12 is_stmt 0 view .LVU259
|
|||
|
935 0028 0121 movs r1, #1
|
|||
|
936 .LVL55:
|
|||
|
341:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
937 .loc 1 341 12 view .LVU260
|
|||
|
938 002a 4CF25030 movw r0, #50000
|
|||
|
939 .LVL56:
|
|||
|
341:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
940 .loc 1 341 12 view .LVU261
|
|||
|
941 002e FFF7FEFF bl FLASH_WaitForLastOperation
|
|||
|
942 .LVL57:
|
|||
|
343:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
943 .loc 1 343 3 is_stmt 1 view .LVU262
|
|||
|
343:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
944 .loc 1 343 6 is_stmt 0 view .LVU263
|
|||
|
945 0032 18B1 cbz r0, .L74
|
|||
|
346:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
946 .loc 1 346 5 is_stmt 1 view .LVU264
|
|||
|
346:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
947 .loc 1 346 5 view .LVU265
|
|||
|
948 0034 124B ldr r3, .L83
|
|||
|
949 0036 0022 movs r2, #0
|
|||
|
950 0038 1A75 strb r2, [r3, #20]
|
|||
|
346:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
951 .loc 1 346 5 view .LVU266
|
|||
|
952 003a F4E7 b .L73
|
|||
|
953 .L74:
|
|||
|
350:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
954 .loc 1 350 5 view .LVU267
|
|||
|
350:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
955 .loc 1 350 20 is_stmt 0 view .LVU268
|
|||
|
956 003c 104B ldr r3, .L83
|
|||
|
957 003e 1D61 str r5, [r3, #16]
|
|||
|
399:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
958 .loc 1 399 5 is_stmt 1 view .LVU269
|
|||
|
399:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
959 .loc 1 399 29 is_stmt 0 view .LVU270
|
|||
|
960 0040 0322 movs r2, #3
|
|||
|
961 0042 1A70 strb r2, [r3]
|
|||
|
411:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
962 .loc 1 411 7 is_stmt 1 view .LVU271
|
|||
|
963 0044 0F4B ldr r3, .L83+4
|
|||
|
964 0046 DA68 ldr r2, [r3, #12]
|
|||
|
965 0048 42F00202 orr r2, r2, #2
|
|||
|
966 004c DA60 str r2, [r3, #12]
|
|||
|
416:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** FLASH_IT_STRBERR_BANK1 | FLASH_IT_INCERR_BANK1 | FLASH_IT_OPERR_B
|
|||
|
967 .loc 1 416 7 view .LVU272
|
|||
|
968 004e DA68 ldr r2, [r3, #12]
|
|||
|
969 0050 42F4DE02 orr r2, r2, #7274496
|
|||
|
970 0054 DA60 str r2, [r3, #12]
|
|||
|
424:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** __DSB();
|
|||
|
971 .loc 1 424 5 view .LVU273
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 55
|
|||
|
|
|||
|
|
|||
|
972 .LBB26:
|
|||
|
973 .LBI26:
|
|||
|
866:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
974 .loc 2 866 27 view .LVU274
|
|||
|
975 .LBB27:
|
|||
|
868:Drivers/CMSIS/Include/cmsis_gcc.h **** }
|
|||
|
976 .loc 2 868 3 view .LVU275
|
|||
|
977 .syntax unified
|
|||
|
978 @ 868 "Drivers/CMSIS/Include/cmsis_gcc.h" 1
|
|||
|
979 0056 BFF36F8F isb 0xF
|
|||
|
980 @ 0 "" 2
|
|||
|
981 .thumb
|
|||
|
982 .syntax unified
|
|||
|
983 .LBE27:
|
|||
|
984 .LBE26:
|
|||
|
425:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
985 .loc 1 425 5 view .LVU276
|
|||
|
986 .LBB28:
|
|||
|
987 .LBI28:
|
|||
|
877:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
988 .loc 2 877 27 view .LVU277
|
|||
|
989 .LBB29:
|
|||
|
990 .loc 2 879 3 view .LVU278
|
|||
|
991 .syntax unified
|
|||
|
992 @ 879 "Drivers/CMSIS/Include/cmsis_gcc.h" 1
|
|||
|
993 005a BFF34F8F dsb 0xF
|
|||
|
994 @ 0 "" 2
|
|||
|
995 .thumb
|
|||
|
996 .syntax unified
|
|||
|
997 .LBE29:
|
|||
|
998 .LBE28:
|
|||
|
309:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
999 .loc 1 309 11 is_stmt 0 view .LVU279
|
|||
|
1000 005e 0823 movs r3, #8
|
|||
|
1001 .LVL58:
|
|||
|
1002 .L75:
|
|||
|
437:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
1003 .loc 1 437 7 is_stmt 1 discriminator 1 view .LVU280
|
|||
|
439:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** dest_addr++;
|
|||
|
1004 .loc 1 439 9 discriminator 1 view .LVU281
|
|||
|
439:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** dest_addr++;
|
|||
|
1005 .loc 1 439 22 is_stmt 0 discriminator 1 view .LVU282
|
|||
|
1006 0060 54F8042B ldr r2, [r4], #4
|
|||
|
1007 .LVL59:
|
|||
|
439:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** dest_addr++;
|
|||
|
1008 .loc 1 439 20 discriminator 1 view .LVU283
|
|||
|
1009 0064 46F8042B str r2, [r6], #4
|
|||
|
1010 .LVL60:
|
|||
|
440:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** src_addr++;
|
|||
|
1011 .loc 1 440 9 is_stmt 1 discriminator 1 view .LVU284
|
|||
|
441:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** row_index--;
|
|||
|
1012 .loc 1 441 9 discriminator 1 view .LVU285
|
|||
|
442:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** } while (row_index != 0U);
|
|||
|
1013 .loc 1 442 9 discriminator 1 view .LVU286
|
|||
|
442:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** } while (row_index != 0U);
|
|||
|
1014 .loc 1 442 18 is_stmt 0 discriminator 1 view .LVU287
|
|||
|
1015 0068 013B subs r3, r3, #1
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 56
|
|||
|
|
|||
|
|
|||
|
1016 .LVL61:
|
|||
|
443:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
1017 .loc 1 443 15 is_stmt 1 discriminator 1 view .LVU288
|
|||
|
443:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
1018 .loc 1 443 7 is_stmt 0 discriminator 1 view .LVU289
|
|||
|
1019 006a 13F0FF03 ands r3, r3, #255
|
|||
|
1020 .LVL62:
|
|||
|
443:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
1021 .loc 1 443 7 discriminator 1 view .LVU290
|
|||
|
1022 006e F7D1 bne .L75
|
|||
|
446:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** __DSB();
|
|||
|
1023 .loc 1 446 5 is_stmt 1 view .LVU291
|
|||
|
1024 .LBB30:
|
|||
|
1025 .LBI30:
|
|||
|
866:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
1026 .loc 2 866 27 view .LVU292
|
|||
|
1027 .LBB31:
|
|||
|
868:Drivers/CMSIS/Include/cmsis_gcc.h **** }
|
|||
|
1028 .loc 2 868 3 view .LVU293
|
|||
|
1029 .syntax unified
|
|||
|
1030 @ 868 "Drivers/CMSIS/Include/cmsis_gcc.h" 1
|
|||
|
1031 0070 BFF36F8F isb 0xF
|
|||
|
1032 @ 0 "" 2
|
|||
|
1033 .thumb
|
|||
|
1034 .syntax unified
|
|||
|
1035 .LBE31:
|
|||
|
1036 .LBE30:
|
|||
|
447:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
1037 .loc 1 447 5 view .LVU294
|
|||
|
1038 .LBB32:
|
|||
|
1039 .LBI32:
|
|||
|
877:Drivers/CMSIS/Include/cmsis_gcc.h **** {
|
|||
|
1040 .loc 2 877 27 view .LVU295
|
|||
|
1041 .LBB33:
|
|||
|
1042 .loc 2 879 3 view .LVU296
|
|||
|
1043 .syntax unified
|
|||
|
1044 @ 879 "Drivers/CMSIS/Include/cmsis_gcc.h" 1
|
|||
|
1045 0074 BFF34F8F dsb 0xF
|
|||
|
1046 @ 0 "" 2
|
|||
|
880:Drivers/CMSIS/Include/cmsis_gcc.h **** }
|
|||
|
1047 .loc 2 880 1 is_stmt 0 view .LVU297
|
|||
|
1048 .thumb
|
|||
|
1049 .syntax unified
|
|||
|
1050 0078 D5E7 b .L73
|
|||
|
1051 .LVL63:
|
|||
|
1052 .L76:
|
|||
|
1053 .LCFI4:
|
|||
|
1054 .cfi_def_cfa_offset 0
|
|||
|
1055 .cfi_restore 4
|
|||
|
1056 .cfi_restore 5
|
|||
|
1057 .cfi_restore 6
|
|||
|
1058 .cfi_restore 14
|
|||
|
1059 .loc 2 880 1 view .LVU298
|
|||
|
1060 .LBE33:
|
|||
|
1061 .LBE32:
|
|||
|
316:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
1062 .loc 1 316 3 view .LVU299
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 57
|
|||
|
|
|||
|
|
|||
|
1063 007a 0220 movs r0, #2
|
|||
|
1064 .LVL64:
|
|||
|
451:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
1065 .loc 1 451 1 view .LVU300
|
|||
|
1066 007c 7047 bx lr
|
|||
|
1067 .L84:
|
|||
|
1068 007e 00BF .align 2
|
|||
|
1069 .L83:
|
|||
|
1070 0080 00000000 .word .LANCHOR0
|
|||
|
1071 0084 00200052 .word 1375739904
|
|||
|
1072 .cfi_endproc
|
|||
|
1073 .LFE142:
|
|||
|
1075 .section .text.FLASH_OB_WaitForLastOperation,"ax",%progbits
|
|||
|
1076 .align 1
|
|||
|
1077 .global FLASH_OB_WaitForLastOperation
|
|||
|
1078 .syntax unified
|
|||
|
1079 .thumb
|
|||
|
1080 .thumb_func
|
|||
|
1081 .fpu fpv5-d16
|
|||
|
1083 FLASH_OB_WaitForLastOperation:
|
|||
|
1084 .LVL65:
|
|||
|
1085 .LFB153:
|
|||
|
1055:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
1056:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /**
|
|||
|
1057:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @brief Wait for a FLASH Option Bytes change operation to complete.
|
|||
|
1058:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @param Timeout maximum flash operation timeout
|
|||
|
1059:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @retval HAL_StatusTypeDef HAL Status
|
|||
|
1060:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** */
|
|||
|
1061:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** HAL_StatusTypeDef FLASH_OB_WaitForLastOperation(uint32_t Timeout)
|
|||
|
1062:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
1086 .loc 1 1062 1 is_stmt 1 view -0
|
|||
|
1087 .cfi_startproc
|
|||
|
1088 @ args = 0, pretend = 0, frame = 0
|
|||
|
1089 @ frame_needed = 0, uses_anonymous_args = 0
|
|||
|
1090 .loc 1 1062 1 is_stmt 0 view .LVU302
|
|||
|
1091 0000 38B5 push {r3, r4, r5, lr}
|
|||
|
1092 .LCFI5:
|
|||
|
1093 .cfi_def_cfa_offset 16
|
|||
|
1094 .cfi_offset 3, -16
|
|||
|
1095 .cfi_offset 4, -12
|
|||
|
1096 .cfi_offset 5, -8
|
|||
|
1097 .cfi_offset 14, -4
|
|||
|
1098 0002 0446 mov r4, r0
|
|||
|
1063:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Get timeout */
|
|||
|
1064:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** uint32_t tickstart = HAL_GetTick();
|
|||
|
1099 .loc 1 1064 3 is_stmt 1 view .LVU303
|
|||
|
1100 .loc 1 1064 24 is_stmt 0 view .LVU304
|
|||
|
1101 0004 FFF7FEFF bl HAL_GetTick
|
|||
|
1102 .LVL66:
|
|||
|
1103 .loc 1 1064 24 view .LVU305
|
|||
|
1104 0008 0546 mov r5, r0
|
|||
|
1105 .LVL67:
|
|||
|
1065:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
1066:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Wait for the FLASH Option Bytes change operation to complete by polling on OPT_BUSY flag to be
|
|||
|
1067:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** while(READ_BIT(FLASH->OPTSR_CUR, FLASH_OPTSR_OPT_BUSY) != 0U)
|
|||
|
1106 .loc 1 1067 3 is_stmt 1 view .LVU306
|
|||
|
1107 .L87:
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 58
|
|||
|
|
|||
|
|
|||
|
1108 .loc 1 1067 8 view .LVU307
|
|||
|
1109 .loc 1 1067 9 is_stmt 0 view .LVU308
|
|||
|
1110 000a 134B ldr r3, .L96
|
|||
|
1111 000c DB69 ldr r3, [r3, #28]
|
|||
|
1112 .loc 1 1067 8 view .LVU309
|
|||
|
1113 000e 13F0010F tst r3, #1
|
|||
|
1114 0012 0BD0 beq .L94
|
|||
|
1068:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
1069:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if(Timeout != HAL_MAX_DELAY)
|
|||
|
1115 .loc 1 1069 5 is_stmt 1 view .LVU310
|
|||
|
1116 .loc 1 1069 7 is_stmt 0 view .LVU311
|
|||
|
1117 0014 B4F1FF3F cmp r4, #-1
|
|||
|
1118 0018 F7D0 beq .L87
|
|||
|
1070:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
1071:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if(((HAL_GetTick() - tickstart) > Timeout) || (Timeout == 0U))
|
|||
|
1119 .loc 1 1071 7 is_stmt 1 view .LVU312
|
|||
|
1120 .loc 1 1071 12 is_stmt 0 view .LVU313
|
|||
|
1121 001a FFF7FEFF bl HAL_GetTick
|
|||
|
1122 .LVL68:
|
|||
|
1123 .loc 1 1071 26 view .LVU314
|
|||
|
1124 001e 401B subs r0, r0, r5
|
|||
|
1125 .loc 1 1071 9 view .LVU315
|
|||
|
1126 0020 A042 cmp r0, r4
|
|||
|
1127 0022 16D8 bhi .L90
|
|||
|
1128 .loc 1 1071 50 discriminator 1 view .LVU316
|
|||
|
1129 0024 002C cmp r4, #0
|
|||
|
1130 0026 F0D1 bne .L87
|
|||
|
1072:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
1073:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** return HAL_TIMEOUT;
|
|||
|
1131 .loc 1 1073 16 view .LVU317
|
|||
|
1132 0028 0320 movs r0, #3
|
|||
|
1133 002a 05E0 b .L88
|
|||
|
1134 .L94:
|
|||
|
1074:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
1075:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
1076:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
1077:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
1078:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Check option byte change error */
|
|||
|
1079:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if(READ_BIT(FLASH->OPTSR_CUR, FLASH_OPTSR_OPTCHANGEERR) != 0U)
|
|||
|
1135 .loc 1 1079 3 is_stmt 1 view .LVU318
|
|||
|
1136 .loc 1 1079 6 is_stmt 0 view .LVU319
|
|||
|
1137 002c 0A4B ldr r3, .L96
|
|||
|
1138 002e DB69 ldr r3, [r3, #28]
|
|||
|
1139 .loc 1 1079 5 view .LVU320
|
|||
|
1140 0030 13F0804F tst r3, #1073741824
|
|||
|
1141 0034 01D1 bne .L95
|
|||
|
1080:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
1081:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Save the error code */
|
|||
|
1082:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** pFlash.ErrorCode |= HAL_FLASH_ERROR_OB_CHANGE;
|
|||
|
1083:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
1084:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Clear the OB error flag */
|
|||
|
1085:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** FLASH->OPTCCR |= FLASH_OPTCCR_CLR_OPTCHANGEERR;
|
|||
|
1086:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
1087:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** return HAL_ERROR;
|
|||
|
1088:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
1089:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
1090:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* If there is no error flag set */
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 59
|
|||
|
|
|||
|
|
|||
|
1091:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** return HAL_OK;
|
|||
|
1142 .loc 1 1091 10 view .LVU321
|
|||
|
1143 0036 0020 movs r0, #0
|
|||
|
1144 .L88:
|
|||
|
1092:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
1145 .loc 1 1092 1 view .LVU322
|
|||
|
1146 0038 38BD pop {r3, r4, r5, pc}
|
|||
|
1147 .LVL69:
|
|||
|
1148 .L95:
|
|||
|
1082:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
1149 .loc 1 1082 5 is_stmt 1 view .LVU323
|
|||
|
1082:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
1150 .loc 1 1082 22 is_stmt 0 view .LVU324
|
|||
|
1151 003a 084A ldr r2, .L96+4
|
|||
|
1152 003c 9369 ldr r3, [r2, #24]
|
|||
|
1153 003e 43F08043 orr r3, r3, #1073741824
|
|||
|
1154 0042 9361 str r3, [r2, #24]
|
|||
|
1085:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
1155 .loc 1 1085 5 is_stmt 1 view .LVU325
|
|||
|
1085:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
1156 .loc 1 1085 19 is_stmt 0 view .LVU326
|
|||
|
1157 0044 044A ldr r2, .L96
|
|||
|
1158 0046 536A ldr r3, [r2, #36]
|
|||
|
1159 0048 43F08043 orr r3, r3, #1073741824
|
|||
|
1160 004c 5362 str r3, [r2, #36]
|
|||
|
1087:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
1161 .loc 1 1087 5 is_stmt 1 view .LVU327
|
|||
|
1087:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
1162 .loc 1 1087 12 is_stmt 0 view .LVU328
|
|||
|
1163 004e 0120 movs r0, #1
|
|||
|
1164 0050 F2E7 b .L88
|
|||
|
1165 .L90:
|
|||
|
1073:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
1166 .loc 1 1073 16 view .LVU329
|
|||
|
1167 0052 0320 movs r0, #3
|
|||
|
1168 0054 F0E7 b .L88
|
|||
|
1169 .L97:
|
|||
|
1170 0056 00BF .align 2
|
|||
|
1171 .L96:
|
|||
|
1172 0058 00200052 .word 1375739904
|
|||
|
1173 005c 00000000 .word .LANCHOR0
|
|||
|
1174 .cfi_endproc
|
|||
|
1175 .LFE153:
|
|||
|
1177 .section .text.FLASH_CRC_WaitForLastOperation,"ax",%progbits
|
|||
|
1178 .align 1
|
|||
|
1179 .global FLASH_CRC_WaitForLastOperation
|
|||
|
1180 .syntax unified
|
|||
|
1181 .thumb
|
|||
|
1182 .thumb_func
|
|||
|
1183 .fpu fpv5-d16
|
|||
|
1185 FLASH_CRC_WaitForLastOperation:
|
|||
|
1186 .LVL70:
|
|||
|
1187 .LFB154:
|
|||
|
1093:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
1094:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /**
|
|||
|
1095:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @brief Wait for a FLASH CRC computation to complete.
|
|||
|
1096:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @param Timeout maximum flash operation timeout
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 60
|
|||
|
|
|||
|
|
|||
|
1097:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @param Bank flash FLASH_BANK_1 or FLASH_BANK_2
|
|||
|
1098:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** * @retval HAL_StatusTypeDef HAL Status
|
|||
|
1099:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** */
|
|||
|
1100:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** HAL_StatusTypeDef FLASH_CRC_WaitForLastOperation(uint32_t Timeout, uint32_t Bank)
|
|||
|
1101:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
1188 .loc 1 1101 1 is_stmt 1 view -0
|
|||
|
1189 .cfi_startproc
|
|||
|
1190 @ args = 0, pretend = 0, frame = 0
|
|||
|
1191 @ frame_needed = 0, uses_anonymous_args = 0
|
|||
|
1192 .loc 1 1101 1 is_stmt 0 view .LVU331
|
|||
|
1193 0000 F8B5 push {r3, r4, r5, r6, r7, lr}
|
|||
|
1194 .LCFI6:
|
|||
|
1195 .cfi_def_cfa_offset 24
|
|||
|
1196 .cfi_offset 3, -24
|
|||
|
1197 .cfi_offset 4, -20
|
|||
|
1198 .cfi_offset 5, -16
|
|||
|
1199 .cfi_offset 6, -12
|
|||
|
1200 .cfi_offset 7, -8
|
|||
|
1201 .cfi_offset 14, -4
|
|||
|
1202 0002 0446 mov r4, r0
|
|||
|
1203 0004 0E46 mov r6, r1
|
|||
|
1102:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** uint32_t bsyflag;
|
|||
|
1204 .loc 1 1102 3 is_stmt 1 view .LVU332
|
|||
|
1103:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** uint32_t tickstart = HAL_GetTick();
|
|||
|
1205 .loc 1 1103 3 view .LVU333
|
|||
|
1206 .loc 1 1103 24 is_stmt 0 view .LVU334
|
|||
|
1207 0006 FFF7FEFF bl HAL_GetTick
|
|||
|
1208 .LVL71:
|
|||
|
1209 .loc 1 1103 24 view .LVU335
|
|||
|
1210 000a 0746 mov r7, r0
|
|||
|
1211 .LVL72:
|
|||
|
1104:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
1105:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** assert_param(IS_FLASH_BANK_EXCLUSIVE(Bank));
|
|||
|
1212 .loc 1 1105 3 is_stmt 1 view .LVU336
|
|||
|
1106:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
1107:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Select bsyflag depending on Bank */
|
|||
|
1108:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if(Bank == FLASH_BANK_1)
|
|||
|
1213 .loc 1 1108 3 view .LVU337
|
|||
|
1214 .loc 1 1108 5 is_stmt 0 view .LVU338
|
|||
|
1215 000c 012E cmp r6, #1
|
|||
|
1216 000e 11D0 beq .L99
|
|||
|
1109:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
1110:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** bsyflag = FLASH_FLAG_CRC_BUSY_BANK1;
|
|||
|
1111:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
1112:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** else
|
|||
|
1113:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
1114:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** bsyflag = FLASH_FLAG_CRC_BUSY_BANK2;
|
|||
|
1217 .loc 1 1114 13 view .LVU339
|
|||
|
1218 0010 154D ldr r5, .L113
|
|||
|
1219 .LVL73:
|
|||
|
1220 .L101:
|
|||
|
1115:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
1116:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
1117:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Wait for the FLASH CRC computation to complete by polling on CRC_BUSY flag to be reset */
|
|||
|
1118:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** while(__HAL_FLASH_GET_FLAG(bsyflag))
|
|||
|
1221 .loc 1 1118 8 is_stmt 1 view .LVU340
|
|||
|
1222 .loc 1 1118 9 is_stmt 0 view .LVU341
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 61
|
|||
|
|
|||
|
|
|||
|
1223 0012 164B ldr r3, .L113+4
|
|||
|
1224 0014 1B69 ldr r3, [r3, #16]
|
|||
|
1225 .loc 1 1118 8 view .LVU342
|
|||
|
1226 0016 35EA0303 bics r3, r5, r3
|
|||
|
1227 001a 0DD1 bne .L110
|
|||
|
1119:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
1120:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if(Timeout != HAL_MAX_DELAY)
|
|||
|
1228 .loc 1 1120 5 is_stmt 1 view .LVU343
|
|||
|
1229 .loc 1 1120 7 is_stmt 0 view .LVU344
|
|||
|
1230 001c B4F1FF3F cmp r4, #-1
|
|||
|
1231 0020 F7D0 beq .L101
|
|||
|
1121:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
1122:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if(((HAL_GetTick() - tickstart) > Timeout) || (Timeout == 0U))
|
|||
|
1232 .loc 1 1122 7 is_stmt 1 view .LVU345
|
|||
|
1233 .loc 1 1122 12 is_stmt 0 view .LVU346
|
|||
|
1234 0022 FFF7FEFF bl HAL_GetTick
|
|||
|
1235 .LVL74:
|
|||
|
1236 .loc 1 1122 26 view .LVU347
|
|||
|
1237 0026 C01B subs r0, r0, r7
|
|||
|
1238 .loc 1 1122 9 view .LVU348
|
|||
|
1239 0028 A042 cmp r0, r4
|
|||
|
1240 002a 1BD8 bhi .L105
|
|||
|
1241 .loc 1 1122 50 discriminator 1 view .LVU349
|
|||
|
1242 002c 002C cmp r4, #0
|
|||
|
1243 002e F0D1 bne .L101
|
|||
|
1123:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
1124:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** return HAL_TIMEOUT;
|
|||
|
1244 .loc 1 1124 16 view .LVU350
|
|||
|
1245 0030 0320 movs r0, #3
|
|||
|
1246 0032 04E0 b .L102
|
|||
|
1247 .LVL75:
|
|||
|
1248 .L99:
|
|||
|
1110:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
1249 .loc 1 1110 13 view .LVU351
|
|||
|
1250 0034 0825 movs r5, #8
|
|||
|
1251 0036 ECE7 b .L101
|
|||
|
1252 .LVL76:
|
|||
|
1253 .L110:
|
|||
|
1125:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
1126:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
1127:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
1128:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
1129:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Check FLASH CRC read error flag */
|
|||
|
1130:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if(Bank == FLASH_BANK_1)
|
|||
|
1254 .loc 1 1130 3 is_stmt 1 view .LVU352
|
|||
|
1255 .loc 1 1130 5 is_stmt 0 view .LVU353
|
|||
|
1256 0038 012E cmp r6, #1
|
|||
|
1257 003a 01D0 beq .L111
|
|||
|
1131:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
1132:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if (__HAL_FLASH_GET_FLAG_BANK1(FLASH_FLAG_CRCRDERR_BANK1))
|
|||
|
1133:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
1134:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Save the error code */
|
|||
|
1135:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** pFlash.ErrorCode |= HAL_FLASH_ERROR_CRCRD_BANK1;
|
|||
|
1136:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
1137:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Clear FLASH CRC read error pending bit */
|
|||
|
1138:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** __HAL_FLASH_CLEAR_FLAG_BANK1(FLASH_FLAG_CRCRDERR_BANK1);
|
|||
|
1139:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 62
|
|||
|
|
|||
|
|
|||
|
1140:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** return HAL_ERROR;
|
|||
|
1141:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
1142:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
1143:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #if defined (DUAL_BANK)
|
|||
|
1144:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** else
|
|||
|
1145:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
1146:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** if (__HAL_FLASH_GET_FLAG_BANK2(FLASH_FLAG_CRCRDERR_BANK2))
|
|||
|
1147:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
1148:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Save the error code */
|
|||
|
1149:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** pFlash.ErrorCode |= HAL_FLASH_ERROR_CRCRD_BANK2;
|
|||
|
1150:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
1151:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* Clear FLASH CRC read error pending bit */
|
|||
|
1152:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** __HAL_FLASH_CLEAR_FLAG_BANK2(FLASH_FLAG_CRCRDERR_BANK2);
|
|||
|
1153:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
1154:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** return HAL_ERROR;
|
|||
|
1155:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
1156:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
1157:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** #endif /* DUAL_BANK */
|
|||
|
1158:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
1159:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** /* If there is no error flag set */
|
|||
|
1160:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** return HAL_OK;
|
|||
|
1258 .loc 1 1160 10 view .LVU354
|
|||
|
1259 003c 0020 movs r0, #0
|
|||
|
1260 .L102:
|
|||
|
1161:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
1261 .loc 1 1161 1 view .LVU355
|
|||
|
1262 003e F8BD pop {r3, r4, r5, r6, r7, pc}
|
|||
|
1263 .LVL77:
|
|||
|
1264 .L111:
|
|||
|
1132:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
1265 .loc 1 1132 5 is_stmt 1 view .LVU356
|
|||
|
1132:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
1266 .loc 1 1132 9 is_stmt 0 view .LVU357
|
|||
|
1267 0040 0A4B ldr r3, .L113+4
|
|||
|
1268 0042 1B69 ldr r3, [r3, #16]
|
|||
|
1132:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
1269 .loc 1 1132 8 view .LVU358
|
|||
|
1270 0044 13F0805F tst r3, #268435456
|
|||
|
1271 0048 01D1 bne .L112
|
|||
|
1160:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
1272 .loc 1 1160 10 view .LVU359
|
|||
|
1273 004a 0020 movs r0, #0
|
|||
|
1274 004c F7E7 b .L102
|
|||
|
1275 .L112:
|
|||
|
1135:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
1276 .loc 1 1135 7 is_stmt 1 view .LVU360
|
|||
|
1135:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
1277 .loc 1 1135 24 is_stmt 0 view .LVU361
|
|||
|
1278 004e 084A ldr r2, .L113+8
|
|||
|
1279 0050 9369 ldr r3, [r2, #24]
|
|||
|
1280 0052 43F08053 orr r3, r3, #268435456
|
|||
|
1281 0056 9361 str r3, [r2, #24]
|
|||
|
1138:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
1282 .loc 1 1138 7 is_stmt 1 view .LVU362
|
|||
|
1283 0058 044B ldr r3, .L113+4
|
|||
|
1284 005a 4FF08052 mov r2, #268435456
|
|||
|
1285 005e 5A61 str r2, [r3, #20]
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 63
|
|||
|
|
|||
|
|
|||
|
1140:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
1286 .loc 1 1140 7 view .LVU363
|
|||
|
1140:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
1287 .loc 1 1140 14 is_stmt 0 view .LVU364
|
|||
|
1288 0060 0120 movs r0, #1
|
|||
|
1289 0062 ECE7 b .L102
|
|||
|
1290 .L105:
|
|||
|
1124:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
1291 .loc 1 1124 16 view .LVU365
|
|||
|
1292 0064 0320 movs r0, #3
|
|||
|
1293 0066 EAE7 b .L102
|
|||
|
1294 .L114:
|
|||
|
1295 .align 2
|
|||
|
1296 .L113:
|
|||
|
1297 0068 08000080 .word -2147483640
|
|||
|
1298 006c 00200052 .word 1375739904
|
|||
|
1299 0070 00000000 .word .LANCHOR0
|
|||
|
1300 .cfi_endproc
|
|||
|
1301 .LFE154:
|
|||
|
1303 .section .text.HAL_FLASH_OB_Launch,"ax",%progbits
|
|||
|
1304 .align 1
|
|||
|
1305 .global HAL_FLASH_OB_Launch
|
|||
|
1306 .syntax unified
|
|||
|
1307 .thumb
|
|||
|
1308 .thumb_func
|
|||
|
1309 .fpu fpv5-d16
|
|||
|
1311 HAL_FLASH_OB_Launch:
|
|||
|
1312 .LFB150:
|
|||
|
885:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** HAL_StatusTypeDef status;
|
|||
|
1313 .loc 1 885 1 is_stmt 1 view -0
|
|||
|
1314 .cfi_startproc
|
|||
|
1315 @ args = 0, pretend = 0, frame = 0
|
|||
|
1316 @ frame_needed = 0, uses_anonymous_args = 0
|
|||
|
1317 0000 08B5 push {r3, lr}
|
|||
|
1318 .LCFI7:
|
|||
|
1319 .cfi_def_cfa_offset 8
|
|||
|
1320 .cfi_offset 3, -8
|
|||
|
1321 .cfi_offset 14, -4
|
|||
|
886:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
1322 .loc 1 886 3 view .LVU367
|
|||
|
889:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
1323 .loc 1 889 3 view .LVU368
|
|||
|
889:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
1324 .loc 1 889 7 is_stmt 0 view .LVU369
|
|||
|
1325 0002 0121 movs r1, #1
|
|||
|
1326 0004 4CF25030 movw r0, #50000
|
|||
|
1327 0008 FFF7FEFF bl FLASH_CRC_WaitForLastOperation
|
|||
|
1328 .LVL78:
|
|||
|
889:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
1329 .loc 1 889 6 view .LVU370
|
|||
|
1330 000c 08B1 cbz r0, .L119
|
|||
|
891:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
1331 .loc 1 891 12 view .LVU371
|
|||
|
1332 000e 0120 movs r0, #1
|
|||
|
1333 .L116:
|
|||
|
1334 .LVL79:
|
|||
|
913:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 64
|
|||
|
|
|||
|
|
|||
|
1335 .loc 1 913 3 is_stmt 1 view .LVU372
|
|||
|
914:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
1336 .loc 1 914 1 is_stmt 0 view .LVU373
|
|||
|
1337 0010 08BD pop {r3, pc}
|
|||
|
1338 .LVL80:
|
|||
|
1339 .L119:
|
|||
|
901:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
1340 .loc 1 901 5 is_stmt 1 view .LVU374
|
|||
|
904:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** {
|
|||
|
1341 .loc 1 904 3 view .LVU375
|
|||
|
907:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c ****
|
|||
|
1342 .loc 1 907 5 view .LVU376
|
|||
|
1343 0012 054A ldr r2, .L120
|
|||
|
1344 0014 9369 ldr r3, [r2, #24]
|
|||
|
1345 0016 43F00203 orr r3, r3, #2
|
|||
|
1346 001a 9361 str r3, [r2, #24]
|
|||
|
910:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
1347 .loc 1 910 5 view .LVU377
|
|||
|
910:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
1348 .loc 1 910 14 is_stmt 0 view .LVU378
|
|||
|
1349 001c 4CF25030 movw r0, #50000
|
|||
|
1350 0020 FFF7FEFF bl FLASH_OB_WaitForLastOperation
|
|||
|
1351 .LVL81:
|
|||
|
910:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_flash.c **** }
|
|||
|
1352 .loc 1 910 14 view .LVU379
|
|||
|
1353 0024 F4E7 b .L116
|
|||
|
1354 .L121:
|
|||
|
1355 0026 00BF .align 2
|
|||
|
1356 .L120:
|
|||
|
1357 0028 00200052 .word 1375739904
|
|||
|
1358 .cfi_endproc
|
|||
|
1359 .LFE150:
|
|||
|
1361 .global pFlash
|
|||
|
1362 .section .bss.pFlash,"aw",%nobits
|
|||
|
1363 .align 2
|
|||
|
1364 .set .LANCHOR0,. + 0
|
|||
|
1367 pFlash:
|
|||
|
1368 0000 00000000 .space 28
|
|||
|
1368 00000000
|
|||
|
1368 00000000
|
|||
|
1368 00000000
|
|||
|
1368 00000000
|
|||
|
1369 .text
|
|||
|
1370 .Letext0:
|
|||
|
1371 .file 3 "/usr/arm-none-eabi/include/machine/_default_types.h"
|
|||
|
1372 .file 4 "/usr/arm-none-eabi/include/sys/_stdint.h"
|
|||
|
1373 .file 5 "Drivers/CMSIS/Device/ST/STM32H7xx/Include/stm32h750xx.h"
|
|||
|
1374 .file 6 "Drivers/CMSIS/Device/ST/STM32H7xx/Include/stm32h7xx.h"
|
|||
|
1375 .file 7 "Drivers/STM32H7xx_HAL_Driver/Inc/stm32h7xx_hal_def.h"
|
|||
|
1376 .file 8 "Drivers/STM32H7xx_HAL_Driver/Inc/stm32h7xx_hal_flash.h"
|
|||
|
1377 .file 9 "Drivers/STM32H7xx_HAL_Driver/Inc/stm32h7xx_hal.h"
|
|||
|
1378 .file 10 "Drivers/STM32H7xx_HAL_Driver/Inc/stm32h7xx_hal_flash_ex.h"
|
|||
|
ARM GAS /tmp/ccCw6Rev.s page 65
|
|||
|
|
|||
|
|
|||
|
DEFINED SYMBOLS
|
|||
|
*ABS*:0000000000000000 stm32h7xx_hal_flash.c
|
|||
|
/tmp/ccCw6Rev.s:17 .text.HAL_FLASH_EndOfOperationCallback:0000000000000000 $t
|
|||
|
/tmp/ccCw6Rev.s:25 .text.HAL_FLASH_EndOfOperationCallback:0000000000000000 HAL_FLASH_EndOfOperationCallback
|
|||
|
/tmp/ccCw6Rev.s:41 .text.HAL_FLASH_OperationErrorCallback:0000000000000000 $t
|
|||
|
/tmp/ccCw6Rev.s:48 .text.HAL_FLASH_OperationErrorCallback:0000000000000000 HAL_FLASH_OperationErrorCallback
|
|||
|
/tmp/ccCw6Rev.s:63 .text.HAL_FLASH_IRQHandler:0000000000000000 $t
|
|||
|
/tmp/ccCw6Rev.s:70 .text.HAL_FLASH_IRQHandler:0000000000000000 HAL_FLASH_IRQHandler
|
|||
|
/tmp/ccCw6Rev.s:309 .text.HAL_FLASH_IRQHandler:00000000000000f8 $d
|
|||
|
/tmp/ccCw6Rev.s:315 .text.HAL_FLASH_Unlock:0000000000000000 $t
|
|||
|
/tmp/ccCw6Rev.s:322 .text.HAL_FLASH_Unlock:0000000000000000 HAL_FLASH_Unlock
|
|||
|
/tmp/ccCw6Rev.s:363 .text.HAL_FLASH_Unlock:000000000000002c $d
|
|||
|
/tmp/ccCw6Rev.s:369 .text.HAL_FLASH_Lock:0000000000000000 $t
|
|||
|
/tmp/ccCw6Rev.s:376 .text.HAL_FLASH_Lock:0000000000000000 HAL_FLASH_Lock
|
|||
|
/tmp/ccCw6Rev.s:405 .text.HAL_FLASH_Lock:000000000000001c $d
|
|||
|
/tmp/ccCw6Rev.s:410 .text.HAL_FLASH_OB_Unlock:0000000000000000 $t
|
|||
|
/tmp/ccCw6Rev.s:417 .text.HAL_FLASH_OB_Unlock:0000000000000000 HAL_FLASH_OB_Unlock
|
|||
|
/tmp/ccCw6Rev.s:458 .text.HAL_FLASH_OB_Unlock:000000000000002c $d
|
|||
|
/tmp/ccCw6Rev.s:464 .text.HAL_FLASH_OB_Lock:0000000000000000 $t
|
|||
|
/tmp/ccCw6Rev.s:471 .text.HAL_FLASH_OB_Lock:0000000000000000 HAL_FLASH_OB_Lock
|
|||
|
/tmp/ccCw6Rev.s:500 .text.HAL_FLASH_OB_Lock:000000000000001c $d
|
|||
|
/tmp/ccCw6Rev.s:505 .text.HAL_FLASH_GetError:0000000000000000 $t
|
|||
|
/tmp/ccCw6Rev.s:512 .text.HAL_FLASH_GetError:0000000000000000 HAL_FLASH_GetError
|
|||
|
/tmp/ccCw6Rev.s:528 .text.HAL_FLASH_GetError:0000000000000008 $d
|
|||
|
/tmp/ccCw6Rev.s:533 .text.FLASH_WaitForLastOperation:0000000000000000 $t
|
|||
|
/tmp/ccCw6Rev.s:540 .text.FLASH_WaitForLastOperation:0000000000000000 FLASH_WaitForLastOperation
|
|||
|
/tmp/ccCw6Rev.s:661 .text.FLASH_WaitForLastOperation:0000000000000078 $d
|
|||
|
/tmp/ccCw6Rev.s:667 .text.HAL_FLASH_Program:0000000000000000 $t
|
|||
|
/tmp/ccCw6Rev.s:674 .text.HAL_FLASH_Program:0000000000000000 HAL_FLASH_Program
|
|||
|
/tmp/ccCw6Rev.s:863 .text.HAL_FLASH_Program:0000000000000080 $d
|
|||
|
/tmp/ccCw6Rev.s:869 .text.HAL_FLASH_Program_IT:0000000000000000 $t
|
|||
|
/tmp/ccCw6Rev.s:876 .text.HAL_FLASH_Program_IT:0000000000000000 HAL_FLASH_Program_IT
|
|||
|
/tmp/ccCw6Rev.s:1070 .text.HAL_FLASH_Program_IT:0000000000000080 $d
|
|||
|
/tmp/ccCw6Rev.s:1076 .text.FLASH_OB_WaitForLastOperation:0000000000000000 $t
|
|||
|
/tmp/ccCw6Rev.s:1083 .text.FLASH_OB_WaitForLastOperation:0000000000000000 FLASH_OB_WaitForLastOperation
|
|||
|
/tmp/ccCw6Rev.s:1172 .text.FLASH_OB_WaitForLastOperation:0000000000000058 $d
|
|||
|
/tmp/ccCw6Rev.s:1178 .text.FLASH_CRC_WaitForLastOperation:0000000000000000 $t
|
|||
|
/tmp/ccCw6Rev.s:1185 .text.FLASH_CRC_WaitForLastOperation:0000000000000000 FLASH_CRC_WaitForLastOperation
|
|||
|
/tmp/ccCw6Rev.s:1297 .text.FLASH_CRC_WaitForLastOperation:0000000000000068 $d
|
|||
|
/tmp/ccCw6Rev.s:1304 .text.HAL_FLASH_OB_Launch:0000000000000000 $t
|
|||
|
/tmp/ccCw6Rev.s:1311 .text.HAL_FLASH_OB_Launch:0000000000000000 HAL_FLASH_OB_Launch
|
|||
|
/tmp/ccCw6Rev.s:1357 .text.HAL_FLASH_OB_Launch:0000000000000028 $d
|
|||
|
/tmp/ccCw6Rev.s:1367 .bss.pFlash:0000000000000000 pFlash
|
|||
|
/tmp/ccCw6Rev.s:1363 .bss.pFlash:0000000000000000 $d
|
|||
|
|
|||
|
UNDEFINED SYMBOLS
|
|||
|
FLASH_Erase_Sector
|
|||
|
HAL_GetTick
|