zynq_sdhci.c 18.6 KB
Newer Older
1
// SPDX-License-Identifier: GPL-2.0+
2
/*
M
Michal Simek 已提交
3
 * (C) Copyright 2013 - 2015 Xilinx, Inc.
4 5 6 7
 *
 * Xilinx Zynq SD Host Controller Interface
 */

8
#include <clk.h>
9
#include <common.h>
M
Michal Simek 已提交
10
#include <dm.h>
11
#include <fdtdec.h>
12
#include <linux/delay.h>
13
#include "mmc_private.h"
14
#include <log.h>
15
#include <dm/device_compat.h>
16
#include <linux/err.h>
17
#include <linux/libfdt.h>
18 19
#include <malloc.h>
#include <sdhci.h>
20
#include <zynqmp_tap_delay.h>
21
#include <zynqmp_firmware.h>
22

23 24 25 26 27 28 29
#define SDHCI_ARASAN_ITAPDLY_REGISTER	0xF0F8
#define SDHCI_ARASAN_ITAPDLY_SEL_MASK	GENMASK(7, 0)
#define SDHCI_ARASAN_OTAPDLY_REGISTER	0xF0FC
#define SDHCI_ARASAN_OTAPDLY_SEL_MASK	GENMASK(5, 0)
#define SDHCI_ITAPDLY_CHGWIN		BIT(9)
#define SDHCI_ITAPDLY_ENABLE		BIT(8)
#define SDHCI_OTAPDLY_ENABLE		BIT(6)
30

31
#define SDHCI_TUNING_LOOP_COUNT		40
32 33 34 35 36 37
#define MMC_BANK2			0x2

struct arasan_sdhci_clk_data {
	int clk_phase_in[MMC_TIMING_MMC_HS400 + 1];
	int clk_phase_out[MMC_TIMING_MMC_HS400 + 1];
};
38

39 40 41 42 43
struct arasan_sdhci_plat {
	struct mmc_config cfg;
	struct mmc mmc;
};

44 45
struct arasan_sdhci_priv {
	struct sdhci_host *host;
46
	struct arasan_sdhci_clk_data clk_data;
47 48
	u8 deviceid;
	u8 bank;
49
	u8 no_1p8;
50 51
};

52
#if defined(CONFIG_ARCH_ZYNQMP) || defined(CONFIG_ARCH_VERSAL)
53
/* Default settings for ZynqMP Clock Phases */
54 55 56 57
static const u32 zynqmp_iclk_phases[] = {0, 63, 63, 0, 63,  0,
					 0, 183, 54,  0, 0};
static const u32 zynqmp_oclk_phases[] = {0, 72, 60, 0, 60, 72,
					 135, 48, 72, 135, 0};
58

59
/* Default settings for Versal Clock Phases */
60 61 62 63
static const u32 versal_iclk_phases[] = {0, 132, 132, 0, 132,
					 0, 0, 162, 90, 0, 0};
static const u32 versal_oclk_phases[] = {0,  60, 48, 0, 48, 72,
					 90, 36, 60, 90, 0};
64

65
static const u8 mode2timing[] = {
A
Ashok Reddy Soma 已提交
66 67 68 69 70 71 72 73 74 75 76
	[MMC_LEGACY] = MMC_TIMING_LEGACY,
	[MMC_HS] = MMC_TIMING_MMC_HS,
	[SD_HS] = MMC_TIMING_SD_HS,
	[MMC_HS_52] = MMC_TIMING_UHS_SDR50,
	[MMC_DDR_52] = MMC_TIMING_UHS_DDR50,
	[UHS_SDR12] = MMC_TIMING_UHS_SDR12,
	[UHS_SDR25] = MMC_TIMING_UHS_SDR25,
	[UHS_SDR50] = MMC_TIMING_UHS_SDR50,
	[UHS_DDR50] = MMC_TIMING_UHS_DDR50,
	[UHS_SDR104] = MMC_TIMING_UHS_SDR104,
	[MMC_HS_200] = MMC_TIMING_MMC_HS200,
77 78
};

