diff options
Diffstat (limited to 'drivers/ram/k3-j721e/lpddr4_sanity.h')
-rw-r--r-- | drivers/ram/k3-j721e/lpddr4_sanity.h | 1165 |
1 files changed, 1165 insertions, 0 deletions
diff --git a/drivers/ram/k3-j721e/lpddr4_sanity.h b/drivers/ram/k3-j721e/lpddr4_sanity.h new file mode 100644 index 0000000000..0f0fc2767c --- /dev/null +++ b/drivers/ram/k3-j721e/lpddr4_sanity.h @@ -0,0 +1,1165 @@ +/* SPDX-License-Identifier: BSD-3-Clause */ +/********************************************************************** + * Copyright (C) 2012-2019 Cadence Design Systems, Inc. + ********************************************************************** + * WARNING: This file is auto-generated using api-generator utility. + * api-generator: 12.02.13bb8d5 + * Do not edit it manually. + ********************************************************************** + * Cadence Core Driver for LPDDR4. + ********************************************************************** + */ + +/** + * This file contains sanity API functions. The purpose of sanity functions + * is to check input parameters validity. They take the same parameters as + * original API functions and return 0 on success or EINVAL on wrong parameter + * value(s). + */ + +#ifndef LPDDR4_SANITY_H +#define LPDDR4_SANITY_H + +#include <errno.h> +#include <linux/types.h> +#include "lpddr4_if.h" + +#define CDN_EOK 0U /* no error */ + +static inline uint32_t lpddr4_configsf(const lpddr4_config *obj); +static inline uint32_t lpddr4_privatedatasf(const lpddr4_privatedata *obj); +static inline uint32_t lpddr4_reginitdatasf(const lpddr4_reginitdata *obj); + +static inline uint32_t lpddr4_sanityfunction1(const lpddr4_config* config, const uint16_t* configsize); +static inline uint32_t lpddr4_sanityfunction2(const lpddr4_privatedata* pd, const lpddr4_config* cfg); +static inline uint32_t lpddr4_sanityfunction3(const lpddr4_privatedata* pd); +static inline uint32_t lpddr4_sanityfunction4(const lpddr4_privatedata* pd, const lpddr4_regblock cpp, const uint32_t* regvalue); +static inline uint32_t lpddr4_sanityfunction5(const lpddr4_privatedata* pd, const lpddr4_regblock cpp); +static inline uint32_t lpddr4_sanityfunction6(const lpddr4_privatedata* pd, const uint64_t* mmrvalue, const uint8_t* mmrstatus); +static inline uint32_t lpddr4_sanityfunction7(const lpddr4_privatedata* pd, const uint8_t* mrwstatus); +static inline uint32_t lpddr4_sanityfunction8(const lpddr4_privatedata* pd, const lpddr4_reginitdata* regvalues); +static inline uint32_t lpddr4_sanityfunction11(const lpddr4_privatedata* pd, const lpddr4_reginitdata* regvalues); +static inline uint32_t lpddr4_sanityfunction14(const lpddr4_privatedata* pd, const uint64_t* mask); +static inline uint32_t lpddr4_sanityfunction15(const lpddr4_privatedata* pd, const uint64_t* mask); +static inline uint32_t lpddr4_sanityfunction16(const lpddr4_privatedata* pd, const lpddr4_ctlinterrupt intr, const bool* irqstatus); +static inline uint32_t lpddr4_sanityfunction17(const lpddr4_privatedata* pd, const lpddr4_ctlinterrupt intr); +static inline uint32_t lpddr4_sanityfunction18(const lpddr4_privatedata* pd, const uint32_t* mask); +static inline uint32_t lpddr4_sanityfunction20(const lpddr4_privatedata* pd, const lpddr4_phyindepinterrupt intr, const bool* irqstatus); +static inline uint32_t lpddr4_sanityfunction21(const lpddr4_privatedata* pd, const lpddr4_phyindepinterrupt intr); +static inline uint32_t lpddr4_sanityfunction22(const lpddr4_privatedata* pd, const lpddr4_debuginfo* debuginfo); +static inline uint32_t lpddr4_sanityfunction23(const lpddr4_privatedata* pd, const lpddr4_lpiwakeupparam* lpiwakeupparam, const lpddr4_ctlfspnum* fspnum, const uint32_t* cycles); +static inline uint32_t lpddr4_sanityfunction25(const lpddr4_privatedata* pd, const lpddr4_eccenable* eccparam); +static inline uint32_t lpddr4_sanityfunction26(const lpddr4_privatedata* pd, const lpddr4_eccenable* eccparam); +static inline uint32_t lpddr4_sanityfunction27(const lpddr4_privatedata* pd, const lpddr4_reducmode* mode); +static inline uint32_t lpddr4_sanityfunction28(const lpddr4_privatedata* pd, const lpddr4_reducmode* mode); +static inline uint32_t lpddr4_sanityfunction29(const lpddr4_privatedata* pd, const bool* on_off); +static inline uint32_t lpddr4_sanityfunction31(const lpddr4_privatedata* pd, const lpddr4_dbimode* mode); +static inline uint32_t lpddr4_sanityfunction32(const lpddr4_privatedata* pd, const lpddr4_ctlfspnum* fspnum, const uint32_t* cycles); + +#define lpddr4_probesf lpddr4_sanityfunction1 +#define lpddr4_initsf lpddr4_sanityfunction2 +#define lpddr4_startsf lpddr4_sanityfunction3 +#define lpddr4_readregsf lpddr4_sanityfunction4 +#define lpddr4_writeregsf lpddr4_sanityfunction5 +#define lpddr4_getmmrregistersf lpddr4_sanityfunction6 +#define lpddr4_setmmrregistersf lpddr4_sanityfunction7 +#define lpddr4_writectlconfigsf lpddr4_sanityfunction8 +#define lpddr4_writephyconfigsf lpddr4_sanityfunction8 +#define lpddr4_writephyindepconfigsf lpddr4_sanityfunction8 +#define lpddr4_readctlconfigsf lpddr4_sanityfunction11 +#define lpddr4_readphyconfigsf lpddr4_sanityfunction11 +#define lpddr4_readphyindepconfigsf lpddr4_sanityfunction11 +#define lpddr4_getctlinterruptmasksf lpddr4_sanityfunction14 +#define lpddr4_setctlinterruptmasksf lpddr4_sanityfunction15 +#define lpddr4_checkctlinterruptsf lpddr4_sanityfunction16 +#define lpddr4_ackctlinterruptsf lpddr4_sanityfunction17 +#define lpddr4_getphyindepinterruptmsf lpddr4_sanityfunction18 +#define lpddr4_setphyindepinterruptmsf lpddr4_sanityfunction18 +#define lpddr4_checkphyindepinterrupsf lpddr4_sanityfunction20 +#define lpddr4_ackphyindepinterruptsf lpddr4_sanityfunction21 +#define lpddr4_getdebuginitinfosf lpddr4_sanityfunction22 +#define lpddr4_getlpiwakeuptimesf lpddr4_sanityfunction23 +#define lpddr4_setlpiwakeuptimesf lpddr4_sanityfunction23 +#define lpddr4_geteccenablesf lpddr4_sanityfunction25 +#define lpddr4_seteccenablesf lpddr4_sanityfunction26 +#define lpddr4_getreducmodesf lpddr4_sanityfunction27 +#define lpddr4_setreducmodesf lpddr4_sanityfunction28 +#define lpddr4_getdbireadmodesf lpddr4_sanityfunction29 +#define lpddr4_getdbiwritemodesf lpddr4_sanityfunction29 +#define lpddr4_setdbimodesf lpddr4_sanityfunction31 +#define lpddr4_getrefreshratesf lpddr4_sanityfunction32 +#define lpddr4_setrefreshratesf lpddr4_sanityfunction32 +#define lpddr4_refreshperchipselectsf lpddr4_sanityfunction3 + +/** + * Function to validate struct Config + * + * @param[in] obj pointer to struct to be verified + * @returns 0 for valid + * @returns EINVAL for invalid + */ +static inline uint32_t lpddr4_configsf(const lpddr4_config *obj) +{ + uint32_t ret = 0; + + if (obj == NULL) + { + ret = EINVAL; + } + + return ret; +} + +/** + * Function to validate struct PrivateData + * + * @param[in] obj pointer to struct to be verified + * @returns 0 for valid + * @returns EINVAL for invalid + */ +static inline uint32_t lpddr4_privatedatasf(const lpddr4_privatedata *obj) +{ + uint32_t ret = 0; + + if (obj == NULL) + { + ret = EINVAL; + } + + return ret; +} + +/** + * Function to validate struct RegInitData + * + * @param[in] obj pointer to struct to be verified + * @returns 0 for valid + * @returns EINVAL for invalid + */ +static inline uint32_t lpddr4_reginitdatasf(const lpddr4_reginitdata *obj) +{ + uint32_t ret = 0; + + if (obj == NULL) + { + ret = EINVAL; + } + + return ret; +} + +/** + * A common function to check the validity of API functions with + * following parameter types + * @param[in] config Driver/hardware configuration required. + * @param[out] configSize Size of memory allocations required. + * @return 0 success + * @return EINVAL invalid parameters + */ +static inline uint32_t lpddr4_sanityfunction1(const lpddr4_config* config, const uint16_t* configsize) +{ + /* Declaring return variable */ + uint32_t ret = 0; + + if (configsize == NULL) + { + ret = EINVAL; + } + else if (lpddr4_configsf(config) == EINVAL) + { + ret = EINVAL; + } + else + { + /* + * All 'if ... else if' constructs shall be terminated with an 'else' statement + * (MISRA2012-RULE-15_7-3) + */ + } + + return ret; +} + +/** + * A common function to check the validity of API functions with + * following parameter types + * @param[in] pD Driver state info specific to this instance. + * @param[in] cfg Specifies driver/hardware configuration. + * @return 0 success + * @return EINVAL invalid parameters + */ +static inline uint32_t lpddr4_sanityfunction2(const lpddr4_privatedata* pd, const lpddr4_config* cfg) +{ + /* Declaring return variable */ + uint32_t ret = 0; + + if (lpddr4_privatedatasf(pd) == EINVAL) + { + ret = EINVAL; + } + else if (lpddr4_configsf(cfg) == EINVAL) + { + ret = EINVAL; + } + else + { + /* + * All 'if ... else if' constructs shall be terminated with an 'else' statement + * (MISRA2012-RULE-15_7-3) + */ + } + + return ret; +} + +/** + * A common function to check the validity of API functions with + * following parameter types + * @param[in] pD Driver state info specific to this instance. + * @return 0 success + * @return EINVAL invalid parameters + */ +static inline uint32_t lpddr4_sanityfunction3(const lpddr4_privatedata* pd) +{ + /* Declaring return variable */ + uint32_t ret = 0; + + if (lpddr4_privatedatasf(pd) == EINVAL) + { + ret = EINVAL; + } + + return ret; +} + +/** + * A common function to check the validity of API functions with + * following parameter types + * @param[in] pD Driver state info specific to this instance. + * @param[in] cpp Indicates whether controller, PHY or PHY Independent Module register + * @param[out] regValue Register value read + * @return 0 success + * @return EINVAL invalid parameters + */ +static inline uint32_t lpddr4_sanityfunction4(const lpddr4_privatedata* pd, const lpddr4_regblock cpp, const uint32_t* regvalue) +{ + /* Declaring return variable */ + uint32_t ret = 0; + + if (regvalue == NULL) + { + ret = EINVAL; + } + else if (lpddr4_privatedatasf(pd) == EINVAL) + { + ret = EINVAL; + } + else if ( + (cpp != LPDDR4_CTL_REGS) && + (cpp != LPDDR4_PHY_REGS) && + (cpp != LPDDR4_PHY_INDEP_REGS) + ) + { + ret = EINVAL; + } + else + { + /* + * All 'if ... else if' constructs shall be terminated with an 'else' statement + * (MISRA2012-RULE-15_7-3) + */ + } + + return ret; +} + +/** + * A common function to check the validity of API functions with + * following parameter types + * @param[in] pD Driver state info specific to this instance. + * @param[in] cpp Indicates whether controller, PHY or PHY Independent Module register + * @return 0 success + * @return EINVAL invalid parameters + */ +static inline uint32_t lpddr4_sanityfunction5(const lpddr4_privatedata* pd, const lpddr4_regblock cpp) +{ + /* Declaring return variable */ + uint32_t ret = 0; + + if (lpddr4_privatedatasf(pd) == EINVAL) + { + ret = EINVAL; + } + else if ( + (cpp != LPDDR4_CTL_REGS) && + (cpp != LPDDR4_PHY_REGS) && + (cpp != LPDDR4_PHY_INDEP_REGS) + ) + { + ret = EINVAL; + } + else + { + /* + * All 'if ... else if' constructs shall be terminated with an 'else' statement + * (MISRA2012-RULE-15_7-3) + */ + } + + return ret; +} + +/** + * A common function to check the validity of API functions with + * following parameter types + * @param[in] pD Driver state info specific to this instance. + * @param[out] mmrValue Value which is read from memory mode register(mmr) for all devices. + * @param[out] mmrStatus Status of mode register read(mrr) instruction. + * @return 0 success + * @return EINVAL invalid parameters + */ +static inline uint32_t lpddr4_sanityfunction6(const lpddr4_privatedata* pd, const uint64_t* mmrvalue, const uint8_t* mmrstatus) +{ + /* Declaring return variable */ + uint32_t ret = 0; + + if (mmrvalue == NULL) + { + ret = EINVAL; + } + else if (mmrstatus == NULL) + { + ret = EINVAL; + } + else if (lpddr4_privatedatasf(pd) == EINVAL) + { + ret = EINVAL; + } + else + { + /* + * All 'if ... else if' constructs shall be terminated with an 'else' statement + * (MISRA2012-RULE-15_7-3) + */ + } + + return ret; +} + +/** + * A common function to check the validity of API functions with + * following parameter types + * @param[in] pD Driver state info specific to this instance. + * @param[out] mrwStatus Status of mode register write(mrw) instruction. + * @return 0 success + * @return EINVAL invalid parameters + */ +static inline uint32_t lpddr4_sanityfunction7(const lpddr4_privatedata* pd, const uint8_t* mrwstatus) +{ + /* Declaring return variable */ + uint32_t ret = 0; + + if (mrwstatus == NULL) + { + ret = EINVAL; + } + else if (lpddr4_privatedatasf(pd) == EINVAL) + { + ret = EINVAL; + } + else + { + /* + * All 'if ... else if' constructs shall be terminated with an 'else' statement + * (MISRA2012-RULE-15_7-3) + */ + } + + return ret; +} + +/** + * A common function to check the validity of API functions with + * following parameter types + * @param[in] pD Driver state info specific to this instance. + * @param[in] regValues Register values to be written + * @return 0 success + * @return EINVAL invalid parameters + */ +static inline uint32_t lpddr4_sanityfunction8(const lpddr4_privatedata* pd, const lpddr4_reginitdata* regvalues) +{ + /* Declaring return variable */ + uint32_t ret = 0; + + if (lpddr4_privatedatasf(pd) == EINVAL) + { + ret = EINVAL; + } + else if (lpddr4_reginitdatasf(regvalues) == EINVAL) + { + ret = EINVAL; + } + else + { + /* + * All 'if ... else if' constructs shall be terminated with an 'else' statement + * (MISRA2012-RULE-15_7-3) + */ + } + + return ret; +} + +/** + * A common function to check the validity of API functions with + * following parameter types + * @param[in] pD Driver state info specific to this instance. + * @param[out] regValues Register values which are read + * @return 0 success + * @return EINVAL invalid parameters + */ +static inline uint32_t lpddr4_sanityfunction11(const lpddr4_privatedata* pd, const lpddr4_reginitdata* regvalues) +{ + /* Declaring return variable */ + uint32_t ret = 0; + + if (regvalues == NULL) + { + ret = EINVAL; + } + else if (lpddr4_privatedatasf(pd) == EINVAL) + { + ret = EINVAL; + } + else + { + /* + * All 'if ... else if' constructs shall be terminated with an 'else' statement + * (MISRA2012-RULE-15_7-3) + */ + } + + return ret; +} + +/** + * A common function to check the validity of API functions with + * following parameter types + * @param[in] pD Driver state info specific to this instance. + * @param[out] mask Value of interrupt mask + * @return 0 success + * @return EINVAL invalid parameters + */ +static inline uint32_t lpddr4_sanityfunction14(const lpddr4_privatedata* pd, const uint64_t* mask) +{ + /* Declaring return variable */ + uint32_t ret = 0; + + if (mask == NULL) + { + ret = EINVAL; + } + else if (lpddr4_privatedatasf(pd) == EINVAL) + { + ret = EINVAL; + } + else + { + /* + * All 'if ... else if' constructs shall be terminated with an 'else' statement + * (MISRA2012-RULE-15_7-3) + */ + } + + return ret; +} + +/** + * A common function to check the validity of API functions with + * following parameter types + * @param[in] pD Driver state info specific to this instance. + * @param[in] mask Value of interrupt mask to be written + * @return 0 success + * @return EINVAL invalid parameters + */ +static inline uint32_t lpddr4_sanityfunction15(const lpddr4_privatedata* pd, const uint64_t* mask) +{ + /* Declaring return variable */ + uint32_t ret = 0; + + if (mask == NULL) + { + ret = EINVAL; + } + else if (lpddr4_privatedatasf(pd) == EINVAL) + { + ret = EINVAL; + } + else + { + /* + * All 'if ... else if' constructs shall be terminated with an 'else' statement + * (MISRA2012-RULE-15_7-3) + */ + } + + return ret; +} + +/** + * A common function to check the validity of API functions with + * following parameter types + * @param[in] pD Driver state info specific to this instance. + * @param[in] intr Interrupt to be checked + * @param[out] irqStatus Status of the interrupt, TRUE if active + * @return 0 success + * @return EINVAL invalid parameters + */ +static inline uint32_t lpddr4_sanityfunction16(const lpddr4_privatedata* pd, const lpddr4_ctlinterrupt intr, const bool* irqstatus) +{ + /* Declaring return variable */ + uint32_t ret = 0; + + if (irqstatus == NULL) + { + ret = EINVAL; + } + else if (lpddr4_privatedatasf(pd) == EINVAL) + { + ret = EINVAL; + } + else if ( + (intr != LPDDR4_RESET_DONE) && + (intr != LPDDR4_BUS_ACCESS_ERROR) && + (intr != LPDDR4_MULTIPLE_BUS_ACCESS_ERROR) && + (intr != LPDDR4_ECC_MULTIPLE_CORR_ERROR) && + (intr != LPDDR4_ECC_MULTIPLE_UNCORR_ERROR) && + (intr != LPDDR4_ECC_WRITEBACK_EXEC_ERROR) && + (intr != LPDDR4_ECC_SCRUB_DONE) && + (intr != LPDDR4_ECC_SCRUB_ERROR) && + (intr != LPDDR4_PORT_COMMAND_ERROR) && + (intr != LPDDR4_MC_INIT_DONE) && + (intr != LPDDR4_LP_DONE) && + (intr != LPDDR4_BIST_DONE) && + (intr != LPDDR4_WRAP_ERROR) && + (intr != LPDDR4_INVALID_BURST_ERROR) && + (intr != LPDDR4_RDLVL_ERROR) && + (intr != LPDDR4_RDLVL_GATE_ERROR) && + (intr != LPDDR4_WRLVL_ERROR) && + (intr != LPDDR4_CA_TRAINING_ERROR) && + (intr != LPDDR4_DFI_UPDATE_ERROR) && + (intr != LPDDR4_MRR_ERROR) && + (intr != LPDDR4_PHY_MASTER_ERROR) && + (intr != LPDDR4_WRLVL_REQ) && + (intr != LPDDR4_RDLVL_REQ) && + (intr != LPDDR4_RDLVL_GATE_REQ) && + (intr != LPDDR4_CA_TRAINING_REQ) && + (intr != LPDDR4_LEVELING_DONE) && + (intr != LPDDR4_PHY_ERROR) && + (intr != LPDDR4_MR_READ_DONE) && + (intr != LPDDR4_TEMP_CHANGE) && + (intr != LPDDR4_TEMP_ALERT) && + (intr != LPDDR4_SW_DQS_COMPLETE) && + (intr != LPDDR4_DQS_OSC_BV_UPDATED) && + (intr != LPDDR4_DQS_OSC_OVERFLOW) && + (intr != LPDDR4_DQS_OSC_VAR_OUT) && + (intr != LPDDR4_MR_WRITE_DONE) && + (intr != LPDDR4_INHIBIT_DRAM_DONE) && + (intr != LPDDR4_DFI_INIT_STATE) && + (intr != LPDDR4_DLL_RESYNC_DONE) && + (intr != LPDDR4_TDFI_TO) && + (intr != LPDDR4_DFS_DONE) && + (intr != LPDDR4_DFS_STATUS) && + (intr != LPDDR4_REFRESH_STATUS) && + (intr != LPDDR4_ZQ_STATUS) && + (intr != LPDDR4_SW_REQ_MODE) && + (intr != LPDDR4_LOR_BITS) + ) + { + ret = EINVAL; + } + else + { + /* + * All 'if ... else if' constructs shall be terminated with an 'else' statement + * (MISRA2012-RULE-15_7-3) + */ + } + + return ret; +} + +/** + * A common function to check the validity of API functions with + * following parameter types + * @param[in] pD Driver state info specific to this instance. + * @param[in] intr Interrupt to be acknowledged + * @return 0 success + * @return EINVAL invalid parameters + */ +static inline uint32_t lpddr4_sanityfunction17(const lpddr4_privatedata* pd, const lpddr4_ctlinterrupt intr) +{ + /* Declaring return variable */ + uint32_t ret = 0; + + if (lpddr4_privatedatasf(pd) == EINVAL) + { + ret = EINVAL; + } + else if ( + (intr != LPDDR4_RESET_DONE) && + (intr != LPDDR4_BUS_ACCESS_ERROR) && + (intr != LPDDR4_MULTIPLE_BUS_ACCESS_ERROR) && + (intr != LPDDR4_ECC_MULTIPLE_CORR_ERROR) && + (intr != LPDDR4_ECC_MULTIPLE_UNCORR_ERROR) && + (intr != LPDDR4_ECC_WRITEBACK_EXEC_ERROR) && + (intr != LPDDR4_ECC_SCRUB_DONE) && + (intr != LPDDR4_ECC_SCRUB_ERROR) && + (intr != LPDDR4_PORT_COMMAND_ERROR) && + (intr != LPDDR4_MC_INIT_DONE) && + (intr != LPDDR4_LP_DONE) && + (intr != LPDDR4_BIST_DONE) && + (intr != LPDDR4_WRAP_ERROR) && + (intr != LPDDR4_INVALID_BURST_ERROR) && + (intr != LPDDR4_RDLVL_ERROR) && + (intr != LPDDR4_RDLVL_GATE_ERROR) && + (intr != LPDDR4_WRLVL_ERROR) && + (intr != LPDDR4_CA_TRAINING_ERROR) && + (intr != LPDDR4_DFI_UPDATE_ERROR) && + (intr != LPDDR4_MRR_ERROR) && + (intr != LPDDR4_PHY_MASTER_ERROR) && + (intr != LPDDR4_WRLVL_REQ) && + (intr != LPDDR4_RDLVL_REQ) && + (intr != LPDDR4_RDLVL_GATE_REQ) && + (intr != LPDDR4_CA_TRAINING_REQ) && + (intr != LPDDR4_LEVELING_DONE) && + (intr != LPDDR4_PHY_ERROR) && + (intr != LPDDR4_MR_READ_DONE) && + (intr != LPDDR4_TEMP_CHANGE) && + (intr != LPDDR4_TEMP_ALERT) && + (intr != LPDDR4_SW_DQS_COMPLETE) && + (intr != LPDDR4_DQS_OSC_BV_UPDATED) && + (intr != LPDDR4_DQS_OSC_OVERFLOW) && + (intr != LPDDR4_DQS_OSC_VAR_OUT) && + (intr != LPDDR4_MR_WRITE_DONE) && + (intr != LPDDR4_INHIBIT_DRAM_DONE) && + (intr != LPDDR4_DFI_INIT_STATE) && + (intr != LPDDR4_DLL_RESYNC_DONE) && + (intr != LPDDR4_TDFI_TO) && + (intr != LPDDR4_DFS_DONE) && + (intr != LPDDR4_DFS_STATUS) && + (intr != LPDDR4_REFRESH_STATUS) && + (intr != LPDDR4_ZQ_STATUS) && + (intr != LPDDR4_SW_REQ_MODE) && + (intr != LPDDR4_LOR_BITS) + ) + { + ret = EINVAL; + } + else + { + /* + * All 'if ... else if' constructs shall be terminated with an 'else' statement + * (MISRA2012-RULE-15_7-3) + */ + } + + return ret; +} + +/** + * A common function to check the validity of API functions with + * following parameter types + * @param[in] pD Driver state info specific to this instance. + * @param[out] mask Value of interrupt mask + * @return 0 success + * @return EINVAL invalid parameters + */ +static inline uint32_t lpddr4_sanityfunction18(const lpddr4_privatedata* pd, const uint32_t* mask) +{ + /* Declaring return variable */ + uint32_t ret = 0; + + if (mask == NULL) + { + ret = EINVAL; + } + else if (lpddr4_privatedatasf(pd) == EINVAL) + { + ret = EINVAL; + } + else + { + /* + * All 'if ... else if' constructs shall be terminated with an 'else' statement + * (MISRA2012-RULE-15_7-3) + */ + } + + return ret; +} + +/** + * A common function to check the validity of API functions with + * following parameter types + * @param[in] pD Driver state info specific to this instance. + * @param[in] intr Interrupt to be checked + * @param[out] irqStatus Status of the interrupt, TRUE if active + * @return 0 success + * @return EINVAL invalid parameters + */ +static inline uint32_t lpddr4_sanityfunction20(const lpddr4_privatedata* pd, const lpddr4_phyindepinterrupt intr, const bool* irqstatus) +{ + /* Declaring return variable */ + uint32_t ret = 0; + + if (irqstatus == NULL) + { + ret = EINVAL; + } + else if (lpddr4_privatedatasf(pd) == EINVAL) + { + ret = EINVAL; + } + else if ( + (intr != LPDDR4_PHY_INDEP_INIT_DONE_BIT) && + (intr != LPDDR4_PHY_INDEP_CONTROL_ERROR_BIT) && + (intr != LPDDR4_PHY_INDEP_CA_PARITY_ERR_BIT) && + (intr != LPDDR4_PHY_INDEP_RDLVL_ERROR_BIT) && + (intr != LPDDR4_PHY_INDEP_RDLVL_GATE_ERROR_BIT) && + (intr != LPDDR4_PHY_INDEP_WRLVL_ERROR_BIT) && + (intr != LPDDR4_PHY_INDEP_CALVL_ERROR_BIT) && + (intr != LPDDR4_PHY_INDEP_WDQLVL_ERROR_BIT) && + (intr != LPDDR4_PHY_INDEP_UPDATE_ERROR_BIT) && + (intr != LPDDR4_PHY_INDEP_RDLVL_REQ_BIT) && + (intr != LPDDR4_PHY_INDEP_RDLVL_GATE_REQ_BIT) && + (intr != LPDDR4_PHY_INDEP_WRLVL_REQ_BIT) && + (intr != LPDDR4_PHY_INDEP_CALVL_REQ_BIT) && + (intr != LPDDR4_PHY_INDEP_WDQLVL_REQ_BIT) && + (intr != LPDDR4_PHY_INDEP_LVL_DONE_BIT) && + (intr != LPDDR4_PHY_INDEP_BIST_DONE_BIT) && + (intr != LPDDR4_PHY_INDEP_TDFI_INIT_TIME_OUT_BIT) && + (intr != LPDDR4_PHY_INDEP_DLL_LOCK_STATE_CHANGE_BIT) + ) + { + ret = EINVAL; + } + else + { + /* + * All 'if ... else if' constructs shall be terminated with an 'else' statement + * (MISRA2012-RULE-15_7-3) + */ + } + + return ret; +} + +/** + * A common function to check the validity of API functions with + * following parameter types + * @param[in] pD Driver state info specific to this instance. + * @param[in] intr Interrupt to be acknowledged + * @return 0 success + * @return EINVAL invalid parameters + */ +static inline uint32_t lpddr4_sanityfunction21(const lpddr4_privatedata* pd, const lpddr4_phyindepinterrupt intr) +{ + /* Declaring return variable */ + uint32_t ret = 0; + + if (lpddr4_privatedatasf(pd) == EINVAL) + { + ret = EINVAL; + } + else if ( + (intr != LPDDR4_PHY_INDEP_INIT_DONE_BIT) && + (intr != LPDDR4_PHY_INDEP_CONTROL_ERROR_BIT) && + (intr != LPDDR4_PHY_INDEP_CA_PARITY_ERR_BIT) && + (intr != LPDDR4_PHY_INDEP_RDLVL_ERROR_BIT) && + (intr != LPDDR4_PHY_INDEP_RDLVL_GATE_ERROR_BIT) && + (intr != LPDDR4_PHY_INDEP_WRLVL_ERROR_BIT) && + (intr != LPDDR4_PHY_INDEP_CALVL_ERROR_BIT) && + (intr != LPDDR4_PHY_INDEP_WDQLVL_ERROR_BIT) && + (intr != LPDDR4_PHY_INDEP_UPDATE_ERROR_BIT) && + (intr != LPDDR4_PHY_INDEP_RDLVL_REQ_BIT) && + (intr != LPDDR4_PHY_INDEP_RDLVL_GATE_REQ_BIT) && + (intr != LPDDR4_PHY_INDEP_WRLVL_REQ_BIT) && + (intr != LPDDR4_PHY_INDEP_CALVL_REQ_BIT) && + (intr != LPDDR4_PHY_INDEP_WDQLVL_REQ_BIT) && + (intr != LPDDR4_PHY_INDEP_LVL_DONE_BIT) && + (intr != LPDDR4_PHY_INDEP_BIST_DONE_BIT) && + (intr != LPDDR4_PHY_INDEP_TDFI_INIT_TIME_OUT_BIT) && + (intr != LPDDR4_PHY_INDEP_DLL_LOCK_STATE_CHANGE_BIT) + ) + { + ret = EINVAL; + } + else + { + /* + * All 'if ... else if' constructs shall be terminated with an 'else' statement + * (MISRA2012-RULE-15_7-3) + */ + } + + return ret; +} + +/** + * A common function to check the validity of API functions with + * following parameter types + * @param[in] pD Driver state info specific to this instance. + * @param[out] debugInfo status + * @return 0 success + * @return EINVAL invalid parameters + */ +static inline uint32_t lpddr4_sanityfunction22(const lpddr4_privatedata* pd, const lpddr4_debuginfo* debuginfo) +{ + /* Declaring return variable */ + uint32_t ret = 0; + + if (debuginfo == NULL) + { + ret = EINVAL; + } + else if (lpddr4_privatedatasf(pd) == EINVAL) + { + ret = EINVAL; + } + else + { + /* + * All 'if ... else if' constructs shall be terminated with an 'else' statement + * (MISRA2012-RULE-15_7-3) + */ + } + + return ret; +} + +/** + * A common function to check the validity of API functions with + * following parameter types + * @param[in] pD Driver state info specific to this instance. + * @param[in] lpiWakeUpParam LPI timing parameter + * @param[in] fspNum Frequency copy + * @param[out] cycles Timing value(in cycles) + * @return 0 success + * @return EINVAL invalid parameters + */ +static inline uint32_t lpddr4_sanityfunction23(const lpddr4_privatedata* pd, const lpddr4_lpiwakeupparam* lpiwakeupparam, const lpddr4_ctlfspnum* fspnum, const uint32_t* cycles) +{ + /* Declaring return variable */ + uint32_t ret = 0; + + if (lpiwakeupparam == NULL) + { + ret = EINVAL; + } + else if (fspnum == NULL) + { + ret = EINVAL; + } + else if (cycles == NULL) + { + ret = EINVAL; + } + else if (lpddr4_privatedatasf(pd) == EINVAL) + { + ret = EINVAL; + } + else if ( + (*lpiwakeupparam != LPDDR4_LPI_PD_WAKEUP_FN) && + (*lpiwakeupparam != LPDDR4_LPI_SR_SHORT_WAKEUP_FN) && + (*lpiwakeupparam != LPDDR4_LPI_SR_LONG_WAKEUP_FN) && + (*lpiwakeupparam != LPDDR4_LPI_SR_LONG_MCCLK_GATE_WAKEUP_FN) && + (*lpiwakeupparam != LPDDR4_LPI_SRPD_SHORT_WAKEUP_FN) && + (*lpiwakeupparam != LPDDR4_LPI_SRPD_LONG_WAKEUP_FN) && + (*lpiwakeupparam != LPDDR4_LPI_SRPD_LONG_MCCLK_GATE_WAKEUP_FN) + ) + { + ret = EINVAL; + } + else if ( + (*fspnum != LPDDR4_FSP_0) && + (*fspnum != LPDDR4_FSP_1) && + (*fspnum != LPDDR4_FSP_2) + ) + { + ret = EINVAL; + } + else + { + /* + * All 'if ... else if' constructs shall be terminated with an 'else' statement + * (MISRA2012-RULE-15_7-3) + */ + } + + return ret; +} + +/** + * A common function to check the validity of API functions with + * following parameter types + * @param[in] pD Driver state info specific to this instance. + * @param[out] eccParam ECC parameter setting + * @return 0 success + * @return EINVAL invalid parameters + */ +static inline uint32_t lpddr4_sanityfunction25(const lpddr4_privatedata* pd, const lpddr4_eccenable* eccparam) +{ + /* Declaring return variable */ + uint32_t ret = 0; + + if (eccparam == NULL) + { + ret = EINVAL; + } + else if (lpddr4_privatedatasf(pd) == EINVAL) + { + ret = EINVAL; + } + else + { + /* + * All 'if ... else if' constructs shall be terminated with an 'else' statement + * (MISRA2012-RULE-15_7-3) + */ + } + + return ret; +} + +/** + * A common function to check the validity of API functions with + * following parameter types + * @param[in] pD Driver state info specific to this instance. + * @param[in] eccParam ECC control parameter setting + * @return 0 success + * @return EINVAL invalid parameters + */ +static inline uint32_t lpddr4_sanityfunction26(const lpddr4_privatedata* pd, const lpddr4_eccenable* eccparam) +{ + /* Declaring return variable */ + uint32_t ret = 0; + + if (eccparam == NULL) + { + ret = EINVAL; + } + else if (lpddr4_privatedatasf(pd) == EINVAL) + { + ret = EINVAL; + } + else if ( + (*eccparam != LPDDR4_ECC_DISABLED) && + (*eccparam != LPDDR4_ECC_ENABLED) && + (*eccparam != LPDDR4_ECC_ERR_DETECT) && + (*eccparam != LPDDR4_ECC_ERR_DETECT_CORRECT) + ) + { + ret = EINVAL; + } + else + { + /* + * All 'if ... else if' constructs shall be terminated with an 'else' statement + * (MISRA2012-RULE-15_7-3) + */ + } + + return ret; +} + +/** + * A common function to check the validity of API functions with + * following parameter types + * @param[in] pD Driver state info specific to this instance. + * @param[out] mode Half Datapath setting + * @return 0 success + * @return EINVAL invalid parameters + */ +static inline uint32_t lpddr4_sanityfunction27(const lpddr4_privatedata* pd, const lpddr4_reducmode* mode) +{ + /* Declaring return variable */ + uint32_t ret = 0; + + if (mode == NULL) + { + ret = EINVAL; + } + else if (lpddr4_privatedatasf(pd) == EINVAL) + { + ret = EINVAL; + } + else + { + /* + * All 'if ... else if' constructs shall be terminated with an 'else' statement + * (MISRA2012-RULE-15_7-3) + */ + } + + return ret; +} + +/** + * A common function to check the validity of API functions with + * following parameter types + * @param[in] pD Driver state info specific to this instance. + * @param[in] mode Half Datapath setting + * @return 0 success + * @return EINVAL invalid parameters + */ +static inline uint32_t lpddr4_sanityfunction28(const lpddr4_privatedata* pd, const lpddr4_reducmode* mode) +{ + /* Declaring return variable */ + uint32_t ret = 0; + + if (mode == NULL) + { + ret = EINVAL; + } + else if (lpddr4_privatedatasf(pd) == EINVAL) + { + ret = EINVAL; + } + else if ( + (*mode != LPDDR4_REDUC_ON) && + (*mode != LPDDR4_REDUC_OFF) + ) + { + ret = EINVAL; + } + else + { + /* + * All 'if ... else if' constructs shall be terminated with an 'else' statement + * (MISRA2012-RULE-15_7-3) + */ + } + + return ret; +} + +/** + * A common function to check the validity of API functions with + * following parameter types + * @param[in] pD Driver state info specific to this instance. + * @param[out] on_off DBI read value + * @return 0 success + * @return EINVAL invalid parameters + */ +static inline uint32_t lpddr4_sanityfunction29(const lpddr4_privatedata* pd, const bool* on_off) +{ + /* Declaring return variable */ + uint32_t ret = 0; + + if (on_off == NULL) + { + ret = EINVAL; + } + else if (lpddr4_privatedatasf(pd) == EINVAL) + { + ret = EINVAL; + } + else + { + /* + * All 'if ... else if' constructs shall be terminated with an 'else' statement + * (MISRA2012-RULE-15_7-3) + */ + } + + return ret; +} + +/** + * A common function to check the validity of API functions with + * following parameter types + * @param[in] pD Driver state info specific to this instance. + * @param[in] mode status + * @return 0 success + * @return EINVAL invalid parameters + */ +static inline uint32_t lpddr4_sanityfunction31(const lpddr4_privatedata* pd, const lpddr4_dbimode* mode) +{ + /* Declaring return variable */ + uint32_t ret = 0; + + if (mode == NULL) + { + ret = EINVAL; + } + else if (lpddr4_privatedatasf(pd) == EINVAL) + { + ret = EINVAL; + } + else if ( + (*mode != LPDDR4_DBI_RD_ON) && + (*mode != LPDDR4_DBI_RD_OFF) && + (*mode != LPDDR4_DBI_WR_ON) && + (*mode != LPDDR4_DBI_WR_OFF) + ) + { + ret = EINVAL; + } + else + { + /* + * All 'if ... else if' constructs shall be terminated with an 'else' statement + * (MISRA2012-RULE-15_7-3) + */ + } + + return ret; +} + +/** + * A common function to check the validity of API functions with + * following parameter types + * @param[in] pD Driver state info specific to this instance. + * @param[in] fspNum Frequency set number + * @param[out] cycles Refresh rate (in cycles) + * @return 0 success + * @return EINVAL invalid parameters + */ +static inline uint32_t lpddr4_sanityfunction32(const lpddr4_privatedata* pd, const lpddr4_ctlfspnum* fspnum, const uint32_t* cycles) +{ + /* Declaring return variable */ + uint32_t ret = 0; + + if (fspnum == NULL) + { + ret = EINVAL; + } + else if (cycles == NULL) + { + ret = EINVAL; + } + else if (lpddr4_privatedatasf(pd) == EINVAL) + { + ret = EINVAL; + } + else if ( + (*fspnum != LPDDR4_FSP_0) && + (*fspnum != LPDDR4_FSP_1) && + (*fspnum != LPDDR4_FSP_2) + ) + { + ret = EINVAL; + } + else + { + /* + * All 'if ... else if' constructs shall be terminated with an 'else' statement + * (MISRA2012-RULE-15_7-3) + */ + } + + return ret; +} + +#endif /* LPDDR4_SANITY_H */ |