Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Dependents: Space_Invaders_Demo neopixels gpio_test_stm32f3_discovery gpio_test_systimer ... more
stm32f30x_can.c File Reference
This file provides firmware functions to manage the following functionalities of the Controller area network (CAN) peripheral: + Initialization and Configuration + CAN Frames Transmission + CAN Frames Reception + Operation modes switch + Error management + Interrupts and flags. More...
Go to the source code of this file.
Functions | |
| static ITStatus | CheckITStatus (uint32_t CAN_Reg, uint32_t It_Bit) |
| Checks whether the CAN interrupt has occurred or not. | |
| void | CAN_DeInit (CAN_TypeDef *CANx) |
| Deinitializes the CAN peripheral registers to their default reset values. | |
| uint8_t | CAN_Init (CAN_TypeDef *CANx, CAN_InitTypeDef *CAN_InitStruct) |
| Initializes the CAN peripheral according to the specified parameters in the CAN_InitStruct. | |
| void | CAN_FilterInit (CAN_FilterInitTypeDef *CAN_FilterInitStruct) |
| Configures the CAN reception filter according to the specified parameters in the CAN_FilterInitStruct. | |
| void | CAN_StructInit (CAN_InitTypeDef *CAN_InitStruct) |
| Fills each CAN_InitStruct member with its default value. | |
| void | CAN_SlaveStartBank (uint8_t CAN_BankNumber) |
| Select the start bank filter for slave CAN. | |
| void | CAN_DBGFreeze (CAN_TypeDef *CANx, FunctionalState NewState) |
| Enables or disables the DBG Freeze for CAN. | |
| void | CAN_TTComModeCmd (CAN_TypeDef *CANx, FunctionalState NewState) |
| Enables or disables the CAN Time TriggerOperation communication mode. | |
| uint8_t | CAN_Transmit (CAN_TypeDef *CANx, CanTxMsg *TxMessage) |
| Initiates and transmits a CAN frame message. | |
| uint8_t | CAN_TransmitStatus (CAN_TypeDef *CANx, uint8_t TransmitMailbox) |
| Checks the transmission status of a CAN Frame. | |
| void | CAN_CancelTransmit (CAN_TypeDef *CANx, uint8_t Mailbox) |
| Cancels a transmit request. | |
| void | CAN_Receive (CAN_TypeDef *CANx, uint8_t FIFONumber, CanRxMsg *RxMessage) |
| Receives a correct CAN frame. | |
| void | CAN_FIFORelease (CAN_TypeDef *CANx, uint8_t FIFONumber) |
| Releases the specified receive FIFO. | |
| uint8_t | CAN_MessagePending (CAN_TypeDef *CANx, uint8_t FIFONumber) |
| Returns the number of pending received messages. | |
| uint8_t | CAN_OperatingModeRequest (CAN_TypeDef *CANx, uint8_t CAN_OperatingMode) |
| Selects the CAN Operation mode. | |
| uint8_t | CAN_Sleep (CAN_TypeDef *CANx) |
| Enters the Sleep (low power) mode. | |
| uint8_t | CAN_WakeUp (CAN_TypeDef *CANx) |
| Wakes up the CAN peripheral from sleep mode . | |
| uint8_t | CAN_GetLastErrorCode (CAN_TypeDef *CANx) |
| Returns the CANx's last error code (LEC). | |
| uint8_t | CAN_GetReceiveErrorCounter (CAN_TypeDef *CANx) |
| Returns the CANx Receive Error Counter (REC). | |
| uint8_t | CAN_GetLSBTransmitErrorCounter (CAN_TypeDef *CANx) |
| Returns the LSB of the 9-bit CANx Transmit Error Counter(TEC). | |
| void | CAN_ITConfig (CAN_TypeDef *CANx, uint32_t CAN_IT, FunctionalState NewState) |
| Enables or disables the specified CANx interrupts. | |
| FlagStatus | CAN_GetFlagStatus (CAN_TypeDef *CANx, uint32_t CAN_FLAG) |
| Checks whether the specified CAN flag is set or not. | |
| void | CAN_ClearFlag (CAN_TypeDef *CANx, uint32_t CAN_FLAG) |
| Clears the CAN's pending flags. | |
| ITStatus | CAN_GetITStatus (CAN_TypeDef *CANx, uint32_t CAN_IT) |
| Checks whether the specified CANx interrupt has occurred or not. | |
| void | CAN_ClearITPendingBit (CAN_TypeDef *CANx, uint32_t CAN_IT) |
| Clears the CANx's interrupt pending bits. | |
Detailed Description
This file provides firmware functions to manage the following functionalities of the Controller area network (CAN) peripheral: + Initialization and Configuration + CAN Frames Transmission + CAN Frames Reception + Operation modes switch + Error management + Interrupts and flags.
- Version:
- V1.2.3
- Date:
- 10-July-2015
=============================================================================== ##### How to use this driver ##### =============================================================================== [..] (#) Enable the CAN controller interface clock using RCC_APB1PeriphClockCmd(RCC_APB1Periph_CAN1, ENABLE); (#) CAN pins configuration: (++) Enable the clock for the CAN GPIOs using the following function: RCC_AHBPeriphClockCmd(RCC_AHBPeriph_GPIOx, ENABLE); (++) Connect the involved CAN pins to AF9 using the following function GPIO_PinAFConfig(GPIOx, GPIO_PinSourcex, GPIO_AF_CANx); (++) Configure these CAN pins in alternate function mode by calling the function GPIO_Init(); (#) Initialize and configure the CAN using CAN_Init() and CAN_FilterInit() functions. (#) Transmit the desired CAN frame using CAN_Transmit() function. (#) Check the transmission of a CAN frame using CAN_TransmitStatus() function. (#) Cancel the transmission of a CAN frame using CAN_CancelTransmit() function. (#) Receive a CAN frame using CAN_Recieve() function. (#) Release the receive FIFOs using CAN_FIFORelease() function. (#) Return the number of pending received frames using CAN_MessagePending() function. (#) To control CAN events you can use one of the following two methods: (++) Check on CAN flags using the CAN_GetFlagStatus() function. (++) Use CAN interrupts through the function CAN_ITConfig() at initialization phase and CAN_GetITStatus() function into interrupt routines to check if the event has occurred or not. After checking on a flag you should clear it using CAN_ClearFlag() function. And after checking on an interrupt event you should clear it using CAN_ClearITPendingBit() function.
- Attention:
© COPYRIGHT 2015 STMicroelectronics
Licensed under MCD-ST Liberty SW License Agreement V2, (the "License"); You may not use this file except in compliance with the License. You may obtain a copy of the License at:
http://www.st.com/software_license_agreement_liberty_v2
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
Definition in file stm32f30x_can.c.
Generated on Tue Jul 12 2022 17:34:45 by
1.7.2