123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258 |
- /*==================================================================================================
- * Project : RTD AUTOSAR 4.4
- * Platform : CORTEXM
- * Peripheral : FTFC_FLS_IP IPV_QSPI
- * Dependencies : none
- *
- * Autosar Version : 4.4.0
- * Autosar Revision : ASR_REL_4_4_REV_0000
- * Autosar Conf.Variant :
- * SW Version : 1.0.0
- * Build Version : S32K1_RTD_1_0_0_HF01_D2109_ASR_REL_4_4_REV_0000_20210907
- *
- * (c) Copyright 2020-2021 NXP Semiconductors
- * All Rights Reserved.
- *
- * NXP Confidential. This software is owned or controlled by NXP and may only be
- * used strictly in accordance with the applicable license terms. By expressly
- * accepting such terms or by downloading, installing, activating and/or otherwise
- * using the software, you are agreeing that you have read, and that you agree to
- * comply with and are bound by, such license terms. If you do not agree to be
- * bound by the applicable license terms, then you may not retain, install,
- * activate or otherwise use the software.
- ==================================================================================================*/
- #ifndef QSPI_IP_CONTROLLER_H
- #define QSPI_IP_CONTROLLER_H
- /**
- * @file Qspi_Ip_Controller.h
- *
- * @addtogroup IPV_QSPI QSPI IPV Driver
- * @{
- */
- /* implements Qspi_Ip_Controller.h_Artifact */
- #ifdef __cplusplus
- extern "C"{
- #endif
- #include "Qspi_Ip_Features.h"
- #include "Qspi_Ip_Common.h"
- #include "Qspi_Ip.h"
- /*==================================================================================================
- * SOURCE FILE VERSION INFORMATION
- ==================================================================================================*/
- #define QSPI_IP_CONTROLLER_VENDOR_ID_H 43
- #define QSPI_IP_CONTROLLER_AR_RELEASE_MAJOR_VERSION_H 4
- #define QSPI_IP_CONTROLLER_AR_RELEASE_MINOR_VERSION_H 4
- #define QSPI_IP_CONTROLLER_AR_RELEASE_REVISION_VERSION_H 0
- #define QSPI_IP_CONTROLLER_SW_MAJOR_VERSION_H 1
- #define QSPI_IP_CONTROLLER_SW_MINOR_VERSION_H 0
- #define QSPI_IP_CONTROLLER_SW_PATCH_VERSION_H 0
- /*==================================================================================================
- * FILE VERSION CHECKS
- ==================================================================================================*/
- /* Check if current file and Qspi_Ip_Features header file are of the same vendor */
- #if (QSPI_IP_CONTROLLER_VENDOR_ID_H != QSPI_IP_FEATURES_VENDOR_ID_CFG)
- #error "Qspi_Ip_Controller.h and Qspi_Ip_Features.h have different vendor ids"
- #endif
- /* Check if current file and Qspi_Ip_Features header file are of the same Autosar version */
- #if ((QSPI_IP_CONTROLLER_AR_RELEASE_MAJOR_VERSION_H != QSPI_IP_FEATURES_AR_RELEASE_MAJOR_VERSION_CFG) || \
- (QSPI_IP_CONTROLLER_AR_RELEASE_MINOR_VERSION_H != QSPI_IP_FEATURES_AR_RELEASE_MINOR_VERSION_CFG) || \
- (QSPI_IP_CONTROLLER_AR_RELEASE_REVISION_VERSION_H != QSPI_IP_FEATURES_AR_RELEASE_REVISION_VERSION_CFG) \
- )
- #error "AutoSar Version Numbers of Qspi_Ip_Controller.h and Qspi_Ip_Features.h are different"
- #endif
- /* Check if current file and Qspi_Ip_Features header file are of the same Software version */
- #if ((QSPI_IP_CONTROLLER_SW_MAJOR_VERSION_H != QSPI_IP_FEATURES_SW_MAJOR_VERSION_CFG) || \
- (QSPI_IP_CONTROLLER_SW_MINOR_VERSION_H != QSPI_IP_FEATURES_SW_MINOR_VERSION_CFG) || \
- (QSPI_IP_CONTROLLER_SW_PATCH_VERSION_H != QSPI_IP_FEATURES_SW_PATCH_VERSION_CFG) \
- )
- #error "Software Version Numbers of Qspi_Ip_Controller.h and Qspi_Ip_Features.h are different"
- #endif
- /* Check if current file and Qspi_Ip_Common header file are of the same vendor */
- #if (QSPI_IP_CONTROLLER_VENDOR_ID_H != QSPI_IP_COMMON_VENDOR_ID_H)
- #error "Qspi_Ip_Controller.h and Qspi_Ip_Common.h have different vendor ids"
- #endif
- /* Check if current file and Qspi_Ip_Common header file are of the same Autosar version */
- #if ((QSPI_IP_CONTROLLER_AR_RELEASE_MAJOR_VERSION_H != QSPI_IP_COMMON_AR_RELEASE_MAJOR_VERSION_H) || \
- (QSPI_IP_CONTROLLER_AR_RELEASE_MINOR_VERSION_H != QSPI_IP_COMMON_AR_RELEASE_MINOR_VERSION_H) || \
- (QSPI_IP_CONTROLLER_AR_RELEASE_REVISION_VERSION_H != QSPI_IP_COMMON_AR_RELEASE_REVISION_VERSION_H) \
- )
- #error "AutoSar Version Numbers of Qspi_Ip_Controller.h and Qspi_Ip_Common.h are different"
- #endif
- /* Check if current file and Qspi_Ip_Common header file are of the same Software version */
- #if ((QSPI_IP_CONTROLLER_SW_MAJOR_VERSION_H != QSPI_IP_COMMON_SW_MAJOR_VERSION_H) || \
- (QSPI_IP_CONTROLLER_SW_MINOR_VERSION_H != QSPI_IP_COMMON_SW_MINOR_VERSION_H) || \
- (QSPI_IP_CONTROLLER_SW_PATCH_VERSION_H != QSPI_IP_COMMON_SW_PATCH_VERSION_H) \
- )
- #error "Software Version Numbers of Qspi_Ip_Controller.h and Qspi_Ip_Common.h are different"
- #endif
- /* Check if current file and Qspi_Ip header file are of the same vendor */
- #if (QSPI_IP_CONTROLLER_VENDOR_ID_H != QSPI_IP_VENDOR_ID_H)
- #error "Qspi_Ip_Controller.h and Qspi_Ip.h have different vendor ids"
- #endif
- /* Check if current file and Qspi_Ip header file are of the same Autosar version */
- #if ((QSPI_IP_CONTROLLER_AR_RELEASE_MAJOR_VERSION_H != QSPI_IP_AR_RELEASE_MAJOR_VERSION_H) || \
- (QSPI_IP_CONTROLLER_AR_RELEASE_MINOR_VERSION_H != QSPI_IP_AR_RELEASE_MINOR_VERSION_H) || \
- (QSPI_IP_CONTROLLER_AR_RELEASE_REVISION_VERSION_H != QSPI_IP_AR_RELEASE_REVISION_VERSION_H) \
- )
- #error "AutoSar Version Numbers of Qspi_Ip_Controller.h and Qspi_Ip.h are different"
- #endif
- /* Check if current file and Qspi_Ip header file are of the same Software version */
- #if ((QSPI_IP_CONTROLLER_SW_MAJOR_VERSION_H != QSPI_IP_SW_MAJOR_VERSION_H) || \
- (QSPI_IP_CONTROLLER_SW_MINOR_VERSION_H != QSPI_IP_SW_MINOR_VERSION_H) || \
- (QSPI_IP_CONTROLLER_SW_PATCH_VERSION_H != QSPI_IP_SW_PATCH_VERSION_H) \
- )
- #error "Software Version Numbers of Qspi_Ip_Controller.h and Qspi_Ip.h are different"
- #endif
- #if (QSPI_IP_MEM_INSTANCE_COUNT > 0)
- /*******************************************************************************
- * Enumerations.
- ******************************************************************************/
- /*******************************************************************************
- * Definitions
- ******************************************************************************/
- #define FLS_START_SEC_CONST_UNSPECIFIED
- #include "Fls_MemMap.h"
- extern QuadSPI_Type * const Qspi_Ip_BaseAddress[];
- #define FLS_STOP_SEC_CONST_UNSPECIFIED
- #include "Fls_MemMap.h"
- /*******************************************************************************
- * API
- ******************************************************************************/
- /*!
- * @name QuadSPI Driver
- * @{
- */
- #define FLS_START_SEC_CODE
- #include "Fls_MemMap.h"
- /*!
- * @brief Configures LUT commands
- *
- * This function configures a pair of LUT commands in the specified LUT register.
- * LUT sequences start at index multiple of 4 and can have up to 8 commands
- *
- * @param instance QuadSPI peripheral instance number
- * @param lut Index in LUT table
- * @param instr0 First instruction
- * @param instr1 Second instruction
- * Implements Qspi_Ip_SetLut_Activity
- */
- void Qspi_Ip_SetLut(uint32 instance,
- uint8 lut,
- Qspi_Ip_InstrOpType operation0,
- Qspi_Ip_InstrOpType operation1
- );
- /*!
- * @brief Sets sequence ID for AHB operations
- *
- * @param instance QuadSPI peripheral instance number
- * @param seqID Sequence ID in LUT for read operation
- * Implements Qspi_Ip_SetAhbSeqId_Activity
- */
- void Qspi_Ip_SetAhbSeqId(uint32 instance,
- uint8 seqID
- );
- /*!
- * @brief Returns the physical base address of a flash device
- *
- * This function returns the physical base address of a flash device, depending on the QSPI connection.
- * The controller must be initialized prior to calling this function.
- *
- * @param instance QuadSPI peripheral instance number
- * @param connectionType Connection of the flash device to QSPI
- */
- uint32 Qspi_Ip_GetBaseAdress(uint32 instance,
- Qspi_Ip_ConnectionType connectionType
- );
- /*!
- * @brief Launches a simple IP command
- *
- * @param instance QuadSPI peripheral instance number
- * @param lut Index of LUT register
- * @param addr Address of the target serial flash
- * @return Error or success status returned by API
- */
- Qspi_Ip_StatusType Qspi_Ip_IpCommand(uint32 instance,
- uint8 lut,
- uint32 addr
- );
- /*!
- * @brief Launches an IP read command
- *
- * This function can launch a read command in 3 modes:
- * - normal read (dataRead != NULL_PTR): Data is read from serial flash and placed in the buffer
- * - verify (dataRead == NULL_PTR, dataCmp != NULL_PTR): Data is read from serial flash and compared to the reference buffer
- * - blank check (dataRead == NULL_PTR, dataCmp == NULL_PTR): Data is read from serial flash and compared to 0xFF
- * Only normal read mode can use DMA.
- *
- * @param instance QuadSPI peripheral instance number
- * @param lut Index of LUT register
- * @param addr Start address for read operation in serial flash
- * @param dataRead Buffer where to store read data
- * @param dataCmp Buffer to be compared to read data
- * @param size Size of data buffer
- * @return Error or success status returned by API
- */
- Qspi_Ip_StatusType Qspi_Ip_IpRead(uint32 instance,
- uint8 lut,
- uint32 addr,
- uint8 * dataRead,
- const uint8 * dataCmp,
- uint32 size
- );
- /*!
- * @brief Launches an IP write command
- *
- * @param instance QuadSPI peripheral instance number
- * @param lut Index of LUT register
- * @param addr Start address for write operation in serial flash
- * @param data Data to be programmed in flash
- * @param size Size of data buffer
- * @return Error or success status returned by API
- */
- Qspi_Ip_StatusType Qspi_Ip_IpWrite(uint32 instance,
- uint8 lut,
- uint32 addr,
- const uint8 * data,
- uint32 size
- );
- #define FLS_STOP_SEC_CODE
- #include "Fls_MemMap.h"
- #endif /* (QSPI_IP_MEM_INSTANCE_COUNT > 0) */
- #ifdef __cplusplus
- }
- #endif
- /** @} */
- #endif /* QSPI_IP_CONTROLLER_H */
|