mirror of
https://github.com/AsahiLinux/u-boot
synced 2025-01-21 09:34:25 +00:00
1166 lines
31 KiB
C
1166 lines
31 KiB
C
|
/* 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 */
|