79
static int arasan_zynqmp_dll_reset(struct sdhci_host *host, u8 node_id)
80
{
81 82
	struct mmc *mmc = (struct mmc *)host->mmc;
	struct udevice *dev = mmc->dev;
83
	unsigned long timeout;
84 85
	int ret;
	u16 clk;
86 87 88 89 90 91

	clk = sdhci_readw(host, SDHCI_CLOCK_CONTROL);
	clk &= ~(SDHCI_CLOCK_CARD_EN);
	sdhci_writew(host, clk, SDHCI_CLOCK_CONTROL);

	/* Issue DLL Reset */
92 93 94 95 96 97 98 99 100 101 102 103 104
	ret = zynqmp_dll_reset(node_id, PM_DLL_RESET_ASSERT);
	if (ret) {
		dev_err(dev, "dll_reset assert failed with err: %d\n", ret);
		return ret;
	}

	/* Allow atleast 1ms delay for proper DLL reset */
	mdelay(1);
	ret = zynqmp_dll_reset(node_id, PM_DLL_RESET_RELEASE);
	if (ret) {
		dev_err(dev, "dll_reset release failed with err: %d\n", ret);
		return ret;
	}
105 106 107 108 109 110

	/* Wait max 20 ms */
	timeout = 100;
	while (!((clk = sdhci_readw(host, SDHCI_CLOCK_CONTROL))
				& SDHCI_CLOCK_INT_STABLE)) {
		if (timeout == 0) {
111 112
			dev_err(dev, ": Internal clock never stabilised.\n");
			return -EBUSY;
113 114 115 116 117 118 119
		}
		timeout--;
		udelay(1000);
	}

	clk |= SDHCI_CLOCK_CARD_EN;
	sdhci_writew(host, clk, SDHCI_CLOCK_CONTROL);
120 121

	return 0;
122 123 124 125 126 127 128 129 130
}

static int arasan_sdhci_execute_tuning(struct mmc *mmc, u8 opcode)
{
	struct mmc_cmd cmd;
	struct mmc_data data;
	u32 ctrl;
	struct sdhci_host *host;
	struct arasan_sdhci_priv *priv = dev_get_priv(mmc->dev);
131
	char tuning_loop_counter = SDHCI_TUNING_LOOP_COUNT;
132
	u8 node_id = priv->deviceid ? NODE_SD_1 : NODE_SD_0;
133 134 135 136 137

	debug("%s\n", __func__);

	host = priv->host;

138
	ctrl = sdhci_readw(host, SDHCI_HOST_CONTROL2);
139
	ctrl |= SDHCI_CTRL_EXEC_TUNING;
140
	sdhci_writew(host, ctrl, SDHCI_HOST_CONTROL2);
141 142 143

	mdelay(1);

144
	arasan_zynqmp_dll_reset(host, node_id);
145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171

	sdhci_writel(host, SDHCI_INT_DATA_AVAIL, SDHCI_INT_ENABLE);
	sdhci_writel(host, SDHCI_INT_DATA_AVAIL, SDHCI_SIGNAL_ENABLE);

	do {
		cmd.cmdidx = opcode;
		cmd.resp_type = MMC_RSP_R1;
		cmd.cmdarg = 0;

		data.blocksize = 64;
		data.blocks = 1;
		data.flags = MMC_DATA_READ;

		if (tuning_loop_counter-- == 0)
			break;

		if (cmd.cmdidx == MMC_CMD_SEND_TUNING_BLOCK_HS200 &&
		    mmc->bus_width == 8)
			data.blocksize = 128;

		sdhci_writew(host, SDHCI_MAKE_BLKSZ(SDHCI_DEFAULT_BOUNDARY_ARG,
						    data.blocksize),
			     SDHCI_BLOCK_SIZE);
		sdhci_writew(host, data.blocks, SDHCI_BLOCK_COUNT);
		sdhci_writew(host, SDHCI_TRNS_READ, SDHCI_TRANSFER_MODE);

		mmc_send_cmd(mmc, &cmd, NULL);
172
		ctrl = sdhci_readw(host, SDHCI_HOST_CONTROL2);
173 174 175 176 177 178 179 180

		if (cmd.cmdidx == MMC_CMD_SEND_TUNING_BLOCK)
			udelay(1);

	} while (ctrl & SDHCI_CTRL_EXEC_TUNING);

	if (tuning_loop_counter < 0) {
		ctrl &= ~SDHCI_CTRL_TUNED_CLK;
181
		sdhci_writel(host, ctrl, SDHCI_HOST_CONTROL2);
182 183 184 185 186 187 188 189
	}

	if (!(ctrl & SDHCI_CTRL_TUNED_CLK)) {
		printf("%s:Tuning failed\n", __func__);
		return -1;
	}

	udelay(1);
190
	arasan_zynqmp_dll_reset(host, node_id);
191 192 193 194 195 196 197 198 199 200

	/* Enable only interrupts served by the SD controller */
	sdhci_writel(host, SDHCI_INT_DATA_MASK | SDHCI_INT_CMD_MASK,
		     SDHCI_INT_ENABLE);
	/* Mask all sdhci interrupt sources */
	sdhci_writel(host, 0x0, SDHCI_SIGNAL_ENABLE);

	return 0;
}

