ARM GAS /tmp/ccj1aKCo.s page 1
1 .cpu cortex-m4
2 .arch armv7e-m
3 .fpu fpv4-sp-d16
4 .eabi_attribute 27, 1
5 .eabi_attribute 28, 1
6 .eabi_attribute 20, 1
7 .eabi_attribute 21, 1
8 .eabi_attribute 23, 3
9 .eabi_attribute 24, 1
10 .eabi_attribute 25, 1
11 .eabi_attribute 26, 1
12 .eabi_attribute 30, 1
13 .eabi_attribute 34, 1
14 .eabi_attribute 18, 4
15 .file "stm32f3xx_hal_can.c"
16 .text
17 .Ltext0:
18 .cfi_sections .debug_frame
19 .file 1 "Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c"
20 .section .text.HAL_CAN_MspInit,"ax",%progbits
21 .align 1
22 .weak HAL_CAN_MspInit
23 .syntax unified
24 .thumb
25 .thumb_func
27 HAL_CAN_MspInit:
28 .LVL0:
29 .LFB132:
1:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /**
2:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ******************************************************************************
3:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @file stm32f3xx_hal_can.c
4:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @author MCD Application Team
5:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @brief CAN HAL module driver.
6:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * This file provides firmware functions to manage the following
7:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * functionalities of the Controller Area Network (CAN) peripheral:
8:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * + Initialization and de-initialization functions
9:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * + Configuration functions
10:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * + Control functions
11:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * + Interrupts management
12:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * + Callbacks functions
13:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * + Peripheral State and Error functions
14:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** *
15:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** @verbatim
16:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ==============================================================================
17:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ##### How to use this driver #####
18:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ==============================================================================
19:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** [..]
20:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (#) Initialize the CAN low level resources by implementing the
21:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_MspInit():
22:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (++) Enable the CAN interface clock using __HAL_RCC_CANx_CLK_ENABLE()
23:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (++) Configure CAN pins
24:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+++) Enable the clock for the CAN GPIOs
25:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+++) Configure CAN pins as alternate function open-drain
26:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (++) In case of using interrupts (e.g. HAL_CAN_ActivateNotification())
27:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+++) Configure the CAN interrupt priority using
28:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_NVIC_SetPriority()
29:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+++) Enable the CAN IRQ handler using HAL_NVIC_EnableIRQ()
ARM GAS /tmp/ccj1aKCo.s page 2
30:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+++) In CAN IRQ handler, call HAL_CAN_IRQHandler()
31:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
32:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (#) Initialize the CAN peripheral using HAL_CAN_Init() function. This
33:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** function resorts to HAL_CAN_MspInit() for low-level initialization.
34:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
35:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (#) Configure the reception filters using the following configuration
36:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** functions:
37:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (++) HAL_CAN_ConfigFilter()
38:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
39:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (#) Start the CAN module using HAL_CAN_Start() function. At this level
40:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** the node is active on the bus: it receive messages, and can send
41:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** messages.
42:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
43:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (#) To manage messages transmission, the following Tx control functions
44:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** can be used:
45:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (++) HAL_CAN_AddTxMessage() to request transmission of a new
46:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** message.
47:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (++) HAL_CAN_AbortTxRequest() to abort transmission of a pending
48:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** message.
49:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (++) HAL_CAN_GetTxMailboxesFreeLevel() to get the number of free Tx
50:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** mailboxes.
51:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (++) HAL_CAN_IsTxMessagePending() to check if a message is pending
52:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** in a Tx mailbox.
53:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (++) HAL_CAN_GetTxTimestamp() to get the timestamp of Tx message
54:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** sent, if time triggered communication mode is enabled.
55:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
56:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (#) When a message is received into the CAN Rx FIFOs, it can be retrieved
57:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** using the HAL_CAN_GetRxMessage() function. The function
58:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_GetRxFifoFillLevel() allows to know how many Rx message are
59:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** stored in the Rx Fifo.
60:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
61:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (#) Calling the HAL_CAN_Stop() function stops the CAN module.
62:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
63:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (#) The deinitialization is achieved with HAL_CAN_DeInit() function.
64:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
65:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
66:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** *** Polling mode operation ***
67:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ==============================
68:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** [..]
69:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (#) Reception:
70:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (++) Monitor reception of message using HAL_CAN_GetRxFifoFillLevel()
71:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** until at least one message is received.
72:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (++) Then get the message using HAL_CAN_GetRxMessage().
73:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
74:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (#) Transmission:
75:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (++) Monitor the Tx mailboxes availability until at least one Tx
76:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** mailbox is free, using HAL_CAN_GetTxMailboxesFreeLevel().
77:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (++) Then request transmission of a message using
78:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_AddTxMessage().
79:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
80:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
81:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** *** Interrupt mode operation ***
82:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ================================
83:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** [..]
84:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (#) Notifications are activated using HAL_CAN_ActivateNotification()
85:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** function. Then, the process can be controlled through the
86:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** available user callbacks: HAL_CAN_xxxCallback(), using same APIs
ARM GAS /tmp/ccj1aKCo.s page 3
87:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_GetRxMessage() and HAL_CAN_AddTxMessage().
88:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
89:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (#) Notifications can be deactivated using
90:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_DeactivateNotification() function.
91:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
92:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (#) Special care should be taken for CAN_IT_RX_FIFO0_MSG_PENDING and
93:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** CAN_IT_RX_FIFO1_MSG_PENDING notifications. These notifications trig
94:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** the callbacks HAL_CAN_RxFIFO0MsgPendingCallback() and
95:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_RxFIFO1MsgPendingCallback(). User has two possible options
96:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** here.
97:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (++) Directly get the Rx message in the callback, using
98:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_GetRxMessage().
99:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (++) Or deactivate the notification in the callback without
100:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** getting the Rx message. The Rx message can then be got later
101:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** using HAL_CAN_GetRxMessage(). Once the Rx message have been
102:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** read, the notification can be activated again.
103:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
104:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
105:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** *** Sleep mode ***
106:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ==================
107:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** [..]
108:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (#) The CAN peripheral can be put in sleep mode (low power), using
109:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_RequestSleep(). The sleep mode will be entered as soon as the
110:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** current CAN activity (transmission or reception of a CAN frame) will
111:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** be completed.
112:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
113:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (#) A notification can be activated to be informed when the sleep mode
114:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** will be entered.
115:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
116:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (#) It can be checked if the sleep mode is entered using
117:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_IsSleepActive().
118:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** Note that the CAN state (accessible from the API HAL_CAN_GetState())
119:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** is HAL_CAN_STATE_SLEEP_PENDING as soon as the sleep mode request is
120:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** submitted (the sleep mode is not yet entered), and become
121:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_STATE_SLEEP_ACTIVE when the sleep mode is effective.
122:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
123:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (#) The wake-up from sleep mode can be triggered by two ways:
124:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (++) Using HAL_CAN_WakeUp(). When returning from this function,
125:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** the sleep mode is exited (if return status is HAL_OK).
126:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (++) When a start of Rx CAN frame is detected by the CAN peripheral,
127:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if automatic wake up mode is enabled.
128:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
129:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** *** Callback registration ***
130:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** =============================================
131:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
132:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** The compilation define USE_HAL_CAN_REGISTER_CALLBACKS when set to 1
133:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** allows the user to configure dynamically the driver callbacks.
134:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** Use Function HAL_CAN_RegisterCallback() to register an interrupt callback.
135:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
136:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** Function HAL_CAN_RegisterCallback() allows to register following callbacks:
137:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) TxMailbox0CompleteCallback : Tx Mailbox 0 Complete Callback.
138:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) TxMailbox1CompleteCallback : Tx Mailbox 1 Complete Callback.
139:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) TxMailbox2CompleteCallback : Tx Mailbox 2 Complete Callback.
140:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) TxMailbox0AbortCallback : Tx Mailbox 0 Abort Callback.
141:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) TxMailbox1AbortCallback : Tx Mailbox 1 Abort Callback.
142:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) TxMailbox2AbortCallback : Tx Mailbox 2 Abort Callback.
143:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) RxFifo0MsgPendingCallback : Rx Fifo 0 Message Pending Callback.
ARM GAS /tmp/ccj1aKCo.s page 4
144:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) RxFifo0FullCallback : Rx Fifo 0 Full Callback.
145:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) RxFifo1MsgPendingCallback : Rx Fifo 1 Message Pending Callback.
146:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) RxFifo1FullCallback : Rx Fifo 1 Full Callback.
147:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) SleepCallback : Sleep Callback.
148:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) WakeUpFromRxMsgCallback : Wake Up From Rx Message Callback.
149:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) ErrorCallback : Error Callback.
150:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) MspInitCallback : CAN MspInit.
151:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) MspDeInitCallback : CAN MspDeInit.
152:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** This function takes as parameters the HAL peripheral handle, the Callback ID
153:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** and a pointer to the user callback function.
154:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
155:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** Use function HAL_CAN_UnRegisterCallback() to reset a callback to the default
156:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** weak function.
157:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_UnRegisterCallback takes as parameters the HAL peripheral handle,
158:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** and the Callback ID.
159:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** This function allows to reset following callbacks:
160:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) TxMailbox0CompleteCallback : Tx Mailbox 0 Complete Callback.
161:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) TxMailbox1CompleteCallback : Tx Mailbox 1 Complete Callback.
162:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) TxMailbox2CompleteCallback : Tx Mailbox 2 Complete Callback.
163:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) TxMailbox0AbortCallback : Tx Mailbox 0 Abort Callback.
164:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) TxMailbox1AbortCallback : Tx Mailbox 1 Abort Callback.
165:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) TxMailbox2AbortCallback : Tx Mailbox 2 Abort Callback.
166:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) RxFifo0MsgPendingCallback : Rx Fifo 0 Message Pending Callback.
167:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) RxFifo0FullCallback : Rx Fifo 0 Full Callback.
168:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) RxFifo1MsgPendingCallback : Rx Fifo 1 Message Pending Callback.
169:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) RxFifo1FullCallback : Rx Fifo 1 Full Callback.
170:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) SleepCallback : Sleep Callback.
171:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) WakeUpFromRxMsgCallback : Wake Up From Rx Message Callback.
172:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) ErrorCallback : Error Callback.
173:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) MspInitCallback : CAN MspInit.
174:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) MspDeInitCallback : CAN MspDeInit.
175:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
176:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** By default, after the HAL_CAN_Init() and when the state is HAL_CAN_STATE_RESET,
177:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** all callbacks are set to the corresponding weak functions:
178:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** example HAL_CAN_ErrorCallback().
179:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** Exception done for MspInit and MspDeInit functions that are
180:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** reset to the legacy weak function in the HAL_CAN_Init()/ HAL_CAN_DeInit() only when
181:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** these callbacks are null (not registered beforehand).
182:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if not, MspInit or MspDeInit are not null, the HAL_CAN_Init()/ HAL_CAN_DeInit()
183:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** keep and use the user MspInit/MspDeInit callbacks (registered beforehand)
184:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
185:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** Callbacks can be registered/unregistered in HAL_CAN_STATE_READY state only.
186:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** Exception done MspInit/MspDeInit that can be registered/unregistered
187:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** in HAL_CAN_STATE_READY or HAL_CAN_STATE_RESET state,
188:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** thus registered (user) MspInit/DeInit callbacks can be used during the Init/DeInit.
189:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** In that case first register the MspInit/MspDeInit user callbacks
190:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** using HAL_CAN_RegisterCallback() before calling HAL_CAN_DeInit()
191:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** or HAL_CAN_Init() function.
192:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
193:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** When The compilation define USE_HAL_CAN_REGISTER_CALLBACKS is set to 0 or
194:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** not defined, the callback registration feature is not available and all callbacks
195:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** are set to the corresponding weak functions.
196:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
197:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** @endverbatim
198:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ******************************************************************************
199:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @attention
200:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** *
ARM GAS /tmp/ccj1aKCo.s page 5
201:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** *
© Copyright (c) 2016 STMicroelectronics.
202:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * All rights reserved.
203:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** *
204:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * This software component is licensed by ST under BSD 3-Clause license,
205:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * the "License"; You may not use this file except in compliance with the
206:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * License. You may obtain a copy of the License at:
207:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * opensource.org/licenses/BSD-3-Clause
208:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** *
209:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ******************************************************************************
210:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
211:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
212:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Includes ------------------------------------------------------------------*/
213:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #include "stm32f3xx_hal.h"
214:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
215:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /** @addtogroup STM32F3xx_HAL_Driver
216:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @{
217:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
218:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
219:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #if defined(CAN)
220:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
221:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /** @defgroup CAN CAN
222:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @brief CAN driver modules
223:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @{
224:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
225:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
226:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #ifdef HAL_CAN_MODULE_ENABLED
227:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
228:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #ifdef HAL_CAN_LEGACY_MODULE_ENABLED
229:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #error "The CAN driver cannot be used with its legacy, Please enable only one CAN module at once"
230:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #endif
231:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
232:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Private typedef -----------------------------------------------------------*/
233:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Private define ------------------------------------------------------------*/
234:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /** @defgroup CAN_Private_Constants CAN Private Constants
235:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @{
236:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
237:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #define CAN_TIMEOUT_VALUE 10U
238:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /**
239:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @}
240:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
241:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Private macro -------------------------------------------------------------*/
242:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Private variables ---------------------------------------------------------*/
243:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Private function prototypes -----------------------------------------------*/
244:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Exported functions --------------------------------------------------------*/
245:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
246:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /** @defgroup CAN_Exported_Functions CAN Exported Functions
247:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @{
248:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
249:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
250:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /** @defgroup CAN_Exported_Functions_Group1 Initialization and de-initialization functions
251:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @brief Initialization and Configuration functions
252:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** *
253:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** @verbatim
254:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ==============================================================================
255:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ##### Initialization and de-initialization functions #####
256:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ==============================================================================
257:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** [..] This section provides functions allowing to:
ARM GAS /tmp/ccj1aKCo.s page 6
258:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) HAL_CAN_Init : Initialize and configure the CAN.
259:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) HAL_CAN_DeInit : De-initialize the CAN.
260:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) HAL_CAN_MspInit : Initialize the CAN MSP.
261:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) HAL_CAN_MspDeInit : DeInitialize the CAN MSP.
262:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
263:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** @endverbatim
264:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @{
265:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
266:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
267:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /**
268:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @brief Initializes the CAN peripheral according to the specified
269:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * parameters in the CAN_InitStruct.
270:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param hcan pointer to a CAN_HandleTypeDef structure that contains
271:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * the configuration information for the specified CAN.
272:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @retval HAL status
273:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
274:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_StatusTypeDef HAL_CAN_Init(CAN_HandleTypeDef *hcan)
275:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
276:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** uint32_t tickstart;
277:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
278:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Check CAN handle */
279:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if (hcan == NULL)
280:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
281:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** return HAL_ERROR;
282:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
283:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
284:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Check the parameters */
285:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_CAN_ALL_INSTANCE(hcan->Instance));
286:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_FUNCTIONAL_STATE(hcan->Init.TimeTriggeredMode));
287:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_FUNCTIONAL_STATE(hcan->Init.AutoBusOff));
288:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_FUNCTIONAL_STATE(hcan->Init.AutoWakeUp));
289:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_FUNCTIONAL_STATE(hcan->Init.AutoRetransmission));
290:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_FUNCTIONAL_STATE(hcan->Init.ReceiveFifoLocked));
291:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_FUNCTIONAL_STATE(hcan->Init.TransmitFifoPriority));
292:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_CAN_MODE(hcan->Init.Mode));
293:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_CAN_SJW(hcan->Init.SyncJumpWidth));
294:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_CAN_BS1(hcan->Init.TimeSeg1));
295:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_CAN_BS2(hcan->Init.TimeSeg2));
296:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_CAN_PRESCALER(hcan->Init.Prescaler));
297:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
298:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #if USE_HAL_CAN_REGISTER_CALLBACKS == 1
299:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if (hcan->State == HAL_CAN_STATE_RESET)
300:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
301:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Reset callbacks to legacy functions */
302:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->RxFifo0MsgPendingCallback = HAL_CAN_RxFifo0MsgPendingCallback; /* Legacy weak RxFifo0M
303:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->RxFifo0FullCallback = HAL_CAN_RxFifo0FullCallback; /* Legacy weak RxFifo0F
304:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->RxFifo1MsgPendingCallback = HAL_CAN_RxFifo1MsgPendingCallback; /* Legacy weak RxFifo1M
305:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->RxFifo1FullCallback = HAL_CAN_RxFifo1FullCallback; /* Legacy weak RxFifo1F
306:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->TxMailbox0CompleteCallback = HAL_CAN_TxMailbox0CompleteCallback; /* Legacy weak TxMailbo
307:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->TxMailbox1CompleteCallback = HAL_CAN_TxMailbox1CompleteCallback; /* Legacy weak TxMailbo
308:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->TxMailbox2CompleteCallback = HAL_CAN_TxMailbox2CompleteCallback; /* Legacy weak TxMailbo
309:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->TxMailbox0AbortCallback = HAL_CAN_TxMailbox0AbortCallback; /* Legacy weak TxMailbo
310:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->TxMailbox1AbortCallback = HAL_CAN_TxMailbox1AbortCallback; /* Legacy weak TxMailbo
311:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->TxMailbox2AbortCallback = HAL_CAN_TxMailbox2AbortCallback; /* Legacy weak TxMailbo
312:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->SleepCallback = HAL_CAN_SleepCallback; /* Legacy weak SleepCal
313:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->WakeUpFromRxMsgCallback = HAL_CAN_WakeUpFromRxMsgCallback; /* Legacy weak WakeUpFr
314:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->ErrorCallback = HAL_CAN_ErrorCallback; /* Legacy weak ErrorCal
ARM GAS /tmp/ccj1aKCo.s page 7
315:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
316:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if (hcan->MspInitCallback == NULL)
317:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
318:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->MspInitCallback = HAL_CAN_MspInit; /* Legacy weak MspInit */
319:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
320:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
321:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Init the low level hardware: CLOCK, NVIC */
322:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->MspInitCallback(hcan);
323:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
324:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
325:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #else
326:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if (hcan->State == HAL_CAN_STATE_RESET)
327:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
328:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Init the low level hardware: CLOCK, NVIC */
329:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_MspInit(hcan);
330:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
331:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #endif /* (USE_HAL_CAN_REGISTER_CALLBACKS) */
332:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
333:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Request initialisation */
334:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** SET_BIT(hcan->Instance->MCR, CAN_MCR_INRQ);
335:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
336:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Get tick */
337:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** tickstart = HAL_GetTick();
338:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
339:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Wait initialisation acknowledge */
340:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** while ((hcan->Instance->MSR & CAN_MSR_INAK) == 0U)
341:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
342:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((HAL_GetTick() - tickstart) > CAN_TIMEOUT_VALUE)
343:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
344:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Update error code */
345:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->ErrorCode |= HAL_CAN_ERROR_TIMEOUT;
346:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
347:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Change CAN state */
348:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->State = HAL_CAN_STATE_ERROR;
349:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
350:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** return HAL_ERROR;
351:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
352:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
353:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
354:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Exit from sleep mode */
355:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** CLEAR_BIT(hcan->Instance->MCR, CAN_MCR_SLEEP);
356:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
357:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Get tick */
358:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** tickstart = HAL_GetTick();
359:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
360:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Check Sleep mode leave acknowledge */
361:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** while ((hcan->Instance->MSR & CAN_MSR_SLAK) != 0U)
362:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
363:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((HAL_GetTick() - tickstart) > CAN_TIMEOUT_VALUE)
364:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
365:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Update error code */
366:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->ErrorCode |= HAL_CAN_ERROR_TIMEOUT;
367:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
368:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Change CAN state */
369:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->State = HAL_CAN_STATE_ERROR;
370:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
371:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** return HAL_ERROR;
ARM GAS /tmp/ccj1aKCo.s page 8
372:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
373:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
374:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
375:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Set the time triggered communication mode */
376:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if (hcan->Init.TimeTriggeredMode == ENABLE)
377:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
378:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** SET_BIT(hcan->Instance->MCR, CAN_MCR_TTCM);
379:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
380:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** else
381:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
382:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** CLEAR_BIT(hcan->Instance->MCR, CAN_MCR_TTCM);
383:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
384:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
385:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Set the automatic bus-off management */
386:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if (hcan->Init.AutoBusOff == ENABLE)
387:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
388:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** SET_BIT(hcan->Instance->MCR, CAN_MCR_ABOM);
389:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
390:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** else
391:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
392:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** CLEAR_BIT(hcan->Instance->MCR, CAN_MCR_ABOM);
393:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
394:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
395:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Set the automatic wake-up mode */
396:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if (hcan->Init.AutoWakeUp == ENABLE)
397:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
398:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** SET_BIT(hcan->Instance->MCR, CAN_MCR_AWUM);
399:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
400:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** else
401:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
402:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** CLEAR_BIT(hcan->Instance->MCR, CAN_MCR_AWUM);
403:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
404:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
405:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Set the automatic retransmission */
406:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if (hcan->Init.AutoRetransmission == ENABLE)
407:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
408:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** CLEAR_BIT(hcan->Instance->MCR, CAN_MCR_NART);
409:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
410:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** else
411:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
412:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** SET_BIT(hcan->Instance->MCR, CAN_MCR_NART);
413:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
414:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
415:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Set the receive FIFO locked mode */
416:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if (hcan->Init.ReceiveFifoLocked == ENABLE)
417:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
418:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** SET_BIT(hcan->Instance->MCR, CAN_MCR_RFLM);
419:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
420:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** else
421:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
422:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** CLEAR_BIT(hcan->Instance->MCR, CAN_MCR_RFLM);
423:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
424:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
425:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Set the transmit FIFO priority */
426:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if (hcan->Init.TransmitFifoPriority == ENABLE)
427:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
428:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** SET_BIT(hcan->Instance->MCR, CAN_MCR_TXFP);
ARM GAS /tmp/ccj1aKCo.s page 9
429:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
430:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** else
431:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
432:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** CLEAR_BIT(hcan->Instance->MCR, CAN_MCR_TXFP);
433:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
434:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
435:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Set the bit timing register */
436:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** WRITE_REG(hcan->Instance->BTR, (uint32_t)(hcan->Init.Mode |
437:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->Init.SyncJumpWidth |
438:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->Init.TimeSeg1 |
439:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->Init.TimeSeg2 |
440:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (hcan->Init.Prescaler - 1U)));
441:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
442:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Initialize the error code */
443:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->ErrorCode = HAL_CAN_ERROR_NONE;
444:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
445:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Initialize the CAN state */
446:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->State = HAL_CAN_STATE_READY;
447:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
448:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Return function status */
449:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** return HAL_OK;
450:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
451:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
452:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /**
453:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @brief Deinitializes the CAN peripheral registers to their default
454:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * reset values.
455:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param hcan pointer to a CAN_HandleTypeDef structure that contains
456:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * the configuration information for the specified CAN.
457:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @retval HAL status
458:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
459:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_StatusTypeDef HAL_CAN_DeInit(CAN_HandleTypeDef *hcan)
460:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
461:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Check CAN handle */
462:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if (hcan == NULL)
463:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
464:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** return HAL_ERROR;
465:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
466:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
467:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Check the parameters */
468:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_CAN_ALL_INSTANCE(hcan->Instance));
469:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
470:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Stop the CAN module */
471:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (void)HAL_CAN_Stop(hcan);
472:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
473:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #if USE_HAL_CAN_REGISTER_CALLBACKS == 1
474:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if (hcan->MspDeInitCallback == NULL)
475:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
476:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->MspDeInitCallback = HAL_CAN_MspDeInit; /* Legacy weak MspDeInit */
477:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
478:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
479:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* DeInit the low level hardware: CLOCK, NVIC */
480:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->MspDeInitCallback(hcan);
481:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
482:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #else
483:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* DeInit the low level hardware: CLOCK, NVIC */
484:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_MspDeInit(hcan);
485:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #endif /* (USE_HAL_CAN_REGISTER_CALLBACKS) */
ARM GAS /tmp/ccj1aKCo.s page 10
486:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
487:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Reset the CAN peripheral */
488:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** SET_BIT(hcan->Instance->MCR, CAN_MCR_RESET);
489:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
490:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Reset the CAN ErrorCode */
491:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->ErrorCode = HAL_CAN_ERROR_NONE;
492:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
493:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Change CAN state */
494:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->State = HAL_CAN_STATE_RESET;
495:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
496:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Return function status */
497:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** return HAL_OK;
498:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
499:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
500:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /**
501:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @brief Initializes the CAN MSP.
502:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param hcan pointer to a CAN_HandleTypeDef structure that contains
503:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * the configuration information for the specified CAN.
504:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @retval None
505:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
506:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** __weak void HAL_CAN_MspInit(CAN_HandleTypeDef *hcan)
507:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
30 .loc 1 507 1 view -0
31 .cfi_startproc
32 @ args = 0, pretend = 0, frame = 0
33 @ frame_needed = 0, uses_anonymous_args = 0
34 @ link register save eliminated.
508:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Prevent unused argument(s) compilation warning */
509:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** UNUSED(hcan);
35 .loc 1 509 3 view .LVU1
510:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
511:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* NOTE : This function Should not be modified, when the callback is needed,
512:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** the HAL_CAN_MspInit could be implemented in the user file
513:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
514:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
36 .loc 1 514 1 is_stmt 0 view .LVU2
37 0000 7047 bx lr
38 .cfi_endproc
39 .LFE132:
41 .section .text.HAL_CAN_Init,"ax",%progbits
42 .align 1
43 .global HAL_CAN_Init
44 .syntax unified
45 .thumb
46 .thumb_func
48 HAL_CAN_Init:
49 .LVL1:
50 .LFB130:
275:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** uint32_t tickstart;
51 .loc 1 275 1 is_stmt 1 view -0
52 .cfi_startproc
53 @ args = 0, pretend = 0, frame = 0
54 @ frame_needed = 0, uses_anonymous_args = 0
276:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
55 .loc 1 276 3 view .LVU4
279:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
56 .loc 1 279 3 view .LVU5
ARM GAS /tmp/ccj1aKCo.s page 11
279:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
57 .loc 1 279 6 is_stmt 0 view .LVU6
58 0000 0028 cmp r0, #0
59 0002 00F0A180 beq .L21
275:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** uint32_t tickstart;
60 .loc 1 275 1 view .LVU7
61 0006 38B5 push {r3, r4, r5, lr}
62 .cfi_def_cfa_offset 16
63 .cfi_offset 3, -16
64 .cfi_offset 4, -12
65 .cfi_offset 5, -8
66 .cfi_offset 14, -4
67 0008 0446 mov r4, r0
285:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_FUNCTIONAL_STATE(hcan->Init.TimeTriggeredMode));
68 .loc 1 285 3 is_stmt 1 view .LVU8
286:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_FUNCTIONAL_STATE(hcan->Init.AutoBusOff));
69 .loc 1 286 3 view .LVU9
287:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_FUNCTIONAL_STATE(hcan->Init.AutoWakeUp));
70 .loc 1 287 3 view .LVU10
288:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_FUNCTIONAL_STATE(hcan->Init.AutoRetransmission));
71 .loc 1 288 3 view .LVU11
289:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_FUNCTIONAL_STATE(hcan->Init.ReceiveFifoLocked));
72 .loc 1 289 3 view .LVU12
290:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_FUNCTIONAL_STATE(hcan->Init.TransmitFifoPriority));
73 .loc 1 290 3 view .LVU13
291:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_CAN_MODE(hcan->Init.Mode));
74 .loc 1 291 3 view .LVU14
292:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_CAN_SJW(hcan->Init.SyncJumpWidth));
75 .loc 1 292 3 view .LVU15
293:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_CAN_BS1(hcan->Init.TimeSeg1));
76 .loc 1 293 3 view .LVU16
294:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_CAN_BS2(hcan->Init.TimeSeg2));
77 .loc 1 294 3 view .LVU17
295:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_CAN_PRESCALER(hcan->Init.Prescaler));
78 .loc 1 295 3 view .LVU18
296:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
79 .loc 1 296 3 view .LVU19
326:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
80 .loc 1 326 3 view .LVU20
326:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
81 .loc 1 326 11 is_stmt 0 view .LVU21
82 000a 90F82030 ldrb r3, [r0, #32] @ zero_extendqisi2
326:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
83 .loc 1 326 6 view .LVU22
84 000e D3B1 cbz r3, .L26
85 .LVL2:
86 .L4:
334:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
87 .loc 1 334 3 is_stmt 1 view .LVU23
88 0010 2268 ldr r2, [r4]
89 0012 1368 ldr r3, [r2]
90 0014 43F00103 orr r3, r3, #1
91 0018 1360 str r3, [r2]
337:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
92 .loc 1 337 3 view .LVU24
337:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
93 .loc 1 337 15 is_stmt 0 view .LVU25
ARM GAS /tmp/ccj1aKCo.s page 12
94 001a FFF7FEFF bl HAL_GetTick
95 .LVL3:
96 001e 0546 mov r5, r0
97 .LVL4:
340:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
98 .loc 1 340 3 is_stmt 1 view .LVU26
99 .L5:
340:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
100 .loc 1 340 47 view .LVU27
340:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
101 .loc 1 340 15 is_stmt 0 view .LVU28
102 0020 2368 ldr r3, [r4]
340:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
103 .loc 1 340 25 view .LVU29
104 0022 5A68 ldr r2, [r3, #4]
340:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
105 .loc 1 340 47 view .LVU30
106 0024 12F0010F tst r2, #1
107 0028 10D1 bne .L27
342:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
108 .loc 1 342 5 is_stmt 1 view .LVU31
342:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
109 .loc 1 342 10 is_stmt 0 view .LVU32
110 002a FFF7FEFF bl HAL_GetTick
111 .LVL5:
342:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
112 .loc 1 342 24 view .LVU33
113 002e 401B subs r0, r0, r5
342:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
114 .loc 1 342 8 view .LVU34
115 0030 0A28 cmp r0, #10
116 0032 F5D9 bls .L5
345:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
117 .loc 1 345 7 is_stmt 1 view .LVU35
345:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
118 .loc 1 345 11 is_stmt 0 view .LVU36
119 0034 636A ldr r3, [r4, #36]
345:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
120 .loc 1 345 23 view .LVU37
121 0036 43F40033 orr r3, r3, #131072
122 003a 6362 str r3, [r4, #36]
348:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
123 .loc 1 348 7 is_stmt 1 view .LVU38
348:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
124 .loc 1 348 19 is_stmt 0 view .LVU39
125 003c 0523 movs r3, #5
126 003e 84F82030 strb r3, [r4, #32]
350:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
127 .loc 1 350 7 is_stmt 1 view .LVU40
350:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
128 .loc 1 350 14 is_stmt 0 view .LVU41
129 0042 0120 movs r0, #1
130 .L3:
450:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
131 .loc 1 450 1 view .LVU42
132 0044 38BD pop {r3, r4, r5, pc}
133 .LVL6:
ARM GAS /tmp/ccj1aKCo.s page 13
134 .L26:
329:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
135 .loc 1 329 5 is_stmt 1 view .LVU43
136 0046 FFF7FEFF bl HAL_CAN_MspInit
137 .LVL7:
329:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
138 .loc 1 329 5 is_stmt 0 view .LVU44
139 004a E1E7 b .L4
140 .LVL8:
141 .L27:
355:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
142 .loc 1 355 3 is_stmt 1 view .LVU45
143 004c 1A68 ldr r2, [r3]
144 004e 22F00202 bic r2, r2, #2
145 0052 1A60 str r2, [r3]
358:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
146 .loc 1 358 3 view .LVU46
358:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
147 .loc 1 358 15 is_stmt 0 view .LVU47
148 0054 FFF7FEFF bl HAL_GetTick
149 .LVL9:
150 0058 0546 mov r5, r0
151 .LVL10:
361:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
152 .loc 1 361 3 is_stmt 1 view .LVU48
153 .L7:
361:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
154 .loc 1 361 47 view .LVU49
361:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
155 .loc 1 361 15 is_stmt 0 view .LVU50
156 005a 2368 ldr r3, [r4]
361:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
157 .loc 1 361 25 view .LVU51
158 005c 5A68 ldr r2, [r3, #4]
361:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
159 .loc 1 361 47 view .LVU52
160 005e 12F0020F tst r2, #2
161 0062 0DD0 beq .L28
363:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
162 .loc 1 363 5 is_stmt 1 view .LVU53
363:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
163 .loc 1 363 10 is_stmt 0 view .LVU54
164 0064 FFF7FEFF bl HAL_GetTick
165 .LVL11:
363:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
166 .loc 1 363 24 view .LVU55
167 0068 401B subs r0, r0, r5
363:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
168 .loc 1 363 8 view .LVU56
169 006a 0A28 cmp r0, #10
170 006c F5D9 bls .L7
366:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
171 .loc 1 366 7 is_stmt 1 view .LVU57
366:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
172 .loc 1 366 11 is_stmt 0 view .LVU58
173 006e 636A ldr r3, [r4, #36]
366:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
ARM GAS /tmp/ccj1aKCo.s page 14
174 .loc 1 366 23 view .LVU59
175 0070 43F40033 orr r3, r3, #131072
176 0074 6362 str r3, [r4, #36]
369:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
177 .loc 1 369 7 is_stmt 1 view .LVU60
369:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
178 .loc 1 369 19 is_stmt 0 view .LVU61
179 0076 0523 movs r3, #5
180 0078 84F82030 strb r3, [r4, #32]
371:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
181 .loc 1 371 7 is_stmt 1 view .LVU62
371:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
182 .loc 1 371 14 is_stmt 0 view .LVU63
183 007c 0120 movs r0, #1
184 007e E1E7 b .L3
185 .L28:
376:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
186 .loc 1 376 3 is_stmt 1 view .LVU64
376:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
187 .loc 1 376 17 is_stmt 0 view .LVU65
188 0080 227E ldrb r2, [r4, #24] @ zero_extendqisi2
376:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
189 .loc 1 376 6 view .LVU66
190 0082 012A cmp r2, #1
191 0084 3DD0 beq .L29
382:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
192 .loc 1 382 5 is_stmt 1 view .LVU67
193 0086 1A68 ldr r2, [r3]
194 0088 22F08002 bic r2, r2, #128
195 008c 1A60 str r2, [r3]
196 .L10:
386:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
197 .loc 1 386 3 view .LVU68
386:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
198 .loc 1 386 17 is_stmt 0 view .LVU69
199 008e 637E ldrb r3, [r4, #25] @ zero_extendqisi2
386:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
200 .loc 1 386 6 view .LVU70
201 0090 012B cmp r3, #1
202 0092 3BD0 beq .L30
392:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
203 .loc 1 392 5 is_stmt 1 view .LVU71
204 0094 2268 ldr r2, [r4]
205 0096 1368 ldr r3, [r2]
206 0098 23F04003 bic r3, r3, #64
207 009c 1360 str r3, [r2]
208 .L12:
396:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
209 .loc 1 396 3 view .LVU72
396:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
210 .loc 1 396 17 is_stmt 0 view .LVU73
211 009e A37E ldrb r3, [r4, #26] @ zero_extendqisi2
396:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
212 .loc 1 396 6 view .LVU74
213 00a0 012B cmp r3, #1
214 00a2 39D0 beq .L31
402:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
ARM GAS /tmp/ccj1aKCo.s page 15
215 .loc 1 402 5 is_stmt 1 view .LVU75
216 00a4 2268 ldr r2, [r4]
217 00a6 1368 ldr r3, [r2]
218 00a8 23F02003 bic r3, r3, #32
219 00ac 1360 str r3, [r2]
220 .L14:
406:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
221 .loc 1 406 3 view .LVU76
406:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
222 .loc 1 406 17 is_stmt 0 view .LVU77
223 00ae E37E ldrb r3, [r4, #27] @ zero_extendqisi2
406:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
224 .loc 1 406 6 view .LVU78
225 00b0 012B cmp r3, #1
226 00b2 37D0 beq .L32
412:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
227 .loc 1 412 5 is_stmt 1 view .LVU79
228 00b4 2268 ldr r2, [r4]
229 00b6 1368 ldr r3, [r2]
230 00b8 43F01003 orr r3, r3, #16
231 00bc 1360 str r3, [r2]
232 .L16:
416:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
233 .loc 1 416 3 view .LVU80
416:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
234 .loc 1 416 17 is_stmt 0 view .LVU81
235 00be 237F ldrb r3, [r4, #28] @ zero_extendqisi2
416:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
236 .loc 1 416 6 view .LVU82
237 00c0 012B cmp r3, #1
238 00c2 35D0 beq .L33
422:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
239 .loc 1 422 5 is_stmt 1 view .LVU83
240 00c4 2268 ldr r2, [r4]
241 00c6 1368 ldr r3, [r2]
242 00c8 23F00803 bic r3, r3, #8
243 00cc 1360 str r3, [r2]
244 .L18:
426:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
245 .loc 1 426 3 view .LVU84
426:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
246 .loc 1 426 17 is_stmt 0 view .LVU85
247 00ce 637F ldrb r3, [r4, #29] @ zero_extendqisi2
426:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
248 .loc 1 426 6 view .LVU86
249 00d0 012B cmp r3, #1
250 00d2 33D0 beq .L34
432:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
251 .loc 1 432 5 is_stmt 1 view .LVU87
252 00d4 2268 ldr r2, [r4]
253 00d6 1368 ldr r3, [r2]
254 00d8 23F00403 bic r3, r3, #4
255 00dc 1360 str r3, [r2]
256 .L20:
436:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->Init.SyncJumpWidth |
257 .loc 1 436 3 view .LVU88
258 00de A368 ldr r3, [r4, #8]
ARM GAS /tmp/ccj1aKCo.s page 16
259 00e0 E268 ldr r2, [r4, #12]
260 00e2 1343 orrs r3, r3, r2
261 00e4 2269 ldr r2, [r4, #16]
262 00e6 1343 orrs r3, r3, r2
263 00e8 6269 ldr r2, [r4, #20]
264 00ea 1343 orrs r3, r3, r2
265 00ec 6268 ldr r2, [r4, #4]
266 00ee 013A subs r2, r2, #1
267 00f0 2168 ldr r1, [r4]
268 00f2 1343 orrs r3, r3, r2
269 00f4 CB61 str r3, [r1, #28]
443:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
270 .loc 1 443 3 view .LVU89
443:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
271 .loc 1 443 19 is_stmt 0 view .LVU90
272 00f6 0020 movs r0, #0
273 00f8 6062 str r0, [r4, #36]
446:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
274 .loc 1 446 3 is_stmt 1 view .LVU91
446:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
275 .loc 1 446 15 is_stmt 0 view .LVU92
276 00fa 0123 movs r3, #1
277 00fc 84F82030 strb r3, [r4, #32]
449:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
278 .loc 1 449 3 is_stmt 1 view .LVU93
449:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
279 .loc 1 449 10 is_stmt 0 view .LVU94
280 0100 A0E7 b .L3
281 .L29:
378:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
282 .loc 1 378 5 is_stmt 1 view .LVU95
283 0102 1A68 ldr r2, [r3]
284 0104 42F08002 orr r2, r2, #128
285 0108 1A60 str r2, [r3]
286 010a C0E7 b .L10
287 .L30:
388:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
288 .loc 1 388 5 view .LVU96
289 010c 2268 ldr r2, [r4]
290 010e 1368 ldr r3, [r2]
291 0110 43F04003 orr r3, r3, #64
292 0114 1360 str r3, [r2]
293 0116 C2E7 b .L12
294 .L31:
398:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
295 .loc 1 398 5 view .LVU97
296 0118 2268 ldr r2, [r4]
297 011a 1368 ldr r3, [r2]
298 011c 43F02003 orr r3, r3, #32
299 0120 1360 str r3, [r2]
300 0122 C4E7 b .L14
301 .L32:
408:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
302 .loc 1 408 5 view .LVU98
303 0124 2268 ldr r2, [r4]
304 0126 1368 ldr r3, [r2]
305 0128 23F01003 bic r3, r3, #16
ARM GAS /tmp/ccj1aKCo.s page 17
306 012c 1360 str r3, [r2]
307 012e C6E7 b .L16
308 .L33:
418:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
309 .loc 1 418 5 view .LVU99
310 0130 2268 ldr r2, [r4]
311 0132 1368 ldr r3, [r2]
312 0134 43F00803 orr r3, r3, #8
313 0138 1360 str r3, [r2]
314 013a C8E7 b .L18
315 .L34:
428:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
316 .loc 1 428 5 view .LVU100
317 013c 2268 ldr r2, [r4]
318 013e 1368 ldr r3, [r2]
319 0140 43F00403 orr r3, r3, #4
320 0144 1360 str r3, [r2]
321 0146 CAE7 b .L20
322 .LVL12:
323 .L21:
324 .cfi_def_cfa_offset 0
325 .cfi_restore 3
326 .cfi_restore 4
327 .cfi_restore 5
328 .cfi_restore 14
281:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
329 .loc 1 281 12 is_stmt 0 view .LVU101
330 0148 0120 movs r0, #1
331 .LVL13:
450:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
332 .loc 1 450 1 view .LVU102
333 014a 7047 bx lr
334 .cfi_endproc
335 .LFE130:
337 .section .text.HAL_CAN_MspDeInit,"ax",%progbits
338 .align 1
339 .weak HAL_CAN_MspDeInit
340 .syntax unified
341 .thumb
342 .thumb_func
344 HAL_CAN_MspDeInit:
345 .LVL14:
346 .LFB133:
515:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
516:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /**
517:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @brief DeInitializes the CAN MSP.
518:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param hcan pointer to a CAN_HandleTypeDef structure that contains
519:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * the configuration information for the specified CAN.
520:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @retval None
521:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
522:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** __weak void HAL_CAN_MspDeInit(CAN_HandleTypeDef *hcan)
523:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
347 .loc 1 523 1 is_stmt 1 view -0
348 .cfi_startproc
349 @ args = 0, pretend = 0, frame = 0
350 @ frame_needed = 0, uses_anonymous_args = 0
351 @ link register save eliminated.
ARM GAS /tmp/ccj1aKCo.s page 18
524:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Prevent unused argument(s) compilation warning */
525:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** UNUSED(hcan);
352 .loc 1 525 3 view .LVU104
526:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
527:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* NOTE : This function Should not be modified, when the callback is needed,
528:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** the HAL_CAN_MspDeInit could be implemented in the user file
529:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
530:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
353 .loc 1 530 1 is_stmt 0 view .LVU105
354 0000 7047 bx lr
355 .cfi_endproc
356 .LFE133:
358 .section .text.HAL_CAN_ConfigFilter,"ax",%progbits
359 .align 1
360 .global HAL_CAN_ConfigFilter
361 .syntax unified
362 .thumb
363 .thumb_func
365 HAL_CAN_ConfigFilter:
366 .LVL15:
367 .LFB134:
531:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
532:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #if USE_HAL_CAN_REGISTER_CALLBACKS == 1
533:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /**
534:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @brief Register a CAN CallBack.
535:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * To be used instead of the weak predefined callback
536:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param hcan pointer to a CAN_HandleTypeDef structure that contains
537:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * the configuration information for CAN module
538:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param CallbackID ID of the callback to be registered
539:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * This parameter can be one of the following values:
540:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @arg @ref HAL_CAN_TX_MAILBOX0_COMPLETE_CB_ID Tx Mailbox 0 Complete callback ID
541:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @arg @ref HAL_CAN_TX_MAILBOX1_COMPLETE_CB_ID Tx Mailbox 1 Complete callback ID
542:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @arg @ref HAL_CAN_TX_MAILBOX2_COMPLETE_CB_ID Tx Mailbox 2 Complete callback ID
543:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @arg @ref HAL_CAN_TX_MAILBOX0_ABORT_CB_ID Tx Mailbox 0 Abort callback ID
544:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @arg @ref HAL_CAN_TX_MAILBOX1_ABORT_CB_ID Tx Mailbox 1 Abort callback ID
545:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @arg @ref HAL_CAN_TX_MAILBOX2_ABORT_CB_ID Tx Mailbox 2 Abort callback ID
546:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @arg @ref HAL_CAN_RX_FIFO0_MSG_PENDING_CB_ID Rx Fifo 0 message pending callback ID
547:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @arg @ref HAL_CAN_RX_FIFO0_FULL_CB_ID Rx Fifo 0 full callback ID
548:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @arg @ref HAL_CAN_RX_FIFO1_MSG_PENDING_CB_ID Rx Fifo 1 message pending callback ID
549:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @arg @ref HAL_CAN_RX_FIFO1_FULL_CB_ID Rx Fifo 1 full callback ID
550:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @arg @ref HAL_CAN_SLEEP_CB_ID Sleep callback ID
551:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @arg @ref HAL_CAN_WAKEUP_FROM_RX_MSG_CB_ID Wake Up from Rx message callback ID
552:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @arg @ref HAL_CAN_ERROR_CB_ID Error callback ID
553:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @arg @ref HAL_CAN_MSPINIT_CB_ID MspInit callback ID
554:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @arg @ref HAL_CAN_MSPDEINIT_CB_ID MspDeInit callback ID
555:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param pCallback pointer to the Callback function
556:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @retval HAL status
557:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
558:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_StatusTypeDef HAL_CAN_RegisterCallback(CAN_HandleTypeDef *hcan, HAL_CAN_CallbackIDTypeDef Callb
559:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
560:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_StatusTypeDef status = HAL_OK;
561:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
562:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if (pCallback == NULL)
563:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
564:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Update the error code */
565:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->ErrorCode |= HAL_CAN_ERROR_INVALID_CALLBACK;
566:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
ARM GAS /tmp/ccj1aKCo.s page 19
567:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** return HAL_ERROR;
568:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
569:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
570:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if (hcan->State == HAL_CAN_STATE_READY)
571:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
572:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** switch (CallbackID)
573:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
574:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** case HAL_CAN_TX_MAILBOX0_COMPLETE_CB_ID :
575:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->TxMailbox0CompleteCallback = pCallback;
576:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
577:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
578:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** case HAL_CAN_TX_MAILBOX1_COMPLETE_CB_ID :
579:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->TxMailbox1CompleteCallback = pCallback;
580:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
581:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
582:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** case HAL_CAN_TX_MAILBOX2_COMPLETE_CB_ID :
583:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->TxMailbox2CompleteCallback = pCallback;
584:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
585:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
586:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** case HAL_CAN_TX_MAILBOX0_ABORT_CB_ID :
587:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->TxMailbox0AbortCallback = pCallback;
588:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
589:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
590:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** case HAL_CAN_TX_MAILBOX1_ABORT_CB_ID :
591:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->TxMailbox1AbortCallback = pCallback;
592:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
593:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
594:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** case HAL_CAN_TX_MAILBOX2_ABORT_CB_ID :
595:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->TxMailbox2AbortCallback = pCallback;
596:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
597:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
598:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** case HAL_CAN_RX_FIFO0_MSG_PENDING_CB_ID :
599:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->RxFifo0MsgPendingCallback = pCallback;
600:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
601:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
602:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** case HAL_CAN_RX_FIFO0_FULL_CB_ID :
603:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->RxFifo0FullCallback = pCallback;
604:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
605:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
606:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** case HAL_CAN_RX_FIFO1_MSG_PENDING_CB_ID :
607:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->RxFifo1MsgPendingCallback = pCallback;
608:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
609:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
610:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** case HAL_CAN_RX_FIFO1_FULL_CB_ID :
611:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->RxFifo1FullCallback = pCallback;
612:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
613:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
614:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** case HAL_CAN_SLEEP_CB_ID :
615:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->SleepCallback = pCallback;
616:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
617:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
618:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** case HAL_CAN_WAKEUP_FROM_RX_MSG_CB_ID :
619:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->WakeUpFromRxMsgCallback = pCallback;
620:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
621:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
622:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** case HAL_CAN_ERROR_CB_ID :
623:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->ErrorCallback = pCallback;
ARM GAS /tmp/ccj1aKCo.s page 20
624:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
625:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
626:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** case HAL_CAN_MSPINIT_CB_ID :
627:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->MspInitCallback = pCallback;
628:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
629:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
630:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** case HAL_CAN_MSPDEINIT_CB_ID :
631:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->MspDeInitCallback = pCallback;
632:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
633:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
634:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** default :
635:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Update the error code */
636:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->ErrorCode |= HAL_CAN_ERROR_INVALID_CALLBACK;
637:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
638:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Return error status */
639:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** status = HAL_ERROR;
640:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
641:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
642:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
643:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** else if (hcan->State == HAL_CAN_STATE_RESET)
644:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
645:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** switch (CallbackID)
646:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
647:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** case HAL_CAN_MSPINIT_CB_ID :
648:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->MspInitCallback = pCallback;
649:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
650:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
651:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** case HAL_CAN_MSPDEINIT_CB_ID :
652:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->MspDeInitCallback = pCallback;
653:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
654:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
655:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** default :
656:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Update the error code */
657:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->ErrorCode |= HAL_CAN_ERROR_INVALID_CALLBACK;
658:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
659:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Return error status */
660:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** status = HAL_ERROR;
661:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
662:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
663:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
664:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** else
665:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
666:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Update the error code */
667:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->ErrorCode |= HAL_CAN_ERROR_INVALID_CALLBACK;
668:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
669:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Return error status */
670:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** status = HAL_ERROR;
671:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
672:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
673:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** return status;
674:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
675:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
676:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /**
677:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @brief Unregister a CAN CallBack.
678:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * CAN callabck is redirected to the weak predefined callback
679:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param hcan pointer to a CAN_HandleTypeDef structure that contains
680:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * the configuration information for CAN module
ARM GAS /tmp/ccj1aKCo.s page 21
681:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param CallbackID ID of the callback to be unregistered
682:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * This parameter can be one of the following values:
683:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @arg @ref HAL_CAN_TX_MAILBOX0_COMPLETE_CB_ID Tx Mailbox 0 Complete callback ID
684:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @arg @ref HAL_CAN_TX_MAILBOX1_COMPLETE_CB_ID Tx Mailbox 1 Complete callback ID
685:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @arg @ref HAL_CAN_TX_MAILBOX2_COMPLETE_CB_ID Tx Mailbox 2 Complete callback ID
686:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @arg @ref HAL_CAN_TX_MAILBOX0_ABORT_CB_ID Tx Mailbox 0 Abort callback ID
687:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @arg @ref HAL_CAN_TX_MAILBOX1_ABORT_CB_ID Tx Mailbox 1 Abort callback ID
688:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @arg @ref HAL_CAN_TX_MAILBOX2_ABORT_CB_ID Tx Mailbox 2 Abort callback ID
689:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @arg @ref HAL_CAN_RX_FIFO0_MSG_PENDING_CB_ID Rx Fifo 0 message pending callback ID
690:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @arg @ref HAL_CAN_RX_FIFO0_FULL_CB_ID Rx Fifo 0 full callback ID
691:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @arg @ref HAL_CAN_RX_FIFO1_MSG_PENDING_CB_ID Rx Fifo 1 message pending callback ID
692:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @arg @ref HAL_CAN_RX_FIFO1_FULL_CB_ID Rx Fifo 1 full callback ID
693:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @arg @ref HAL_CAN_SLEEP_CB_ID Sleep callback ID
694:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @arg @ref HAL_CAN_WAKEUP_FROM_RX_MSG_CB_ID Wake Up from Rx message callback ID
695:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @arg @ref HAL_CAN_ERROR_CB_ID Error callback ID
696:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @arg @ref HAL_CAN_MSPINIT_CB_ID MspInit callback ID
697:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @arg @ref HAL_CAN_MSPDEINIT_CB_ID MspDeInit callback ID
698:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @retval HAL status
699:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
700:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_StatusTypeDef HAL_CAN_UnRegisterCallback(CAN_HandleTypeDef *hcan, HAL_CAN_CallbackIDTypeDef Cal
701:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
702:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_StatusTypeDef status = HAL_OK;
703:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
704:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if (hcan->State == HAL_CAN_STATE_READY)
705:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
706:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** switch (CallbackID)
707:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
708:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** case HAL_CAN_TX_MAILBOX0_COMPLETE_CB_ID :
709:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->TxMailbox0CompleteCallback = HAL_CAN_TxMailbox0CompleteCallback;
710:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
711:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
712:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** case HAL_CAN_TX_MAILBOX1_COMPLETE_CB_ID :
713:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->TxMailbox1CompleteCallback = HAL_CAN_TxMailbox1CompleteCallback;
714:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
715:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
716:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** case HAL_CAN_TX_MAILBOX2_COMPLETE_CB_ID :
717:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->TxMailbox2CompleteCallback = HAL_CAN_TxMailbox2CompleteCallback;
718:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
719:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
720:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** case HAL_CAN_TX_MAILBOX0_ABORT_CB_ID :
721:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->TxMailbox0AbortCallback = HAL_CAN_TxMailbox0AbortCallback;
722:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
723:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
724:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** case HAL_CAN_TX_MAILBOX1_ABORT_CB_ID :
725:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->TxMailbox1AbortCallback = HAL_CAN_TxMailbox1AbortCallback;
726:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
727:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
728:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** case HAL_CAN_TX_MAILBOX2_ABORT_CB_ID :
729:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->TxMailbox2AbortCallback = HAL_CAN_TxMailbox2AbortCallback;
730:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
731:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
732:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** case HAL_CAN_RX_FIFO0_MSG_PENDING_CB_ID :
733:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->RxFifo0MsgPendingCallback = HAL_CAN_RxFifo0MsgPendingCallback;
734:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
735:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
736:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** case HAL_CAN_RX_FIFO0_FULL_CB_ID :
737:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->RxFifo0FullCallback = HAL_CAN_RxFifo0FullCallback;
ARM GAS /tmp/ccj1aKCo.s page 22
738:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
739:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
740:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** case HAL_CAN_RX_FIFO1_MSG_PENDING_CB_ID :
741:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->RxFifo1MsgPendingCallback = HAL_CAN_RxFifo1MsgPendingCallback;
742:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
743:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
744:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** case HAL_CAN_RX_FIFO1_FULL_CB_ID :
745:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->RxFifo1FullCallback = HAL_CAN_RxFifo1FullCallback;
746:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
747:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
748:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** case HAL_CAN_SLEEP_CB_ID :
749:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->SleepCallback = HAL_CAN_SleepCallback;
750:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
751:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
752:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** case HAL_CAN_WAKEUP_FROM_RX_MSG_CB_ID :
753:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->WakeUpFromRxMsgCallback = HAL_CAN_WakeUpFromRxMsgCallback;
754:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
755:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
756:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** case HAL_CAN_ERROR_CB_ID :
757:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->ErrorCallback = HAL_CAN_ErrorCallback;
758:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
759:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
760:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** case HAL_CAN_MSPINIT_CB_ID :
761:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->MspInitCallback = HAL_CAN_MspInit;
762:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
763:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
764:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** case HAL_CAN_MSPDEINIT_CB_ID :
765:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->MspDeInitCallback = HAL_CAN_MspDeInit;
766:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
767:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
768:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** default :
769:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Update the error code */
770:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->ErrorCode |= HAL_CAN_ERROR_INVALID_CALLBACK;
771:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
772:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Return error status */
773:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** status = HAL_ERROR;
774:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
775:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
776:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
777:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** else if (hcan->State == HAL_CAN_STATE_RESET)
778:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
779:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** switch (CallbackID)
780:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
781:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** case HAL_CAN_MSPINIT_CB_ID :
782:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->MspInitCallback = HAL_CAN_MspInit;
783:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
784:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
785:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** case HAL_CAN_MSPDEINIT_CB_ID :
786:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->MspDeInitCallback = HAL_CAN_MspDeInit;
787:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
788:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
789:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** default :
790:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Update the error code */
791:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->ErrorCode |= HAL_CAN_ERROR_INVALID_CALLBACK;
792:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
793:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Return error status */
794:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** status = HAL_ERROR;
ARM GAS /tmp/ccj1aKCo.s page 23
795:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
796:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
797:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
798:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** else
799:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
800:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Update the error code */
801:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->ErrorCode |= HAL_CAN_ERROR_INVALID_CALLBACK;
802:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
803:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Return error status */
804:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** status = HAL_ERROR;
805:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
806:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
807:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** return status;
808:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
809:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #endif /* USE_HAL_CAN_REGISTER_CALLBACKS */
810:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
811:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /**
812:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @}
813:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
814:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
815:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /** @defgroup CAN_Exported_Functions_Group2 Configuration functions
816:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @brief Configuration functions.
817:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** *
818:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** @verbatim
819:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ==============================================================================
820:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ##### Configuration functions #####
821:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ==============================================================================
822:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** [..] This section provides functions allowing to:
823:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) HAL_CAN_ConfigFilter : Configure the CAN reception filters
824:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
825:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** @endverbatim
826:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @{
827:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
828:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
829:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /**
830:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @brief Configures the CAN reception filter according to the specified
831:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * parameters in the CAN_FilterInitStruct.
832:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param hcan pointer to a CAN_HandleTypeDef structure that contains
833:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * the configuration information for the specified CAN.
834:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param sFilterConfig pointer to a CAN_FilterTypeDef structure that
835:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * contains the filter configuration information.
836:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @retval None
837:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
838:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_StatusTypeDef HAL_CAN_ConfigFilter(CAN_HandleTypeDef *hcan, CAN_FilterTypeDef *sFilterConfig)
839:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
368 .loc 1 839 1 is_stmt 1 view -0
369 .cfi_startproc
370 @ args = 0, pretend = 0, frame = 0
371 @ frame_needed = 0, uses_anonymous_args = 0
372 @ link register save eliminated.
840:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** uint32_t filternbrbitpos;
373 .loc 1 840 3 view .LVU107
841:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** CAN_TypeDef *can_ip = hcan->Instance;
374 .loc 1 841 3 view .LVU108
375 .loc 1 841 16 is_stmt 0 view .LVU109
376 0000 0268 ldr r2, [r0]
377 .LVL16:
ARM GAS /tmp/ccj1aKCo.s page 24
842:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_StateTypeDef state = hcan->State;
378 .loc 1 842 3 is_stmt 1 view .LVU110
379 .loc 1 842 24 is_stmt 0 view .LVU111
380 0002 90F82030 ldrb r3, [r0, #32] @ zero_extendqisi2
381 .LVL17:
843:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
844:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((state == HAL_CAN_STATE_READY) ||
382 .loc 1 844 3 is_stmt 1 view .LVU112
383 .loc 1 844 38 is_stmt 0 view .LVU113
384 0006 013B subs r3, r3, #1
385 .LVL18:
386 .loc 1 844 38 view .LVU114
387 0008 DBB2 uxtb r3, r3
388 .loc 1 844 6 view .LVU115
389 000a 012B cmp r3, #1
390 000c 05D9 bls .L50
845:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (state == HAL_CAN_STATE_LISTENING))
846:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
847:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Check the parameters */
848:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_CAN_FILTER_ID_HALFWORD(sFilterConfig->FilterIdHigh));
849:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_CAN_FILTER_ID_HALFWORD(sFilterConfig->FilterIdLow));
850:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_CAN_FILTER_ID_HALFWORD(sFilterConfig->FilterMaskIdHigh));
851:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_CAN_FILTER_ID_HALFWORD(sFilterConfig->FilterMaskIdLow));
852:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_CAN_FILTER_MODE(sFilterConfig->FilterMode));
853:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_CAN_FILTER_SCALE(sFilterConfig->FilterScale));
854:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_CAN_FILTER_FIFO(sFilterConfig->FilterFIFOAssignment));
855:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_CAN_FILTER_ACTIVATION(sFilterConfig->FilterActivation));
856:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
857:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* CAN is single instance with 14 dedicated filters banks */
858:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
859:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Check the parameters */
860:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_CAN_FILTER_BANK_SINGLE(sFilterConfig->FilterBank));
861:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
862:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Initialisation mode for the filter */
863:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** SET_BIT(can_ip->FMR, CAN_FMR_FINIT);
864:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
865:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Convert filter number into bit position */
866:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** filternbrbitpos = (uint32_t)1 << (sFilterConfig->FilterBank & 0x1FU);
867:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
868:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Filter Deactivation */
869:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** CLEAR_BIT(can_ip->FA1R, filternbrbitpos);
870:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
871:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Filter Scale */
872:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if (sFilterConfig->FilterScale == CAN_FILTERSCALE_16BIT)
873:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
874:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* 16-bit scale for the filter */
875:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** CLEAR_BIT(can_ip->FS1R, filternbrbitpos);
876:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
877:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* First 16-bit identifier and First 16-bit mask */
878:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Or First 16-bit identifier and Second 16-bit identifier */
879:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** can_ip->sFilterRegister[sFilterConfig->FilterBank].FR1 =
880:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ((0x0000FFFFU & (uint32_t)sFilterConfig->FilterMaskIdLow) << 16U) |
881:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (0x0000FFFFU & (uint32_t)sFilterConfig->FilterIdLow);
882:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
883:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Second 16-bit identifier and Second 16-bit mask */
884:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Or Third 16-bit identifier and Fourth 16-bit identifier */
885:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** can_ip->sFilterRegister[sFilterConfig->FilterBank].FR2 =
ARM GAS /tmp/ccj1aKCo.s page 25
886:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ((0x0000FFFFU & (uint32_t)sFilterConfig->FilterMaskIdHigh) << 16U) |
887:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (0x0000FFFFU & (uint32_t)sFilterConfig->FilterIdHigh);
888:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
889:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
890:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if (sFilterConfig->FilterScale == CAN_FILTERSCALE_32BIT)
891:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
892:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* 32-bit scale for the filter */
893:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** SET_BIT(can_ip->FS1R, filternbrbitpos);
894:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
895:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* 32-bit identifier or First 32-bit identifier */
896:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** can_ip->sFilterRegister[sFilterConfig->FilterBank].FR1 =
897:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ((0x0000FFFFU & (uint32_t)sFilterConfig->FilterIdHigh) << 16U) |
898:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (0x0000FFFFU & (uint32_t)sFilterConfig->FilterIdLow);
899:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
900:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* 32-bit mask or Second 32-bit identifier */
901:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** can_ip->sFilterRegister[sFilterConfig->FilterBank].FR2 =
902:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ((0x0000FFFFU & (uint32_t)sFilterConfig->FilterMaskIdHigh) << 16U) |
903:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (0x0000FFFFU & (uint32_t)sFilterConfig->FilterMaskIdLow);
904:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
905:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
906:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Filter Mode */
907:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if (sFilterConfig->FilterMode == CAN_FILTERMODE_IDMASK)
908:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
909:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Id/Mask mode for the filter*/
910:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** CLEAR_BIT(can_ip->FM1R, filternbrbitpos);
911:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
912:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** else /* CAN_FilterInitStruct->CAN_FilterMode == CAN_FilterMode_IdList */
913:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
914:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Identifier list mode for the filter*/
915:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** SET_BIT(can_ip->FM1R, filternbrbitpos);
916:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
917:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
918:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Filter FIFO assignment */
919:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if (sFilterConfig->FilterFIFOAssignment == CAN_FILTER_FIFO0)
920:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
921:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* FIFO 0 assignation for the filter */
922:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** CLEAR_BIT(can_ip->FFA1R, filternbrbitpos);
923:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
924:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** else
925:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
926:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* FIFO 1 assignation for the filter */
927:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** SET_BIT(can_ip->FFA1R, filternbrbitpos);
928:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
929:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
930:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Filter activation */
931:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if (sFilterConfig->FilterActivation == CAN_FILTER_ENABLE)
932:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
933:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** SET_BIT(can_ip->FA1R, filternbrbitpos);
934:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
935:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
936:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Leave the initialisation mode for the filter */
937:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** CLEAR_BIT(can_ip->FMR, CAN_FMR_FINIT);
938:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
939:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Return function status */
940:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** return HAL_OK;
941:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
942:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** else
ARM GAS /tmp/ccj1aKCo.s page 26
943:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
944:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Update error code */
945:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->ErrorCode |= HAL_CAN_ERROR_NOT_INITIALIZED;
391 .loc 1 945 5 is_stmt 1 view .LVU116
392 .loc 1 945 9 is_stmt 0 view .LVU117
393 000e 436A ldr r3, [r0, #36]
394 .loc 1 945 21 view .LVU118
395 0010 43F48023 orr r3, r3, #262144
396 0014 4362 str r3, [r0, #36]
946:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
947:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** return HAL_ERROR;
397 .loc 1 947 5 is_stmt 1 view .LVU119
398 .loc 1 947 12 is_stmt 0 view .LVU120
399 0016 0120 movs r0, #1
400 .LVL19:
948:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
949:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
401 .loc 1 949 1 view .LVU121
402 0018 7047 bx lr
403 .LVL20:
404 .L50:
839:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** uint32_t filternbrbitpos;
405 .loc 1 839 1 view .LVU122
406 001a 30B4 push {r4, r5}
407 .cfi_def_cfa_offset 8
408 .cfi_offset 4, -8
409 .cfi_offset 5, -4
848:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_CAN_FILTER_ID_HALFWORD(sFilterConfig->FilterIdLow));
410 .loc 1 848 5 is_stmt 1 view .LVU123
849:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_CAN_FILTER_ID_HALFWORD(sFilterConfig->FilterMaskIdHigh));
411 .loc 1 849 5 view .LVU124
850:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_CAN_FILTER_ID_HALFWORD(sFilterConfig->FilterMaskIdLow));
412 .loc 1 850 5 view .LVU125
851:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_CAN_FILTER_MODE(sFilterConfig->FilterMode));
413 .loc 1 851 5 view .LVU126
852:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_CAN_FILTER_SCALE(sFilterConfig->FilterScale));
414 .loc 1 852 5 view .LVU127
853:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_CAN_FILTER_FIFO(sFilterConfig->FilterFIFOAssignment));
415 .loc 1 853 5 view .LVU128
854:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_CAN_FILTER_ACTIVATION(sFilterConfig->FilterActivation));
416 .loc 1 854 5 view .LVU129
855:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
417 .loc 1 855 5 view .LVU130
860:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
418 .loc 1 860 5 view .LVU131
863:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
419 .loc 1 863 5 view .LVU132
420 001c D2F80032 ldr r3, [r2, #512]
421 0020 43F00103 orr r3, r3, #1
422 0024 C2F80032 str r3, [r2, #512]
866:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
423 .loc 1 866 5 view .LVU133
866:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
424 .loc 1 866 52 is_stmt 0 view .LVU134
425 0028 4B69 ldr r3, [r1, #20]
866:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
426 .loc 1 866 65 view .LVU135
ARM GAS /tmp/ccj1aKCo.s page 27
427 002a 03F01F03 and r3, r3, #31
866:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
428 .loc 1 866 21 view .LVU136
429 002e 0120 movs r0, #1
430 .LVL21:
866:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
431 .loc 1 866 21 view .LVU137
432 0030 00FA03F3 lsl r3, r0, r3
433 .LVL22:
869:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
434 .loc 1 869 5 is_stmt 1 view .LVU138
435 0034 D2F81C02 ldr r0, [r2, #540]
436 0038 6FEA030C mvn ip, r3
437 003c 20EA0300 bic r0, r0, r3
438 0040 C2F81C02 str r0, [r2, #540]
872:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
439 .loc 1 872 5 view .LVU139
872:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
440 .loc 1 872 22 is_stmt 0 view .LVU140
441 0044 C869 ldr r0, [r1, #28]
872:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
442 .loc 1 872 8 view .LVU141
443 0046 B0B9 cbnz r0, .L38
875:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
444 .loc 1 875 7 is_stmt 1 view .LVU142
445 0048 D2F80C02 ldr r0, [r2, #524]
446 004c 0CEA0000 and r0, ip, r0
447 0050 C2F80C02 str r0, [r2, #524]
879:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ((0x0000FFFFU & (uint32_t)sFilterConfig->FilterMaskIdLow) << 16U) |
448 .loc 1 879 7 view .LVU143
881:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
449 .loc 1 881 22 is_stmt 0 view .LVU144
450 0054 8C88 ldrh r4, [r1, #4]
879:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ((0x0000FFFFU & (uint32_t)sFilterConfig->FilterMaskIdLow) << 16U) |
451 .loc 1 879 44 view .LVU145
452 0056 4869 ldr r0, [r1, #20]
880:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (0x0000FFFFU & (uint32_t)sFilterConfig->FilterIdLow);
453 .loc 1 880 75 view .LVU146
454 0058 CD68 ldr r5, [r1, #12]
455 005a 44EA0544 orr r4, r4, r5, lsl #16
879:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ((0x0000FFFFU & (uint32_t)sFilterConfig->FilterMaskIdLow) << 16U) |
456 .loc 1 879 62 view .LVU147
457 005e 4830 adds r0, r0, #72
458 0060 42F83040 str r4, [r2, r0, lsl #3]
885:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ((0x0000FFFFU & (uint32_t)sFilterConfig->FilterMaskIdHigh) << 16U) |
459 .loc 1 885 7 is_stmt 1 view .LVU148
887:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
460 .loc 1 887 22 is_stmt 0 view .LVU149
461 0064 0C88 ldrh r4, [r1]
885:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ((0x0000FFFFU & (uint32_t)sFilterConfig->FilterMaskIdHigh) << 16U) |
462 .loc 1 885 44 view .LVU150
463 0066 4869 ldr r0, [r1, #20]
886:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (0x0000FFFFU & (uint32_t)sFilterConfig->FilterIdHigh);
464 .loc 1 886 76 view .LVU151
465 0068 8D68 ldr r5, [r1, #8]
466 006a 44EA0544 orr r4, r4, r5, lsl #16
885:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ((0x0000FFFFU & (uint32_t)sFilterConfig->FilterMaskIdHigh) << 16U) |
ARM GAS /tmp/ccj1aKCo.s page 28
467 .loc 1 885 62 view .LVU152
468 006e 4830 adds r0, r0, #72
469 0070 02EBC000 add r0, r2, r0, lsl #3
470 0074 4460 str r4, [r0, #4]
471 .L38:
890:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
472 .loc 1 890 5 is_stmt 1 view .LVU153
890:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
473 .loc 1 890 22 is_stmt 0 view .LVU154
474 0076 C869 ldr r0, [r1, #28]
890:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
475 .loc 1 890 8 view .LVU155
476 0078 0128 cmp r0, #1
477 007a 1BD0 beq .L51
478 .L39:
907:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
479 .loc 1 907 5 is_stmt 1 view .LVU156
907:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
480 .loc 1 907 22 is_stmt 0 view .LVU157
481 007c 8869 ldr r0, [r1, #24]
907:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
482 .loc 1 907 8 view .LVU158
483 007e 80BB cbnz r0, .L40
910:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
484 .loc 1 910 7 is_stmt 1 view .LVU159
485 0080 D2F80402 ldr r0, [r2, #516]
486 0084 0CEA0000 and r0, ip, r0
487 0088 C2F80402 str r0, [r2, #516]
488 .L41:
919:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
489 .loc 1 919 5 view .LVU160
919:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
490 .loc 1 919 22 is_stmt 0 view .LVU161
491 008c 0869 ldr r0, [r1, #16]
919:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
492 .loc 1 919 8 view .LVU162
493 008e 70BB cbnz r0, .L42
922:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
494 .loc 1 922 7 is_stmt 1 view .LVU163
495 0090 D2F81402 ldr r0, [r2, #532]
496 0094 0CEA0000 and r0, ip, r0
497 0098 C2F81402 str r0, [r2, #532]
498 .L43:
931:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
499 .loc 1 931 5 view .LVU164
931:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
500 .loc 1 931 22 is_stmt 0 view .LVU165
501 009c 096A ldr r1, [r1, #32]
502 .LVL23:
931:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
503 .loc 1 931 8 view .LVU166
504 009e 0129 cmp r1, #1
505 00a0 2BD0 beq .L52
506 .LVL24:
507 .L44:
937:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
508 .loc 1 937 5 is_stmt 1 view .LVU167
ARM GAS /tmp/ccj1aKCo.s page 29
509 00a2 D2F80032 ldr r3, [r2, #512]
510 00a6 23F00103 bic r3, r3, #1
511 00aa C2F80032 str r3, [r2, #512]
940:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
512 .loc 1 940 5 view .LVU168
940:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
513 .loc 1 940 12 is_stmt 0 view .LVU169
514 00ae 0020 movs r0, #0
515 .loc 1 949 1 view .LVU170
516 00b0 30BC pop {r4, r5}
517 .cfi_remember_state
518 .cfi_restore 5
519 .cfi_restore 4
520 .cfi_def_cfa_offset 0
521 00b2 7047 bx lr
522 .LVL25:
523 .L51:
524 .cfi_restore_state
893:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
525 .loc 1 893 7 is_stmt 1 view .LVU171
526 00b4 D2F80C02 ldr r0, [r2, #524]
527 00b8 1843 orrs r0, r0, r3
528 00ba C2F80C02 str r0, [r2, #524]
896:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ((0x0000FFFFU & (uint32_t)sFilterConfig->FilterIdHigh) << 16U) |
529 .loc 1 896 7 view .LVU172
898:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
530 .loc 1 898 22 is_stmt 0 view .LVU173
531 00be 8C88 ldrh r4, [r1, #4]
896:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ((0x0000FFFFU & (uint32_t)sFilterConfig->FilterIdHigh) << 16U) |
532 .loc 1 896 44 view .LVU174
533 00c0 4869 ldr r0, [r1, #20]
897:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (0x0000FFFFU & (uint32_t)sFilterConfig->FilterIdLow);
534 .loc 1 897 72 view .LVU175
535 00c2 0D68 ldr r5, [r1]
536 00c4 44EA0544 orr r4, r4, r5, lsl #16
896:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ((0x0000FFFFU & (uint32_t)sFilterConfig->FilterIdHigh) << 16U) |
537 .loc 1 896 62 view .LVU176
538 00c8 4830 adds r0, r0, #72
539 00ca 42F83040 str r4, [r2, r0, lsl #3]
901:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ((0x0000FFFFU & (uint32_t)sFilterConfig->FilterMaskIdHigh) << 16U) |
540 .loc 1 901 7 is_stmt 1 view .LVU177
903:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
541 .loc 1 903 22 is_stmt 0 view .LVU178
542 00ce 8C89 ldrh r4, [r1, #12]
901:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ((0x0000FFFFU & (uint32_t)sFilterConfig->FilterMaskIdHigh) << 16U) |
543 .loc 1 901 44 view .LVU179
544 00d0 4869 ldr r0, [r1, #20]
902:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (0x0000FFFFU & (uint32_t)sFilterConfig->FilterMaskIdLow);
545 .loc 1 902 76 view .LVU180
546 00d2 8D68 ldr r5, [r1, #8]
547 00d4 44EA0544 orr r4, r4, r5, lsl #16
901:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ((0x0000FFFFU & (uint32_t)sFilterConfig->FilterMaskIdHigh) << 16U) |
548 .loc 1 901 62 view .LVU181
549 00d8 4830 adds r0, r0, #72
550 00da 02EBC000 add r0, r2, r0, lsl #3
551 00de 4460 str r4, [r0, #4]
552 00e0 CCE7 b .L39
ARM GAS /tmp/ccj1aKCo.s page 30
553 .L40:
915:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
554 .loc 1 915 7 is_stmt 1 view .LVU182
555 00e2 D2F80402 ldr r0, [r2, #516]
556 00e6 1843 orrs r0, r0, r3
557 00e8 C2F80402 str r0, [r2, #516]
558 00ec CEE7 b .L41
559 .L42:
927:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
560 .loc 1 927 7 view .LVU183
561 00ee D2F81402 ldr r0, [r2, #532]
562 00f2 1843 orrs r0, r0, r3
563 00f4 C2F81402 str r0, [r2, #532]
564 00f8 D0E7 b .L43
565 .LVL26:
566 .L52:
933:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
567 .loc 1 933 7 view .LVU184
568 00fa D2F81C12 ldr r1, [r2, #540]
569 00fe 0B43 orrs r3, r3, r1
570 .LVL27:
933:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
571 .loc 1 933 7 is_stmt 0 view .LVU185
572 0100 C2F81C32 str r3, [r2, #540]
573 0104 CDE7 b .L44
574 .cfi_endproc
575 .LFE134:
577 .section .text.HAL_CAN_Start,"ax",%progbits
578 .align 1
579 .global HAL_CAN_Start
580 .syntax unified
581 .thumb
582 .thumb_func
584 HAL_CAN_Start:
585 .LVL28:
586 .LFB135:
950:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
951:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /**
952:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @}
953:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
954:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
955:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /** @defgroup CAN_Exported_Functions_Group3 Control functions
956:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @brief Control functions
957:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** *
958:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** @verbatim
959:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ==============================================================================
960:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ##### Control functions #####
961:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ==============================================================================
962:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** [..] This section provides functions allowing to:
963:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) HAL_CAN_Start : Start the CAN module
964:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) HAL_CAN_Stop : Stop the CAN module
965:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) HAL_CAN_RequestSleep : Request sleep mode entry.
966:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) HAL_CAN_WakeUp : Wake up from sleep mode.
967:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) HAL_CAN_IsSleepActive : Check is sleep mode is active.
968:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) HAL_CAN_AddTxMessage : Add a message to the Tx mailboxes
969:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** and activate the corresponding
970:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** transmission request
ARM GAS /tmp/ccj1aKCo.s page 31
971:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) HAL_CAN_AbortTxRequest : Abort transmission request
972:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) HAL_CAN_GetTxMailboxesFreeLevel : Return Tx mailboxes free level
973:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) HAL_CAN_IsTxMessagePending : Check if a transmission request is
974:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** pending on the selected Tx mailbox
975:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) HAL_CAN_GetRxMessage : Get a CAN frame from the Rx FIFO
976:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) HAL_CAN_GetRxFifoFillLevel : Return Rx FIFO fill level
977:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
978:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** @endverbatim
979:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @{
980:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
981:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
982:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /**
983:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @brief Start the CAN module.
984:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param hcan pointer to an CAN_HandleTypeDef structure that contains
985:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * the configuration information for the specified CAN.
986:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @retval HAL status
987:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
988:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_StatusTypeDef HAL_CAN_Start(CAN_HandleTypeDef *hcan)
989:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
587 .loc 1 989 1 is_stmt 1 view -0
588 .cfi_startproc
589 @ args = 0, pretend = 0, frame = 0
590 @ frame_needed = 0, uses_anonymous_args = 0
591 .loc 1 989 1 is_stmt 0 view .LVU187
592 0000 70B5 push {r4, r5, r6, lr}
593 .cfi_def_cfa_offset 16
594 .cfi_offset 4, -16
595 .cfi_offset 5, -12
596 .cfi_offset 6, -8
597 .cfi_offset 14, -4
598 0002 0446 mov r4, r0
990:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** uint32_t tickstart;
599 .loc 1 990 3 is_stmt 1 view .LVU188
991:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
992:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if (hcan->State == HAL_CAN_STATE_READY)
600 .loc 1 992 3 view .LVU189
601 .loc 1 992 11 is_stmt 0 view .LVU190
602 0004 90F82050 ldrb r5, [r0, #32] @ zero_extendqisi2
603 0008 EDB2 uxtb r5, r5
604 .loc 1 992 6 view .LVU191
605 000a 012D cmp r5, #1
606 000c 06D0 beq .L59
993:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
994:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Change CAN peripheral state */
995:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->State = HAL_CAN_STATE_LISTENING;
996:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
997:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Request leave initialisation */
998:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** CLEAR_BIT(hcan->Instance->MCR, CAN_MCR_INRQ);
999:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1000:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Get tick */
1001:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** tickstart = HAL_GetTick();
1002:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1003:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Wait the acknowledge */
1004:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** while ((hcan->Instance->MSR & CAN_MSR_INAK) != 0U)
1005:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1006:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Check for the Timeout */
1007:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((HAL_GetTick() - tickstart) > CAN_TIMEOUT_VALUE)
ARM GAS /tmp/ccj1aKCo.s page 32
1008:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1009:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Update error code */
1010:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->ErrorCode |= HAL_CAN_ERROR_TIMEOUT;
1011:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1012:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Change CAN state */
1013:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->State = HAL_CAN_STATE_ERROR;
1014:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1015:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** return HAL_ERROR;
1016:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1017:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1018:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1019:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Reset the CAN ErrorCode */
1020:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->ErrorCode = HAL_CAN_ERROR_NONE;
1021:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1022:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Return function status */
1023:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** return HAL_OK;
1024:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1025:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** else
1026:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1027:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Update error code */
1028:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->ErrorCode |= HAL_CAN_ERROR_NOT_READY;
607 .loc 1 1028 5 is_stmt 1 view .LVU192
608 .loc 1 1028 9 is_stmt 0 view .LVU193
609 000e 436A ldr r3, [r0, #36]
610 .loc 1 1028 21 view .LVU194
611 0010 43F40023 orr r3, r3, #524288
612 0014 4362 str r3, [r0, #36]
1029:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1030:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** return HAL_ERROR;
613 .loc 1 1030 5 is_stmt 1 view .LVU195
614 .loc 1 1030 12 is_stmt 0 view .LVU196
615 0016 0125 movs r5, #1
616 .LVL29:
617 .L56:
1031:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1032:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
618 .loc 1 1032 1 view .LVU197
619 0018 2846 mov r0, r5
620 001a 70BD pop {r4, r5, r6, pc}
621 .LVL30:
622 .L59:
995:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
623 .loc 1 995 5 is_stmt 1 view .LVU198
995:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
624 .loc 1 995 17 is_stmt 0 view .LVU199
625 001c 0223 movs r3, #2
626 001e 80F82030 strb r3, [r0, #32]
998:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
627 .loc 1 998 5 is_stmt 1 view .LVU200
628 0022 0268 ldr r2, [r0]
629 0024 1368 ldr r3, [r2]
630 0026 23F00103 bic r3, r3, #1
631 002a 1360 str r3, [r2]
1001:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
632 .loc 1 1001 5 view .LVU201
1001:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
633 .loc 1 1001 17 is_stmt 0 view .LVU202
ARM GAS /tmp/ccj1aKCo.s page 33
634 002c FFF7FEFF bl HAL_GetTick
635 .LVL31:
1001:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
636 .loc 1 1001 17 view .LVU203
637 0030 0646 mov r6, r0
638 .LVL32:
1004:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
639 .loc 1 1004 5 is_stmt 1 view .LVU204
640 .L55:
1004:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
641 .loc 1 1004 49 view .LVU205
1004:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
642 .loc 1 1004 17 is_stmt 0 view .LVU206
643 0032 2368 ldr r3, [r4]
1004:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
644 .loc 1 1004 27 view .LVU207
645 0034 5B68 ldr r3, [r3, #4]
1004:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
646 .loc 1 1004 49 view .LVU208
647 0036 13F0010F tst r3, #1
648 003a 0CD0 beq .L60
1007:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
649 .loc 1 1007 7 is_stmt 1 view .LVU209
1007:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
650 .loc 1 1007 12 is_stmt 0 view .LVU210
651 003c FFF7FEFF bl HAL_GetTick
652 .LVL33:
1007:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
653 .loc 1 1007 26 view .LVU211
654 0040 831B subs r3, r0, r6
1007:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
655 .loc 1 1007 10 view .LVU212
656 0042 0A2B cmp r3, #10
657 0044 F5D9 bls .L55
1010:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
658 .loc 1 1010 9 is_stmt 1 view .LVU213
1010:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
659 .loc 1 1010 13 is_stmt 0 view .LVU214
660 0046 636A ldr r3, [r4, #36]
1010:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
661 .loc 1 1010 25 view .LVU215
662 0048 43F40033 orr r3, r3, #131072
663 004c 6362 str r3, [r4, #36]
1013:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
664 .loc 1 1013 9 is_stmt 1 view .LVU216
1013:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
665 .loc 1 1013 21 is_stmt 0 view .LVU217
666 004e 0523 movs r3, #5
667 0050 84F82030 strb r3, [r4, #32]
1015:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
668 .loc 1 1015 9 is_stmt 1 view .LVU218
1015:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
669 .loc 1 1015 16 is_stmt 0 view .LVU219
670 0054 E0E7 b .L56
671 .L60:
1020:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
672 .loc 1 1020 5 is_stmt 1 view .LVU220
ARM GAS /tmp/ccj1aKCo.s page 34
1020:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
673 .loc 1 1020 21 is_stmt 0 view .LVU221
674 0056 0025 movs r5, #0
675 0058 6562 str r5, [r4, #36]
1023:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
676 .loc 1 1023 5 is_stmt 1 view .LVU222
1023:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
677 .loc 1 1023 12 is_stmt 0 view .LVU223
678 005a DDE7 b .L56
679 .cfi_endproc
680 .LFE135:
682 .section .text.HAL_CAN_Stop,"ax",%progbits
683 .align 1
684 .global HAL_CAN_Stop
685 .syntax unified
686 .thumb
687 .thumb_func
689 HAL_CAN_Stop:
690 .LVL34:
691 .LFB136:
1033:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1034:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /**
1035:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @brief Stop the CAN module and enable access to configuration registers.
1036:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param hcan pointer to an CAN_HandleTypeDef structure that contains
1037:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * the configuration information for the specified CAN.
1038:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @retval HAL status
1039:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
1040:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_StatusTypeDef HAL_CAN_Stop(CAN_HandleTypeDef *hcan)
1041:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
692 .loc 1 1041 1 is_stmt 1 view -0
693 .cfi_startproc
694 @ args = 0, pretend = 0, frame = 0
695 @ frame_needed = 0, uses_anonymous_args = 0
696 .loc 1 1041 1 is_stmt 0 view .LVU225
697 0000 38B5 push {r3, r4, r5, lr}
698 .cfi_def_cfa_offset 16
699 .cfi_offset 3, -16
700 .cfi_offset 4, -12
701 .cfi_offset 5, -8
702 .cfi_offset 14, -4
703 0002 0446 mov r4, r0
1042:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** uint32_t tickstart;
704 .loc 1 1042 3 is_stmt 1 view .LVU226
1043:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1044:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if (hcan->State == HAL_CAN_STATE_LISTENING)
705 .loc 1 1044 3 view .LVU227
706 .loc 1 1044 11 is_stmt 0 view .LVU228
707 0004 90F82030 ldrb r3, [r0, #32] @ zero_extendqisi2
708 0008 DBB2 uxtb r3, r3
709 .loc 1 1044 6 view .LVU229
710 000a 022B cmp r3, #2
711 000c 05D0 beq .L67
1045:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1046:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Request initialisation */
1047:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** SET_BIT(hcan->Instance->MCR, CAN_MCR_INRQ);
1048:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1049:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Get tick */
ARM GAS /tmp/ccj1aKCo.s page 35
1050:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** tickstart = HAL_GetTick();
1051:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1052:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Wait the acknowledge */
1053:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** while ((hcan->Instance->MSR & CAN_MSR_INAK) == 0U)
1054:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1055:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Check for the Timeout */
1056:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((HAL_GetTick() - tickstart) > CAN_TIMEOUT_VALUE)
1057:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1058:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Update error code */
1059:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->ErrorCode |= HAL_CAN_ERROR_TIMEOUT;
1060:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1061:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Change CAN state */
1062:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->State = HAL_CAN_STATE_ERROR;
1063:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1064:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** return HAL_ERROR;
1065:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1066:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1067:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1068:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Exit from sleep mode */
1069:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** CLEAR_BIT(hcan->Instance->MCR, CAN_MCR_SLEEP);
1070:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1071:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Change CAN peripheral state */
1072:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->State = HAL_CAN_STATE_READY;
1073:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1074:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Return function status */
1075:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** return HAL_OK;
1076:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1077:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** else
1078:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1079:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Update error code */
1080:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->ErrorCode |= HAL_CAN_ERROR_NOT_STARTED;
712 .loc 1 1080 5 is_stmt 1 view .LVU230
713 .loc 1 1080 9 is_stmt 0 view .LVU231
714 000e 436A ldr r3, [r0, #36]
715 .loc 1 1080 21 view .LVU232
716 0010 43F48013 orr r3, r3, #1048576
717 0014 4362 str r3, [r0, #36]
1081:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1082:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** return HAL_ERROR;
718 .loc 1 1082 5 is_stmt 1 view .LVU233
719 .loc 1 1082 12 is_stmt 0 view .LVU234
720 0016 0120 movs r0, #1
721 .LVL35:
722 .L64:
1083:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1084:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
723 .loc 1 1084 1 view .LVU235
724 0018 38BD pop {r3, r4, r5, pc}
725 .LVL36:
726 .L67:
1047:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
727 .loc 1 1047 5 is_stmt 1 view .LVU236
728 001a 0268 ldr r2, [r0]
729 001c 1368 ldr r3, [r2]
730 001e 43F00103 orr r3, r3, #1
731 0022 1360 str r3, [r2]
1050:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
ARM GAS /tmp/ccj1aKCo.s page 36
732 .loc 1 1050 5 view .LVU237
1050:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
733 .loc 1 1050 17 is_stmt 0 view .LVU238
734 0024 FFF7FEFF bl HAL_GetTick
735 .LVL37:
1050:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
736 .loc 1 1050 17 view .LVU239
737 0028 0546 mov r5, r0
738 .LVL38:
1053:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
739 .loc 1 1053 5 is_stmt 1 view .LVU240
740 .L63:
1053:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
741 .loc 1 1053 49 view .LVU241
1053:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
742 .loc 1 1053 17 is_stmt 0 view .LVU242
743 002a 2368 ldr r3, [r4]
1053:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
744 .loc 1 1053 27 view .LVU243
745 002c 5A68 ldr r2, [r3, #4]
1053:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
746 .loc 1 1053 49 view .LVU244
747 002e 12F0010F tst r2, #1
748 0032 0DD1 bne .L68
1056:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
749 .loc 1 1056 7 is_stmt 1 view .LVU245
1056:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
750 .loc 1 1056 12 is_stmt 0 view .LVU246
751 0034 FFF7FEFF bl HAL_GetTick
752 .LVL39:
1056:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
753 .loc 1 1056 26 view .LVU247
754 0038 431B subs r3, r0, r5
1056:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
755 .loc 1 1056 10 view .LVU248
756 003a 0A2B cmp r3, #10
757 003c F5D9 bls .L63
1059:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
758 .loc 1 1059 9 is_stmt 1 view .LVU249
1059:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
759 .loc 1 1059 13 is_stmt 0 view .LVU250
760 003e 636A ldr r3, [r4, #36]
1059:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
761 .loc 1 1059 25 view .LVU251
762 0040 43F40033 orr r3, r3, #131072
763 0044 6362 str r3, [r4, #36]
1062:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
764 .loc 1 1062 9 is_stmt 1 view .LVU252
1062:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
765 .loc 1 1062 21 is_stmt 0 view .LVU253
766 0046 0523 movs r3, #5
767 0048 84F82030 strb r3, [r4, #32]
1064:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
768 .loc 1 1064 9 is_stmt 1 view .LVU254
1064:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
769 .loc 1 1064 16 is_stmt 0 view .LVU255
770 004c 0120 movs r0, #1
ARM GAS /tmp/ccj1aKCo.s page 37
771 004e E3E7 b .L64
772 .L68:
1069:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
773 .loc 1 1069 5 is_stmt 1 view .LVU256
774 0050 1A68 ldr r2, [r3]
775 0052 22F00202 bic r2, r2, #2
776 0056 1A60 str r2, [r3]
1072:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
777 .loc 1 1072 5 view .LVU257
1072:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
778 .loc 1 1072 17 is_stmt 0 view .LVU258
779 0058 0123 movs r3, #1
780 005a 84F82030 strb r3, [r4, #32]
1075:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
781 .loc 1 1075 5 is_stmt 1 view .LVU259
1075:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
782 .loc 1 1075 12 is_stmt 0 view .LVU260
783 005e 0020 movs r0, #0
784 0060 DAE7 b .L64
785 .cfi_endproc
786 .LFE136:
788 .section .text.HAL_CAN_DeInit,"ax",%progbits
789 .align 1
790 .global HAL_CAN_DeInit
791 .syntax unified
792 .thumb
793 .thumb_func
795 HAL_CAN_DeInit:
796 .LVL40:
797 .LFB131:
460:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Check CAN handle */
798 .loc 1 460 1 is_stmt 1 view -0
799 .cfi_startproc
800 @ args = 0, pretend = 0, frame = 0
801 @ frame_needed = 0, uses_anonymous_args = 0
462:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
802 .loc 1 462 3 view .LVU262
462:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
803 .loc 1 462 6 is_stmt 0 view .LVU263
804 0000 80B1 cbz r0, .L71
460:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Check CAN handle */
805 .loc 1 460 1 view .LVU264
806 0002 10B5 push {r4, lr}
807 .cfi_def_cfa_offset 8
808 .cfi_offset 4, -8
809 .cfi_offset 14, -4
810 0004 0446 mov r4, r0
468:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
811 .loc 1 468 3 is_stmt 1 view .LVU265
471:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
812 .loc 1 471 3 view .LVU266
471:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
813 .loc 1 471 9 is_stmt 0 view .LVU267
814 0006 FFF7FEFF bl HAL_CAN_Stop
815 .LVL41:
484:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #endif /* (USE_HAL_CAN_REGISTER_CALLBACKS) */
816 .loc 1 484 3 is_stmt 1 view .LVU268
ARM GAS /tmp/ccj1aKCo.s page 38
817 000a 2046 mov r0, r4
818 000c FFF7FEFF bl HAL_CAN_MspDeInit
819 .LVL42:
488:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
820 .loc 1 488 3 view .LVU269
821 0010 2268 ldr r2, [r4]
822 0012 1368 ldr r3, [r2]
823 0014 43F40043 orr r3, r3, #32768
824 0018 1360 str r3, [r2]
491:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
825 .loc 1 491 3 view .LVU270
491:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
826 .loc 1 491 19 is_stmt 0 view .LVU271
827 001a 0020 movs r0, #0
828 001c 6062 str r0, [r4, #36]
494:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
829 .loc 1 494 3 is_stmt 1 view .LVU272
494:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
830 .loc 1 494 15 is_stmt 0 view .LVU273
831 001e 84F82000 strb r0, [r4, #32]
497:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
832 .loc 1 497 3 is_stmt 1 view .LVU274
498:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
833 .loc 1 498 1 is_stmt 0 view .LVU275
834 0022 10BD pop {r4, pc}
835 .LVL43:
836 .L71:
837 .cfi_def_cfa_offset 0
838 .cfi_restore 4
839 .cfi_restore 14
464:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
840 .loc 1 464 12 view .LVU276
841 0024 0120 movs r0, #1
842 .LVL44:
498:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
843 .loc 1 498 1 view .LVU277
844 0026 7047 bx lr
845 .cfi_endproc
846 .LFE131:
848 .section .text.HAL_CAN_RequestSleep,"ax",%progbits
849 .align 1
850 .global HAL_CAN_RequestSleep
851 .syntax unified
852 .thumb
853 .thumb_func
855 HAL_CAN_RequestSleep:
856 .LVL45:
857 .LFB137:
1085:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1086:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /**
1087:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @brief Request the sleep mode (low power) entry.
1088:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * When returning from this function, Sleep mode will be entered
1089:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * as soon as the current CAN activity (transmission or reception
1090:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * of a CAN frame) has been completed.
1091:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param hcan pointer to a CAN_HandleTypeDef structure that contains
1092:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * the configuration information for the specified CAN.
1093:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @retval HAL status.
ARM GAS /tmp/ccj1aKCo.s page 39
1094:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
1095:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_StatusTypeDef HAL_CAN_RequestSleep(CAN_HandleTypeDef *hcan)
1096:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
858 .loc 1 1096 1 is_stmt 1 view -0
859 .cfi_startproc
860 @ args = 0, pretend = 0, frame = 0
861 @ frame_needed = 0, uses_anonymous_args = 0
862 @ link register save eliminated.
1097:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_StateTypeDef state = hcan->State;
863 .loc 1 1097 3 view .LVU279
864 .loc 1 1097 24 is_stmt 0 view .LVU280
865 0000 90F82030 ldrb r3, [r0, #32] @ zero_extendqisi2
866 .LVL46:
1098:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1099:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((state == HAL_CAN_STATE_READY) ||
867 .loc 1 1099 3 is_stmt 1 view .LVU281
868 .loc 1 1099 38 is_stmt 0 view .LVU282
869 0004 013B subs r3, r3, #1
870 .LVL47:
871 .loc 1 1099 38 view .LVU283
872 0006 DBB2 uxtb r3, r3
873 .loc 1 1099 6 view .LVU284
874 0008 012B cmp r3, #1
875 000a 05D9 bls .L79
1100:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (state == HAL_CAN_STATE_LISTENING))
1101:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1102:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Request Sleep mode */
1103:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** SET_BIT(hcan->Instance->MCR, CAN_MCR_SLEEP);
1104:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1105:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Return function status */
1106:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** return HAL_OK;
1107:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1108:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** else
1109:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1110:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Update error code */
1111:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->ErrorCode |= HAL_CAN_ERROR_NOT_INITIALIZED;
876 .loc 1 1111 5 is_stmt 1 view .LVU285
877 .loc 1 1111 9 is_stmt 0 view .LVU286
878 000c 436A ldr r3, [r0, #36]
879 .loc 1 1111 21 view .LVU287
880 000e 43F48023 orr r3, r3, #262144
881 0012 4362 str r3, [r0, #36]
1112:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1113:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Return function status */
1114:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** return HAL_ERROR;
882 .loc 1 1114 5 is_stmt 1 view .LVU288
883 .loc 1 1114 12 is_stmt 0 view .LVU289
884 0014 0120 movs r0, #1
885 .LVL48:
1115:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1116:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
886 .loc 1 1116 1 view .LVU290
887 0016 7047 bx lr
888 .LVL49:
889 .L79:
1103:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
890 .loc 1 1103 5 is_stmt 1 view .LVU291
ARM GAS /tmp/ccj1aKCo.s page 40
891 0018 0268 ldr r2, [r0]
892 001a 1368 ldr r3, [r2]
893 001c 43F00203 orr r3, r3, #2
894 0020 1360 str r3, [r2]
1106:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
895 .loc 1 1106 5 view .LVU292
1106:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
896 .loc 1 1106 12 is_stmt 0 view .LVU293
897 0022 0020 movs r0, #0
898 .LVL50:
1106:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
899 .loc 1 1106 12 view .LVU294
900 0024 7047 bx lr
901 .cfi_endproc
902 .LFE137:
904 .section .text.HAL_CAN_WakeUp,"ax",%progbits
905 .align 1
906 .global HAL_CAN_WakeUp
907 .syntax unified
908 .thumb
909 .thumb_func
911 HAL_CAN_WakeUp:
912 .LVL51:
913 .LFB138:
1117:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1118:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /**
1119:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @brief Wake up from sleep mode.
1120:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * When returning with HAL_OK status from this function, Sleep mode
1121:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * is exited.
1122:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param hcan pointer to a CAN_HandleTypeDef structure that contains
1123:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * the configuration information for the specified CAN.
1124:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @retval HAL status.
1125:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
1126:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_StatusTypeDef HAL_CAN_WakeUp(CAN_HandleTypeDef *hcan)
1127:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
914 .loc 1 1127 1 is_stmt 1 view -0
915 .cfi_startproc
916 @ args = 0, pretend = 0, frame = 8
917 @ frame_needed = 0, uses_anonymous_args = 0
918 @ link register save eliminated.
919 .loc 1 1127 1 is_stmt 0 view .LVU296
920 0000 82B0 sub sp, sp, #8
921 .cfi_def_cfa_offset 8
1128:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** __IO uint32_t count = 0;
922 .loc 1 1128 3 is_stmt 1 view .LVU297
923 .loc 1 1128 17 is_stmt 0 view .LVU298
924 0002 0023 movs r3, #0
925 0004 0193 str r3, [sp, #4]
1129:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** uint32_t timeout = 1000000U;
926 .loc 1 1129 3 is_stmt 1 view .LVU299
927 .LVL52:
1130:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_StateTypeDef state = hcan->State;
928 .loc 1 1130 3 view .LVU300
929 .loc 1 1130 24 is_stmt 0 view .LVU301
930 0006 90F82030 ldrb r3, [r0, #32] @ zero_extendqisi2
931 .LVL53:
1131:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
ARM GAS /tmp/ccj1aKCo.s page 41
1132:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((state == HAL_CAN_STATE_READY) ||
932 .loc 1 1132 3 is_stmt 1 view .LVU302
933 .loc 1 1132 38 is_stmt 0 view .LVU303
934 000a 013B subs r3, r3, #1
935 .LVL54:
936 .loc 1 1132 38 view .LVU304
937 000c DBB2 uxtb r3, r3
938 .loc 1 1132 6 view .LVU305
939 000e 012B cmp r3, #1
940 0010 18D8 bhi .L81
1133:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (state == HAL_CAN_STATE_LISTENING))
1134:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1135:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Wake up request */
1136:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** CLEAR_BIT(hcan->Instance->MCR, CAN_MCR_SLEEP);
941 .loc 1 1136 5 is_stmt 1 view .LVU306
942 0012 0268 ldr r2, [r0]
943 0014 1368 ldr r3, [r2]
944 0016 23F00203 bic r3, r3, #2
945 001a 1360 str r3, [r2]
946 .L84:
1137:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1138:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Wait sleep mode is exited */
1139:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** do
947 .loc 1 1139 5 view .LVU307
1140:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1141:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Increment counter */
1142:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** count++;
948 .loc 1 1142 7 view .LVU308
949 .loc 1 1142 12 is_stmt 0 view .LVU309
950 001c 019B ldr r3, [sp, #4]
951 001e 0133 adds r3, r3, #1
952 0020 0193 str r3, [sp, #4]
1143:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1144:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Check if timeout is reached */
1145:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if (count > timeout)
953 .loc 1 1145 7 is_stmt 1 view .LVU310
954 .loc 1 1145 17 is_stmt 0 view .LVU311
955 0022 019A ldr r2, [sp, #4]
956 .loc 1 1145 10 view .LVU312
957 0024 0B4B ldr r3, .L87
958 0026 9A42 cmp r2, r3
959 0028 06D8 bhi .L86
1146:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1147:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Update error code */
1148:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->ErrorCode |= HAL_CAN_ERROR_TIMEOUT;
1149:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1150:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** return HAL_ERROR;
1151:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1152:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1153:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** while ((hcan->Instance->MSR & CAN_MSR_SLAK) != 0U);
960 .loc 1 1153 49 is_stmt 1 view .LVU313
961 .loc 1 1153 17 is_stmt 0 view .LVU314
962 002a 0368 ldr r3, [r0]
963 .loc 1 1153 27 view .LVU315
964 002c 5B68 ldr r3, [r3, #4]
965 .loc 1 1153 49 view .LVU316
966 002e 13F0020F tst r3, #2
ARM GAS /tmp/ccj1aKCo.s page 42
967 0032 F3D1 bne .L84
1154:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1155:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Return function status */
1156:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** return HAL_OK;
968 .loc 1 1156 12 view .LVU317
969 0034 0020 movs r0, #0
970 .LVL55:
971 .loc 1 1156 12 view .LVU318
972 0036 0AE0 b .L83
973 .LVL56:
974 .L86:
1148:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
975 .loc 1 1148 9 is_stmt 1 view .LVU319
1148:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
976 .loc 1 1148 13 is_stmt 0 view .LVU320
977 0038 436A ldr r3, [r0, #36]
1148:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
978 .loc 1 1148 25 view .LVU321
979 003a 43F40033 orr r3, r3, #131072
980 003e 4362 str r3, [r0, #36]
1150:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
981 .loc 1 1150 9 is_stmt 1 view .LVU322
1150:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
982 .loc 1 1150 16 is_stmt 0 view .LVU323
983 0040 0120 movs r0, #1
984 .LVL57:
1150:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
985 .loc 1 1150 16 view .LVU324
986 0042 04E0 b .L83
987 .LVL58:
988 .L81:
1157:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1158:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** else
1159:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1160:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Update error code */
1161:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->ErrorCode |= HAL_CAN_ERROR_NOT_INITIALIZED;
989 .loc 1 1161 5 is_stmt 1 view .LVU325
990 .loc 1 1161 9 is_stmt 0 view .LVU326
991 0044 436A ldr r3, [r0, #36]
992 .loc 1 1161 21 view .LVU327
993 0046 43F48023 orr r3, r3, #262144
994 004a 4362 str r3, [r0, #36]
1162:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1163:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** return HAL_ERROR;
995 .loc 1 1163 5 is_stmt 1 view .LVU328
996 .loc 1 1163 12 is_stmt 0 view .LVU329
997 004c 0120 movs r0, #1
998 .LVL59:
999 .L83:
1164:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1165:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1000 .loc 1 1165 1 view .LVU330
1001 004e 02B0 add sp, sp, #8
1002 .cfi_def_cfa_offset 0
1003 @ sp needed
1004 0050 7047 bx lr
1005 .L88:
ARM GAS /tmp/ccj1aKCo.s page 43
1006 0052 00BF .align 2
1007 .L87:
1008 0054 40420F00 .word 1000000
1009 .cfi_endproc
1010 .LFE138:
1012 .section .text.HAL_CAN_IsSleepActive,"ax",%progbits
1013 .align 1
1014 .global HAL_CAN_IsSleepActive
1015 .syntax unified
1016 .thumb
1017 .thumb_func
1019 HAL_CAN_IsSleepActive:
1020 .LVL60:
1021 .LFB139:
1166:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1167:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /**
1168:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @brief Check is sleep mode is active.
1169:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param hcan pointer to a CAN_HandleTypeDef structure that contains
1170:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * the configuration information for the specified CAN.
1171:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @retval Status
1172:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * - 0 : Sleep mode is not active.
1173:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * - 1 : Sleep mode is active.
1174:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
1175:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** uint32_t HAL_CAN_IsSleepActive(CAN_HandleTypeDef *hcan)
1176:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1022 .loc 1 1176 1 is_stmt 1 view -0
1023 .cfi_startproc
1024 @ args = 0, pretend = 0, frame = 0
1025 @ frame_needed = 0, uses_anonymous_args = 0
1026 @ link register save eliminated.
1177:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** uint32_t status = 0U;
1027 .loc 1 1177 3 view .LVU332
1178:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_StateTypeDef state = hcan->State;
1028 .loc 1 1178 3 view .LVU333
1029 .loc 1 1178 24 is_stmt 0 view .LVU334
1030 0000 90F82030 ldrb r3, [r0, #32] @ zero_extendqisi2
1031 .LVL61:
1179:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1180:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((state == HAL_CAN_STATE_READY) ||
1032 .loc 1 1180 3 is_stmt 1 view .LVU335
1033 .loc 1 1180 38 is_stmt 0 view .LVU336
1034 0004 013B subs r3, r3, #1
1035 .LVL62:
1036 .loc 1 1180 38 view .LVU337
1037 0006 DBB2 uxtb r3, r3
1038 .loc 1 1180 6 view .LVU338
1039 0008 012B cmp r3, #1
1040 000a 01D9 bls .L93
1177:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_StateTypeDef state = hcan->State;
1041 .loc 1 1177 12 view .LVU339
1042 000c 0020 movs r0, #0
1043 .LVL63:
1177:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_StateTypeDef state = hcan->State;
1044 .loc 1 1177 12 view .LVU340
1045 000e 7047 bx lr
1046 .LVL64:
1047 .L93:
ARM GAS /tmp/ccj1aKCo.s page 44
1181:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (state == HAL_CAN_STATE_LISTENING))
1182:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1183:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Check Sleep mode */
1184:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((hcan->Instance->MSR & CAN_MSR_SLAK) != 0U)
1048 .loc 1 1184 5 is_stmt 1 view .LVU341
1049 .loc 1 1184 14 is_stmt 0 view .LVU342
1050 0010 0368 ldr r3, [r0]
1051 .loc 1 1184 24 view .LVU343
1052 0012 5868 ldr r0, [r3, #4]
1053 .LVL65:
1054 .loc 1 1184 8 view .LVU344
1055 0014 10F00200 ands r0, r0, #2
1056 0018 00D1 bne .L92
1057 001a 7047 bx lr
1058 .L92:
1185:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1186:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** status = 1U;
1059 .loc 1 1186 14 view .LVU345
1060 001c 0120 movs r0, #1
1061 .LVL66:
1187:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1188:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1189:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1190:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Return function status */
1191:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** return status;
1062 .loc 1 1191 3 is_stmt 1 view .LVU346
1192:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1063 .loc 1 1192 1 is_stmt 0 view .LVU347
1064 001e 7047 bx lr
1065 .cfi_endproc
1066 .LFE139:
1068 .section .text.HAL_CAN_AddTxMessage,"ax",%progbits
1069 .align 1
1070 .global HAL_CAN_AddTxMessage
1071 .syntax unified
1072 .thumb
1073 .thumb_func
1075 HAL_CAN_AddTxMessage:
1076 .LVL67:
1077 .LFB140:
1193:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1194:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /**
1195:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @brief Add a message to the first free Tx mailbox and activate the
1196:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * corresponding transmission request.
1197:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param hcan pointer to a CAN_HandleTypeDef structure that contains
1198:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * the configuration information for the specified CAN.
1199:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param pHeader pointer to a CAN_TxHeaderTypeDef structure.
1200:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param aData array containing the payload of the Tx frame.
1201:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param pTxMailbox pointer to a variable where the function will return
1202:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * the TxMailbox used to store the Tx message.
1203:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * This parameter can be a value of @arg CAN_Tx_Mailboxes.
1204:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @retval HAL status
1205:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
1206:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_StatusTypeDef HAL_CAN_AddTxMessage(CAN_HandleTypeDef *hcan, CAN_TxHeaderTypeDef *pHeader, uint8
1207:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1078 .loc 1 1207 1 is_stmt 1 view -0
1079 .cfi_startproc
ARM GAS /tmp/ccj1aKCo.s page 45
1080 @ args = 0, pretend = 0, frame = 0
1081 @ frame_needed = 0, uses_anonymous_args = 0
1082 .loc 1 1207 1 is_stmt 0 view .LVU349
1083 0000 30B5 push {r4, r5, lr}
1084 .cfi_def_cfa_offset 12
1085 .cfi_offset 4, -12
1086 .cfi_offset 5, -8
1087 .cfi_offset 14, -4
1208:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** uint32_t transmitmailbox;
1088 .loc 1 1208 3 is_stmt 1 view .LVU350
1209:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_StateTypeDef state = hcan->State;
1089 .loc 1 1209 3 view .LVU351
1090 .loc 1 1209 24 is_stmt 0 view .LVU352
1091 0002 90F820C0 ldrb ip, [r0, #32] @ zero_extendqisi2
1092 .LVL68:
1210:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** uint32_t tsr = READ_REG(hcan->Instance->TSR);
1093 .loc 1 1210 3 is_stmt 1 view .LVU353
1094 .loc 1 1210 12 is_stmt 0 view .LVU354
1095 0006 0468 ldr r4, [r0]
1096 0008 A468 ldr r4, [r4, #8]
1097 .LVL69:
1211:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1212:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Check the parameters */
1213:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_CAN_IDTYPE(pHeader->IDE));
1098 .loc 1 1213 3 is_stmt 1 view .LVU355
1214:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_CAN_RTR(pHeader->RTR));
1099 .loc 1 1214 3 view .LVU356
1215:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_CAN_DLC(pHeader->DLC));
1100 .loc 1 1215 3 view .LVU357
1216:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if (pHeader->IDE == CAN_ID_STD)
1101 .loc 1 1216 3 view .LVU358
1217:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1218:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_CAN_STDID(pHeader->StdId));
1219:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1220:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** else
1221:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1222:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_CAN_EXTID(pHeader->ExtId));
1102 .loc 1 1222 5 view .LVU359
1223:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1224:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_FUNCTIONAL_STATE(pHeader->TransmitGlobalTime));
1103 .loc 1 1224 3 view .LVU360
1225:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1226:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((state == HAL_CAN_STATE_READY) ||
1104 .loc 1 1226 3 view .LVU361
1105 .loc 1 1226 38 is_stmt 0 view .LVU362
1106 000a 0CF1FF3C add ip, ip, #-1
1107 .LVL70:
1108 .loc 1 1226 38 view .LVU363
1109 000e 5FFA8CFC uxtb ip, ip
1110 .loc 1 1226 6 view .LVU364
1111 0012 BCF1010F cmp ip, #1
1112 0016 6BD8 bhi .L95
1227:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (state == HAL_CAN_STATE_LISTENING))
1228:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1229:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Check that all the Tx mailboxes are not full */
1230:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if (((tsr & CAN_TSR_TME0) != 0U) ||
1113 .loc 1 1230 5 is_stmt 1 view .LVU365
ARM GAS /tmp/ccj1aKCo.s page 46
1114 .loc 1 1230 8 is_stmt 0 view .LVU366
1115 0018 14F0E05F tst r4, #469762048
1116 001c 62D0 beq .L96
1231:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ((tsr & CAN_TSR_TME1) != 0U) ||
1232:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ((tsr & CAN_TSR_TME2) != 0U))
1233:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1234:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Select an empty transmit mailbox */
1235:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** transmitmailbox = (tsr & CAN_TSR_CODE) >> CAN_TSR_CODE_Pos;
1117 .loc 1 1235 7 is_stmt 1 view .LVU367
1118 .loc 1 1235 23 is_stmt 0 view .LVU368
1119 001e C4F3016C ubfx ip, r4, #24, #2
1120 .LVL71:
1236:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1237:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Check transmit mailbox value */
1238:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if (transmitmailbox > 2U)
1121 .loc 1 1238 7 is_stmt 1 view .LVU369
1122 .loc 1 1238 10 is_stmt 0 view .LVU370
1123 0022 BCF1020F cmp ip, #2
1124 0026 05D9 bls .L97
1239:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1240:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Update error code */
1241:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->ErrorCode |= HAL_CAN_ERROR_INTERNAL;
1125 .loc 1 1241 9 is_stmt 1 view .LVU371
1126 .loc 1 1241 13 is_stmt 0 view .LVU372
1127 0028 436A ldr r3, [r0, #36]
1128 .LVL72:
1129 .loc 1 1241 25 view .LVU373
1130 002a 43F40003 orr r3, r3, #8388608
1131 002e 4362 str r3, [r0, #36]
1242:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1243:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** return HAL_ERROR;
1132 .loc 1 1243 9 is_stmt 1 view .LVU374
1133 .loc 1 1243 16 is_stmt 0 view .LVU375
1134 0030 0120 movs r0, #1
1135 .LVL73:
1136 .loc 1 1243 16 view .LVU376
1137 0032 62E0 b .L98
1138 .LVL74:
1139 .L97:
1244:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1245:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1246:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Store the Tx mailbox */
1247:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** *pTxMailbox = (uint32_t)1 << transmitmailbox;
1140 .loc 1 1247 7 is_stmt 1 view .LVU377
1141 .loc 1 1247 33 is_stmt 0 view .LVU378
1142 0034 0124 movs r4, #1
1143 .LVL75:
1144 .loc 1 1247 33 view .LVU379
1145 0036 04FA0CF4 lsl r4, r4, ip
1146 .loc 1 1247 19 view .LVU380
1147 003a 1C60 str r4, [r3]
1248:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1249:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Set up the Id */
1250:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if (pHeader->IDE == CAN_ID_STD)
1148 .loc 1 1250 7 is_stmt 1 view .LVU381
1149 .loc 1 1250 18 is_stmt 0 view .LVU382
1150 003c 8B68 ldr r3, [r1, #8]
ARM GAS /tmp/ccj1aKCo.s page 47
1151 .LVL76:
1152 .loc 1 1250 10 view .LVU383
1153 003e 002B cmp r3, #0
1154 0040 3DD1 bne .L99
1251:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1252:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->Instance->sTxMailBox[transmitmailbox].TIR = ((pHeader->StdId << CAN_TI0R_STID_Pos) |
1155 .loc 1 1252 9 is_stmt 1 view .LVU384
1156 .loc 1 1252 68 is_stmt 0 view .LVU385
1157 0042 0D68 ldr r5, [r1]
1253:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** pHeader->RTR);
1158 .loc 1 1253 67 view .LVU386
1159 0044 CB68 ldr r3, [r1, #12]
1252:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** pHeader->RTR);
1160 .loc 1 1252 13 view .LVU387
1161 0046 0468 ldr r4, [r0]
1252:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** pHeader->RTR);
1162 .loc 1 1252 98 view .LVU388
1163 0048 43EA4555 orr r5, r3, r5, lsl #21
1252:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** pHeader->RTR);
1164 .loc 1 1252 57 view .LVU389
1165 004c 0CF11803 add r3, ip, #24
1166 0050 1B01 lsls r3, r3, #4
1167 0052 E550 str r5, [r4, r3]
1168 .L100:
1254:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1255:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** else
1256:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1257:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->Instance->sTxMailBox[transmitmailbox].TIR = ((pHeader->ExtId << CAN_TI0R_EXID_Pos) |
1258:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** pHeader->IDE |
1259:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** pHeader->RTR);
1260:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1261:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1262:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Set up the DLC */
1263:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->Instance->sTxMailBox[transmitmailbox].TDTR = (pHeader->DLC);
1169 .loc 1 1263 7 is_stmt 1 view .LVU390
1170 .loc 1 1263 11 is_stmt 0 view .LVU391
1171 0054 0368 ldr r3, [r0]
1172 .loc 1 1263 66 view .LVU392
1173 0056 0C69 ldr r4, [r1, #16]
1174 .loc 1 1263 56 view .LVU393
1175 0058 0CF1180E add lr, ip, #24
1176 005c 03EB0E13 add r3, r3, lr, lsl #4
1177 0060 5C60 str r4, [r3, #4]
1264:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1265:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Set up the Transmit Global Time mode */
1266:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if (pHeader->TransmitGlobalTime == ENABLE)
1178 .loc 1 1266 7 is_stmt 1 view .LVU394
1179 .loc 1 1266 18 is_stmt 0 view .LVU395
1180 0062 0B7D ldrb r3, [r1, #20] @ zero_extendqisi2
1181 .loc 1 1266 10 view .LVU396
1182 0064 012B cmp r3, #1
1183 0066 35D0 beq .L103
1184 .LVL77:
1185 .L101:
1267:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1268:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** SET_BIT(hcan->Instance->sTxMailBox[transmitmailbox].TDTR, CAN_TDT0R_TGT);
1269:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
ARM GAS /tmp/ccj1aKCo.s page 48
1270:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1271:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Set up the data field */
1272:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** WRITE_REG(hcan->Instance->sTxMailBox[transmitmailbox].TDHR,
1186 .loc 1 1272 7 is_stmt 1 view .LVU397
1187 0068 D179 ldrb r1, [r2, #7] @ zero_extendqisi2
1188 006a 9379 ldrb r3, [r2, #6] @ zero_extendqisi2
1189 006c 1B04 lsls r3, r3, #16
1190 006e 43EA0163 orr r3, r3, r1, lsl #24
1191 0072 5179 ldrb r1, [r2, #5] @ zero_extendqisi2
1192 0074 43EA0123 orr r3, r3, r1, lsl #8
1193 0078 1479 ldrb r4, [r2, #4] @ zero_extendqisi2
1194 007a 0168 ldr r1, [r0]
1195 007c 2343 orrs r3, r3, r4
1196 007e 01EB0C11 add r1, r1, ip, lsl #4
1197 0082 C1F88C31 str r3, [r1, #396]
1273:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ((uint32_t)aData[7] << CAN_TDH0R_DATA7_Pos) |
1274:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ((uint32_t)aData[6] << CAN_TDH0R_DATA6_Pos) |
1275:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ((uint32_t)aData[5] << CAN_TDH0R_DATA5_Pos) |
1276:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ((uint32_t)aData[4] << CAN_TDH0R_DATA4_Pos));
1277:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** WRITE_REG(hcan->Instance->sTxMailBox[transmitmailbox].TDLR,
1198 .loc 1 1277 7 view .LVU398
1199 0086 D178 ldrb r1, [r2, #3] @ zero_extendqisi2
1200 0088 9378 ldrb r3, [r2, #2] @ zero_extendqisi2
1201 008a 1B04 lsls r3, r3, #16
1202 008c 43EA0163 orr r3, r3, r1, lsl #24
1203 0090 5178 ldrb r1, [r2, #1] @ zero_extendqisi2
1204 0092 43EA0123 orr r3, r3, r1, lsl #8
1205 0096 1178 ldrb r1, [r2] @ zero_extendqisi2
1206 0098 0268 ldr r2, [r0]
1207 .LVL78:
1208 .loc 1 1277 7 is_stmt 0 view .LVU399
1209 009a 0B43 orrs r3, r3, r1
1210 009c 02EB0C12 add r2, r2, ip, lsl #4
1211 00a0 C2F88831 str r3, [r2, #392]
1278:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ((uint32_t)aData[3] << CAN_TDL0R_DATA3_Pos) |
1279:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ((uint32_t)aData[2] << CAN_TDL0R_DATA2_Pos) |
1280:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ((uint32_t)aData[1] << CAN_TDL0R_DATA1_Pos) |
1281:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ((uint32_t)aData[0] << CAN_TDL0R_DATA0_Pos));
1282:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1283:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Request transmission */
1284:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** SET_BIT(hcan->Instance->sTxMailBox[transmitmailbox].TIR, CAN_TI0R_TXRQ);
1212 .loc 1 1284 7 is_stmt 1 view .LVU400
1213 00a4 0268 ldr r2, [r0]
1214 00a6 0CF1180C add ip, ip, #24
1215 .LVL79:
1216 .loc 1 1284 7 is_stmt 0 view .LVU401
1217 00aa 4FEA0C1C lsl ip, ip, #4
1218 00ae 52F80C30 ldr r3, [r2, ip]
1219 00b2 43F00103 orr r3, r3, #1
1220 00b6 42F80C30 str r3, [r2, ip]
1285:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1286:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Return function status */
1287:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** return HAL_OK;
1221 .loc 1 1287 7 is_stmt 1 view .LVU402
1222 .loc 1 1287 14 is_stmt 0 view .LVU403
1223 00ba 0020 movs r0, #0
1224 .LVL80:
ARM GAS /tmp/ccj1aKCo.s page 49
1225 .loc 1 1287 14 view .LVU404
1226 00bc 1DE0 b .L98
1227 .LVL81:
1228 .L99:
1257:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** pHeader->IDE |
1229 .loc 1 1257 9 is_stmt 1 view .LVU405
1257:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** pHeader->IDE |
1230 .loc 1 1257 68 is_stmt 0 view .LVU406
1231 00be 4C68 ldr r4, [r1, #4]
1257:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** pHeader->IDE |
1232 .loc 1 1257 98 view .LVU407
1233 00c0 43EAC403 orr r3, r3, r4, lsl #3
1259:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1234 .loc 1 1259 67 view .LVU408
1235 00c4 CC68 ldr r4, [r1, #12]
1258:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** pHeader->RTR);
1236 .loc 1 1258 73 view .LVU409
1237 00c6 2343 orrs r3, r3, r4
1257:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** pHeader->IDE |
1238 .loc 1 1257 57 view .LVU410
1239 00c8 0CF11804 add r4, ip, #24
1240 00cc 2401 lsls r4, r4, #4
1241 00ce 0568 ldr r5, [r0]
1242 00d0 2B51 str r3, [r5, r4]
1243 00d2 BFE7 b .L100
1244 .L103:
1268:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1245 .loc 1 1268 9 is_stmt 1 view .LVU411
1246 00d4 0368 ldr r3, [r0]
1247 00d6 03EB0E13 add r3, r3, lr, lsl #4
1248 00da 5968 ldr r1, [r3, #4]
1249 .LVL82:
1268:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1250 .loc 1 1268 9 is_stmt 0 view .LVU412
1251 00dc 41F48071 orr r1, r1, #256
1252 00e0 5960 str r1, [r3, #4]
1253 00e2 C1E7 b .L101
1254 .LVL83:
1255 .L96:
1288:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1289:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** else
1290:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1291:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Update error code */
1292:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->ErrorCode |= HAL_CAN_ERROR_PARAM;
1256 .loc 1 1292 7 is_stmt 1 view .LVU413
1257 .loc 1 1292 11 is_stmt 0 view .LVU414
1258 00e4 436A ldr r3, [r0, #36]
1259 .LVL84:
1260 .loc 1 1292 23 view .LVU415
1261 00e6 43F40013 orr r3, r3, #2097152
1262 00ea 4362 str r3, [r0, #36]
1293:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1294:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** return HAL_ERROR;
1263 .loc 1 1294 7 is_stmt 1 view .LVU416
1264 .loc 1 1294 14 is_stmt 0 view .LVU417
1265 00ec 0120 movs r0, #1
1266 .LVL85:
ARM GAS /tmp/ccj1aKCo.s page 50
1267 .loc 1 1294 14 view .LVU418
1268 00ee 04E0 b .L98
1269 .LVL86:
1270 .L95:
1295:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1296:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1297:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** else
1298:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1299:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Update error code */
1300:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->ErrorCode |= HAL_CAN_ERROR_NOT_INITIALIZED;
1271 .loc 1 1300 5 is_stmt 1 view .LVU419
1272 .loc 1 1300 9 is_stmt 0 view .LVU420
1273 00f0 436A ldr r3, [r0, #36]
1274 .LVL87:
1275 .loc 1 1300 21 view .LVU421
1276 00f2 43F48023 orr r3, r3, #262144
1277 00f6 4362 str r3, [r0, #36]
1301:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1302:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** return HAL_ERROR;
1278 .loc 1 1302 5 is_stmt 1 view .LVU422
1279 .loc 1 1302 12 is_stmt 0 view .LVU423
1280 00f8 0120 movs r0, #1
1281 .LVL88:
1282 .L98:
1303:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1304:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1283 .loc 1 1304 1 view .LVU424
1284 00fa 30BD pop {r4, r5, pc}
1285 .cfi_endproc
1286 .LFE140:
1288 .section .text.HAL_CAN_AbortTxRequest,"ax",%progbits
1289 .align 1
1290 .global HAL_CAN_AbortTxRequest
1291 .syntax unified
1292 .thumb
1293 .thumb_func
1295 HAL_CAN_AbortTxRequest:
1296 .LVL89:
1297 .LFB141:
1305:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1306:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /**
1307:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @brief Abort transmission requests
1308:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param hcan pointer to an CAN_HandleTypeDef structure that contains
1309:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * the configuration information for the specified CAN.
1310:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param TxMailboxes List of the Tx Mailboxes to abort.
1311:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * This parameter can be any combination of @arg CAN_Tx_Mailboxes.
1312:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @retval HAL status
1313:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
1314:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_StatusTypeDef HAL_CAN_AbortTxRequest(CAN_HandleTypeDef *hcan, uint32_t TxMailboxes)
1315:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1298 .loc 1 1315 1 is_stmt 1 view -0
1299 .cfi_startproc
1300 @ args = 0, pretend = 0, frame = 0
1301 @ frame_needed = 0, uses_anonymous_args = 0
1302 @ link register save eliminated.
1316:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_StateTypeDef state = hcan->State;
1303 .loc 1 1316 3 view .LVU426
ARM GAS /tmp/ccj1aKCo.s page 51
1304 .loc 1 1316 24 is_stmt 0 view .LVU427
1305 0000 90F82030 ldrb r3, [r0, #32] @ zero_extendqisi2
1306 .LVL90:
1317:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1318:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Check function parameters */
1319:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_CAN_TX_MAILBOX_LIST(TxMailboxes));
1307 .loc 1 1319 3 is_stmt 1 view .LVU428
1320:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1321:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((state == HAL_CAN_STATE_READY) ||
1308 .loc 1 1321 3 view .LVU429
1309 .loc 1 1321 38 is_stmt 0 view .LVU430
1310 0004 013B subs r3, r3, #1
1311 .LVL91:
1312 .loc 1 1321 38 view .LVU431
1313 0006 DBB2 uxtb r3, r3
1314 .loc 1 1321 6 view .LVU432
1315 0008 012B cmp r3, #1
1316 000a 05D9 bls .L110
1322:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (state == HAL_CAN_STATE_LISTENING))
1323:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1324:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Check Tx Mailbox 0 */
1325:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((TxMailboxes & CAN_TX_MAILBOX0) != 0U)
1326:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1327:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Add cancellation request for Tx Mailbox 0 */
1328:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** SET_BIT(hcan->Instance->TSR, CAN_TSR_ABRQ0);
1329:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1330:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1331:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Check Tx Mailbox 1 */
1332:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((TxMailboxes & CAN_TX_MAILBOX1) != 0U)
1333:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1334:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Add cancellation request for Tx Mailbox 1 */
1335:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** SET_BIT(hcan->Instance->TSR, CAN_TSR_ABRQ1);
1336:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1337:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1338:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Check Tx Mailbox 2 */
1339:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((TxMailboxes & CAN_TX_MAILBOX2) != 0U)
1340:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1341:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Add cancellation request for Tx Mailbox 2 */
1342:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** SET_BIT(hcan->Instance->TSR, CAN_TSR_ABRQ2);
1343:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1344:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1345:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Return function status */
1346:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** return HAL_OK;
1347:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1348:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** else
1349:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1350:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Update error code */
1351:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->ErrorCode |= HAL_CAN_ERROR_NOT_INITIALIZED;
1317 .loc 1 1351 5 is_stmt 1 view .LVU433
1318 .loc 1 1351 9 is_stmt 0 view .LVU434
1319 000c 436A ldr r3, [r0, #36]
1320 .loc 1 1351 21 view .LVU435
1321 000e 43F48023 orr r3, r3, #262144
1322 0012 4362 str r3, [r0, #36]
1352:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1353:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** return HAL_ERROR;
1323 .loc 1 1353 5 is_stmt 1 view .LVU436
ARM GAS /tmp/ccj1aKCo.s page 52
1324 .loc 1 1353 12 is_stmt 0 view .LVU437
1325 0014 0120 movs r0, #1
1326 .LVL92:
1354:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1355:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1327 .loc 1 1355 1 view .LVU438
1328 0016 7047 bx lr
1329 .LVL93:
1330 .L110:
1325:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1331 .loc 1 1325 5 is_stmt 1 view .LVU439
1325:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1332 .loc 1 1325 8 is_stmt 0 view .LVU440
1333 0018 11F0010F tst r1, #1
1334 001c 04D0 beq .L106
1328:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1335 .loc 1 1328 7 is_stmt 1 view .LVU441
1336 001e 0268 ldr r2, [r0]
1337 0020 9368 ldr r3, [r2, #8]
1338 0022 43F08003 orr r3, r3, #128
1339 0026 9360 str r3, [r2, #8]
1340 .L106:
1332:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1341 .loc 1 1332 5 view .LVU442
1332:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1342 .loc 1 1332 8 is_stmt 0 view .LVU443
1343 0028 11F0020F tst r1, #2
1344 002c 04D0 beq .L107
1335:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1345 .loc 1 1335 7 is_stmt 1 view .LVU444
1346 002e 0268 ldr r2, [r0]
1347 0030 9368 ldr r3, [r2, #8]
1348 0032 43F40043 orr r3, r3, #32768
1349 0036 9360 str r3, [r2, #8]
1350 .L107:
1339:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1351 .loc 1 1339 5 view .LVU445
1339:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1352 .loc 1 1339 8 is_stmt 0 view .LVU446
1353 0038 11F0040F tst r1, #4
1354 003c 04D0 beq .L108
1342:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1355 .loc 1 1342 7 is_stmt 1 view .LVU447
1356 003e 0268 ldr r2, [r0]
1357 0040 9368 ldr r3, [r2, #8]
1358 0042 43F40003 orr r3, r3, #8388608
1359 0046 9360 str r3, [r2, #8]
1360 .L108:
1346:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1361 .loc 1 1346 5 view .LVU448
1346:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1362 .loc 1 1346 12 is_stmt 0 view .LVU449
1363 0048 0020 movs r0, #0
1364 .LVL94:
1346:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1365 .loc 1 1346 12 view .LVU450
1366 004a 7047 bx lr
ARM GAS /tmp/ccj1aKCo.s page 53
1367 .cfi_endproc
1368 .LFE141:
1370 .section .text.HAL_CAN_GetTxMailboxesFreeLevel,"ax",%progbits
1371 .align 1
1372 .global HAL_CAN_GetTxMailboxesFreeLevel
1373 .syntax unified
1374 .thumb
1375 .thumb_func
1377 HAL_CAN_GetTxMailboxesFreeLevel:
1378 .LVL95:
1379 .LFB142:
1356:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1357:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /**
1358:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @brief Return Tx Mailboxes free level: number of free Tx Mailboxes.
1359:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param hcan pointer to a CAN_HandleTypeDef structure that contains
1360:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * the configuration information for the specified CAN.
1361:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @retval Number of free Tx Mailboxes.
1362:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
1363:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** uint32_t HAL_CAN_GetTxMailboxesFreeLevel(CAN_HandleTypeDef *hcan)
1364:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1380 .loc 1 1364 1 is_stmt 1 view -0
1381 .cfi_startproc
1382 @ args = 0, pretend = 0, frame = 0
1383 @ frame_needed = 0, uses_anonymous_args = 0
1384 @ link register save eliminated.
1365:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** uint32_t freelevel = 0U;
1385 .loc 1 1365 3 view .LVU452
1366:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_StateTypeDef state = hcan->State;
1386 .loc 1 1366 3 view .LVU453
1387 .loc 1 1366 24 is_stmt 0 view .LVU454
1388 0000 90F82030 ldrb r3, [r0, #32] @ zero_extendqisi2
1389 .LVL96:
1367:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1368:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((state == HAL_CAN_STATE_READY) ||
1390 .loc 1 1368 3 is_stmt 1 view .LVU455
1391 .loc 1 1368 38 is_stmt 0 view .LVU456
1392 0004 013B subs r3, r3, #1
1393 .LVL97:
1394 .loc 1 1368 38 view .LVU457
1395 0006 DBB2 uxtb r3, r3
1396 .loc 1 1368 6 view .LVU458
1397 0008 012B cmp r3, #1
1398 000a 01D9 bls .L117
1365:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_StateTypeDef state = hcan->State;
1399 .loc 1 1365 12 view .LVU459
1400 000c 0020 movs r0, #0
1401 .LVL98:
1369:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (state == HAL_CAN_STATE_LISTENING))
1370:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1371:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Check Tx Mailbox 0 status */
1372:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((hcan->Instance->TSR & CAN_TSR_TME0) != 0U)
1373:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1374:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** freelevel++;
1375:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1376:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1377:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Check Tx Mailbox 1 status */
1378:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((hcan->Instance->TSR & CAN_TSR_TME1) != 0U)
ARM GAS /tmp/ccj1aKCo.s page 54
1379:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1380:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** freelevel++;
1381:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1382:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1383:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Check Tx Mailbox 2 status */
1384:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((hcan->Instance->TSR & CAN_TSR_TME2) != 0U)
1385:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1386:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** freelevel++;
1387:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1388:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1389:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1390:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Return Tx Mailboxes free level */
1391:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** return freelevel;
1402 .loc 1 1391 3 is_stmt 1 view .LVU460
1403 .L111:
1392:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1404 .loc 1 1392 1 is_stmt 0 view .LVU461
1405 000e 7047 bx lr
1406 .LVL99:
1407 .L117:
1372:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1408 .loc 1 1372 5 is_stmt 1 view .LVU462
1372:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1409 .loc 1 1372 14 is_stmt 0 view .LVU463
1410 0010 0368 ldr r3, [r0]
1372:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1411 .loc 1 1372 24 view .LVU464
1412 0012 9868 ldr r0, [r3, #8]
1413 .LVL100:
1372:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1414 .loc 1 1372 8 view .LVU465
1415 0014 10F08060 ands r0, r0, #67108864
1416 0018 00D0 beq .L113
1374:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1417 .loc 1 1374 16 view .LVU466
1418 001a 0120 movs r0, #1
1419 .L113:
1420 .LVL101:
1378:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1421 .loc 1 1378 5 is_stmt 1 view .LVU467
1378:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1422 .loc 1 1378 24 is_stmt 0 view .LVU468
1423 001c 9A68 ldr r2, [r3, #8]
1378:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1424 .loc 1 1378 8 view .LVU469
1425 001e 12F0006F tst r2, #134217728
1426 0022 00D0 beq .L114
1380:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1427 .loc 1 1380 7 is_stmt 1 view .LVU470
1380:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1428 .loc 1 1380 16 is_stmt 0 view .LVU471
1429 0024 0130 adds r0, r0, #1
1430 .LVL102:
1431 .L114:
1384:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1432 .loc 1 1384 5 is_stmt 1 view .LVU472
1384:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
ARM GAS /tmp/ccj1aKCo.s page 55
1433 .loc 1 1384 24 is_stmt 0 view .LVU473
1434 0026 9B68 ldr r3, [r3, #8]
1384:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1435 .loc 1 1384 8 view .LVU474
1436 0028 13F0805F tst r3, #268435456
1437 002c EFD0 beq .L111
1386:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1438 .loc 1 1386 7 is_stmt 1 view .LVU475
1386:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1439 .loc 1 1386 16 is_stmt 0 view .LVU476
1440 002e 0130 adds r0, r0, #1
1441 .LVL103:
1386:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1442 .loc 1 1386 16 view .LVU477
1443 0030 7047 bx lr
1444 .cfi_endproc
1445 .LFE142:
1447 .section .text.HAL_CAN_IsTxMessagePending,"ax",%progbits
1448 .align 1
1449 .global HAL_CAN_IsTxMessagePending
1450 .syntax unified
1451 .thumb
1452 .thumb_func
1454 HAL_CAN_IsTxMessagePending:
1455 .LVL104:
1456 .LFB143:
1393:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1394:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /**
1395:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @brief Check if a transmission request is pending on the selected Tx
1396:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * Mailboxes.
1397:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param hcan pointer to an CAN_HandleTypeDef structure that contains
1398:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * the configuration information for the specified CAN.
1399:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param TxMailboxes List of Tx Mailboxes to check.
1400:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * This parameter can be any combination of @arg CAN_Tx_Mailboxes.
1401:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @retval Status
1402:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * - 0 : No pending transmission request on any selected Tx Mailboxes.
1403:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * - 1 : Pending transmission request on at least one of the selected
1404:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * Tx Mailbox.
1405:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
1406:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** uint32_t HAL_CAN_IsTxMessagePending(CAN_HandleTypeDef *hcan, uint32_t TxMailboxes)
1407:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1457 .loc 1 1407 1 is_stmt 1 view -0
1458 .cfi_startproc
1459 @ args = 0, pretend = 0, frame = 0
1460 @ frame_needed = 0, uses_anonymous_args = 0
1461 @ link register save eliminated.
1408:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** uint32_t status = 0U;
1462 .loc 1 1408 3 view .LVU479
1409:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_StateTypeDef state = hcan->State;
1463 .loc 1 1409 3 view .LVU480
1464 .loc 1 1409 24 is_stmt 0 view .LVU481
1465 0000 90F82030 ldrb r3, [r0, #32] @ zero_extendqisi2
1466 .LVL105:
1410:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1411:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Check function parameters */
1412:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_CAN_TX_MAILBOX_LIST(TxMailboxes));
1467 .loc 1 1412 3 is_stmt 1 view .LVU482
ARM GAS /tmp/ccj1aKCo.s page 56
1413:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1414:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((state == HAL_CAN_STATE_READY) ||
1468 .loc 1 1414 3 view .LVU483
1469 .loc 1 1414 38 is_stmt 0 view .LVU484
1470 0004 013B subs r3, r3, #1
1471 .LVL106:
1472 .loc 1 1414 38 view .LVU485
1473 0006 DBB2 uxtb r3, r3
1474 .loc 1 1414 6 view .LVU486
1475 0008 012B cmp r3, #1
1476 000a 01D9 bls .L122
1408:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_StateTypeDef state = hcan->State;
1477 .loc 1 1408 12 view .LVU487
1478 000c 0020 movs r0, #0
1479 .LVL107:
1408:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_StateTypeDef state = hcan->State;
1480 .loc 1 1408 12 view .LVU488
1481 000e 7047 bx lr
1482 .LVL108:
1483 .L122:
1415:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (state == HAL_CAN_STATE_LISTENING))
1416:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1417:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Check pending transmission request on the selected Tx Mailboxes */
1418:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((hcan->Instance->TSR & (TxMailboxes << CAN_TSR_TME0_Pos)) != (TxMailboxes << CAN_TSR_TME0_P
1484 .loc 1 1418 5 is_stmt 1 view .LVU489
1485 .loc 1 1418 14 is_stmt 0 view .LVU490
1486 0010 0368 ldr r3, [r0]
1487 .loc 1 1418 24 view .LVU491
1488 0012 9B68 ldr r3, [r3, #8]
1489 .loc 1 1418 30 view .LVU492
1490 0014 03EA8163 and r3, r3, r1, lsl #26
1491 .loc 1 1418 8 view .LVU493
1492 0018 B3EB816F cmp r3, r1, lsl #26
1493 001c 01D0 beq .L123
1419:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1420:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** status = 1U;
1494 .loc 1 1420 14 view .LVU494
1495 001e 0120 movs r0, #1
1496 .LVL109:
1421:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1422:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1423:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1424:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Return status */
1425:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** return status;
1497 .loc 1 1425 3 is_stmt 1 view .LVU495
1426:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1498 .loc 1 1426 1 is_stmt 0 view .LVU496
1499 0020 7047 bx lr
1500 .LVL110:
1501 .L123:
1408:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_StateTypeDef state = hcan->State;
1502 .loc 1 1408 12 view .LVU497
1503 0022 0020 movs r0, #0
1504 .LVL111:
1408:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_StateTypeDef state = hcan->State;
1505 .loc 1 1408 12 view .LVU498
1506 0024 7047 bx lr
ARM GAS /tmp/ccj1aKCo.s page 57
1507 .cfi_endproc
1508 .LFE143:
1510 .section .text.HAL_CAN_GetTxTimestamp,"ax",%progbits
1511 .align 1
1512 .global HAL_CAN_GetTxTimestamp
1513 .syntax unified
1514 .thumb
1515 .thumb_func
1517 HAL_CAN_GetTxTimestamp:
1518 .LVL112:
1519 .LFB144:
1427:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1428:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /**
1429:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @brief Return timestamp of Tx message sent, if time triggered communication
1430:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** mode is enabled.
1431:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param hcan pointer to a CAN_HandleTypeDef structure that contains
1432:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * the configuration information for the specified CAN.
1433:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param TxMailbox Tx Mailbox where the timestamp of message sent will be
1434:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * read.
1435:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * This parameter can be one value of @arg CAN_Tx_Mailboxes.
1436:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @retval Timestamp of message sent from Tx Mailbox.
1437:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
1438:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** uint32_t HAL_CAN_GetTxTimestamp(CAN_HandleTypeDef *hcan, uint32_t TxMailbox)
1439:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1520 .loc 1 1439 1 is_stmt 1 view -0
1521 .cfi_startproc
1522 @ args = 0, pretend = 0, frame = 0
1523 @ frame_needed = 0, uses_anonymous_args = 0
1524 @ link register save eliminated.
1440:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** uint32_t timestamp = 0U;
1525 .loc 1 1440 3 view .LVU500
1441:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** uint32_t transmitmailbox;
1526 .loc 1 1441 3 view .LVU501
1442:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_StateTypeDef state = hcan->State;
1527 .loc 1 1442 3 view .LVU502
1528 .loc 1 1442 24 is_stmt 0 view .LVU503
1529 0000 90F82030 ldrb r3, [r0, #32] @ zero_extendqisi2
1530 .LVL113:
1443:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1444:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Check function parameters */
1445:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_CAN_TX_MAILBOX(TxMailbox));
1531 .loc 1 1445 3 is_stmt 1 view .LVU504
1446:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1447:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((state == HAL_CAN_STATE_READY) ||
1532 .loc 1 1447 3 view .LVU505
1533 .loc 1 1447 38 is_stmt 0 view .LVU506
1534 0004 013B subs r3, r3, #1
1535 .LVL114:
1536 .loc 1 1447 38 view .LVU507
1537 0006 DBB2 uxtb r3, r3
1538 .loc 1 1447 6 view .LVU508
1539 0008 012B cmp r3, #1
1540 000a 01D9 bls .L127
1440:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** uint32_t transmitmailbox;
1541 .loc 1 1440 12 view .LVU509
1542 000c 0020 movs r0, #0
1543 .LVL115:
ARM GAS /tmp/ccj1aKCo.s page 58
1448:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (state == HAL_CAN_STATE_LISTENING))
1449:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1450:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Select the Tx mailbox */
1451:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** transmitmailbox = POSITION_VAL(TxMailbox);
1452:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1453:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Get timestamp */
1454:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** timestamp = (hcan->Instance->sTxMailBox[transmitmailbox].TDTR & CAN_TDT0R_TIME) >> CAN_TDT0R_TI
1455:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1456:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1457:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Return the timestamp */
1458:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** return timestamp;
1544 .loc 1 1458 3 is_stmt 1 view .LVU510
1459:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1545 .loc 1 1459 1 is_stmt 0 view .LVU511
1546 000e 7047 bx lr
1547 .LVL116:
1548 .L127:
1451:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1549 .loc 1 1451 5 is_stmt 1 view .LVU512
1550 .LBB4:
1551 .LBI4:
1552 .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 ****
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
ARM GAS /tmp/ccj1aKCo.s page 59
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"
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
ARM GAS /tmp/ccj1aKCo.s page 60
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.
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
ARM GAS /tmp/ccj1aKCo.s page 61
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");
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 **** {
ARM GAS /tmp/ccj1aKCo.s page 62
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);
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 **** {
ARM GAS /tmp/ccj1aKCo.s page 63
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 ****
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) );
ARM GAS /tmp/ccj1aKCo.s page 64
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)
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 **** /**
ARM GAS /tmp/ccj1aKCo.s page 65
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 **** */
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 **** /**
ARM GAS /tmp/ccj1aKCo.s page 66
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) );
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)
ARM GAS /tmp/ccj1aKCo.s page 67
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 **** /**
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 **** }
ARM GAS /tmp/ccj1aKCo.s page 68
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)) && \
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))
ARM GAS /tmp/ccj1aKCo.s page 69
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)
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;
ARM GAS /tmp/ccj1aKCo.s page 70
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;
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
ARM GAS /tmp/ccj1aKCo.s page 71
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 **** */
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;
ARM GAS /tmp/ccj1aKCo.s page 72
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__)
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
ARM GAS /tmp/ccj1aKCo.s page 73
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)
867:Drivers/CMSIS/Include/cmsis_gcc.h **** {
868:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("isb 0xF":::"memory");
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)
878:Drivers/CMSIS/Include/cmsis_gcc.h **** {
879:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("dsb 0xF":::"memory");
880:Drivers/CMSIS/Include/cmsis_gcc.h **** }
881:Drivers/CMSIS/Include/cmsis_gcc.h ****
882:Drivers/CMSIS/Include/cmsis_gcc.h ****
883:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
884:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Data Memory Barrier
885:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Ensures the apparent order of the explicit memory operations before
886:Drivers/CMSIS/Include/cmsis_gcc.h **** and after the instruction, without ensuring their completion.
887:Drivers/CMSIS/Include/cmsis_gcc.h **** */
888:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE void __DMB(void)
889:Drivers/CMSIS/Include/cmsis_gcc.h **** {
890:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("dmb 0xF":::"memory");
ARM GAS /tmp/ccj1aKCo.s page 74
891:Drivers/CMSIS/Include/cmsis_gcc.h **** }
892:Drivers/CMSIS/Include/cmsis_gcc.h ****
893:Drivers/CMSIS/Include/cmsis_gcc.h ****
894:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
895:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Reverse byte order (32 bit)
896:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Reverses the byte order in unsigned integer value. For example, 0x12345678 becomes 0x785
897:Drivers/CMSIS/Include/cmsis_gcc.h **** \param [in] value Value to reverse
898:Drivers/CMSIS/Include/cmsis_gcc.h **** \return Reversed value
899:Drivers/CMSIS/Include/cmsis_gcc.h **** */
900:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE uint32_t __REV(uint32_t value)
901:Drivers/CMSIS/Include/cmsis_gcc.h **** {
902:Drivers/CMSIS/Include/cmsis_gcc.h **** #if (__GNUC__ > 4) || (__GNUC__ == 4 && __GNUC_MINOR__ >= 5)
903:Drivers/CMSIS/Include/cmsis_gcc.h **** return __builtin_bswap32(value);
904:Drivers/CMSIS/Include/cmsis_gcc.h **** #else
905:Drivers/CMSIS/Include/cmsis_gcc.h **** uint32_t result;
906:Drivers/CMSIS/Include/cmsis_gcc.h ****
907:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("rev %0, %1" : __CMSIS_GCC_OUT_REG (result) : __CMSIS_GCC_USE_REG (value) );
908:Drivers/CMSIS/Include/cmsis_gcc.h **** return result;
909:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
910:Drivers/CMSIS/Include/cmsis_gcc.h **** }
911:Drivers/CMSIS/Include/cmsis_gcc.h ****
912:Drivers/CMSIS/Include/cmsis_gcc.h ****
913:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
914:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Reverse byte order (16 bit)
915:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Reverses the byte order within each halfword of a word. For example, 0x12345678 becomes
916:Drivers/CMSIS/Include/cmsis_gcc.h **** \param [in] value Value to reverse
917:Drivers/CMSIS/Include/cmsis_gcc.h **** \return Reversed value
918:Drivers/CMSIS/Include/cmsis_gcc.h **** */
919:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE uint32_t __REV16(uint32_t value)
920:Drivers/CMSIS/Include/cmsis_gcc.h **** {
921:Drivers/CMSIS/Include/cmsis_gcc.h **** uint32_t result;
922:Drivers/CMSIS/Include/cmsis_gcc.h ****
923:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("rev16 %0, %1" : __CMSIS_GCC_OUT_REG (result) : __CMSIS_GCC_USE_REG (value) );
924:Drivers/CMSIS/Include/cmsis_gcc.h **** return result;
925:Drivers/CMSIS/Include/cmsis_gcc.h **** }
926:Drivers/CMSIS/Include/cmsis_gcc.h ****
927:Drivers/CMSIS/Include/cmsis_gcc.h ****
928:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
929:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Reverse byte order (16 bit)
930:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Reverses the byte order in a 16-bit value and returns the signed 16-bit result. For exam
931:Drivers/CMSIS/Include/cmsis_gcc.h **** \param [in] value Value to reverse
932:Drivers/CMSIS/Include/cmsis_gcc.h **** \return Reversed value
933:Drivers/CMSIS/Include/cmsis_gcc.h **** */
934:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE int16_t __REVSH(int16_t value)
935:Drivers/CMSIS/Include/cmsis_gcc.h **** {
936:Drivers/CMSIS/Include/cmsis_gcc.h **** #if (__GNUC__ > 4) || (__GNUC__ == 4 && __GNUC_MINOR__ >= 8)
937:Drivers/CMSIS/Include/cmsis_gcc.h **** return (int16_t)__builtin_bswap16(value);
938:Drivers/CMSIS/Include/cmsis_gcc.h **** #else
939:Drivers/CMSIS/Include/cmsis_gcc.h **** int16_t result;
940:Drivers/CMSIS/Include/cmsis_gcc.h ****
941:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("revsh %0, %1" : __CMSIS_GCC_OUT_REG (result) : __CMSIS_GCC_USE_REG (value) );
942:Drivers/CMSIS/Include/cmsis_gcc.h **** return result;
943:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
944:Drivers/CMSIS/Include/cmsis_gcc.h **** }
945:Drivers/CMSIS/Include/cmsis_gcc.h ****
946:Drivers/CMSIS/Include/cmsis_gcc.h ****
947:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
ARM GAS /tmp/ccj1aKCo.s page 75
948:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Rotate Right in unsigned value (32 bit)
949:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Rotate Right (immediate) provides the value of the contents of a register rotated by a v
950:Drivers/CMSIS/Include/cmsis_gcc.h **** \param [in] op1 Value to rotate
951:Drivers/CMSIS/Include/cmsis_gcc.h **** \param [in] op2 Number of Bits to rotate
952:Drivers/CMSIS/Include/cmsis_gcc.h **** \return Rotated value
953:Drivers/CMSIS/Include/cmsis_gcc.h **** */
954:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE uint32_t __ROR(uint32_t op1, uint32_t op2)
955:Drivers/CMSIS/Include/cmsis_gcc.h **** {
956:Drivers/CMSIS/Include/cmsis_gcc.h **** op2 %= 32U;
957:Drivers/CMSIS/Include/cmsis_gcc.h **** if (op2 == 0U)
958:Drivers/CMSIS/Include/cmsis_gcc.h **** {
959:Drivers/CMSIS/Include/cmsis_gcc.h **** return op1;
960:Drivers/CMSIS/Include/cmsis_gcc.h **** }
961:Drivers/CMSIS/Include/cmsis_gcc.h **** return (op1 >> op2) | (op1 << (32U - op2));
962:Drivers/CMSIS/Include/cmsis_gcc.h **** }
963:Drivers/CMSIS/Include/cmsis_gcc.h ****
964:Drivers/CMSIS/Include/cmsis_gcc.h ****
965:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
966:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Breakpoint
967:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Causes the processor to enter Debug state.
968:Drivers/CMSIS/Include/cmsis_gcc.h **** Debug tools can use this to investigate system state when the instruction at a particula
969:Drivers/CMSIS/Include/cmsis_gcc.h **** \param [in] value is ignored by the processor.
970:Drivers/CMSIS/Include/cmsis_gcc.h **** If required, a debugger can use it to store additional information about the break
971:Drivers/CMSIS/Include/cmsis_gcc.h **** */
972:Drivers/CMSIS/Include/cmsis_gcc.h **** #define __BKPT(value) __ASM volatile ("bkpt "#value)
973:Drivers/CMSIS/Include/cmsis_gcc.h ****
974:Drivers/CMSIS/Include/cmsis_gcc.h ****
975:Drivers/CMSIS/Include/cmsis_gcc.h **** /**
976:Drivers/CMSIS/Include/cmsis_gcc.h **** \brief Reverse bit order of value
977:Drivers/CMSIS/Include/cmsis_gcc.h **** \details Reverses the bit order of the given value.
978:Drivers/CMSIS/Include/cmsis_gcc.h **** \param [in] value Value to reverse
979:Drivers/CMSIS/Include/cmsis_gcc.h **** \return Reversed value
980:Drivers/CMSIS/Include/cmsis_gcc.h **** */
981:Drivers/CMSIS/Include/cmsis_gcc.h **** __STATIC_FORCEINLINE uint32_t __RBIT(uint32_t value)
1553 .loc 2 981 31 view .LVU513
1554 .LBB5:
982:Drivers/CMSIS/Include/cmsis_gcc.h **** {
983:Drivers/CMSIS/Include/cmsis_gcc.h **** uint32_t result;
1555 .loc 2 983 3 view .LVU514
984:Drivers/CMSIS/Include/cmsis_gcc.h ****
985:Drivers/CMSIS/Include/cmsis_gcc.h **** #if ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \
986:Drivers/CMSIS/Include/cmsis_gcc.h **** (defined (__ARM_ARCH_7EM__ ) && (__ARM_ARCH_7EM__ == 1)) || \
987:Drivers/CMSIS/Include/cmsis_gcc.h **** (defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) )
988:Drivers/CMSIS/Include/cmsis_gcc.h **** __ASM volatile ("rbit %0, %1" : "=r" (result) : "r" (value) );
1556 .loc 2 988 4 view .LVU515
1557 .syntax unified
1558 @ 988 "Drivers/CMSIS/Include/cmsis_gcc.h" 1
1559 0010 91FAA1F1 rbit r1, r1
1560 @ 0 "" 2
1561 .LVL117:
989:Drivers/CMSIS/Include/cmsis_gcc.h **** #else
990:Drivers/CMSIS/Include/cmsis_gcc.h **** uint32_t s = (4U /*sizeof(v)*/ * 8U) - 1U; /* extra shift needed at end */
991:Drivers/CMSIS/Include/cmsis_gcc.h ****
992:Drivers/CMSIS/Include/cmsis_gcc.h **** result = value; /* r will be reversed bits of v; first get LSB of v */
993:Drivers/CMSIS/Include/cmsis_gcc.h **** for (value >>= 1U; value != 0U; value >>= 1U)
994:Drivers/CMSIS/Include/cmsis_gcc.h **** {
995:Drivers/CMSIS/Include/cmsis_gcc.h **** result <<= 1U;
ARM GAS /tmp/ccj1aKCo.s page 76
996:Drivers/CMSIS/Include/cmsis_gcc.h **** result |= value & 1U;
997:Drivers/CMSIS/Include/cmsis_gcc.h **** s--;
998:Drivers/CMSIS/Include/cmsis_gcc.h **** }
999:Drivers/CMSIS/Include/cmsis_gcc.h **** result <<= s; /* shift when v's highest bits are zero */
1000:Drivers/CMSIS/Include/cmsis_gcc.h **** #endif
1001:Drivers/CMSIS/Include/cmsis_gcc.h **** return result;
1562 .loc 2 1001 3 view .LVU516
1563 .loc 2 1001 3 is_stmt 0 view .LVU517
1564 .thumb
1565 .syntax unified
1566 .LBE5:
1567 .LBE4:
1451:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1568 .loc 1 1451 21 view .LVU518
1569 0014 B1FA81F1 clz r1, r1
1570 .LVL118:
1454:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1571 .loc 1 1454 5 is_stmt 1 view .LVU519
1454:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1572 .loc 1 1454 22 is_stmt 0 view .LVU520
1573 0018 0368 ldr r3, [r0]
1454:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1574 .loc 1 1454 61 view .LVU521
1575 001a 1831 adds r1, r1, #24
1576 .LVL119:
1454:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1577 .loc 1 1454 61 view .LVU522
1578 001c 03EB0113 add r3, r3, r1, lsl #4
1579 0020 5868 ldr r0, [r3, #4]
1580 .LVL120:
1454:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1581 .loc 1 1454 85 view .LVU523
1582 0022 000C lsrs r0, r0, #16
1583 .LVL121:
1454:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1584 .loc 1 1454 85 view .LVU524
1585 0024 7047 bx lr
1586 .cfi_endproc
1587 .LFE144:
1589 .section .text.HAL_CAN_GetRxMessage,"ax",%progbits
1590 .align 1
1591 .global HAL_CAN_GetRxMessage
1592 .syntax unified
1593 .thumb
1594 .thumb_func
1596 HAL_CAN_GetRxMessage:
1597 .LVL122:
1598 .LFB145:
1460:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1461:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /**
1462:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @brief Get an CAN frame from the Rx FIFO zone into the message RAM.
1463:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param hcan pointer to an CAN_HandleTypeDef structure that contains
1464:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * the configuration information for the specified CAN.
1465:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param RxFifo Fifo number of the received message to be read.
1466:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * This parameter can be a value of @arg CAN_receive_FIFO_number.
1467:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param pHeader pointer to a CAN_RxHeaderTypeDef structure where the header
1468:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * of the Rx frame will be stored.
ARM GAS /tmp/ccj1aKCo.s page 77
1469:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param aData array where the payload of the Rx frame will be stored.
1470:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @retval HAL status
1471:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
1472:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_StatusTypeDef HAL_CAN_GetRxMessage(CAN_HandleTypeDef *hcan, uint32_t RxFifo, CAN_RxHeaderTypeDe
1473:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1599 .loc 1 1473 1 is_stmt 1 view -0
1600 .cfi_startproc
1601 @ args = 0, pretend = 0, frame = 0
1602 @ frame_needed = 0, uses_anonymous_args = 0
1603 @ link register save eliminated.
1474:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_StateTypeDef state = hcan->State;
1604 .loc 1 1474 3 view .LVU526
1605 .loc 1 1474 24 is_stmt 0 view .LVU527
1606 0000 90F820C0 ldrb ip, [r0, #32] @ zero_extendqisi2
1607 .LVL123:
1475:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1476:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_CAN_RX_FIFO(RxFifo));
1608 .loc 1 1476 3 is_stmt 1 view .LVU528
1477:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1478:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((state == HAL_CAN_STATE_READY) ||
1609 .loc 1 1478 3 view .LVU529
1610 .loc 1 1478 38 is_stmt 0 view .LVU530
1611 0004 0CF1FF3C add ip, ip, #-1
1612 .LVL124:
1613 .loc 1 1478 38 view .LVU531
1614 0008 5FFA8CFC uxtb ip, ip
1615 .loc 1 1478 6 view .LVU532
1616 000c BCF1010F cmp ip, #1
1617 0010 00F29580 bhi .L129
1473:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_StateTypeDef state = hcan->State;
1618 .loc 1 1473 1 view .LVU533
1619 0014 30B4 push {r4, r5}
1620 .cfi_def_cfa_offset 8
1621 .cfi_offset 4, -8
1622 .cfi_offset 5, -4
1479:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (state == HAL_CAN_STATE_LISTENING))
1480:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1481:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Check the Rx FIFO */
1482:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if (RxFifo == CAN_RX_FIFO0) /* Rx element is assigned to Rx FIFO 0 */
1623 .loc 1 1482 5 is_stmt 1 view .LVU534
1624 .loc 1 1482 8 is_stmt 0 view .LVU535
1625 0016 51B9 cbnz r1, .L130
1483:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1484:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Check that the Rx FIFO 0 is not empty */
1485:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((hcan->Instance->RF0R & CAN_RF0R_FMP0) == 0U)
1626 .loc 1 1485 7 is_stmt 1 view .LVU536
1627 .loc 1 1485 16 is_stmt 0 view .LVU537
1628 0018 0468 ldr r4, [r0]
1629 .loc 1 1485 26 view .LVU538
1630 001a E468 ldr r4, [r4, #12]
1631 .loc 1 1485 10 view .LVU539
1632 001c 14F0030F tst r4, #3
1633 0020 10D1 bne .L131
1486:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1487:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Update error code */
1488:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->ErrorCode |= HAL_CAN_ERROR_PARAM;
1634 .loc 1 1488 9 is_stmt 1 view .LVU540
ARM GAS /tmp/ccj1aKCo.s page 78
1635 .loc 1 1488 13 is_stmt 0 view .LVU541
1636 0022 436A ldr r3, [r0, #36]
1637 .LVL125:
1638 .loc 1 1488 25 view .LVU542
1639 0024 43F40013 orr r3, r3, #2097152
1640 0028 4362 str r3, [r0, #36]
1489:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1490:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** return HAL_ERROR;
1641 .loc 1 1490 9 is_stmt 1 view .LVU543
1642 .loc 1 1490 16 is_stmt 0 view .LVU544
1643 002a 0120 movs r0, #1
1644 .LVL126:
1645 .loc 1 1490 16 view .LVU545
1646 002c 77E0 b .L132
1647 .LVL127:
1648 .L130:
1491:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1492:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1493:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** else /* Rx element is assigned to Rx FIFO 1 */
1494:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1495:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Check that the Rx FIFO 1 is not empty */
1496:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((hcan->Instance->RF1R & CAN_RF1R_FMP1) == 0U)
1649 .loc 1 1496 7 is_stmt 1 view .LVU546
1650 .loc 1 1496 16 is_stmt 0 view .LVU547
1651 002e 0468 ldr r4, [r0]
1652 .loc 1 1496 26 view .LVU548
1653 0030 2469 ldr r4, [r4, #16]
1654 .loc 1 1496 10 view .LVU549
1655 0032 14F0030F tst r4, #3
1656 0036 05D1 bne .L131
1497:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1498:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Update error code */
1499:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->ErrorCode |= HAL_CAN_ERROR_PARAM;
1657 .loc 1 1499 9 is_stmt 1 view .LVU550
1658 .loc 1 1499 13 is_stmt 0 view .LVU551
1659 0038 436A ldr r3, [r0, #36]
1660 .LVL128:
1661 .loc 1 1499 25 view .LVU552
1662 003a 43F40013 orr r3, r3, #2097152
1663 003e 4362 str r3, [r0, #36]
1500:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1501:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** return HAL_ERROR;
1664 .loc 1 1501 9 is_stmt 1 view .LVU553
1665 .loc 1 1501 16 is_stmt 0 view .LVU554
1666 0040 0120 movs r0, #1
1667 .LVL129:
1668 .loc 1 1501 16 view .LVU555
1669 0042 6CE0 b .L132
1670 .LVL130:
1671 .L131:
1502:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1503:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1504:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1505:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Get the header */
1506:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** pHeader->IDE = CAN_RI0R_IDE & hcan->Instance->sFIFOMailBox[RxFifo].RIR;
1672 .loc 1 1506 5 is_stmt 1 view .LVU556
1673 .loc 1 1506 71 is_stmt 0 view .LVU557
ARM GAS /tmp/ccj1aKCo.s page 79
1674 0044 01F11B04 add r4, r1, #27
1675 0048 2401 lsls r4, r4, #4
1676 004a 0568 ldr r5, [r0]
1677 004c 2C59 ldr r4, [r5, r4]
1678 .loc 1 1506 33 view .LVU558
1679 004e 04F00404 and r4, r4, #4
1680 .loc 1 1506 18 view .LVU559
1681 0052 9460 str r4, [r2, #8]
1507:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if (pHeader->IDE == CAN_ID_STD)
1682 .loc 1 1507 5 is_stmt 1 view .LVU560
1683 .loc 1 1507 8 is_stmt 0 view .LVU561
1684 0054 002C cmp r4, #0
1685 0056 64D1 bne .L133
1508:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1509:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** pHeader->StdId = (CAN_RI0R_STID & hcan->Instance->sFIFOMailBox[RxFifo].RIR) >> CAN_TI0R_STID_
1686 .loc 1 1509 7 is_stmt 1 view .LVU562
1687 .loc 1 1509 77 is_stmt 0 view .LVU563
1688 0058 01F11B04 add r4, r1, #27
1689 005c 2401 lsls r4, r4, #4
1690 005e 0568 ldr r5, [r0]
1691 0060 2C59 ldr r4, [r5, r4]
1692 .loc 1 1509 83 view .LVU564
1693 0062 640D lsrs r4, r4, #21
1694 .loc 1 1509 22 view .LVU565
1695 0064 1460 str r4, [r2]
1696 .L134:
1510:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1511:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** else
1512:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1513:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** pHeader->ExtId = ((CAN_RI0R_EXID | CAN_RI0R_STID) & hcan->Instance->sFIFOMailBox[RxFifo].RIR)
1514:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1515:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** pHeader->RTR = (CAN_RI0R_RTR & hcan->Instance->sFIFOMailBox[RxFifo].RIR);
1697 .loc 1 1515 5 is_stmt 1 view .LVU566
1698 .loc 1 1515 40 is_stmt 0 view .LVU567
1699 0066 0468 ldr r4, [r0]
1700 .loc 1 1515 72 view .LVU568
1701 0068 01F11B0C add ip, r1, #27
1702 006c 4FEA0C1C lsl ip, ip, #4
1703 0070 54F80C40 ldr r4, [r4, ip]
1704 .loc 1 1515 34 view .LVU569
1705 0074 04F00204 and r4, r4, #2
1706 .loc 1 1515 18 view .LVU570
1707 0078 D460 str r4, [r2, #12]
1516:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** pHeader->DLC = (CAN_RDT0R_DLC & hcan->Instance->sFIFOMailBox[RxFifo].RDTR) >> CAN_RDT0R_DLC_Pos
1708 .loc 1 1516 5 is_stmt 1 view .LVU571
1709 .loc 1 1516 41 is_stmt 0 view .LVU572
1710 007a 0468 ldr r4, [r0]
1711 .loc 1 1516 73 view .LVU573
1712 007c 6444 add r4, r4, ip
1713 007e 6468 ldr r4, [r4, #4]
1714 .loc 1 1516 80 view .LVU574
1715 0080 04F00F04 and r4, r4, #15
1716 .loc 1 1516 18 view .LVU575
1717 0084 1461 str r4, [r2, #16]
1517:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** pHeader->FilterMatchIndex = (CAN_RDT0R_FMI & hcan->Instance->sFIFOMailBox[RxFifo].RDTR) >> CAN_
1718 .loc 1 1517 5 is_stmt 1 view .LVU576
1719 .loc 1 1517 54 is_stmt 0 view .LVU577
ARM GAS /tmp/ccj1aKCo.s page 80
1720 0086 0468 ldr r4, [r0]
1721 .loc 1 1517 86 view .LVU578
1722 0088 6444 add r4, r4, ip
1723 008a 6468 ldr r4, [r4, #4]
1724 .loc 1 1517 93 view .LVU579
1725 008c C4F30724 ubfx r4, r4, #8, #8
1726 .loc 1 1517 31 view .LVU580
1727 0090 9461 str r4, [r2, #24]
1518:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** pHeader->Timestamp = (CAN_RDT0R_TIME & hcan->Instance->sFIFOMailBox[RxFifo].RDTR) >> CAN_RDT0R_
1728 .loc 1 1518 5 is_stmt 1 view .LVU581
1729 .loc 1 1518 48 is_stmt 0 view .LVU582
1730 0092 0468 ldr r4, [r0]
1731 .loc 1 1518 80 view .LVU583
1732 0094 6444 add r4, r4, ip
1733 0096 6468 ldr r4, [r4, #4]
1734 .loc 1 1518 87 view .LVU584
1735 0098 240C lsrs r4, r4, #16
1736 .loc 1 1518 24 view .LVU585
1737 009a 5461 str r4, [r2, #20]
1519:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1520:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Get the data */
1521:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** aData[0] = (uint8_t)((CAN_RDL0R_DATA0 & hcan->Instance->sFIFOMailBox[RxFifo].RDLR) >> CAN_RDL0R
1738 .loc 1 1521 5 is_stmt 1 view .LVU586
1739 .loc 1 1521 49 is_stmt 0 view .LVU587
1740 009c 0268 ldr r2, [r0]
1741 .LVL131:
1742 .loc 1 1521 81 view .LVU588
1743 009e 02EB0112 add r2, r2, r1, lsl #4
1744 00a2 D2F8B821 ldr r2, [r2, #440]
1745 .loc 1 1521 14 view .LVU589
1746 00a6 1A70 strb r2, [r3]
1522:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** aData[1] = (uint8_t)((CAN_RDL0R_DATA1 & hcan->Instance->sFIFOMailBox[RxFifo].RDLR) >> CAN_RDL0R
1747 .loc 1 1522 5 is_stmt 1 view .LVU590
1748 .loc 1 1522 49 is_stmt 0 view .LVU591
1749 00a8 0268 ldr r2, [r0]
1750 .loc 1 1522 81 view .LVU592
1751 00aa 02EB0112 add r2, r2, r1, lsl #4
1752 00ae D2F8B821 ldr r2, [r2, #440]
1753 .loc 1 1522 16 view .LVU593
1754 00b2 C2F30722 ubfx r2, r2, #8, #8
1755 .loc 1 1522 14 view .LVU594
1756 00b6 5A70 strb r2, [r3, #1]
1523:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** aData[2] = (uint8_t)((CAN_RDL0R_DATA2 & hcan->Instance->sFIFOMailBox[RxFifo].RDLR) >> CAN_RDL0R
1757 .loc 1 1523 5 is_stmt 1 view .LVU595
1758 .loc 1 1523 49 is_stmt 0 view .LVU596
1759 00b8 0268 ldr r2, [r0]
1760 .loc 1 1523 81 view .LVU597
1761 00ba 02EB0112 add r2, r2, r1, lsl #4
1762 00be D2F8B821 ldr r2, [r2, #440]
1763 .loc 1 1523 16 view .LVU598
1764 00c2 C2F30742 ubfx r2, r2, #16, #8
1765 .loc 1 1523 14 view .LVU599
1766 00c6 9A70 strb r2, [r3, #2]
1524:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** aData[3] = (uint8_t)((CAN_RDL0R_DATA3 & hcan->Instance->sFIFOMailBox[RxFifo].RDLR) >> CAN_RDL0R
1767 .loc 1 1524 5 is_stmt 1 view .LVU600
1768 .loc 1 1524 49 is_stmt 0 view .LVU601
1769 00c8 0268 ldr r2, [r0]
ARM GAS /tmp/ccj1aKCo.s page 81
1770 .loc 1 1524 81 view .LVU602
1771 00ca 02EB0112 add r2, r2, r1, lsl #4
1772 00ce D2F8B821 ldr r2, [r2, #440]
1773 .loc 1 1524 16 view .LVU603
1774 00d2 120E lsrs r2, r2, #24
1775 .loc 1 1524 14 view .LVU604
1776 00d4 DA70 strb r2, [r3, #3]
1525:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** aData[4] = (uint8_t)((CAN_RDH0R_DATA4 & hcan->Instance->sFIFOMailBox[RxFifo].RDHR) >> CAN_RDH0R
1777 .loc 1 1525 5 is_stmt 1 view .LVU605
1778 .loc 1 1525 49 is_stmt 0 view .LVU606
1779 00d6 0268 ldr r2, [r0]
1780 .loc 1 1525 81 view .LVU607
1781 00d8 02EB0112 add r2, r2, r1, lsl #4
1782 00dc D2F8BC21 ldr r2, [r2, #444]
1783 .loc 1 1525 14 view .LVU608
1784 00e0 1A71 strb r2, [r3, #4]
1526:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** aData[5] = (uint8_t)((CAN_RDH0R_DATA5 & hcan->Instance->sFIFOMailBox[RxFifo].RDHR) >> CAN_RDH0R
1785 .loc 1 1526 5 is_stmt 1 view .LVU609
1786 .loc 1 1526 49 is_stmt 0 view .LVU610
1787 00e2 0268 ldr r2, [r0]
1788 .loc 1 1526 81 view .LVU611
1789 00e4 02EB0112 add r2, r2, r1, lsl #4
1790 00e8 D2F8BC21 ldr r2, [r2, #444]
1791 .loc 1 1526 16 view .LVU612
1792 00ec C2F30722 ubfx r2, r2, #8, #8
1793 .loc 1 1526 14 view .LVU613
1794 00f0 5A71 strb r2, [r3, #5]
1527:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** aData[6] = (uint8_t)((CAN_RDH0R_DATA6 & hcan->Instance->sFIFOMailBox[RxFifo].RDHR) >> CAN_RDH0R
1795 .loc 1 1527 5 is_stmt 1 view .LVU614
1796 .loc 1 1527 49 is_stmt 0 view .LVU615
1797 00f2 0268 ldr r2, [r0]
1798 .loc 1 1527 81 view .LVU616
1799 00f4 02EB0112 add r2, r2, r1, lsl #4
1800 00f8 D2F8BC21 ldr r2, [r2, #444]
1801 .loc 1 1527 16 view .LVU617
1802 00fc C2F30742 ubfx r2, r2, #16, #8
1803 .loc 1 1527 14 view .LVU618
1804 0100 9A71 strb r2, [r3, #6]
1528:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** aData[7] = (uint8_t)((CAN_RDH0R_DATA7 & hcan->Instance->sFIFOMailBox[RxFifo].RDHR) >> CAN_RDH0R
1805 .loc 1 1528 5 is_stmt 1 view .LVU619
1806 .loc 1 1528 49 is_stmt 0 view .LVU620
1807 0102 0268 ldr r2, [r0]
1808 .loc 1 1528 81 view .LVU621
1809 0104 02EB0112 add r2, r2, r1, lsl #4
1810 0108 D2F8BC21 ldr r2, [r2, #444]
1811 .loc 1 1528 16 view .LVU622
1812 010c 120E lsrs r2, r2, #24
1813 .loc 1 1528 14 view .LVU623
1814 010e DA71 strb r2, [r3, #7]
1529:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1530:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Release the FIFO */
1531:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if (RxFifo == CAN_RX_FIFO0) /* Rx element is assigned to Rx FIFO 0 */
1815 .loc 1 1531 5 is_stmt 1 view .LVU624
1816 .loc 1 1531 8 is_stmt 0 view .LVU625
1817 0110 79B9 cbnz r1, .L135
1532:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1533:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Release RX FIFO 0 */
ARM GAS /tmp/ccj1aKCo.s page 82
1534:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** SET_BIT(hcan->Instance->RF0R, CAN_RF0R_RFOM0);
1818 .loc 1 1534 7 is_stmt 1 view .LVU626
1819 0112 0268 ldr r2, [r0]
1820 0114 D368 ldr r3, [r2, #12]
1821 .LVL132:
1822 .loc 1 1534 7 is_stmt 0 view .LVU627
1823 0116 43F02003 orr r3, r3, #32
1824 011a D360 str r3, [r2, #12]
1825 .L136:
1535:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1536:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** else /* Rx element is assigned to Rx FIFO 1 */
1537:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1538:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Release RX FIFO 1 */
1539:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** SET_BIT(hcan->Instance->RF1R, CAN_RF1R_RFOM1);
1540:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1541:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1542:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Return function status */
1543:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** return HAL_OK;
1826 .loc 1 1543 5 is_stmt 1 view .LVU628
1827 .loc 1 1543 12 is_stmt 0 view .LVU629
1828 011c 0020 movs r0, #0
1829 .LVL133:
1830 .L132:
1544:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1545:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** else
1546:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1547:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Update error code */
1548:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->ErrorCode |= HAL_CAN_ERROR_NOT_INITIALIZED;
1549:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1550:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** return HAL_ERROR;
1551:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1552:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1831 .loc 1 1552 1 view .LVU630
1832 011e 30BC pop {r4, r5}
1833 .cfi_remember_state
1834 .cfi_restore 5
1835 .cfi_restore 4
1836 .cfi_def_cfa_offset 0
1837 0120 7047 bx lr
1838 .LVL134:
1839 .L133:
1840 .cfi_restore_state
1513:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1841 .loc 1 1513 7 is_stmt 1 view .LVU631
1513:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1842 .loc 1 1513 95 is_stmt 0 view .LVU632
1843 0122 01F11B04 add r4, r1, #27
1844 0126 2401 lsls r4, r4, #4
1845 0128 0568 ldr r5, [r0]
1846 012a 2C59 ldr r4, [r5, r4]
1513:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1847 .loc 1 1513 101 view .LVU633
1848 012c E408 lsrs r4, r4, #3
1513:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1849 .loc 1 1513 22 view .LVU634
1850 012e 5460 str r4, [r2, #4]
1851 0130 99E7 b .L134
ARM GAS /tmp/ccj1aKCo.s page 83
1852 .LVL135:
1853 .L135:
1539:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1854 .loc 1 1539 7 is_stmt 1 view .LVU635
1855 0132 0268 ldr r2, [r0]
1856 0134 1369 ldr r3, [r2, #16]
1857 .LVL136:
1539:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1858 .loc 1 1539 7 is_stmt 0 view .LVU636
1859 0136 43F02003 orr r3, r3, #32
1860 013a 1361 str r3, [r2, #16]
1861 013c EEE7 b .L136
1862 .LVL137:
1863 .L129:
1864 .cfi_def_cfa_offset 0
1865 .cfi_restore 4
1866 .cfi_restore 5
1548:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1867 .loc 1 1548 5 is_stmt 1 view .LVU637
1548:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1868 .loc 1 1548 9 is_stmt 0 view .LVU638
1869 013e 436A ldr r3, [r0, #36]
1870 .LVL138:
1548:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1871 .loc 1 1548 21 view .LVU639
1872 0140 43F48023 orr r3, r3, #262144
1873 0144 4362 str r3, [r0, #36]
1550:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1874 .loc 1 1550 5 is_stmt 1 view .LVU640
1550:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1875 .loc 1 1550 12 is_stmt 0 view .LVU641
1876 0146 0120 movs r0, #1
1877 .LVL139:
1878 .loc 1 1552 1 view .LVU642
1879 0148 7047 bx lr
1880 .cfi_endproc
1881 .LFE145:
1883 .section .text.HAL_CAN_GetRxFifoFillLevel,"ax",%progbits
1884 .align 1
1885 .global HAL_CAN_GetRxFifoFillLevel
1886 .syntax unified
1887 .thumb
1888 .thumb_func
1890 HAL_CAN_GetRxFifoFillLevel:
1891 .LVL140:
1892 .LFB146:
1553:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1554:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /**
1555:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @brief Return Rx FIFO fill level.
1556:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param hcan pointer to an CAN_HandleTypeDef structure that contains
1557:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * the configuration information for the specified CAN.
1558:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param RxFifo Rx FIFO.
1559:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * This parameter can be a value of @arg CAN_receive_FIFO_number.
1560:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @retval Number of messages available in Rx FIFO.
1561:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
1562:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** uint32_t HAL_CAN_GetRxFifoFillLevel(CAN_HandleTypeDef *hcan, uint32_t RxFifo)
1563:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
ARM GAS /tmp/ccj1aKCo.s page 84
1893 .loc 1 1563 1 is_stmt 1 view -0
1894 .cfi_startproc
1895 @ args = 0, pretend = 0, frame = 0
1896 @ frame_needed = 0, uses_anonymous_args = 0
1897 @ link register save eliminated.
1564:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** uint32_t filllevel = 0U;
1898 .loc 1 1564 3 view .LVU644
1565:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_StateTypeDef state = hcan->State;
1899 .loc 1 1565 3 view .LVU645
1900 .loc 1 1565 24 is_stmt 0 view .LVU646
1901 0000 90F82030 ldrb r3, [r0, #32] @ zero_extendqisi2
1902 .LVL141:
1566:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1567:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Check function parameters */
1568:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_CAN_RX_FIFO(RxFifo));
1903 .loc 1 1568 3 is_stmt 1 view .LVU647
1569:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1570:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((state == HAL_CAN_STATE_READY) ||
1904 .loc 1 1570 3 view .LVU648
1905 .loc 1 1570 38 is_stmt 0 view .LVU649
1906 0004 013B subs r3, r3, #1
1907 .LVL142:
1908 .loc 1 1570 38 view .LVU650
1909 0006 DBB2 uxtb r3, r3
1910 .loc 1 1570 6 view .LVU651
1911 0008 012B cmp r3, #1
1912 000a 01D9 bls .L145
1564:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_StateTypeDef state = hcan->State;
1913 .loc 1 1564 12 view .LVU652
1914 000c 0020 movs r0, #0
1915 .LVL143:
1571:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (state == HAL_CAN_STATE_LISTENING))
1572:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1573:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if (RxFifo == CAN_RX_FIFO0)
1574:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1575:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** filllevel = hcan->Instance->RF0R & CAN_RF0R_FMP0;
1576:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1577:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** else /* RxFifo == CAN_RX_FIFO1 */
1578:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1579:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** filllevel = hcan->Instance->RF1R & CAN_RF1R_FMP1;
1580:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1581:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1582:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1583:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Return Rx FIFO fill level */
1584:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** return filllevel;
1916 .loc 1 1584 3 is_stmt 1 view .LVU653
1585:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1917 .loc 1 1585 1 is_stmt 0 view .LVU654
1918 000e 7047 bx lr
1919 .LVL144:
1920 .L145:
1573:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1921 .loc 1 1573 5 is_stmt 1 view .LVU655
1573:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1922 .loc 1 1573 8 is_stmt 0 view .LVU656
1923 0010 21B9 cbnz r1, .L143
1575:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
ARM GAS /tmp/ccj1aKCo.s page 85
1924 .loc 1 1575 7 is_stmt 1 view .LVU657
1575:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1925 .loc 1 1575 23 is_stmt 0 view .LVU658
1926 0012 0368 ldr r3, [r0]
1575:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1927 .loc 1 1575 33 view .LVU659
1928 0014 D868 ldr r0, [r3, #12]
1929 .LVL145:
1575:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1930 .loc 1 1575 17 view .LVU660
1931 0016 00F00300 and r0, r0, #3
1932 .LVL146:
1575:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1933 .loc 1 1575 17 view .LVU661
1934 001a 7047 bx lr
1935 .LVL147:
1936 .L143:
1579:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1937 .loc 1 1579 7 is_stmt 1 view .LVU662
1579:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1938 .loc 1 1579 23 is_stmt 0 view .LVU663
1939 001c 0368 ldr r3, [r0]
1579:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1940 .loc 1 1579 33 view .LVU664
1941 001e 1869 ldr r0, [r3, #16]
1942 .LVL148:
1579:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1943 .loc 1 1579 17 view .LVU665
1944 0020 00F00300 and r0, r0, #3
1945 .LVL149:
1579:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1946 .loc 1 1579 17 view .LVU666
1947 0024 7047 bx lr
1948 .cfi_endproc
1949 .LFE146:
1951 .section .text.HAL_CAN_ActivateNotification,"ax",%progbits
1952 .align 1
1953 .global HAL_CAN_ActivateNotification
1954 .syntax unified
1955 .thumb
1956 .thumb_func
1958 HAL_CAN_ActivateNotification:
1959 .LVL150:
1960 .LFB147:
1586:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1587:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /**
1588:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @}
1589:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
1590:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1591:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /** @defgroup CAN_Exported_Functions_Group4 Interrupts management
1592:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @brief Interrupts management
1593:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** *
1594:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** @verbatim
1595:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ==============================================================================
1596:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ##### Interrupts management #####
1597:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ==============================================================================
1598:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** [..] This section provides functions allowing to:
ARM GAS /tmp/ccj1aKCo.s page 86
1599:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) HAL_CAN_ActivateNotification : Enable interrupts
1600:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) HAL_CAN_DeactivateNotification : Disable interrupts
1601:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) HAL_CAN_IRQHandler : Handles CAN interrupt request
1602:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1603:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** @endverbatim
1604:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @{
1605:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
1606:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1607:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /**
1608:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @brief Enable interrupts.
1609:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param hcan pointer to an CAN_HandleTypeDef structure that contains
1610:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * the configuration information for the specified CAN.
1611:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param ActiveITs indicates which interrupts will be enabled.
1612:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * This parameter can be any combination of @arg CAN_Interrupts.
1613:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @retval HAL status
1614:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
1615:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_StatusTypeDef HAL_CAN_ActivateNotification(CAN_HandleTypeDef *hcan, uint32_t ActiveITs)
1616:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1961 .loc 1 1616 1 is_stmt 1 view -0
1962 .cfi_startproc
1963 @ args = 0, pretend = 0, frame = 0
1964 @ frame_needed = 0, uses_anonymous_args = 0
1965 @ link register save eliminated.
1617:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_StateTypeDef state = hcan->State;
1966 .loc 1 1617 3 view .LVU668
1967 .loc 1 1617 24 is_stmt 0 view .LVU669
1968 0000 90F82030 ldrb r3, [r0, #32] @ zero_extendqisi2
1969 .LVL151:
1618:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1619:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Check function parameters */
1620:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_CAN_IT(ActiveITs));
1970 .loc 1 1620 3 is_stmt 1 view .LVU670
1621:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1622:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((state == HAL_CAN_STATE_READY) ||
1971 .loc 1 1622 3 view .LVU671
1972 .loc 1 1622 38 is_stmt 0 view .LVU672
1973 0004 013B subs r3, r3, #1
1974 .LVL152:
1975 .loc 1 1622 38 view .LVU673
1976 0006 DBB2 uxtb r3, r3
1977 .loc 1 1622 6 view .LVU674
1978 0008 012B cmp r3, #1
1979 000a 05D9 bls .L149
1623:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (state == HAL_CAN_STATE_LISTENING))
1624:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1625:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Enable the selected interrupts */
1626:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** __HAL_CAN_ENABLE_IT(hcan, ActiveITs);
1627:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1628:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Return function status */
1629:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** return HAL_OK;
1630:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1631:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** else
1632:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1633:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Update error code */
1634:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->ErrorCode |= HAL_CAN_ERROR_NOT_INITIALIZED;
1980 .loc 1 1634 5 is_stmt 1 view .LVU675
1981 .loc 1 1634 9 is_stmt 0 view .LVU676
ARM GAS /tmp/ccj1aKCo.s page 87
1982 000c 436A ldr r3, [r0, #36]
1983 .loc 1 1634 21 view .LVU677
1984 000e 43F48023 orr r3, r3, #262144
1985 0012 4362 str r3, [r0, #36]
1635:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1636:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** return HAL_ERROR;
1986 .loc 1 1636 5 is_stmt 1 view .LVU678
1987 .loc 1 1636 12 is_stmt 0 view .LVU679
1988 0014 0120 movs r0, #1
1989 .LVL153:
1637:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1638:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1990 .loc 1 1638 1 view .LVU680
1991 0016 7047 bx lr
1992 .LVL154:
1993 .L149:
1626:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1994 .loc 1 1626 5 is_stmt 1 view .LVU681
1995 0018 0268 ldr r2, [r0]
1996 001a 5369 ldr r3, [r2, #20]
1997 001c 0B43 orrs r3, r3, r1
1998 001e 5361 str r3, [r2, #20]
1629:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1999 .loc 1 1629 5 view .LVU682
1629:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2000 .loc 1 1629 12 is_stmt 0 view .LVU683
2001 0020 0020 movs r0, #0
2002 .LVL155:
1629:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2003 .loc 1 1629 12 view .LVU684
2004 0022 7047 bx lr
2005 .cfi_endproc
2006 .LFE147:
2008 .section .text.HAL_CAN_DeactivateNotification,"ax",%progbits
2009 .align 1
2010 .global HAL_CAN_DeactivateNotification
2011 .syntax unified
2012 .thumb
2013 .thumb_func
2015 HAL_CAN_DeactivateNotification:
2016 .LVL156:
2017 .LFB148:
1639:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1640:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /**
1641:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @brief Disable interrupts.
1642:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param hcan pointer to an CAN_HandleTypeDef structure that contains
1643:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * the configuration information for the specified CAN.
1644:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param InactiveITs indicates which interrupts will be disabled.
1645:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * This parameter can be any combination of @arg CAN_Interrupts.
1646:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @retval HAL status
1647:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
1648:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_StatusTypeDef HAL_CAN_DeactivateNotification(CAN_HandleTypeDef *hcan, uint32_t InactiveITs)
1649:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2018 .loc 1 1649 1 is_stmt 1 view -0
2019 .cfi_startproc
2020 @ args = 0, pretend = 0, frame = 0
2021 @ frame_needed = 0, uses_anonymous_args = 0
ARM GAS /tmp/ccj1aKCo.s page 88
2022 @ link register save eliminated.
1650:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_StateTypeDef state = hcan->State;
2023 .loc 1 1650 3 view .LVU686
2024 .loc 1 1650 24 is_stmt 0 view .LVU687
2025 0000 90F82030 ldrb r3, [r0, #32] @ zero_extendqisi2
2026 .LVL157:
1651:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1652:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Check function parameters */
1653:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** assert_param(IS_CAN_IT(InactiveITs));
2027 .loc 1 1653 3 is_stmt 1 view .LVU688
1654:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1655:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((state == HAL_CAN_STATE_READY) ||
2028 .loc 1 1655 3 view .LVU689
2029 .loc 1 1655 38 is_stmt 0 view .LVU690
2030 0004 013B subs r3, r3, #1
2031 .LVL158:
2032 .loc 1 1655 38 view .LVU691
2033 0006 DBB2 uxtb r3, r3
2034 .loc 1 1655 6 view .LVU692
2035 0008 012B cmp r3, #1
2036 000a 05D9 bls .L153
1656:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (state == HAL_CAN_STATE_LISTENING))
1657:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1658:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Disable the selected interrupts */
1659:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** __HAL_CAN_DISABLE_IT(hcan, InactiveITs);
1660:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1661:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Return function status */
1662:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** return HAL_OK;
1663:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1664:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** else
1665:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1666:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Update error code */
1667:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->ErrorCode |= HAL_CAN_ERROR_NOT_INITIALIZED;
2037 .loc 1 1667 5 is_stmt 1 view .LVU693
2038 .loc 1 1667 9 is_stmt 0 view .LVU694
2039 000c 436A ldr r3, [r0, #36]
2040 .loc 1 1667 21 view .LVU695
2041 000e 43F48023 orr r3, r3, #262144
2042 0012 4362 str r3, [r0, #36]
1668:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1669:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** return HAL_ERROR;
2043 .loc 1 1669 5 is_stmt 1 view .LVU696
2044 .loc 1 1669 12 is_stmt 0 view .LVU697
2045 0014 0120 movs r0, #1
2046 .LVL159:
1670:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1671:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2047 .loc 1 1671 1 view .LVU698
2048 0016 7047 bx lr
2049 .LVL160:
2050 .L153:
1659:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2051 .loc 1 1659 5 is_stmt 1 view .LVU699
2052 0018 0268 ldr r2, [r0]
2053 001a 5369 ldr r3, [r2, #20]
2054 001c 23EA0103 bic r3, r3, r1
2055 0020 5361 str r3, [r2, #20]
ARM GAS /tmp/ccj1aKCo.s page 89
1662:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2056 .loc 1 1662 5 view .LVU700
1662:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2057 .loc 1 1662 12 is_stmt 0 view .LVU701
2058 0022 0020 movs r0, #0
2059 .LVL161:
1662:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2060 .loc 1 1662 12 view .LVU702
2061 0024 7047 bx lr
2062 .cfi_endproc
2063 .LFE148:
2065 .section .text.HAL_CAN_TxMailbox0CompleteCallback,"ax",%progbits
2066 .align 1
2067 .weak HAL_CAN_TxMailbox0CompleteCallback
2068 .syntax unified
2069 .thumb
2070 .thumb_func
2072 HAL_CAN_TxMailbox0CompleteCallback:
2073 .LVL162:
2074 .LFB150:
1672:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1673:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /**
1674:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @brief Handles CAN interrupt request
1675:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param hcan pointer to a CAN_HandleTypeDef structure that contains
1676:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * the configuration information for the specified CAN.
1677:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @retval None
1678:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
1679:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** void HAL_CAN_IRQHandler(CAN_HandleTypeDef *hcan)
1680:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1681:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** uint32_t errorcode = HAL_CAN_ERROR_NONE;
1682:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** uint32_t interrupts = READ_REG(hcan->Instance->IER);
1683:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** uint32_t msrflags = READ_REG(hcan->Instance->MSR);
1684:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** uint32_t tsrflags = READ_REG(hcan->Instance->TSR);
1685:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** uint32_t rf0rflags = READ_REG(hcan->Instance->RF0R);
1686:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** uint32_t rf1rflags = READ_REG(hcan->Instance->RF1R);
1687:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** uint32_t esrflags = READ_REG(hcan->Instance->ESR);
1688:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1689:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Transmit Mailbox empty interrupt management *****************************/
1690:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((interrupts & CAN_IT_TX_MAILBOX_EMPTY) != 0U)
1691:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1692:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Transmit Mailbox 0 management *****************************************/
1693:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((tsrflags & CAN_TSR_RQCP0) != 0U)
1694:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1695:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Clear the Transmission Complete flag (and TXOK0,ALST0,TERR0 bits) */
1696:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** __HAL_CAN_CLEAR_FLAG(hcan, CAN_FLAG_RQCP0);
1697:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1698:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((tsrflags & CAN_TSR_TXOK0) != 0U)
1699:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1700:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Transmission Mailbox 0 complete callback */
1701:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #if USE_HAL_CAN_REGISTER_CALLBACKS == 1
1702:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Call registered callback*/
1703:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->TxMailbox0CompleteCallback(hcan);
1704:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #else
1705:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Call weak (surcharged) callback */
1706:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_TxMailbox0CompleteCallback(hcan);
1707:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #endif /* USE_HAL_CAN_REGISTER_CALLBACKS */
1708:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
ARM GAS /tmp/ccj1aKCo.s page 90
1709:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** else
1710:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1711:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((tsrflags & CAN_TSR_ALST0) != 0U)
1712:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1713:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Update error code */
1714:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** errorcode |= HAL_CAN_ERROR_TX_ALST0;
1715:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1716:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** else if ((tsrflags & CAN_TSR_TERR0) != 0U)
1717:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1718:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Update error code */
1719:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** errorcode |= HAL_CAN_ERROR_TX_TERR0;
1720:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1721:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** else
1722:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1723:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Transmission Mailbox 0 abort callback */
1724:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #if USE_HAL_CAN_REGISTER_CALLBACKS == 1
1725:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Call registered callback*/
1726:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->TxMailbox0AbortCallback(hcan);
1727:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #else
1728:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Call weak (surcharged) callback */
1729:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_TxMailbox0AbortCallback(hcan);
1730:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #endif /* USE_HAL_CAN_REGISTER_CALLBACKS */
1731:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1732:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1733:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1734:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1735:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Transmit Mailbox 1 management *****************************************/
1736:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((tsrflags & CAN_TSR_RQCP1) != 0U)
1737:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1738:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Clear the Transmission Complete flag (and TXOK1,ALST1,TERR1 bits) */
1739:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** __HAL_CAN_CLEAR_FLAG(hcan, CAN_FLAG_RQCP1);
1740:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1741:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((tsrflags & CAN_TSR_TXOK1) != 0U)
1742:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1743:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Transmission Mailbox 1 complete callback */
1744:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #if USE_HAL_CAN_REGISTER_CALLBACKS == 1
1745:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Call registered callback*/
1746:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->TxMailbox1CompleteCallback(hcan);
1747:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #else
1748:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Call weak (surcharged) callback */
1749:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_TxMailbox1CompleteCallback(hcan);
1750:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #endif /* USE_HAL_CAN_REGISTER_CALLBACKS */
1751:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1752:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** else
1753:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1754:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((tsrflags & CAN_TSR_ALST1) != 0U)
1755:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1756:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Update error code */
1757:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** errorcode |= HAL_CAN_ERROR_TX_ALST1;
1758:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1759:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** else if ((tsrflags & CAN_TSR_TERR1) != 0U)
1760:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1761:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Update error code */
1762:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** errorcode |= HAL_CAN_ERROR_TX_TERR1;
1763:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1764:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** else
1765:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
ARM GAS /tmp/ccj1aKCo.s page 91
1766:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Transmission Mailbox 1 abort callback */
1767:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #if USE_HAL_CAN_REGISTER_CALLBACKS == 1
1768:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Call registered callback*/
1769:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->TxMailbox1AbortCallback(hcan);
1770:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #else
1771:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Call weak (surcharged) callback */
1772:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_TxMailbox1AbortCallback(hcan);
1773:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #endif /* USE_HAL_CAN_REGISTER_CALLBACKS */
1774:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1775:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1776:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1777:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1778:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Transmit Mailbox 2 management *****************************************/
1779:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((tsrflags & CAN_TSR_RQCP2) != 0U)
1780:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1781:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Clear the Transmission Complete flag (and TXOK2,ALST2,TERR2 bits) */
1782:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** __HAL_CAN_CLEAR_FLAG(hcan, CAN_FLAG_RQCP2);
1783:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1784:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((tsrflags & CAN_TSR_TXOK2) != 0U)
1785:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1786:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Transmission Mailbox 2 complete callback */
1787:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #if USE_HAL_CAN_REGISTER_CALLBACKS == 1
1788:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Call registered callback*/
1789:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->TxMailbox2CompleteCallback(hcan);
1790:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #else
1791:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Call weak (surcharged) callback */
1792:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_TxMailbox2CompleteCallback(hcan);
1793:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #endif /* USE_HAL_CAN_REGISTER_CALLBACKS */
1794:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1795:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** else
1796:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1797:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((tsrflags & CAN_TSR_ALST2) != 0U)
1798:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1799:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Update error code */
1800:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** errorcode |= HAL_CAN_ERROR_TX_ALST2;
1801:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1802:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** else if ((tsrflags & CAN_TSR_TERR2) != 0U)
1803:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1804:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Update error code */
1805:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** errorcode |= HAL_CAN_ERROR_TX_TERR2;
1806:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1807:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** else
1808:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1809:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Transmission Mailbox 2 abort callback */
1810:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #if USE_HAL_CAN_REGISTER_CALLBACKS == 1
1811:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Call registered callback*/
1812:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->TxMailbox2AbortCallback(hcan);
1813:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #else
1814:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Call weak (surcharged) callback */
1815:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_TxMailbox2AbortCallback(hcan);
1816:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #endif /* USE_HAL_CAN_REGISTER_CALLBACKS */
1817:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1818:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1819:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1820:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1821:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1822:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Receive FIFO 0 overrun interrupt management *****************************/
ARM GAS /tmp/ccj1aKCo.s page 92
1823:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((interrupts & CAN_IT_RX_FIFO0_OVERRUN) != 0U)
1824:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1825:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((rf0rflags & CAN_RF0R_FOVR0) != 0U)
1826:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1827:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Set CAN error code to Rx Fifo 0 overrun error */
1828:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** errorcode |= HAL_CAN_ERROR_RX_FOV0;
1829:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1830:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Clear FIFO0 Overrun Flag */
1831:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** __HAL_CAN_CLEAR_FLAG(hcan, CAN_FLAG_FOV0);
1832:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1833:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1834:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1835:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Receive FIFO 0 full interrupt management ********************************/
1836:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((interrupts & CAN_IT_RX_FIFO0_FULL) != 0U)
1837:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1838:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((rf0rflags & CAN_RF0R_FULL0) != 0U)
1839:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1840:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Clear FIFO 0 full Flag */
1841:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** __HAL_CAN_CLEAR_FLAG(hcan, CAN_FLAG_FF0);
1842:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1843:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Receive FIFO 0 full Callback */
1844:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #if USE_HAL_CAN_REGISTER_CALLBACKS == 1
1845:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Call registered callback*/
1846:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->RxFifo0FullCallback(hcan);
1847:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #else
1848:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Call weak (surcharged) callback */
1849:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_RxFifo0FullCallback(hcan);
1850:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #endif /* USE_HAL_CAN_REGISTER_CALLBACKS */
1851:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1852:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1853:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1854:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Receive FIFO 0 message pending interrupt management *********************/
1855:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((interrupts & CAN_IT_RX_FIFO0_MSG_PENDING) != 0U)
1856:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1857:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Check if message is still pending */
1858:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((hcan->Instance->RF0R & CAN_RF0R_FMP0) != 0U)
1859:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1860:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Receive FIFO 0 message pending Callback */
1861:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #if USE_HAL_CAN_REGISTER_CALLBACKS == 1
1862:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Call registered callback*/
1863:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->RxFifo0MsgPendingCallback(hcan);
1864:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #else
1865:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Call weak (surcharged) callback */
1866:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_RxFifo0MsgPendingCallback(hcan);
1867:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #endif /* USE_HAL_CAN_REGISTER_CALLBACKS */
1868:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1869:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1870:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1871:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Receive FIFO 1 overrun interrupt management *****************************/
1872:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((interrupts & CAN_IT_RX_FIFO1_OVERRUN) != 0U)
1873:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1874:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((rf1rflags & CAN_RF1R_FOVR1) != 0U)
1875:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1876:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Set CAN error code to Rx Fifo 1 overrun error */
1877:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** errorcode |= HAL_CAN_ERROR_RX_FOV1;
1878:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1879:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Clear FIFO1 Overrun Flag */
ARM GAS /tmp/ccj1aKCo.s page 93
1880:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** __HAL_CAN_CLEAR_FLAG(hcan, CAN_FLAG_FOV1);
1881:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1882:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1883:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1884:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Receive FIFO 1 full interrupt management ********************************/
1885:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((interrupts & CAN_IT_RX_FIFO1_FULL) != 0U)
1886:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1887:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((rf1rflags & CAN_RF1R_FULL1) != 0U)
1888:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1889:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Clear FIFO 1 full Flag */
1890:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** __HAL_CAN_CLEAR_FLAG(hcan, CAN_FLAG_FF1);
1891:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1892:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Receive FIFO 1 full Callback */
1893:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #if USE_HAL_CAN_REGISTER_CALLBACKS == 1
1894:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Call registered callback*/
1895:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->RxFifo1FullCallback(hcan);
1896:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #else
1897:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Call weak (surcharged) callback */
1898:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_RxFifo1FullCallback(hcan);
1899:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #endif /* USE_HAL_CAN_REGISTER_CALLBACKS */
1900:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1901:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1902:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1903:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Receive FIFO 1 message pending interrupt management *********************/
1904:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((interrupts & CAN_IT_RX_FIFO1_MSG_PENDING) != 0U)
1905:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1906:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Check if message is still pending */
1907:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((hcan->Instance->RF1R & CAN_RF1R_FMP1) != 0U)
1908:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1909:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Receive FIFO 1 message pending Callback */
1910:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #if USE_HAL_CAN_REGISTER_CALLBACKS == 1
1911:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Call registered callback*/
1912:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->RxFifo1MsgPendingCallback(hcan);
1913:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #else
1914:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Call weak (surcharged) callback */
1915:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_RxFifo1MsgPendingCallback(hcan);
1916:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #endif /* USE_HAL_CAN_REGISTER_CALLBACKS */
1917:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1918:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1919:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1920:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Sleep interrupt management *********************************************/
1921:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((interrupts & CAN_IT_SLEEP_ACK) != 0U)
1922:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1923:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((msrflags & CAN_MSR_SLAKI) != 0U)
1924:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1925:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Clear Sleep interrupt Flag */
1926:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** __HAL_CAN_CLEAR_FLAG(hcan, CAN_FLAG_SLAKI);
1927:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1928:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Sleep Callback */
1929:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #if USE_HAL_CAN_REGISTER_CALLBACKS == 1
1930:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Call registered callback*/
1931:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->SleepCallback(hcan);
1932:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #else
1933:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Call weak (surcharged) callback */
1934:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_SleepCallback(hcan);
1935:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #endif /* USE_HAL_CAN_REGISTER_CALLBACKS */
1936:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
ARM GAS /tmp/ccj1aKCo.s page 94
1937:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1938:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1939:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* WakeUp interrupt management *********************************************/
1940:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((interrupts & CAN_IT_WAKEUP) != 0U)
1941:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1942:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((msrflags & CAN_MSR_WKUI) != 0U)
1943:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1944:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Clear WakeUp Flag */
1945:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** __HAL_CAN_CLEAR_FLAG(hcan, CAN_FLAG_WKU);
1946:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1947:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* WakeUp Callback */
1948:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #if USE_HAL_CAN_REGISTER_CALLBACKS == 1
1949:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Call registered callback*/
1950:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->WakeUpFromRxMsgCallback(hcan);
1951:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #else
1952:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Call weak (surcharged) callback */
1953:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_WakeUpFromRxMsgCallback(hcan);
1954:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #endif /* USE_HAL_CAN_REGISTER_CALLBACKS */
1955:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1956:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1957:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1958:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Error interrupts management *********************************************/
1959:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((interrupts & CAN_IT_ERROR) != 0U)
1960:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1961:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((msrflags & CAN_MSR_ERRI) != 0U)
1962:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1963:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Check Error Warning Flag */
1964:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if (((interrupts & CAN_IT_ERROR_WARNING) != 0U) &&
1965:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ((esrflags & CAN_ESR_EWGF) != 0U))
1966:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1967:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Set CAN error code to Error Warning */
1968:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** errorcode |= HAL_CAN_ERROR_EWG;
1969:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1970:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* No need for clear of Error Warning Flag as read-only */
1971:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1972:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1973:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Check Error Passive Flag */
1974:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if (((interrupts & CAN_IT_ERROR_PASSIVE) != 0U) &&
1975:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ((esrflags & CAN_ESR_EPVF) != 0U))
1976:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1977:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Set CAN error code to Error Passive */
1978:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** errorcode |= HAL_CAN_ERROR_EPV;
1979:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1980:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* No need for clear of Error Passive Flag as read-only */
1981:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1982:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1983:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Check Bus-off Flag */
1984:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if (((interrupts & CAN_IT_BUSOFF) != 0U) &&
1985:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ((esrflags & CAN_ESR_BOFF) != 0U))
1986:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1987:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Set CAN error code to Bus-Off */
1988:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** errorcode |= HAL_CAN_ERROR_BOF;
1989:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1990:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* No need for clear of Error Bus-Off as read-only */
1991:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
1992:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
1993:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Check Last Error Code Flag */
ARM GAS /tmp/ccj1aKCo.s page 95
1994:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if (((interrupts & CAN_IT_LAST_ERROR_CODE) != 0U) &&
1995:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ((esrflags & CAN_ESR_LEC) != 0U))
1996:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1997:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** switch (esrflags & CAN_ESR_LEC)
1998:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
1999:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** case (CAN_ESR_LEC_0):
2000:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Set CAN error code to Stuff error */
2001:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** errorcode |= HAL_CAN_ERROR_STF;
2002:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
2003:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** case (CAN_ESR_LEC_1):
2004:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Set CAN error code to Form error */
2005:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** errorcode |= HAL_CAN_ERROR_FOR;
2006:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
2007:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** case (CAN_ESR_LEC_1 | CAN_ESR_LEC_0):
2008:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Set CAN error code to Acknowledgement error */
2009:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** errorcode |= HAL_CAN_ERROR_ACK;
2010:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
2011:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** case (CAN_ESR_LEC_2):
2012:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Set CAN error code to Bit recessive error */
2013:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** errorcode |= HAL_CAN_ERROR_BR;
2014:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
2015:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** case (CAN_ESR_LEC_2 | CAN_ESR_LEC_0):
2016:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Set CAN error code to Bit Dominant error */
2017:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** errorcode |= HAL_CAN_ERROR_BD;
2018:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
2019:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** case (CAN_ESR_LEC_2 | CAN_ESR_LEC_1):
2020:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Set CAN error code to CRC error */
2021:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** errorcode |= HAL_CAN_ERROR_CRC;
2022:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
2023:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** default:
2024:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
2025:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2026:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2027:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Clear Last error code Flag */
2028:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** CLEAR_BIT(hcan->Instance->ESR, CAN_ESR_LEC);
2029:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2030:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2031:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2032:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Clear ERRI Flag */
2033:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** __HAL_CAN_CLEAR_FLAG(hcan, CAN_FLAG_ERRI);
2034:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2035:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2036:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Call the Error call Back in case of Errors */
2037:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if (errorcode != HAL_CAN_ERROR_NONE)
2038:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2039:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Update error code in handle */
2040:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->ErrorCode |= errorcode;
2041:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2042:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Call Error callback function */
2043:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #if USE_HAL_CAN_REGISTER_CALLBACKS == 1
2044:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Call registered callback*/
2045:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->ErrorCallback(hcan);
2046:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #else
2047:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Call weak (surcharged) callback */
2048:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_ErrorCallback(hcan);
2049:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #endif /* USE_HAL_CAN_REGISTER_CALLBACKS */
2050:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
ARM GAS /tmp/ccj1aKCo.s page 96
2051:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2052:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2053:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /**
2054:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @}
2055:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
2056:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2057:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /** @defgroup CAN_Exported_Functions_Group5 Callback functions
2058:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @brief CAN Callback functions
2059:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** *
2060:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** @verbatim
2061:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ==============================================================================
2062:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ##### Callback functions #####
2063:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ==============================================================================
2064:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** [..]
2065:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** This subsection provides the following callback functions:
2066:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) HAL_CAN_TxMailbox0CompleteCallback
2067:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) HAL_CAN_TxMailbox1CompleteCallback
2068:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) HAL_CAN_TxMailbox2CompleteCallback
2069:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) HAL_CAN_TxMailbox0AbortCallback
2070:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) HAL_CAN_TxMailbox1AbortCallback
2071:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) HAL_CAN_TxMailbox2AbortCallback
2072:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) HAL_CAN_RxFifo0MsgPendingCallback
2073:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) HAL_CAN_RxFifo0FullCallback
2074:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) HAL_CAN_RxFifo1MsgPendingCallback
2075:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) HAL_CAN_RxFifo1FullCallback
2076:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) HAL_CAN_SleepCallback
2077:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) HAL_CAN_WakeUpFromRxMsgCallback
2078:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) HAL_CAN_ErrorCallback
2079:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2080:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** @endverbatim
2081:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @{
2082:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
2083:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2084:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /**
2085:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @brief Transmission Mailbox 0 complete callback.
2086:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param hcan pointer to a CAN_HandleTypeDef structure that contains
2087:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * the configuration information for the specified CAN.
2088:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @retval None
2089:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
2090:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** __weak void HAL_CAN_TxMailbox0CompleteCallback(CAN_HandleTypeDef *hcan)
2091:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2075 .loc 1 2091 1 is_stmt 1 view -0
2076 .cfi_startproc
2077 @ args = 0, pretend = 0, frame = 0
2078 @ frame_needed = 0, uses_anonymous_args = 0
2079 @ link register save eliminated.
2092:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Prevent unused argument(s) compilation warning */
2093:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** UNUSED(hcan);
2080 .loc 1 2093 3 view .LVU704
2094:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2095:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* NOTE : This function Should not be modified, when the callback is needed,
2096:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** the HAL_CAN_TxMailbox0CompleteCallback could be implemented in the
2097:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** user file
2098:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
2099:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2081 .loc 1 2099 1 is_stmt 0 view .LVU705
2082 0000 7047 bx lr
ARM GAS /tmp/ccj1aKCo.s page 97
2083 .cfi_endproc
2084 .LFE150:
2086 .section .text.HAL_CAN_TxMailbox1CompleteCallback,"ax",%progbits
2087 .align 1
2088 .weak HAL_CAN_TxMailbox1CompleteCallback
2089 .syntax unified
2090 .thumb
2091 .thumb_func
2093 HAL_CAN_TxMailbox1CompleteCallback:
2094 .LVL163:
2095 .LFB151:
2100:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2101:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /**
2102:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @brief Transmission Mailbox 1 complete callback.
2103:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param hcan pointer to a CAN_HandleTypeDef structure that contains
2104:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * the configuration information for the specified CAN.
2105:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @retval None
2106:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
2107:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** __weak void HAL_CAN_TxMailbox1CompleteCallback(CAN_HandleTypeDef *hcan)
2108:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2096 .loc 1 2108 1 is_stmt 1 view -0
2097 .cfi_startproc
2098 @ args = 0, pretend = 0, frame = 0
2099 @ frame_needed = 0, uses_anonymous_args = 0
2100 @ link register save eliminated.
2109:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Prevent unused argument(s) compilation warning */
2110:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** UNUSED(hcan);
2101 .loc 1 2110 3 view .LVU707
2111:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2112:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* NOTE : This function Should not be modified, when the callback is needed,
2113:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** the HAL_CAN_TxMailbox1CompleteCallback could be implemented in the
2114:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** user file
2115:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
2116:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2102 .loc 1 2116 1 is_stmt 0 view .LVU708
2103 0000 7047 bx lr
2104 .cfi_endproc
2105 .LFE151:
2107 .section .text.HAL_CAN_TxMailbox2CompleteCallback,"ax",%progbits
2108 .align 1
2109 .weak HAL_CAN_TxMailbox2CompleteCallback
2110 .syntax unified
2111 .thumb
2112 .thumb_func
2114 HAL_CAN_TxMailbox2CompleteCallback:
2115 .LVL164:
2116 .LFB152:
2117:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2118:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /**
2119:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @brief Transmission Mailbox 2 complete callback.
2120:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param hcan pointer to a CAN_HandleTypeDef structure that contains
2121:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * the configuration information for the specified CAN.
2122:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @retval None
2123:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
2124:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** __weak void HAL_CAN_TxMailbox2CompleteCallback(CAN_HandleTypeDef *hcan)
2125:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2117 .loc 1 2125 1 is_stmt 1 view -0
ARM GAS /tmp/ccj1aKCo.s page 98
2118 .cfi_startproc
2119 @ args = 0, pretend = 0, frame = 0
2120 @ frame_needed = 0, uses_anonymous_args = 0
2121 @ link register save eliminated.
2126:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Prevent unused argument(s) compilation warning */
2127:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** UNUSED(hcan);
2122 .loc 1 2127 3 view .LVU710
2128:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2129:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* NOTE : This function Should not be modified, when the callback is needed,
2130:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** the HAL_CAN_TxMailbox2CompleteCallback could be implemented in the
2131:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** user file
2132:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
2133:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2123 .loc 1 2133 1 is_stmt 0 view .LVU711
2124 0000 7047 bx lr
2125 .cfi_endproc
2126 .LFE152:
2128 .section .text.HAL_CAN_TxMailbox0AbortCallback,"ax",%progbits
2129 .align 1
2130 .weak HAL_CAN_TxMailbox0AbortCallback
2131 .syntax unified
2132 .thumb
2133 .thumb_func
2135 HAL_CAN_TxMailbox0AbortCallback:
2136 .LVL165:
2137 .LFB153:
2134:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2135:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /**
2136:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @brief Transmission Mailbox 0 Cancellation callback.
2137:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param hcan pointer to an CAN_HandleTypeDef structure that contains
2138:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * the configuration information for the specified CAN.
2139:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @retval None
2140:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
2141:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** __weak void HAL_CAN_TxMailbox0AbortCallback(CAN_HandleTypeDef *hcan)
2142:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2138 .loc 1 2142 1 is_stmt 1 view -0
2139 .cfi_startproc
2140 @ args = 0, pretend = 0, frame = 0
2141 @ frame_needed = 0, uses_anonymous_args = 0
2142 @ link register save eliminated.
2143:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Prevent unused argument(s) compilation warning */
2144:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** UNUSED(hcan);
2143 .loc 1 2144 3 view .LVU713
2145:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2146:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* NOTE : This function Should not be modified, when the callback is needed,
2147:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** the HAL_CAN_TxMailbox0AbortCallback could be implemented in the
2148:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** user file
2149:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
2150:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2144 .loc 1 2150 1 is_stmt 0 view .LVU714
2145 0000 7047 bx lr
2146 .cfi_endproc
2147 .LFE153:
2149 .section .text.HAL_CAN_TxMailbox1AbortCallback,"ax",%progbits
2150 .align 1
2151 .weak HAL_CAN_TxMailbox1AbortCallback
2152 .syntax unified
ARM GAS /tmp/ccj1aKCo.s page 99
2153 .thumb
2154 .thumb_func
2156 HAL_CAN_TxMailbox1AbortCallback:
2157 .LVL166:
2158 .LFB154:
2151:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2152:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /**
2153:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @brief Transmission Mailbox 1 Cancellation callback.
2154:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param hcan pointer to an CAN_HandleTypeDef structure that contains
2155:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * the configuration information for the specified CAN.
2156:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @retval None
2157:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
2158:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** __weak void HAL_CAN_TxMailbox1AbortCallback(CAN_HandleTypeDef *hcan)
2159:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2159 .loc 1 2159 1 is_stmt 1 view -0
2160 .cfi_startproc
2161 @ args = 0, pretend = 0, frame = 0
2162 @ frame_needed = 0, uses_anonymous_args = 0
2163 @ link register save eliminated.
2160:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Prevent unused argument(s) compilation warning */
2161:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** UNUSED(hcan);
2164 .loc 1 2161 3 view .LVU716
2162:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2163:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* NOTE : This function Should not be modified, when the callback is needed,
2164:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** the HAL_CAN_TxMailbox1AbortCallback could be implemented in the
2165:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** user file
2166:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
2167:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2165 .loc 1 2167 1 is_stmt 0 view .LVU717
2166 0000 7047 bx lr
2167 .cfi_endproc
2168 .LFE154:
2170 .section .text.HAL_CAN_TxMailbox2AbortCallback,"ax",%progbits
2171 .align 1
2172 .weak HAL_CAN_TxMailbox2AbortCallback
2173 .syntax unified
2174 .thumb
2175 .thumb_func
2177 HAL_CAN_TxMailbox2AbortCallback:
2178 .LVL167:
2179 .LFB155:
2168:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2169:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /**
2170:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @brief Transmission Mailbox 2 Cancellation callback.
2171:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param hcan pointer to an CAN_HandleTypeDef structure that contains
2172:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * the configuration information for the specified CAN.
2173:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @retval None
2174:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
2175:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** __weak void HAL_CAN_TxMailbox2AbortCallback(CAN_HandleTypeDef *hcan)
2176:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2180 .loc 1 2176 1 is_stmt 1 view -0
2181 .cfi_startproc
2182 @ args = 0, pretend = 0, frame = 0
2183 @ frame_needed = 0, uses_anonymous_args = 0
2184 @ link register save eliminated.
2177:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Prevent unused argument(s) compilation warning */
2178:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** UNUSED(hcan);
ARM GAS /tmp/ccj1aKCo.s page 100
2185 .loc 1 2178 3 view .LVU719
2179:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2180:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* NOTE : This function Should not be modified, when the callback is needed,
2181:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** the HAL_CAN_TxMailbox2AbortCallback could be implemented in the
2182:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** user file
2183:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
2184:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2186 .loc 1 2184 1 is_stmt 0 view .LVU720
2187 0000 7047 bx lr
2188 .cfi_endproc
2189 .LFE155:
2191 .section .text.HAL_CAN_RxFifo0MsgPendingCallback,"ax",%progbits
2192 .align 1
2193 .weak HAL_CAN_RxFifo0MsgPendingCallback
2194 .syntax unified
2195 .thumb
2196 .thumb_func
2198 HAL_CAN_RxFifo0MsgPendingCallback:
2199 .LVL168:
2200 .LFB156:
2185:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2186:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /**
2187:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @brief Rx FIFO 0 message pending callback.
2188:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param hcan pointer to a CAN_HandleTypeDef structure that contains
2189:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * the configuration information for the specified CAN.
2190:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @retval None
2191:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
2192:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** __weak void HAL_CAN_RxFifo0MsgPendingCallback(CAN_HandleTypeDef *hcan)
2193:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2201 .loc 1 2193 1 is_stmt 1 view -0
2202 .cfi_startproc
2203 @ args = 0, pretend = 0, frame = 0
2204 @ frame_needed = 0, uses_anonymous_args = 0
2205 @ link register save eliminated.
2194:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Prevent unused argument(s) compilation warning */
2195:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** UNUSED(hcan);
2206 .loc 1 2195 3 view .LVU722
2196:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2197:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* NOTE : This function Should not be modified, when the callback is needed,
2198:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** the HAL_CAN_RxFifo0MsgPendingCallback could be implemented in the
2199:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** user file
2200:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
2201:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2207 .loc 1 2201 1 is_stmt 0 view .LVU723
2208 0000 7047 bx lr
2209 .cfi_endproc
2210 .LFE156:
2212 .section .text.HAL_CAN_RxFifo0FullCallback,"ax",%progbits
2213 .align 1
2214 .weak HAL_CAN_RxFifo0FullCallback
2215 .syntax unified
2216 .thumb
2217 .thumb_func
2219 HAL_CAN_RxFifo0FullCallback:
2220 .LVL169:
2221 .LFB157:
2202:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
ARM GAS /tmp/ccj1aKCo.s page 101
2203:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /**
2204:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @brief Rx FIFO 0 full callback.
2205:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param hcan pointer to a CAN_HandleTypeDef structure that contains
2206:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * the configuration information for the specified CAN.
2207:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @retval None
2208:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
2209:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** __weak void HAL_CAN_RxFifo0FullCallback(CAN_HandleTypeDef *hcan)
2210:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2222 .loc 1 2210 1 is_stmt 1 view -0
2223 .cfi_startproc
2224 @ args = 0, pretend = 0, frame = 0
2225 @ frame_needed = 0, uses_anonymous_args = 0
2226 @ link register save eliminated.
2211:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Prevent unused argument(s) compilation warning */
2212:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** UNUSED(hcan);
2227 .loc 1 2212 3 view .LVU725
2213:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2214:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* NOTE : This function Should not be modified, when the callback is needed,
2215:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** the HAL_CAN_RxFifo0FullCallback could be implemented in the user
2216:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** file
2217:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
2218:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2228 .loc 1 2218 1 is_stmt 0 view .LVU726
2229 0000 7047 bx lr
2230 .cfi_endproc
2231 .LFE157:
2233 .section .text.HAL_CAN_RxFifo1MsgPendingCallback,"ax",%progbits
2234 .align 1
2235 .weak HAL_CAN_RxFifo1MsgPendingCallback
2236 .syntax unified
2237 .thumb
2238 .thumb_func
2240 HAL_CAN_RxFifo1MsgPendingCallback:
2241 .LVL170:
2242 .LFB158:
2219:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2220:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /**
2221:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @brief Rx FIFO 1 message pending callback.
2222:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param hcan pointer to a CAN_HandleTypeDef structure that contains
2223:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * the configuration information for the specified CAN.
2224:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @retval None
2225:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
2226:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** __weak void HAL_CAN_RxFifo1MsgPendingCallback(CAN_HandleTypeDef *hcan)
2227:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2243 .loc 1 2227 1 is_stmt 1 view -0
2244 .cfi_startproc
2245 @ args = 0, pretend = 0, frame = 0
2246 @ frame_needed = 0, uses_anonymous_args = 0
2247 @ link register save eliminated.
2228:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Prevent unused argument(s) compilation warning */
2229:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** UNUSED(hcan);
2248 .loc 1 2229 3 view .LVU728
2230:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2231:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* NOTE : This function Should not be modified, when the callback is needed,
2232:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** the HAL_CAN_RxFifo1MsgPendingCallback could be implemented in the
2233:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** user file
2234:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
ARM GAS /tmp/ccj1aKCo.s page 102
2235:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2249 .loc 1 2235 1 is_stmt 0 view .LVU729
2250 0000 7047 bx lr
2251 .cfi_endproc
2252 .LFE158:
2254 .section .text.HAL_CAN_RxFifo1FullCallback,"ax",%progbits
2255 .align 1
2256 .weak HAL_CAN_RxFifo1FullCallback
2257 .syntax unified
2258 .thumb
2259 .thumb_func
2261 HAL_CAN_RxFifo1FullCallback:
2262 .LVL171:
2263 .LFB159:
2236:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2237:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /**
2238:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @brief Rx FIFO 1 full callback.
2239:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param hcan pointer to a CAN_HandleTypeDef structure that contains
2240:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * the configuration information for the specified CAN.
2241:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @retval None
2242:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
2243:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** __weak void HAL_CAN_RxFifo1FullCallback(CAN_HandleTypeDef *hcan)
2244:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2264 .loc 1 2244 1 is_stmt 1 view -0
2265 .cfi_startproc
2266 @ args = 0, pretend = 0, frame = 0
2267 @ frame_needed = 0, uses_anonymous_args = 0
2268 @ link register save eliminated.
2245:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Prevent unused argument(s) compilation warning */
2246:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** UNUSED(hcan);
2269 .loc 1 2246 3 view .LVU731
2247:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2248:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* NOTE : This function Should not be modified, when the callback is needed,
2249:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** the HAL_CAN_RxFifo1FullCallback could be implemented in the user
2250:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** file
2251:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
2252:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2270 .loc 1 2252 1 is_stmt 0 view .LVU732
2271 0000 7047 bx lr
2272 .cfi_endproc
2273 .LFE159:
2275 .section .text.HAL_CAN_SleepCallback,"ax",%progbits
2276 .align 1
2277 .weak HAL_CAN_SleepCallback
2278 .syntax unified
2279 .thumb
2280 .thumb_func
2282 HAL_CAN_SleepCallback:
2283 .LVL172:
2284 .LFB160:
2253:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2254:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /**
2255:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @brief Sleep callback.
2256:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param hcan pointer to a CAN_HandleTypeDef structure that contains
2257:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * the configuration information for the specified CAN.
2258:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @retval None
2259:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
ARM GAS /tmp/ccj1aKCo.s page 103
2260:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** __weak void HAL_CAN_SleepCallback(CAN_HandleTypeDef *hcan)
2261:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2285 .loc 1 2261 1 is_stmt 1 view -0
2286 .cfi_startproc
2287 @ args = 0, pretend = 0, frame = 0
2288 @ frame_needed = 0, uses_anonymous_args = 0
2289 @ link register save eliminated.
2262:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Prevent unused argument(s) compilation warning */
2263:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** UNUSED(hcan);
2290 .loc 1 2263 3 view .LVU734
2264:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2265:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* NOTE : This function Should not be modified, when the callback is needed,
2266:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** the HAL_CAN_SleepCallback could be implemented in the user file
2267:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
2268:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2291 .loc 1 2268 1 is_stmt 0 view .LVU735
2292 0000 7047 bx lr
2293 .cfi_endproc
2294 .LFE160:
2296 .section .text.HAL_CAN_WakeUpFromRxMsgCallback,"ax",%progbits
2297 .align 1
2298 .weak HAL_CAN_WakeUpFromRxMsgCallback
2299 .syntax unified
2300 .thumb
2301 .thumb_func
2303 HAL_CAN_WakeUpFromRxMsgCallback:
2304 .LVL173:
2305 .LFB161:
2269:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2270:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /**
2271:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @brief WakeUp from Rx message callback.
2272:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param hcan pointer to a CAN_HandleTypeDef structure that contains
2273:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * the configuration information for the specified CAN.
2274:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @retval None
2275:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
2276:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** __weak void HAL_CAN_WakeUpFromRxMsgCallback(CAN_HandleTypeDef *hcan)
2277:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2306 .loc 1 2277 1 is_stmt 1 view -0
2307 .cfi_startproc
2308 @ args = 0, pretend = 0, frame = 0
2309 @ frame_needed = 0, uses_anonymous_args = 0
2310 @ link register save eliminated.
2278:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Prevent unused argument(s) compilation warning */
2279:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** UNUSED(hcan);
2311 .loc 1 2279 3 view .LVU737
2280:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2281:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* NOTE : This function Should not be modified, when the callback is needed,
2282:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** the HAL_CAN_WakeUpFromRxMsgCallback could be implemented in the
2283:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** user file
2284:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
2285:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2312 .loc 1 2285 1 is_stmt 0 view .LVU738
2313 0000 7047 bx lr
2314 .cfi_endproc
2315 .LFE161:
2317 .section .text.HAL_CAN_ErrorCallback,"ax",%progbits
2318 .align 1
ARM GAS /tmp/ccj1aKCo.s page 104
2319 .weak HAL_CAN_ErrorCallback
2320 .syntax unified
2321 .thumb
2322 .thumb_func
2324 HAL_CAN_ErrorCallback:
2325 .LVL174:
2326 .LFB162:
2286:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2287:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /**
2288:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @brief Error CAN callback.
2289:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param hcan pointer to a CAN_HandleTypeDef structure that contains
2290:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * the configuration information for the specified CAN.
2291:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @retval None
2292:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
2293:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** __weak void HAL_CAN_ErrorCallback(CAN_HandleTypeDef *hcan)
2294:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2327 .loc 1 2294 1 is_stmt 1 view -0
2328 .cfi_startproc
2329 @ args = 0, pretend = 0, frame = 0
2330 @ frame_needed = 0, uses_anonymous_args = 0
2331 @ link register save eliminated.
2295:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Prevent unused argument(s) compilation warning */
2296:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** UNUSED(hcan);
2332 .loc 1 2296 3 view .LVU740
2297:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2298:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* NOTE : This function Should not be modified, when the callback is needed,
2299:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** the HAL_CAN_ErrorCallback could be implemented in the user file
2300:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
2301:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2333 .loc 1 2301 1 is_stmt 0 view .LVU741
2334 0000 7047 bx lr
2335 .cfi_endproc
2336 .LFE162:
2338 .section .text.HAL_CAN_IRQHandler,"ax",%progbits
2339 .align 1
2340 .global HAL_CAN_IRQHandler
2341 .syntax unified
2342 .thumb
2343 .thumb_func
2345 HAL_CAN_IRQHandler:
2346 .LVL175:
2347 .LFB149:
1680:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** uint32_t errorcode = HAL_CAN_ERROR_NONE;
2348 .loc 1 1680 1 is_stmt 1 view -0
2349 .cfi_startproc
2350 @ args = 0, pretend = 0, frame = 0
2351 @ frame_needed = 0, uses_anonymous_args = 0
1680:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** uint32_t errorcode = HAL_CAN_ERROR_NONE;
2352 .loc 1 1680 1 is_stmt 0 view .LVU743
2353 0000 2DE9F84F push {r3, r4, r5, r6, r7, r8, r9, r10, fp, lr}
2354 .cfi_def_cfa_offset 40
2355 .cfi_offset 3, -40
2356 .cfi_offset 4, -36
2357 .cfi_offset 5, -32
2358 .cfi_offset 6, -28
2359 .cfi_offset 7, -24
2360 .cfi_offset 8, -20
ARM GAS /tmp/ccj1aKCo.s page 105
2361 .cfi_offset 9, -16
2362 .cfi_offset 10, -12
2363 .cfi_offset 11, -8
2364 .cfi_offset 14, -4
2365 0004 0546 mov r5, r0
1681:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** uint32_t interrupts = READ_REG(hcan->Instance->IER);
2366 .loc 1 1681 3 is_stmt 1 view .LVU744
2367 .LVL176:
1682:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** uint32_t msrflags = READ_REG(hcan->Instance->MSR);
2368 .loc 1 1682 3 view .LVU745
1682:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** uint32_t msrflags = READ_REG(hcan->Instance->MSR);
2369 .loc 1 1682 25 is_stmt 0 view .LVU746
2370 0006 0368 ldr r3, [r0]
1682:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** uint32_t msrflags = READ_REG(hcan->Instance->MSR);
2371 .loc 1 1682 12 view .LVU747
2372 0008 5C69 ldr r4, [r3, #20]
2373 .LVL177:
1683:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** uint32_t tsrflags = READ_REG(hcan->Instance->TSR);
2374 .loc 1 1683 3 is_stmt 1 view .LVU748
1683:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** uint32_t tsrflags = READ_REG(hcan->Instance->TSR);
2375 .loc 1 1683 12 is_stmt 0 view .LVU749
2376 000a D3F80480 ldr r8, [r3, #4]
2377 .LVL178:
1684:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** uint32_t rf0rflags = READ_REG(hcan->Instance->RF0R);
2378 .loc 1 1684 3 is_stmt 1 view .LVU750
1684:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** uint32_t rf0rflags = READ_REG(hcan->Instance->RF0R);
2379 .loc 1 1684 12 is_stmt 0 view .LVU751
2380 000e 9F68 ldr r7, [r3, #8]
2381 .LVL179:
1685:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** uint32_t rf1rflags = READ_REG(hcan->Instance->RF1R);
2382 .loc 1 1685 3 is_stmt 1 view .LVU752
1685:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** uint32_t rf1rflags = READ_REG(hcan->Instance->RF1R);
2383 .loc 1 1685 12 is_stmt 0 view .LVU753
2384 0010 D3F80CB0 ldr fp, [r3, #12]
2385 .LVL180:
1686:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** uint32_t esrflags = READ_REG(hcan->Instance->ESR);
2386 .loc 1 1686 3 is_stmt 1 view .LVU754
1686:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** uint32_t esrflags = READ_REG(hcan->Instance->ESR);
2387 .loc 1 1686 12 is_stmt 0 view .LVU755
2388 0014 D3F810A0 ldr r10, [r3, #16]
2389 .LVL181:
1687:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2390 .loc 1 1687 3 is_stmt 1 view .LVU756
1687:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2391 .loc 1 1687 12 is_stmt 0 view .LVU757
2392 0018 D3F81890 ldr r9, [r3, #24]
2393 .LVL182:
1690:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2394 .loc 1 1690 3 is_stmt 1 view .LVU758
1690:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2395 .loc 1 1690 6 is_stmt 0 view .LVU759
2396 001c 14F00106 ands r6, r4, #1
2397 0020 3BD0 beq .L168
1693:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2398 .loc 1 1693 5 is_stmt 1 view .LVU760
1693:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2399 .loc 1 1693 8 is_stmt 0 view .LVU761
ARM GAS /tmp/ccj1aKCo.s page 106
2400 0022 17F00106 ands r6, r7, #1
2401 0026 16D0 beq .L169
1696:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2402 .loc 1 1696 7 is_stmt 1 view .LVU762
2403 0028 0122 movs r2, #1
2404 002a 9A60 str r2, [r3, #8]
1698:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2405 .loc 1 1698 7 view .LVU763
1698:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2406 .loc 1 1698 10 is_stmt 0 view .LVU764
2407 002c 17F0020F tst r7, #2
2408 0030 08D1 bne .L203
1711:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2409 .loc 1 1711 9 is_stmt 1 view .LVU765
1711:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2410 .loc 1 1711 12 is_stmt 0 view .LVU766
2411 0032 17F0040F tst r7, #4
2412 0036 0CD1 bne .L200
1716:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2413 .loc 1 1716 14 is_stmt 1 view .LVU767
1716:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2414 .loc 1 1716 17 is_stmt 0 view .LVU768
2415 0038 17F00806 ands r6, r7, #8
2416 003c 06D0 beq .L204
1719:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2417 .loc 1 1719 21 view .LVU769
2418 003e 4FF48056 mov r6, #4096
2419 0042 08E0 b .L169
2420 .L203:
1706:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #endif /* USE_HAL_CAN_REGISTER_CALLBACKS */
2421 .loc 1 1706 9 is_stmt 1 view .LVU770
2422 0044 FFF7FEFF bl HAL_CAN_TxMailbox0CompleteCallback
2423 .LVL183:
1681:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** uint32_t interrupts = READ_REG(hcan->Instance->IER);
2424 .loc 1 1681 12 is_stmt 0 view .LVU771
2425 0048 0026 movs r6, #0
2426 004a 04E0 b .L169
2427 .LVL184:
2428 .L204:
1729:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #endif /* USE_HAL_CAN_REGISTER_CALLBACKS */
2429 .loc 1 1729 11 is_stmt 1 view .LVU772
2430 004c FFF7FEFF bl HAL_CAN_TxMailbox0AbortCallback
2431 .LVL185:
1729:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #endif /* USE_HAL_CAN_REGISTER_CALLBACKS */
2432 .loc 1 1729 11 is_stmt 0 view .LVU773
2433 0050 01E0 b .L169
2434 .LVL186:
2435 .L200:
1714:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2436 .loc 1 1714 21 view .LVU774
2437 0052 4FF40066 mov r6, #2048
2438 .LVL187:
2439 .L169:
1736:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2440 .loc 1 1736 5 is_stmt 1 view .LVU775
1736:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2441 .loc 1 1736 8 is_stmt 0 view .LVU776
ARM GAS /tmp/ccj1aKCo.s page 107
2442 0056 17F4807F tst r7, #256
2443 005a 0DD0 beq .L171
1739:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2444 .loc 1 1739 7 is_stmt 1 view .LVU777
2445 005c 2B68 ldr r3, [r5]
2446 005e 4FF48072 mov r2, #256
2447 0062 9A60 str r2, [r3, #8]
1741:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2448 .loc 1 1741 7 view .LVU778
1741:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2449 .loc 1 1741 10 is_stmt 0 view .LVU779
2450 0064 17F4007F tst r7, #512
2451 0068 40F08680 bne .L205
1754:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2452 .loc 1 1754 9 is_stmt 1 view .LVU780
1754:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2453 .loc 1 1754 12 is_stmt 0 view .LVU781
2454 006c 17F4806F tst r7, #1024
2455 0070 00F08680 beq .L173
1757:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2456 .loc 1 1757 11 is_stmt 1 view .LVU782
1757:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2457 .loc 1 1757 21 is_stmt 0 view .LVU783
2458 0074 46F40056 orr r6, r6, #8192
2459 .LVL188:
2460 .L171:
1779:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2461 .loc 1 1779 5 is_stmt 1 view .LVU784
1779:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2462 .loc 1 1779 8 is_stmt 0 view .LVU785
2463 0078 17F4803F tst r7, #65536
2464 007c 0DD0 beq .L168
1782:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2465 .loc 1 1782 7 is_stmt 1 view .LVU786
2466 007e 2B68 ldr r3, [r5]
2467 0080 4FF48032 mov r2, #65536
2468 0084 9A60 str r2, [r3, #8]
1784:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2469 .loc 1 1784 7 view .LVU787
1784:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2470 .loc 1 1784 10 is_stmt 0 view .LVU788
2471 0086 17F4003F tst r7, #131072
2472 008a 40F08380 bne .L206
1797:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2473 .loc 1 1797 9 is_stmt 1 view .LVU789
1797:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2474 .loc 1 1797 12 is_stmt 0 view .LVU790
2475 008e 17F4802F tst r7, #262144
2476 0092 00F08380 beq .L176
1800:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2477 .loc 1 1800 11 is_stmt 1 view .LVU791
1800:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2478 .loc 1 1800 21 is_stmt 0 view .LVU792
2479 0096 46F40046 orr r6, r6, #32768
2480 .LVL189:
2481 .L168:
1823:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
ARM GAS /tmp/ccj1aKCo.s page 108
2482 .loc 1 1823 3 is_stmt 1 view .LVU793
1823:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2483 .loc 1 1823 6 is_stmt 0 view .LVU794
2484 009a 14F0080F tst r4, #8
2485 009e 07D0 beq .L178
1825:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2486 .loc 1 1825 5 is_stmt 1 view .LVU795
1825:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2487 .loc 1 1825 8 is_stmt 0 view .LVU796
2488 00a0 1BF0100F tst fp, #16
2489 00a4 04D0 beq .L178
1828:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2490 .loc 1 1828 7 is_stmt 1 view .LVU797
1828:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2491 .loc 1 1828 17 is_stmt 0 view .LVU798
2492 00a6 46F40076 orr r6, r6, #512
2493 .LVL190:
1831:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2494 .loc 1 1831 7 is_stmt 1 view .LVU799
2495 00aa 2B68 ldr r3, [r5]
2496 00ac 1022 movs r2, #16
2497 00ae DA60 str r2, [r3, #12]
2498 .L178:
1836:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2499 .loc 1 1836 3 view .LVU800
1836:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2500 .loc 1 1836 6 is_stmt 0 view .LVU801
2501 00b0 14F0040F tst r4, #4
2502 00b4 02D0 beq .L179
1838:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2503 .loc 1 1838 5 is_stmt 1 view .LVU802
1838:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2504 .loc 1 1838 8 is_stmt 0 view .LVU803
2505 00b6 1BF0080F tst fp, #8
2506 00ba 79D1 bne .L207
2507 .L179:
1855:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2508 .loc 1 1855 3 is_stmt 1 view .LVU804
1855:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2509 .loc 1 1855 6 is_stmt 0 view .LVU805
2510 00bc 14F0020F tst r4, #2
2511 00c0 04D0 beq .L180
1858:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2512 .loc 1 1858 5 is_stmt 1 view .LVU806
1858:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2513 .loc 1 1858 14 is_stmt 0 view .LVU807
2514 00c2 2B68 ldr r3, [r5]
1858:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2515 .loc 1 1858 24 view .LVU808
2516 00c4 DB68 ldr r3, [r3, #12]
1858:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2517 .loc 1 1858 8 view .LVU809
2518 00c6 13F0030F tst r3, #3
2519 00ca 78D1 bne .L208
2520 .L180:
1872:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2521 .loc 1 1872 3 is_stmt 1 view .LVU810
ARM GAS /tmp/ccj1aKCo.s page 109
1872:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2522 .loc 1 1872 6 is_stmt 0 view .LVU811
2523 00cc 14F0400F tst r4, #64
2524 00d0 07D0 beq .L181
1874:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2525 .loc 1 1874 5 is_stmt 1 view .LVU812
1874:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2526 .loc 1 1874 8 is_stmt 0 view .LVU813
2527 00d2 1AF0100F tst r10, #16
2528 00d6 04D0 beq .L181
1877:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2529 .loc 1 1877 7 is_stmt 1 view .LVU814
1877:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2530 .loc 1 1877 17 is_stmt 0 view .LVU815
2531 00d8 46F48066 orr r6, r6, #1024
2532 .LVL191:
1880:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2533 .loc 1 1880 7 is_stmt 1 view .LVU816
2534 00dc 2B68 ldr r3, [r5]
2535 00de 1022 movs r2, #16
2536 00e0 1A61 str r2, [r3, #16]
2537 .L181:
1885:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2538 .loc 1 1885 3 view .LVU817
1885:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2539 .loc 1 1885 6 is_stmt 0 view .LVU818
2540 00e2 14F0200F tst r4, #32
2541 00e6 02D0 beq .L182
1887:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2542 .loc 1 1887 5 is_stmt 1 view .LVU819
1887:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2543 .loc 1 1887 8 is_stmt 0 view .LVU820
2544 00e8 1AF0080F tst r10, #8
2545 00ec 6BD1 bne .L209
2546 .L182:
1904:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2547 .loc 1 1904 3 is_stmt 1 view .LVU821
1904:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2548 .loc 1 1904 6 is_stmt 0 view .LVU822
2549 00ee 14F0100F tst r4, #16
2550 00f2 04D0 beq .L183
1907:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2551 .loc 1 1907 5 is_stmt 1 view .LVU823
1907:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2552 .loc 1 1907 14 is_stmt 0 view .LVU824
2553 00f4 2B68 ldr r3, [r5]
1907:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2554 .loc 1 1907 24 view .LVU825
2555 00f6 1B69 ldr r3, [r3, #16]
1907:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2556 .loc 1 1907 8 view .LVU826
2557 00f8 13F0030F tst r3, #3
2558 00fc 6AD1 bne .L210
2559 .L183:
1921:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2560 .loc 1 1921 3 is_stmt 1 view .LVU827
1921:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
ARM GAS /tmp/ccj1aKCo.s page 110
2561 .loc 1 1921 6 is_stmt 0 view .LVU828
2562 00fe 14F4003F tst r4, #131072
2563 0102 02D0 beq .L184
1923:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2564 .loc 1 1923 5 is_stmt 1 view .LVU829
1923:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2565 .loc 1 1923 8 is_stmt 0 view .LVU830
2566 0104 18F0100F tst r8, #16
2567 0108 68D1 bne .L211
2568 .L184:
1940:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2569 .loc 1 1940 3 is_stmt 1 view .LVU831
1940:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2570 .loc 1 1940 6 is_stmt 0 view .LVU832
2571 010a 14F4803F tst r4, #65536
2572 010e 02D0 beq .L185
1942:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2573 .loc 1 1942 5 is_stmt 1 view .LVU833
1942:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2574 .loc 1 1942 8 is_stmt 0 view .LVU834
2575 0110 18F0080F tst r8, #8
2576 0114 69D1 bne .L212
2577 .L185:
1959:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2578 .loc 1 1959 3 is_stmt 1 view .LVU835
1959:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2579 .loc 1 1959 6 is_stmt 0 view .LVU836
2580 0116 14F4004F tst r4, #32768
2581 011a 7AD0 beq .L186
1961:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2582 .loc 1 1961 5 is_stmt 1 view .LVU837
1961:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2583 .loc 1 1961 8 is_stmt 0 view .LVU838
2584 011c 18F0040F tst r8, #4
2585 0120 74D0 beq .L187
1964:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ((esrflags & CAN_ESR_EWGF) != 0U))
2586 .loc 1 1964 7 is_stmt 1 view .LVU839
1964:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ((esrflags & CAN_ESR_EWGF) != 0U))
2587 .loc 1 1964 10 is_stmt 0 view .LVU840
2588 0122 14F4807F tst r4, #256
2589 0126 04D0 beq .L188
1964:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ((esrflags & CAN_ESR_EWGF) != 0U))
2590 .loc 1 1964 55 discriminator 1 view .LVU841
2591 0128 19F0010F tst r9, #1
2592 012c 01D0 beq .L188
1968:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2593 .loc 1 1968 9 is_stmt 1 view .LVU842
1968:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2594 .loc 1 1968 19 is_stmt 0 view .LVU843
2595 012e 46F00106 orr r6, r6, #1
2596 .LVL192:
2597 .L188:
1974:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ((esrflags & CAN_ESR_EPVF) != 0U))
2598 .loc 1 1974 7 is_stmt 1 view .LVU844
1974:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ((esrflags & CAN_ESR_EPVF) != 0U))
2599 .loc 1 1974 10 is_stmt 0 view .LVU845
2600 0132 14F4007F tst r4, #512
ARM GAS /tmp/ccj1aKCo.s page 111
2601 0136 04D0 beq .L189
1974:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ((esrflags & CAN_ESR_EPVF) != 0U))
2602 .loc 1 1974 55 discriminator 1 view .LVU846
2603 0138 19F0020F tst r9, #2
2604 013c 01D0 beq .L189
1978:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2605 .loc 1 1978 9 is_stmt 1 view .LVU847
1978:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2606 .loc 1 1978 19 is_stmt 0 view .LVU848
2607 013e 46F00206 orr r6, r6, #2
2608 .LVL193:
2609 .L189:
1984:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ((esrflags & CAN_ESR_BOFF) != 0U))
2610 .loc 1 1984 7 is_stmt 1 view .LVU849
1984:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ((esrflags & CAN_ESR_BOFF) != 0U))
2611 .loc 1 1984 10 is_stmt 0 view .LVU850
2612 0142 14F4806F tst r4, #1024
2613 0146 04D0 beq .L190
1984:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ((esrflags & CAN_ESR_BOFF) != 0U))
2614 .loc 1 1984 48 discriminator 1 view .LVU851
2615 0148 19F0040F tst r9, #4
2616 014c 01D0 beq .L190
1988:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2617 .loc 1 1988 9 is_stmt 1 view .LVU852
1988:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2618 .loc 1 1988 19 is_stmt 0 view .LVU853
2619 014e 46F00406 orr r6, r6, #4
2620 .LVL194:
2621 .L190:
1994:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ((esrflags & CAN_ESR_LEC) != 0U))
2622 .loc 1 1994 7 is_stmt 1 view .LVU854
1994:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ((esrflags & CAN_ESR_LEC) != 0U))
2623 .loc 1 1994 10 is_stmt 0 view .LVU855
2624 0152 14F4006F tst r4, #2048
2625 0156 59D0 beq .L187
1994:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ((esrflags & CAN_ESR_LEC) != 0U))
2626 .loc 1 1994 57 discriminator 1 view .LVU856
2627 0158 19F07009 ands r9, r9, #112
2628 .LVL195:
1994:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ((esrflags & CAN_ESR_LEC) != 0U))
2629 .loc 1 1994 57 discriminator 1 view .LVU857
2630 015c 56D0 beq .L187
1997:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2631 .loc 1 1997 9 is_stmt 1 view .LVU858
2632 015e B9F1400F cmp r9, #64
2633 0162 65D0 beq .L191
2634 0164 58D8 bhi .L192
2635 0166 B9F1200F cmp r9, #32
2636 016a 5ED0 beq .L193
2637 016c B9F1300F cmp r9, #48
2638 0170 42D1 bne .L213
2009:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
2639 .loc 1 2009 13 view .LVU859
2009:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
2640 .loc 1 2009 23 is_stmt 0 view .LVU860
2641 0172 46F02006 orr r6, r6, #32
2642 .LVL196:
ARM GAS /tmp/ccj1aKCo.s page 112
2010:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** case (CAN_ESR_LEC_2):
2643 .loc 1 2010 13 is_stmt 1 view .LVU861
2644 0176 44E0 b .L196
2645 .LVL197:
2646 .L205:
1749:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #endif /* USE_HAL_CAN_REGISTER_CALLBACKS */
2647 .loc 1 1749 9 view .LVU862
2648 0178 2846 mov r0, r5
2649 017a FFF7FEFF bl HAL_CAN_TxMailbox1CompleteCallback
2650 .LVL198:
2651 017e 7BE7 b .L171
2652 .L173:
1759:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2653 .loc 1 1759 14 view .LVU863
1759:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2654 .loc 1 1759 17 is_stmt 0 view .LVU864
2655 0180 17F4006F tst r7, #2048
2656 0184 02D0 beq .L174
1762:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2657 .loc 1 1762 11 is_stmt 1 view .LVU865
1762:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2658 .loc 1 1762 21 is_stmt 0 view .LVU866
2659 0186 46F48046 orr r6, r6, #16384
2660 .LVL199:
1762:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2661 .loc 1 1762 21 view .LVU867
2662 018a 75E7 b .L171
2663 .L174:
1772:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #endif /* USE_HAL_CAN_REGISTER_CALLBACKS */
2664 .loc 1 1772 11 is_stmt 1 view .LVU868
2665 018c 2846 mov r0, r5
2666 018e FFF7FEFF bl HAL_CAN_TxMailbox1AbortCallback
2667 .LVL200:
2668 0192 71E7 b .L171
2669 .L206:
1792:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #endif /* USE_HAL_CAN_REGISTER_CALLBACKS */
2670 .loc 1 1792 9 view .LVU869
2671 0194 2846 mov r0, r5
2672 0196 FFF7FEFF bl HAL_CAN_TxMailbox2CompleteCallback
2673 .LVL201:
2674 019a 7EE7 b .L168
2675 .L176:
1802:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2676 .loc 1 1802 14 view .LVU870
1802:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2677 .loc 1 1802 17 is_stmt 0 view .LVU871
2678 019c 17F4002F tst r7, #524288
2679 01a0 02D0 beq .L177
1805:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2680 .loc 1 1805 11 is_stmt 1 view .LVU872
1805:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2681 .loc 1 1805 21 is_stmt 0 view .LVU873
2682 01a2 46F48036 orr r6, r6, #65536
2683 .LVL202:
1805:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2684 .loc 1 1805 21 view .LVU874
2685 01a6 78E7 b .L168
ARM GAS /tmp/ccj1aKCo.s page 113
2686 .L177:
1815:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #endif /* USE_HAL_CAN_REGISTER_CALLBACKS */
2687 .loc 1 1815 11 is_stmt 1 view .LVU875
2688 01a8 2846 mov r0, r5
2689 01aa FFF7FEFF bl HAL_CAN_TxMailbox2AbortCallback
2690 .LVL203:
2691 01ae 74E7 b .L168
2692 .L207:
1841:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2693 .loc 1 1841 7 view .LVU876
2694 01b0 2B68 ldr r3, [r5]
2695 01b2 0822 movs r2, #8
2696 01b4 DA60 str r2, [r3, #12]
1849:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #endif /* USE_HAL_CAN_REGISTER_CALLBACKS */
2697 .loc 1 1849 7 view .LVU877
2698 01b6 2846 mov r0, r5
2699 01b8 FFF7FEFF bl HAL_CAN_RxFifo0FullCallback
2700 .LVL204:
2701 01bc 7EE7 b .L179
2702 .L208:
1866:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #endif /* USE_HAL_CAN_REGISTER_CALLBACKS */
2703 .loc 1 1866 7 view .LVU878
2704 01be 2846 mov r0, r5
2705 01c0 FFF7FEFF bl HAL_CAN_RxFifo0MsgPendingCallback
2706 .LVL205:
2707 01c4 82E7 b .L180
2708 .L209:
1890:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2709 .loc 1 1890 7 view .LVU879
2710 01c6 2B68 ldr r3, [r5]
2711 01c8 0822 movs r2, #8
2712 01ca 1A61 str r2, [r3, #16]
1898:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #endif /* USE_HAL_CAN_REGISTER_CALLBACKS */
2713 .loc 1 1898 7 view .LVU880
2714 01cc 2846 mov r0, r5
2715 01ce FFF7FEFF bl HAL_CAN_RxFifo1FullCallback
2716 .LVL206:
2717 01d2 8CE7 b .L182
2718 .L210:
1915:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #endif /* USE_HAL_CAN_REGISTER_CALLBACKS */
2719 .loc 1 1915 7 view .LVU881
2720 01d4 2846 mov r0, r5
2721 01d6 FFF7FEFF bl HAL_CAN_RxFifo1MsgPendingCallback
2722 .LVL207:
2723 01da 90E7 b .L183
2724 .L211:
1926:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2725 .loc 1 1926 7 view .LVU882
2726 01dc 2B68 ldr r3, [r5]
2727 01de 1022 movs r2, #16
2728 01e0 5A60 str r2, [r3, #4]
1934:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #endif /* USE_HAL_CAN_REGISTER_CALLBACKS */
2729 .loc 1 1934 7 view .LVU883
2730 01e2 2846 mov r0, r5
2731 01e4 FFF7FEFF bl HAL_CAN_SleepCallback
2732 .LVL208:
2733 01e8 8FE7 b .L184
ARM GAS /tmp/ccj1aKCo.s page 114
2734 .L212:
1945:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2735 .loc 1 1945 7 view .LVU884
2736 01ea 2B68 ldr r3, [r5]
2737 01ec 0822 movs r2, #8
2738 01ee 5A60 str r2, [r3, #4]
1953:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #endif /* USE_HAL_CAN_REGISTER_CALLBACKS */
2739 .loc 1 1953 7 view .LVU885
2740 01f0 2846 mov r0, r5
2741 01f2 FFF7FEFF bl HAL_CAN_WakeUpFromRxMsgCallback
2742 .LVL209:
2743 01f6 8EE7 b .L185
2744 .LVL210:
2745 .L213:
1997:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2746 .loc 1 1997 9 is_stmt 0 view .LVU886
2747 01f8 B9F1100F cmp r9, #16
2748 01fc 01D1 bne .L196
2001:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
2749 .loc 1 2001 13 is_stmt 1 view .LVU887
2001:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
2750 .loc 1 2001 23 is_stmt 0 view .LVU888
2751 01fe 46F00806 orr r6, r6, #8
2752 .LVL211:
2002:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** case (CAN_ESR_LEC_1):
2753 .loc 1 2002 13 is_stmt 1 view .LVU889
2754 .L196:
2028:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2755 .loc 1 2028 9 view .LVU890
2756 0202 2A68 ldr r2, [r5]
2757 0204 9369 ldr r3, [r2, #24]
2758 0206 23F07003 bic r3, r3, #112
2759 020a 9361 str r3, [r2, #24]
2760 .L187:
2033:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2761 .loc 1 2033 5 view .LVU891
2762 020c 2B68 ldr r3, [r5]
2763 020e 0422 movs r2, #4
2764 0210 5A60 str r2, [r3, #4]
2765 .L186:
2037:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2766 .loc 1 2037 3 view .LVU892
2037:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2767 .loc 1 2037 6 is_stmt 0 view .LVU893
2768 0212 9EB9 cbnz r6, .L214
2769 .L167:
2051:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2770 .loc 1 2051 1 view .LVU894
2771 0214 BDE8F88F pop {r3, r4, r5, r6, r7, r8, r9, r10, fp, pc}
2772 .LVL212:
2773 .L192:
1997:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2774 .loc 1 1997 9 view .LVU895
2775 0218 B9F1500F cmp r9, #80
2776 021c 0BD0 beq .L197
2777 021e B9F1600F cmp r9, #96
2778 0222 EED1 bne .L196
ARM GAS /tmp/ccj1aKCo.s page 115
2021:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
2779 .loc 1 2021 13 is_stmt 1 view .LVU896
2021:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
2780 .loc 1 2021 23 is_stmt 0 view .LVU897
2781 0224 46F48076 orr r6, r6, #256
2782 .LVL213:
2022:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** default:
2783 .loc 1 2022 13 is_stmt 1 view .LVU898
2784 0228 EBE7 b .L196
2785 .L193:
2005:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
2786 .loc 1 2005 13 view .LVU899
2005:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
2787 .loc 1 2005 23 is_stmt 0 view .LVU900
2788 022a 46F01006 orr r6, r6, #16
2789 .LVL214:
2006:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** case (CAN_ESR_LEC_1 | CAN_ESR_LEC_0):
2790 .loc 1 2006 13 is_stmt 1 view .LVU901
2791 022e E8E7 b .L196
2792 .L191:
2013:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
2793 .loc 1 2013 13 view .LVU902
2013:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
2794 .loc 1 2013 23 is_stmt 0 view .LVU903
2795 0230 46F04006 orr r6, r6, #64
2796 .LVL215:
2014:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** case (CAN_ESR_LEC_2 | CAN_ESR_LEC_0):
2797 .loc 1 2014 13 is_stmt 1 view .LVU904
2798 0234 E5E7 b .L196
2799 .L197:
2017:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
2800 .loc 1 2017 13 view .LVU905
2017:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** break;
2801 .loc 1 2017 23 is_stmt 0 view .LVU906
2802 0236 46F08006 orr r6, r6, #128
2803 .LVL216:
2018:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** case (CAN_ESR_LEC_2 | CAN_ESR_LEC_1):
2804 .loc 1 2018 13 is_stmt 1 view .LVU907
2805 023a E2E7 b .L196
2806 .L214:
2040:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2807 .loc 1 2040 5 view .LVU908
2040:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2808 .loc 1 2040 9 is_stmt 0 view .LVU909
2809 023c 6B6A ldr r3, [r5, #36]
2040:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2810 .loc 1 2040 21 view .LVU910
2811 023e 3343 orrs r3, r3, r6
2812 0240 6B62 str r3, [r5, #36]
2048:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** #endif /* USE_HAL_CAN_REGISTER_CALLBACKS */
2813 .loc 1 2048 5 is_stmt 1 view .LVU911
2814 0242 2846 mov r0, r5
2815 0244 FFF7FEFF bl HAL_CAN_ErrorCallback
2816 .LVL217:
2051:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2817 .loc 1 2051 1 is_stmt 0 view .LVU912
2818 0248 E4E7 b .L167
ARM GAS /tmp/ccj1aKCo.s page 116
2819 .cfi_endproc
2820 .LFE149:
2822 .section .text.HAL_CAN_GetState,"ax",%progbits
2823 .align 1
2824 .global HAL_CAN_GetState
2825 .syntax unified
2826 .thumb
2827 .thumb_func
2829 HAL_CAN_GetState:
2830 .LVL218:
2831 .LFB163:
2302:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2303:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /**
2304:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @}
2305:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
2306:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2307:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /** @defgroup CAN_Exported_Functions_Group6 Peripheral State and Error functions
2308:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @brief CAN Peripheral State functions
2309:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** *
2310:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** @verbatim
2311:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ==============================================================================
2312:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ##### Peripheral State and Error functions #####
2313:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** ==============================================================================
2314:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** [..]
2315:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** This subsection provides functions allowing to :
2316:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) HAL_CAN_GetState() : Return the CAN state.
2317:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) HAL_CAN_GetError() : Return the CAN error codes if any.
2318:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (+) HAL_CAN_ResetError(): Reset the CAN error codes if any.
2319:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2320:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** @endverbatim
2321:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @{
2322:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
2323:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2324:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /**
2325:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @brief Return the CAN state.
2326:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param hcan pointer to a CAN_HandleTypeDef structure that contains
2327:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * the configuration information for the specified CAN.
2328:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @retval HAL state
2329:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
2330:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_StateTypeDef HAL_CAN_GetState(CAN_HandleTypeDef *hcan)
2331:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2832 .loc 1 2331 1 is_stmt 1 view -0
2833 .cfi_startproc
2834 @ args = 0, pretend = 0, frame = 0
2835 @ frame_needed = 0, uses_anonymous_args = 0
2836 @ link register save eliminated.
2837 .loc 1 2331 1 is_stmt 0 view .LVU914
2838 0000 0246 mov r2, r0
2332:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_StateTypeDef state = hcan->State;
2839 .loc 1 2332 3 is_stmt 1 view .LVU915
2840 .loc 1 2332 24 is_stmt 0 view .LVU916
2841 0002 90F82030 ldrb r3, [r0, #32] @ zero_extendqisi2
2842 0006 D8B2 uxtb r0, r3
2843 .LVL219:
2333:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2334:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((state == HAL_CAN_STATE_READY) ||
2844 .loc 1 2334 3 is_stmt 1 view .LVU917
ARM GAS /tmp/ccj1aKCo.s page 117
2845 .loc 1 2334 38 is_stmt 0 view .LVU918
2846 0008 013B subs r3, r3, #1
2847 000a DBB2 uxtb r3, r3
2848 .loc 1 2334 6 view .LVU919
2849 000c 012B cmp r3, #1
2850 000e 00D9 bls .L219
2851 .LVL220:
2852 .L216:
2335:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (state == HAL_CAN_STATE_LISTENING))
2336:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2337:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Check sleep mode acknowledge flag */
2338:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((hcan->Instance->MSR & CAN_MSR_SLAK) != 0U)
2339:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2340:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Sleep mode is active */
2341:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** state = HAL_CAN_STATE_SLEEP_ACTIVE;
2342:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2343:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Check sleep mode request flag */
2344:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** else if ((hcan->Instance->MCR & CAN_MCR_SLEEP) != 0U)
2345:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2346:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Sleep mode request is pending */
2347:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** state = HAL_CAN_STATE_SLEEP_PENDING;
2348:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2349:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** else
2350:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2351:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Neither sleep mode request nor sleep mode acknowledge */
2352:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2853 .loc 1 2352 5 is_stmt 1 view .LVU920
2353:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2354:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2355:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Return CAN state */
2356:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** return state;
2854 .loc 1 2356 3 view .LVU921
2357:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2855 .loc 1 2357 1 is_stmt 0 view .LVU922
2856 0010 7047 bx lr
2857 .LVL221:
2858 .L219:
2338:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2859 .loc 1 2338 5 is_stmt 1 view .LVU923
2338:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2860 .loc 1 2338 14 is_stmt 0 view .LVU924
2861 0012 1368 ldr r3, [r2]
2338:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2862 .loc 1 2338 24 view .LVU925
2863 0014 5A68 ldr r2, [r3, #4]
2864 .LVL222:
2338:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2865 .loc 1 2338 8 view .LVU926
2866 0016 12F0020F tst r2, #2
2867 001a 05D1 bne .L217
2344:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2868 .loc 1 2344 10 is_stmt 1 view .LVU927
2344:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2869 .loc 1 2344 29 is_stmt 0 view .LVU928
2870 001c 1B68 ldr r3, [r3]
2344:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2871 .loc 1 2344 13 view .LVU929
ARM GAS /tmp/ccj1aKCo.s page 118
2872 001e 13F0020F tst r3, #2
2873 0022 F5D0 beq .L216
2347:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2874 .loc 1 2347 13 view .LVU930
2875 0024 0320 movs r0, #3
2876 .LVL223:
2347:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2877 .loc 1 2347 13 view .LVU931
2878 0026 F3E7 b .L216
2879 .LVL224:
2880 .L217:
2341:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2881 .loc 1 2341 13 view .LVU932
2882 0028 0420 movs r0, #4
2883 .LVL225:
2341:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2884 .loc 1 2341 13 view .LVU933
2885 002a 7047 bx lr
2886 .cfi_endproc
2887 .LFE163:
2889 .section .text.HAL_CAN_GetError,"ax",%progbits
2890 .align 1
2891 .global HAL_CAN_GetError
2892 .syntax unified
2893 .thumb
2894 .thumb_func
2896 HAL_CAN_GetError:
2897 .LVL226:
2898 .LFB164:
2358:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2359:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /**
2360:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @brief Return the CAN error code.
2361:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param hcan pointer to a CAN_HandleTypeDef structure that contains
2362:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * the configuration information for the specified CAN.
2363:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @retval CAN Error Code
2364:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
2365:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** uint32_t HAL_CAN_GetError(CAN_HandleTypeDef *hcan)
2366:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2899 .loc 1 2366 1 is_stmt 1 view -0
2900 .cfi_startproc
2901 @ args = 0, pretend = 0, frame = 0
2902 @ frame_needed = 0, uses_anonymous_args = 0
2903 @ link register save eliminated.
2367:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Return CAN error code */
2368:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** return hcan->ErrorCode;
2904 .loc 1 2368 3 view .LVU935
2905 .loc 1 2368 14 is_stmt 0 view .LVU936
2906 0000 406A ldr r0, [r0, #36]
2907 .LVL227:
2369:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2908 .loc 1 2369 1 view .LVU937
2909 0002 7047 bx lr
2910 .cfi_endproc
2911 .LFE164:
2913 .section .text.HAL_CAN_ResetError,"ax",%progbits
2914 .align 1
2915 .global HAL_CAN_ResetError
ARM GAS /tmp/ccj1aKCo.s page 119
2916 .syntax unified
2917 .thumb
2918 .thumb_func
2920 HAL_CAN_ResetError:
2921 .LVL228:
2922 .LFB165:
2370:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2371:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /**
2372:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @brief Reset the CAN error code.
2373:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @param hcan pointer to a CAN_HandleTypeDef structure that contains
2374:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * the configuration information for the specified CAN.
2375:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** * @retval HAL status
2376:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** */
2377:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_StatusTypeDef HAL_CAN_ResetError(CAN_HandleTypeDef *hcan)
2378:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2923 .loc 1 2378 1 is_stmt 1 view -0
2924 .cfi_startproc
2925 @ args = 0, pretend = 0, frame = 0
2926 @ frame_needed = 0, uses_anonymous_args = 0
2927 @ link register save eliminated.
2379:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_StatusTypeDef status = HAL_OK;
2928 .loc 1 2379 3 view .LVU939
2380:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_StateTypeDef state = hcan->State;
2929 .loc 1 2380 3 view .LVU940
2930 .loc 1 2380 24 is_stmt 0 view .LVU941
2931 0000 90F82030 ldrb r3, [r0, #32] @ zero_extendqisi2
2932 .LVL229:
2381:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2382:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** if ((state == HAL_CAN_STATE_READY) ||
2933 .loc 1 2382 3 is_stmt 1 view .LVU942
2934 .loc 1 2382 38 is_stmt 0 view .LVU943
2935 0004 013B subs r3, r3, #1
2936 .LVL230:
2937 .loc 1 2382 38 view .LVU944
2938 0006 DBB2 uxtb r3, r3
2939 .loc 1 2382 6 view .LVU945
2940 0008 012B cmp r3, #1
2941 000a 05D9 bls .L224
2383:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** (state == HAL_CAN_STATE_LISTENING))
2384:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2385:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Reset CAN error code */
2386:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->ErrorCode = 0U;
2387:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2388:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** else
2389:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** {
2390:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Update error code */
2391:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** hcan->ErrorCode |= HAL_CAN_ERROR_NOT_INITIALIZED;
2942 .loc 1 2391 5 is_stmt 1 view .LVU946
2943 .loc 1 2391 9 is_stmt 0 view .LVU947
2944 000c 436A ldr r3, [r0, #36]
2945 .loc 1 2391 21 view .LVU948
2946 000e 43F48023 orr r3, r3, #262144
2947 0012 4362 str r3, [r0, #36]
2392:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2393:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** status = HAL_ERROR;
2948 .loc 1 2393 5 is_stmt 1 view .LVU949
2949 .LVL231:
ARM GAS /tmp/ccj1aKCo.s page 120
2950 .loc 1 2393 12 is_stmt 0 view .LVU950
2951 0014 0120 movs r0, #1
2952 .LVL232:
2394:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2395:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c ****
2396:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** /* Return the status */
2397:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** return status;
2953 .loc 1 2397 3 is_stmt 1 view .LVU951
2398:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2954 .loc 1 2398 1 is_stmt 0 view .LVU952
2955 0016 7047 bx lr
2956 .LVL233:
2957 .L224:
2386:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2958 .loc 1 2386 5 is_stmt 1 view .LVU953
2386:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** }
2959 .loc 1 2386 21 is_stmt 0 view .LVU954
2960 0018 0023 movs r3, #0
2961 001a 4362 str r3, [r0, #36]
2379:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_StateTypeDef state = hcan->State;
2962 .loc 1 2379 21 view .LVU955
2963 001c 1846 mov r0, r3
2964 .LVL234:
2379:Drivers/STM32F3xx_HAL_Driver/Src/stm32f3xx_hal_can.c **** HAL_CAN_StateTypeDef state = hcan->State;
2965 .loc 1 2379 21 view .LVU956
2966 001e 7047 bx lr
2967 .cfi_endproc
2968 .LFE165:
2970 .text
2971 .Letext0:
2972 .file 3 "/home/david/.config/Code/User/globalStorage/bmd.stm32-for-vscode/@xpack-dev-tools/arm-non
2973 .file 4 "/home/david/.config/Code/User/globalStorage/bmd.stm32-for-vscode/@xpack-dev-tools/arm-non
2974 .file 5 "Drivers/CMSIS/Device/ST/STM32F3xx/Include/stm32f302xc.h"
2975 .file 6 "Drivers/CMSIS/Device/ST/STM32F3xx/Include/stm32f3xx.h"
2976 .file 7 "Drivers/STM32F3xx_HAL_Driver/Inc/stm32f3xx_hal_def.h"
2977 .file 8 "Drivers/STM32F3xx_HAL_Driver/Inc/stm32f3xx_hal_can.h"
2978 .file 9 "Drivers/STM32F3xx_HAL_Driver/Inc/stm32f3xx_hal.h"
ARM GAS /tmp/ccj1aKCo.s page 121
DEFINED SYMBOLS
*ABS*:0000000000000000 stm32f3xx_hal_can.c
/tmp/ccj1aKCo.s:21 .text.HAL_CAN_MspInit:0000000000000000 $t
/tmp/ccj1aKCo.s:27 .text.HAL_CAN_MspInit:0000000000000000 HAL_CAN_MspInit
/tmp/ccj1aKCo.s:42 .text.HAL_CAN_Init:0000000000000000 $t
/tmp/ccj1aKCo.s:48 .text.HAL_CAN_Init:0000000000000000 HAL_CAN_Init
/tmp/ccj1aKCo.s:338 .text.HAL_CAN_MspDeInit:0000000000000000 $t
/tmp/ccj1aKCo.s:344 .text.HAL_CAN_MspDeInit:0000000000000000 HAL_CAN_MspDeInit
/tmp/ccj1aKCo.s:359 .text.HAL_CAN_ConfigFilter:0000000000000000 $t
/tmp/ccj1aKCo.s:365 .text.HAL_CAN_ConfigFilter:0000000000000000 HAL_CAN_ConfigFilter
/tmp/ccj1aKCo.s:578 .text.HAL_CAN_Start:0000000000000000 $t
/tmp/ccj1aKCo.s:584 .text.HAL_CAN_Start:0000000000000000 HAL_CAN_Start
/tmp/ccj1aKCo.s:683 .text.HAL_CAN_Stop:0000000000000000 $t
/tmp/ccj1aKCo.s:689 .text.HAL_CAN_Stop:0000000000000000 HAL_CAN_Stop
/tmp/ccj1aKCo.s:789 .text.HAL_CAN_DeInit:0000000000000000 $t
/tmp/ccj1aKCo.s:795 .text.HAL_CAN_DeInit:0000000000000000 HAL_CAN_DeInit
/tmp/ccj1aKCo.s:849 .text.HAL_CAN_RequestSleep:0000000000000000 $t
/tmp/ccj1aKCo.s:855 .text.HAL_CAN_RequestSleep:0000000000000000 HAL_CAN_RequestSleep
/tmp/ccj1aKCo.s:905 .text.HAL_CAN_WakeUp:0000000000000000 $t
/tmp/ccj1aKCo.s:911 .text.HAL_CAN_WakeUp:0000000000000000 HAL_CAN_WakeUp
/tmp/ccj1aKCo.s:1008 .text.HAL_CAN_WakeUp:0000000000000054 $d
/tmp/ccj1aKCo.s:1013 .text.HAL_CAN_IsSleepActive:0000000000000000 $t
/tmp/ccj1aKCo.s:1019 .text.HAL_CAN_IsSleepActive:0000000000000000 HAL_CAN_IsSleepActive
/tmp/ccj1aKCo.s:1069 .text.HAL_CAN_AddTxMessage:0000000000000000 $t
/tmp/ccj1aKCo.s:1075 .text.HAL_CAN_AddTxMessage:0000000000000000 HAL_CAN_AddTxMessage
/tmp/ccj1aKCo.s:1289 .text.HAL_CAN_AbortTxRequest:0000000000000000 $t
/tmp/ccj1aKCo.s:1295 .text.HAL_CAN_AbortTxRequest:0000000000000000 HAL_CAN_AbortTxRequest
/tmp/ccj1aKCo.s:1371 .text.HAL_CAN_GetTxMailboxesFreeLevel:0000000000000000 $t
/tmp/ccj1aKCo.s:1377 .text.HAL_CAN_GetTxMailboxesFreeLevel:0000000000000000 HAL_CAN_GetTxMailboxesFreeLevel
/tmp/ccj1aKCo.s:1448 .text.HAL_CAN_IsTxMessagePending:0000000000000000 $t
/tmp/ccj1aKCo.s:1454 .text.HAL_CAN_IsTxMessagePending:0000000000000000 HAL_CAN_IsTxMessagePending
/tmp/ccj1aKCo.s:1511 .text.HAL_CAN_GetTxTimestamp:0000000000000000 $t
/tmp/ccj1aKCo.s:1517 .text.HAL_CAN_GetTxTimestamp:0000000000000000 HAL_CAN_GetTxTimestamp
/tmp/ccj1aKCo.s:1590 .text.HAL_CAN_GetRxMessage:0000000000000000 $t
/tmp/ccj1aKCo.s:1596 .text.HAL_CAN_GetRxMessage:0000000000000000 HAL_CAN_GetRxMessage
/tmp/ccj1aKCo.s:1884 .text.HAL_CAN_GetRxFifoFillLevel:0000000000000000 $t
/tmp/ccj1aKCo.s:1890 .text.HAL_CAN_GetRxFifoFillLevel:0000000000000000 HAL_CAN_GetRxFifoFillLevel
/tmp/ccj1aKCo.s:1952 .text.HAL_CAN_ActivateNotification:0000000000000000 $t
/tmp/ccj1aKCo.s:1958 .text.HAL_CAN_ActivateNotification:0000000000000000 HAL_CAN_ActivateNotification
/tmp/ccj1aKCo.s:2009 .text.HAL_CAN_DeactivateNotification:0000000000000000 $t
/tmp/ccj1aKCo.s:2015 .text.HAL_CAN_DeactivateNotification:0000000000000000 HAL_CAN_DeactivateNotification
/tmp/ccj1aKCo.s:2066 .text.HAL_CAN_TxMailbox0CompleteCallback:0000000000000000 $t
/tmp/ccj1aKCo.s:2072 .text.HAL_CAN_TxMailbox0CompleteCallback:0000000000000000 HAL_CAN_TxMailbox0CompleteCallback
/tmp/ccj1aKCo.s:2087 .text.HAL_CAN_TxMailbox1CompleteCallback:0000000000000000 $t
/tmp/ccj1aKCo.s:2093 .text.HAL_CAN_TxMailbox1CompleteCallback:0000000000000000 HAL_CAN_TxMailbox1CompleteCallback
/tmp/ccj1aKCo.s:2108 .text.HAL_CAN_TxMailbox2CompleteCallback:0000000000000000 $t
/tmp/ccj1aKCo.s:2114 .text.HAL_CAN_TxMailbox2CompleteCallback:0000000000000000 HAL_CAN_TxMailbox2CompleteCallback
/tmp/ccj1aKCo.s:2129 .text.HAL_CAN_TxMailbox0AbortCallback:0000000000000000 $t
/tmp/ccj1aKCo.s:2135 .text.HAL_CAN_TxMailbox0AbortCallback:0000000000000000 HAL_CAN_TxMailbox0AbortCallback
/tmp/ccj1aKCo.s:2150 .text.HAL_CAN_TxMailbox1AbortCallback:0000000000000000 $t
/tmp/ccj1aKCo.s:2156 .text.HAL_CAN_TxMailbox1AbortCallback:0000000000000000 HAL_CAN_TxMailbox1AbortCallback
/tmp/ccj1aKCo.s:2171 .text.HAL_CAN_TxMailbox2AbortCallback:0000000000000000 $t
/tmp/ccj1aKCo.s:2177 .text.HAL_CAN_TxMailbox2AbortCallback:0000000000000000 HAL_CAN_TxMailbox2AbortCallback
/tmp/ccj1aKCo.s:2192 .text.HAL_CAN_RxFifo0MsgPendingCallback:0000000000000000 $t
/tmp/ccj1aKCo.s:2198 .text.HAL_CAN_RxFifo0MsgPendingCallback:0000000000000000 HAL_CAN_RxFifo0MsgPendingCallback
/tmp/ccj1aKCo.s:2213 .text.HAL_CAN_RxFifo0FullCallback:0000000000000000 $t
/tmp/ccj1aKCo.s:2219 .text.HAL_CAN_RxFifo0FullCallback:0000000000000000 HAL_CAN_RxFifo0FullCallback
ARM GAS /tmp/ccj1aKCo.s page 122
/tmp/ccj1aKCo.s:2234 .text.HAL_CAN_RxFifo1MsgPendingCallback:0000000000000000 $t
/tmp/ccj1aKCo.s:2240 .text.HAL_CAN_RxFifo1MsgPendingCallback:0000000000000000 HAL_CAN_RxFifo1MsgPendingCallback
/tmp/ccj1aKCo.s:2255 .text.HAL_CAN_RxFifo1FullCallback:0000000000000000 $t
/tmp/ccj1aKCo.s:2261 .text.HAL_CAN_RxFifo1FullCallback:0000000000000000 HAL_CAN_RxFifo1FullCallback
/tmp/ccj1aKCo.s:2276 .text.HAL_CAN_SleepCallback:0000000000000000 $t
/tmp/ccj1aKCo.s:2282 .text.HAL_CAN_SleepCallback:0000000000000000 HAL_CAN_SleepCallback
/tmp/ccj1aKCo.s:2297 .text.HAL_CAN_WakeUpFromRxMsgCallback:0000000000000000 $t
/tmp/ccj1aKCo.s:2303 .text.HAL_CAN_WakeUpFromRxMsgCallback:0000000000000000 HAL_CAN_WakeUpFromRxMsgCallback
/tmp/ccj1aKCo.s:2318 .text.HAL_CAN_ErrorCallback:0000000000000000 $t
/tmp/ccj1aKCo.s:2324 .text.HAL_CAN_ErrorCallback:0000000000000000 HAL_CAN_ErrorCallback
/tmp/ccj1aKCo.s:2339 .text.HAL_CAN_IRQHandler:0000000000000000 $t
/tmp/ccj1aKCo.s:2345 .text.HAL_CAN_IRQHandler:0000000000000000 HAL_CAN_IRQHandler
/tmp/ccj1aKCo.s:2823 .text.HAL_CAN_GetState:0000000000000000 $t
/tmp/ccj1aKCo.s:2829 .text.HAL_CAN_GetState:0000000000000000 HAL_CAN_GetState
/tmp/ccj1aKCo.s:2890 .text.HAL_CAN_GetError:0000000000000000 $t
/tmp/ccj1aKCo.s:2896 .text.HAL_CAN_GetError:0000000000000000 HAL_CAN_GetError
/tmp/ccj1aKCo.s:2914 .text.HAL_CAN_ResetError:0000000000000000 $t
/tmp/ccj1aKCo.s:2920 .text.HAL_CAN_ResetError:0000000000000000 HAL_CAN_ResetError
UNDEFINED SYMBOLS
HAL_GetTick