|  | /* | 
|  | * MMCIF driver. | 
|  | * | 
|  | * Copyright (C)  2011 Renesas Solutions Corp. | 
|  | * | 
|  | * This program is free software; you can redistribute it and/or modify | 
|  | * it under the terms of the GNU General Public License as published by | 
|  | * the Free Software Foundation; either version 2 of the License. | 
|  | * | 
|  | */ | 
|  |  | 
|  | #ifndef _SH_MMCIF_H_ | 
|  | #define _SH_MMCIF_H_ | 
|  |  | 
|  | struct sh_mmcif_regs { | 
|  | unsigned long ce_cmd_set; | 
|  | unsigned long reserved; | 
|  | unsigned long ce_arg; | 
|  | unsigned long ce_arg_cmd12; | 
|  | unsigned long ce_cmd_ctrl; | 
|  | unsigned long ce_block_set; | 
|  | unsigned long ce_clk_ctrl; | 
|  | unsigned long ce_buf_acc; | 
|  | unsigned long ce_resp3; | 
|  | unsigned long ce_resp2; | 
|  | unsigned long ce_resp1; | 
|  | unsigned long ce_resp0; | 
|  | unsigned long ce_resp_cmd12; | 
|  | unsigned long ce_data; | 
|  | unsigned long reserved2[2]; | 
|  | unsigned long ce_int; | 
|  | unsigned long ce_int_mask; | 
|  | unsigned long ce_host_sts1; | 
|  | unsigned long ce_host_sts2; | 
|  | unsigned long reserved3[11]; | 
|  | unsigned long ce_version; | 
|  | }; | 
|  |  | 
|  | /* CE_CMD_SET */ | 
|  | #define CMD_MASK		0x3f000000 | 
|  | #define CMD_SET_RTYP_NO		((0 << 23) | (0 << 22)) | 
|  | /* R1/R1b/R3/R4/R5 */ | 
|  | #define CMD_SET_RTYP_6B		((0 << 23) | (1 << 22)) | 
|  | /* R2 */ | 
|  | #define CMD_SET_RTYP_17B	((1 << 23) | (0 << 22)) | 
|  | /* R1b */ | 
|  | #define CMD_SET_RBSY		(1 << 21) | 
|  | #define CMD_SET_CCSEN		(1 << 20) | 
|  | /* 1: on data, 0: no data */ | 
|  | #define CMD_SET_WDAT		(1 << 19) | 
|  | /* 1: write to card, 0: read from card */ | 
|  | #define CMD_SET_DWEN		(1 << 18) | 
|  | /* 1: multi block trans, 0: single */ | 
|  | #define CMD_SET_CMLTE		(1 << 17) | 
|  | /* 1: CMD12 auto issue */ | 
|  | #define CMD_SET_CMD12EN		(1 << 16) | 
|  | /* index check */ | 
|  | #define CMD_SET_RIDXC_INDEX	((0 << 15) | (0 << 14)) | 
|  | /* check bits check */ | 
|  | #define CMD_SET_RIDXC_BITS	((0 << 15) | (1 << 14)) | 
|  | /* no check */ | 
|  | #define CMD_SET_RIDXC_NO	((1 << 15) | (0 << 14)) | 
|  | /* 1: CRC7 check*/ | 
|  | #define CMD_SET_CRC7C		((0 << 13) | (0 << 12)) | 
|  | /* 1: check bits check*/ | 
|  | #define CMD_SET_CRC7C_BITS	((0 << 13) | (1 << 12)) | 
|  | /* 1: internal CRC7 check*/ | 
|  | #define CMD_SET_CRC7C_INTERNAL	((1 << 13) | (0 << 12)) | 
|  | /* 1: CRC16 check*/ | 
|  | #define CMD_SET_CRC16C		(1 << 10) | 
|  | /* 1: not receive CRC status */ | 
|  | #define CMD_SET_CRCSTE		(1 << 8) | 
|  | /* 1: tran mission bit "Low" */ | 
|  | #define CMD_SET_TBIT		(1 << 7) | 
|  | /* 1: open/drain */ | 
|  | #define CMD_SET_OPDM		(1 << 6) | 
|  | #define CMD_SET_CCSH		(1 << 5) | 
|  | /* 1bit */ | 
|  | #define CMD_SET_DATW_1		((0 << 1) | (0 << 0)) | 
|  | /* 4bit */ | 
|  | #define CMD_SET_DATW_4		((0 << 1) | (1 << 0)) | 
|  | /* 8bit */ | 
|  | #define CMD_SET_DATW_8		((1 << 1) | (0 << 0)) | 
|  |  | 
|  | /* CE_CMD_CTRL */ | 
|  | #define CMD_CTRL_BREAK		(1 << 0) | 
|  |  | 
|  | /* CE_BLOCK_SET */ | 
|  | #define BLOCK_SIZE_MASK		0x0000ffff | 
|  |  | 
|  | /* CE_CLK_CTRL */ | 
|  | #define CLK_ENABLE		(1 << 24) | 
|  | #define CLK_CLEAR		((1 << 19) | (1 << 18) | (1 << 17) | (1 << 16)) | 
|  | #define CLK_PCLK		((1 << 19) | (1 << 18) | (1 << 17) | (1 << 16)) | 
|  | /* respons timeout */ | 
|  | #define SRSPTO_256		((1 << 13) | (0 << 12)) | 
|  | /* respons busy timeout */ | 
|  | #define SRBSYTO_29		((1 << 11) | (1 << 10) | (1 << 9) | (1 << 8)) | 
|  | /* read/write timeout */ | 
|  | #define SRWDTO_29		((1 << 7) | (1 << 6) | (1 << 5) | (1 << 4)) | 
|  | /* ccs timeout */ | 
|  | #define SCCSTO_29		((1 << 3) | (1 << 2) | (1 << 1) | (1 << 0)) | 
|  |  | 
|  | /* CE_BUF_ACC */ | 
|  | #define BUF_ACC_DMAWEN		(1 << 25) | 
|  | #define BUF_ACC_DMAREN		(1 << 24) | 
|  | #define BUF_ACC_BUSW_32		(0 << 17) | 
|  | #define BUF_ACC_BUSW_16		(1 << 17) | 
|  | #define BUF_ACC_ATYP		(1 << 16) | 
|  |  | 
|  | /* CE_INT */ | 
|  | #define INT_CCSDE		(1 << 29) | 
|  | #define INT_CMD12DRE		(1 << 26) | 
|  | #define INT_CMD12RBE		(1 << 25) | 
|  | #define INT_CMD12CRE		(1 << 24) | 
|  | #define INT_DTRANE		(1 << 23) | 
|  | #define INT_BUFRE		(1 << 22) | 
|  | #define INT_BUFWEN		(1 << 21) | 
|  | #define INT_BUFREN		(1 << 20) | 
|  | #define INT_CCSRCV		(1 << 19) | 
|  | #define INT_RBSYE		(1 << 17) | 
|  | #define INT_CRSPE		(1 << 16) | 
|  | #define INT_CMDVIO		(1 << 15) | 
|  | #define INT_BUFVIO		(1 << 14) | 
|  | #define INT_WDATERR		(1 << 11) | 
|  | #define INT_RDATERR		(1 << 10) | 
|  | #define INT_RIDXERR		(1 << 9) | 
|  | #define INT_RSPERR		(1 << 8) | 
|  | #define INT_CCSTO		(1 << 5) | 
|  | #define INT_CRCSTO		(1 << 4) | 
|  | #define INT_WDATTO		(1 << 3) | 
|  | #define INT_RDATTO		(1 << 2) | 
|  | #define INT_RBSYTO		(1 << 1) | 
|  | #define INT_RSPTO		(1 << 0) | 
|  | #define INT_ERR_STS		(INT_CMDVIO | INT_BUFVIO | INT_WDATERR |  \ | 
|  | INT_RDATERR | INT_RIDXERR | INT_RSPERR | \ | 
|  | INT_CCSTO | INT_CRCSTO | INT_WDATTO |	  \ | 
|  | INT_RDATTO | INT_RBSYTO | INT_RSPTO) | 
|  | #define INT_START_MAGIC		0xD80430C0 | 
|  |  | 
|  | /* CE_INT_MASK */ | 
|  | #define MASK_ALL		0x00000000 | 
|  | #define MASK_MCCSDE		(1 << 29) | 
|  | #define MASK_MCMD12DRE		(1 << 26) | 
|  | #define MASK_MCMD12RBE		(1 << 25) | 
|  | #define MASK_MCMD12CRE		(1 << 24) | 
|  | #define MASK_MDTRANE		(1 << 23) | 
|  | #define MASK_MBUFRE		(1 << 22) | 
|  | #define MASK_MBUFWEN		(1 << 21) | 
|  | #define MASK_MBUFREN		(1 << 20) | 
|  | #define MASK_MCCSRCV		(1 << 19) | 
|  | #define MASK_MRBSYE		(1 << 17) | 
|  | #define MASK_MCRSPE		(1 << 16) | 
|  | #define MASK_MCMDVIO		(1 << 15) | 
|  | #define MASK_MBUFVIO		(1 << 14) | 
|  | #define MASK_MWDATERR		(1 << 11) | 
|  | #define MASK_MRDATERR		(1 << 10) | 
|  | #define MASK_MRIDXERR		(1 << 9) | 
|  | #define MASK_MRSPERR		(1 << 8) | 
|  | #define MASK_MCCSTO		(1 << 5) | 
|  | #define MASK_MCRCSTO		(1 << 4) | 
|  | #define MASK_MWDATTO		(1 << 3) | 
|  | #define MASK_MRDATTO		(1 << 2) | 
|  | #define MASK_MRBSYTO		(1 << 1) | 
|  | #define MASK_MRSPTO		(1 << 0) | 
|  |  | 
|  | /* CE_HOST_STS1 */ | 
|  | #define STS1_CMDSEQ		(1 << 31) | 
|  |  | 
|  | /* CE_HOST_STS2 */ | 
|  | #define STS2_CRCSTE		(1 << 31) | 
|  | #define STS2_CRC16E		(1 << 30) | 
|  | #define STS2_AC12CRCE		(1 << 29) | 
|  | #define STS2_RSPCRC7E		(1 << 28) | 
|  | #define STS2_CRCSTEBE		(1 << 27) | 
|  | #define STS2_RDATEBE		(1 << 26) | 
|  | #define STS2_AC12REBE		(1 << 25) | 
|  | #define STS2_RSPEBE		(1 << 24) | 
|  | #define STS2_AC12IDXE		(1 << 23) | 
|  | #define STS2_RSPIDXE		(1 << 22) | 
|  | #define STS2_CCSTO		(1 << 15) | 
|  | #define STS2_RDATTO		(1 << 14) | 
|  | #define STS2_DATBSYTO		(1 << 13) | 
|  | #define STS2_CRCSTTO		(1 << 12) | 
|  | #define STS2_AC12BSYTO		(1 << 11) | 
|  | #define STS2_RSPBSYTO		(1 << 10) | 
|  | #define STS2_AC12RSPTO		(1 << 9) | 
|  | #define STS2_RSPTO		(1 << 8) | 
|  |  | 
|  | #define STS2_CRC_ERR		(STS2_CRCSTE | STS2_CRC16E |		\ | 
|  | STS2_AC12CRCE | STS2_RSPCRC7E | STS2_CRCSTEBE) | 
|  | #define STS2_TIMEOUT_ERR	(STS2_CCSTO | STS2_RDATTO |		\ | 
|  | STS2_DATBSYTO | STS2_CRCSTTO |		\ | 
|  | STS2_AC12BSYTO | STS2_RSPBSYTO |	\ | 
|  | STS2_AC12RSPTO | STS2_RSPTO) | 
|  |  | 
|  | /* CE_VERSION */ | 
|  | #define SOFT_RST_ON		(1 << 31) | 
|  | #define SOFT_RST_OFF		(0 << 31) | 
|  |  | 
|  | #define CLKDEV_EMMC_DATA	52000000	/* 52MHz */ | 
|  | #define	CLKDEV_MMC_INIT		400000		/* 100 - 400 KHz */ | 
|  |  | 
|  | #define MMC_BUS_WIDTH_1		0 | 
|  | #define MMC_BUS_WIDTH_4		2 | 
|  | #define MMC_BUS_WIDTH_8		3 | 
|  |  | 
|  | struct sh_mmcif_host { | 
|  | struct mmc_data		*data; | 
|  | struct sh_mmcif_regs	*regs; | 
|  | unsigned int		clk; | 
|  | int			bus_width; | 
|  | u16			wait_int; | 
|  | u16			sd_error; | 
|  | u8			last_cmd; | 
|  | }; | 
|  |  | 
|  | static inline u32 sh_mmcif_read(unsigned long *reg) | 
|  | { | 
|  | return readl(reg); | 
|  | } | 
|  |  | 
|  | static inline void sh_mmcif_write(u32 val, unsigned long *reg) | 
|  | { | 
|  | writel(val, reg); | 
|  | } | 
|  |  | 
|  | static inline void sh_mmcif_bitset(u32 val, unsigned long *reg) | 
|  | { | 
|  | sh_mmcif_write(val | sh_mmcif_read(reg), reg); | 
|  | } | 
|  |  | 
|  | static inline void sh_mmcif_bitclr(u32 val, unsigned long *reg) | 
|  | { | 
|  | sh_mmcif_write(~val & sh_mmcif_read(reg), reg); | 
|  | } | 
|  |  | 
|  | #endif /* _SH_MMCIF_H_ */ |