201 202 203 204 205
/**
 * sdhci_zynqmp_sdcardclk_set_phase - Set the SD Output Clock Tap Delays
 *
 * @host:		Pointer to the sdhci_host structure.
 * @degrees:		The clock phase shift between 0 - 359.
206
 * Return: 0
207 208
 *
 * Set the SD Output Clock Tap Delays for Output path
209 210 211 212 213
 */
static int sdhci_zynqmp_sdcardclk_set_phase(struct sdhci_host *host,
					    int degrees)
{
	struct mmc *mmc = (struct mmc *)host->mmc;
214 215 216
	struct udevice *dev = mmc->dev;
	struct arasan_sdhci_priv *priv = dev_get_priv(mmc->dev);
	u8 node_id = priv->deviceid ? NODE_SD_1 : NODE_SD_0;
217 218
	u8 tap_delay, tap_max = 0;
	int timing = mode2timing[mmc->selected_mode];
219
	int ret;
220 221 222 223 224 225

	/*
	 * This is applicable for SDHCI_SPEC_300 and above
	 * ZynqMP does not set phase for <=25MHz clock.
	 * If degrees is zero, no need to do anything.
	 */
226
	if (SDHCI_GET_VERSION(host) < SDHCI_SPEC_300)
227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251
		return 0;

	switch (timing) {
	case MMC_TIMING_MMC_HS:
	case MMC_TIMING_SD_HS:
	case MMC_TIMING_UHS_SDR25:
	case MMC_TIMING_UHS_DDR50:
	case MMC_TIMING_MMC_DDR52:
		/* For 50MHz clock, 30 Taps are available */
		tap_max = 30;
		break;
	case MMC_TIMING_UHS_SDR50:
		/* For 100MHz clock, 15 Taps are available */
		tap_max = 15;
		break;
	case MMC_TIMING_UHS_SDR104:
	case MMC_TIMING_MMC_HS200:
		/* For 200MHz clock, 8 Taps are available */
		tap_max = 8;
	default:
		break;
	}

	tap_delay = (degrees * tap_max) / 360;

252 253 254
	/* Limit output tap_delay value to 6 bits */
	tap_delay &= SDHCI_ARASAN_OTAPDLY_SEL_MASK;

255 256 257 258 259 260 261 262 263 264 265 266 267
	/* Set the Clock Phase */
	ret = arasan_zynqmp_set_out_tapdelay(node_id, tap_delay);
	if (ret) {
		dev_err(dev, "Error setting output Tap Delay\n");
		return ret;
	}

	/* Release DLL Reset */
	ret = zynqmp_dll_reset(node_id, PM_DLL_RESET_RELEASE);
	if (ret) {
		dev_err(dev, "dll_reset release failed with err: %d\n", ret);
		return ret;
	}
268

269
	return 0;
270 271 272 273 274 275 276
}

