Kevin Scholz | 3bb3f26 | 2019-10-07 19:26:36 +0530 | [diff] [blame] | 1 | /* SPDX-License-Identifier: BSD-3-Clause */ |
Dave Gerlach | a8c13c7 | 2021-05-11 10:22:11 -0500 | [diff] [blame] | 2 | /* |
| 3 | * Cadence DDR Driver |
| 4 | * |
Bryan Brattlof | ee31be4 | 2022-10-24 16:53:28 -0500 | [diff] [blame] | 5 | * Copyright (C) 2012-2022 Cadence Design Systems, Inc. |
| 6 | * Copyright (C) 2018-2022 Texas Instruments Incorporated - https://www.ti.com/ |
Kevin Scholz | 3bb3f26 | 2019-10-07 19:26:36 +0530 | [diff] [blame] | 7 | */ |
| 8 | |
| 9 | #ifndef LPDDR4_IF_H |
| 10 | #define LPDDR4_IF_H |
| 11 | |
| 12 | #include <linux/types.h> |
Dave Gerlach | a8c13c7 | 2021-05-11 10:22:11 -0500 | [diff] [blame] | 13 | #ifdef CONFIG_K3_AM64_DDRSS |
Bryan Brattlof | ee31be4 | 2022-10-24 16:53:28 -0500 | [diff] [blame] | 14 | #include <lpddr4_am64_if.h> |
| 15 | #elif CONFIG_K3_AM62A_DDRSS |
| 16 | #include <lpddr4_am62a_if.h> |
Dave Gerlach | a8c13c7 | 2021-05-11 10:22:11 -0500 | [diff] [blame] | 17 | #else |
Bryan Brattlof | ee31be4 | 2022-10-24 16:53:28 -0500 | [diff] [blame] | 18 | #include <lpddr4_j721e_if.h> |
Dave Gerlach | a8c13c7 | 2021-05-11 10:22:11 -0500 | [diff] [blame] | 19 | #endif |
Kevin Scholz | 3bb3f26 | 2019-10-07 19:26:36 +0530 | [diff] [blame] | 20 | |
Kevin Scholz | 3bb3f26 | 2019-10-07 19:26:36 +0530 | [diff] [blame] | 21 | typedef struct lpddr4_config_s lpddr4_config; |
| 22 | typedef struct lpddr4_privatedata_s lpddr4_privatedata; |
| 23 | typedef struct lpddr4_debuginfo_s lpddr4_debuginfo; |
| 24 | typedef struct lpddr4_fspmoderegs_s lpddr4_fspmoderegs; |
Kevin Scholz | 3bb3f26 | 2019-10-07 19:26:36 +0530 | [diff] [blame] | 25 | |
Dave Gerlach | a8c13c7 | 2021-05-11 10:22:11 -0500 | [diff] [blame] | 26 | typedef enum { |
| 27 | LPDDR4_CTL_REGS = 0U, |
| 28 | LPDDR4_PHY_REGS = 1U, |
| 29 | LPDDR4_PHY_INDEP_REGS = 2U |
Kevin Scholz | 3bb3f26 | 2019-10-07 19:26:36 +0530 | [diff] [blame] | 30 | } lpddr4_regblock; |
| 31 | |
Dave Gerlach | a8c13c7 | 2021-05-11 10:22:11 -0500 | [diff] [blame] | 32 | typedef enum { |
| 33 | LPDDR4_DRV_NONE = 0U, |
| 34 | LPDDR4_DRV_SOC_PLL_UPDATE = 1U |
Kevin Scholz | 3bb3f26 | 2019-10-07 19:26:36 +0530 | [diff] [blame] | 35 | } lpddr4_infotype; |
| 36 | |
Dave Gerlach | a8c13c7 | 2021-05-11 10:22:11 -0500 | [diff] [blame] | 37 | typedef enum { |
| 38 | LPDDR4_LPI_PD_WAKEUP_FN = 0U, |
| 39 | LPDDR4_LPI_SR_SHORT_WAKEUP_FN = 1U, |
| 40 | LPDDR4_LPI_SR_LONG_WAKEUP_FN = 2U, |
| 41 | LPDDR4_LPI_SR_LONG_MCCLK_GATE_WAKEUP_FN = 3U, |
| 42 | LPDDR4_LPI_SRPD_SHORT_WAKEUP_FN = 4U, |
| 43 | LPDDR4_LPI_SRPD_LONG_WAKEUP_FN = 5U, |
| 44 | LPDDR4_LPI_SRPD_LONG_MCCLK_GATE_WAKEUP_FN = 6U |
Kevin Scholz | 3bb3f26 | 2019-10-07 19:26:36 +0530 | [diff] [blame] | 45 | } lpddr4_lpiwakeupparam; |
| 46 | |
Dave Gerlach | a8c13c7 | 2021-05-11 10:22:11 -0500 | [diff] [blame] | 47 | typedef enum { |
| 48 | LPDDR4_REDUC_ON = 0U, |
| 49 | LPDDR4_REDUC_OFF = 1U |
Kevin Scholz | 3bb3f26 | 2019-10-07 19:26:36 +0530 | [diff] [blame] | 50 | } lpddr4_reducmode; |
| 51 | |
Dave Gerlach | a8c13c7 | 2021-05-11 10:22:11 -0500 | [diff] [blame] | 52 | typedef enum { |
| 53 | LPDDR4_ECC_DISABLED = 0U, |
| 54 | LPDDR4_ECC_ENABLED = 1U, |
| 55 | LPDDR4_ECC_ERR_DETECT = 2U, |
| 56 | LPDDR4_ECC_ERR_DETECT_CORRECT = 3U |
Kevin Scholz | 3bb3f26 | 2019-10-07 19:26:36 +0530 | [diff] [blame] | 57 | } lpddr4_eccenable; |
| 58 | |
Dave Gerlach | a8c13c7 | 2021-05-11 10:22:11 -0500 | [diff] [blame] | 59 | typedef enum { |
| 60 | LPDDR4_DBI_RD_ON = 0U, |
| 61 | LPDDR4_DBI_RD_OFF = 1U, |
| 62 | LPDDR4_DBI_WR_ON = 2U, |
| 63 | LPDDR4_DBI_WR_OFF = 3U |
Kevin Scholz | 3bb3f26 | 2019-10-07 19:26:36 +0530 | [diff] [blame] | 64 | } lpddr4_dbimode; |
| 65 | |
Dave Gerlach | a8c13c7 | 2021-05-11 10:22:11 -0500 | [diff] [blame] | 66 | typedef enum { |
| 67 | LPDDR4_FSP_0 = 0U, |
| 68 | LPDDR4_FSP_1 = 1U, |
| 69 | LPDDR4_FSP_2 = 2U |
Kevin Scholz | 3bb3f26 | 2019-10-07 19:26:36 +0530 | [diff] [blame] | 70 | } lpddr4_ctlfspnum; |
| 71 | |
Dave Gerlach | a8c13c7 | 2021-05-11 10:22:11 -0500 | [diff] [blame] | 72 | typedef void (*lpddr4_infocallback)(const lpddr4_privatedata *pd, lpddr4_infotype infotype); |
Kevin Scholz | 3bb3f26 | 2019-10-07 19:26:36 +0530 | [diff] [blame] | 73 | |
Dave Gerlach | a8c13c7 | 2021-05-11 10:22:11 -0500 | [diff] [blame] | 74 | typedef void (*lpddr4_ctlcallback)(const lpddr4_privatedata *pd, lpddr4_intr_ctlinterrupt ctlinterrupt, u8 chipselect); |
Kevin Scholz | 3bb3f26 | 2019-10-07 19:26:36 +0530 | [diff] [blame] | 75 | |
Dave Gerlach | a8c13c7 | 2021-05-11 10:22:11 -0500 | [diff] [blame] | 76 | typedef void (*lpddr4_phyindepcallback)(const lpddr4_privatedata *pd, lpddr4_intr_phyindepinterrupt phyindepinterrupt, u8 chipselect); |
Kevin Scholz | 3bb3f26 | 2019-10-07 19:26:36 +0530 | [diff] [blame] | 77 | |
Dave Gerlach | a8c13c7 | 2021-05-11 10:22:11 -0500 | [diff] [blame] | 78 | u32 lpddr4_probe(const lpddr4_config *config, u16 *configsize); |
Kevin Scholz | 3bb3f26 | 2019-10-07 19:26:36 +0530 | [diff] [blame] | 79 | |
Dave Gerlach | a8c13c7 | 2021-05-11 10:22:11 -0500 | [diff] [blame] | 80 | u32 lpddr4_init(lpddr4_privatedata *pd, const lpddr4_config *cfg); |
Kevin Scholz | 3bb3f26 | 2019-10-07 19:26:36 +0530 | [diff] [blame] | 81 | |
Dave Gerlach | a8c13c7 | 2021-05-11 10:22:11 -0500 | [diff] [blame] | 82 | u32 lpddr4_start(const lpddr4_privatedata *pd); |
Kevin Scholz | 3bb3f26 | 2019-10-07 19:26:36 +0530 | [diff] [blame] | 83 | |
Dave Gerlach | a8c13c7 | 2021-05-11 10:22:11 -0500 | [diff] [blame] | 84 | u32 lpddr4_readreg(const lpddr4_privatedata *pd, lpddr4_regblock cpp, u32 regoffset, u32 *regvalue); |
Kevin Scholz | 3bb3f26 | 2019-10-07 19:26:36 +0530 | [diff] [blame] | 85 | |
Dave Gerlach | a8c13c7 | 2021-05-11 10:22:11 -0500 | [diff] [blame] | 86 | u32 lpddr4_writereg(const lpddr4_privatedata *pd, lpddr4_regblock cpp, u32 regoffset, u32 regvalue); |
Kevin Scholz | 3bb3f26 | 2019-10-07 19:26:36 +0530 | [diff] [blame] | 87 | |
Dave Gerlach | a8c13c7 | 2021-05-11 10:22:11 -0500 | [diff] [blame] | 88 | u32 lpddr4_getmmrregister(const lpddr4_privatedata *pd, u32 readmoderegval, u64 *mmrvalue, u8 *mmrstatus); |
Kevin Scholz | 3bb3f26 | 2019-10-07 19:26:36 +0530 | [diff] [blame] | 89 | |
Dave Gerlach | a8c13c7 | 2021-05-11 10:22:11 -0500 | [diff] [blame] | 90 | u32 lpddr4_setmmrregister(const lpddr4_privatedata *pd, u32 writemoderegval, u8 *mrwstatus); |
Kevin Scholz | 3bb3f26 | 2019-10-07 19:26:36 +0530 | [diff] [blame] | 91 | |
Dave Gerlach | a8c13c7 | 2021-05-11 10:22:11 -0500 | [diff] [blame] | 92 | u32 lpddr4_writectlconfig(const lpddr4_privatedata *pd, u32 regvalues[], u16 regnum[], u16 regcount); |
Kevin Scholz | 3bb3f26 | 2019-10-07 19:26:36 +0530 | [diff] [blame] | 93 | |
Dave Gerlach | a8c13c7 | 2021-05-11 10:22:11 -0500 | [diff] [blame] | 94 | u32 lpddr4_writephyconfig(const lpddr4_privatedata *pd, u32 regvalues[], u16 regnum[], u16 regcount); |
Kevin Scholz | 3bb3f26 | 2019-10-07 19:26:36 +0530 | [diff] [blame] | 95 | |
Dave Gerlach | a8c13c7 | 2021-05-11 10:22:11 -0500 | [diff] [blame] | 96 | u32 lpddr4_writephyindepconfig(const lpddr4_privatedata *pd, u32 regvalues[], u16 regnum[], u16 regcount); |
Kevin Scholz | 3bb3f26 | 2019-10-07 19:26:36 +0530 | [diff] [blame] | 97 | |
Dave Gerlach | a8c13c7 | 2021-05-11 10:22:11 -0500 | [diff] [blame] | 98 | u32 lpddr4_readctlconfig(const lpddr4_privatedata *pd, u32 regvalues[], u16 regnum[], u16 regcount); |
Kevin Scholz | 3bb3f26 | 2019-10-07 19:26:36 +0530 | [diff] [blame] | 99 | |
Dave Gerlach | a8c13c7 | 2021-05-11 10:22:11 -0500 | [diff] [blame] | 100 | u32 lpddr4_readphyconfig(const lpddr4_privatedata *pd, u32 regvalues[], u16 regnum[], u16 regcount); |
Kevin Scholz | 3bb3f26 | 2019-10-07 19:26:36 +0530 | [diff] [blame] | 101 | |
Dave Gerlach | a8c13c7 | 2021-05-11 10:22:11 -0500 | [diff] [blame] | 102 | u32 lpddr4_readphyindepconfig(const lpddr4_privatedata *pd, u32 regvalues[], u16 regnum[], u16 regcount); |
Kevin Scholz | 3bb3f26 | 2019-10-07 19:26:36 +0530 | [diff] [blame] | 103 | |
Dave Gerlach | a8c13c7 | 2021-05-11 10:22:11 -0500 | [diff] [blame] | 104 | u32 lpddr4_getctlinterruptmask(const lpddr4_privatedata *pd, u64 *mask); |
Kevin Scholz | 3bb3f26 | 2019-10-07 19:26:36 +0530 | [diff] [blame] | 105 | |
Dave Gerlach | a8c13c7 | 2021-05-11 10:22:11 -0500 | [diff] [blame] | 106 | u32 lpddr4_setctlinterruptmask(const lpddr4_privatedata *pd, const u64 *mask); |
Kevin Scholz | 3bb3f26 | 2019-10-07 19:26:36 +0530 | [diff] [blame] | 107 | |
Dave Gerlach | a8c13c7 | 2021-05-11 10:22:11 -0500 | [diff] [blame] | 108 | u32 lpddr4_checkctlinterrupt(const lpddr4_privatedata *pd, lpddr4_intr_ctlinterrupt intr, bool *irqstatus); |
Kevin Scholz | 3bb3f26 | 2019-10-07 19:26:36 +0530 | [diff] [blame] | 109 | |
Dave Gerlach | a8c13c7 | 2021-05-11 10:22:11 -0500 | [diff] [blame] | 110 | u32 lpddr4_ackctlinterrupt(const lpddr4_privatedata *pd, lpddr4_intr_ctlinterrupt intr); |
Kevin Scholz | 3bb3f26 | 2019-10-07 19:26:36 +0530 | [diff] [blame] | 111 | |
Dave Gerlach | a8c13c7 | 2021-05-11 10:22:11 -0500 | [diff] [blame] | 112 | u32 lpddr4_getphyindepinterruptmask(const lpddr4_privatedata *pd, u32 *mask); |
Kevin Scholz | 3bb3f26 | 2019-10-07 19:26:36 +0530 | [diff] [blame] | 113 | |
Dave Gerlach | a8c13c7 | 2021-05-11 10:22:11 -0500 | [diff] [blame] | 114 | u32 lpddr4_setphyindepinterruptmask(const lpddr4_privatedata *pd, const u32 *mask); |
Kevin Scholz | 3bb3f26 | 2019-10-07 19:26:36 +0530 | [diff] [blame] | 115 | |
Dave Gerlach | a8c13c7 | 2021-05-11 10:22:11 -0500 | [diff] [blame] | 116 | u32 lpddr4_checkphyindepinterrupt(const lpddr4_privatedata *pd, lpddr4_intr_phyindepinterrupt intr, bool *irqstatus); |
Kevin Scholz | 3bb3f26 | 2019-10-07 19:26:36 +0530 | [diff] [blame] | 117 | |
Dave Gerlach | a8c13c7 | 2021-05-11 10:22:11 -0500 | [diff] [blame] | 118 | u32 lpddr4_ackphyindepinterrupt(const lpddr4_privatedata *pd, lpddr4_intr_phyindepinterrupt intr); |
Kevin Scholz | 3bb3f26 | 2019-10-07 19:26:36 +0530 | [diff] [blame] | 119 | |
Dave Gerlach | a8c13c7 | 2021-05-11 10:22:11 -0500 | [diff] [blame] | 120 | u32 lpddr4_getdebuginitinfo(const lpddr4_privatedata *pd, lpddr4_debuginfo *debuginfo); |
Kevin Scholz | 3bb3f26 | 2019-10-07 19:26:36 +0530 | [diff] [blame] | 121 | |
Dave Gerlach | a8c13c7 | 2021-05-11 10:22:11 -0500 | [diff] [blame] | 122 | u32 lpddr4_getlpiwakeuptime(const lpddr4_privatedata *pd, const lpddr4_lpiwakeupparam *lpiwakeupparam, const lpddr4_ctlfspnum *fspnum, u32 *cycles); |
Kevin Scholz | 3bb3f26 | 2019-10-07 19:26:36 +0530 | [diff] [blame] | 123 | |
Dave Gerlach | a8c13c7 | 2021-05-11 10:22:11 -0500 | [diff] [blame] | 124 | u32 lpddr4_setlpiwakeuptime(const lpddr4_privatedata *pd, const lpddr4_lpiwakeupparam *lpiwakeupparam, const lpddr4_ctlfspnum *fspnum, const u32 *cycles); |
Kevin Scholz | 3bb3f26 | 2019-10-07 19:26:36 +0530 | [diff] [blame] | 125 | |
Dave Gerlach | a8c13c7 | 2021-05-11 10:22:11 -0500 | [diff] [blame] | 126 | u32 lpddr4_geteccenable(const lpddr4_privatedata *pd, lpddr4_eccenable *eccparam); |
Kevin Scholz | 3bb3f26 | 2019-10-07 19:26:36 +0530 | [diff] [blame] | 127 | |
Dave Gerlach | a8c13c7 | 2021-05-11 10:22:11 -0500 | [diff] [blame] | 128 | u32 lpddr4_seteccenable(const lpddr4_privatedata *pd, const lpddr4_eccenable *eccparam); |
Kevin Scholz | 3bb3f26 | 2019-10-07 19:26:36 +0530 | [diff] [blame] | 129 | |
Dave Gerlach | a8c13c7 | 2021-05-11 10:22:11 -0500 | [diff] [blame] | 130 | u32 lpddr4_getreducmode(const lpddr4_privatedata *pd, lpddr4_reducmode *mode); |
Kevin Scholz | 3bb3f26 | 2019-10-07 19:26:36 +0530 | [diff] [blame] | 131 | |
Dave Gerlach | a8c13c7 | 2021-05-11 10:22:11 -0500 | [diff] [blame] | 132 | u32 lpddr4_setreducmode(const lpddr4_privatedata *pd, const lpddr4_reducmode *mode); |
Kevin Scholz | 3bb3f26 | 2019-10-07 19:26:36 +0530 | [diff] [blame] | 133 | |
Dave Gerlach | a8c13c7 | 2021-05-11 10:22:11 -0500 | [diff] [blame] | 134 | u32 lpddr4_getdbireadmode(const lpddr4_privatedata *pd, bool *on_off); |
Kevin Scholz | 3bb3f26 | 2019-10-07 19:26:36 +0530 | [diff] [blame] | 135 | |
Dave Gerlach | a8c13c7 | 2021-05-11 10:22:11 -0500 | [diff] [blame] | 136 | u32 lpddr4_getdbiwritemode(const lpddr4_privatedata *pd, bool *on_off); |
Kevin Scholz | 3bb3f26 | 2019-10-07 19:26:36 +0530 | [diff] [blame] | 137 | |
Dave Gerlach | a8c13c7 | 2021-05-11 10:22:11 -0500 | [diff] [blame] | 138 | u32 lpddr4_setdbimode(const lpddr4_privatedata *pd, const lpddr4_dbimode *mode); |
Kevin Scholz | 3bb3f26 | 2019-10-07 19:26:36 +0530 | [diff] [blame] | 139 | |
Dave Gerlach | a8c13c7 | 2021-05-11 10:22:11 -0500 | [diff] [blame] | 140 | u32 lpddr4_getrefreshrate(const lpddr4_privatedata *pd, const lpddr4_ctlfspnum *fspnum, u32 *tref, u32 *tras_max); |
Kevin Scholz | 3bb3f26 | 2019-10-07 19:26:36 +0530 | [diff] [blame] | 141 | |
Dave Gerlach | a8c13c7 | 2021-05-11 10:22:11 -0500 | [diff] [blame] | 142 | u32 lpddr4_setrefreshrate(const lpddr4_privatedata *pd, const lpddr4_ctlfspnum *fspnum, const u32 *tref, const u32 *tras_max); |
Kevin Scholz | 3bb3f26 | 2019-10-07 19:26:36 +0530 | [diff] [blame] | 143 | |
Dave Gerlach | a8c13c7 | 2021-05-11 10:22:11 -0500 | [diff] [blame] | 144 | u32 lpddr4_refreshperchipselect(const lpddr4_privatedata *pd, const u32 trefinterval); |
Kevin Scholz | 3bb3f26 | 2019-10-07 19:26:36 +0530 | [diff] [blame] | 145 | |
Bryan Brattlof | ee31be4 | 2022-10-24 16:53:28 -0500 | [diff] [blame] | 146 | u32 lpddr4_deferredregverify(const lpddr4_privatedata *pd, lpddr4_regblock cpp, u32 regvalues[], u16 regnum[], u16 regcount); |
| 147 | |
Kevin Scholz | 3bb3f26 | 2019-10-07 19:26:36 +0530 | [diff] [blame] | 148 | #endif /* LPDDR4_IF_H */ |