/* SPDX-License-Identifier: GPL-2.0-or-later */
/* Driver for Realtek PCI-Express card reader
*
* Copyright(c) 2009-2013 Realtek Semiconductor Corp. All rights reserved.
*
* Author:
* Wei WANG <wei_wang@realsil.com.cn>
*/
#ifndef __RTSX_PCI_H
#define __RTSX_PCI_H
#include <linux/sched.h>
#include <linux/pci.h>
#include <linux/rtsx_common.h>
#define MAX_RW_REG_CNT 1024
#define RTSX_HCBAR 0 x00
#define RTSX_HCBCTLR 0 x04
#define STOP_CMD (0 x01 << 28 )
#define READ_REG_CMD 0
#define WRITE_REG_CMD 1
#define CHECK_REG_CMD 2
#define RTSX_HDBAR 0 x08
#define RTSX_SG_INT 0 x04
#define RTSX_SG_END 0 x02
#define RTSX_SG_VALID 0 x01
#define RTSX_SG_NO_OP 0 x00
#define RTSX_SG_TRANS_DATA (0 x02 << 4 )
#define RTSX_SG_LINK_DESC (0 x03 << 4 )
#define RTSX_HDBCTLR 0 x0C
#define SDMA_MODE 0 x00
#define ADMA_MODE (0 x02 << 26 )
#define STOP_DMA (0 x01 << 28 )
#define TRIG_DMA (0 x01 << 31 )
#define RTSX_HAIMR 0 x10
#define HAIMR_TRANS_START (0 x01 << 31 )
#define HAIMR_READ 0 x00
#define HAIMR_WRITE (0 x01 << 30 )
#define HAIMR_READ_START (HAIMR_TRANS_START | HAIMR_READ)
#define HAIMR_WRITE_START (HAIMR_TRANS_START | HAIMR_WRITE)
#define HAIMR_TRANS_END (HAIMR_TRANS_START)
#define RTSX_BIPR 0 x14
#define CMD_DONE_INT (1 << 31 )
#define DATA_DONE_INT (1 << 30 )
#define TRANS_OK_INT (1 << 29 )
#define TRANS_FAIL_INT (1 << 28 )
#define XD_INT (1 << 27 )
#define MS_INT (1 << 26 )
#define SD_INT (1 << 25 )
#define GPIO0_INT (1 << 24 )
#define OC_INT (1 << 23 )
#define SD_WRITE_PROTECT (1 << 19 )
#define XD_EXIST (1 << 18 )
#define MS_EXIST (1 << 17 )
#define SD_EXIST (1 << 16 )
#define DELINK_INT GPIO0_INT
#define MS_OC_INT (1 << 23 )
#define SD_OVP_INT (1 << 23 )
#define SD_OC_INT (1 << 22 )
#define CARD_INT (XD_INT | MS_INT | SD_INT)
#define NEED_COMPLETE_INT (DATA_DONE_INT | TRANS_OK_INT | TRANS_FAIL_INT)
#define RTSX_INT (CMD_DONE_INT | NEED_COMPLETE_INT | \
CARD_INT | GPIO0_INT | OC_INT)
#define CARD_EXIST (XD_EXIST | MS_EXIST | SD_EXIST)
#define RTSX_BIER 0 x18
#define CMD_DONE_INT_EN (1 << 31 )
#define DATA_DONE_INT_EN (1 << 30 )
#define TRANS_OK_INT_EN (1 << 29 )
#define TRANS_FAIL_INT_EN (1 << 28 )
#define XD_INT_EN (1 << 27 )
#define MS_INT_EN (1 << 26 )
#define SD_INT_EN (1 << 25 )
#define GPIO0_INT_EN (1 << 24 )
#define OC_INT_EN (1 << 23 )
#define DELINK_INT_EN GPIO0_INT_EN
#define MS_OC_INT_EN (1 << 23 )
#define SD_OVP_INT_EN (1 << 23 )
#define SD_OC_INT_EN (1 << 22 )
#define RTSX_DUM_REG 0 x1C
/*
* macros for easy use
*/
#define rtsx_pci_writel(pcr, reg, value) \
iowrite32(value, (pcr)->remap_addr + reg)
#define rtsx_pci_readl(pcr, reg) \
ioread32((pcr)->remap_addr + reg)
#define rtsx_pci_writew(pcr, reg, value) \
iowrite16(value, (pcr)->remap_addr + reg)
#define rtsx_pci_readw(pcr, reg) \
ioread16((pcr)->remap_addr + reg)
#define rtsx_pci_writeb(pcr, reg, value) \
iowrite8(value, (pcr)->remap_addr + reg)
#define rtsx_pci_readb(pcr, reg) \
ioread8((pcr)->remap_addr + reg)
#define STATE_TRANS_NONE 0
#define STATE_TRANS_CMD 1
#define STATE_TRANS_BUF 2
#define STATE_TRANS_SG 3
#define TRANS_NOT_READY 0
#define TRANS_RESULT_OK 1
#define TRANS_RESULT_FAIL 2
#define TRANS_NO_DEVICE 3
#define RTSX_RESV_BUF_LEN 4096
#define HOST_CMDS_BUF_LEN 1024
#define HOST_SG_TBL_BUF_LEN (RTSX_RESV_BUF_LEN - HOST_CMDS_BUF_LEN)
#define HOST_SG_TBL_ITEMS (HOST_SG_TBL_BUF_LEN / 8 )
#define MAX_SG_ITEM_LEN 0 x80000
#define HOST_TO_DEVICE 0
#define DEVICE_TO_HOST 1
#define OUTPUT_3V3 0
#define OUTPUT_1V8 1
#define RTSX_PHASE_MAX 32
#define RX_TUNING_CNT 3
#define MS_CFG 0 xFD40
#define SAMPLE_TIME_RISING 0 x00
#define SAMPLE_TIME_FALLING 0 x80
#define PUSH_TIME_DEFAULT 0 x00
#define PUSH_TIME_ODD 0 x40
#define NO_EXTEND_TOGGLE 0 x00
#define EXTEND_TOGGLE_CHK 0 x20
#define MS_BUS_WIDTH_1 0 x00
#define MS_BUS_WIDTH_4 0 x10
#define MS_BUS_WIDTH_8 0 x18
#define MS_2K_SECTOR_MODE 0 x04
#define MS_512_SECTOR_MODE 0 x00
#define MS_TOGGLE_TIMEOUT_EN 0 x00
#define MS_TOGGLE_TIMEOUT_DISEN 0 x01
#define MS_NO_CHECK_INT 0 x02
#define MS_TPC 0 xFD41
#define MS_TRANS_CFG 0 xFD42
#define WAIT_INT 0 x80
#define NO_WAIT_INT 0 x00
#define NO_AUTO_READ_INT_REG 0 x00
#define AUTO_READ_INT_REG 0 x40
#define MS_CRC16_ERR 0 x20
#define MS_RDY_TIMEOUT 0 x10
#define MS_INT_CMDNK 0 x08
#define MS_INT_BREQ 0 x04
#define MS_INT_ERR 0 x02
#define MS_INT_CED 0 x01
#define MS_TRANSFER 0 xFD43
#define MS_TRANSFER_START 0 x80
#define MS_TRANSFER_END 0 x40
#define MS_TRANSFER_ERR 0 x20
#define MS_BS_STATE 0 x10
#define MS_TM_READ_BYTES 0 x00
#define MS_TM_NORMAL_READ 0 x01
#define MS_TM_WRITE_BYTES 0 x04
#define MS_TM_NORMAL_WRITE 0 x05
#define MS_TM_AUTO_READ 0 x08
#define MS_TM_AUTO_WRITE 0 x0C
#define MS_INT_REG 0 xFD44
#define MS_BYTE_CNT 0 xFD45
#define MS_SECTOR_CNT_L 0 xFD46
#define MS_SECTOR_CNT_H 0 xFD47
#define MS_DBUS_H 0 xFD48
#define SD_CFG1 0 xFDA0
#define SD_CLK_DIVIDE_0 0 x00
#define SD_CLK_DIVIDE_256 0 xC0
#define SD_CLK_DIVIDE_128 0 x80
#define SD_BUS_WIDTH_1BIT 0 x00
#define SD_BUS_WIDTH_4BIT 0 x01
#define SD_BUS_WIDTH_8BIT 0 x02
#define SD_ASYNC_FIFO_NOT_RST 0 x10
#define SD_20_MODE 0 x00
#define SD_DDR_MODE 0 x04
#define SD_30_MODE 0 x08
#define SD_CLK_DIVIDE_MASK 0 xC0
#define SD_MODE_SELECT_MASK 0 x0C
#define SD_CFG2 0 xFDA1
#define SD_CALCULATE_CRC7 0 x00
#define SD_NO_CALCULATE_CRC7 0 x80
#define SD_CHECK_CRC16 0 x00
#define SD_NO_CHECK_CRC16 0 x40
#define SD_NO_CHECK_WAIT_CRC_TO 0 x20
#define SD_WAIT_BUSY_END 0 x08
#define SD_NO_WAIT_BUSY_END 0 x00
#define SD_CHECK_CRC7 0 x00
#define SD_NO_CHECK_CRC7 0 x04
#define SD_RSP_LEN_0 0 x00
#define SD_RSP_LEN_6 0 x01
#define SD_RSP_LEN_17 0 x02
#define SD_RSP_TYPE_R0 0 x04
#define SD_RSP_TYPE_R1 0 x01
#define SD_RSP_TYPE_R1b 0 x09
#define SD_RSP_TYPE_R2 0 x02
#define SD_RSP_TYPE_R3 0 x05
#define SD_RSP_TYPE_R4 0 x05
#define SD_RSP_TYPE_R5 0 x01
#define SD_RSP_TYPE_R6 0 x01
#define SD_RSP_TYPE_R7 0 x01
#define SD_CFG3 0 xFDA2
#define SD30_CLK_END_EN 0 x10
#define SD_RSP_80CLK_TIMEOUT_EN 0 x01
#define SD_STAT1 0 xFDA3
#define SD_CRC7_ERR 0 x80
#define SD_CRC16_ERR 0 x40
#define SD_CRC_WRITE_ERR 0 x20
#define SD_CRC_WRITE_ERR_MASK 0 x1C
#define GET_CRC_TIME_OUT 0 x02
#define SD_TUNING_COMPARE_ERR 0 x01
#define SD_STAT2 0 xFDA4
#define SD_RSP_80CLK_TIMEOUT 0 x01
#define SD_BUS_STAT 0 xFDA5
#define SD_CLK_TOGGLE_EN 0 x80
#define SD_CLK_FORCE_STOP 0 x40
#define SD_DAT3_STATUS 0 x10
#define SD_DAT2_STATUS 0 x08
#define SD_DAT1_STATUS 0 x04
#define SD_DAT0_STATUS 0 x02
#define SD_CMD_STATUS 0 x01
#define SD_PAD_CTL 0 xFDA6
#define SD_IO_USING_1V8 0 x80
#define SD_IO_USING_3V3 0 x7F
#define TYPE_A_DRIVING 0 x00
#define TYPE_B_DRIVING 0 x01
#define TYPE_C_DRIVING 0 x02
#define TYPE_D_DRIVING 0 x03
#define SD_SAMPLE_POINT_CTL 0 xFDA7
#define DDR_FIX_RX_DAT 0 x00
#define DDR_VAR_RX_DAT 0 x80
#define DDR_FIX_RX_DAT_EDGE 0 x00
#define DDR_FIX_RX_DAT_14_DELAY 0 x40
#define DDR_FIX_RX_CMD 0 x00
#define DDR_VAR_RX_CMD 0 x20
#define DDR_FIX_RX_CMD_POS_EDGE 0 x00
#define DDR_FIX_RX_CMD_14_DELAY 0 x10
#define SD20_RX_POS_EDGE 0 x00
#define SD20_RX_14_DELAY 0 x08
#define SD20_RX_SEL_MASK 0 x08
#define SD_PUSH_POINT_CTL 0 xFDA8
#define DDR_FIX_TX_CMD_DAT 0 x00
#define DDR_VAR_TX_CMD_DAT 0 x80
#define DDR_FIX_TX_DAT_14_TSU 0 x00
#define DDR_FIX_TX_DAT_12_TSU 0 x40
#define DDR_FIX_TX_CMD_NEG_EDGE 0 x00
#define DDR_FIX_TX_CMD_14_AHEAD 0 x20
#define SD20_TX_NEG_EDGE 0 x00
#define SD20_TX_14_AHEAD 0 x10
#define SD20_TX_SEL_MASK 0 x10
#define DDR_VAR_SDCLK_POL_SWAP 0 x01
#define SD_CMD0 0 xFDA9
#define SD_CMD_START 0 x40
#define SD_CMD1 0 xFDAA
#define SD_CMD2 0 xFDAB
#define SD_CMD3 0 xFDAC
#define SD_CMD4 0 xFDAD
#define SD_CMD5 0 xFDAE
#define SD_BYTE_CNT_L 0 xFDAF
#define SD_BYTE_CNT_H 0 xFDB0
#define SD_BLOCK_CNT_L 0 xFDB1
#define SD_BLOCK_CNT_H 0 xFDB2
#define SD_TRANSFER 0 xFDB3
#define SD_TRANSFER_START 0 x80
#define SD_TRANSFER_END 0 x40
#define SD_STAT_IDLE 0 x20
#define SD_TRANSFER_ERR 0 x10
#define SD_TM_NORMAL_WRITE 0 x00
#define SD_TM_AUTO_WRITE_3 0 x01
#define SD_TM_AUTO_WRITE_4 0 x02
#define SD_TM_AUTO_READ_3 0 x05
#define SD_TM_AUTO_READ_4 0 x06
#define SD_TM_CMD_RSP 0 x08
#define SD_TM_AUTO_WRITE_1 0 x09
#define SD_TM_AUTO_WRITE_2 0 x0A
#define SD_TM_NORMAL_READ 0 x0C
#define SD_TM_AUTO_READ_1 0 x0D
#define SD_TM_AUTO_READ_2 0 x0E
#define SD_TM_AUTO_TUNING 0 x0F
#define SD_CMD_STATE 0 xFDB5
#define SD_CMD_IDLE 0 x80
#define SD_DATA_STATE 0 xFDB6
#define SD_DATA_IDLE 0 x80
#define REG_SD_STOP_SDCLK_CFG 0 xFDB8
#define SD30_CLK_STOP_CFG_EN 0 x04
#define SD30_CLK_STOP_CFG1 0 x02
#define SD30_CLK_STOP_CFG0 0 x01
#define REG_PRE_RW_MODE 0 xFD70
#define EN_INFINITE_MODE 0 x01
#define REG_CRC_DUMMY_0 0 xFD71
#define CFG_SD_POW_AUTO_PD (1 <<0 )
#define SRCTL 0 xFC13
#define DCM_DRP_CTL 0 xFC23
#define DCM_RESET 0 x08
#define DCM_LOCKED 0 x04
#define DCM_208M 0 x00
#define DCM_TX 0 x01
#define DCM_RX 0 x02
#define DCM_DRP_TRIG 0 xFC24
#define DRP_START 0 x80
#define DRP_DONE 0 x40
#define DCM_DRP_CFG 0 xFC25
#define DRP_WRITE 0 x80
#define DRP_READ 0 x00
#define DCM_WRITE_ADDRESS_50 0 x50
#define DCM_WRITE_ADDRESS_51 0 x51
#define DCM_READ_ADDRESS_00 0 x00
#define DCM_READ_ADDRESS_51 0 x51
#define DCM_DRP_WR_DATA_L 0 xFC26
#define DCM_DRP_WR_DATA_H 0 xFC27
#define DCM_DRP_RD_DATA_L 0 xFC28
#define DCM_DRP_RD_DATA_H 0 xFC29
#define SD_VPCLK0_CTL 0 xFC2A
#define SD_VPCLK1_CTL 0 xFC2B
#define PHASE_SELECT_MASK 0 x1F
#define SD_DCMPS0_CTL 0 xFC2C
#define SD_DCMPS1_CTL 0 xFC2D
#define SD_VPTX_CTL SD_VPCLK0_CTL
#define SD_VPRX_CTL SD_VPCLK1_CTL
#define PHASE_CHANGE 0 x80
#define PHASE_NOT_RESET 0 x40
#define SD_DCMPS_TX_CTL SD_DCMPS0_CTL
#define SD_DCMPS_RX_CTL SD_DCMPS1_CTL
#define DCMPS_CHANGE 0 x80
#define DCMPS_CHANGE_DONE 0 x40
#define DCMPS_ERROR 0 x20
#define DCMPS_CURRENT_PHASE 0 x1F
#define CARD_CLK_SOURCE 0 xFC2E
#define CRC_FIX_CLK (0 x00 << 0 )
#define CRC_VAR_CLK0 (0 x01 << 0 )
#define CRC_VAR_CLK1 (0 x02 << 0 )
#define SD30_FIX_CLK (0 x00 << 2 )
#define SD30_VAR_CLK0 (0 x01 << 2 )
#define SD30_VAR_CLK1 (0 x02 << 2 )
#define SAMPLE_FIX_CLK (0 x00 << 4 )
#define SAMPLE_VAR_CLK0 (0 x01 << 4 )
#define SAMPLE_VAR_CLK1 (0 x02 << 4 )
#define CARD_PWR_CTL 0 xFD50
#define PMOS_STRG_MASK 0 x10
#define PMOS_STRG_800mA 0 x10
#define PMOS_STRG_400mA 0 x00
#define SD_POWER_OFF 0 x03
#define SD_PARTIAL_POWER_ON 0 x01
#define SD_POWER_ON 0 x00
#define SD_POWER_MASK 0 x03
#define MS_POWER_OFF 0 x0C
#define MS_PARTIAL_POWER_ON 0 x04
#define MS_POWER_ON 0 x00
#define MS_POWER_MASK 0 x0C
#define BPP_POWER_OFF 0 x0F
#define BPP_POWER_5_PERCENT_ON 0 x0E
#define BPP_POWER_10_PERCENT_ON 0 x0C
#define BPP_POWER_15_PERCENT_ON 0 x08
#define BPP_POWER_ON 0 x00
#define BPP_POWER_MASK 0 x0F
#define SD_VCC_PARTIAL_POWER_ON 0 x02
#define SD_VCC_POWER_ON 0 x00
#define CARD_CLK_SWITCH 0 xFD51
#define RTL8411B_PACKAGE_MODE 0 xFD51
#define CARD_SHARE_MODE 0 xFD52
#define CARD_SHARE_MASK 0 x0F
#define CARD_SHARE_MULTI_LUN 0 x00
#define CARD_SHARE_NORMAL 0 x00
#define CARD_SHARE_48_SD 0 x04
#define CARD_SHARE_48_MS 0 x08
#define CARD_SHARE_BAROSSA_SD 0 x01
#define CARD_SHARE_BAROSSA_MS 0 x02
#define CARD_DRIVE_SEL 0 xFD53
#define MS_DRIVE_8mA (0 x01 << 6 )
#define MMC_DRIVE_8mA (0 x01 << 4 )
#define XD_DRIVE_8mA (0 x01 << 2 )
#define GPIO_DRIVE_8mA 0 x01
#define RTS5209_CARD_DRIVE_DEFAULT (MS_DRIVE_8mA | MMC_DRIVE_8mA |\
XD_DRIVE_8mA | GPIO_DRIVE_8mA)
#define RTL8411_CARD_DRIVE_DEFAULT (MS_DRIVE_8mA | MMC_DRIVE_8mA |\
XD_DRIVE_8mA)
#define RTSX_CARD_DRIVE_DEFAULT (MS_DRIVE_8mA | GPIO_DRIVE_8mA)
#define CARD_STOP 0 xFD54
#define SPI_STOP 0 x01
#define XD_STOP 0 x02
#define SD_STOP 0 x04
#define MS_STOP 0 x08
#define SPI_CLR_ERR 0 x10
#define XD_CLR_ERR 0 x20
#define SD_CLR_ERR 0 x40
#define MS_CLR_ERR 0 x80
#define CARD_OE 0 xFD55
#define SD_OUTPUT_EN 0 x04
#define MS_OUTPUT_EN 0 x08
#define CARD_AUTO_BLINK 0 xFD56
#define CARD_GPIO_DIR 0 xFD57
#define CARD_GPIO 0 xFD58
#define CARD_DATA_SOURCE 0 xFD5B
#define PINGPONG_BUFFER 0 x01
#define RING_BUFFER 0 x00
#define SD30_CLK_DRIVE_SEL 0 xFD5A
#define DRIVER_TYPE_A 0 x05
#define DRIVER_TYPE_B 0 x03
#define DRIVER_TYPE_C 0 x02
#define DRIVER_TYPE_D 0 x01
#define CARD_SELECT 0 xFD5C
#define SD_MOD_SEL 2
#define MS_MOD_SEL 3
#define SD30_DRIVE_SEL 0 xFD5E
#define CFG_DRIVER_TYPE_A 0 x02
#define CFG_DRIVER_TYPE_B 0 x03
#define CFG_DRIVER_TYPE_C 0 x01
#define CFG_DRIVER_TYPE_D 0 x00
#define SD30_CMD_DRIVE_SEL 0 xFD5E
#define SD30_DAT_DRIVE_SEL 0 xFD5F
#define CARD_CLK_EN 0 xFD69
#define SD_CLK_EN 0 x04
#define MS_CLK_EN 0 x08
#define SD40_CLK_EN 0 x10
#define SDIO_CTRL 0 xFD6B
#define CD_PAD_CTL 0 xFD73
#define CD_DISABLE_MASK 0 x07
#define MS_CD_DISABLE 0 x04
#define SD_CD_DISABLE 0 x02
#define XD_CD_DISABLE 0 x01
#define CD_DISABLE 0 x07
#define CD_ENABLE 0 x00
#define MS_CD_EN_ONLY 0 x03
#define SD_CD_EN_ONLY 0 x05
#define XD_CD_EN_ONLY 0 x06
#define FORCE_CD_LOW_MASK 0 x38
#define FORCE_CD_XD_LOW 0 x08
#define FORCE_CD_SD_LOW 0 x10
#define FORCE_CD_MS_LOW 0 x20
#define CD_AUTO_DISABLE 0 x40
#define FPDCTL 0 xFC00
#define SSC_POWER_DOWN 0 x01
#define SD_OC_POWER_DOWN 0 x02
#define ALL_POWER_DOWN 0 x03
#define OC_POWER_DOWN 0 x02
#define PDINFO 0 xFC01
#define CLK_CTL 0 xFC02
#define CHANGE_CLK 0 x01
#define CLK_LOW_FREQ 0 x01
#define CLK_DIV 0 xFC03
#define CLK_DIV_1 0 x01
#define CLK_DIV_2 0 x02
#define CLK_DIV_4 0 x03
#define CLK_DIV_8 0 x04
#define CLK_SEL 0 xFC04
#define SSC_DIV_N_0 0 xFC0F
#define SSC_DIV_N_1 0 xFC10
#define SSC_CTL1 0 xFC11
#define SSC_RSTB 0 x80
#define SSC_8X_EN 0 x40
#define SSC_FIX_FRAC 0 x20
#define SSC_SEL_1M 0 x00
#define SSC_SEL_2M 0 x08
#define SSC_SEL_4M 0 x10
#define SSC_SEL_8M 0 x18
#define SSC_CTL2 0 xFC12
#define SSC_DEPTH_MASK 0 x07
#define SSC_DEPTH_DISALBE 0 x00
#define SSC_DEPTH_4M 0 x01
#define SSC_DEPTH_2M 0 x02
#define SSC_DEPTH_1M 0 x03
#define SSC_DEPTH_500K 0 x04
#define SSC_DEPTH_250K 0 x05
#define RCCTL 0 xFC14
#define FPGA_PULL_CTL 0 xFC1D
#define OLT_LED_CTL 0 xFC1E
#define LED_SHINE_MASK 0 x08
#define LED_SHINE_EN 0 x08
#define LED_SHINE_DISABLE 0 x00
#define GPIO_CTL 0 xFC1F
#define LDO_CTL 0 xFC1E
#define BPP_ASIC_1V7 0 x00
#define BPP_ASIC_1V8 0 x01
#define BPP_ASIC_1V9 0 x02
#define BPP_ASIC_2V0 0 x03
#define BPP_ASIC_2V7 0 x04
#define BPP_ASIC_2V8 0 x05
#define BPP_ASIC_3V2 0 x06
#define BPP_ASIC_3V3 0 x07
#define BPP_REG_TUNED18 0 x07
#define BPP_TUNED18_SHIFT_8402 5
#define BPP_TUNED18_SHIFT_8411 4
#define BPP_PAD_MASK 0 x04
#define BPP_PAD_3V3 0 x04
#define BPP_PAD_1V8 0 x00
#define BPP_LDO_POWB 0 x03
#define BPP_LDO_ON 0 x00
#define BPP_LDO_SUSPEND 0 x02
#define BPP_LDO_OFF 0 x03
#define EFUSE_CTL 0 xFC30
#define EFUSE_ADD 0 xFC31
#define SYS_VER 0 xFC32
#define EFUSE_DATAL 0 xFC34
#define EFUSE_DATAH 0 xFC35
#define CARD_PULL_CTL1 0 xFD60
#define CARD_PULL_CTL2 0 xFD61
#define CARD_PULL_CTL3 0 xFD62
#define CARD_PULL_CTL4 0 xFD63
#define CARD_PULL_CTL5 0 xFD64
#define CARD_PULL_CTL6 0 xFD65
/* PCI Express Related Registers */
#define IRQEN0 0 xFE20
#define IRQSTAT0 0 xFE21
#define DMA_DONE_INT 0 x80
#define SUSPEND_INT 0 x40
#define LINK_RDY_INT 0 x20
#define LINK_DOWN_INT 0 x10
#define IRQEN1 0 xFE22
#define IRQSTAT1 0 xFE23
#define TLPRIEN 0 xFE24
#define TLPRISTAT 0 xFE25
#define TLPTIEN 0 xFE26
#define TLPTISTAT 0 xFE27
#define DMATC0 0 xFE28
#define DMATC1 0 xFE29
#define DMATC2 0 xFE2A
#define DMATC3 0 xFE2B
#define DMACTL 0 xFE2C
#define DMA_RST 0 x80
#define DMA_BUSY 0 x04
#define DMA_DIR_TO_CARD 0 x00
#define DMA_DIR_FROM_CARD 0 x02
#define DMA_EN 0 x01
#define DMA_128 (0 << 4 )
#define DMA_256 (1 << 4 )
#define DMA_512 (2 << 4 )
#define DMA_1024 (3 << 4 )
#define DMA_PACK_SIZE_MASK 0 x30
#define BCTL 0 xFE2D
#define RBBC0 0 xFE2E
#define RBBC1 0 xFE2F
#define RBDAT 0 xFE30
#define RBCTL 0 xFE34
#define U_AUTO_DMA_EN_MASK 0 x20
#define U_AUTO_DMA_DISABLE 0 x00
#define RB_FLUSH 0 x80
#define CFGADDR0 0 xFE35
#define CFGADDR1 0 xFE36
#define CFGDATA0 0 xFE37
#define CFGDATA1 0 xFE38
#define CFGDATA2 0 xFE39
#define CFGDATA3 0 xFE3A
#define CFGRWCTL 0 xFE3B
#define PHYRWCTL 0 xFE3C
#define PHYDATA0 0 xFE3D
#define PHYDATA1 0 xFE3E
#define PHYADDR 0 xFE3F
#define MSGRXDATA0 0 xFE40
#define MSGRXDATA1 0 xFE41
#define MSGRXDATA2 0 xFE42
#define MSGRXDATA3 0 xFE43
#define MSGTXDATA0 0 xFE44
#define MSGTXDATA1 0 xFE45
#define MSGTXDATA2 0 xFE46
#define MSGTXDATA3 0 xFE47
#define MSGTXCTL 0 xFE48
#define LTR_CTL 0 xFE4A
#define LTR_TX_EN_MASK BIT(7 )
#define LTR_TX_EN_1 BIT(7 )
#define LTR_TX_EN_0 0
#define LTR_LATENCY_MODE_MASK BIT(6 )
#define LTR_LATENCY_MODE_HW 0
#define LTR_LATENCY_MODE_SW BIT(6 )
#define OBFF_CFG 0 xFE4C
#define OBFF_EN_MASK 0 x03
#define OBFF_DISABLE 0 x00
#define CDRESUMECTL 0 xFE52
#define CDGW 0 xFE53
#define WAKE_SEL_CTL 0 xFE54
#define PCLK_CTL 0 xFE55
#define PCLK_MODE_SEL 0 x20
#define PME_FORCE_CTL 0 xFE56
#define ASPM_FORCE_CTL 0 xFE57
#define FORCE_ASPM_CTL0 0 x10
#define FORCE_ASPM_CTL1 0 x20
#define FORCE_ASPM_VAL_MASK 0 x03
#define FORCE_ASPM_L1_EN 0 x02
#define FORCE_ASPM_L0_EN 0 x01
#define FORCE_ASPM_NO_ASPM 0 x00
#define PM_CLK_FORCE_CTL 0 xFE58
#define CLK_PM_EN 0 x01
#define FUNC_FORCE_CTL 0 xFE59
#define FUNC_FORCE_UPME_XMT_DBG 0 x02
#define PERST_GLITCH_WIDTH 0 xFE5C
#define CHANGE_LINK_STATE 0 xFE5B
#define RESET_LOAD_REG 0 xFE5E
#define EFUSE_CONTENT 0 xFE5F
#define HOST_SLEEP_STATE 0 xFE60
#define HOST_ENTER_S1 1
#define HOST_ENTER_S3 2
#define SDIO_CFG 0 xFE70
#define PM_EVENT_DEBUG 0 xFE71
#define PME_DEBUG_0 0 x08
#define NFTS_TX_CTRL 0 xFE72
#define PWR_GATE_CTRL 0 xFE75
#define PWR_GATE_EN 0 x01
#define LDO3318_PWR_MASK 0 x06
#define LDO_ON 0 x00
#define LDO_SUSPEND 0 x04
#define LDO_OFF 0 x06
#define PWD_SUSPEND_EN 0 xFE76
#define LDO_PWR_SEL 0 xFE78
#define L1SUB_CONFIG1 0 xFE8D
#define AUX_CLK_ACTIVE_SEL_MASK 0 x01
#define MAC_CKSW_DONE 0 x00
#define L1SUB_CONFIG2 0 xFE8E
#define L1SUB_AUTO_CFG 0 x02
#define L1SUB_CONFIG3 0 xFE8F
#define L1OFF_MBIAS2_EN_5250 BIT(7 )
#define DUMMY_REG_RESET_0 0 xFE90
#define IC_VERSION_MASK 0 x0F
#define REG_VREF 0 xFE97
#define PWD_SUSPND_EN 0 x10
#define RTS5260_DMA_RST_CTL_0 0 xFEBF
#define RTS5260_DMA_RST 0 x80
#define RTS5260_ADMA3_RST 0 x40
#define AUTOLOAD_CFG_BASE 0 xFF00
#define RELINK_TIME_MASK 0 x01
#define PETXCFG 0 xFF03
#define FORCE_CLKREQ_DELINK_MASK BIT(7 )
#define FORCE_CLKREQ_LOW 0 x80
#define FORCE_CLKREQ_HIGH 0 x00
#define PM_CTRL1 0 xFF44
#define CD_RESUME_EN_MASK 0 xF0
#define PM_CTRL2 0 xFF45
#define PM_CTRL3 0 xFF46
#define SDIO_SEND_PME_EN 0 x80
#define FORCE_RC_MODE_ON 0 x40
#define FORCE_RX50_LINK_ON 0 x20
#define D3_DELINK_MODE_EN 0 x10
#define USE_PESRTB_CTL_DELINK 0 x08
#define DELAY_PIN_WAKE 0 x04
#define RESET_PIN_WAKE 0 x02
#define PM_WAKE_EN 0 x01
#define PM_CTRL4 0 xFF47
/* FW config info register */
#define RTS5261_FW_CFG_INFO0 0 xFF50
#define RTS5261_FW_EXPRESS_TEST_MASK (0 x01 << 0 )
#define RTS5261_FW_EA_MODE_MASK (0 x01 << 5 )
#define RTS5261_FW_CFG0 0 xFF54
#define RTS5261_FW_ENTER_EXPRESS (0 x01 << 0 )
#define RTS5261_FW_CFG1 0 xFF55
#define RTS5261_SYS_CLK_SEL_MCU_CLK (0 x01 << 7 )
#define RTS5261_CRC_CLK_SEL_MCU_CLK (0 x01 << 6 )
#define RTS5261_FAKE_MCU_CLOCK_GATING (0 x01 << 5 )
#define RTS5261_MCU_BUS_SEL_MASK (0 x01 << 4 )
#define RTS5261_MCU_CLOCK_SEL_MASK (0 x03 << 2 )
#define RTS5261_MCU_CLOCK_SEL_16M (0 x01 << 2 )
#define RTS5261_MCU_CLOCK_GATING (0 x01 << 1 )
#define RTS5261_DRIVER_ENABLE_FW (0 x01 << 0 )
#define REG_CFG_OOBS_OFF_TIMER 0 xFEA6
#define REG_CFG_OOBS_ON_TIMER 0 xFEA7
#define REG_CFG_VCM_ON_TIMER 0 xFEA8
#define REG_CFG_OOBS_POLLING 0 xFEA9
/* Memory mapping */
#define SRAM_BASE 0 xE600
#define RBUF_BASE 0 xF400
#define PPBUF_BASE1 0 xF800
#define PPBUF_BASE2 0 xFA00
#define IMAGE_FLAG_ADDR0 0 xCE80
#define IMAGE_FLAG_ADDR1 0 xCE81
#define RREF_CFG 0 xFF6C
#define RREF_VBGSEL_MASK 0 x38
#define RREF_VBGSEL_1V25 0 x28
#define OOBS_CONFIG 0 xFF6E
#define OOBS_AUTOK_DIS 0 x80
#define OOBS_VAL_MASK 0 x1F
#define LDO_DV18_CFG 0 xFF70
#define LDO_DV18_SR_MASK 0 xC0
#define LDO_DV18_SR_DF 0 x40
#define DV331812_MASK 0 x70
#define DV331812_33 0 x70
#define DV331812_17 0 x30
#define LDO_CONFIG2 0 xFF71
#define LDO_D3318_MASK 0 x07
#define LDO_D3318_33V 0 x07
#define LDO_D3318_18V 0 x02
#define DV331812_VDD1 0 x04
#define DV331812_POWERON 0 x08
#define DV331812_POWEROFF 0 x00
#define LDO_VCC_CFG0 0 xFF72
#define LDO_VCC_LMTVTH_MASK 0 x30
#define LDO_VCC_LMTVTH_2A 0 x10
/*RTS5260*/
#define RTS5260_DVCC_TUNE_MASK 0 x70
#define RTS5260_DVCC_33 0 x70
/*RTS5261*/
#define RTS5261_LDO1_CFG0 0 xFF72
#define RTS5261_LDO1_OCP_THD_MASK (0 x07 << 5 )
#define RTS5261_LDO1_OCP_EN (0 x01 << 4 )
#define RTS5261_LDO1_OCP_LMT_THD_MASK (0 x03 << 2 )
#define RTS5261_LDO1_OCP_LMT_EN (0 x01 << 1 )
#define LDO_VCC_CFG1 0 xFF73
#define LDO_VCC_REF_TUNE_MASK 0 x30
#define LDO_VCC_REF_1V2 0 x20
#define LDO_VCC_TUNE_MASK 0 x07
#define LDO_VCC_1V8 0 x04
#define LDO_VCC_3V3 0 x07
#define LDO_VCC_LMT_EN 0 x08
/*RTS5260*/
#define LDO_POW_SDVDD1_MASK 0 x08
#define LDO_POW_SDVDD1_ON 0 x08
#define LDO_POW_SDVDD1_OFF 0 x00
#define LDO_VIO_CFG 0 xFF75
#define LDO_VIO_SR_MASK 0 xC0
#define LDO_VIO_SR_DF 0 x40
#define LDO_VIO_REF_TUNE_MASK 0 x30
#define LDO_VIO_REF_1V2 0 x20
#define LDO_VIO_TUNE_MASK 0 x07
#define LDO_VIO_1V7 0 x03
#define LDO_VIO_1V8 0 x04
#define LDO_VIO_3V3 0 x07
#define LDO_DV12S_CFG 0 xFF76
#define LDO_REF12_TUNE_MASK 0 x18
#define LDO_REF12_TUNE_DF 0 x10
#define LDO_D12_TUNE_MASK 0 x07
#define LDO_D12_TUNE_DF 0 x04
#define LDO_AV12S_CFG 0 xFF77
#define LDO_AV12S_TUNE_MASK 0 x07
#define LDO_AV12S_TUNE_DF 0 x04
#define SD40_LDO_CTL1 0 xFE7D
#define SD40_VIO_TUNE_MASK 0 x70
#define SD40_VIO_TUNE_1V7 0 x30
#define SD_VIO_LDO_1V8 0 x40
#define SD_VIO_LDO_3V3 0 x70
#define RTS5264_AUTOLOAD_CFG2 0 xFF7D
#define RTS5264_CHIP_RST_N_SEL (1 << 6 )
#define RTS5260_AUTOLOAD_CFG4 0 xFF7F
#define RTS5260_MIMO_DISABLE 0 x8A
/*RTS5261*/
#define RTS5261_AUX_CLK_16M_EN (1 << 5 )
#define RTS5260_REG_GPIO_CTL0 0 xFC1A
#define RTS5260_REG_GPIO_MASK 0 x01
#define RTS5260_REG_GPIO_ON 0 x01
#define RTS5260_REG_GPIO_OFF 0 x00
#define PWR_GLOBAL_CTRL 0 xF200
#define PCIE_L1_2_EN 0 x0C
#define PCIE_L1_1_EN 0 x0A
#define PCIE_L1_0_EN 0 x09
#define PWR_FE_CTL 0 xF201
#define PCIE_L1_2_PD_FE_EN 0 x0C
#define PCIE_L1_1_PD_FE_EN 0 x0A
#define PCIE_L1_0_PD_FE_EN 0 x09
#define CFG_PCIE_APHY_OFF_0 0 xF204
#define CFG_PCIE_APHY_OFF_0_DEFAULT 0 xBF
#define CFG_PCIE_APHY_OFF_1 0 xF205
#define CFG_PCIE_APHY_OFF_1_DEFAULT 0 xFF
#define CFG_PCIE_APHY_OFF_2 0 xF206
#define CFG_PCIE_APHY_OFF_2_DEFAULT 0 x01
#define CFG_PCIE_APHY_OFF_3 0 xF207
#define CFG_PCIE_APHY_OFF_3_DEFAULT 0 x00
#define CFG_L1_0_PCIE_MAC_RET_VALUE 0 xF20C
#define CFG_L1_0_PCIE_DPHY_RET_VALUE 0 xF20E
#define CFG_L1_0_SYS_RET_VALUE 0 xF210
#define CFG_L1_0_CRC_MISC_RET_VALUE 0 xF212
#define CFG_L1_0_CRC_SD30_RET_VALUE 0 xF214
#define CFG_L1_0_CRC_SD40_RET_VALUE 0 xF216
#define CFG_LP_FPWM_VALUE 0 xF219
#define CFG_LP_FPWM_VALUE_DEFAULT 0 x18
#define PWC_CDR 0 xF253
#define PWC_CDR_DEFAULT 0 x03
#define CFG_L1_0_RET_VALUE_DEFAULT 0 x1B
#define CFG_L1_0_CRC_MISC_RET_VALUE_DEFAULT 0 x0C
/* OCPCTL */
#define SD_DETECT_EN 0 x08
#define SD_OCP_INT_EN 0 x04
#define SD_OCP_INT_CLR 0 x02
#define SD_OC_CLR 0 x01
#define SDVIO_DETECT_EN (1 << 7 )
#define SDVIO_OCP_INT_EN (1 << 6 )
#define SDVIO_OCP_INT_CLR (1 << 5 )
#define SDVIO_OC_CLR (1 << 4 )
/* OCPSTAT */
#define SD_OCP_DETECT 0 x08
#define SD_OC_NOW 0 x04
#define SD_OC_EVER 0 x02
#define SDVIO_OC_NOW (1 << 6 )
#define SDVIO_OC_EVER (1 << 5 )
#define REG_OCPCTL 0 xFD6A
#define REG_OCPSTAT 0 xFD6E
#define REG_OCPGLITCH 0 xFD6C
#define REG_OCPPARA1 0 xFD6B
#define REG_OCPPARA2 0 xFD6D
/* rts5260 DV3318 OCP-related registers */
#define REG_DV3318_OCPCTL 0 xFD89
#define DV3318_OCP_TIME_MASK 0 xF0
#define DV3318_DETECT_EN 0 x08
#define DV3318_OCP_INT_EN 0 x04
#define DV3318_OCP_INT_CLR 0 x02
#define DV3318_OCP_CLR 0 x01
#define REG_DV3318_OCPSTAT 0 xFD8A
#define DV3318_OCP_GlITCH_TIME_MASK 0 xF0
#define DV3318_OCP_DETECT 0 x08
#define DV3318_OCP_NOW 0 x04
#define DV3318_OCP_EVER 0 x02
#define SD_OCP_GLITCH_MASK 0 x0F
/* OCPPARA1 */
#define SDVIO_OCP_TIME_60 0 x00
#define SDVIO_OCP_TIME_100 0 x10
#define SDVIO_OCP_TIME_200 0 x20
#define SDVIO_OCP_TIME_400 0 x30
#define SDVIO_OCP_TIME_600 0 x40
#define SDVIO_OCP_TIME_800 0 x50
#define SDVIO_OCP_TIME_1100 0 x60
#define SDVIO_OCP_TIME_MASK 0 x70
#define SD_OCP_TIME_60 0 x00
#define SD_OCP_TIME_100 0 x01
#define SD_OCP_TIME_200 0 x02
#define SD_OCP_TIME_400 0 x03
#define SD_OCP_TIME_600 0 x04
#define SD_OCP_TIME_800 0 x05
#define SD_OCP_TIME_1100 0 x06
#define SD_OCP_TIME_MASK 0 x07
/* OCPPARA2 */
#define SDVIO_OCP_THD_190 0 x00
#define SDVIO_OCP_THD_250 0 x10
#define SDVIO_OCP_THD_320 0 x20
#define SDVIO_OCP_THD_380 0 x30
#define SDVIO_OCP_THD_440 0 x40
#define SDVIO_OCP_THD_500 0 x50
#define SDVIO_OCP_THD_570 0 x60
#define SDVIO_OCP_THD_630 0 x70
#define SDVIO_OCP_THD_MASK 0 x70
#define SD_OCP_THD_450 0 x00
#define SD_OCP_THD_550 0 x01
#define SD_OCP_THD_650 0 x02
#define SD_OCP_THD_750 0 x03
#define SD_OCP_THD_850 0 x04
#define SD_OCP_THD_950 0 x05
#define SD_OCP_THD_1050 0 x06
#define SD_OCP_THD_1150 0 x07
#define SD_OCP_THD_MASK 0 x07
#define SDVIO_OCP_GLITCH_MASK 0 xF0
#define SDVIO_OCP_GLITCH_NONE 0 x00
#define SDVIO_OCP_GLITCH_50U 0 x10
#define SDVIO_OCP_GLITCH_100U 0 x20
#define SDVIO_OCP_GLITCH_200U 0 x30
#define SDVIO_OCP_GLITCH_600U 0 x40
#define SDVIO_OCP_GLITCH_800U 0 x50
#define SDVIO_OCP_GLITCH_1M 0 x60
#define SDVIO_OCP_GLITCH_2M 0 x70
#define SDVIO_OCP_GLITCH_3M 0 x80
#define SDVIO_OCP_GLITCH_4M 0 x90
#define SDVIO_OCP_GLIVCH_5M 0 xA0
#define SDVIO_OCP_GLITCH_6M 0 xB0
#define SDVIO_OCP_GLITCH_7M 0 xC0
#define SDVIO_OCP_GLITCH_8M 0 xD0
#define SDVIO_OCP_GLITCH_9M 0 xE0
#define SDVIO_OCP_GLITCH_10M 0 xF0
#define SD_OCP_GLITCH_MASK 0 x0F
#define SD_OCP_GLITCH_NONE 0 x00
#define SD_OCP_GLITCH_50U 0 x01
#define SD_OCP_GLITCH_100U 0 x02
#define SD_OCP_GLITCH_200U 0 x03
#define SD_OCP_GLITCH_600U 0 x04
#define SD_OCP_GLITCH_800U 0 x05
#define SD_OCP_GLITCH_1M 0 x06
#define SD_OCP_GLITCH_2M 0 x07
#define SD_OCP_GLITCH_3M 0 x08
#define SD_OCP_GLITCH_4M 0 x09
#define SD_OCP_GLIVCH_5M 0 x0A
#define SD_OCP_GLITCH_6M 0 x0B
#define SD_OCP_GLITCH_7M 0 x0C
#define SD_OCP_GLITCH_8M 0 x0D
#define SD_OCP_GLITCH_9M 0 x0E
#define SD_OCP_GLITCH_10M 0 x0F
/* Phy register */
#define PHY_PCR 0 x00
#define PHY_PCR_FORCE_CODE 0 xB000
#define PHY_PCR_OOBS_CALI_50 0 x0800
#define PHY_PCR_OOBS_VCM_08 0 x0200
#define PHY_PCR_OOBS_SEN_90 0 x0040
#define PHY_PCR_RSSI_EN 0 x0002
#define PHY_PCR_RX10K 0 x0001
#define PHY_RCR0 0 x01
#define PHY_RCR1 0 x02
#define PHY_RCR1_ADP_TIME_4 0 x0400
#define PHY_RCR1_VCO_COARSE 0 x001F
#define PHY_RCR1_INIT_27S 0 x0A1F
#define PHY_SSCCR2 0 x02
#define PHY_SSCCR2_PLL_NCODE 0 x0A00
#define PHY_SSCCR2_TIME0 0 x001C
#define PHY_SSCCR2_TIME2_WIDTH 0 x0003
#define PHY_RCR2 0 x03
#define PHY_RCR2_EMPHASE_EN 0 x8000
#define PHY_RCR2_NADJR 0 x4000
#define PHY_RCR2_CDR_SR_2 0 x0100
#define PHY_RCR2_FREQSEL_12 0 x0040
#define PHY_RCR2_CDR_SC_12P 0 x0010
#define PHY_RCR2_CALIB_LATE 0 x0002
#define PHY_RCR2_INIT_27S 0 xC152
#define PHY_SSCCR3 0 x03
#define PHY_SSCCR3_STEP_IN 0 x2740
#define PHY_SSCCR3_CHECK_DELAY 0 x0008
#define _PHY_ANA03 0 x03
#define _PHY_ANA03_TIMER_MAX 0 x2700
#define _PHY_ANA03_OOBS_DEB_EN 0 x0040
#define _PHY_CMU_DEBUG_EN 0 x0008
#define PHY_RTCR 0 x04
#define PHY_RDR 0 x05
#define PHY_RDR_RXDSEL_1_9 0 x4000
#define PHY_SSC_AUTO_PWD 0 x0600
#define PHY_TCR0 0 x06
#define PHY_TCR1 0 x07
#define PHY_TUNE 0 x08
#define PHY_TUNE_TUNEREF_1_0 0 x4000
#define PHY_TUNE_VBGSEL_1252 0 x0C00
#define PHY_TUNE_SDBUS_33 0 x0200
#define PHY_TUNE_TUNED18 0 x01C0
#define PHY_TUNE_TUNED12 0 X0020
#define PHY_TUNE_TUNEA12 0 x0004
#define PHY_TUNE_VOLTAGE_MASK 0 xFC3F
#define PHY_TUNE_VOLTAGE_3V3 0 x03C0
#define PHY_TUNE_D18_1V8 0 x0100
#define PHY_TUNE_D18_1V7 0 x0080
#define PHY_ANA08 0 x08
#define PHY_ANA08_RX_EQ_DCGAIN 0 x5000
#define PHY_ANA08_SEL_RX_EN 0 x0400
#define PHY_ANA08_RX_EQ_VAL 0 x03C0
#define PHY_ANA08_SCP 0 x0020
#define PHY_ANA08_SEL_IPI 0 x0004
#define PHY_IMR 0 x09
#define PHY_BPCR 0 x0A
#define PHY_BPCR_IBRXSEL 0 x0400
#define PHY_BPCR_IBTXSEL 0 x0100
#define PHY_BPCR_IB_FILTER 0 x0080
#define PHY_BPCR_CMIRROR_EN 0 x0040
#define PHY_BIST 0 x0B
#define PHY_RAW_L 0 x0C
#define PHY_RAW_H 0 x0D
#define PHY_RAW_DATA 0 x0E
#define PHY_HOST_CLK_CTRL 0 x0F
#define PHY_DMR 0 x10
#define PHY_BACR 0 x11
#define PHY_BACR_BASIC_MASK 0 xFFF3
#define PHY_IER 0 x12
#define PHY_BCSR 0 x13
#define PHY_BPR 0 x14
#define PHY_BPNR2 0 x15
#define PHY_BPNR 0 x16
#define PHY_BRNR2 0 x17
#define PHY_BENR 0 x18
#define PHY_REV 0 x19
#define PHY_REV_RESV 0 xE000
#define PHY_REV_RXIDLE_LATCHED 0 x1000
#define PHY_REV_P1_EN 0 x0800
#define PHY_REV_RXIDLE_EN 0 x0400
#define PHY_REV_CLKREQ_TX_EN 0 x0200
#define PHY_REV_CLKREQ_RX_EN 0 x0100
#define PHY_REV_CLKREQ_DT_1_0 0 x0040
#define PHY_REV_STOP_CLKRD 0 x0020
#define PHY_REV_RX_PWST 0 x0008
#define PHY_REV_STOP_CLKWR 0 x0004
#define _PHY_REV0 0 x19
#define _PHY_REV0_FILTER_OUT 0 x3800
#define _PHY_REV0_CDR_BYPASS_PFD 0 x0100
#define _PHY_REV0_CDR_RX_IDLE_BYPASS 0 x0002
#define PHY_FLD0 0 x1A
#define PHY_ANA1A 0 x1A
#define PHY_ANA1A_TXR_LOOPBACK 0 x2000
#define PHY_ANA1A_RXT_BIST 0 x0500
#define PHY_ANA1A_TXR_BIST 0 x0040
#define PHY_ANA1A_REV 0 x0006
#define PHY_FLD0_INIT_27S 0 x2546
#define PHY_FLD1 0 x1B
#define PHY_FLD2 0 x1C
#define PHY_FLD3 0 x1D
#define PHY_FLD3_TIMER_4 0 x0800
#define PHY_FLD3_TIMER_6 0 x0020
#define PHY_FLD3_RXDELINK 0 x0004
#define PHY_FLD3_INIT_27S 0 x0004
#define PHY_ANA1D 0 x1D
#define PHY_ANA1D_DEBUG_ADDR 0 x0004
#define _PHY_FLD0 0 x1D
#define _PHY_FLD0_CLK_REQ_20C 0 x8000
#define _PHY_FLD0_RX_IDLE_EN 0 x1000
#define _PHY_FLD0_BIT_ERR_RSTN 0 x0800
#define _PHY_FLD0_BER_COUNT 0 x01E0
#define _PHY_FLD0_BER_TIMER 0 x001E
#define _PHY_FLD0_CHECK_EN 0 x0001
#define PHY_FLD4 0 x1E
#define PHY_FLD4_FLDEN_SEL 0 x4000
#define PHY_FLD4_REQ_REF 0 x2000
#define PHY_FLD4_RXAMP_OFF 0 x1000
#define PHY_FLD4_REQ_ADDA 0 x0800
#define PHY_FLD4_BER_COUNT 0 x00E0
#define PHY_FLD4_BER_TIMER 0 x000A
#define PHY_FLD4_BER_CHK_EN 0 x0001
#define PHY_FLD4_INIT_27S 0 x5C7F
#define PHY_DIG1E 0 x1E
#define PHY_DIG1E_REV 0 x4000
#define PHY_DIG1E_D0_X_D1 0 x1000
#define PHY_DIG1E_RX_ON_HOST 0 x0800
#define PHY_DIG1E_RCLK_REF_HOST 0 x0400
#define PHY_DIG1E_RCLK_TX_EN_KEEP 0 x0040
#define PHY_DIG1E_RCLK_TX_TERM_KEEP 0 x0020
#define PHY_DIG1E_RCLK_RX_EIDLE_ON 0 x0010
#define PHY_DIG1E_TX_TERM_KEEP 0 x0008
#define PHY_DIG1E_RX_TERM_KEEP 0 x0004
#define PHY_DIG1E_TX_EN_KEEP 0 x0002
#define PHY_DIG1E_RX_EN_KEEP 0 x0001
#define PHY_DUM_REG 0 x1F
#define PCR_SETTING_REG1 0 x724
#define PCR_SETTING_REG2 0 x814
#define PCR_SETTING_REG3 0 x747
#define PCR_SETTING_REG4 0 x818
#define PCR_SETTING_REG5 0 x81C
#define rtsx_pci_init_cmd(pcr) ((pcr)->ci = 0 )
#define RTS5227_DEVICE_ID 0 x5227
#define RTS_MAX_TIMES_FREQ_REDUCTION 8
struct rtsx_pcr;
struct pcr_handle {
struct rtsx_pcr *pcr;
};
struct pcr_ops {
int (*write_phy)(struct rtsx_pcr *pcr, u8 addr, u16 val);
int (*read_phy)(struct rtsx_pcr *pcr, u8 addr, u16 *val);
int (*extra_init_hw)(struct rtsx_pcr *pcr);
int (*optimize_phy)(struct rtsx_pcr *pcr);
int (*turn_on_led)(struct rtsx_pcr *pcr);
int (*turn_off_led)(struct rtsx_pcr *pcr);
int (*enable_auto_blink)(struct rtsx_pcr *pcr);
int (*disable_auto_blink)(struct rtsx_pcr *pcr);
int (*card_power_on)(struct rtsx_pcr *pcr, int card);
int (*card_power_off)(struct rtsx_pcr *pcr, int card);
int (*switch_output_voltage)(struct rtsx_pcr *pcr,
u8 voltage);
unsigned int (*cd_deglitch)(struct rtsx_pcr *pcr);
int (*conv_clk_and_div_n)(int clk, int dir);
void (*fetch_vendor_settings)(struct rtsx_pcr *pcr);
void (*force_power_down)(struct rtsx_pcr *pcr, u8 pm_state, bool runtime);
void (*stop_cmd)(struct rtsx_pcr *pcr);
void (*set_aspm)(struct rtsx_pcr *pcr, bool enable);
void (*set_l1off_cfg_sub_d0)(struct rtsx_pcr *pcr, int active);
void (*enable_ocp)(struct rtsx_pcr *pcr);
void (*disable_ocp)(struct rtsx_pcr *pcr);
void (*init_ocp)(struct rtsx_pcr *pcr);
void (*process_ocp)(struct rtsx_pcr *pcr);
int (*get_ocpstat)(struct rtsx_pcr *pcr, u8 *val);
void (*clear_ocpstat)(struct rtsx_pcr *pcr);
};
enum PDEV_STAT {PDEV_STAT_IDLE, PDEV_STAT_RUN};
enum ASPM_MODE {ASPM_MODE_CFG, ASPM_MODE_REG};
#define ASPM_L1_1_EN BIT(0 )
#define ASPM_L1_2_EN BIT(1 )
#define PM_L1_1_EN BIT(2 )
#define PM_L1_2_EN BIT(3 )
#define LTR_L1SS_PWR_GATE_EN BIT(4 )
#define L1_SNOOZE_TEST_EN BIT(5 )
#define LTR_L1SS_PWR_GATE_CHECK_CARD_EN BIT(6 )
/*
* struct rtsx_cr_option - card reader option
* @dev_flags: device flags
* @force_clkreq_0: force clock request
* @ltr_en: enable ltr mode flag
* @ltr_enabled: ltr mode in configure space flag
* @ltr_active: ltr mode status
* @ltr_active_latency: ltr mode active latency
* @ltr_idle_latency: ltr mode idle latency
* @ltr_l1off_latency: ltr mode l1off latency
* @l1_snooze_delay: l1 snooze delay
* @ltr_l1off_sspwrgate: ltr l1off sspwrgate
* @ltr_l1off_snooze_sspwrgate: ltr l1off snooze sspwrgate
* @ocp_en: enable ocp flag
* @sd_400mA_ocp_thd: 400mA ocp thd
* @sd_800mA_ocp_thd: 800mA ocp thd
*/
struct rtsx_cr_option {
u32 dev_flags;
bool force_clkreq_0;
bool ltr_en;
bool ltr_enabled;
bool ltr_active;
u32 ltr_active_latency;
u32 ltr_idle_latency;
u32 ltr_l1off_latency;
u32 l1_snooze_delay;
u8 ltr_l1off_sspwrgate;
u8 ltr_l1off_snooze_sspwrgate;
bool ocp_en;
u8 sd_400mA_ocp_thd;
u8 sd_800mA_ocp_thd;
};
/*
* struct rtsx_hw_param - card reader hardware param
* @interrupt_en: indicate which interrutp enable
* @ocp_glitch: ocp glitch time
*/
struct rtsx_hw_param {
u32 interrupt_en;
u8 ocp_glitch;
};
#define rtsx_set_dev_flag(cr, flag) \
((cr)->option.dev_flags |= (flag))
#define rtsx_clear_dev_flag(cr, flag) \
((cr)->option.dev_flags &= ~(flag))
#define rtsx_check_dev_flag(cr, flag) \
((cr)->option.dev_flags & (flag))
struct rtsx_pcr {
struct pci_dev *pci;
unsigned int id;
struct rtsx_cr_option option;
struct rtsx_hw_param hw_param;
/* pci resources */
unsigned long addr;
void __iomem *remap_addr;
int irq;
/* host reserved buffer */
void *rtsx_resv_buf;
dma_addr_t rtsx_resv_buf_addr;
void *host_cmds_ptr;
dma_addr_t host_cmds_addr;
int ci;
void *host_sg_tbl_ptr;
dma_addr_t host_sg_tbl_addr;
int sgi;
u32 bier;
char trans_result;
unsigned int card_inserted;
unsigned int card_removed;
unsigned int card_exist;
struct delayed_work carddet_work;
spinlock_t lock;
struct mutex pcr_mutex;
struct completion *done;
struct completion *finish_me;
unsigned int cur_clock;
bool remove_pci;
bool msi_en;
#define EXTRA_CAPS_SD_SDR50 (1 << 0 )
#define EXTRA_CAPS_SD_SDR104 (1 << 1 )
#define EXTRA_CAPS_SD_DDR50 (1 << 2 )
#define EXTRA_CAPS_MMC_HSDDR (1 << 3 )
#define EXTRA_CAPS_MMC_HS200 (1 << 4 )
#define EXTRA_CAPS_MMC_8BIT (1 << 5 )
#define EXTRA_CAPS_NO_MMC (1 << 7 )
#define EXTRA_CAPS_SD_EXPRESS (1 << 8 )
u32 extra_caps;
#define IC_VER_A 0
#define IC_VER_B 1
#define IC_VER_C 2
#define IC_VER_D 3
u8 ic_version;
u8 sd30_drive_sel_1v8;
u8 sd30_drive_sel_3v3;
u8 card_drive_sel;
#define ASPM_L1_EN 0 x02
u8 aspm_en;
enum ASPM_MODE aspm_mode;
bool aspm_enabled;
#define PCR_MS_PMOS (1 << 0 )
#define PCR_REVERSE_SOCKET (1 << 1 )
u32 flags;
u32 tx_initial_phase;
u32 rx_initial_phase;
const u32 *sd_pull_ctl_enable_tbl;
const u32 *sd_pull_ctl_disable_tbl;
const u32 *ms_pull_ctl_enable_tbl;
const u32 *ms_pull_ctl_disable_tbl;
const struct pcr_ops *ops;
enum PDEV_STAT state;
u16 reg_pm_ctrl3;
int num_slots;
struct rtsx_slot *slots;
u8 dma_error_count;
u8 ocp_stat;
u8 ocp_stat2;
u8 ovp_stat;
u8 rtd3_en;
};
#define PID_524A 0 x524A
#define PID_5249 0 x5249
#define PID_5250 0 x5250
#define PID_525A 0 x525A
#define PID_5260 0 x5260
#define PID_5261 0 x5261
#define PID_5228 0 x5228
#define PID_5264 0 x5264
#define CHK_PCI_PID(pcr, pid) ((pcr)->pci->device == (pid))
#define PCI_VID(pcr) ((pcr)->pci->vendor)
#define PCI_PID(pcr) ((pcr)->pci->device)
#define is_version(pcr, pid, ver) \
(CHK_PCI_PID(pcr, pid) && (pcr)->ic_version == (ver))
#define is_version_higher_than(pcr, pid, ver) \
(CHK_PCI_PID(pcr, pid) && (pcr)->ic_version > (ver))
#define pcr_dbg(pcr, fmt, arg...) \
dev_dbg(&(pcr)->pci->dev, fmt, ## arg)
#define SDR104_PHASE(val) ((val) & 0 xFF)
#define SDR50_PHASE(val) (((val) >> 8 ) & 0 xFF)
#define DDR50_PHASE(val) (((val) >> 16 ) & 0 xFF)
#define SDR104_TX_PHASE(pcr) SDR104_PHASE((pcr)->tx_initial_phase)
#define SDR50_TX_PHASE(pcr) SDR50_PHASE((pcr)->tx_initial_phase)
#define DDR50_TX_PHASE(pcr) DDR50_PHASE((pcr)->tx_initial_phase)
#define SDR104_RX_PHASE(pcr) SDR104_PHASE((pcr)->rx_initial_phase)
#define SDR50_RX_PHASE(pcr) SDR50_PHASE((pcr)->rx_initial_phase)
#define DDR50_RX_PHASE(pcr) DDR50_PHASE((pcr)->rx_initial_phase)
#define SET_CLOCK_PHASE(sdr104, sdr50, ddr50) \
(((ddr50) << 16 ) | ((sdr50) << 8 ) | (sdr104))
void rtsx_pci_start_run(struct rtsx_pcr *pcr);
int rtsx_pci_write_register(struct rtsx_pcr *pcr, u16 addr, u8 mask, u8 data);
int rtsx_pci_read_register(struct rtsx_pcr *pcr, u16 addr, u8 *data);
int rtsx_pci_write_phy_register(struct rtsx_pcr *pcr, u8 addr, u16 val);
int rtsx_pci_read_phy_register(struct rtsx_pcr *pcr, u8 addr, u16 *val);
void rtsx_pci_stop_cmd(struct rtsx_pcr *pcr);
void rtsx_pci_add_cmd(struct rtsx_pcr *pcr,
u8 cmd_type, u16 reg_addr, u8 mask, u8 data);
void rtsx_pci_send_cmd_no_wait(struct rtsx_pcr *pcr);
int rtsx_pci_send_cmd(struct rtsx_pcr *pcr, int timeout);
int rtsx_pci_dma_map_sg(struct rtsx_pcr *pcr, struct scatterlist *sglist,
int num_sg, bool read);
void rtsx_pci_dma_unmap_sg(struct rtsx_pcr *pcr, struct scatterlist *sglist,
int num_sg, bool read);
int rtsx_pci_dma_transfer(struct rtsx_pcr *pcr, struct scatterlist *sglist,
int count, bool read, int timeout);
int rtsx_pci_read_ppbuf(struct rtsx_pcr *pcr, u8 *buf, int buf_len);
int rtsx_pci_write_ppbuf(struct rtsx_pcr *pcr, u8 *buf, int buf_len);
int rtsx_pci_card_pull_ctl_enable(struct rtsx_pcr *pcr, int card);
int rtsx_pci_card_pull_ctl_disable(struct rtsx_pcr *pcr, int card);
int rtsx_pci_switch_clock(struct rtsx_pcr *pcr, unsigned int card_clock,
u8 ssc_depth, bool initial_mode, bool double_clk, bool vpclk);
int rtsx_pci_card_power_on(struct rtsx_pcr *pcr, int card);
int rtsx_pci_card_power_off(struct rtsx_pcr *pcr, int card);
int rtsx_pci_card_exclusive_check(struct rtsx_pcr *pcr, int card);
int rtsx_pci_switch_output_voltage(struct rtsx_pcr *pcr, u8 voltage);
unsigned int rtsx_pci_card_exist(struct rtsx_pcr *pcr);
void rtsx_pci_complete_unfinished_transfer(struct rtsx_pcr *pcr);
static inline u8 *rtsx_pci_get_cmd_data(struct rtsx_pcr *pcr)
{
return (u8 *)(pcr->host_cmds_ptr);
}
static inline void rtsx_pci_write_be32(struct rtsx_pcr *pcr, u16 reg, u32 val)
{
rtsx_pci_add_cmd(pcr, WRITE_REG_CMD, reg, 0 xFF, val >> 24 );
rtsx_pci_add_cmd(pcr, WRITE_REG_CMD, reg + 1 , 0 xFF, val >> 16 );
rtsx_pci_add_cmd(pcr, WRITE_REG_CMD, reg + 2 , 0 xFF, val >> 8 );
rtsx_pci_add_cmd(pcr, WRITE_REG_CMD, reg + 3 , 0 xFF, val);
}
static inline int rtsx_pci_update_phy(struct rtsx_pcr *pcr, u8 addr,
u16 mask, u16 append)
{
int err;
u16 val;
err = rtsx_pci_read_phy_register(pcr, addr, &val);
if (err < 0 )
return err;
return rtsx_pci_write_phy_register(pcr, addr, (val & mask) | append);
}
#endif
Messung V0.5 in Prozent C=91 H=93 G=91
¤ Dauer der Verarbeitung: 0.23 Sekunden
(vorverarbeitet am 2026-06-07)
¤
*© Formatika GbR, Deutschland