/**
 * sdhci_zynqmp_sampleclk_set_phase - Set the SD Input Clock Tap Delays
 *
 * @host:		Pointer to the sdhci_host structure.
 * @degrees:		The clock phase shift between 0 - 359.
277
 * Return: 0
278 279
 *
 * Set the SD Input Clock Tap Delays for Input path
280 281 282 283 284
 */
static int sdhci_zynqmp_sampleclk_set_phase(struct sdhci_host *host,
					    int degrees)
{
	struct mmc *mmc = (struct mmc *)host->mmc;
285 286 287
	struct udevice *dev = mmc->dev;
	struct arasan_sdhci_priv *priv = dev_get_priv(mmc->dev);
	u8 node_id = priv->deviceid ? NODE_SD_1 : NODE_SD_0;
288 289
	u8 tap_delay, tap_max = 0;
	int timing = mode2timing[mmc->selected_mode];
290
	int ret;
291 292 293 294 295 296

	/*
	 * This is applicable for SDHCI_SPEC_300 and above
	 * ZynqMP does not set phase for <=25MHz clock.
	 * If degrees is zero, no need to do anything.
	 */
297
	if (SDHCI_GET_VERSION(host) < SDHCI_SPEC_300)
298 299
		return 0;

300 301 302 303 304 305 306
	/* Assert DLL Reset */
	ret = zynqmp_dll_reset(node_id, PM_DLL_RESET_ASSERT);
	if (ret) {
		dev_err(dev, "dll_reset assert failed with err: %d\n", ret);
		return ret;
	}

307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329
	switch (timing) {
	case MMC_TIMING_MMC_HS:
	case MMC_TIMING_SD_HS:
	case MMC_TIMING_UHS_SDR25:
	case MMC_TIMING_UHS_DDR50:
	case MMC_TIMING_MMC_DDR52:
		/* For 50MHz clock, 120 Taps are available */
		tap_max = 120;
		break;
	case MMC_TIMING_UHS_SDR50:
		/* For 100MHz clock, 60 Taps are available */
		tap_max = 60;
		break;
	case MMC_TIMING_UHS_SDR104:
	case MMC_TIMING_MMC_HS200:
		/* For 200MHz clock, 30 Taps are available */
		tap_max = 30;
	default:
		break;
	}

	tap_delay = (degrees * tap_max) / 360;

330 331 332
	/* Limit input tap_delay value to 8 bits */
	tap_delay &= SDHCI_ARASAN_ITAPDLY_SEL_MASK;

333 334 335 336 337
	ret = arasan_zynqmp_set_in_tapdelay(node_id, tap_delay);
	if (ret) {
		dev_err(dev, "Error setting Input Tap Delay\n");
		return ret;
	}
338

339
	return 0;
340 341
}

342 343 344 345
/**
 * sdhci_versal_sdcardclk_set_phase - Set the SD Output Clock Tap Delays
 *
 * @host:		Pointer to the sdhci_host structure.
346
 * @degrees:		The clock phase shift between 0 - 359.
347
 * Return: 0
348 349
 *
 * Set the SD Output Clock Tap Delays for Output path
350 351 352 353 354 355 356
 */
