#include <linux/acpi.h>
#include <linux/arm-smccc.h>
#include <linux/bitfield.h>
#include <linux/clk.h>
#include <linux/dma-mapping.h>
#include <linux/iopoll.h>
#include <linux/kernel.h>
#include <linux/module.h>
#include <linux/of.h>
#include <linux/platform_device.h>
#include <linux/pm_runtime.h>
#include <linux/reset.h>
#include <linux/sizes.h>
#include "sdhci-pltfm.h"
#include "cqhci.h"
#define SDHCI_DWCMSHC_ARG2_STUFF …
#define DWCMSHC_CTRL_HS400 …
#define DWCMSHC_P_VENDOR_AREA1 …
#define DWCMSHC_AREA1_MASK …
#define DWCMSHC_HOST_CTRL3 …
#define DWCMSHC_EMMC_CONTROL …
#define DWCMSHC_CARD_IS_EMMC …
#define DWCMSHC_ENHANCED_STROBE …
#define DWCMSHC_EMMC_ATCTRL …
#define AT_CTRL_AT_EN …
#define AT_CTRL_CI_SEL …
#define AT_CTRL_SWIN_TH_EN …
#define AT_CTRL_RPT_TUNE_ERR …
#define AT_CTRL_SW_TUNE_EN …
#define AT_CTRL_WIN_EDGE_SEL_MASK …
#define AT_CTRL_WIN_EDGE_SEL …
#define AT_CTRL_TUNE_CLK_STOP_EN …
#define AT_CTRL_PRE_CHANGE_DLY_MASK …
#define AT_CTRL_PRE_CHANGE_DLY …
#define AT_CTRL_POST_CHANGE_DLY_MASK …
#define AT_CTRL_POST_CHANGE_DLY …
#define AT_CTRL_SWIN_TH_VAL_MASK …
#define AT_CTRL_SWIN_TH_VAL …
#define DWCMSHC_P_VENDOR_AREA2 …
#define CV18XX_SDHCI_MSHC_CTRL …
#define CV18XX_EMMC_FUNC_EN …
#define CV18XX_LATANCY_1T …
#define CV18XX_SDHCI_PHY_TX_RX_DLY …
#define CV18XX_PHY_TX_DLY_MSK …
#define CV18XX_PHY_TX_SRC_MSK …
#define CV18XX_PHY_TX_SRC_INVERT_CLK_TX …
#define CV18XX_PHY_RX_DLY_MSK …
#define CV18XX_PHY_RX_SRC_MSK …
#define CV18XX_PHY_RX_SRC_INVERT_RX_CLK …
#define CV18XX_SDHCI_PHY_CONFIG …
#define CV18XX_PHY_TX_BPS …
#define CV18XX_TUNE_MAX …
#define CV18XX_TUNE_STEP …
#define CV18XX_RETRY_TUNING_MAX …
#define DWCMSHC_EMMC_DLL_CTRL …
#define DWCMSHC_EMMC_DLL_RXCLK …
#define DWCMSHC_EMMC_DLL_TXCLK …
#define DWCMSHC_EMMC_DLL_STRBIN …
#define DECMSHC_EMMC_DLL_CMDOUT …
#define DWCMSHC_EMMC_DLL_STATUS0 …
#define DWCMSHC_EMMC_DLL_START …
#define DWCMSHC_EMMC_DLL_LOCKED …
#define DWCMSHC_EMMC_DLL_TIMEOUT …
#define DWCMSHC_EMMC_DLL_RXCLK_SRCSEL …
#define DWCMSHC_EMMC_DLL_START_POINT …
#define DWCMSHC_EMMC_DLL_INC …
#define DWCMSHC_EMMC_DLL_BYPASS …
#define DWCMSHC_EMMC_DLL_DLYENA …
#define DLL_TXCLK_TAPNUM_DEFAULT …
#define DLL_TXCLK_TAPNUM_90_DEGREES …
#define DLL_TXCLK_TAPNUM_FROM_SW …
#define DLL_STRBIN_TAPNUM_DEFAULT …
#define DLL_STRBIN_TAPNUM_FROM_SW …
#define DLL_STRBIN_DELAY_NUM_SEL …
#define DLL_STRBIN_DELAY_NUM_OFFSET …
#define DLL_STRBIN_DELAY_NUM_DEFAULT …
#define DLL_RXCLK_NO_INVERTER …
#define DLL_RXCLK_INVERTER …
#define DLL_CMDOUT_TAPNUM_90_DEGREES …
#define DLL_RXCLK_ORI_GATE …
#define DLL_CMDOUT_TAPNUM_FROM_SW …
#define DLL_CMDOUT_SRC_CLK_NEG …
#define DLL_CMDOUT_EN_SRC_CLK_NEG …
#define DLL_LOCK_WO_TMOUT(x) …
#define DWC_MSHC_PTR_PHY_R …
#define PHY_CNFG_R …
#define PHY_CNFG_RSTN_DEASSERT …
#define PHY_CNFG_PHY_PWRGOOD_MASK …
#define PHY_CNFG_PAD_SP_MASK …
#define PHY_CNFG_PAD_SP …
#define PHY_CNFG_PAD_SP_SG2042 …
#define PHY_CNFG_PAD_SN_MASK …
#define PHY_CNFG_PAD_SN …
#define PHY_CNFG_PAD_SN_SG2042 …
#define PHY_CMDPAD_CNFG_R …
#define PHY_DATAPAD_CNFG_R …
#define PHY_CLKPAD_CNFG_R …
#define PHY_STBPAD_CNFG_R …
#define PHY_RSTNPAD_CNFG_R …
#define PHY_PAD_RXSEL_1V8 …
#define PHY_PAD_RXSEL_3V3 …
#define PHY_PAD_WEAKPULL_MASK …
#define PHY_PAD_WEAKPULL_PULLUP …
#define PHY_PAD_WEAKPULL_PULLDOWN …
#define PHY_PAD_TXSLEW_CTRL_P_MASK …
#define PHY_PAD_TXSLEW_CTRL_P …
#define PHY_PAD_TXSLEW_CTRL_N_MASK …
#define PHY_PAD_TXSLEW_CTRL_N …
#define PHY_PAD_TXSLEW_CTRL_N_SG2042 …
#define PHY_SDCLKDL_CNFG_R …
#define PHY_SDCLKDL_CNFG_EXTDLY_EN …
#define PHY_SDCLKDL_CNFG_UPDATE …
#define PHY_SDCLKDL_DC_R …
#define PHY_SDCLKDL_DC_INITIAL …
#define PHY_SDCLKDL_DC_DEFAULT …
#define PHY_SDCLKDL_DC_HS400 …
#define PHY_SMPLDL_CNFG_R …
#define PHY_SMPLDL_CNFG_BYPASS_EN …
#define PHY_ATDL_CNFG_R …
#define PHY_ATDL_CNFG_INPSEL_MASK …
#define PHY_ATDL_CNFG_INPSEL …
#define PHY_ATDL_CNFG_INPSEL_SG2042 …
#define PHY_DLL_CTRL_R …
#define PHY_DLL_CTRL_DISABLE …
#define PHY_DLL_CTRL_ENABLE …
#define PHY_DLL_CNFG1_R …
#define PHY_DLL_CNFG1_SLVDLY_MASK …
#define PHY_DLL_CNFG1_SLVDLY …
#define PHY_DLL_CNFG1_WAITCYCLE …
#define PHY_DLL_CNFG2_R …
#define PHY_DLL_CNFG2_JUMPSTEP …
#define PHY_DLLDL_CNFG_R …
#define PHY_DLLDL_CNFG_SLV_INPSEL_MASK …
#define PHY_DLLDL_CNFG_SLV_INPSEL …
#define FLAG_IO_FIXED_1V8 …
#define BOUNDARY_OK(addr, len) …
#define DWCMSHC_SDHCI_CQE_TRNS_MODE …
#define BLUEFIELD_SMC_SET_EMMC_RST_N …
enum dwcmshc_rk_type { … };
struct rk35xx_priv { … };
#define DWCMSHC_MAX_OTHER_CLKS …
struct dwcmshc_priv { … };
struct dwcmshc_pltfm_data { … };
static int dwcmshc_get_enable_other_clks(struct device *dev,
struct dwcmshc_priv *priv,
int num_clks,
const char * const clk_ids[])
{ … }
static void dwcmshc_adma_write_desc(struct sdhci_host *host, void **desc,
dma_addr_t addr, int len, unsigned int cmd)
{ … }
static unsigned int dwcmshc_get_max_clock(struct sdhci_host *host)
{ … }
static unsigned int rk35xx_get_max_clock(struct sdhci_host *host)
{ … }
static void dwcmshc_check_auto_cmd23(struct mmc_host *mmc,
struct mmc_request *mrq)
{ … }
static void dwcmshc_request(struct mmc_host *mmc, struct mmc_request *mrq)
{ … }
static void dwcmshc_phy_1_8v_init(struct sdhci_host *host)
{ … }
static void dwcmshc_phy_3_3v_init(struct sdhci_host *host)
{ … }
static void th1520_sdhci_set_phy(struct sdhci_host *host)
{ … }
static void dwcmshc_set_uhs_signaling(struct sdhci_host *host,
unsigned int timing)
{ … }
static void th1520_set_uhs_signaling(struct sdhci_host *host,
unsigned int timing)
{ … }
static void dwcmshc_hs400_enhanced_strobe(struct mmc_host *mmc,
struct mmc_ios *ios)
{ … }
static int dwcmshc_execute_tuning(struct mmc_host *mmc, u32 opcode)
{ … }
static u32 dwcmshc_cqe_irq_handler(struct sdhci_host *host, u32 intmask)
{ … }
static void dwcmshc_sdhci_cqe_enable(struct mmc_host *mmc)
{ … }
static void dwcmshc_set_tran_desc(struct cqhci_host *cq_host, u8 **desc,
dma_addr_t addr, int len, bool end, bool dma64)
{ … }
static void dwcmshc_cqhci_dumpregs(struct mmc_host *mmc)
{ … }
static void dwcmshc_rk3568_set_clock(struct sdhci_host *host, unsigned int clock)
{ … }
static void rk35xx_sdhci_reset(struct sdhci_host *host, u8 mask)
{ … }
static int dwcmshc_rk35xx_init(struct device *dev, struct sdhci_host *host,
struct dwcmshc_priv *dwc_priv)
{ … }
static void dwcmshc_rk35xx_postinit(struct sdhci_host *host, struct dwcmshc_priv *dwc_priv)
{ … }
static int th1520_execute_tuning(struct sdhci_host *host, u32 opcode)
{ … }
static void th1520_sdhci_reset(struct sdhci_host *host, u8 mask)
{ … }
static int th1520_init(struct device *dev,
struct sdhci_host *host,
struct dwcmshc_priv *dwc_priv)
{ … }
static void cv18xx_sdhci_reset(struct sdhci_host *host, u8 mask)
{ … }
static void cv18xx_sdhci_set_tap(struct sdhci_host *host, int tap)
{ … }
static int cv18xx_retry_tuning(struct mmc_host *mmc, u32 opcode, int *cmd_error)
{ … }
static void cv18xx_sdhci_post_tuning(struct sdhci_host *host)
{ … }
static int cv18xx_sdhci_execute_tuning(struct sdhci_host *host, u32 opcode)
{ … }
static inline void sg2042_sdhci_phy_init(struct sdhci_host *host)
{ … }
static void sg2042_sdhci_reset(struct sdhci_host *host, u8 mask)
{ … }
static int sg2042_init(struct device *dev, struct sdhci_host *host,
struct dwcmshc_priv *dwc_priv)
{ … }
static const struct sdhci_ops sdhci_dwcmshc_ops = …;
#ifdef CONFIG_ACPI
static void dwcmshc_bf3_hw_reset(struct sdhci_host *host)
{ … }
static const struct sdhci_ops sdhci_dwcmshc_bf3_ops = …;
#endif
static const struct sdhci_ops sdhci_dwcmshc_rk35xx_ops = …;
static const struct sdhci_ops sdhci_dwcmshc_th1520_ops = …;
static const struct sdhci_ops sdhci_dwcmshc_cv18xx_ops = …;
static const struct sdhci_ops sdhci_dwcmshc_sg2042_ops = …;
static const struct dwcmshc_pltfm_data sdhci_dwcmshc_pdata = …;
#ifdef CONFIG_ACPI
static const struct dwcmshc_pltfm_data sdhci_dwcmshc_bf3_pdata = …;
#endif
static const struct dwcmshc_pltfm_data sdhci_dwcmshc_rk35xx_pdata = …;
static const struct dwcmshc_pltfm_data sdhci_dwcmshc_th1520_pdata = …;
static const struct dwcmshc_pltfm_data sdhci_dwcmshc_cv18xx_pdata = …;
static const struct dwcmshc_pltfm_data sdhci_dwcmshc_sg2042_pdata = …;
static const struct cqhci_host_ops dwcmshc_cqhci_ops = …;
static void dwcmshc_cqhci_init(struct sdhci_host *host, struct platform_device *pdev)
{ … }
static const struct of_device_id sdhci_dwcmshc_dt_ids[] = …;
MODULE_DEVICE_TABLE(of, sdhci_dwcmshc_dt_ids);
#ifdef CONFIG_ACPI
static const struct acpi_device_id sdhci_dwcmshc_acpi_ids[] = …;
MODULE_DEVICE_TABLE(acpi, sdhci_dwcmshc_acpi_ids);
#endif
static int dwcmshc_probe(struct platform_device *pdev)
{ … }
static void dwcmshc_disable_card_clk(struct sdhci_host *host)
{ … }
static void dwcmshc_remove(struct platform_device *pdev)
{ … }
#ifdef CONFIG_PM_SLEEP
static int dwcmshc_suspend(struct device *dev)
{ … }
static int dwcmshc_resume(struct device *dev)
{ … }
#endif
#ifdef CONFIG_PM
static void dwcmshc_enable_card_clk(struct sdhci_host *host)
{ … }
static int dwcmshc_runtime_suspend(struct device *dev)
{ … }
static int dwcmshc_runtime_resume(struct device *dev)
{ … }
#endif
static const struct dev_pm_ops dwcmshc_pmops = …;
static struct platform_driver sdhci_dwcmshc_driver = …;
module_platform_driver(…) …;
MODULE_DESCRIPTION(…) …;
MODULE_AUTHOR(…) …;
MODULE_LICENSE(…) …;