STM32H750VB_Bootloader/build/stm32h7xx_hal_hsem.lst

928 lines
61 KiB
Plaintext
Raw Blame History

This file contains invisible Unicode characters

This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

ARM GAS /tmp/cc8V8hSh.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_hsem.c"
13 .text
14 .Ltext0:
15 .cfi_sections .debug_frame
16 .section .text.HAL_HSEM_Take,"ax",%progbits
17 .align 1
18 .global HAL_HSEM_Take
19 .arch armv7e-m
20 .syntax unified
21 .thumb
22 .thumb_func
23 .fpu fpv5-d16
25 HAL_HSEM_Take:
26 .LVL0:
27 .LFB141:
28 .file 1 "Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c"
1:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /**
2:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** ******************************************************************************
3:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @file stm32h7xx_hal_hsem.c
4:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @author MCD Application Team
5:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @brief HSEM HAL module driver.
6:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * This file provides firmware functions to manage the following
7:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * functionalities of the semaphore peripheral:
8:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * + Semaphore Take function (2-Step Procedure) , non blocking
9:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * + Semaphore FastTake function (1-Step Procedure) , non blocking
10:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * + Semaphore Status check
11:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * + Semaphore Clear Key Set and Get
12:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * + Release and release all functions
13:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * + Semaphore notification enabling and disabling and callnack functions
14:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * + IRQ handler management
15:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** *
16:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** *
17:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** @verbatim
18:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** ==============================================================================
19:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** ##### How to use this driver #####
20:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** ==============================================================================
21:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** [..]
22:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** (#)Take a semaphore In 2-Step mode Using function HAL_HSEM_Take. This function takes as param
23:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** (++) the semaphore ID from 0 to 31
24:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** (++) the process ID from 0 to 255
25:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** (#) Fast Take semaphore In 1-Step mode Using function HAL_HSEM_FastTake. This function takes
26:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** (++) the semaphore ID from 0_ID to 31. Note that the process ID value is implicitly assu
27:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** (#) Check if a semaphore is Taken using function HAL_HSEM_IsSemTaken. This function takes as
28:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** (++) the semaphore ID from 0_ID to 31
29:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** (++) It returns 1 if the given semaphore is taken otherwise (Free) zero
30:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** (#)Release a semaphore using function with HAL_HSEM_Release. This function takes as parameter
ARM GAS /tmp/cc8V8hSh.s page 2
31:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** (++) the semaphore ID from 0 to 31
32:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** (++) the process ID from 0 to 255:
33:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** (++) Note: If ProcessID and MasterID match, semaphore is freed, and an interrupt
34:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** may be generated when enabled (notification activated). If ProcessID or MasterID does not
35:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** semaphore remains taken (locked)
36:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
37:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** (#)Release all semaphores at once taken by a given Master using function HAL_HSEM_Release_All
38:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** This function takes as parameters :
39:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** (++) the Release Key (value from 0 to 0xFFFF) can be Set or Get respectively by
40:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** HAL_HSEM_SetClearKey() or HAL_HSEM_GetClearKey functions
41:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** (++) the Master ID:
42:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** (++) Note: If the Key and MasterID match, all semaphores taken by the given CPU that cor
43:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** to MasterID will be freed, and an interrupt may be generated when enabled (notification
44:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** Key or the MasterID doesn't match, semaphores remains taken (locked)
45:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
46:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** (#)Semaphores Release all key functions:
47:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** (++) HAL_HSEM_SetClearKey() to set semaphore release all Key
48:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** (++) HAL_HSEM_GetClearKey() to get release all Key
49:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** (#)Semaphores notification functions :
50:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** (++) HAL_HSEM_ActivateNotification to activate a notification callback on
51:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** a given semaphores Mask (bitfield). When one or more semaphores defined by the mask
52:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** the callback HAL_HSEM_FreeCallback will be asserted giving as parameters a mask of t
53:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** semaphores (bitfield).
54:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
55:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** (++) HAL_HSEM_DeactivateNotification to deactivate the notification of a given semaphores
56:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** (++) See the description of the macro __HAL_HSEM_SEMID_TO_MASK to check how to calculate a
57:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** Used by the notification functions
58:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** *** HSEM HAL driver macros list ***
59:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** =============================================
60:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** [..] Below the list of most used macros in HSEM HAL driver.
61:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
62:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** (+) __HAL_HSEM_SEMID_TO_MASK: Helper macro to convert a Semaphore ID to a Mask.
63:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** [..] Example of use :
64:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** [..] mask = __HAL_HSEM_SEMID_TO_MASK(8) | __HAL_HSEM_SEMID_TO_MASK(21) | __HAL_HSEM_SEMID_T
65:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** [..] All next macros take as parameter a semaphore Mask (bitfiled) that can be constructed us
66:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** (+) __HAL_HSEM_ENABLE_IT: Enable the specified semaphores Mask interrupts.
67:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** (+) __HAL_HSEM_DISABLE_IT: Disable the specified semaphores Mask interrupts.
68:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** (+) __HAL_HSEM_GET_IT: Checks whether the specified semaphore interrupt has occurred or not.
69:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** (+) __HAL_HSEM_GET_FLAG: Get the semaphores status release flags.
70:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** (+) __HAL_HSEM_CLEAR_FLAG: Clear the semaphores status release flags.
71:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
72:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** @endverbatim
73:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** ******************************************************************************
74:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @attention
75:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** *
76:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * <h2><center>&copy; Copyright (c) 2017 STMicroelectronics.
77:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * All rights reserved.</center></h2>
78:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** *
79:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * This software component is licensed by ST under BSD 3-Clause license,
80:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * the "License"; You may not use this file except in compliance with the
81:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * License. You may obtain a copy of the License at:
82:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * opensource.org/licenses/BSD-3-Clause
83:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** *
84:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** ******************************************************************************
85:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** */
86:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
87:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /* Includes ------------------------------------------------------------------*/
ARM GAS /tmp/cc8V8hSh.s page 3
88:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** #include "stm32h7xx_hal.h"
89:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
90:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /** @addtogroup STM32H7xx_HAL_Driver
91:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @{
92:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** */
93:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
94:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /** @defgroup HSEM HSEM
95:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @brief HSEM HAL module driver
96:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @{
97:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** */
98:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
99:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** #ifdef HAL_HSEM_MODULE_ENABLED
100:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
101:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /* Private typedef -----------------------------------------------------------*/
102:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /* Private define ------------------------------------------------------------*/
103:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** #if defined(DUAL_CORE)
104:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /** @defgroup HSEM_Private_Constants HSEM Private Constants
105:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @{
106:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** */
107:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
108:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** #ifndef HSEM_R_MASTERID
109:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** #define HSEM_R_MASTERID HSEM_R_COREID
110:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** #endif
111:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
112:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** #ifndef HSEM_RLR_MASTERID
113:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** #define HSEM_RLR_MASTERID HSEM_RLR_COREID
114:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** #endif
115:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
116:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** #ifndef HSEM_CR_MASTERID
117:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** #define HSEM_CR_MASTERID HSEM_CR_COREID
118:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** #endif
119:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
120:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /**
121:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @}
122:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** */
123:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** #endif /* DUAL_CORE */
124:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /* Private macro -------------------------------------------------------------*/
125:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /* Private variables ---------------------------------------------------------*/
126:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /* Private function prototypes -----------------------------------------------*/
127:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /* Private functions ---------------------------------------------------------*/
128:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /* Exported functions --------------------------------------------------------*/
129:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
130:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /** @defgroup HSEM_Exported_Functions HSEM Exported Functions
131:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @{
132:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** */
133:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
134:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /** @defgroup HSEM_Exported_Functions_Group1 Take and Release functions
135:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @brief HSEM Take and Release functions
136:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** *
137:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** @verbatim
138:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** ==============================================================================
139:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** ##### HSEM Take and Release functions #####
140:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** ==============================================================================
141:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** [..] This section provides functions allowing to:
142:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** (+) Take a semaphore with 2 Step method
143:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** (+) Fast Take a semaphore with 1 Step method
144:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** (+) Check semaphore state Taken or not
ARM GAS /tmp/cc8V8hSh.s page 4
145:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** (+) Release a semaphore
146:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** (+) Release all semaphore at once
147:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
148:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** @endverbatim
149:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @{
150:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** */
151:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
152:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
153:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /**
154:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @brief Take a semaphore in 2 Step mode.
155:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @param SemID: semaphore ID from 0 to 31
156:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @param ProcessID: Process ID from 0 to 255
157:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @retval HAL status
158:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** */
159:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** HAL_StatusTypeDef HAL_HSEM_Take(uint32_t SemID, uint32_t ProcessID)
160:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** {
29 .loc 1 160 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.
161:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /* Check the parameters */
162:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** assert_param(IS_HSEM_SEMID(SemID));
34 .loc 1 162 3 view .LVU1
163:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** assert_param(IS_HSEM_PROCESSID(ProcessID));
35 .loc 1 163 3 view .LVU2
164:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
165:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** #if USE_MULTI_CORE_SHARED_CODE != 0U
166:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /* First step write R register with MasterID, processID and take bit=1*/
167:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** HSEM->R[SemID] = ((ProcessID & HSEM_R_PROCID) | ((HAL_GetCurrentCPUID() << POSITION_VAL(HSEM_R_MA
168:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
169:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /* second step : read the R register . Take achieved if MasterID and processID match and take bit
170:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** if (HSEM->R[SemID] == ((ProcessID & HSEM_R_PROCID) | ((HAL_GetCurrentCPUID() << POSITION_VAL(HSEM
171:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** {
172:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /*take success when MasterID and ProcessID match and take bit set*/
173:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** return HAL_OK;
174:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** }
175:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** #else
176:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /* First step write R register with MasterID, processID and take bit=1*/
177:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** HSEM->R[SemID] = (ProcessID | HSEM_CR_COREID_CURRENT | HSEM_R_LOCK);
36 .loc 1 177 3 view .LVU3
37 .loc 1 177 56 is_stmt 0 view .LVU4
38 0000 064B ldr r3, .L4
39 0002 0B43 orrs r3, r3, r1
40 .loc 1 177 18 view .LVU5
41 0004 064A ldr r2, .L4+4
42 0006 42F82030 str r3, [r2, r0, lsl #2]
178:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
179:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /* second step : read the R register . Take achieved if MasterID and processID match and take bit
180:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** if (HSEM->R[SemID] == (ProcessID | HSEM_CR_COREID_CURRENT | HSEM_R_LOCK))
43 .loc 1 180 3 is_stmt 1 view .LVU6
44 .loc 1 180 14 is_stmt 0 view .LVU7
45 000a 52F82020 ldr r2, [r2, r0, lsl #2]
46 .loc 1 180 6 view .LVU8
47 000e 9342 cmp r3, r2
48 0010 01D0 beq .L3
181:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** {
ARM GAS /tmp/cc8V8hSh.s page 5
182:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /*take success when MasterID and ProcessID match and take bit set*/
183:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** return HAL_OK;
184:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** }
185:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** #endif
186:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
187:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /* Semaphore take fails*/
188:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** return HAL_ERROR;
49 .loc 1 188 10 view .LVU9
50 0012 0120 movs r0, #1
51 .LVL1:
52 .loc 1 188 10 view .LVU10
53 0014 7047 bx lr
54 .LVL2:
55 .L3:
183:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** }
56 .loc 1 183 12 view .LVU11
57 0016 0020 movs r0, #0
58 .LVL3:
189:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** }
59 .loc 1 189 1 view .LVU12
60 0018 7047 bx lr
61 .L5:
62 001a 00BF .align 2
63 .L4:
64 001c 00030080 .word -2147482880
65 0020 00640258 .word 1476551680
66 .cfi_endproc
67 .LFE141:
69 .section .text.HAL_HSEM_FastTake,"ax",%progbits
70 .align 1
71 .global HAL_HSEM_FastTake
72 .syntax unified
73 .thumb
74 .thumb_func
75 .fpu fpv5-d16
77 HAL_HSEM_FastTake:
78 .LVL4:
79 .LFB142:
190:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
191:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /**
192:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @brief Fast Take a semaphore with 1 Step mode.
193:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @param SemID: semaphore ID from 0 to 31
194:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @retval HAL status
195:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** */
196:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** HAL_StatusTypeDef HAL_HSEM_FastTake(uint32_t SemID)
197:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** {
80 .loc 1 197 1 is_stmt 1 view -0
81 .cfi_startproc
82 @ args = 0, pretend = 0, frame = 0
83 @ frame_needed = 0, uses_anonymous_args = 0
84 @ link register save eliminated.
198:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /* Check the parameters */
199:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** assert_param(IS_HSEM_SEMID(SemID));
85 .loc 1 199 3 view .LVU14
200:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
201:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** #if USE_MULTI_CORE_SHARED_CODE != 0U
202:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /* Read the RLR register to take the semaphore */
ARM GAS /tmp/cc8V8hSh.s page 6
203:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** if (HSEM->RLR[SemID] == (((HAL_GetCurrentCPUID() << POSITION_VAL(HSEM_R_MASTERID)) & HSEM_RLR_MAS
204:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** {
205:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /*take success when MasterID match and take bit set*/
206:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** return HAL_OK;
207:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** }
208:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** #else
209:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /* Read the RLR register to take the semaphore */
210:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** if (HSEM->RLR[SemID] == (HSEM_CR_COREID_CURRENT | HSEM_RLR_LOCK))
86 .loc 1 210 3 view .LVU15
87 .loc 1 210 16 is_stmt 0 view .LVU16
88 0000 2030 adds r0, r0, #32
89 .LVL5:
90 .loc 1 210 16 view .LVU17
91 0002 054B ldr r3, .L9
92 0004 53F82020 ldr r2, [r3, r0, lsl #2]
93 .loc 1 210 6 view .LVU18
94 0008 044B ldr r3, .L9+4
95 000a 9A42 cmp r2, r3
96 000c 01D0 beq .L8
211:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** {
212:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /*take success when MasterID match and take bit set*/
213:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** return HAL_OK;
214:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** }
215:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** #endif
216:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
217:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /* Semaphore take fails */
218:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** return HAL_ERROR;
97 .loc 1 218 10 view .LVU19
98 000e 0120 movs r0, #1
99 .LVL6:
100 .loc 1 218 10 view .LVU20
101 0010 7047 bx lr
102 .L8:
213:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** }
103 .loc 1 213 12 view .LVU21
104 0012 0020 movs r0, #0
219:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** }
105 .loc 1 219 1 view .LVU22
106 0014 7047 bx lr
107 .L10:
108 0016 00BF .align 2
109 .L9:
110 0018 00640258 .word 1476551680
111 001c 00030080 .word -2147482880
112 .cfi_endproc
113 .LFE142:
115 .section .text.HAL_HSEM_IsSemTaken,"ax",%progbits
116 .align 1
117 .global HAL_HSEM_IsSemTaken
118 .syntax unified
119 .thumb
120 .thumb_func
121 .fpu fpv5-d16
123 HAL_HSEM_IsSemTaken:
124 .LVL7:
125 .LFB143:
220:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /**
ARM GAS /tmp/cc8V8hSh.s page 7
221:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @brief Check semaphore state Taken or not.
222:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @param SemID: semaphore ID
223:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @retval HAL HSEM state
224:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** */
225:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** uint32_t HAL_HSEM_IsSemTaken(uint32_t SemID)
226:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** {
126 .loc 1 226 1 is_stmt 1 view -0
127 .cfi_startproc
128 @ args = 0, pretend = 0, frame = 0
129 @ frame_needed = 0, uses_anonymous_args = 0
130 @ link register save eliminated.
227:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** return (((HSEM->R[SemID] & HSEM_R_LOCK) != 0U) ? 1UL : 0UL);
131 .loc 1 227 3 view .LVU24
132 .loc 1 227 20 is_stmt 0 view .LVU25
133 0000 044B ldr r3, .L15
134 0002 53F82030 ldr r3, [r3, r0, lsl #2]
135 .loc 1 227 56 view .LVU26
136 0006 002B cmp r3, #0
137 0008 01DB blt .L14
138 000a 0020 movs r0, #0
139 .LVL8:
228:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** }
140 .loc 1 228 1 view .LVU27
141 000c 7047 bx lr
142 .LVL9:
143 .L14:
227:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** return (((HSEM->R[SemID] & HSEM_R_LOCK) != 0U) ? 1UL : 0UL);
144 .loc 1 227 56 view .LVU28
145 000e 0120 movs r0, #1
146 .LVL10:
227:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** return (((HSEM->R[SemID] & HSEM_R_LOCK) != 0U) ? 1UL : 0UL);
147 .loc 1 227 56 view .LVU29
148 0010 7047 bx lr
149 .L16:
150 0012 00BF .align 2
151 .L15:
152 0014 00640258 .word 1476551680
153 .cfi_endproc
154 .LFE143:
156 .section .text.HAL_HSEM_Release,"ax",%progbits
157 .align 1
158 .global HAL_HSEM_Release
159 .syntax unified
160 .thumb
161 .thumb_func
162 .fpu fpv5-d16
164 HAL_HSEM_Release:
165 .LVL11:
166 .LFB144:
229:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
230:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
231:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /**
232:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @brief Release a semaphore.
233:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @param SemID: semaphore ID from 0 to 31
234:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @param ProcessID: Process ID from 0 to 255
235:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @retval None
236:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** */
ARM GAS /tmp/cc8V8hSh.s page 8
237:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** void HAL_HSEM_Release(uint32_t SemID, uint32_t ProcessID)
238:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** {
167 .loc 1 238 1 is_stmt 1 view -0
168 .cfi_startproc
169 @ args = 0, pretend = 0, frame = 0
170 @ frame_needed = 0, uses_anonymous_args = 0
171 @ link register save eliminated.
239:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /* Check the parameters */
240:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** assert_param(IS_HSEM_SEMID(SemID));
172 .loc 1 240 3 view .LVU31
241:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** assert_param(IS_HSEM_PROCESSID(ProcessID));
173 .loc 1 241 3 view .LVU32
242:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
243:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /* Clear the semaphore by writing to the R register : the MasterID , the processID and take bit =
244:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** #if USE_MULTI_CORE_SHARED_CODE != 0U
245:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** HSEM->R[SemID] = (ProcessID | ((HAL_GetCurrentCPUID() << POSITION_VAL(HSEM_R_MASTERID)) & HSEM_R_
246:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** #else
247:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** HSEM->R[SemID] = (ProcessID | HSEM_CR_COREID_CURRENT);
174 .loc 1 247 3 view .LVU33
175 .loc 1 247 31 is_stmt 0 view .LVU34
176 0000 41F44071 orr r1, r1, #768
177 .LVL12:
178 .loc 1 247 18 view .LVU35
179 0004 014B ldr r3, .L18
180 0006 43F82010 str r1, [r3, r0, lsl #2]
248:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** #endif
249:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
250:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** }
181 .loc 1 250 1 view .LVU36
182 000a 7047 bx lr
183 .L19:
184 .align 2
185 .L18:
186 000c 00640258 .word 1476551680
187 .cfi_endproc
188 .LFE144:
190 .section .text.HAL_HSEM_ReleaseAll,"ax",%progbits
191 .align 1
192 .global HAL_HSEM_ReleaseAll
193 .syntax unified
194 .thumb
195 .thumb_func
196 .fpu fpv5-d16
198 HAL_HSEM_ReleaseAll:
199 .LVL13:
200 .LFB145:
251:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
252:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /**
253:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @brief Release All semaphore used by a given Master .
254:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @param Key: Semaphore Key , value from 0 to 0xFFFF
255:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @param CoreID: CoreID of the CPU that is using semaphores to be released
256:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @retval None
257:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** */
258:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** void HAL_HSEM_ReleaseAll(uint32_t Key, uint32_t CoreID)
259:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** {
201 .loc 1 259 1 is_stmt 1 view -0
202 .cfi_startproc
ARM GAS /tmp/cc8V8hSh.s page 9
203 @ args = 0, pretend = 0, frame = 0
204 @ frame_needed = 0, uses_anonymous_args = 0
205 @ link register save eliminated.
260:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** assert_param(IS_HSEM_KEY(Key));
206 .loc 1 260 3 view .LVU38
261:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** assert_param(IS_HSEM_COREID(CoreID));
207 .loc 1 261 3 view .LVU39
262:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
263:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** HSEM->CR = ((Key << HSEM_CR_KEY_Pos) | (CoreID << HSEM_CR_COREID_Pos));
208 .loc 1 263 3 view .LVU40
209 .loc 1 263 50 is_stmt 0 view .LVU41
210 0000 0902 lsls r1, r1, #8
211 .LVL14:
212 .loc 1 263 40 view .LVU42
213 0002 41EA0041 orr r1, r1, r0, lsl #16
214 .loc 1 263 12 view .LVU43
215 0006 024B ldr r3, .L21
216 0008 C3F84011 str r1, [r3, #320]
264:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** }
217 .loc 1 264 1 view .LVU44
218 000c 7047 bx lr
219 .L22:
220 000e 00BF .align 2
221 .L21:
222 0010 00640258 .word 1476551680
223 .cfi_endproc
224 .LFE145:
226 .section .text.HAL_HSEM_SetClearKey,"ax",%progbits
227 .align 1
228 .global HAL_HSEM_SetClearKey
229 .syntax unified
230 .thumb
231 .thumb_func
232 .fpu fpv5-d16
234 HAL_HSEM_SetClearKey:
235 .LVL15:
236 .LFB146:
265:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
266:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /**
267:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @}
268:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** */
269:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
270:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /** @defgroup HSEM_Exported_Functions_Group2 HSEM Set and Get Key functions
271:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @brief HSEM Set and Get Key functions.
272:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** *
273:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** @verbatim
274:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** ==============================================================================
275:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** ##### HSEM Set and Get Key functions #####
276:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** ==============================================================================
277:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** [..] This section provides functions allowing to:
278:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** (+) Set semaphore Key
279:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** (+) Get semaphore Key
280:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** @endverbatim
281:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
282:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @{
283:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** */
284:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
ARM GAS /tmp/cc8V8hSh.s page 10
285:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /**
286:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @brief Set semaphore Key .
287:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @param Key: Semaphore Key , value from 0 to 0xFFFF
288:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @retval None
289:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** */
290:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** void HAL_HSEM_SetClearKey(uint32_t Key)
291:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** {
237 .loc 1 291 1 is_stmt 1 view -0
238 .cfi_startproc
239 @ args = 0, pretend = 0, frame = 0
240 @ frame_needed = 0, uses_anonymous_args = 0
241 @ link register save eliminated.
292:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** assert_param(IS_HSEM_KEY(Key));
242 .loc 1 292 3 view .LVU46
293:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
294:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** MODIFY_REG(HSEM->KEYR, HSEM_KEYR_KEY, (Key << HSEM_KEYR_KEY_Pos));
243 .loc 1 294 3 view .LVU47
244 0000 044A ldr r2, .L24
245 0002 D2F84431 ldr r3, [r2, #324]
246 0006 9BB2 uxth r3, r3
247 0008 43EA0043 orr r3, r3, r0, lsl #16
248 000c C2F84431 str r3, [r2, #324]
295:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
296:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** }
249 .loc 1 296 1 is_stmt 0 view .LVU48
250 0010 7047 bx lr
251 .L25:
252 0012 00BF .align 2
253 .L24:
254 0014 00640258 .word 1476551680
255 .cfi_endproc
256 .LFE146:
258 .section .text.HAL_HSEM_GetClearKey,"ax",%progbits
259 .align 1
260 .global HAL_HSEM_GetClearKey
261 .syntax unified
262 .thumb
263 .thumb_func
264 .fpu fpv5-d16
266 HAL_HSEM_GetClearKey:
267 .LFB147:
297:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
298:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /**
299:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @brief Get semaphore Key .
300:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @retval Semaphore Key , value from 0 to 0xFFFF
301:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** */
302:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** uint32_t HAL_HSEM_GetClearKey(void)
303:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** {
268 .loc 1 303 1 is_stmt 1 view -0
269 .cfi_startproc
270 @ args = 0, pretend = 0, frame = 0
271 @ frame_needed = 0, uses_anonymous_args = 0
272 @ link register save eliminated.
304:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** return (HSEM->KEYR >> HSEM_KEYR_KEY_Pos);
273 .loc 1 304 3 view .LVU50
274 .loc 1 304 15 is_stmt 0 view .LVU51
275 0000 024B ldr r3, .L27
ARM GAS /tmp/cc8V8hSh.s page 11
276 0002 D3F84401 ldr r0, [r3, #324]
305:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** }
277 .loc 1 305 1 view .LVU52
278 0006 000C lsrs r0, r0, #16
279 0008 7047 bx lr
280 .L28:
281 000a 00BF .align 2
282 .L27:
283 000c 00640258 .word 1476551680
284 .cfi_endproc
285 .LFE147:
287 .section .text.HAL_HSEM_ActivateNotification,"ax",%progbits
288 .align 1
289 .global HAL_HSEM_ActivateNotification
290 .syntax unified
291 .thumb
292 .thumb_func
293 .fpu fpv5-d16
295 HAL_HSEM_ActivateNotification:
296 .LVL16:
297 .LFB148:
306:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
307:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /**
308:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @}
309:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** */
310:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
311:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /** @defgroup HSEM_Exported_Functions_Group3 HSEM IRQ handler management
312:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @brief HSEM Notification functions.
313:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** *
314:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** @verbatim
315:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** ==============================================================================
316:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** ##### HSEM IRQ handler management and Notification functions #####
317:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** ==============================================================================
318:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** [..] This section provides HSEM IRQ handler and Notification function.
319:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
320:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** @endverbatim
321:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @{
322:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** */
323:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
324:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /**
325:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @brief Activate Semaphore release Notification for a given Semaphores Mask .
326:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @param SemMask: Mask of Released semaphores
327:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @retval Semaphore Key
328:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** */
329:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** void HAL_HSEM_ActivateNotification(uint32_t SemMask)
330:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** {
298 .loc 1 330 1 is_stmt 1 view -0
299 .cfi_startproc
300 @ args = 0, pretend = 0, frame = 0
301 @ frame_needed = 0, uses_anonymous_args = 0
302 @ link register save eliminated.
331:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** #if USE_MULTI_CORE_SHARED_CODE != 0U
332:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /*enable the semaphore mask interrupts */
333:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** if (HAL_GetCurrentCPUID() == HSEM_CPU1_COREID)
334:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** {
335:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /*Use interrupt line 0 for CPU1 Master */
336:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** HSEM->C1IER |= SemMask;
ARM GAS /tmp/cc8V8hSh.s page 12
337:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** }
338:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** else /* HSEM_CPU2_COREID */
339:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** {
340:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /*Use interrupt line 1 for CPU2 Master*/
341:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** HSEM->C2IER |= SemMask;
342:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** }
343:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** #else
344:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** HSEM_COMMON->IER |= SemMask;
303 .loc 1 344 3 view .LVU54
304 .loc 1 344 20 is_stmt 0 view .LVU55
305 0000 024A ldr r2, .L30
306 0002 1368 ldr r3, [r2]
307 0004 0343 orrs r3, r3, r0
308 0006 1360 str r3, [r2]
345:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** #endif
346:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** }
309 .loc 1 346 1 view .LVU56
310 0008 7047 bx lr
311 .L31:
312 000a 00BF .align 2
313 .L30:
314 000c 00650258 .word 1476551936
315 .cfi_endproc
316 .LFE148:
318 .section .text.HAL_HSEM_DeactivateNotification,"ax",%progbits
319 .align 1
320 .global HAL_HSEM_DeactivateNotification
321 .syntax unified
322 .thumb
323 .thumb_func
324 .fpu fpv5-d16
326 HAL_HSEM_DeactivateNotification:
327 .LVL17:
328 .LFB149:
347:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
348:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /**
349:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @brief Deactivate Semaphore release Notification for a given Semaphores Mask .
350:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @param SemMask: Mask of Released semaphores
351:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @retval Semaphore Key
352:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** */
353:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** void HAL_HSEM_DeactivateNotification(uint32_t SemMask)
354:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** {
329 .loc 1 354 1 is_stmt 1 view -0
330 .cfi_startproc
331 @ args = 0, pretend = 0, frame = 0
332 @ frame_needed = 0, uses_anonymous_args = 0
333 @ link register save eliminated.
355:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** #if USE_MULTI_CORE_SHARED_CODE != 0U
356:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /*enable the semaphore mask interrupts */
357:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** if (HAL_GetCurrentCPUID() == HSEM_CPU1_COREID)
358:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** {
359:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /*Use interrupt line 0 for CPU1 Master */
360:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** HSEM->C1IER &= ~SemMask;
361:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** }
362:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** else /* HSEM_CPU2_COREID */
363:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** {
364:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /*Use interrupt line 1 for CPU2 Master*/
ARM GAS /tmp/cc8V8hSh.s page 13
365:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** HSEM->C2IER &= ~SemMask;
366:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** }
367:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** #else
368:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** HSEM_COMMON->IER &= ~SemMask;
334 .loc 1 368 3 view .LVU58
335 .loc 1 368 20 is_stmt 0 view .LVU59
336 0000 024A ldr r2, .L33
337 0002 1368 ldr r3, [r2]
338 0004 23EA0003 bic r3, r3, r0
339 0008 1360 str r3, [r2]
369:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** #endif
370:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** }
340 .loc 1 370 1 view .LVU60
341 000a 7047 bx lr
342 .L34:
343 .align 2
344 .L33:
345 000c 00650258 .word 1476551936
346 .cfi_endproc
347 .LFE149:
349 .section .text.HAL_HSEM_FreeCallback,"ax",%progbits
350 .align 1
351 .weak HAL_HSEM_FreeCallback
352 .syntax unified
353 .thumb
354 .thumb_func
355 .fpu fpv5-d16
357 HAL_HSEM_FreeCallback:
358 .LVL18:
359 .LFB151:
371:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
372:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /**
373:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @brief This function handles HSEM interrupt request
374:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @retval None
375:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** */
376:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** void HAL_HSEM_IRQHandler(void)
377:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** {
378:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** uint32_t statusreg;
379:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** #if USE_MULTI_CORE_SHARED_CODE != 0U
380:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** if (HAL_GetCurrentCPUID() == HSEM_CPU1_COREID)
381:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** {
382:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /* Get the list of masked freed semaphores*/
383:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** statusreg = HSEM->C1MISR; /*Use interrupt line 0 for CPU1 Master*/
384:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
385:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /*Disable Interrupts*/
386:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** HSEM->C1IER &= ~((uint32_t)statusreg);
387:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
388:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /*Clear Flags*/
389:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** HSEM->C1ICR = ((uint32_t)statusreg);
390:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** }
391:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** else /* HSEM_CPU2_COREID */
392:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** {
393:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /* Get the list of masked freed semaphores*/
394:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** statusreg = HSEM->C2MISR;/*Use interrupt line 1 for CPU2 Master*/
395:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
396:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /*Disable Interrupts*/
397:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** HSEM->C2IER &= ~((uint32_t)statusreg);
ARM GAS /tmp/cc8V8hSh.s page 14
398:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
399:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /*Clear Flags*/
400:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** HSEM->C2ICR = ((uint32_t)statusreg);
401:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** }
402:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** #else
403:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /* Get the list of masked freed semaphores*/
404:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** statusreg = HSEM_COMMON->MISR;
405:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
406:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /*Disable Interrupts*/
407:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** HSEM_COMMON->IER &= ~((uint32_t)statusreg);
408:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
409:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /*Clear Flags*/
410:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** HSEM_COMMON->ICR = ((uint32_t)statusreg);
411:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
412:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** #endif
413:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /* Call FreeCallback */
414:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** HAL_HSEM_FreeCallback(statusreg);
415:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** }
416:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
417:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /**
418:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @brief Semaphore Released Callback.
419:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @param SemMask: Mask of Released semaphores
420:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** * @retval None
421:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** */
422:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** __weak void HAL_HSEM_FreeCallback(uint32_t SemMask)
423:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** {
360 .loc 1 423 1 is_stmt 1 view -0
361 .cfi_startproc
362 @ args = 0, pretend = 0, frame = 0
363 @ frame_needed = 0, uses_anonymous_args = 0
364 @ link register save eliminated.
424:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /* Prevent unused argument(s) compilation warning */
425:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** UNUSED(SemMask);
365 .loc 1 425 3 view .LVU62
426:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
427:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** /* NOTE : This function should not be modified, when the callback is needed,
428:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** the HAL_HSEM_FreeCallback can be implemented in the user file
429:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** */
430:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** }
366 .loc 1 430 1 is_stmt 0 view .LVU63
367 0000 7047 bx lr
368 .cfi_endproc
369 .LFE151:
371 .section .text.HAL_HSEM_IRQHandler,"ax",%progbits
372 .align 1
373 .global HAL_HSEM_IRQHandler
374 .syntax unified
375 .thumb
376 .thumb_func
377 .fpu fpv5-d16
379 HAL_HSEM_IRQHandler:
380 .LFB150:
377:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** uint32_t statusreg;
381 .loc 1 377 1 is_stmt 1 view -0
382 .cfi_startproc
383 @ args = 0, pretend = 0, frame = 0
384 @ frame_needed = 0, uses_anonymous_args = 0
ARM GAS /tmp/cc8V8hSh.s page 15
385 0000 08B5 push {r3, lr}
386 .LCFI0:
387 .cfi_def_cfa_offset 8
388 .cfi_offset 3, -8
389 .cfi_offset 14, -4
378:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** #if USE_MULTI_CORE_SHARED_CODE != 0U
390 .loc 1 378 3 view .LVU65
404:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
391 .loc 1 404 3 view .LVU66
404:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
392 .loc 1 404 13 is_stmt 0 view .LVU67
393 0002 054B ldr r3, .L38
394 0004 D868 ldr r0, [r3, #12]
395 .LVL19:
407:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
396 .loc 1 407 3 is_stmt 1 view .LVU68
407:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
397 .loc 1 407 20 is_stmt 0 view .LVU69
398 0006 1A68 ldr r2, [r3]
399 0008 22EA0002 bic r2, r2, r0
400 000c 1A60 str r2, [r3]
410:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
401 .loc 1 410 3 is_stmt 1 view .LVU70
410:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
402 .loc 1 410 20 is_stmt 0 view .LVU71
403 000e 5860 str r0, [r3, #4]
414:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c **** }
404 .loc 1 414 3 is_stmt 1 view .LVU72
405 0010 FFF7FEFF bl HAL_HSEM_FreeCallback
406 .LVL20:
415:Drivers/STM32H7xx_HAL_Driver/Src/stm32h7xx_hal_hsem.c ****
407 .loc 1 415 1 is_stmt 0 view .LVU73
408 0014 08BD pop {r3, pc}
409 .L39:
410 0016 00BF .align 2
411 .L38:
412 0018 00650258 .word 1476551936
413 .cfi_endproc
414 .LFE150:
416 .text
417 .Letext0:
418 .file 2 "/usr/arm-none-eabi/include/machine/_default_types.h"
419 .file 3 "/usr/arm-none-eabi/include/sys/_stdint.h"
420 .file 4 "Drivers/CMSIS/Device/ST/STM32H7xx/Include/stm32h750xx.h"
421 .file 5 "Drivers/STM32H7xx_HAL_Driver/Inc/stm32h7xx_hal_def.h"
ARM GAS /tmp/cc8V8hSh.s page 16
DEFINED SYMBOLS
*ABS*:0000000000000000 stm32h7xx_hal_hsem.c
/tmp/cc8V8hSh.s:17 .text.HAL_HSEM_Take:0000000000000000 $t
/tmp/cc8V8hSh.s:25 .text.HAL_HSEM_Take:0000000000000000 HAL_HSEM_Take
/tmp/cc8V8hSh.s:64 .text.HAL_HSEM_Take:000000000000001c $d
/tmp/cc8V8hSh.s:70 .text.HAL_HSEM_FastTake:0000000000000000 $t
/tmp/cc8V8hSh.s:77 .text.HAL_HSEM_FastTake:0000000000000000 HAL_HSEM_FastTake
/tmp/cc8V8hSh.s:110 .text.HAL_HSEM_FastTake:0000000000000018 $d
/tmp/cc8V8hSh.s:116 .text.HAL_HSEM_IsSemTaken:0000000000000000 $t
/tmp/cc8V8hSh.s:123 .text.HAL_HSEM_IsSemTaken:0000000000000000 HAL_HSEM_IsSemTaken
/tmp/cc8V8hSh.s:152 .text.HAL_HSEM_IsSemTaken:0000000000000014 $d
/tmp/cc8V8hSh.s:157 .text.HAL_HSEM_Release:0000000000000000 $t
/tmp/cc8V8hSh.s:164 .text.HAL_HSEM_Release:0000000000000000 HAL_HSEM_Release
/tmp/cc8V8hSh.s:186 .text.HAL_HSEM_Release:000000000000000c $d
/tmp/cc8V8hSh.s:191 .text.HAL_HSEM_ReleaseAll:0000000000000000 $t
/tmp/cc8V8hSh.s:198 .text.HAL_HSEM_ReleaseAll:0000000000000000 HAL_HSEM_ReleaseAll
/tmp/cc8V8hSh.s:222 .text.HAL_HSEM_ReleaseAll:0000000000000010 $d
/tmp/cc8V8hSh.s:227 .text.HAL_HSEM_SetClearKey:0000000000000000 $t
/tmp/cc8V8hSh.s:234 .text.HAL_HSEM_SetClearKey:0000000000000000 HAL_HSEM_SetClearKey
/tmp/cc8V8hSh.s:254 .text.HAL_HSEM_SetClearKey:0000000000000014 $d
/tmp/cc8V8hSh.s:259 .text.HAL_HSEM_GetClearKey:0000000000000000 $t
/tmp/cc8V8hSh.s:266 .text.HAL_HSEM_GetClearKey:0000000000000000 HAL_HSEM_GetClearKey
/tmp/cc8V8hSh.s:283 .text.HAL_HSEM_GetClearKey:000000000000000c $d
/tmp/cc8V8hSh.s:288 .text.HAL_HSEM_ActivateNotification:0000000000000000 $t
/tmp/cc8V8hSh.s:295 .text.HAL_HSEM_ActivateNotification:0000000000000000 HAL_HSEM_ActivateNotification
/tmp/cc8V8hSh.s:314 .text.HAL_HSEM_ActivateNotification:000000000000000c $d
/tmp/cc8V8hSh.s:319 .text.HAL_HSEM_DeactivateNotification:0000000000000000 $t
/tmp/cc8V8hSh.s:326 .text.HAL_HSEM_DeactivateNotification:0000000000000000 HAL_HSEM_DeactivateNotification
/tmp/cc8V8hSh.s:345 .text.HAL_HSEM_DeactivateNotification:000000000000000c $d
/tmp/cc8V8hSh.s:350 .text.HAL_HSEM_FreeCallback:0000000000000000 $t
/tmp/cc8V8hSh.s:357 .text.HAL_HSEM_FreeCallback:0000000000000000 HAL_HSEM_FreeCallback
/tmp/cc8V8hSh.s:372 .text.HAL_HSEM_IRQHandler:0000000000000000 $t
/tmp/cc8V8hSh.s:379 .text.HAL_HSEM_IRQHandler:0000000000000000 HAL_HSEM_IRQHandler
/tmp/cc8V8hSh.s:412 .text.HAL_HSEM_IRQHandler:0000000000000018 $d
NO UNDEFINED SYMBOLS