static int sdhci_versal_sdcardclk_set_phase(struct sdhci_host *host,
					    int degrees)
{
	struct mmc *mmc = (struct mmc *)host->mmc;
	u8 tap_delay, tap_max = 0;
	int timing = mode2timing[mmc->selected_mode];
357
	u32 regval;
358 359 360 361 362 363

	/*
	 * This is applicable for SDHCI_SPEC_300 and above
	 * Versal does not set phase for <=25MHz clock.
	 * If degrees is zero, no need to do anything.
	 */
364
	if (SDHCI_GET_VERSION(host) < SDHCI_SPEC_300)
365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389
		return 0;

	switch (timing) {
	case MMC_TIMING_MMC_HS:
	case MMC_TIMING_SD_HS:
	case MMC_TIMING_UHS_SDR25:
	case MMC_TIMING_UHS_DDR50:
	case MMC_TIMING_MMC_DDR52:
		/* For 50MHz clock, 30 Taps are available */
		tap_max = 30;
		break;
	case MMC_TIMING_UHS_SDR50:
		/* For 100MHz clock, 15 Taps are available */
		tap_max = 15;
		break;
	case MMC_TIMING_UHS_SDR104:
	case MMC_TIMING_MMC_HS200:
		/* For 200MHz clock, 8 Taps are available */
		tap_max = 8;
	default:
		break;
	}

	tap_delay = (degrees * tap_max) / 360;

390 391 392
	/* Limit output tap_delay value to 6 bits */
	tap_delay &= SDHCI_ARASAN_OTAPDLY_SEL_MASK;

393
	/* Set the Clock Phase */
394 395 396 397 398 399
	regval = sdhci_readl(host, SDHCI_ARASAN_OTAPDLY_REGISTER);
	regval |= SDHCI_OTAPDLY_ENABLE;
	sdhci_writel(host, regval, SDHCI_ARASAN_OTAPDLY_REGISTER);
	regval &= ~SDHCI_ARASAN_OTAPDLY_SEL_MASK;
	regval |= tap_delay;
	sdhci_writel(host, regval, SDHCI_ARASAN_OTAPDLY_REGISTER);
400

401
	return 0;
402 403 404 405 406 407
}

/**
 * sdhci_versal_sampleclk_set_phase - Set the SD Input Clock Tap Delays
 *
 * @host:		Pointer to the sdhci_host structure.
408
 * @degrees:		The clock phase shift between 0 - 359.
409
 * Return: 0
410 411
 *
 * Set the SD Input Clock Tap Delays for Input path
412 413 414 415 416 417 418
 */
static int sdhci_versal_sampleclk_set_phase(struct sdhci_host *host,
					    int degrees)
{
	struct mmc *mmc = (struct mmc *)host->mmc;
	u8 tap_delay, tap_max = 0;
	int timing = mode2timing[mmc->selected_mode];
419
	u32 regval;
420 421 422 423 424 425

	/*
	 * This is applicable for SDHCI_SPEC_300 and above
	 * Versal does not set phase for <=25MHz clock.
	 * If degrees is zero, no need to do anything.
	 */
426
	if (SDHCI_GET_VERSION(host) < SDHCI_SPEC_300)
427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451
		return 0;

	switch (timing) {
	case MMC_TIMING_MMC_HS:
	case MMC_TIMING_SD_HS:
	case MMC_TIMING_UHS_SDR25:
	case MMC_TIMING_UHS_DDR50:
	case MMC_TIMING_MMC_DDR52:
		/* For 50MHz clock, 120 Taps are available */
		tap_max = 120;
		break;
	case MMC_TIMING_UHS_SDR50:
		/* For 100MHz clock, 60 Taps are available */
		tap_max = 60;
		break;
	case MMC_TIMING_UHS_SDR104:
	case MMC_TIMING_MMC_HS200:
		/* For 200MHz clock, 30 Taps are available */
		tap_max = 30;
	default:
		break;
	}

	tap_delay = (degrees * tap_max) / 360;

452 453 454
	/* Limit input tap_delay value to 8 bits */
	tap_delay &= SDHCI_ARASAN_ITAPDLY_SEL_MASK;

455
	/* Set the Clock Phase */
456 457 458 459 460 461 462 463 464 465
	regval = sdhci_readl(host, SDHCI_ARASAN_ITAPDLY_REGISTER);
	regval |= SDHCI_ITAPDLY_CHGWIN;
	sdhci_writel(host, regval, SDHCI_ARASAN_ITAPDLY_REGISTER);
	regval |= SDHCI_ITAPDLY_ENABLE;
	sdhci_writel(host, regval, SDHCI_ARASAN_ITAPDLY_REGISTER);
	regval &= ~SDHCI_ARASAN_ITAPDLY_SEL_MASK;
	regval |= tap_delay;
	sdhci_writel(host, regval, SDHCI_ARASAN_ITAPDLY_REGISTER);
	regval &= ~SDHCI_ITAPDLY_CHGWIN;
	sdhci_writel(host, regval, SDHCI_ARASAN_ITAPDLY_REGISTER);
466

467
	return 0;
468 469
}

