Tom Rini | 10e4779 | 2018-05-06 17:58:06 -0400 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0 */ |
Yoshihiro Shimoda | db7717b | 2011-07-04 22:21:22 +0000 | [diff] [blame] | 2 | /* |
| 3 | * MMCIF driver. |
| 4 | * |
| 5 | * Copyright (C) 2011 Renesas Solutions Corp. |
Yoshihiro Shimoda | db7717b | 2011-07-04 22:21:22 +0000 | [diff] [blame] | 6 | */ |
| 7 | |
| 8 | #ifndef _SH_MMCIF_H_ |
| 9 | #define _SH_MMCIF_H_ |
| 10 | |
| 11 | struct sh_mmcif_regs { |
| 12 | unsigned long ce_cmd_set; |
| 13 | unsigned long reserved; |
| 14 | unsigned long ce_arg; |
| 15 | unsigned long ce_arg_cmd12; |
| 16 | unsigned long ce_cmd_ctrl; |
| 17 | unsigned long ce_block_set; |
| 18 | unsigned long ce_clk_ctrl; |
| 19 | unsigned long ce_buf_acc; |
| 20 | unsigned long ce_resp3; |
| 21 | unsigned long ce_resp2; |
| 22 | unsigned long ce_resp1; |
| 23 | unsigned long ce_resp0; |
| 24 | unsigned long ce_resp_cmd12; |
| 25 | unsigned long ce_data; |
| 26 | unsigned long reserved2[2]; |
| 27 | unsigned long ce_int; |
| 28 | unsigned long ce_int_mask; |
| 29 | unsigned long ce_host_sts1; |
| 30 | unsigned long ce_host_sts2; |
| 31 | unsigned long reserved3[11]; |
| 32 | unsigned long ce_version; |
| 33 | }; |
| 34 | |
| 35 | /* CE_CMD_SET */ |
| 36 | #define CMD_MASK 0x3f000000 |
| 37 | #define CMD_SET_RTYP_NO ((0 << 23) | (0 << 22)) |
| 38 | /* R1/R1b/R3/R4/R5 */ |
| 39 | #define CMD_SET_RTYP_6B ((0 << 23) | (1 << 22)) |
| 40 | /* R2 */ |
| 41 | #define CMD_SET_RTYP_17B ((1 << 23) | (0 << 22)) |
| 42 | /* R1b */ |
| 43 | #define CMD_SET_RBSY (1 << 21) |
| 44 | #define CMD_SET_CCSEN (1 << 20) |
| 45 | /* 1: on data, 0: no data */ |
| 46 | #define CMD_SET_WDAT (1 << 19) |
| 47 | /* 1: write to card, 0: read from card */ |
| 48 | #define CMD_SET_DWEN (1 << 18) |
| 49 | /* 1: multi block trans, 0: single */ |
| 50 | #define CMD_SET_CMLTE (1 << 17) |
| 51 | /* 1: CMD12 auto issue */ |
| 52 | #define CMD_SET_CMD12EN (1 << 16) |
| 53 | /* index check */ |
| 54 | #define CMD_SET_RIDXC_INDEX ((0 << 15) | (0 << 14)) |
| 55 | /* check bits check */ |
| 56 | #define CMD_SET_RIDXC_BITS ((0 << 15) | (1 << 14)) |
| 57 | /* no check */ |
| 58 | #define CMD_SET_RIDXC_NO ((1 << 15) | (0 << 14)) |
| 59 | /* 1: CRC7 check*/ |
| 60 | #define CMD_SET_CRC7C ((0 << 13) | (0 << 12)) |
| 61 | /* 1: check bits check*/ |
| 62 | #define CMD_SET_CRC7C_BITS ((0 << 13) | (1 << 12)) |
| 63 | /* 1: internal CRC7 check*/ |
| 64 | #define CMD_SET_CRC7C_INTERNAL ((1 << 13) | (0 << 12)) |
| 65 | /* 1: CRC16 check*/ |
| 66 | #define CMD_SET_CRC16C (1 << 10) |
| 67 | /* 1: not receive CRC status */ |
| 68 | #define CMD_SET_CRCSTE (1 << 8) |
| 69 | /* 1: tran mission bit "Low" */ |
| 70 | #define CMD_SET_TBIT (1 << 7) |
| 71 | /* 1: open/drain */ |
| 72 | #define CMD_SET_OPDM (1 << 6) |
| 73 | #define CMD_SET_CCSH (1 << 5) |
| 74 | /* 1bit */ |
| 75 | #define CMD_SET_DATW_1 ((0 << 1) | (0 << 0)) |
| 76 | /* 4bit */ |
| 77 | #define CMD_SET_DATW_4 ((0 << 1) | (1 << 0)) |
| 78 | /* 8bit */ |
| 79 | #define CMD_SET_DATW_8 ((1 << 1) | (0 << 0)) |
| 80 | |
| 81 | /* CE_CMD_CTRL */ |
| 82 | #define CMD_CTRL_BREAK (1 << 0) |
| 83 | |
| 84 | /* CE_BLOCK_SET */ |
| 85 | #define BLOCK_SIZE_MASK 0x0000ffff |
| 86 | |
| 87 | /* CE_CLK_CTRL */ |
| 88 | #define CLK_ENABLE (1 << 24) |
| 89 | #define CLK_CLEAR ((1 << 19) | (1 << 18) | (1 << 17) | (1 << 16)) |
| 90 | #define CLK_PCLK ((1 << 19) | (1 << 18) | (1 << 17) | (1 << 16)) |
| 91 | /* respons timeout */ |
| 92 | #define SRSPTO_256 ((1 << 13) | (0 << 12)) |
| 93 | /* respons busy timeout */ |
| 94 | #define SRBSYTO_29 ((1 << 11) | (1 << 10) | (1 << 9) | (1 << 8)) |
| 95 | /* read/write timeout */ |
| 96 | #define SRWDTO_29 ((1 << 7) | (1 << 6) | (1 << 5) | (1 << 4)) |
| 97 | /* ccs timeout */ |
| 98 | #define SCCSTO_29 ((1 << 3) | (1 << 2) | (1 << 1) | (1 << 0)) |
| 99 | |
| 100 | /* CE_BUF_ACC */ |
| 101 | #define BUF_ACC_DMAWEN (1 << 25) |
| 102 | #define BUF_ACC_DMAREN (1 << 24) |
| 103 | #define BUF_ACC_BUSW_32 (0 << 17) |
| 104 | #define BUF_ACC_BUSW_16 (1 << 17) |
| 105 | #define BUF_ACC_ATYP (1 << 16) |
| 106 | |
| 107 | /* CE_INT */ |
| 108 | #define INT_CCSDE (1 << 29) |
| 109 | #define INT_CMD12DRE (1 << 26) |
| 110 | #define INT_CMD12RBE (1 << 25) |
| 111 | #define INT_CMD12CRE (1 << 24) |
| 112 | #define INT_DTRANE (1 << 23) |
| 113 | #define INT_BUFRE (1 << 22) |
| 114 | #define INT_BUFWEN (1 << 21) |
| 115 | #define INT_BUFREN (1 << 20) |
| 116 | #define INT_CCSRCV (1 << 19) |
| 117 | #define INT_RBSYE (1 << 17) |
| 118 | #define INT_CRSPE (1 << 16) |
| 119 | #define INT_CMDVIO (1 << 15) |
| 120 | #define INT_BUFVIO (1 << 14) |
| 121 | #define INT_WDATERR (1 << 11) |
| 122 | #define INT_RDATERR (1 << 10) |
| 123 | #define INT_RIDXERR (1 << 9) |
| 124 | #define INT_RSPERR (1 << 8) |
| 125 | #define INT_CCSTO (1 << 5) |
| 126 | #define INT_CRCSTO (1 << 4) |
| 127 | #define INT_WDATTO (1 << 3) |
| 128 | #define INT_RDATTO (1 << 2) |
| 129 | #define INT_RBSYTO (1 << 1) |
| 130 | #define INT_RSPTO (1 << 0) |
| 131 | #define INT_ERR_STS (INT_CMDVIO | INT_BUFVIO | INT_WDATERR | \ |
| 132 | INT_RDATERR | INT_RIDXERR | INT_RSPERR | \ |
| 133 | INT_CCSTO | INT_CRCSTO | INT_WDATTO | \ |
| 134 | INT_RDATTO | INT_RBSYTO | INT_RSPTO) |
| 135 | #define INT_START_MAGIC 0xD80430C0 |
| 136 | |
| 137 | /* CE_INT_MASK */ |
| 138 | #define MASK_ALL 0x00000000 |
| 139 | #define MASK_MCCSDE (1 << 29) |
| 140 | #define MASK_MCMD12DRE (1 << 26) |
| 141 | #define MASK_MCMD12RBE (1 << 25) |
| 142 | #define MASK_MCMD12CRE (1 << 24) |
| 143 | #define MASK_MDTRANE (1 << 23) |
| 144 | #define MASK_MBUFRE (1 << 22) |
| 145 | #define MASK_MBUFWEN (1 << 21) |
| 146 | #define MASK_MBUFREN (1 << 20) |
| 147 | #define MASK_MCCSRCV (1 << 19) |
| 148 | #define MASK_MRBSYE (1 << 17) |
| 149 | #define MASK_MCRSPE (1 << 16) |
| 150 | #define MASK_MCMDVIO (1 << 15) |
| 151 | #define MASK_MBUFVIO (1 << 14) |
| 152 | #define MASK_MWDATERR (1 << 11) |
| 153 | #define MASK_MRDATERR (1 << 10) |
| 154 | #define MASK_MRIDXERR (1 << 9) |
| 155 | #define MASK_MRSPERR (1 << 8) |
| 156 | #define MASK_MCCSTO (1 << 5) |
| 157 | #define MASK_MCRCSTO (1 << 4) |
| 158 | #define MASK_MWDATTO (1 << 3) |
| 159 | #define MASK_MRDATTO (1 << 2) |
| 160 | #define MASK_MRBSYTO (1 << 1) |
| 161 | #define MASK_MRSPTO (1 << 0) |
| 162 | |
| 163 | /* CE_HOST_STS1 */ |
| 164 | #define STS1_CMDSEQ (1 << 31) |
| 165 | |
| 166 | /* CE_HOST_STS2 */ |
| 167 | #define STS2_CRCSTE (1 << 31) |
| 168 | #define STS2_CRC16E (1 << 30) |
| 169 | #define STS2_AC12CRCE (1 << 29) |
| 170 | #define STS2_RSPCRC7E (1 << 28) |
| 171 | #define STS2_CRCSTEBE (1 << 27) |
| 172 | #define STS2_RDATEBE (1 << 26) |
| 173 | #define STS2_AC12REBE (1 << 25) |
| 174 | #define STS2_RSPEBE (1 << 24) |
| 175 | #define STS2_AC12IDXE (1 << 23) |
| 176 | #define STS2_RSPIDXE (1 << 22) |
| 177 | #define STS2_CCSTO (1 << 15) |
| 178 | #define STS2_RDATTO (1 << 14) |
| 179 | #define STS2_DATBSYTO (1 << 13) |
| 180 | #define STS2_CRCSTTO (1 << 12) |
| 181 | #define STS2_AC12BSYTO (1 << 11) |
| 182 | #define STS2_RSPBSYTO (1 << 10) |
| 183 | #define STS2_AC12RSPTO (1 << 9) |
| 184 | #define STS2_RSPTO (1 << 8) |
| 185 | |
| 186 | #define STS2_CRC_ERR (STS2_CRCSTE | STS2_CRC16E | \ |
| 187 | STS2_AC12CRCE | STS2_RSPCRC7E | STS2_CRCSTEBE) |
| 188 | #define STS2_TIMEOUT_ERR (STS2_CCSTO | STS2_RDATTO | \ |
| 189 | STS2_DATBSYTO | STS2_CRCSTTO | \ |
| 190 | STS2_AC12BSYTO | STS2_RSPBSYTO | \ |
| 191 | STS2_AC12RSPTO | STS2_RSPTO) |
| 192 | |
| 193 | /* CE_VERSION */ |
| 194 | #define SOFT_RST_ON (1 << 31) |
| 195 | #define SOFT_RST_OFF (0 << 31) |
| 196 | |
| 197 | #define CLKDEV_EMMC_DATA 52000000 /* 52MHz */ |
Marek Vasut | 6468c4c | 2024-02-27 17:05:55 +0100 | [diff] [blame] | 198 | #ifdef CONFIG_ARCH_RENESAS |
Nobuhiro Iwamatsu | 36c6e71 | 2014-12-03 17:57:48 +0900 | [diff] [blame] | 199 | #define MMC_CLK_DIV_MIN(clk) (clk / (1 << 9)) |
| 200 | #define MMC_CLK_DIV_MAX(clk) (clk / (1 << 1)) |
| 201 | #else |
Nobuhiro Iwamatsu | 2fb07ee | 2014-12-03 17:57:01 +0900 | [diff] [blame] | 202 | #define MMC_CLK_DIV_MIN(clk) (clk / (1 << 8)) |
Nobuhiro Iwamatsu | 36c6e71 | 2014-12-03 17:57:48 +0900 | [diff] [blame] | 203 | #define MMC_CLK_DIV_MAX(clk) CLKDEV_EMMC_DATA |
| 204 | #endif |
Yoshihiro Shimoda | db7717b | 2011-07-04 22:21:22 +0000 | [diff] [blame] | 205 | |
| 206 | #define MMC_BUS_WIDTH_1 0 |
| 207 | #define MMC_BUS_WIDTH_4 2 |
| 208 | #define MMC_BUS_WIDTH_8 3 |
| 209 | |
| 210 | struct sh_mmcif_host { |
| 211 | struct mmc_data *data; |
| 212 | struct sh_mmcif_regs *regs; |
| 213 | unsigned int clk; |
| 214 | int bus_width; |
| 215 | u16 wait_int; |
| 216 | u16 sd_error; |
| 217 | u8 last_cmd; |
| 218 | }; |
| 219 | |
| 220 | static inline u32 sh_mmcif_read(unsigned long *reg) |
| 221 | { |
| 222 | return readl(reg); |
| 223 | } |
| 224 | |
| 225 | static inline void sh_mmcif_write(u32 val, unsigned long *reg) |
| 226 | { |
| 227 | writel(val, reg); |
| 228 | } |
| 229 | |
| 230 | static inline void sh_mmcif_bitset(u32 val, unsigned long *reg) |
| 231 | { |
| 232 | sh_mmcif_write(val | sh_mmcif_read(reg), reg); |
| 233 | } |
| 234 | |
| 235 | static inline void sh_mmcif_bitclr(u32 val, unsigned long *reg) |
| 236 | { |
| 237 | sh_mmcif_write(~val & sh_mmcif_read(reg), reg); |
| 238 | } |
| 239 | |
| 240 | #endif /* _SH_MMCIF_H_ */ |