/* Copyright Statement: * * This software/firmware and related documentation ("AutoChips Software") are * protected under relevant copyright laws. The information contained herein is * confidential and proprietary to AutoChips Inc. and/or its licensors. Without * the prior written psramission of AutoChips inc. and/or its licensors, any * reproduction, modification, use or disclosure of AutoChips Software, and * information contained herein, in whole or in part, shall be strictly * prohibited. * * AutoChips Inc. (C) 2021. All rights reserved. * * BY OPENING THIS FILE, RECEIVER HEREBY UNEQUIVOCALLY ACKNOWLEDGES AND AGREES * THAT THE SOFTWARE/FIRMWARE AND ITS DOCUMENTATIONS ("AUTOCHIPS SOFTWARE") * RECEIVED FROM AUTOCHIPS AND/OR ITS REPRESENTATIVES ARE PROVIDED TO RECEIVER * ON AN "AS-IS" BASIS ONLY. AUTOCHIPS EXPRESSLY DISCLAIMS ANY AND ALL * WARRANTIES, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE IMPLIED * WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR * NONINFRINGEMENT. NEITHER DOES AUTOCHIPS PROVIDE ANY WARRANTY WHATSOEVER WITH * RESPECT TO THE SOFTWARE OF ANY THIRD PARTY WHICH MAY BE USED BY, * INCORPORATED IN, OR SUPPLIED WITH THE AUTOCHIPS SOFTWARE, AND RECEIVER AGREES * TO LOOK ONLY TO SUCH THIRD PARTY FOR ANY WARRANTY CLAIM RELATING THERETO. * RECEIVER EXPRESSLY ACKNOWLEDGES THAT IT IS RECEIVER'S SOLE RESPONSIBILITY TO * OBTAIN FROM ANY THIRD PARTY ALL PROPER LICENSES CONTAINED IN AUTOCHIPS * SOFTWARE. AUTOCHIPS SHALL ALSO NOT BE RESPONSIBLE FOR ANY AUTOCHIPS SOFTWARE * RELEASES MADE TO RECEIVER'S SPECIFICATION OR TO CONFORM TO A PARTICULAR * STANDARD OR OPEN FORUM. RECEIVER'S SOLE AND EXCLUSIVE REMEDY AND AUTOCHIPS'S * ENTIRE AND CUMULATIVE LIABILITY WITH RESPECT TO THE AUTOCHIPS SOFTWARE * RELEASED HEREUNDER WILL BE, AT AUTOCHIPS'S OPTION, TO REVISE OR REPLACE THE * AUTOCHIPS SOFTWARE AT ISSUE, OR REFUND ANY SOFTWARE LICENSE FEES OR SERVICE * CHARGE PAID BY RECEIVER TO AUTOCHIPS FOR SUCH AUTOCHIPS SOFTWARE AT ISSUE. */ /*! * @file sram_drv.h * * @brief This file provides sram functions interface. * */ /* PRQA S 3630 EOF */ /* struct/union type will be used by user app. */ #ifndef SRAM_DRV_H #define SRAM_DRV_H #ifdef __cplusplus extern "C" { #endif /* __cplusplus */ /* =========================================== Includes =========================================== */ #include "device_register.h" /*=====================================SOURCE FILE VERSION INFORMATION==============================*/ #define SRAM_HAL_MODULE_ID (132U) #define SRAM_HAL_SW_MAJOR_VERSION (1U) #define SRAM_HAL_SW_MINOR_VERSION (2U) #define SRAM_HAL_SW_PATCH_VERSION (0U) /* ============================================ Define ============================================ */ /* =========================================== Typedef ============================================ */ /*!< Callback for SRAM ECC */ typedef void (*sram_callback_t)(void *device, uint32_t wpara, uint32_t lpara); /*! * @brief ECC index enum */ typedef enum { ECC_CHANNEL_0 = 0x00U, /*!< ecc channel 0 */ ECC_CHANNEL_1 = 0x01U /*!< ecc channel 1 */ } sram_channel_index_t; /*! * @brief SRAM ECC events */ typedef enum { SRAM_EVENT_NONE = 0U, /*!< None event */ SRAM_EVENT_SINGLE_BIT = 1U, /*!< Single-bit correction ECC event */ SRAM_EVENT_NON_CORRECTABLE = 2U /*!< Non-correctable ECC event */ } sram_ecc_event_t; /*! * @brief SRAM ECC status */ typedef enum { ECC_STATUS_NO_ERROR = 0U, /*!< No ECC error */ ECC_STATUS_2BIT_ERROR = 1U, /*!< 2bit Non-correctable ECC error */ ECC_STATUS_1BIT_AT_BIT38 = 2U, /*!< Single-bit correction ECC error at bit38 */ ECC_STATUS_1BIT_AT_BIT37_0 = 3U, /*!< Single-bit correction ECC error at bit37:0 */ ECC_STATUS_ADDR_ERROR = 4U /*!< address error */ } sram_ecc_status_t; /*! * @brief SRAM interrupt configuration structure */ typedef struct { bool enableSingleCorrection; /*!< Enable Single Correction Interrupt */ bool enableNonCorrectable; /*!< Enable Non-Correctable Interrupt */ } sram_interrupt_config_t; /*! * @brief SRAM configuration structure */ typedef struct { uint8_t channel; /*!< SRAM channel */ const sram_interrupt_config_t * interruptCfg; /*!< SRAM Interrupt configuration */ } sram_user_config_t; /* ========================================== Variables =========================================== */ /* ==================================== Functions declaration ===================================== */ /*! * @brief Initializes and configures SRAM module. * * @param[in] instance: The instance number of SRAM * @param[in] channelIndex: The channel index of SRAM * @param[in] userConfigArr: configure structure of SRAM * @return None */ void SRAM_DRV_Init(uint8_t instance, uint8_t channelIndex, const sram_user_config_t *userConfigArr); /*! * @brief Sets SRAM to default configuration. * * @param[in] instance: The instance number of SRAM * @return None */ void SRAM_DRV_Deinit(uint8_t instance); /*! * @brief Sets interrupt notification of SRAM. * * @param[in] instance: The instance number of SRAM * @param[in] channel: The channel index of SRAM * @param[in] interruptCfg: The configuration structure of SRAM interrupt * @return None */ void SRAM_DRV_SetInterruptConfig(uint8_t instance, uint8_t channel, sram_interrupt_config_t interruptCfg); /*! * @brief Gets interrupt notification of SRAM. * * @param[in] instance: The instance number of SRAM * @param[in] channel: The channel index of SRAM * @param[out] interruptPtr: SRAM interrupt configuration structure * @return None */ void SRAM_DRV_GetInterruptConfig(uint8_t instance, uint8_t channel, sram_interrupt_config_t * const interruptPtr); /*! * @brief Clears error event and interrupt flag. * * @param[in] instance: The instance number of SRAM * @param[in] channel: The channel index of SRAM * @return None */ void SRAM_DRV_ClearEvent(uint8_t instance, uint8_t channel); /*! * @brief Gets the error address and event of SRAM ECC. * * @param[in] instance: The instance number of SRAM * @param[in] channel: The channel index of SRAM * @param[out] addressPtr: The error address * @return The ECC event */ sram_ecc_event_t SRAM_DRV_GetErrorDetail(uint8_t instance, uint8_t channel, uint32_t *addressPtr); /*! * @brief Installs SRAM callback function. * * @param[in] event: ECC error event * @param[in] func: Timer callback task * @return None */ void SRAM_DRV_InstallCallback(sram_ecc_event_t event, const sram_callback_t func); /*! * @brief Get module version information. * * @param[out] versionInfo: Module version information address. * @return void */ void SRAM_DRV_GetVersionInfo(Drv_VersionInfo_Type *versionInfo); #ifdef __cplusplus } #endif /* __cplusplus */ #endif /* SRAM_DRV_H */ /* ============================================= EOF ============================================== */