470
static int arasan_sdhci_set_tapdelay(struct sdhci_host *host)
471 472
{
	struct arasan_sdhci_priv *priv = dev_get_priv(host->mmc->dev);
473
	struct arasan_sdhci_clk_data *clk_data = &priv->clk_data;
474
	struct mmc *mmc = (struct mmc *)host->mmc;
475 476 477 478
	struct udevice *dev = mmc->dev;
	u8 timing = mode2timing[mmc->selected_mode];
	u32 iclk_phase = clk_data->clk_phase_in[timing];
	u32 oclk_phase = clk_data->clk_phase_out[timing];
479
	int ret;
480

481
	dev_dbg(dev, "%s, host:%s, mode:%d\n", __func__, host->name, timing);
482

483 484
	if (IS_ENABLED(CONFIG_ARCH_ZYNQMP) &&
	    device_is_compatible(dev, "xlnx,zynqmp-8.9a")) {
485 486 487 488 489 490 491
		ret = sdhci_zynqmp_sampleclk_set_phase(host, iclk_phase);
		if (ret)
			return ret;

		ret = sdhci_zynqmp_sdcardclk_set_phase(host, oclk_phase);
		if (ret)
			return ret;
492 493
	} else if (IS_ENABLED(CONFIG_ARCH_VERSAL) &&
		   device_is_compatible(dev, "xlnx,versal-8.9a")) {
494 495 496 497 498 499 500
		ret = sdhci_versal_sampleclk_set_phase(host, iclk_phase);
		if (ret)
			return ret;

		ret = sdhci_versal_sdcardclk_set_phase(host, oclk_phase);
		if (ret)
			return ret;
501
	}
502 503

	return 0;
504 505
}

506 507 508 509 510 511 512 513 514 515 516 517 518 519 520 521 522 523 524 525 526 527 528 529 530 531 532
static void arasan_dt_read_clk_phase(struct udevice *dev, unsigned char timing,
				     const char *prop)
{
	struct arasan_sdhci_priv *priv = dev_get_priv(dev);
	struct arasan_sdhci_clk_data *clk_data = &priv->clk_data;
	u32 clk_phase[2] = {0};

	/*
	 * Read Tap Delay values from DT, if the DT does not contain the
	 * Tap Values then use the pre-defined values
	 */
	if (dev_read_u32_array(dev, prop, &clk_phase[0], 2)) {
		dev_dbg(dev, "Using predefined clock phase for %s = %d %d\n",
			prop, clk_data->clk_phase_in[timing],
			clk_data->clk_phase_out[timing]);
		return;
	}

	/* The values read are Input and Output Clock Delays in order */
	clk_data->clk_phase_in[timing] = clk_phase[0];
	clk_data->clk_phase_out[timing] = clk_phase[1];
}

/**
 * arasan_dt_parse_clk_phases - Read Tap Delay values from DT
 *
 * @dev:                Pointer to our struct udevice.
533 534
 *
 * Called at initialization to parse the values of Tap Delays.
535 536 537 538 539 540 541 542 543 544 545 546 547 548 549 550 551 552 553 554
 */
