nt9856x/rtos/BSP/u-boot/drivers/mmc/nvt_ivot_mmc.h
2023-03-28 15:07:53 +08:00

328 lines
14 KiB
C
Executable File

/*
* driver/mmc/nvt_ivot_mmc.h
*
* Author: Howard Chang
* Created: April 8, 2016
* Copyright: Novatek Inc.
*
*/
#ifndef __NVT_IVOT_MMC_H__
#define __NVT_IVOT_MMC_H__
#include "nvt_ivot_mmcreg.h"
int nvt_mmc_init(int id);
#define CLK_26M (26000000)
#define CLK_52M (52000000)
#define CLK_200M (200000000)
#define CLK_100M (100000000)
#if (defined(CONFIG_TARGET_NA51090_A64) || defined(CONFIG_TARGET_NA51102_A64) || defined(CONFIG_TARGET_NA51103_A64))
#define PIN_SDIO_CFG_1ST_PINMUX 0x02
#define PIN_SDIO2_CFG_1ST_PINMUX 0x10
#define PIN_SDIO2_CFG_BUS_WIDTH 0x20
#define PIN_SDIO2_CFG_DS 0x40
#else
#define PIN_SDIO_CFG_8BITS 0x02 /*8 bits wide*/
#define PIN_SDIO_CFG_2ND_PINMUX 0x10 /*2nd pinmux location*/
#define PIN_SDIO_CFG_3RD_PINMUX 0x20 /*3rd pinmux location*/
#endif
#define BIT(nr) (1UL << (nr))
#if (defined(CONFIG_TARGET_NA51090_A64) || defined(CONFIG_TARGET_NA51102_A64) || defined(CONFIG_TARGET_NA51103_A64))
#define PAD_PUPD0_REG_OFS 0x00
#define PAD_REG_TO_BASE(reg) (((reg)/(4))*(32))
#define PAD_DS_CGPIO_BASE PAD_REG_TO_BASE(0x50) // 0x50~0x54
#define PAD_DS_PGPIO_BASE PAD_REG_TO_BASE(0x60) // 0x60~0x74
#define PAD_DS_CGPIO2 (PAD_DS_CGPIO_BASE + 8) ///< C_GPIO_2
#define PAD_DS_CGPIO3 (PAD_DS_CGPIO_BASE + 12) ///< C_GPIO_3
#define PAD_DS_CGPIO4 (PAD_DS_CGPIO_BASE + 16) ///< C_GPIO_4
#define PAD_DS_CGPIO5 (PAD_DS_CGPIO_BASE + 20) ///< C_GPIO_5
#define PAD_DS_CGPIO8 (PAD_DS_CGPIO_BASE + 32) ///< C_GPIO_8
#define PAD_DS_CGPIO9 (PAD_DS_CGPIO_BASE + 36) ///< C_GPIO_9
#define PAD_DS_CGPIO10 (PAD_DS_CGPIO_BASE + 40) ///< C_GPIO_10
#define PAD_DS_CGPIO11 (PAD_DS_CGPIO_BASE + 44) ///< C_GPIO_11
#define PAD_DS_CGPIO12 (PAD_DS_CGPIO_BASE + 48) ///< C_GPIO_12
#define PAD_DS_CGPIO13 (PAD_DS_CGPIO_BASE + 52) ///< C_GPIO_13
#define PAD_DS_PGPIO12 (PAD_DS_PGPIO_BASE + 48) ///< P_GPIO_12
#define PAD_DS_PGPIO13 (PAD_DS_PGPIO_BASE + 52) ///< P_GPIO_13
#define PAD_DS_PGPIO15 (PAD_DS_PGPIO_BASE + 60) ///< P_GPIO_15
#define PAD_DS_PGPIO16 (PAD_DS_PGPIO_BASE + 64) ///< P_GPIO_16
#define PAD_DS_PGPIO17 (PAD_DS_PGPIO_BASE + 68) ///< P_GPIO_17
#define PAD_DS_PGPIO18 (PAD_DS_PGPIO_BASE + 72) ///< P_GPIO_18
#else
#define PAD_PUPD0_REG_OFS 0x00
#define PAD_PUPD1_REG_OFS 0x04
#define PAD_PUPD2_REG_OFS 0x08
#define PAD_PUPD3_REG_OFS 0x0C
#define PAD_PUPD4_REG_OFS 0x10
#define PAD_PUPD5_REG_OFS 0x14
#define PAD_PUPD6_REG_OFS 0x18
#define PAD_PUPD7_REG_OFS 0x1C
#define PAD_PUPD8_REG_OFS 0x20
#define PAD_PUPD9_REG_OFS 0x24
#define PAD_DS_REG_OFS 0x40
#define PAD_DS1_REG_OFS 0x44
#define PAD_DS2_REG_OFS 0x48
#define PAD_DS3_REG_OFS 0x4C
#define PAD_DS4_REG_OFS 0x50
#define PAD_DS5_REG_OFS 0x54
#define PAD_DS6_REG_OFS 0x58
#define PAD_DS7_REG_OFS 0x5C
#define PAD_DS8_REG_OFS 0x60
#define PAD_DS9_REG_OFS 0x64
#define PAD_DS10_REG_OFS 0x68
#define PAD_DS11_REG_OFS 0x90
#define PAD_DS_GPIO_BASE_MASK 0xFFFF
#define PAD_DS_GROUP_10_MSK 0x0003
#define PAD_DS_GROUP_16_MSK 0x0030
#define PAD_DS_GROUP_40_MSK 0xFF00
#define PAD_DS_GROUP_COMBO_MSK 0xFFFFF
#define PAD_DS_CGPIO_BASE 0
#define PAD_DS_HGPIO_BASE 320
#define PAD_DS_GROUP_10 0x00000000
#define PAD_DS_GROUP_16 0x10000000
#define PAD_DS_GROUP_40 0x80000000
#define PAD_DS_GROUP_MASK 0xF0000000
#ifdef CONFIG_TARGET_NA51089
#define PAD_DS_CGPIO0 ((PAD_DS_CGPIO_BASE + 0) | PAD_DS_GROUP_16)
#define PAD_DS_CGPIO1 ((PAD_DS_CGPIO_BASE + 2) | PAD_DS_GROUP_16)
#define PAD_DS_CGPIO2 ((PAD_DS_CGPIO_BASE + 4) | PAD_DS_GROUP_16)
#define PAD_DS_CGPIO3 ((PAD_DS_CGPIO_BASE + 6) | PAD_DS_GROUP_16)
#define PAD_DS_CGPIO4 ((PAD_DS_CGPIO_BASE + 8) | PAD_DS_GROUP_16)
#define PAD_DS_CGPIO5 ((PAD_DS_CGPIO_BASE + 10) | PAD_DS_GROUP_16)
#define PAD_DS_CGPIO6 ((PAD_DS_CGPIO_BASE + 12) | PAD_DS_GROUP_16)
#define PAD_DS_CGPIO7 ((PAD_DS_CGPIO_BASE + 14) | PAD_DS_GROUP_16)
#define PAD_DS_CGPIO8 ((PAD_DS_CGPIO_BASE + 16) | PAD_DS_GROUP_16)
#define PAD_DS_CGPIO9 ((PAD_DS_CGPIO_BASE + 18) | PAD_DS_GROUP_16)
#else
#define PAD_DS_CGPIO0 ((PAD_DS_CGPIO_BASE + 0) | PAD_DS_GROUP_10)
#define PAD_DS_CGPIO1 ((PAD_DS_CGPIO_BASE + 2) | PAD_DS_GROUP_10)
#define PAD_DS_CGPIO2 ((PAD_DS_CGPIO_BASE + 4) | PAD_DS_GROUP_10)
#define PAD_DS_CGPIO3 ((PAD_DS_CGPIO_BASE + 6) | PAD_DS_GROUP_10)
#define PAD_DS_CGPIO4 ((PAD_DS_CGPIO_BASE + 8) | PAD_DS_GROUP_10)
#define PAD_DS_CGPIO5 ((PAD_DS_CGPIO_BASE + 10) | PAD_DS_GROUP_10)
#define PAD_DS_CGPIO6 ((PAD_DS_CGPIO_BASE + 12) | PAD_DS_GROUP_10)
#define PAD_DS_CGPIO7 ((PAD_DS_CGPIO_BASE + 14) | PAD_DS_GROUP_10)
#define PAD_DS_CGPIO8 ((PAD_DS_CGPIO_BASE + 16) | PAD_DS_GROUP_16)
#define PAD_DS_CGPIO9 ((PAD_DS_CGPIO_BASE + 18) | PAD_DS_GROUP_10)
#endif
#define PAD_DS_CGPIO11 ((PAD_DS_CGPIO_BASE + 0) | PAD_DS_GROUP_40)
#define PAD_DS_CGPIO12 ((PAD_DS_CGPIO_BASE + 4) | PAD_DS_GROUP_40)
#define PAD_DS_CGPIO13 ((PAD_DS_CGPIO_BASE + 8) | PAD_DS_GROUP_40)
#define PAD_DS_CGPIO14 ((PAD_DS_CGPIO_BASE + 12) | PAD_DS_GROUP_40)
#define PAD_DS_CGPIO15 ((PAD_DS_CGPIO_BASE + 16) | PAD_DS_GROUP_40)
#define PAD_DS_CGPIO16 ((PAD_DS_CGPIO_BASE + 20) | PAD_DS_GROUP_40)
#define PAD_DS_CGPIO17 ((PAD_DS_CGPIO_BASE + 24) | PAD_DS_GROUP_40)
#define PAD_DS_CGPIO18 ((PAD_DS_CGPIO_BASE + 36) | PAD_DS_GROUP_16)
#define PAD_DS_CGPIO19 ((PAD_DS_CGPIO_BASE + 38) | PAD_DS_GROUP_16)
#define PAD_DS_CGPIO20 ((PAD_DS_CGPIO_BASE + 40) | PAD_DS_GROUP_16)
#define PAD_DS_CGPIO21 ((PAD_DS_CGPIO_BASE + 42) | PAD_DS_GROUP_16)
#define PAD_DS_CGPIO22 ((PAD_DS_CGPIO_BASE + 44) | PAD_DS_GROUP_16)
#define PAD_DS_HSIGPIO0 ((PAD_DS_HGPIO_BASE + 0) | PAD_DS_GROUP_10)
#define PAD_DRIVINGSINK_4MA 0x0001 ///< Pad driver/sink 4mA
#define PAD_DRIVINGSINK_10MA 0x0202 ///< Pad driver/sink 10mA
#define PAD_DRIVINGSINK_6MA 0x0010 ///< Pad driver/sink 6mA
#define PAD_DRIVINGSINK_16MA 0x0020 ///< Pad driver/sink 16mA
#define PAD_DRIVINGSINK_5MA 0x0100 ///< Pad driver/sink 5mA
#define PAD_DRIVINGSINK_15MA 0x0400 ///< Pad driver/sink 15mA
#define PAD_DRIVINGSINK_20MA 0x0800 ///< Pad driver/sink 20mA
#define PAD_DRIVINGSINK_25MA 0x1000 ///< Pad driver/sink 25mA
#define PAD_DRIVINGSINK_30MA 0x2000 ///< Pad driver/sink 30mA
#define PAD_DRIVINGSINK_35MA 0x4000 ///< Pad driver/sink 35mA
#define PAD_DRIVINGSINK_40MA 0x8000 ///< Pad driver/sink 40mA
#define PAD_DRIVINGSINK_8MA 0x10000 ///< Pad driver/sink 8mA
#define PAD_DRIVINGSINK_12MA 0x20000 ///< Pad driver/sink 12mA
#endif
#define SDIO_HOST_WRITE_DATA (FALSE)
#define SDIO_HOST_READ_DATA (TRUE)
enum SDIO_MODE_DRIVING {
SDIO_DS_MODE_CLK = 0,
SDIO_DS_MODE_CMD,
SDIO_DS_MODE_DATA,
SDIO_HS_MODE_CLK,
SDIO_HS_MODE_CMD,
SDIO_HS_MODE_DATA,
SDIO_SDR50_MODE_CLK,
SDIO_SDR50_MODE_CMD,
SDIO_SDR50_MODE_DATA,
SDIO_SDR104_MODE_CLK,
SDIO_SDR104_MODE_CMD,
SDIO_SDR104_MODE_DATA,
SDIO_MAX_MODE_DRIVING,
};
struct mmc_nvt_host {
struct mmc_cmd *cmd;
struct mmc_data *data;
u32 mmc_input_clk;
u32 mmc_default_clk;
void __iomem *base;
struct resource *mem_res;
int id;
unsigned char bus_mode;
unsigned char data_dir;
unsigned char suspended;
/* buffer is used during PIO of one scatterlist segment, and
* is updated along with buffer_bytes_left. bytes_left applies
* to all N blocks of the PIO transfer.
*/
u8 *buffer;
u32 buffer_bytes_left;
u32 bytes_left;
bool do_dma;
/*early data*/
bool data_early;
u32 pad_driving[SDIO_MAX_MODE_DRIVING];
u32 pinmux_value;
int enable_8bits;
u32 ext_caps;
/* Version of the MMC/SD controller */
u8 version;
/* for ns in one cycle calculation */
unsigned ns_in_one_cycle;
int indly_sel;
};
/*
SDIO send command execution result.
Encoding of sdiohost_sendcmd() result.
*/
#define SDIO_HOST_CMD_OK (0) /* command execution OK*/
#define SDIO_HOST_RSP_TIMEOUT (-1) /* response timeout*/
#define SDIO_HOST_RSP_CRCFAIL (-2) /* response CRC fail*/
#define SDIO_HOST_CMD_FAIL (-3) /* command fail*/
/*
SDIO data transfer result.
Encoding of sdiohost_waitdataend() result.
*/
#define SDIO_HOST_DATA_OK (0) /* data transfer OK*/
#define SDIO_HOST_DATA_TIMEOUT (-1) /* data block timeout*/
#define SDIO_HOST_DATA_CRCFAIL (-2) /* data block CRC fail*/
#define SDIO_HOST_DATA_FAIL (-3) /* data transfer fail*/
#define SDIO_HOST_BOOT_ACK_OK (0)
#define SDIO_HOST_BOOT_ACK_TIMEOUT (-1)
#define SDIO_HOST_BOOT_ACK_ERROR (-2)
#define SDIO_HOST_BOOT_END (0)
#define SDIO_HOST_BOOT_END_ERROR (-1)
/*
SDIO response type
@note for sdiohost_sendcmd()
*/
typedef enum {
SDIO_HOST_RSP_NONE, /* No response*/
SDIO_HOST_RSP_SHORT, /* Short response*/
SDIO_HOST_RSP_LONG, /* Long response*/
SDIO_HOST_RSP_SHORT_TYPE2, /* Short response timeout is 5 bus clock*/
SDIO_HOST_RSP_LONG_TYPE2, /* Long response timeout is 5 bus clock*/
SDIO_HOST_RSP_VOLT_DETECT, /* voltage detect response*/
ENUM_DUMMY4WORD(SDIO_HOST_RESPONSE)
} SDIO_HOST_RESPONSE;
#define SDIO_HOST_MAX_VOLT_TIMER (0xFFF) /* max value of voltage switch timer*/
#define SDIO_DES_TABLE_NUM (128)
#define SDIO_DES_WORD_SIZE (3) /*descriptor 3 word*/
#define SDIO_HOST_MAX_DATA_LENGTH (64*1024*1024)
#if (defined(CONFIG_TARGET_NA51090) || defined(CONFIG_TARGET_NA51090_A64) || defined(CONFIG_TARGET_NA51102) || defined(CONFIG_TARGET_NA51102_A64) || defined(CONFIG_TARGET_NA51103) || defined(CONFIG_TARGET_NA51103_A64))
#define SDIO_HOST_DATA_FIFO_DEPTH (32)
#else
#define SDIO_HOST_DATA_FIFO_DEPTH (16)
#endif
/*sdio_protocol.h*/
#define SDIO_HOST_WRITE_DATA (FALSE)
#define SDIO_HOST_READ_DATA (TRUE)
/* Command Register Bit*/
#define SDIO_CMD_REG_INDEX 0x0000003F /* bit 5..0*/
#define SDIO_CMD_REG_NEED_RSP 0x00000040 /* bit 6*/
#define SDIO_CMD_REG_LONG_RSP 0x000000C0 /* bit 7*/
#define SDIO_CMD_REG_RSP_TYPE2 0x00000100 /* bit 8*/
#define SDIO_CMD_REG_APP_CMD 0x00000000 /* bit x*/
#define SDIO_CMD_REG_ABORT 0x00000800 /* bit 11*/
#define SDIO_CMD_REG_VOLTAGE_SWITCH_DETECT 0x00001000 /* bit 12*/
/* Status/Interrupt Mask Register Bit*/
#define SDIO_STATUS_REG_RSP_CRC_FAIL 0x00000001 /* bit 0*/
#define SDIO_STATUS_REG_DATA_CRC_FAIL 0x00000002 /* bit 1*/
#define SDIO_STATUS_REG_RSP_TIMEOUT 0x00000004 /* bit 2*/
#define SDIO_STATUS_REG_DATA_TIMEOUT 0x00000008 /* bit 3*/
#define SDIO_STATUS_REG_RSP_CRC_OK 0x00000010 /* bit 4*/
#define SDIO_STATUS_REG_DATA_CRC_OK 0x00000020 /* bit 5*/
#define SDIO_STATUS_REG_CMD_SEND 0x00000040 /* bit 6*/
#define SDIO_STATUS_REG_DATA_END 0x00000080 /* bit 7*/
#define SDIO_STATUS_REG_INT 0x00000100 /* bit 8*/
#define SDIO_STATUS_REG_READWAIT 0x00000200 /* bit 9*/
#define SDIO_STATUS_REG_EMMC_BOOTACKREV 0x00008000 /* bit 15*/
#define SDIO_STATUS_REG_EMMC_BOOTACKTOUT 0x00010000 /* bit 16*/
#define SDIO_STATUS_REG_EMMC_BOOTEND 0x00020000 /* bit 17*/
#define SDIO_STATUS_REG_EMMC_BOOTACKERR 0x00040000 /* bit 18*/
#define SDIO_STATUS_REG_DMA_ERR 0x00080000 /* bit 19*/
#define SDIO_INTMASK_ALL 0x000003FF /* bit 9..0*/
/* Bus Width Register bit definition*/
#define SDIO_BUS_WIDTH1 0x0 /* bit 1..0*/
#define SDIO_BUS_WIDTH4 0x1 /* bit 1..0*/
#define SDIO_BUS_WIDTH8 0x2 /* bit 1..0*/
#define MMCST_RSP_CRC_FAIL BIT(0)
#define MMCST_DATA_CRC_FAIL BIT(1)
#define MMCST_RSP_TIMEOUT BIT(2)
#define MMCST_DATA_TIMEOUT BIT(3)
#define MMCST_RSP_CRC_OK BIT(4)
#define MMCST_DATA_CRC_OK BIT(5)
#define MMCST_CMD_SENT BIT(6)
#define MMCST_DATA_END BIT(7)
#define MMCST_SDIO_INT BIT(8)
#define MMCST_READ_WAIT BIT(9)
#define MMCST_CARD_BUSY2READY BIT(10)
#define MMCST_VOL_SWITCH_END BIT(11)
#define MMCST_VOL_SWITCH_TIMEOUT BIT(12)
#define MMCST_RSP_VOL_SWITCH_FAIL BIT(13)
#define MMCST_VOL_SWITCH_GLITCH BIT(14)
#define MMCST_EMMC_BOOT_ACK_RECEIVE BIT(15)
#define MMCST_EMMC_BOOT_ACK_TIMEOUT BIT(16)
#define MMCST_EMMC_BOOT_END BIT(17)
#define MMCST_EMMC_BOOT_ACK_ERROR BIT(18)
#define MMCST_DMA_ERROR BIT(19)
#define SDIO_HOST_ID_1 0
#define SDIO_HOST_ID_2 1
#define SDIO_HOST_ID_3 2
typedef enum {
SDIO_MODE_DS = 25000000,
SDIO_MODE_HS = 50000000,
SDIO_MODE_SDR50 = 100000000,
SDIO_MODE_SDR104 = 208000000,
ENUM_DUMMY4WORD(SDIO_SPEED_MODE)
} SDIO_SPEED_MODE;
#endif