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