mirror of
https://github.com/torvalds/linux.git
synced 2024-12-23 19:31:53 +00:00
2874c5fd28
Based on 1 normalized pattern(s): 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 or at your option any later version extracted by the scancode license scanner the SPDX license identifier GPL-2.0-or-later has been chosen to replace the boilerplate/reference in 3029 file(s). Signed-off-by: Thomas Gleixner <tglx@linutronix.de> Reviewed-by: Allison Randal <allison@lohutok.net> Cc: linux-spdx@vger.kernel.org Link: https://lkml.kernel.org/r/20190527070032.746973796@linutronix.de Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
70 lines
2.3 KiB
C
70 lines
2.3 KiB
C
/* SPDX-License-Identifier: GPL-2.0-or-later */
|
|
/*
|
|
* Exynos Specific Extensions for Synopsys DW Multimedia Card Interface driver
|
|
*
|
|
* Copyright (C) 2012-2014 Samsung Electronics Co., Ltd.
|
|
*/
|
|
|
|
#ifndef _DW_MMC_EXYNOS_H_
|
|
#define _DW_MMC_EXYNOS_H_
|
|
|
|
#define SDMMC_CLKSEL 0x09C
|
|
#define SDMMC_CLKSEL64 0x0A8
|
|
|
|
/* Extended Register's Offset */
|
|
#define SDMMC_HS400_DQS_EN 0x180
|
|
#define SDMMC_HS400_ASYNC_FIFO_CTRL 0x184
|
|
#define SDMMC_HS400_DLINE_CTRL 0x188
|
|
|
|
/* CLKSEL register defines */
|
|
#define SDMMC_CLKSEL_CCLK_SAMPLE(x) (((x) & 7) << 0)
|
|
#define SDMMC_CLKSEL_CCLK_DRIVE(x) (((x) & 7) << 16)
|
|
#define SDMMC_CLKSEL_CCLK_DIVIDER(x) (((x) & 7) << 24)
|
|
#define SDMMC_CLKSEL_GET_DRV_WD3(x) (((x) >> 16) & 0x7)
|
|
#define SDMMC_CLKSEL_GET_DIV(x) (((x) >> 24) & 0x7)
|
|
#define SDMMC_CLKSEL_UP_SAMPLE(x, y) (((x) & ~SDMMC_CLKSEL_CCLK_SAMPLE(7)) |\
|
|
SDMMC_CLKSEL_CCLK_SAMPLE(y))
|
|
#define SDMMC_CLKSEL_TIMING(x, y, z) (SDMMC_CLKSEL_CCLK_SAMPLE(x) | \
|
|
SDMMC_CLKSEL_CCLK_DRIVE(y) | \
|
|
SDMMC_CLKSEL_CCLK_DIVIDER(z))
|
|
#define SDMMC_CLKSEL_TIMING_MASK SDMMC_CLKSEL_TIMING(0x7, 0x7, 0x7)
|
|
#define SDMMC_CLKSEL_WAKEUP_INT BIT(11)
|
|
|
|
/* RCLK_EN register defines */
|
|
#define DATA_STROBE_EN BIT(0)
|
|
#define AXI_NON_BLOCKING_WR BIT(7)
|
|
|
|
/* DLINE_CTRL register defines */
|
|
#define DQS_CTRL_RD_DELAY(x, y) (((x) & ~0x3FF) | ((y) & 0x3FF))
|
|
#define DQS_CTRL_GET_RD_DELAY(x) ((x) & 0x3FF)
|
|
|
|
/* Protector Register */
|
|
#define SDMMC_EMMCP_BASE 0x1000
|
|
#define SDMMC_MPSECURITY (SDMMC_EMMCP_BASE + 0x0010)
|
|
#define SDMMC_MPSBEGIN0 (SDMMC_EMMCP_BASE + 0x0200)
|
|
#define SDMMC_MPSEND0 (SDMMC_EMMCP_BASE + 0x0204)
|
|
#define SDMMC_MPSCTRL0 (SDMMC_EMMCP_BASE + 0x020C)
|
|
|
|
/* SMU control defines */
|
|
#define SDMMC_MPSCTRL_SECURE_READ_BIT BIT(7)
|
|
#define SDMMC_MPSCTRL_SECURE_WRITE_BIT BIT(6)
|
|
#define SDMMC_MPSCTRL_NON_SECURE_READ_BIT BIT(5)
|
|
#define SDMMC_MPSCTRL_NON_SECURE_WRITE_BIT BIT(4)
|
|
#define SDMMC_MPSCTRL_USE_FUSE_KEY BIT(3)
|
|
#define SDMMC_MPSCTRL_ECB_MODE BIT(2)
|
|
#define SDMMC_MPSCTRL_ENCRYPTION BIT(1)
|
|
#define SDMMC_MPSCTRL_VALID BIT(0)
|
|
|
|
/* Maximum number of Ending sector */
|
|
#define SDMMC_ENDING_SEC_NR_MAX 0xFFFFFFFF
|
|
|
|
/* Fixed clock divider */
|
|
#define EXYNOS4210_FIXED_CIU_CLK_DIV 2
|
|
#define EXYNOS4412_FIXED_CIU_CLK_DIV 4
|
|
#define HS400_FIXED_CIU_CLK_DIV 1
|
|
|
|
/* Minimal required clock frequency for cclkin, unit: HZ */
|
|
#define EXYNOS_CCLKIN_MIN 50000000
|
|
|
|
#endif /* _DW_MMC_EXYNOS_H_ */
|