20#ifndef STM32F4xx_HAL_FMPI2C_H
21#define STM32F4xx_HAL_FMPI2C_H
27#if defined(FMPI2C_CR1_PE)
164#define HAL_FMPI2C_ERROR_NONE (0x00000000U)
165#define HAL_FMPI2C_ERROR_BERR (0x00000001U)
166#define HAL_FMPI2C_ERROR_ARLO (0x00000002U)
167#define HAL_FMPI2C_ERROR_AF (0x00000004U)
168#define HAL_FMPI2C_ERROR_OVR (0x00000008U)
169#define HAL_FMPI2C_ERROR_DMA (0x00000010U)
170#define HAL_FMPI2C_ERROR_TIMEOUT (0x00000020U)
171#define HAL_FMPI2C_ERROR_SIZE (0x00000040U)
172#define HAL_FMPI2C_ERROR_DMA_PARAM (0x00000080U)
173#if (USE_HAL_FMPI2C_REGISTER_CALLBACKS == 1)
174#define HAL_FMPI2C_ERROR_INVALID_CALLBACK (0x00000100U)
176#define HAL_FMPI2C_ERROR_INVALID_PARAM (0x00000200U)
224#if (USE_HAL_FMPI2C_REGISTER_CALLBACKS == 1)
244 void (* AddrCallback)(
struct __FMPI2C_HandleTypeDef *hfmpi2c, uint8_t TransferDirection, uint16_t AddrMatchCode);
255#if (USE_HAL_FMPI2C_REGISTER_CALLBACKS == 1)
261 HAL_FMPI2C_MASTER_TX_COMPLETE_CB_ID = 0x00U,
262 HAL_FMPI2C_MASTER_RX_COMPLETE_CB_ID = 0x01U,
263 HAL_FMPI2C_SLAVE_TX_COMPLETE_CB_ID = 0x02U,
264 HAL_FMPI2C_SLAVE_RX_COMPLETE_CB_ID = 0x03U,
265 HAL_FMPI2C_LISTEN_COMPLETE_CB_ID = 0x04U,
266 HAL_FMPI2C_MEM_TX_COMPLETE_CB_ID = 0x05U,
267 HAL_FMPI2C_MEM_RX_COMPLETE_CB_ID = 0x06U,
268 HAL_FMPI2C_ERROR_CB_ID = 0x07U,
269 HAL_FMPI2C_ABORT_CB_ID = 0x08U,
271 HAL_FMPI2C_MSPINIT_CB_ID = 0x09U,
272 HAL_FMPI2C_MSPDEINIT_CB_ID = 0x0AU
274} HAL_FMPI2C_CallbackIDTypeDef;
281typedef void (*pFMPI2C_AddrCallbackTypeDef)(
FMPI2C_HandleTypeDef *hfmpi2c, uint8_t TransferDirection,
282 uint16_t AddrMatchCode);
302#define FMPI2C_FIRST_FRAME ((uint32_t)FMPI2C_SOFTEND_MODE)
303#define FMPI2C_FIRST_AND_NEXT_FRAME ((uint32_t)(FMPI2C_RELOAD_MODE | FMPI2C_SOFTEND_MODE))
304#define FMPI2C_NEXT_FRAME ((uint32_t)(FMPI2C_RELOAD_MODE | FMPI2C_SOFTEND_MODE))
305#define FMPI2C_FIRST_AND_LAST_FRAME ((uint32_t)FMPI2C_AUTOEND_MODE)
306#define FMPI2C_LAST_FRAME ((uint32_t)FMPI2C_AUTOEND_MODE)
307#define FMPI2C_LAST_FRAME_NO_STOP ((uint32_t)FMPI2C_SOFTEND_MODE)
312#define FMPI2C_OTHER_FRAME (0x000000AAU)
313#define FMPI2C_OTHER_AND_LAST_FRAME (0x0000AA00U)
321#define FMPI2C_ADDRESSINGMODE_7BIT (0x00000001U)
322#define FMPI2C_ADDRESSINGMODE_10BIT (0x00000002U)
330#define FMPI2C_DUALADDRESS_DISABLE (0x00000000U)
331#define FMPI2C_DUALADDRESS_ENABLE FMPI2C_OAR2_OA2EN
339#define FMPI2C_OA2_NOMASK ((uint8_t)0x00U)
340#define FMPI2C_OA2_MASK01 ((uint8_t)0x01U)
341#define FMPI2C_OA2_MASK02 ((uint8_t)0x02U)
342#define FMPI2C_OA2_MASK03 ((uint8_t)0x03U)
343#define FMPI2C_OA2_MASK04 ((uint8_t)0x04U)
344#define FMPI2C_OA2_MASK05 ((uint8_t)0x05U)
345#define FMPI2C_OA2_MASK06 ((uint8_t)0x06U)
346#define FMPI2C_OA2_MASK07 ((uint8_t)0x07U)
354#define FMPI2C_GENERALCALL_DISABLE (0x00000000U)
355#define FMPI2C_GENERALCALL_ENABLE FMPI2C_CR1_GCEN
363#define FMPI2C_NOSTRETCH_DISABLE (0x00000000U)
364#define FMPI2C_NOSTRETCH_ENABLE FMPI2C_CR1_NOSTRETCH
372#define FMPI2C_MEMADD_SIZE_8BIT (0x00000001U)
373#define FMPI2C_MEMADD_SIZE_16BIT (0x00000002U)
381#define FMPI2C_DIRECTION_TRANSMIT (0x00000000U)
382#define FMPI2C_DIRECTION_RECEIVE (0x00000001U)
390#define FMPI2C_RELOAD_MODE FMPI2C_CR2_RELOAD
391#define FMPI2C_AUTOEND_MODE FMPI2C_CR2_AUTOEND
392#define FMPI2C_SOFTEND_MODE (0x00000000U)
400#define FMPI2C_NO_STARTSTOP (0x00000000U)
401#define FMPI2C_GENERATE_STOP (uint32_t)(0x80000000U | FMPI2C_CR2_STOP)
402#define FMPI2C_GENERATE_START_READ (uint32_t)(0x80000000U | FMPI2C_CR2_START | FMPI2C_CR2_RD_WRN)
403#define FMPI2C_GENERATE_START_WRITE (uint32_t)(0x80000000U | FMPI2C_CR2_START)
414#define FMPI2C_IT_ERRI FMPI2C_CR1_ERRIE
415#define FMPI2C_IT_TCI FMPI2C_CR1_TCIE
416#define FMPI2C_IT_STOPI FMPI2C_CR1_STOPIE
417#define FMPI2C_IT_NACKI FMPI2C_CR1_NACKIE
418#define FMPI2C_IT_ADDRI FMPI2C_CR1_ADDRIE
419#define FMPI2C_IT_RXI FMPI2C_CR1_RXIE
420#define FMPI2C_IT_TXI FMPI2C_CR1_TXIE
428#define FMPI2C_FLAG_TXE FMPI2C_ISR_TXE
429#define FMPI2C_FLAG_TXIS FMPI2C_ISR_TXIS
430#define FMPI2C_FLAG_RXNE FMPI2C_ISR_RXNE
431#define FMPI2C_FLAG_ADDR FMPI2C_ISR_ADDR
432#define FMPI2C_FLAG_AF FMPI2C_ISR_NACKF
433#define FMPI2C_FLAG_STOPF FMPI2C_ISR_STOPF
434#define FMPI2C_FLAG_TC FMPI2C_ISR_TC
435#define FMPI2C_FLAG_TCR FMPI2C_ISR_TCR
436#define FMPI2C_FLAG_BERR FMPI2C_ISR_BERR
437#define FMPI2C_FLAG_ARLO FMPI2C_ISR_ARLO
438#define FMPI2C_FLAG_OVR FMPI2C_ISR_OVR
439#define FMPI2C_FLAG_PECERR FMPI2C_ISR_PECERR
440#define FMPI2C_FLAG_TIMEOUT FMPI2C_ISR_TIMEOUT
441#define FMPI2C_FLAG_ALERT FMPI2C_ISR_ALERT
442#define FMPI2C_FLAG_BUSY FMPI2C_ISR_BUSY
443#define FMPI2C_FLAG_DIR FMPI2C_ISR_DIR
462#if (USE_HAL_FMPI2C_REGISTER_CALLBACKS == 1)
463#define __HAL_FMPI2C_RESET_HANDLE_STATE(__HANDLE__) do{ \
464 (__HANDLE__)->State = HAL_FMPI2C_STATE_RESET; \
465 (__HANDLE__)->MspInitCallback = NULL; \
466 (__HANDLE__)->MspDeInitCallback = NULL; \
469#define __HAL_FMPI2C_RESET_HANDLE_STATE(__HANDLE__) ((__HANDLE__)->State = HAL_FMPI2C_STATE_RESET)
486#define __HAL_FMPI2C_ENABLE_IT(__HANDLE__, __INTERRUPT__) ((__HANDLE__)->Instance->CR1 |= (__INTERRUPT__))
502#define __HAL_FMPI2C_DISABLE_IT(__HANDLE__, __INTERRUPT__) ((__HANDLE__)->Instance->CR1 &= (~(__INTERRUPT__)))
518#define __HAL_FMPI2C_GET_IT_SOURCE(__HANDLE__, __INTERRUPT__) ((((__HANDLE__)->Instance->CR1 & \
519 (__INTERRUPT__)) == (__INTERRUPT__)) ? SET : RESET)
544#define FMPI2C_FLAG_MASK (0x0001FFFFU)
545#define __HAL_FMPI2C_GET_FLAG(__HANDLE__, __FLAG__) (((((__HANDLE__)->Instance->ISR) & \
546 (__FLAG__)) == (__FLAG__)) ? SET : RESET)
565#define __HAL_FMPI2C_CLEAR_FLAG(__HANDLE__, __FLAG__) (((__FLAG__) == FMPI2C_FLAG_TXE) ? \
566 ((__HANDLE__)->Instance->ISR |= (__FLAG__)) : \
567 ((__HANDLE__)->Instance->ICR = (__FLAG__)))
573#define __HAL_FMPI2C_ENABLE(__HANDLE__) (SET_BIT((__HANDLE__)->Instance->CR1, FMPI2C_CR1_PE))
579#define __HAL_FMPI2C_DISABLE(__HANDLE__) (CLEAR_BIT((__HANDLE__)->Instance->CR1, FMPI2C_CR1_PE))
585#define __HAL_FMPI2C_GENERATE_NACK(__HANDLE__) (SET_BIT((__HANDLE__)->Instance->CR2, FMPI2C_CR2_NACK))
608#if (USE_HAL_FMPI2C_REGISTER_CALLBACKS == 1)
610 pFMPI2C_CallbackTypeDef pCallback);
626 uint16_t Size, uint32_t Timeout);
628 uint16_t Size, uint32_t Timeout);
634 uint16_t MemAddSize, uint8_t *pData, uint16_t Size, uint32_t Timeout);
636 uint16_t MemAddSize, uint8_t *pData, uint16_t Size, uint32_t Timeout);
648 uint16_t MemAddSize, uint8_t *pData, uint16_t Size);
650 uint16_t MemAddSize, uint8_t *pData, uint16_t Size);
672 uint16_t MemAddSize, uint8_t *pData, uint16_t Size);
674 uint16_t MemAddSize, uint8_t *pData, uint16_t Size);
738#define IS_FMPI2C_ADDRESSING_MODE(MODE) (((MODE) == FMPI2C_ADDRESSINGMODE_7BIT) || \
739 ((MODE) == FMPI2C_ADDRESSINGMODE_10BIT))
741#define IS_FMPI2C_DUAL_ADDRESS(ADDRESS) (((ADDRESS) == FMPI2C_DUALADDRESS_DISABLE) || \
742 ((ADDRESS) == FMPI2C_DUALADDRESS_ENABLE))
744#define IS_FMPI2C_OWN_ADDRESS2_MASK(MASK) (((MASK) == FMPI2C_OA2_NOMASK) || \
745 ((MASK) == FMPI2C_OA2_MASK01) || \
746 ((MASK) == FMPI2C_OA2_MASK02) || \
747 ((MASK) == FMPI2C_OA2_MASK03) || \
748 ((MASK) == FMPI2C_OA2_MASK04) || \
749 ((MASK) == FMPI2C_OA2_MASK05) || \
750 ((MASK) == FMPI2C_OA2_MASK06) || \
751 ((MASK) == FMPI2C_OA2_MASK07))
753#define IS_FMPI2C_GENERAL_CALL(CALL) (((CALL) == FMPI2C_GENERALCALL_DISABLE) || \
754 ((CALL) == FMPI2C_GENERALCALL_ENABLE))
756#define IS_FMPI2C_NO_STRETCH(STRETCH) (((STRETCH) == FMPI2C_NOSTRETCH_DISABLE) || \
757 ((STRETCH) == FMPI2C_NOSTRETCH_ENABLE))
759#define IS_FMPI2C_MEMADD_SIZE(SIZE) (((SIZE) == FMPI2C_MEMADD_SIZE_8BIT) || \
760 ((SIZE) == FMPI2C_MEMADD_SIZE_16BIT))
762#define IS_TRANSFER_MODE(MODE) (((MODE) == FMPI2C_RELOAD_MODE) || \
763 ((MODE) == FMPI2C_AUTOEND_MODE) || \
764 ((MODE) == FMPI2C_SOFTEND_MODE))
766#define IS_TRANSFER_REQUEST(REQUEST) (((REQUEST) == FMPI2C_GENERATE_STOP) || \
767 ((REQUEST) == FMPI2C_GENERATE_START_READ) || \
768 ((REQUEST) == FMPI2C_GENERATE_START_WRITE) || \
769 ((REQUEST) == FMPI2C_NO_STARTSTOP))
771#define IS_FMPI2C_TRANSFER_OPTIONS_REQUEST(REQUEST) (((REQUEST) == FMPI2C_FIRST_FRAME) || \
772 ((REQUEST) == FMPI2C_FIRST_AND_NEXT_FRAME) || \
773 ((REQUEST) == FMPI2C_NEXT_FRAME) || \
774 ((REQUEST) == FMPI2C_FIRST_AND_LAST_FRAME) || \
775 ((REQUEST) == FMPI2C_LAST_FRAME) || \
776 ((REQUEST) == FMPI2C_LAST_FRAME_NO_STOP) || \
777 IS_FMPI2C_TRANSFER_OTHER_OPTIONS_REQUEST(REQUEST))
779#define IS_FMPI2C_TRANSFER_OTHER_OPTIONS_REQUEST(REQUEST) (((REQUEST) == FMPI2C_OTHER_FRAME) || \
780 ((REQUEST) == FMPI2C_OTHER_AND_LAST_FRAME))
782#define FMPI2C_RESET_CR2(__HANDLE__) ((__HANDLE__)->Instance->CR2 &= \
783 (uint32_t)~((uint32_t)(FMPI2C_CR2_SADD | FMPI2C_CR2_HEAD10R | \
784 FMPI2C_CR2_NBYTES | FMPI2C_CR2_RELOAD | \
787#define FMPI2C_GET_ADDR_MATCH(__HANDLE__) ((uint16_t)(((__HANDLE__)->Instance->ISR & FMPI2C_ISR_ADDCODE) \
789#define FMPI2C_GET_DIR(__HANDLE__) ((uint8_t)(((__HANDLE__)->Instance->ISR & FMPI2C_ISR_DIR) \
791#define FMPI2C_GET_STOP_MODE(__HANDLE__) ((__HANDLE__)->Instance->CR2 & FMPI2C_CR2_AUTOEND)
792#define FMPI2C_GET_OWN_ADDRESS1(__HANDLE__) ((uint16_t)((__HANDLE__)->Instance->OAR1 & FMPI2C_OAR1_OA1))
793#define FMPI2C_GET_OWN_ADDRESS2(__HANDLE__) ((uint16_t)((__HANDLE__)->Instance->OAR2 & FMPI2C_OAR2_OA2))
795#define IS_FMPI2C_OWN_ADDRESS1(ADDRESS1) ((ADDRESS1) <= 0x000003FFU)
796#define IS_FMPI2C_OWN_ADDRESS2(ADDRESS2) ((ADDRESS2) <= (uint16_t)0x00FFU)
798#define FMPI2C_MEM_ADD_MSB(__ADDRESS__) ((uint8_t)((uint16_t)(((uint16_t)((__ADDRESS__) & \
799 (uint16_t)(0xFF00U))) >> 8U)))
800#define FMPI2C_MEM_ADD_LSB(__ADDRESS__) ((uint8_t)((uint16_t)((__ADDRESS__) & (uint16_t)(0x00FFU))))
802#define FMPI2C_GENERATE_START(__ADDMODE__,__ADDRESS__) (((__ADDMODE__) == FMPI2C_ADDRESSINGMODE_7BIT) ? \
803 (uint32_t)((((uint32_t)(__ADDRESS__) & (FMPI2C_CR2_SADD)) | \
804 (FMPI2C_CR2_START) | (FMPI2C_CR2_AUTOEND)) & \
805 (~FMPI2C_CR2_RD_WRN)) : \
806 (uint32_t)((((uint32_t)(__ADDRESS__) & (FMPI2C_CR2_SADD)) | \
807 (FMPI2C_CR2_ADD10) | (FMPI2C_CR2_START) | \
808 (FMPI2C_CR2_AUTOEND)) & (~FMPI2C_CR2_RD_WRN)))
810#define FMPI2C_CHECK_FLAG(__ISR__, __FLAG__) ((((__ISR__) & ((__FLAG__) & FMPI2C_FLAG_MASK)) == \
811 ((__FLAG__) & FMPI2C_FLAG_MASK)) ? SET : RESET)
812#define FMPI2C_CHECK_IT_SOURCE(__CR1__, __IT__) ((((__CR1__) & (__IT__)) == (__IT__)) ? SET : RESET)
HAL_StatusTypeDef HAL_FMPI2C_DeInit(FMPI2C_HandleTypeDef *hfmpi2c)
DeInitialize the FMPI2C peripheral.
void HAL_FMPI2C_MspDeInit(FMPI2C_HandleTypeDef *hfmpi2c)
DeInitialize the FMPI2C MSP.
void HAL_FMPI2C_MspInit(FMPI2C_HandleTypeDef *hfmpi2c)
Initialize the FMPI2C MSP.
HAL_StatusTypeDef HAL_FMPI2C_Init(FMPI2C_HandleTypeDef *hfmpi2c)
Initializes the FMPI2C according to the specified parameters in the FMPI2C_InitTypeDef and initialize...
HAL_StatusTypeDef HAL_FMPI2C_Slave_Receive_IT(FMPI2C_HandleTypeDef *hfmpi2c, uint8_t *pData, uint16_t Size)
Receive in slave mode an amount of data in non-blocking mode with Interrupt.
HAL_StatusTypeDef HAL_FMPI2C_Master_Seq_Receive_IT(FMPI2C_HandleTypeDef *hfmpi2c, uint16_t DevAddress, uint8_t *pData, uint16_t Size, uint32_t XferOptions)
Sequential receive in master FMPI2C mode an amount of data in non-blocking mode with Interrupt.
HAL_StatusTypeDef HAL_FMPI2C_Slave_Receive(FMPI2C_HandleTypeDef *hfmpi2c, uint8_t *pData, uint16_t Size, uint32_t Timeout)
Receive in slave mode an amount of data in blocking mode.
HAL_StatusTypeDef HAL_FMPI2C_Master_Seq_Receive_DMA(FMPI2C_HandleTypeDef *hfmpi2c, uint16_t DevAddress, uint8_t *pData, uint16_t Size, uint32_t XferOptions)
Sequential receive in master FMPI2C mode an amount of data in non-blocking mode with DMA.
HAL_StatusTypeDef HAL_FMPI2C_IsDeviceReady(FMPI2C_HandleTypeDef *hfmpi2c, uint16_t DevAddress, uint32_t Trials, uint32_t Timeout)
Checks if target device is ready for communication.
HAL_StatusTypeDef HAL_FMPI2C_Mem_Read(FMPI2C_HandleTypeDef *hfmpi2c, uint16_t DevAddress, uint16_t MemAddress, uint16_t MemAddSize, uint8_t *pData, uint16_t Size, uint32_t Timeout)
Read an amount of data in blocking mode from a specific memory address.
HAL_StatusTypeDef HAL_FMPI2C_Master_Transmit_IT(FMPI2C_HandleTypeDef *hfmpi2c, uint16_t DevAddress, uint8_t *pData, uint16_t Size)
Transmit in master mode an amount of data in non-blocking mode with Interrupt.
HAL_StatusTypeDef HAL_FMPI2C_Mem_Write_DMA(FMPI2C_HandleTypeDef *hfmpi2c, uint16_t DevAddress, uint16_t MemAddress, uint16_t MemAddSize, uint8_t *pData, uint16_t Size)
Write an amount of data in non-blocking mode with DMA to a specific memory address.
HAL_StatusTypeDef HAL_FMPI2C_Slave_Seq_Receive_DMA(FMPI2C_HandleTypeDef *hfmpi2c, uint8_t *pData, uint16_t Size, uint32_t XferOptions)
Sequential receive in slave/device FMPI2C mode an amount of data in non-blocking mode with DMA.
HAL_StatusTypeDef HAL_FMPI2C_Slave_Receive_DMA(FMPI2C_HandleTypeDef *hfmpi2c, uint8_t *pData, uint16_t Size)
Receive in slave mode an amount of data in non-blocking mode with DMA.
HAL_StatusTypeDef HAL_FMPI2C_EnableListen_IT(FMPI2C_HandleTypeDef *hfmpi2c)
Enable the Address listen mode with Interrupt.
HAL_StatusTypeDef HAL_FMPI2C_Master_Transmit_DMA(FMPI2C_HandleTypeDef *hfmpi2c, uint16_t DevAddress, uint8_t *pData, uint16_t Size)
Transmit in master mode an amount of data in non-blocking mode with DMA.
HAL_StatusTypeDef HAL_FMPI2C_Mem_Read_DMA(FMPI2C_HandleTypeDef *hfmpi2c, uint16_t DevAddress, uint16_t MemAddress, uint16_t MemAddSize, uint8_t *pData, uint16_t Size)
Reads an amount of data in non-blocking mode with DMA from a specific memory address.
HAL_StatusTypeDef HAL_FMPI2C_Master_Seq_Transmit_DMA(FMPI2C_HandleTypeDef *hfmpi2c, uint16_t DevAddress, uint8_t *pData, uint16_t Size, uint32_t XferOptions)
Sequential transmit in master FMPI2C mode an amount of data in non-blocking mode with DMA.
HAL_StatusTypeDef HAL_FMPI2C_Master_Receive_IT(FMPI2C_HandleTypeDef *hfmpi2c, uint16_t DevAddress, uint8_t *pData, uint16_t Size)
Receive in master mode an amount of data in non-blocking mode with Interrupt.
HAL_StatusTypeDef HAL_FMPI2C_Mem_Read_IT(FMPI2C_HandleTypeDef *hfmpi2c, uint16_t DevAddress, uint16_t MemAddress, uint16_t MemAddSize, uint8_t *pData, uint16_t Size)
Read an amount of data in non-blocking mode with Interrupt from a specific memory address.
HAL_StatusTypeDef HAL_FMPI2C_DisableListen_IT(FMPI2C_HandleTypeDef *hfmpi2c)
Disable the Address listen mode with Interrupt.
HAL_StatusTypeDef HAL_FMPI2C_Master_Receive(FMPI2C_HandleTypeDef *hfmpi2c, uint16_t DevAddress, uint8_t *pData, uint16_t Size, uint32_t Timeout)
Receives in master mode an amount of data in blocking mode.
HAL_StatusTypeDef HAL_FMPI2C_Master_Transmit(FMPI2C_HandleTypeDef *hfmpi2c, uint16_t DevAddress, uint8_t *pData, uint16_t Size, uint32_t Timeout)
Transmits in master mode an amount of data in blocking mode.
HAL_StatusTypeDef HAL_FMPI2C_Slave_Transmit(FMPI2C_HandleTypeDef *hfmpi2c, uint8_t *pData, uint16_t Size, uint32_t Timeout)
Transmits in slave mode an amount of data in blocking mode.
HAL_StatusTypeDef HAL_FMPI2C_Slave_Seq_Transmit_IT(FMPI2C_HandleTypeDef *hfmpi2c, uint8_t *pData, uint16_t Size, uint32_t XferOptions)
Sequential transmit in slave/device FMPI2C mode an amount of data in non-blocking mode with Interrupt...
HAL_StatusTypeDef HAL_FMPI2C_Master_Seq_Transmit_IT(FMPI2C_HandleTypeDef *hfmpi2c, uint16_t DevAddress, uint8_t *pData, uint16_t Size, uint32_t XferOptions)
Sequential transmit in master FMPI2C mode an amount of data in non-blocking mode with Interrupt.
HAL_StatusTypeDef HAL_FMPI2C_Slave_Transmit_DMA(FMPI2C_HandleTypeDef *hfmpi2c, uint8_t *pData, uint16_t Size)
Transmit in slave mode an amount of data in non-blocking mode with DMA.
HAL_StatusTypeDef HAL_FMPI2C_Slave_Seq_Transmit_DMA(FMPI2C_HandleTypeDef *hfmpi2c, uint8_t *pData, uint16_t Size, uint32_t XferOptions)
Sequential transmit in slave/device FMPI2C mode an amount of data in non-blocking mode with DMA.
HAL_StatusTypeDef HAL_FMPI2C_Slave_Transmit_IT(FMPI2C_HandleTypeDef *hfmpi2c, uint8_t *pData, uint16_t Size)
Transmit in slave mode an amount of data in non-blocking mode with Interrupt.
HAL_StatusTypeDef HAL_FMPI2C_Slave_Seq_Receive_IT(FMPI2C_HandleTypeDef *hfmpi2c, uint8_t *pData, uint16_t Size, uint32_t XferOptions)
Sequential receive in slave/device FMPI2C mode an amount of data in non-blocking mode with Interrupt.
HAL_StatusTypeDef HAL_FMPI2C_Mem_Write_IT(FMPI2C_HandleTypeDef *hfmpi2c, uint16_t DevAddress, uint16_t MemAddress, uint16_t MemAddSize, uint8_t *pData, uint16_t Size)
Write an amount of data in non-blocking mode with Interrupt to a specific memory address.
HAL_StatusTypeDef HAL_FMPI2C_Master_Abort_IT(FMPI2C_HandleTypeDef *hfmpi2c, uint16_t DevAddress)
Abort a master FMPI2C IT or DMA process communication with Interrupt.
HAL_StatusTypeDef HAL_FMPI2C_Master_Receive_DMA(FMPI2C_HandleTypeDef *hfmpi2c, uint16_t DevAddress, uint8_t *pData, uint16_t Size)
Receive in master mode an amount of data in non-blocking mode with DMA.
HAL_StatusTypeDef HAL_FMPI2C_Mem_Write(FMPI2C_HandleTypeDef *hfmpi2c, uint16_t DevAddress, uint16_t MemAddress, uint16_t MemAddSize, uint8_t *pData, uint16_t Size, uint32_t Timeout)
Write an amount of data in blocking mode to a specific memory address.
HAL_FMPI2C_StateTypeDef HAL_FMPI2C_GetState(const FMPI2C_HandleTypeDef *hfmpi2c)
Return the FMPI2C handle state.
uint32_t HAL_FMPI2C_GetError(const FMPI2C_HandleTypeDef *hfmpi2c)
Return the FMPI2C error code.
HAL_FMPI2C_ModeTypeDef HAL_FMPI2C_GetMode(const FMPI2C_HandleTypeDef *hfmpi2c)
Returns the FMPI2C Master, Slave, Memory or no mode.
void HAL_FMPI2C_ER_IRQHandler(FMPI2C_HandleTypeDef *hfmpi2c)
This function handles FMPI2C error interrupt request.
void HAL_FMPI2C_MasterTxCpltCallback(FMPI2C_HandleTypeDef *hfmpi2c)
Master Tx Transfer completed callback.
void HAL_FMPI2C_ListenCpltCallback(FMPI2C_HandleTypeDef *hfmpi2c)
Listen Complete callback.
void HAL_FMPI2C_AbortCpltCallback(FMPI2C_HandleTypeDef *hfmpi2c)
FMPI2C abort callback.
void HAL_FMPI2C_MemTxCpltCallback(FMPI2C_HandleTypeDef *hfmpi2c)
Memory Tx Transfer completed callback.
void HAL_FMPI2C_ErrorCallback(FMPI2C_HandleTypeDef *hfmpi2c)
FMPI2C error callback.
void HAL_FMPI2C_EV_IRQHandler(FMPI2C_HandleTypeDef *hfmpi2c)
This function handles FMPI2C event interrupt request.
void HAL_FMPI2C_SlaveTxCpltCallback(FMPI2C_HandleTypeDef *hfmpi2c)
Slave Tx Transfer completed callback.
void HAL_FMPI2C_AddrCallback(FMPI2C_HandleTypeDef *hfmpi2c, uint8_t TransferDirection, uint16_t AddrMatchCode)
Slave Address Match callback.
void HAL_FMPI2C_MasterRxCpltCallback(FMPI2C_HandleTypeDef *hfmpi2c)
Master Rx Transfer completed callback.
void HAL_FMPI2C_SlaveRxCpltCallback(FMPI2C_HandleTypeDef *hfmpi2c)
Slave Rx Transfer completed callback.
void HAL_FMPI2C_MemRxCpltCallback(FMPI2C_HandleTypeDef *hfmpi2c)
Memory Rx Transfer completed callback.
struct __FMPI2C_HandleTypeDef FMPI2C_HandleTypeDef
@ HAL_FMPI2C_STATE_LISTEN
@ HAL_FMPI2C_STATE_BUSY_RX
@ HAL_FMPI2C_STATE_BUSY_RX_LISTEN
@ HAL_FMPI2C_STATE_BUSY_TX_LISTEN
@ HAL_FMPI2C_STATE_BUSY_TX
This file contains HAL common defines, enumeration, macros and structures definitions.
HAL_StatusTypeDef
HAL Status structures definition
HAL_LockTypeDef
HAL Lock structures definition
Header file of FMPI2C HAL Extended module.
uint32_t OwnAddress2Masks
DMA handle Structure definition.
__IO uint32_t PreviousState
__IO uint32_t AddrEventCount
FMPI2C_TypeDef * Instance
__IO HAL_FMPI2C_ModeTypeDef Mode
__IO HAL_FMPI2C_StateTypeDef State
__IO uint32_t XferOptions
DMA_HandleTypeDef * hdmarx
HAL_StatusTypeDef(* XferISR)(struct __FMPI2C_HandleTypeDef *hfmpi2c, uint32_t ITFlags, uint32_t ITSources)
DMA_HandleTypeDef * hdmatx