static void arasan_dt_parse_clk_phases(struct udevice *dev)
{
	struct arasan_sdhci_priv *priv = dev_get_priv(dev);
	struct arasan_sdhci_clk_data *clk_data = &priv->clk_data;
	int i;

	if (IS_ENABLED(CONFIG_ARCH_ZYNQMP) &&
	    device_is_compatible(dev, "xlnx,zynqmp-8.9a")) {
		for (i = 0; i <= MMC_TIMING_MMC_HS400; i++) {
			clk_data->clk_phase_in[i] = zynqmp_iclk_phases[i];
			clk_data->clk_phase_out[i] = zynqmp_oclk_phases[i];
		}

		if (priv->bank == MMC_BANK2) {
			clk_data->clk_phase_out[MMC_TIMING_UHS_SDR104] = 90;
			clk_data->clk_phase_out[MMC_TIMING_MMC_HS200] = 90;
		}
	}

555 556 557 558 559 560 561 562
	if (IS_ENABLED(CONFIG_ARCH_VERSAL) &&
	    device_is_compatible(dev, "xlnx,versal-8.9a")) {
		for (i = 0; i <= MMC_TIMING_MMC_HS400; i++) {
			clk_data->clk_phase_in[i] = versal_iclk_phases[i];
			clk_data->clk_phase_out[i] = versal_oclk_phases[i];
		}
	}

563 564 565 566 567 568 569 570 571 572 573 574 575 576 577 578 579 580 581 582 583 584 585 586
	arasan_dt_read_clk_phase(dev, MMC_TIMING_LEGACY,
				 "clk-phase-legacy");
	arasan_dt_read_clk_phase(dev, MMC_TIMING_MMC_HS,
				 "clk-phase-mmc-hs");
	arasan_dt_read_clk_phase(dev, MMC_TIMING_SD_HS,
				 "clk-phase-sd-hs");
	arasan_dt_read_clk_phase(dev, MMC_TIMING_UHS_SDR12,
				 "clk-phase-uhs-sdr12");
	arasan_dt_read_clk_phase(dev, MMC_TIMING_UHS_SDR25,
				 "clk-phase-uhs-sdr25");
	arasan_dt_read_clk_phase(dev, MMC_TIMING_UHS_SDR50,
				 "clk-phase-uhs-sdr50");
	arasan_dt_read_clk_phase(dev, MMC_TIMING_UHS_SDR104,
				 "clk-phase-uhs-sdr104");
	arasan_dt_read_clk_phase(dev, MMC_TIMING_UHS_DDR50,
				 "clk-phase-uhs-ddr50");
	arasan_dt_read_clk_phase(dev, MMC_TIMING_MMC_DDR52,
				 "clk-phase-mmc-ddr52");
	arasan_dt_read_clk_phase(dev, MMC_TIMING_MMC_HS200,
				 "clk-phase-mmc-hs200");
	arasan_dt_read_clk_phase(dev, MMC_TIMING_MMC_HS400,
				 "clk-phase-mmc-hs400");
}

587 588 589 590 591
static void arasan_sdhci_set_control_reg(struct sdhci_host *host)
{
	struct mmc *mmc = (struct mmc *)host->mmc;
	u32 reg;

592 593 594
	if (!IS_SD(mmc))
		return;

595
	if (mmc->signal_voltage == MMC_SIGNAL_VOLTAGE_180) {
596 597 598
		reg = sdhci_readw(host, SDHCI_HOST_CONTROL2);
		reg |= SDHCI_CTRL_VDD_180;
		sdhci_writew(host, reg, SDHCI_HOST_CONTROL2);
599 600 601
	}

	if (mmc->selected_mode > SD_HS &&
602
	    mmc->selected_mode <= MMC_HS_200)
603
		sdhci_set_uhs_timing(host);
604 605
}

606 607
static const struct sdhci_ops arasan_ops = {
	.platform_execute_tuning	= &arasan_sdhci_execute_tuning,
608 609 610 611 612
	.set_delay = &arasan_sdhci_set_tapdelay,
	.set_control_reg = &arasan_sdhci_set_control_reg,
};
#endif

