1*ddaf02d1SJit Loon Lim /* 2*ddaf02d1SJit Loon Lim * Copyright (c) 2022, ARM Limited and Contributors. All rights reserved. 3*ddaf02d1SJit Loon Lim * Copyright (c) 2022-2023, Intel Corporation. All rights reserved. 4*ddaf02d1SJit Loon Lim * 5*ddaf02d1SJit Loon Lim * SPDX-License-Identifier: BSD-3-Clause 6*ddaf02d1SJit Loon Lim */ 7*ddaf02d1SJit Loon Lim 8*ddaf02d1SJit Loon Lim #ifndef CDN_MMC_H 9*ddaf02d1SJit Loon Lim #define CDN_MMC_H 10*ddaf02d1SJit Loon Lim 11*ddaf02d1SJit Loon Lim #include <drivers/cadence/cdns_combo_phy.h> 12*ddaf02d1SJit Loon Lim #include <drivers/mmc.h> 13*ddaf02d1SJit Loon Lim #include "socfpga_plat_def.h" 14*ddaf02d1SJit Loon Lim 15*ddaf02d1SJit Loon Lim #if MMC_DEVICE_TYPE == 0 16*ddaf02d1SJit Loon Lim #define CONFIG_DMA_ADDR_T_64BIT 0 17*ddaf02d1SJit Loon Lim #endif 18*ddaf02d1SJit Loon Lim 19*ddaf02d1SJit Loon Lim #define MMC_REG_BASE SOCFPGA_MMC_REG_BASE 20*ddaf02d1SJit Loon Lim #define COMBO_PHY_REG 0x0 21*ddaf02d1SJit Loon Lim #define SDHC_EXTENDED_WR_MODE_MASK 0xFFFFFFF7 22*ddaf02d1SJit Loon Lim #define SDHC_DLL_RESET_MASK 0x00000001 23*ddaf02d1SJit Loon Lim /* HRS09 */ 24*ddaf02d1SJit Loon Lim #define SDHC_PHY_SW_RESET BIT(0) 25*ddaf02d1SJit Loon Lim #define SDHC_PHY_INIT_COMPLETE BIT(1) 26*ddaf02d1SJit Loon Lim #define SDHC_EXTENDED_RD_MODE(x) ((x) << 2) 27*ddaf02d1SJit Loon Lim #define EXTENDED_WR_MODE 3 28*ddaf02d1SJit Loon Lim #define SDHC_EXTENDED_WR_MODE(x) ((x) << 3) 29*ddaf02d1SJit Loon Lim #define RDCMD_EN 15 30*ddaf02d1SJit Loon Lim #define SDHC_RDCMD_EN(x) ((x) << 15) 31*ddaf02d1SJit Loon Lim #define SDHC_RDDATA_EN(x) ((x) << 16) 32*ddaf02d1SJit Loon Lim 33*ddaf02d1SJit Loon Lim /* CMD_DATA_OUTPUT */ 34*ddaf02d1SJit Loon Lim #define SDHC_CDNS_HRS16 0x40 35*ddaf02d1SJit Loon Lim 36*ddaf02d1SJit Loon Lim /* This value determines the interval by which DAT line timeouts are detected */ 37*ddaf02d1SJit Loon Lim /* The interval can be computed as below: */ 38*ddaf02d1SJit Loon Lim /* • 1111b - Reserved */ 39*ddaf02d1SJit Loon Lim /* • 1110b - t_sdmclk*2(27+2) */ 40*ddaf02d1SJit Loon Lim /* • 1101b - t_sdmclk*2(26+2) */ 41*ddaf02d1SJit Loon Lim #define READ_CLK 0xa << 16 42*ddaf02d1SJit Loon Lim #define WRITE_CLK 0xe << 16 43*ddaf02d1SJit Loon Lim #define DTC_VAL 0xE 44*ddaf02d1SJit Loon Lim 45*ddaf02d1SJit Loon Lim /* SRS00 */ 46*ddaf02d1SJit Loon Lim /* System Address / Argument 2 / 32-bit block count 47*ddaf02d1SJit Loon Lim * This field is used as: 48*ddaf02d1SJit Loon Lim * • 32-bit Block Count register 49*ddaf02d1SJit Loon Lim * • SDMA system memory address 50*ddaf02d1SJit Loon Lim * • Auto CMD23 Argument 51*ddaf02d1SJit Loon Lim */ 52*ddaf02d1SJit Loon Lim #define SAAR (1) 53*ddaf02d1SJit Loon Lim 54*ddaf02d1SJit Loon Lim /* SRS01 */ 55*ddaf02d1SJit Loon Lim /* Transfer Block Size 56*ddaf02d1SJit Loon Lim * This field defines block size for block data transfers 57*ddaf02d1SJit Loon Lim */ 58*ddaf02d1SJit Loon Lim #define BLOCK_SIZE 0 59*ddaf02d1SJit Loon Lim 60*ddaf02d1SJit Loon Lim /* SDMA Buffer Boundary 61*ddaf02d1SJit Loon Lim * System address boundary can be set for SDMA engine. 62*ddaf02d1SJit Loon Lim */ 63*ddaf02d1SJit Loon Lim #define SDMA_BUF 7 << 12 64*ddaf02d1SJit Loon Lim 65*ddaf02d1SJit Loon Lim /* Block Count For Current Transfer 66*ddaf02d1SJit Loon Lim * To set the number of data blocks can be defined for next transfer 67*ddaf02d1SJit Loon Lim */ 68*ddaf02d1SJit Loon Lim #define BLK_COUNT_CT 16 69*ddaf02d1SJit Loon Lim 70*ddaf02d1SJit Loon Lim /* SRS03 */ 71*ddaf02d1SJit Loon Lim #define CMD_START (U(1) << 31) 72*ddaf02d1SJit Loon Lim #define CMD_USE_HOLD_REG (1 << 29) 73*ddaf02d1SJit Loon Lim #define CMD_UPDATE_CLK_ONLY (1 << 21) 74*ddaf02d1SJit Loon Lim #define CMD_SEND_INIT (1 << 15) 75*ddaf02d1SJit Loon Lim #define CMD_STOP_ABORT_CMD (4 << 22) 76*ddaf02d1SJit Loon Lim #define CMD_RESUME_CMD (2 << 22) 77*ddaf02d1SJit Loon Lim #define CMD_SUSPEND_CMD (1 << 22) 78*ddaf02d1SJit Loon Lim #define DATA_PRESENT (1 << 21) 79*ddaf02d1SJit Loon Lim #define CMD_IDX_CHK_ENABLE (1 << 20) 80*ddaf02d1SJit Loon Lim #define CMD_WRITE (0 << 4) 81*ddaf02d1SJit Loon Lim #define CMD_READ (1 << 4) 82*ddaf02d1SJit Loon Lim #define MULTI_BLK_READ (1 << 5) 83*ddaf02d1SJit Loon Lim #define RESP_ERR (1 << 7) 84*ddaf02d1SJit Loon Lim #define CMD_CHECK_RESP_CRC (1 << 19) 85*ddaf02d1SJit Loon Lim #define RES_TYPE_SEL_48 (2 << 16) 86*ddaf02d1SJit Loon Lim #define RES_TYPE_SEL_136 (1 << 16) 87*ddaf02d1SJit Loon Lim #define RES_TYPE_SEL_48_B (3 << 16) 88*ddaf02d1SJit Loon Lim #define RES_TYPE_SEL_NO (0 << 16) 89*ddaf02d1SJit Loon Lim #define DMA_ENABLED (1 << 0) 90*ddaf02d1SJit Loon Lim #define BLK_CNT_EN (1 << 1) 91*ddaf02d1SJit Loon Lim #define AUTO_CMD_EN (2 << 2) 92*ddaf02d1SJit Loon Lim #define COM_IDX 24 93*ddaf02d1SJit Loon Lim #define ERROR_INT (1 << 15) 94*ddaf02d1SJit Loon Lim #define INT_SBE (1 << 13) 95*ddaf02d1SJit Loon Lim #define INT_HLE (1 << 12) 96*ddaf02d1SJit Loon Lim #define INT_FRUN (1 << 11) 97*ddaf02d1SJit Loon Lim #define INT_DRT (1 << 9) 98*ddaf02d1SJit Loon Lim #define INT_RTO (1 << 8) 99*ddaf02d1SJit Loon Lim #define INT_DCRC (1 << 7) 100*ddaf02d1SJit Loon Lim #define INT_RCRC (1 << 6) 101*ddaf02d1SJit Loon Lim #define INT_RXDR (1 << 5) 102*ddaf02d1SJit Loon Lim #define INT_TXDR (1 << 4) 103*ddaf02d1SJit Loon Lim #define INT_DTO (1 << 3) 104*ddaf02d1SJit Loon Lim #define INT_CMD_DONE (1 << 0) 105*ddaf02d1SJit Loon Lim #define TRAN_COMP (1 << 1) 106*ddaf02d1SJit Loon Lim 107*ddaf02d1SJit Loon Lim /* SRS09 */ 108*ddaf02d1SJit Loon Lim #define STATUS_DATA_BUSY BIT(2) 109*ddaf02d1SJit Loon Lim 110*ddaf02d1SJit Loon Lim /* SRS10 */ 111*ddaf02d1SJit Loon Lim /* LED Control 112*ddaf02d1SJit Loon Lim * State of this bit directly drives led port of the host 113*ddaf02d1SJit Loon Lim * in order to control the external LED diode 114*ddaf02d1SJit Loon Lim * Default value 0 << 1 115*ddaf02d1SJit Loon Lim */ 116*ddaf02d1SJit Loon Lim #define LEDC BIT(0) 117*ddaf02d1SJit Loon Lim #define LEDC_OFF 0 << 1 118*ddaf02d1SJit Loon Lim 119*ddaf02d1SJit Loon Lim /* Data Transfer Width 120*ddaf02d1SJit Loon Lim * Bit used to configure DAT bus width to 1 or 4 121*ddaf02d1SJit Loon Lim * Default value 1 << 1 122*ddaf02d1SJit Loon Lim */ 123*ddaf02d1SJit Loon Lim #define DT_WIDTH BIT(1) 124*ddaf02d1SJit Loon Lim #define DTW_4BIT 1 << 1 125*ddaf02d1SJit Loon Lim 126*ddaf02d1SJit Loon Lim /* Extended Data Transfer Width 127*ddaf02d1SJit Loon Lim * This bit is to enable/disable 8-bit DAT bus width mode 128*ddaf02d1SJit Loon Lim * Default value 1 << 5 129*ddaf02d1SJit Loon Lim */ 130*ddaf02d1SJit Loon Lim #define EDTW_8BIT 1 << 5 131*ddaf02d1SJit Loon Lim 132*ddaf02d1SJit Loon Lim /* High Speed Enable 133*ddaf02d1SJit Loon Lim * Selects operating mode to Default Speed (HSE=0) or High Speed (HSE=1) 134*ddaf02d1SJit Loon Lim */ 135*ddaf02d1SJit Loon Lim #define HS_EN BIT(2) 136*ddaf02d1SJit Loon Lim 137*ddaf02d1SJit Loon Lim /* here 0 defines the 64 Kb size */ 138*ddaf02d1SJit Loon Lim #define MAX_64KB_PAGE 0 139*ddaf02d1SJit Loon Lim #define EMMC_DESC_SIZE (1<<20) 140*ddaf02d1SJit Loon Lim 141*ddaf02d1SJit Loon Lim /* SRS11 */ 142*ddaf02d1SJit Loon Lim /* Software Reset For All 143*ddaf02d1SJit Loon Lim * When set to 1, the entire slot is reset 144*ddaf02d1SJit Loon Lim * After completing the reset operation, SRFA bit is automatically cleared 145*ddaf02d1SJit Loon Lim */ 146*ddaf02d1SJit Loon Lim #define SRFA BIT(24) 147*ddaf02d1SJit Loon Lim 148*ddaf02d1SJit Loon Lim /* Software Reset For CMD Line 149*ddaf02d1SJit Loon Lim * When set to 1, resets the logic related to the command generation and response checking 150*ddaf02d1SJit Loon Lim */ 151*ddaf02d1SJit Loon Lim #define SRCMD BIT(25) 152*ddaf02d1SJit Loon Lim 153*ddaf02d1SJit Loon Lim /* Software Reset For DAT Line 154*ddaf02d1SJit Loon Lim * When set to 1, resets the logic related to the data path, 155*ddaf02d1SJit Loon Lim * including data buffers and the DMA logic 156*ddaf02d1SJit Loon Lim */ 157*ddaf02d1SJit Loon Lim #define SRDAT BIT(26) 158*ddaf02d1SJit Loon Lim 159*ddaf02d1SJit Loon Lim /* SRS15 */ 160*ddaf02d1SJit Loon Lim /* UHS Mode Select 161*ddaf02d1SJit Loon Lim * Used to select one of UHS-I modes. 162*ddaf02d1SJit Loon Lim * • 000b - SDR12 163*ddaf02d1SJit Loon Lim * • 001b - SDR25 164*ddaf02d1SJit Loon Lim * • 010b - SDR50 165*ddaf02d1SJit Loon Lim * • 011b - SDR104 166*ddaf02d1SJit Loon Lim * • 100b - DDR50 167*ddaf02d1SJit Loon Lim */ 168*ddaf02d1SJit Loon Lim #define SDR12_MODE 0 << 16 169*ddaf02d1SJit Loon Lim #define SDR25_MODE 1 << 16 170*ddaf02d1SJit Loon Lim #define SDR50_MODE 2 << 16 171*ddaf02d1SJit Loon Lim #define SDR104_MODE 3 << 16 172*ddaf02d1SJit Loon Lim #define DDR50_MODE 4 << 16 173*ddaf02d1SJit Loon Lim /* 1.8V Signaling Enable 174*ddaf02d1SJit Loon Lim * • 0 - for Default Speed, High Speed mode 175*ddaf02d1SJit Loon Lim * • 1 - for UHS-I mode 176*ddaf02d1SJit Loon Lim */ 177*ddaf02d1SJit Loon Lim #define V18SE BIT(19) 178*ddaf02d1SJit Loon Lim 179*ddaf02d1SJit Loon Lim /* CMD23 Enable 180*ddaf02d1SJit Loon Lim * In result of Card Identification process, 181*ddaf02d1SJit Loon Lim * Host Driver set this bit to 1 if Card supports CMD23 182*ddaf02d1SJit Loon Lim */ 183*ddaf02d1SJit Loon Lim #define CMD23_EN BIT(27) 184*ddaf02d1SJit Loon Lim 185*ddaf02d1SJit Loon Lim /* Host Version 4.00 Enable 186*ddaf02d1SJit Loon Lim * • 0 - Version 3.00 187*ddaf02d1SJit Loon Lim * • 1 - Version 4.00 188*ddaf02d1SJit Loon Lim */ 189*ddaf02d1SJit Loon Lim #define HV4E BIT(28) 190*ddaf02d1SJit Loon Lim /* Conf depends on SRS15.HV4E */ 191*ddaf02d1SJit Loon Lim #define SDMA 0 << 3 192*ddaf02d1SJit Loon Lim #define ADMA2_32 2 << 3 193*ddaf02d1SJit Loon Lim #define ADMA2_64 3 << 3 194*ddaf02d1SJit Loon Lim 195*ddaf02d1SJit Loon Lim /* Preset Value Enable 196*ddaf02d1SJit Loon Lim * Setting this bit to 1 triggers an automatically update of SRS11 197*ddaf02d1SJit Loon Lim */ 198*ddaf02d1SJit Loon Lim #define PVE BIT(31) 199*ddaf02d1SJit Loon Lim 200*ddaf02d1SJit Loon Lim #define BIT_AD_32 0 << 29 201*ddaf02d1SJit Loon Lim #define BIT_AD_64 1 << 29 202*ddaf02d1SJit Loon Lim 203*ddaf02d1SJit Loon Lim /* SW RESET REG*/ 204*ddaf02d1SJit Loon Lim #define SDHC_CDNS_HRS00 (0x00) 205*ddaf02d1SJit Loon Lim #define SDHC_CDNS_HRS00_SWR BIT(0) 206*ddaf02d1SJit Loon Lim 207*ddaf02d1SJit Loon Lim /* PHY access port */ 208*ddaf02d1SJit Loon Lim #define SDHC_CDNS_HRS04 0x10 209*ddaf02d1SJit Loon Lim #define SDHC_CDNS_HRS04_ADDR GENMASK(5, 0) 210*ddaf02d1SJit Loon Lim 211*ddaf02d1SJit Loon Lim /* PHY data access port */ 212*ddaf02d1SJit Loon Lim #define SDHC_CDNS_HRS05 0x14 213*ddaf02d1SJit Loon Lim 214*ddaf02d1SJit Loon Lim /* eMMC control registers */ 215*ddaf02d1SJit Loon Lim #define SDHC_CDNS_HRS06 0x18 216*ddaf02d1SJit Loon Lim 217*ddaf02d1SJit Loon Lim /* SRS */ 218*ddaf02d1SJit Loon Lim #define SDHC_CDNS_SRS_BASE 0x200 219*ddaf02d1SJit Loon Lim #define SDHC_CDNS_SRS00 0x200 220*ddaf02d1SJit Loon Lim #define SDHC_CDNS_SRS01 0x204 221*ddaf02d1SJit Loon Lim #define SDHC_CDNS_SRS02 0x208 222*ddaf02d1SJit Loon Lim #define SDHC_CDNS_SRS03 0x20c 223*ddaf02d1SJit Loon Lim #define SDHC_CDNS_SRS04 0x210 224*ddaf02d1SJit Loon Lim #define SDHC_CDNS_SRS05 0x214 225*ddaf02d1SJit Loon Lim #define SDHC_CDNS_SRS06 0x218 226*ddaf02d1SJit Loon Lim #define SDHC_CDNS_SRS07 0x21C 227*ddaf02d1SJit Loon Lim #define SDHC_CDNS_SRS08 0x220 228*ddaf02d1SJit Loon Lim #define SDHC_CDNS_SRS09 0x224 229*ddaf02d1SJit Loon Lim #define SDHC_CDNS_SRS09_CI BIT(16) 230*ddaf02d1SJit Loon Lim #define SDHC_CDNS_SRS10 0x228 231*ddaf02d1SJit Loon Lim #define SDHC_CDNS_SRS11 0x22C 232*ddaf02d1SJit Loon Lim #define SDHC_CDNS_SRS12 0x230 233*ddaf02d1SJit Loon Lim #define SDHC_CDNS_SRS13 0x234 234*ddaf02d1SJit Loon Lim #define SDHC_CDNS_SRS14 0x238 235*ddaf02d1SJit Loon Lim #define SDHC_CDNS_SRS15 0x23c 236*ddaf02d1SJit Loon Lim #define SDHC_CDNS_SRS21 0x254 237*ddaf02d1SJit Loon Lim #define SDHC_CDNS_SRS22 0x258 238*ddaf02d1SJit Loon Lim #define SDHC_CDNS_SRS23 0x25c 239*ddaf02d1SJit Loon Lim 240*ddaf02d1SJit Loon Lim /* HRS07 */ 241*ddaf02d1SJit Loon Lim #define SDHC_CDNS_HRS07 0x1c 242*ddaf02d1SJit Loon Lim #define SDHC_IDELAY_VAL(x) ((x) << 0) 243*ddaf02d1SJit Loon Lim #define SDHC_RW_COMPENSATE(x) ((x) << 16) 244*ddaf02d1SJit Loon Lim 245*ddaf02d1SJit Loon Lim /* PHY reset port */ 246*ddaf02d1SJit Loon Lim #define SDHC_CDNS_HRS09 0x24 247*ddaf02d1SJit Loon Lim 248*ddaf02d1SJit Loon Lim /* HRS10 */ 249*ddaf02d1SJit Loon Lim /* PHY reset port */ 250*ddaf02d1SJit Loon Lim #define SDHC_CDNS_HRS10 0x28 251*ddaf02d1SJit Loon Lim 252*ddaf02d1SJit Loon Lim /* HCSDCLKADJ DATA; DDR Mode */ 253*ddaf02d1SJit Loon Lim #define SDHC_HCSDCLKADJ(x) ((x) << 16) 254*ddaf02d1SJit Loon Lim 255*ddaf02d1SJit Loon Lim /* Pinmux headers will reomove after ATF driver implementation */ 256*ddaf02d1SJit Loon Lim #define PINMUX_SDMMC_SEL 0x0 257*ddaf02d1SJit Loon Lim #define PIN0SEL 0x00 258*ddaf02d1SJit Loon Lim #define PIN1SEL 0x04 259*ddaf02d1SJit Loon Lim #define PIN2SEL 0x08 260*ddaf02d1SJit Loon Lim #define PIN3SEL 0x0C 261*ddaf02d1SJit Loon Lim #define PIN4SEL 0x10 262*ddaf02d1SJit Loon Lim #define PIN5SEL 0x14 263*ddaf02d1SJit Loon Lim #define PIN6SEL 0x18 264*ddaf02d1SJit Loon Lim #define PIN7SEL 0x1C 265*ddaf02d1SJit Loon Lim #define PIN8SEL 0x20 266*ddaf02d1SJit Loon Lim #define PIN9SEL 0x24 267*ddaf02d1SJit Loon Lim #define PIN10SEL 0x28 268*ddaf02d1SJit Loon Lim 269*ddaf02d1SJit Loon Lim /* HRS16 */ 270*ddaf02d1SJit Loon Lim #define SDHC_WRCMD0_DLY(x) ((x) << 0) 271*ddaf02d1SJit Loon Lim #define SDHC_WRCMD1_DLY(x) ((x) << 4) 272*ddaf02d1SJit Loon Lim #define SDHC_WRDATA0_DLY(x) ((x) << 8) 273*ddaf02d1SJit Loon Lim #define SDHC_WRDATA1_DLY(x) ((x) << 12) 274*ddaf02d1SJit Loon Lim #define SDHC_WRCMD0_SDCLK_DLY(x) ((x) << 16) 275*ddaf02d1SJit Loon Lim #define SDHC_WRCMD1_SDCLK_DLY(x) ((x) << 20) 276*ddaf02d1SJit Loon Lim #define SDHC_WRDATA0_SDCLK_DLY(x) ((x) << 24) 277*ddaf02d1SJit Loon Lim #define SDHC_WRDATA1_SDCLK_DLY(x) ((x) << 28) 278*ddaf02d1SJit Loon Lim 279*ddaf02d1SJit Loon Lim /* Shared Macros */ 280*ddaf02d1SJit Loon Lim #define SDMMC_CDN(_reg) (SDMMC_CDN_REG_BASE + \ 281*ddaf02d1SJit Loon Lim (SDMMC_CDN_##_reg)) 282*ddaf02d1SJit Loon Lim 283*ddaf02d1SJit Loon Lim /* Refer to atf/tools/cert_create/include/debug.h */ 284*ddaf02d1SJit Loon Lim #define BIT_32(nr) (U(1) << (nr)) 285*ddaf02d1SJit Loon Lim 286*ddaf02d1SJit Loon Lim /* MMC Peripheral Definition */ 287*ddaf02d1SJit Loon Lim #define SOCFPGA_MMC_BLOCK_SIZE U(8192) 288*ddaf02d1SJit Loon Lim #define SOCFPGA_MMC_BLOCK_MASK (SOCFPGA_MMC_BLOCK_SIZE - U(1)) 289*ddaf02d1SJit Loon Lim #define SOCFPGA_MMC_BOOT_CLK_RATE (400 * 1000) 290*ddaf02d1SJit Loon Lim #define MMC_RESPONSE_NONE 0 291*ddaf02d1SJit Loon Lim #define SDHC_CDNS_SRS03_VALUE 0x01020013 292*ddaf02d1SJit Loon Lim 293*ddaf02d1SJit Loon Lim /* Value randomly chosen for eMMC RCA, it should be > 1 */ 294*ddaf02d1SJit Loon Lim #define MMC_FIX_RCA 6 295*ddaf02d1SJit Loon Lim #define RCA_SHIFT_OFFSET 16 296*ddaf02d1SJit Loon Lim 297*ddaf02d1SJit Loon Lim #define CMD_EXTCSD_PARTITION_CONFIG 179 298*ddaf02d1SJit Loon Lim #define CMD_EXTCSD_BUS_WIDTH 183 299*ddaf02d1SJit Loon Lim #define CMD_EXTCSD_HS_TIMING 185 300*ddaf02d1SJit Loon Lim #define CMD_EXTCSD_SEC_CNT 212 301*ddaf02d1SJit Loon Lim 302*ddaf02d1SJit Loon Lim #define PART_CFG_BOOT_PARTITION1_ENABLE (U(1) << 3) 303*ddaf02d1SJit Loon Lim #define PART_CFG_PARTITION1_ACCESS (U(1) << 0) 304*ddaf02d1SJit Loon Lim 305*ddaf02d1SJit Loon Lim /* Values in EXT CSD register */ 306*ddaf02d1SJit Loon Lim #define MMC_BUS_WIDTH_1 U(0) 307*ddaf02d1SJit Loon Lim #define MMC_BUS_WIDTH_4 U(1) 308*ddaf02d1SJit Loon Lim #define MMC_BUS_WIDTH_8 U(2) 309*ddaf02d1SJit Loon Lim #define MMC_BUS_WIDTH_DDR_4 U(5) 310*ddaf02d1SJit Loon Lim #define MMC_BUS_WIDTH_DDR_8 U(6) 311*ddaf02d1SJit Loon Lim #define MMC_BOOT_MODE_BACKWARD (U(0) << 3) 312*ddaf02d1SJit Loon Lim #define MMC_BOOT_MODE_HS_TIMING (U(1) << 3) 313*ddaf02d1SJit Loon Lim #define MMC_BOOT_MODE_DDR (U(2) << 3) 314*ddaf02d1SJit Loon Lim 315*ddaf02d1SJit Loon Lim #define EXTCSD_SET_CMD (U(0) << 24) 316*ddaf02d1SJit Loon Lim #define EXTCSD_SET_BITS (U(1) << 24) 317*ddaf02d1SJit Loon Lim #define EXTCSD_CLR_BITS (U(2) << 24) 318*ddaf02d1SJit Loon Lim #define EXTCSD_WRITE_BYTES (U(3) << 24) 319*ddaf02d1SJit Loon Lim #define EXTCSD_CMD(x) (((x) & 0xff) << 16) 320*ddaf02d1SJit Loon Lim #define EXTCSD_VALUE(x) (((x) & 0xff) << 8) 321*ddaf02d1SJit Loon Lim #define EXTCSD_CMD_SET_NORMAL U(1) 322*ddaf02d1SJit Loon Lim 323*ddaf02d1SJit Loon Lim #define CSD_TRAN_SPEED_UNIT_MASK GENMASK(2, 0) 324*ddaf02d1SJit Loon Lim #define CSD_TRAN_SPEED_MULT_MASK GENMASK(6, 3) 325*ddaf02d1SJit Loon Lim #define CSD_TRAN_SPEED_MULT_SHIFT 3 326*ddaf02d1SJit Loon Lim 327*ddaf02d1SJit Loon Lim #define STATUS_CURRENT_STATE(x) (((x) & 0xf) << 9) 328*ddaf02d1SJit Loon Lim #define STATUS_READY_FOR_DATA BIT(8) 329*ddaf02d1SJit Loon Lim #define STATUS_SWITCH_ERROR BIT(7) 330*ddaf02d1SJit Loon Lim #define MMC_GET_STATE(x) (((x) >> 9) & 0xf) 331*ddaf02d1SJit Loon Lim #define MMC_STATE_IDLE 0 332*ddaf02d1SJit Loon Lim #define MMC_STATE_READY 1 333*ddaf02d1SJit Loon Lim #define MMC_STATE_IDENT 2 334*ddaf02d1SJit Loon Lim #define MMC_STATE_STBY 3 335*ddaf02d1SJit Loon Lim #define MMC_STATE_TRAN 4 336*ddaf02d1SJit Loon Lim #define MMC_STATE_DATA 5 337*ddaf02d1SJit Loon Lim #define MMC_STATE_RCV 6 338*ddaf02d1SJit Loon Lim #define MMC_STATE_PRG 7 339*ddaf02d1SJit Loon Lim #define MMC_STATE_DIS 8 340*ddaf02d1SJit Loon Lim #define MMC_STATE_BTST 9 341*ddaf02d1SJit Loon Lim #define MMC_STATE_SLP 10 342*ddaf02d1SJit Loon Lim 343*ddaf02d1SJit Loon Lim #define MMC_FLAG_CMD23 (U(1) << 0) 344*ddaf02d1SJit Loon Lim 345*ddaf02d1SJit Loon Lim #define CMD8_CHECK_PATTERN U(0xAA) 346*ddaf02d1SJit Loon Lim #define VHS_2_7_3_6_V BIT(8) 347*ddaf02d1SJit Loon Lim 348*ddaf02d1SJit Loon Lim /*ADMA table component*/ 349*ddaf02d1SJit Loon Lim #define ADMA_DESC_ATTR_VALID BIT(0) 350*ddaf02d1SJit Loon Lim #define ADMA_DESC_ATTR_END BIT(1) 351*ddaf02d1SJit Loon Lim #define ADMA_DESC_ATTR_INT BIT(2) 352*ddaf02d1SJit Loon Lim #define ADMA_DESC_ATTR_ACT1 BIT(4) 353*ddaf02d1SJit Loon Lim #define ADMA_DESC_ATTR_ACT2 BIT(5) 354*ddaf02d1SJit Loon Lim #define ADMA_DESC_TRANSFER_DATA ADMA_DESC_ATTR_ACT2 355*ddaf02d1SJit Loon Lim 356*ddaf02d1SJit Loon Lim enum sd_opcode { 357*ddaf02d1SJit Loon Lim SD_GO_IDLE_STATE = 0, 358*ddaf02d1SJit Loon Lim SD_ALL_SEND_CID = 2, 359*ddaf02d1SJit Loon Lim SD_SEND_RELATIVE_ADDR = 3, 360*ddaf02d1SJit Loon Lim SDIO_SEND_OP_COND = 5, /* SDIO cards only */ 361*ddaf02d1SJit Loon Lim SD_SWITCH = 6, 362*ddaf02d1SJit Loon Lim SD_SELECT_CARD = 7, 363*ddaf02d1SJit Loon Lim SD_SEND_IF_COND = 8, 364*ddaf02d1SJit Loon Lim SD_SEND_CSD = 9, 365*ddaf02d1SJit Loon Lim SD_SEND_CID = 10, 366*ddaf02d1SJit Loon Lim SD_VOL_SWITCH = 11, 367*ddaf02d1SJit Loon Lim SD_STOP_TRANSMISSION = 12, 368*ddaf02d1SJit Loon Lim SD_SEND_STATUS = 13, 369*ddaf02d1SJit Loon Lim SD_GO_INACTIVE_STATE = 15, 370*ddaf02d1SJit Loon Lim SD_SET_BLOCK_SIZE = 16, 371*ddaf02d1SJit Loon Lim SD_READ_SINGLE_BLOCK = 17, 372*ddaf02d1SJit Loon Lim SD_READ_MULTIPLE_BLOCK = 18, 373*ddaf02d1SJit Loon Lim SD_SEND_TUNING_BLOCK = 19, 374*ddaf02d1SJit Loon Lim SD_SET_BLOCK_COUNT = 23, 375*ddaf02d1SJit Loon Lim SD_WRITE_SINGLE_BLOCK = 24, 376*ddaf02d1SJit Loon Lim SD_WRITE_MULTIPLE_BLOCK = 25, 377*ddaf02d1SJit Loon Lim SD_ERASE_BLOCK_START = 32, 378*ddaf02d1SJit Loon Lim SD_ERASE_BLOCK_END = 33, 379*ddaf02d1SJit Loon Lim SD_ERASE_BLOCK_OPERATION = 38, 380*ddaf02d1SJit Loon Lim SD_APP_CMD = 55, 381*ddaf02d1SJit Loon Lim SD_SPI_READ_OCR = 58, /* SPI mode only */ 382*ddaf02d1SJit Loon Lim SD_SPI_CRC_ON_OFF = 59, /* SPI mode only */ 383*ddaf02d1SJit Loon Lim }; 384*ddaf02d1SJit Loon Lim 385*ddaf02d1SJit Loon Lim enum sd_app_cmd { 386*ddaf02d1SJit Loon Lim SD_APP_SET_BUS_WIDTH = 6, 387*ddaf02d1SJit Loon Lim SD_APP_SEND_STATUS = 13, 388*ddaf02d1SJit Loon Lim SD_APP_SEND_NUM_WRITTEN_BLK = 22, 389*ddaf02d1SJit Loon Lim SD_APP_SET_WRITE_BLK_ERASE_CNT = 23, 390*ddaf02d1SJit Loon Lim SD_APP_SEND_OP_COND = 41, 391*ddaf02d1SJit Loon Lim SD_APP_CLEAR_CARD_DETECT = 42, 392*ddaf02d1SJit Loon Lim SD_APP_SEND_SCR = 51, 393*ddaf02d1SJit Loon Lim }; 394*ddaf02d1SJit Loon Lim 395*ddaf02d1SJit Loon Lim struct cdns_sdmmc_sdhc { 396*ddaf02d1SJit Loon Lim uint32_t sdhc_extended_rd_mode; 397*ddaf02d1SJit Loon Lim uint32_t sdhc_extended_wr_mode; 398*ddaf02d1SJit Loon Lim uint32_t sdhc_hcsdclkadj; 399*ddaf02d1SJit Loon Lim uint32_t sdhc_idelay_val; 400*ddaf02d1SJit Loon Lim uint32_t sdhc_rdcmd_en; 401*ddaf02d1SJit Loon Lim uint32_t sdhc_rddata_en; 402*ddaf02d1SJit Loon Lim uint32_t sdhc_rw_compensate; 403*ddaf02d1SJit Loon Lim uint32_t sdhc_sdcfsh; 404*ddaf02d1SJit Loon Lim uint32_t sdhc_sdcfsl; 405*ddaf02d1SJit Loon Lim uint32_t sdhc_wrcmd0_dly; 406*ddaf02d1SJit Loon Lim uint32_t sdhc_wrcmd0_sdclk_dly; 407*ddaf02d1SJit Loon Lim uint32_t sdhc_wrcmd1_dly; 408*ddaf02d1SJit Loon Lim uint32_t sdhc_wrcmd1_sdclk_dly; 409*ddaf02d1SJit Loon Lim uint32_t sdhc_wrdata0_dly; 410*ddaf02d1SJit Loon Lim uint32_t sdhc_wrdata0_sdclk_dly; 411*ddaf02d1SJit Loon Lim uint32_t sdhc_wrdata1_dly; 412*ddaf02d1SJit Loon Lim uint32_t sdhc_wrdata1_sdclk_dly; 413*ddaf02d1SJit Loon Lim }; 414*ddaf02d1SJit Loon Lim 415*ddaf02d1SJit Loon Lim enum sdmmc_device_mode { 416*ddaf02d1SJit Loon Lim SD_DS_ID, /* Identification */ 417*ddaf02d1SJit Loon Lim SD_DS, /* Default speed */ 418*ddaf02d1SJit Loon Lim SD_HS, /* High speed */ 419*ddaf02d1SJit Loon Lim SD_UHS_SDR12, /* Ultra high speed SDR12 */ 420*ddaf02d1SJit Loon Lim SD_UHS_SDR25, /* Ultra high speed SDR25 */ 421*ddaf02d1SJit Loon Lim SD_UHS_SDR50, /* Ultra high speed SDR`50 */ 422*ddaf02d1SJit Loon Lim SD_UHS_SDR104, /* Ultra high speed SDR104 */ 423*ddaf02d1SJit Loon Lim SD_UHS_DDR50, /* Ultra high speed DDR50 */ 424*ddaf02d1SJit Loon Lim EMMC_SDR_BC, /* SDR backward compatible */ 425*ddaf02d1SJit Loon Lim EMMC_SDR, /* SDR */ 426*ddaf02d1SJit Loon Lim EMMC_DDR, /* DDR */ 427*ddaf02d1SJit Loon Lim EMMC_HS200, /* High speed 200Mhz in SDR */ 428*ddaf02d1SJit Loon Lim EMMC_HS400, /* High speed 200Mhz in DDR */ 429*ddaf02d1SJit Loon Lim EMMC_HS400es, /* High speed 200Mhz in SDR with enhanced strobe*/ 430*ddaf02d1SJit Loon Lim }; 431*ddaf02d1SJit Loon Lim 432*ddaf02d1SJit Loon Lim struct cdns_sdmmc_params { 433*ddaf02d1SJit Loon Lim uintptr_t reg_base; 434*ddaf02d1SJit Loon Lim uintptr_t reg_pinmux; 435*ddaf02d1SJit Loon Lim uintptr_t reg_phy; 436*ddaf02d1SJit Loon Lim uintptr_t desc_base; 437*ddaf02d1SJit Loon Lim size_t desc_size; 438*ddaf02d1SJit Loon Lim int clk_rate; 439*ddaf02d1SJit Loon Lim int bus_width; 440*ddaf02d1SJit Loon Lim unsigned int flags; 441*ddaf02d1SJit Loon Lim enum sdmmc_device_mode cdn_sdmmc_dev_mode; 442*ddaf02d1SJit Loon Lim enum mmc_device_type cdn_sdmmc_dev_type; 443*ddaf02d1SJit Loon Lim uint32_t combophy; 444*ddaf02d1SJit Loon Lim }; 445*ddaf02d1SJit Loon Lim 446*ddaf02d1SJit Loon Lim /* read and write API */ 447*ddaf02d1SJit Loon Lim size_t sdmmc_read_blocks(int lba, uintptr_t buf, size_t size); 448*ddaf02d1SJit Loon Lim size_t sdmmc_write_blocks(int lba, const uintptr_t buf, size_t size); 449*ddaf02d1SJit Loon Lim 450*ddaf02d1SJit Loon Lim struct cdns_idmac_desc { 451*ddaf02d1SJit Loon Lim /*8 bit attribute*/ 452*ddaf02d1SJit Loon Lim uint8_t attr; 453*ddaf02d1SJit Loon Lim /*reserved bits in desc*/ 454*ddaf02d1SJit Loon Lim uint8_t reserved; 455*ddaf02d1SJit Loon Lim /*page length for the descriptor*/ 456*ddaf02d1SJit Loon Lim uint16_t len; 457*ddaf02d1SJit Loon Lim /*lower 32 bits for buffer (64 bit addressing)*/ 458*ddaf02d1SJit Loon Lim uint32_t addr_lo; 459*ddaf02d1SJit Loon Lim #if CONFIG_DMA_ADDR_T_64BIT == 1 460*ddaf02d1SJit Loon Lim /*higher 32 bits for buffer (64 bit addressing)*/ 461*ddaf02d1SJit Loon Lim uint32_t addr_hi; 462*ddaf02d1SJit Loon Lim } __aligned(8); 463*ddaf02d1SJit Loon Lim #else 464*ddaf02d1SJit Loon Lim } __packed; 465*ddaf02d1SJit Loon Lim #endif 466*ddaf02d1SJit Loon Lim 467*ddaf02d1SJit Loon Lim 468*ddaf02d1SJit Loon Lim 469*ddaf02d1SJit Loon Lim /* Function Prototype */ 470*ddaf02d1SJit Loon Lim int cdns_sd_host_init(struct cdns_sdmmc_combo_phy *mmc_combo_phy_reg, 471*ddaf02d1SJit Loon Lim struct cdns_sdmmc_sdhc *mmc_sdhc_reg); 472*ddaf02d1SJit Loon Lim void cdns_set_sdmmc_var(struct cdns_sdmmc_combo_phy *combo_phy_reg, 473*ddaf02d1SJit Loon Lim struct cdns_sdmmc_sdhc *sdhc_reg); 474*ddaf02d1SJit Loon Lim #endif 475