M
Michal Simek 已提交
613
static int arasan_sdhci_probe(struct udevice *dev)
614
{
615
	struct arasan_sdhci_plat *plat = dev_get_plat(dev);
M
Michal Simek 已提交
616
	struct mmc_uclass_priv *upriv = dev_get_uclass_priv(dev);
617 618
	struct arasan_sdhci_priv *priv = dev_get_priv(dev);
	struct sdhci_host *host;
619 620
	struct clk clk;
	unsigned long clock;
621
	int ret;
622

623 624
	host = priv->host;

625 626 627 628 629 630 631 632 633 634 635
	ret = clk_get_by_index(dev, 0, &clk);
	if (ret < 0) {
		dev_err(dev, "failed to get clock\n");
		return ret;
	}

	clock = clk_get_rate(&clk);
	if (IS_ERR_VALUE(clock)) {
		dev_err(dev, "failed to get rate\n");
		return clock;
	}
636

637 638 639
	debug("%s: CLK %ld\n", __func__, clock);

	ret = clk_enable(&clk);
640
	if (ret) {
641 642 643 644
		dev_err(dev, "failed to enable clock\n");
		return ret;
	}

645
	host->quirks = SDHCI_QUIRK_WAIT_SEND_CMD |
646
		       SDHCI_QUIRK_BROKEN_R1B;
647 648

#ifdef CONFIG_ZYNQ_HISPD_BROKEN
649
	host->quirks |= SDHCI_QUIRK_BROKEN_HISPD_MODE;
650 651
#endif

652 653 654
	if (priv->no_1p8)
		host->quirks |= SDHCI_QUIRK_NO_1_8_V;

655 656 657 658 659
	plat->cfg.f_max = CONFIG_ZYNQ_SDHCI_MAX_FREQ;

	ret = mmc_of_parse(dev, &plat->cfg);
	if (ret)
		return ret;
660

661
	host->max_clk = clock;
662

663 664 665 666
	host->mmc = &plat->mmc;
	host->mmc->dev = dev;
	host->mmc->priv = host;

667
	ret = sdhci_setup_cfg(&plat->cfg, host, plat->cfg.f_max,
668
			      CONFIG_ZYNQ_SDHCI_MIN_FREQ);
669 670 671
	if (ret)
		return ret;
	upriv->mmc = host->mmc;
M
Michal Simek 已提交
672

673
	return sdhci_probe(dev);
674
}
M
Michal Simek 已提交
675

676
static int arasan_sdhci_of_to_plat(struct udevice *dev)
M
Michal Simek 已提交
677
{
678 679 680 681 682
	struct arasan_sdhci_priv *priv = dev_get_priv(dev);

	priv->host = calloc(1, sizeof(struct sdhci_host));
	if (!priv->host)
		return -1;
M
Michal Simek 已提交
683

684 685
	priv->host->name = dev->name;

686
#if defined(CONFIG_ARCH_ZYNQMP) || defined(CONFIG_ARCH_VERSAL)
687
	priv->host->ops = &arasan_ops;
688
	arasan_dt_parse_clk_phases(dev);
689
#endif
M
Michal Simek 已提交
690

691 692 693
	priv->host->ioaddr = (void *)dev_read_addr(dev);
	if (IS_ERR(priv->host->ioaddr))
		return PTR_ERR(priv->host->ioaddr);
694

695
	priv->deviceid = dev_read_u32_default(dev, "xlnx,device_id", -1);
696
	priv->bank = dev_read_u32_default(dev, "xlnx,mio-bank", 0);
697
	priv->no_1p8 = dev_read_bool(dev, "no-1-8-v");
698

M
Michal Simek 已提交
699 700 701
	return 0;
}

702 703
static int arasan_sdhci_bind(struct udevice *dev)
{
704
	struct arasan_sdhci_plat *plat = dev_get_plat(dev);
705

706
	return sdhci_bind(dev, &plat->mmc, &plat->cfg);
707 708
}

M
Michal Simek 已提交
709 710 711 712 713 714 715 716 717
static const struct udevice_id arasan_sdhci_ids[] = {
	{ .compatible = "arasan,sdhci-8.9a" },
	{ }
};

U_BOOT_DRIVER(arasan_sdhci_drv) = {
	.name		= "arasan_sdhci",
	.id		= UCLASS_MMC,
	.of_match	= arasan_sdhci_ids,
718
	.of_to_plat = arasan_sdhci_of_to_plat,
719 720
	.ops		= &sdhci_ops,
	.bind		= arasan_sdhci_bind,
M
Michal Simek 已提交
721
	.probe		= arasan_sdhci_probe,
722
	.priv_auto	= sizeof(struct arasan_sdhci_priv),
723
	.plat_auto	= sizeof(struct arasan_sdhci_plat),
M
Michal Simek 已提交
724
};