tmio_mmc_core.c 35.2 KB
Newer Older
1
/*
2 3 4
 * Driver for the MMC / SD / SDIO IP found in:
 *
 * TC6393XB, TC6391XB, TC6387XB, T7L66XB, ASIC3, SH-Mobile SoCs
5
 *
6 7
 * Copyright (C) 2016 Sang Engineering, Wolfram Sang
 * Copyright (C) 2015-16 Renesas Electronics Corporation
8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35
 * Copyright (C) 2011 Guennadi Liakhovetski
 * Copyright (C) 2007 Ian Molton
 * Copyright (C) 2004 Ian Molton
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License version 2 as
 * published by the Free Software Foundation.
 *
 * This driver draws mainly on scattered spec sheets, Reverse engineering
 * of the toshiba e800  SD driver and some parts of the 2.4 ASIC3 driver (4 bit
 * support). (Further 4 bit support from a later datasheet).
 *
 * TODO:
 *   Investigate using a workqueue for PIO transfers
 *   Eliminate FIXMEs
 *   Better Power management
 *   Handle MMC errors better
 *   double buffer support
 *
 */

#include <linux/delay.h>
#include <linux/device.h>
#include <linux/highmem.h>
#include <linux/interrupt.h>
#include <linux/io.h>
#include <linux/irq.h>
#include <linux/mfd/tmio.h>
A
Ai Kyuse 已提交
36
#include <linux/mmc/card.h>
37
#include <linux/mmc/host.h>
38
#include <linux/mmc/mmc.h>
39
#include <linux/mmc/slot-gpio.h>
40 41 42
#include <linux/module.h>
#include <linux/pagemap.h>
#include <linux/platform_device.h>
43
#include <linux/pm_qos.h>
44
#include <linux/pm_runtime.h>
45
#include <linux/regulator/consumer.h>
46
#include <linux/mmc/sdio.h>
47 48
#include <linux/scatterlist.h>
#include <linux/spinlock.h>
49
#include <linux/workqueue.h>
50 51 52

#include "tmio_mmc.h"

53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88
static inline void tmio_mmc_start_dma(struct tmio_mmc_host *host,
				      struct mmc_data *data)
{
	if (host->dma_ops)
		host->dma_ops->start(host, data);
}

static inline void tmio_mmc_enable_dma(struct tmio_mmc_host *host, bool enable)
{
	if (host->dma_ops)
		host->dma_ops->enable(host, enable);
}

static inline void tmio_mmc_request_dma(struct tmio_mmc_host *host,
					struct tmio_mmc_data *pdata)
{
	if (host->dma_ops) {
		host->dma_ops->request(host, pdata);
	} else {
		host->chan_tx = NULL;
		host->chan_rx = NULL;
	}
}

static inline void tmio_mmc_release_dma(struct tmio_mmc_host *host)
{
	if (host->dma_ops)
		host->dma_ops->release(host);
}

static inline void tmio_mmc_abort_dma(struct tmio_mmc_host *host)
{
	if (host->dma_ops)
		host->dma_ops->abort(host);
}

89 90
void tmio_mmc_enable_mmc_irqs(struct tmio_mmc_host *host, u32 i)
{
S
Simon Horman 已提交
91
	host->sdcard_irq_mask &= ~(i & TMIO_MASK_IRQ);
92
	sd_ctrl_write32_as_16_and_16(host, CTL_IRQ_MASK, host->sdcard_irq_mask);
93
}
94
EXPORT_SYMBOL(tmio_mmc_enable_mmc_irqs);
95 96 97

void tmio_mmc_disable_mmc_irqs(struct tmio_mmc_host *host, u32 i)
{
S
Simon Horman 已提交
98
	host->sdcard_irq_mask |= (i & TMIO_MASK_IRQ);
99
	sd_ctrl_write32_as_16_and_16(host, CTL_IRQ_MASK, host->sdcard_irq_mask);
100
}
101
EXPORT_SYMBOL(tmio_mmc_disable_mmc_irqs);
102 103 104

static void tmio_mmc_ack_mmc_irqs(struct tmio_mmc_host *host, u32 i)
{
105
	sd_ctrl_write32_as_16_and_16(host, CTL_STATUS, ~i);
106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122
}

static void tmio_mmc_init_sg(struct tmio_mmc_host *host, struct mmc_data *data)
{
	host->sg_len = data->sg_len;
	host->sg_ptr = data->sg;
	host->sg_orig = data->sg;
	host->sg_off = 0;
}

static int tmio_mmc_next_sg(struct tmio_mmc_host *host)
{
	host->sg_ptr = sg_next(host->sg_ptr);
	host->sg_off = 0;
	return --host->sg_len;
}

123 124
#define CMDREQ_TIMEOUT	5000

125 126 127 128 129 130 131 132 133 134 135 136 137 138
#ifdef CONFIG_MMC_DEBUG

#define STATUS_TO_TEXT(a, status, i) \
	do { \
		if (status & TMIO_STAT_##a) { \
			if (i++) \
				printk(" | "); \
			printk(#a); \
		} \
	} while (0)

static void pr_debug_status(u32 status)
{
	int i = 0;
139
	pr_debug("status: %08x = ", status);
140 141 142 143 144 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
	STATUS_TO_TEXT(CARD_REMOVE, status, i);
	STATUS_TO_TEXT(CARD_INSERT, status, i);
	STATUS_TO_TEXT(SIGSTATE, status, i);
	STATUS_TO_TEXT(WRPROTECT, status, i);
	STATUS_TO_TEXT(CARD_REMOVE_A, status, i);
	STATUS_TO_TEXT(CARD_INSERT_A, status, i);
	STATUS_TO_TEXT(SIGSTATE_A, status, i);
	STATUS_TO_TEXT(CMD_IDX_ERR, status, i);
	STATUS_TO_TEXT(STOPBIT_ERR, status, i);
	STATUS_TO_TEXT(ILL_FUNC, status, i);
	STATUS_TO_TEXT(CMD_BUSY, status, i);
	STATUS_TO_TEXT(CMDRESPEND, status, i);
	STATUS_TO_TEXT(DATAEND, status, i);
	STATUS_TO_TEXT(CRCFAIL, status, i);
	STATUS_TO_TEXT(DATATIMEOUT, status, i);
	STATUS_TO_TEXT(CMDTIMEOUT, status, i);
	STATUS_TO_TEXT(RXOVERFLOW, status, i);
	STATUS_TO_TEXT(TXUNDERRUN, status, i);
	STATUS_TO_TEXT(RXRDY, status, i);
	STATUS_TO_TEXT(TXRQ, status, i);
	STATUS_TO_TEXT(ILL_ACCESS, status, i);
	printk("\n");
}

#else
#define pr_debug_status(s)  do { } while (0)
#endif

static void tmio_mmc_enable_sdio_irq(struct mmc_host *mmc, int enable)
{
	struct tmio_mmc_host *host = mmc_priv(mmc);

172
	if (enable && !host->sdio_irq_enabled) {
173 174
		u16 sdio_status;

175 176 177
		/* Keep device active while SDIO irq is enabled */
		pm_runtime_get_sync(mmc_dev(mmc));

178
		host->sdio_irq_enabled = true;
S
Simon Horman 已提交
179 180
		host->sdio_irq_mask = TMIO_SDIO_MASK_ALL &
					~TMIO_SDIO_STAT_IOIRQ;
181 182 183 184 185 186 187

		/* Clear obsolete interrupts before enabling */
		sdio_status = sd_ctrl_read16(host, CTL_SDIO_STATUS) & ~TMIO_SDIO_MASK_ALL;
		if (host->pdata->flags & TMIO_MMC_SDIO_STATUS_SETBITS)
			sdio_status |= TMIO_SDIO_SETBITS_MASK;
		sd_ctrl_write16(host, CTL_SDIO_STATUS, sdio_status);

S
Simon Horman 已提交
188
		sd_ctrl_write16(host, CTL_SDIO_IRQ_MASK, host->sdio_irq_mask);
189
	} else if (!enable && host->sdio_irq_enabled) {
S
Simon Horman 已提交
190 191
		host->sdio_irq_mask = TMIO_SDIO_MASK_ALL;
		sd_ctrl_write16(host, CTL_SDIO_IRQ_MASK, host->sdio_irq_mask);
192 193

		host->sdio_irq_enabled = false;
194 195
		pm_runtime_mark_last_busy(mmc_dev(mmc));
		pm_runtime_put_autosuspend(mmc_dev(mmc));
196 197 198
	}
}

199 200 201 202
static void tmio_mmc_clk_start(struct tmio_mmc_host *host)
{
	sd_ctrl_write16(host, CTL_SD_CARD_CLK_CTL, CLK_CTL_SCLKEN |
		sd_ctrl_read16(host, CTL_SD_CARD_CLK_CTL));
203
	msleep(host->pdata->flags & TMIO_MMC_MIN_RCAR2 ? 1 : 10);
204 205 206 207 208 209 210

	if (host->pdata->flags & TMIO_MMC_HAVE_HIGH_REG) {
		sd_ctrl_write16(host, CTL_CLK_AND_WAIT_CTL, 0x0100);
		msleep(10);
	}
}

211 212 213 214 215 216 217 218 219
static void tmio_mmc_clk_stop(struct tmio_mmc_host *host)
{
	if (host->pdata->flags & TMIO_MMC_HAVE_HIGH_REG) {
		sd_ctrl_write16(host, CTL_CLK_AND_WAIT_CTL, 0x0000);
		msleep(10);
	}

	sd_ctrl_write16(host, CTL_SD_CARD_CLK_CTL, ~CLK_CTL_SCLKEN &
		sd_ctrl_read16(host, CTL_SD_CARD_CLK_CTL));
220
	msleep(host->pdata->flags & TMIO_MMC_MIN_RCAR2 ? 5 : 10);
221 222
}

223 224
static void tmio_mmc_set_clock(struct tmio_mmc_host *host,
				unsigned int new_clock)
225 226 227
{
	u32 clk = 0, clock;

228 229 230 231
	if (new_clock == 0) {
		tmio_mmc_clk_stop(host);
		return;
	}
232

233 234 235 236
	if (host->clk_update)
		clock = host->clk_update(host, new_clock) / 512;
	else
		clock = host->mmc->f_min;
237

238 239 240 241 242 243
	for (clk = 0x80000080; new_clock >= (clock << 1); clk >>= 1)
		clock <<= 1;

	/* 1/1 clock is option */
	if ((host->pdata->flags & TMIO_MMC_CLK_ACTUAL) && ((clk >> 22) & 0x1))
		clk |= 0xff;
244 245

	if (host->set_clk_div)
246
		host->set_clk_div(host->pdev, (clk >> 22) & 1);
247

248 249
	sd_ctrl_write16(host, CTL_SD_CARD_CLK_CTL, ~CLK_CTL_SCLKEN &
			sd_ctrl_read16(host, CTL_SD_CARD_CLK_CTL));
250
	sd_ctrl_write16(host, CTL_SD_CARD_CLK_CTL, clk & CLK_CTL_DIV_MASK);
251
	if (!(host->pdata->flags & TMIO_MMC_MIN_RCAR2))
252
		msleep(10);
253 254

	tmio_mmc_clk_start(host);
255 256 257 258 259 260
}

static void tmio_mmc_reset(struct tmio_mmc_host *host)
{
	/* FIXME - should we set stop clock reg here */
	sd_ctrl_write16(host, CTL_RESET_SD, 0x0000);
261
	if (host->pdata->flags & TMIO_MMC_HAVE_HIGH_REG)
262
		sd_ctrl_write16(host, CTL_RESET_SDIO, 0x0000);
263 264
	msleep(10);
	sd_ctrl_write16(host, CTL_RESET_SD, 0x0001);
265
	if (host->pdata->flags & TMIO_MMC_HAVE_HIGH_REG)
266
		sd_ctrl_write16(host, CTL_RESET_SDIO, 0x0001);
267 268 269 270 271 272 273 274 275 276 277 278 279
	msleep(10);
}

static void tmio_mmc_reset_work(struct work_struct *work)
{
	struct tmio_mmc_host *host = container_of(work, struct tmio_mmc_host,
						  delayed_reset_work.work);
	struct mmc_request *mrq;
	unsigned long flags;

	spin_lock_irqsave(&host->lock, flags);
	mrq = host->mrq;

280 281 282 283 284 285
	/*
	 * is request already finished? Since we use a non-blocking
	 * cancel_delayed_work(), it can happen, that a .set_ios() call preempts
	 * us, so, have to check for IS_ERR(host->mrq)
	 */
	if (IS_ERR_OR_NULL(mrq)
286
	    || time_is_after_jiffies(host->last_req_ts +
287
		msecs_to_jiffies(CMDREQ_TIMEOUT))) {
288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310
		spin_unlock_irqrestore(&host->lock, flags);
		return;
	}

	dev_warn(&host->pdev->dev,
		"timeout waiting for hardware interrupt (CMD%u)\n",
		mrq->cmd->opcode);

	if (host->data)
		host->data->error = -ETIMEDOUT;
	else if (host->cmd)
		host->cmd->error = -ETIMEDOUT;
	else
		mrq->cmd->error = -ETIMEDOUT;

	host->cmd = NULL;
	host->data = NULL;
	host->force_pio = false;

	spin_unlock_irqrestore(&host->lock, flags);

	tmio_mmc_reset(host);

311 312 313
	/* Ready for new calls */
	host->mrq = NULL;

314
	tmio_mmc_abort_dma(host);
315 316 317
	mmc_request_done(host->mmc, mrq);
}

318
/* called with host->lock held, interrupts disabled */
319 320
static void tmio_mmc_finish_request(struct tmio_mmc_host *host)
{
321 322
	struct mmc_request *mrq;
	unsigned long flags;
323

324 325 326 327 328
	spin_lock_irqsave(&host->lock, flags);

	mrq = host->mrq;
	if (IS_ERR_OR_NULL(mrq)) {
		spin_unlock_irqrestore(&host->lock, flags);
329
		return;
330
	}
331 332 333 334 335 336 337

	host->cmd = NULL;
	host->data = NULL;
	host->force_pio = false;

	cancel_delayed_work(&host->delayed_reset_work);

338
	host->mrq = NULL;
339
	spin_unlock_irqrestore(&host->lock, flags);
340

341 342 343
	if (mrq->cmd->error || (mrq->data && mrq->data->error))
		tmio_mmc_abort_dma(host);

A
Ai Kyuse 已提交
344 345 346
	if (host->check_scc_error)
		host->check_scc_error(host);

347 348 349
	mmc_request_done(host->mmc, mrq);
}

350 351 352 353 354 355 356
static void tmio_mmc_done_work(struct work_struct *work)
{
	struct tmio_mmc_host *host = container_of(work, struct tmio_mmc_host,
						  done);
	tmio_mmc_finish_request(host);
}

357 358 359 360 361 362 363 364 365 366 367 368
/* These are the bitmasks the tmio chip requires to implement the MMC response
 * types. Note that R1 and R6 are the same in this scheme. */
#define APP_CMD        0x0040
#define RESP_NONE      0x0300
#define RESP_R1        0x0400
#define RESP_R1B       0x0500
#define RESP_R2        0x0600
#define RESP_R3        0x0700
#define DATA_PRESENT   0x0800
#define TRANSFER_READ  0x1000
#define TRANSFER_MULTI 0x2000
#define SECURITY_CMD   0x4000
369
#define NO_CMD12_ISSUE 0x4000 /* TMIO_MMC_HAVE_CMD12_CTRL */
370 371 372 373 374

static int tmio_mmc_start_command(struct tmio_mmc_host *host, struct mmc_command *cmd)
{
	struct mmc_data *data = host->data;
	int c = cmd->opcode;
375
	u32 irq_mask = TMIO_MASK_CMD;
376

377 378
	/* CMD12 is handled by hardware */
	if (cmd->opcode == MMC_STOP_TRANSMISSION && !cmd->arg) {
379
		sd_ctrl_write16(host, CTL_STOP_INTERNAL_ACTION, TMIO_STOP_STP);
380 381 382 383 384
		return 0;
	}

	switch (mmc_resp_type(cmd)) {
	case MMC_RSP_NONE: c |= RESP_NONE; break;
W
Wolfram Sang 已提交
385 386 387
	case MMC_RSP_R1:
	case MMC_RSP_R1_NO_CRC:
			   c |= RESP_R1;   break;
388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405
	case MMC_RSP_R1B:  c |= RESP_R1B;  break;
	case MMC_RSP_R2:   c |= RESP_R2;   break;
	case MMC_RSP_R3:   c |= RESP_R3;   break;
	default:
		pr_debug("Unknown response type %d\n", mmc_resp_type(cmd));
		return -EINVAL;
	}

	host->cmd = cmd;

/* FIXME - this seems to be ok commented out but the spec suggest this bit
 *         should be set when issuing app commands.
 *	if(cmd->flags & MMC_FLAG_ACMD)
 *		c |= APP_CMD;
 */
	if (data) {
		c |= DATA_PRESENT;
		if (data->blocks > 1) {
406
			sd_ctrl_write16(host, CTL_STOP_INTERNAL_ACTION, TMIO_STOP_SEC);
407
			c |= TRANSFER_MULTI;
408 409 410 411 412 413 414 415

			/*
			 * Disable auto CMD12 at IO_RW_EXTENDED when
			 * multiple block transfer
			 */
			if ((host->pdata->flags & TMIO_MMC_HAVE_CMD12_CTRL) &&
			    (cmd->opcode == SD_IO_RW_EXTENDED))
				c |= NO_CMD12_ISSUE;
416 417 418 419 420
		}
		if (data->flags & MMC_DATA_READ)
			c |= TRANSFER_READ;
	}

421 422 423
	if (!host->native_hotplug)
		irq_mask &= ~(TMIO_STAT_CARD_REMOVE | TMIO_STAT_CARD_INSERT);
	tmio_mmc_enable_mmc_irqs(host, irq_mask);
424 425

	/* Fire off the command */
426
	sd_ctrl_write32_as_16_and_16(host, CTL_ARG_REG, cmd->arg);
427 428 429 430 431
	sd_ctrl_write16(host, CTL_SD_CMD, c);

	return 0;
}

432 433 434 435 436 437 438 439 440 441
static void tmio_mmc_transfer_data(struct tmio_mmc_host *host,
				   unsigned short *buf,
				   unsigned int count)
{
	int is_read = host->data->flags & MMC_DATA_READ;
	u8  *buf8;

	/*
	 * Transfer the data
	 */
442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470 471
	if (host->pdata->flags & TMIO_MMC_32BIT_DATA_PORT) {
		u8 data[4] = { };

		if (is_read)
			sd_ctrl_read32_rep(host, CTL_SD_DATA_PORT, (u32 *)buf,
					   count >> 2);
		else
			sd_ctrl_write32_rep(host, CTL_SD_DATA_PORT, (u32 *)buf,
					    count >> 2);

		/* if count was multiple of 4 */
		if (!(count & 0x3))
			return;

		buf8 = (u8 *)(buf + (count >> 2));
		count %= 4;

		if (is_read) {
			sd_ctrl_read32_rep(host, CTL_SD_DATA_PORT,
					   (u32 *)data, 1);
			memcpy(buf8, data, count);
		} else {
			memcpy(data, buf8, count);
			sd_ctrl_write32_rep(host, CTL_SD_DATA_PORT,
					    (u32 *)data, 1);
		}

		return;
	}

472 473 474 475 476 477 478 479 480 481 482 483 484 485 486 487 488 489 490 491 492 493 494 495
	if (is_read)
		sd_ctrl_read16_rep(host, CTL_SD_DATA_PORT, buf, count >> 1);
	else
		sd_ctrl_write16_rep(host, CTL_SD_DATA_PORT, buf, count >> 1);

	/* if count was even number */
	if (!(count & 0x1))
		return;

	/* if count was odd number */
	buf8 = (u8 *)(buf + (count >> 1));

	/*
	 * FIXME
	 *
	 * driver and this function are assuming that
	 * it is used as little endian
	 */
	if (is_read)
		*buf8 = sd_ctrl_read16(host, CTL_SD_DATA_PORT) & 0xff;
	else
		sd_ctrl_write16(host, CTL_SD_DATA_PORT, *buf8);
}

496 497 498
/*
 * This chip always returns (at least?) as much data as you ask for.
 * I'm unsure what happens if you ask for less than a block. This should be
L
Lucas De Marchi 已提交
499
 * looked into to ensure that a funny length read doesn't hose the controller.
500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515 516 517 518 519 520 521 522 523 524 525 526 527
 */
static void tmio_mmc_pio_irq(struct tmio_mmc_host *host)
{
	struct mmc_data *data = host->data;
	void *sg_virt;
	unsigned short *buf;
	unsigned int count;
	unsigned long flags;

	if ((host->chan_tx || host->chan_rx) && !host->force_pio) {
		pr_err("PIO IRQ in DMA mode!\n");
		return;
	} else if (!data) {
		pr_debug("Spurious PIO IRQ\n");
		return;
	}

	sg_virt = tmio_mmc_kmap_atomic(host->sg_ptr, &flags);
	buf = (unsigned short *)(sg_virt + host->sg_off);

	count = host->sg_ptr->length - host->sg_off;
	if (count > data->blksz)
		count = data->blksz;

	pr_debug("count: %08x offset: %08x flags %08x\n",
		 count, host->sg_off, data->flags);

	/* Transfer the data */
528
	tmio_mmc_transfer_data(host, buf, count);
529 530 531 532 533 534 535 536 537 538 539 540 541 542 543 544 545 546 547 548 549 550 551 552 553 554 555 556 557 558 559 560 561 562 563 564 565 566 567 568 569 570 571 572 573 574 575 576 577 578 579 580 581 582 583 584 585 586 587 588 589 590 591

	host->sg_off += count;

	tmio_mmc_kunmap_atomic(host->sg_ptr, &flags, sg_virt);

	if (host->sg_off == host->sg_ptr->length)
		tmio_mmc_next_sg(host);

	return;
}

static void tmio_mmc_check_bounce_buffer(struct tmio_mmc_host *host)
{
	if (host->sg_ptr == &host->bounce_sg) {
		unsigned long flags;
		void *sg_vaddr = tmio_mmc_kmap_atomic(host->sg_orig, &flags);
		memcpy(sg_vaddr, host->bounce_buf, host->bounce_sg.length);
		tmio_mmc_kunmap_atomic(host->sg_orig, &flags, sg_vaddr);
	}
}

/* needs to be called with host->lock held */
void tmio_mmc_do_data_irq(struct tmio_mmc_host *host)
{
	struct mmc_data *data = host->data;
	struct mmc_command *stop;

	host->data = NULL;

	if (!data) {
		dev_warn(&host->pdev->dev, "Spurious data end IRQ\n");
		return;
	}
	stop = data->stop;

	/* FIXME - return correct transfer count on errors */
	if (!data->error)
		data->bytes_xfered = data->blocks * data->blksz;
	else
		data->bytes_xfered = 0;

	pr_debug("Completed data request\n");

	/*
	 * FIXME: other drivers allow an optional stop command of any given type
	 *        which we dont do, as the chip can auto generate them.
	 *        Perhaps we can be smarter about when to use auto CMD12 and
	 *        only issue the auto request when we know this is the desired
	 *        stop command, allowing fallback to the stop command the
	 *        upper layers expect. For now, we do what works.
	 */

	if (data->flags & MMC_DATA_READ) {
		if (host->chan_rx && !host->force_pio)
			tmio_mmc_check_bounce_buffer(host);
		dev_dbg(&host->pdev->dev, "Complete Rx request %p\n",
			host->mrq);
	} else {
		dev_dbg(&host->pdev->dev, "Complete Tx request %p\n",
			host->mrq);
	}

	if (stop) {
592 593 594 595
		if (stop->opcode != MMC_STOP_TRANSMISSION || stop->arg)
			dev_err(&host->pdev->dev, "unsupported stop: CMD%u,0x%x. We did CMD12,0\n",
				stop->opcode, stop->arg);

596 597 598
		/* fill in response from auto CMD12 */
		stop->resp[0] = sd_ctrl_read16_and_16_as_32(host, CTL_RESPONSE);

599
		sd_ctrl_write16(host, CTL_STOP_INTERNAL_ACTION, 0);
600 601
	}

602
	schedule_work(&host->done);
603
}
604
EXPORT_SYMBOL(tmio_mmc_do_data_irq);
605

606
static void tmio_mmc_data_irq(struct tmio_mmc_host *host, unsigned int stat)
607 608 609 610 611 612 613 614
{
	struct mmc_data *data;
	spin_lock(&host->lock);
	data = host->data;

	if (!data)
		goto out;

615 616 617
	if (stat & TMIO_STAT_CRCFAIL || stat & TMIO_STAT_STOPBIT_ERR ||
	    stat & TMIO_STAT_TXUNDERRUN)
		data->error = -EILSEQ;
618
	if (host->chan_tx && (data->flags & MMC_DATA_WRITE) && !host->force_pio) {
619
		u32 status = sd_ctrl_read16_and_16_as_32(host, CTL_STATUS);
620 621
		bool done = false;

622 623 624 625 626 627 628 629
		/*
		 * Has all data been written out yet? Testing on SuperH showed,
		 * that in most cases the first interrupt comes already with the
		 * BUSY status bit clear, but on some operations, like mount or
		 * in the beginning of a write / sync / umount, there is one
		 * DATAEND interrupt with the BUSY bit set, in this cases
		 * waiting for one more interrupt fixes the problem.
		 */
630
		if (host->pdata->flags & TMIO_MMC_HAS_IDLE_WAIT) {
631
			if (status & TMIO_STAT_SCLKDIVEN)
632 633 634 635 636 637 638
				done = true;
		} else {
			if (!(status & TMIO_STAT_CMD_BUSY))
				done = true;
		}

		if (done) {
639
			tmio_mmc_disable_mmc_irqs(host, TMIO_STAT_DATAEND);
640
			complete(&host->dma_dataend);
641 642 643
		}
	} else if (host->chan_rx && (data->flags & MMC_DATA_READ) && !host->force_pio) {
		tmio_mmc_disable_mmc_irqs(host, TMIO_STAT_DATAEND);
644
		complete(&host->dma_dataend);
645 646 647 648 649 650 651 652 653 654 655 656 657 658 659 660 661 662 663 664 665 666 667 668 669 670 671
	} else {
		tmio_mmc_do_data_irq(host);
		tmio_mmc_disable_mmc_irqs(host, TMIO_MASK_READOP | TMIO_MASK_WRITEOP);
	}
out:
	spin_unlock(&host->lock);
}

static void tmio_mmc_cmd_irq(struct tmio_mmc_host *host,
	unsigned int stat)
{
	struct mmc_command *cmd = host->cmd;
	int i, addr;

	spin_lock(&host->lock);

	if (!host->cmd) {
		pr_debug("Spurious CMD irq\n");
		goto out;
	}

	/* This controller is sicker than the PXA one. Not only do we need to
	 * drop the top 8 bits of the first response word, we also need to
	 * modify the order of the response for short response command types.
	 */

	for (i = 3, addr = CTL_RESPONSE ; i >= 0 ; i--, addr += 4)
672
		cmd->resp[i] = sd_ctrl_read16_and_16_as_32(host, addr);
673 674 675 676 677 678 679 680 681 682 683 684

	if (cmd->flags &  MMC_RSP_136) {
		cmd->resp[0] = (cmd->resp[0] << 8) | (cmd->resp[1] >> 24);
		cmd->resp[1] = (cmd->resp[1] << 8) | (cmd->resp[2] >> 24);
		cmd->resp[2] = (cmd->resp[2] << 8) | (cmd->resp[3] >> 24);
		cmd->resp[3] <<= 8;
	} else if (cmd->flags & MMC_RSP_R3) {
		cmd->resp[0] = cmd->resp[3];
	}

	if (stat & TMIO_STAT_CMDTIMEOUT)
		cmd->error = -ETIMEDOUT;
685 686 687
	else if ((stat & TMIO_STAT_CRCFAIL && cmd->flags & MMC_RSP_CRC) ||
		 stat & TMIO_STAT_STOPBIT_ERR ||
		 stat & TMIO_STAT_CMD_IDX_ERR)
688 689 690 691 692 693
		cmd->error = -EILSEQ;

	/* If there is data to handle we enable data IRQs here, and
	 * we will ultimatley finish the request in the data_end handler.
	 * If theres no data or we encountered an error, finish now.
	 */
694
	if (host->data && (!cmd->error || cmd->error == -EILSEQ)) {
695 696 697 698 699 700 701 702 703 704 705 706
		if (host->data->flags & MMC_DATA_READ) {
			if (host->force_pio || !host->chan_rx)
				tmio_mmc_enable_mmc_irqs(host, TMIO_MASK_READOP);
			else
				tasklet_schedule(&host->dma_issue);
		} else {
			if (host->force_pio || !host->chan_tx)
				tmio_mmc_enable_mmc_irqs(host, TMIO_MASK_WRITEOP);
			else
				tasklet_schedule(&host->dma_issue);
		}
	} else {
707
		schedule_work(&host->done);
708 709 710 711 712 713
	}

out:
	spin_unlock(&host->lock);
}

714 715 716 717
static bool __tmio_mmc_card_detect_irq(struct tmio_mmc_host *host,
				      int ireg, int status)
{
	struct mmc_host *mmc = host->mmc;
718

719 720 721 722
	/* Card insert / remove attempts */
	if (ireg & (TMIO_STAT_CARD_INSERT | TMIO_STAT_CARD_REMOVE)) {
		tmio_mmc_ack_mmc_irqs(host, TMIO_STAT_CARD_INSERT |
			TMIO_STAT_CARD_REMOVE);
723 724 725
		if ((((ireg & TMIO_STAT_CARD_REMOVE) && mmc->card) ||
		     ((ireg & TMIO_STAT_CARD_INSERT) && !mmc->card)) &&
		    !work_pending(&mmc->detect.work))
726
			mmc_detect_change(host->mmc, msecs_to_jiffies(100));
727
		return true;
728 729
	}

730 731 732 733 734 735
	return false;
}

static bool __tmio_mmc_sdcard_irq(struct tmio_mmc_host *host,
				 int ireg, int status)
{
736 737 738 739 740 741
	/* Command completion */
	if (ireg & (TMIO_STAT_CMDRESPEND | TMIO_STAT_CMDTIMEOUT)) {
		tmio_mmc_ack_mmc_irqs(host,
			     TMIO_STAT_CMDRESPEND |
			     TMIO_STAT_CMDTIMEOUT);
		tmio_mmc_cmd_irq(host, status);
742
		return true;
743
	}
744

745 746 747 748
	/* Data transfer */
	if (ireg & (TMIO_STAT_RXRDY | TMIO_STAT_TXRQ)) {
		tmio_mmc_ack_mmc_irqs(host, TMIO_STAT_RXRDY | TMIO_STAT_TXRQ);
		tmio_mmc_pio_irq(host);
749
		return true;
750
	}
751

752 753 754
	/* Data transfer completion */
	if (ireg & TMIO_STAT_DATAEND) {
		tmio_mmc_ack_mmc_irqs(host, TMIO_STAT_DATAEND);
755
		tmio_mmc_data_irq(host, status);
756
		return true;
757
	}
758

759 760 761
	return false;
}

762
static void __tmio_mmc_sdio_irq(struct tmio_mmc_host *host)
763 764 765 766
{
	struct mmc_host *mmc = host->mmc;
	struct tmio_mmc_data *pdata = host->pdata;
	unsigned int ireg, status;
767
	unsigned int sdio_status;
768 769

	if (!(pdata->flags & TMIO_MMC_SDIO_IRQ))
770
		return;
771 772

	status = sd_ctrl_read16(host, CTL_SDIO_STATUS);
773
	ireg = status & TMIO_SDIO_MASK_ALL & ~host->sdio_irq_mask;
774

775
	sdio_status = status & ~TMIO_SDIO_MASK_ALL;
776
	if (pdata->flags & TMIO_MMC_SDIO_STATUS_SETBITS)
777
		sdio_status |= TMIO_SDIO_SETBITS_MASK;
778 779

	sd_ctrl_write16(host, CTL_SDIO_STATUS, sdio_status);
780 781 782 783 784 785 786 787 788 789

	if (mmc->caps & MMC_CAP_SDIO_IRQ && ireg & TMIO_SDIO_STAT_IOIRQ)
		mmc_signal_sdio_irq(mmc);
}

irqreturn_t tmio_mmc_irq(int irq, void *devid)
{
	struct tmio_mmc_host *host = devid;
	unsigned int ireg, status;

790
	status = sd_ctrl_read16_and_16_as_32(host, CTL_STATUS);
W
Wolfram Sang 已提交
791 792 793 794 795 796
	ireg = status & TMIO_MASK_IRQ & ~host->sdcard_irq_mask;

	pr_debug_status(status);
	pr_debug_status(ireg);

	/* Clear the status except the interrupt status */
797
	sd_ctrl_write32_as_16_and_16(host, CTL_STATUS, TMIO_MASK_IRQ);
798 799 800 801 802 803

	if (__tmio_mmc_card_detect_irq(host, ireg, status))
		return IRQ_HANDLED;
	if (__tmio_mmc_sdcard_irq(host, ireg, status))
		return IRQ_HANDLED;

804
	__tmio_mmc_sdio_irq(host);
805 806 807

	return IRQ_HANDLED;
}
808
EXPORT_SYMBOL(tmio_mmc_irq);
809 810 811 812 813 814 815 816 817

static int tmio_mmc_start_data(struct tmio_mmc_host *host,
	struct mmc_data *data)
{
	struct tmio_mmc_data *pdata = host->pdata;

	pr_debug("setup data transfer: blocksize %08x  nr_blocks %d\n",
		 data->blksz, data->blocks);

W
Wolfram Sang 已提交
818 819 820
	/* Some hardware cannot perform 2 byte requests in 4/8 bit mode */
	if (host->mmc->ios.bus_width == MMC_BUS_WIDTH_4 ||
	    host->mmc->ios.bus_width == MMC_BUS_WIDTH_8) {
821 822 823
		int blksz_2bytes = pdata->flags & TMIO_MMC_BLKSZ_2BYTES;

		if (data->blksz < 2 || (data->blksz < 4 && !blksz_2bytes)) {
W
Wolfram Sang 已提交
824
			pr_err("%s: %d byte block unsupported in 4/8 bit mode\n",
825 826 827 828 829 830 831 832 833 834 835 836 837 838 839 840 841
			       mmc_hostname(host->mmc), data->blksz);
			return -EINVAL;
		}
	}

	tmio_mmc_init_sg(host, data);
	host->data = data;

	/* Set transfer length / blocksize */
	sd_ctrl_write16(host, CTL_SD_XFER_LEN, data->blksz);
	sd_ctrl_write16(host, CTL_XFER_BLK_COUNT, data->blocks);

	tmio_mmc_start_dma(host, data);

	return 0;
}

A
Ai Kyuse 已提交
842 843 844 845 846 847 848 849
static void tmio_mmc_hw_reset(struct mmc_host *mmc)
{
	struct tmio_mmc_host *host = mmc_priv(mmc);

	if (host->hw_reset)
		host->hw_reset(host);
}

A
Ai Kyuse 已提交
850 851 852 853 854
static int tmio_mmc_execute_tuning(struct mmc_host *mmc, u32 opcode)
{
	struct tmio_mmc_host *host = mmc_priv(mmc);
	int i, ret = 0;

855 856 857
	if (!host->init_tuning || !host->select_tuning)
		/* Tuning is not supported */
		goto out;
A
Ai Kyuse 已提交
858

859 860 861 862
	host->tap_num = host->init_tuning(host);
	if (!host->tap_num)
		/* Tuning is not supported */
		goto out;
A
Ai Kyuse 已提交
863 864 865 866 867 868 869 870 871 872 873 874 875 876 877 878 879 880 881 882 883 884 885 886 887 888 889 890 891 892 893 894 895 896

	if (host->tap_num * 2 >= sizeof(host->taps) * BITS_PER_BYTE) {
		dev_warn_once(&host->pdev->dev,
		      "Too many taps, skipping tuning. Please consider updating size of taps field of tmio_mmc_host\n");
		goto out;
	}

	bitmap_zero(host->taps, host->tap_num * 2);

	/* Issue CMD19 twice for each tap */
	for (i = 0; i < 2 * host->tap_num; i++) {
		if (host->prepare_tuning)
			host->prepare_tuning(host, i % host->tap_num);

		ret = mmc_send_tuning(mmc, opcode, NULL);
		if (ret && ret != -EILSEQ)
			goto out;
		if (ret == 0)
			set_bit(i, host->taps);

		mdelay(1);
	}

	ret = host->select_tuning(host);

out:
	if (ret < 0) {
		dev_warn(&host->pdev->dev, "Tuning procedure failed\n");
		tmio_mmc_hw_reset(mmc);
	}

	return ret;
}

897 898 899 900
/* Process requests from the MMC layer */
static void tmio_mmc_request(struct mmc_host *mmc, struct mmc_request *mrq)
{
	struct tmio_mmc_host *host = mmc_priv(mmc);
901
	unsigned long flags;
902 903
	int ret;

904 905 906
	spin_lock_irqsave(&host->lock, flags);

	if (host->mrq) {
907
		pr_debug("request not null\n");
908 909 910 911 912 913 914
		if (IS_ERR(host->mrq)) {
			spin_unlock_irqrestore(&host->lock, flags);
			mrq->cmd->error = -EAGAIN;
			mmc_request_done(mmc, mrq);
			return;
		}
	}
915 916 917 918 919

	host->last_req_ts = jiffies;
	wmb();
	host->mrq = mrq;

920 921
	spin_unlock_irqrestore(&host->lock, flags);

922 923 924 925 926 927 928
	if (mrq->data) {
		ret = tmio_mmc_start_data(host, mrq->data);
		if (ret)
			goto fail;
	}

	ret = tmio_mmc_start_command(host, mrq->cmd);
929 930 931 932 933 934
	if (ret)
		goto fail;

	schedule_delayed_work(&host->delayed_reset_work,
			      msecs_to_jiffies(CMDREQ_TIMEOUT));
	return;
935 936 937

fail:
	host->force_pio = false;
938
	host->mrq = NULL;
939 940 941 942
	mrq->cmd->error = ret;
	mmc_request_done(mmc, mrq);
}

943
static int tmio_mmc_clk_enable(struct tmio_mmc_host *host)
944
{
945
	if (!host->clk_enable)
946 947
		return -ENOTSUPP;

948
	return host->clk_enable(host);
949 950
}

951 952 953 954 955 956
static void tmio_mmc_clk_disable(struct tmio_mmc_host *host)
{
	if (host->clk_disable)
		host->clk_disable(host);
}

957
static void tmio_mmc_power_on(struct tmio_mmc_host *host, unsigned short vdd)
958 959
{
	struct mmc_host *mmc = host->mmc;
960 961 962
	int ret = 0;

	/* .set_ios() is returning void, so, no chance to report an error */
963

964 965 966
	if (host->set_pwr)
		host->set_pwr(host->pdev, 1);

967 968 969 970 971 972 973 974 975 976 977 978 979 980 981
	if (!IS_ERR(mmc->supply.vmmc)) {
		ret = mmc_regulator_set_ocr(mmc, mmc->supply.vmmc, vdd);
		/*
		 * Attention: empiric value. With a b43 WiFi SDIO card this
		 * delay proved necessary for reliable card-insertion probing.
		 * 100us were not enough. Is this the same 140us delay, as in
		 * tmio_mmc_set_ios()?
		 */
		udelay(200);
	}
	/*
	 * It seems, VccQ should be switched on after Vcc, this is also what the
	 * omap_hsmmc.c driver does.
	 */
	if (!IS_ERR(mmc->supply.vqmmc) && !ret) {
982
		ret = regulator_enable(mmc->supply.vqmmc);
983 984
		udelay(200);
	}
985 986 987 988

	if (ret < 0)
		dev_dbg(&host->pdev->dev, "Regulators failed to power up: %d\n",
			ret);
989 990 991 992 993 994 995 996 997
}

static void tmio_mmc_power_off(struct tmio_mmc_host *host)
{
	struct mmc_host *mmc = host->mmc;

	if (!IS_ERR(mmc->supply.vqmmc))
		regulator_disable(mmc->supply.vqmmc);

998
	if (!IS_ERR(mmc->supply.vmmc))
999
		mmc_regulator_set_ocr(mmc, mmc->supply.vmmc, 0);
1000 1001 1002

	if (host->set_pwr)
		host->set_pwr(host->pdev, 0);
1003 1004
}

1005 1006 1007
static void tmio_mmc_set_bus_width(struct tmio_mmc_host *host,
				unsigned char bus_width)
{
W
Wolfram Sang 已提交
1008 1009 1010 1011 1012 1013 1014 1015 1016 1017
	u16 reg = sd_ctrl_read16(host, CTL_SD_MEM_CARD_OPT)
				& ~(CARD_OPT_WIDTH | CARD_OPT_WIDTH8);

	/* reg now applies to MMC_BUS_WIDTH_4 */
	if (bus_width == MMC_BUS_WIDTH_1)
		reg |= CARD_OPT_WIDTH;
	else if (bus_width == MMC_BUS_WIDTH_8)
		reg |= CARD_OPT_WIDTH8;

	sd_ctrl_write16(host, CTL_SD_MEM_CARD_OPT, reg);
1018 1019
}

1020 1021 1022 1023 1024 1025 1026 1027 1028
/* Set MMC clock / power.
 * Note: This controller uses a simple divider scheme therefore it cannot
 * run a MMC card at full speed (20MHz). The max clock is 24MHz on SD, but as
 * MMC wont run that fast, it has to be clocked at 12MHz which is the next
 * slowest setting.
 */
static void tmio_mmc_set_ios(struct mmc_host *mmc, struct mmc_ios *ios)
{
	struct tmio_mmc_host *host = mmc_priv(mmc);
1029
	struct device *dev = &host->pdev->dev;
1030 1031
	unsigned long flags;

1032 1033
	mutex_lock(&host->ios_lock);

1034 1035 1036
	spin_lock_irqsave(&host->lock, flags);
	if (host->mrq) {
		if (IS_ERR(host->mrq)) {
1037
			dev_dbg(dev,
1038 1039 1040 1041 1042
				"%s.%d: concurrent .set_ios(), clk %u, mode %u\n",
				current->comm, task_pid_nr(current),
				ios->clock, ios->power_mode);
			host->mrq = ERR_PTR(-EINTR);
		} else {
1043
			dev_dbg(dev,
1044 1045 1046 1047 1048
				"%s.%d: CMD%u active since %lu, now %lu!\n",
				current->comm, task_pid_nr(current),
				host->mrq->cmd->opcode, host->last_req_ts, jiffies);
		}
		spin_unlock_irqrestore(&host->lock, flags);
1049 1050

		mutex_unlock(&host->ios_lock);
1051 1052 1053 1054 1055 1056
		return;
	}

	host->mrq = ERR_PTR(-EBUSY);

	spin_unlock_irqrestore(&host->lock, flags);
1057

1058 1059 1060 1061 1062 1063 1064
	switch (ios->power_mode) {
	case MMC_POWER_OFF:
		tmio_mmc_power_off(host);
		tmio_mmc_clk_stop(host);
		break;
	case MMC_POWER_UP:
		tmio_mmc_power_on(host, ios->vdd);
1065
		tmio_mmc_set_clock(host, ios->clock);
1066
		tmio_mmc_set_bus_width(host, ios->bus_width);
1067 1068 1069 1070 1071 1072
		break;
	case MMC_POWER_ON:
		tmio_mmc_set_clock(host, ios->clock);
		tmio_mmc_set_bus_width(host, ios->bus_width);
		break;
	}
1073 1074 1075

	/* Let things settle. delay taken from winCE driver */
	udelay(140);
1076 1077 1078 1079 1080 1081
	if (PTR_ERR(host->mrq) == -EINTR)
		dev_dbg(&host->pdev->dev,
			"%s.%d: IOS interrupted: clk %u, mode %u",
			current->comm, task_pid_nr(current),
			ios->clock, ios->power_mode);
	host->mrq = NULL;
1082

1083 1084
	host->clk_cache = ios->clock;

1085
	mutex_unlock(&host->ios_lock);
1086 1087 1088 1089 1090 1091
}

static int tmio_mmc_get_ro(struct mmc_host *mmc)
{
	struct tmio_mmc_host *host = mmc_priv(mmc);
	struct tmio_mmc_data *pdata = host->pdata;
1092 1093 1094
	int ret = mmc_gpio_get_ro(mmc);
	if (ret >= 0)
		return ret;
1095

1096
	ret = !((pdata->flags & TMIO_MMC_WRPROTECT_DISABLE) ||
1097
		(sd_ctrl_read16_and_16_as_32(host, CTL_STATUS) & TMIO_STAT_WRPROTECT));
1098 1099

	return ret;
1100 1101
}

1102 1103 1104 1105 1106
static int tmio_multi_io_quirk(struct mmc_card *card,
			       unsigned int direction, int blk_size)
{
	struct tmio_mmc_host *host = mmc_priv(card->host);

1107 1108
	if (host->multi_io_quirk)
		return host->multi_io_quirk(card, direction, blk_size);
1109 1110 1111 1112

	return blk_size;
}

W
Wolfram Sang 已提交
1113
static struct mmc_host_ops tmio_mmc_ops = {
1114 1115 1116
	.request	= tmio_mmc_request,
	.set_ios	= tmio_mmc_set_ios,
	.get_ro         = tmio_mmc_get_ro,
1117
	.get_cd		= mmc_gpio_get_cd,
1118
	.enable_sdio_irq = tmio_mmc_enable_sdio_irq,
1119
	.multi_io_quirk	= tmio_multi_io_quirk,
A
Ai Kyuse 已提交
1120
	.hw_reset	= tmio_mmc_hw_reset,
A
Ai Kyuse 已提交
1121
	.execute_tuning = tmio_mmc_execute_tuning,
1122 1123
};

1124
static int tmio_mmc_init_ocr(struct tmio_mmc_host *host)
1125 1126 1127 1128 1129 1130
{
	struct tmio_mmc_data *pdata = host->pdata;
	struct mmc_host *mmc = host->mmc;

	mmc_regulator_get_supply(mmc);

1131
	/* use ocr_mask if no regulator */
1132
	if (!mmc->ocr_avail)
1133 1134 1135 1136 1137 1138 1139 1140 1141 1142
		mmc->ocr_avail =  pdata->ocr_mask;

	/*
	 * try again.
	 * There is possibility that regulator has not been probed
	 */
	if (!mmc->ocr_avail)
		return -EPROBE_DEFER;

	return 0;
1143 1144
}

1145 1146 1147 1148 1149 1150 1151 1152 1153 1154 1155
static void tmio_mmc_of_parse(struct platform_device *pdev,
			      struct tmio_mmc_data *pdata)
{
	const struct device_node *np = pdev->dev.of_node;
	if (!np)
		return;

	if (of_get_property(np, "toshiba,mmc-wrprotect-disable", NULL))
		pdata->flags |= TMIO_MMC_WRPROTECT_DISABLE;
}

1156 1157
struct tmio_mmc_host*
tmio_mmc_host_alloc(struct platform_device *pdev)
1158
{
1159
	struct tmio_mmc_host *host;
1160
	struct mmc_host *mmc;
1161 1162 1163 1164 1165 1166 1167 1168 1169 1170 1171 1172 1173 1174 1175 1176 1177 1178 1179 1180

	mmc = mmc_alloc_host(sizeof(struct tmio_mmc_host), &pdev->dev);
	if (!mmc)
		return NULL;

	host = mmc_priv(mmc);
	host->mmc = mmc;
	host->pdev = pdev;

	return host;
}
EXPORT_SYMBOL(tmio_mmc_host_alloc);

void tmio_mmc_host_free(struct tmio_mmc_host *host)
{
	mmc_free_host(host->mmc);
}
EXPORT_SYMBOL(tmio_mmc_host_free);

int tmio_mmc_host_probe(struct tmio_mmc_host *_host,
1181 1182
			struct tmio_mmc_data *pdata,
			const struct tmio_mmc_dma_ops *dma_ops)
1183 1184 1185
{
	struct platform_device *pdev = _host->pdev;
	struct mmc_host *mmc = _host->mmc;
1186 1187 1188 1189
	struct resource *res_ctl;
	int ret;
	u32 irq_mask = TMIO_MASK_CMD;

1190 1191
	tmio_mmc_of_parse(pdev, pdata);

1192
	if (!(pdata->flags & TMIO_MMC_HAS_IDLE_WAIT))
1193
		_host->write16_hook = NULL;
1194

1195 1196 1197 1198
	res_ctl = platform_get_resource(pdev, IORESOURCE_MEM, 0);
	if (!res_ctl)
		return -EINVAL;

1199 1200
	ret = mmc_of_parse(mmc);
	if (ret < 0)
1201
		return ret;
1202

1203 1204 1205
	_host->pdata = pdata;
	platform_set_drvdata(pdev, mmc);

1206
	_host->set_pwr = pdata->set_pwr;
1207 1208
	_host->set_clk_div = pdata->set_clk_div;

1209 1210
	ret = tmio_mmc_init_ocr(_host);
	if (ret < 0)
1211
		return ret;
1212

1213 1214
	_host->ctl = devm_ioremap(&pdev->dev,
				  res_ctl->start, resource_size(res_ctl));
1215 1216
	if (!_host->ctl)
		return -ENOMEM;
1217

1218
	tmio_mmc_ops.card_busy = _host->card_busy;
W
Wolfram Sang 已提交
1219
	tmio_mmc_ops.start_signal_voltage_switch = _host->start_signal_voltage_switch;
1220
	mmc->ops = &tmio_mmc_ops;
W
Wolfram Sang 已提交
1221

1222
	mmc->caps |= MMC_CAP_4_BIT_DATA | pdata->capabilities;
1223
	mmc->caps2 |= pdata->capabilities2;
1224 1225
	mmc->max_segs = 32;
	mmc->max_blk_size = 512;
1226
	mmc->max_blk_count = (PAGE_SIZE / mmc->max_blk_size) *
1227 1228 1229 1230
		mmc->max_segs;
	mmc->max_req_size = mmc->max_blk_size * mmc->max_blk_count;
	mmc->max_seg_size = mmc->max_req_size;

1231
	_host->native_hotplug = !(pdata->flags & TMIO_MMC_USE_GPIO_CD ||
1232
				  mmc->caps & MMC_CAP_NEEDS_POLL ||
1233
				  !mmc_card_is_removable(mmc));
1234

W
Wolfram Sang 已提交
1235 1236 1237 1238 1239 1240 1241 1242 1243
	/*
	 * On Gen2+, eMMC with NONREMOVABLE currently fails because native
	 * hotplug gets disabled. It seems RuntimePM related yet we need further
	 * research. Since we are planning a PM overhaul anyway, let's enforce
	 * for now the device being active by enabling native hotplug always.
	 */
	if (pdata->flags & TMIO_MMC_MIN_RCAR2)
		_host->native_hotplug = true;

1244
	if (tmio_mmc_clk_enable(_host) < 0) {
1245 1246 1247 1248
		mmc->f_max = pdata->hclk;
		mmc->f_min = mmc->f_max / 512;
	}

1249 1250 1251 1252
	/*
	 * Check the sanity of mmc->f_min to prevent tmio_mmc_set_clock() from
	 * looping forever...
	 */
1253 1254
	if (mmc->f_min == 0)
		return -EINVAL;
1255

1256
	/*
1257 1258
	 * While using internal tmio hardware logic for card detection, we need
	 * to ensure it stays powered for it to work.
1259
	 */
1260
	if (_host->native_hotplug)
1261 1262
		pm_runtime_get_noresume(&pdev->dev);

1263 1264 1265
	tmio_mmc_clk_stop(_host);
	tmio_mmc_reset(_host);

1266
	_host->sdcard_irq_mask = sd_ctrl_read16_and_16_as_32(_host, CTL_IRQ_MASK);
1267
	tmio_mmc_disable_mmc_irqs(_host, TMIO_MASK_ALL);
1268 1269 1270 1271 1272 1273 1274 1275 1276 1277 1278

	/* Unmask the IRQs we want to know about */
	if (!_host->chan_rx)
		irq_mask |= TMIO_MASK_READOP;
	if (!_host->chan_tx)
		irq_mask |= TMIO_MASK_WRITEOP;
	if (!_host->native_hotplug)
		irq_mask &= ~(TMIO_STAT_CARD_REMOVE | TMIO_STAT_CARD_INSERT);

	_host->sdcard_irq_mask &= ~irq_mask;

1279 1280 1281 1282
	_host->sdio_irq_enabled = false;
	if (pdata->flags & TMIO_MMC_SDIO_IRQ) {
		_host->sdio_irq_mask = TMIO_SDIO_MASK_ALL;
		sd_ctrl_write16(_host, CTL_SDIO_IRQ_MASK, _host->sdio_irq_mask);
1283
		sd_ctrl_write16(_host, CTL_TRANSACTION_CTL, 0x0001);
1284
	}
1285 1286

	spin_lock_init(&_host->lock);
1287
	mutex_init(&_host->ios_lock);
1288 1289 1290

	/* Init delayed work for request timeouts */
	INIT_DELAYED_WORK(&_host->delayed_reset_work, tmio_mmc_reset_work);
1291
	INIT_WORK(&_host->done, tmio_mmc_done_work);
1292 1293

	/* See if we also get DMA */
1294
	_host->dma_ops = dma_ops;
1295 1296
	tmio_mmc_request_dma(_host, pdata);

1297 1298 1299 1300 1301
	pm_runtime_set_active(&pdev->dev);
	pm_runtime_set_autosuspend_delay(&pdev->dev, 50);
	pm_runtime_use_autosuspend(&pdev->dev);
	pm_runtime_enable(&pdev->dev);

1302 1303 1304 1305 1306
	ret = mmc_add_host(mmc);
	if (ret < 0) {
		tmio_mmc_host_remove(_host);
		return ret;
	}
1307

1308 1309
	dev_pm_qos_expose_latency_limit(&pdev->dev, 100);

1310
	if (pdata->flags & TMIO_MMC_USE_GPIO_CD) {
1311
		ret = mmc_gpio_request_cd(mmc, pdata->cd_gpio, 0);
1312 1313 1314 1315
		if (ret < 0) {
			tmio_mmc_host_remove(_host);
			return ret;
		}
1316
		mmc_gpiod_request_cd_irq(mmc);
1317 1318
	}

1319 1320 1321 1322 1323 1324
	return 0;
}
EXPORT_SYMBOL(tmio_mmc_host_probe);

void tmio_mmc_host_remove(struct tmio_mmc_host *host)
{
1325
	struct platform_device *pdev = host->pdev;
1326 1327
	struct mmc_host *mmc = host->mmc;

1328 1329 1330
	if (host->pdata->flags & TMIO_MMC_SDIO_IRQ)
		sd_ctrl_write16(host, CTL_TRANSACTION_CTL, 0x0000);

1331
	if (!host->native_hotplug)
1332 1333
		pm_runtime_get_sync(&pdev->dev);

1334 1335
	dev_pm_qos_hide_latency_limit(&pdev->dev);

1336
	mmc_remove_host(mmc);
1337
	cancel_work_sync(&host->done);
1338 1339
	cancel_delayed_work_sync(&host->delayed_reset_work);
	tmio_mmc_release_dma(host);
1340 1341 1342

	pm_runtime_put_sync(&pdev->dev);
	pm_runtime_disable(&pdev->dev);
1343 1344

	tmio_mmc_clk_disable(host);
1345 1346 1347
}
EXPORT_SYMBOL(tmio_mmc_host_remove);

1348
#ifdef CONFIG_PM
1349 1350
int tmio_mmc_host_runtime_suspend(struct device *dev)
{
1351 1352 1353
	struct mmc_host *mmc = dev_get_drvdata(dev);
	struct tmio_mmc_host *host = mmc_priv(mmc);

1354 1355
	tmio_mmc_disable_mmc_irqs(host, TMIO_MASK_ALL);

1356 1357 1358
	if (host->clk_cache)
		tmio_mmc_clk_stop(host);

1359
	tmio_mmc_clk_disable(host);
1360

1361 1362 1363 1364
	return 0;
}
EXPORT_SYMBOL(tmio_mmc_host_runtime_suspend);

A
Ai Kyuse 已提交
1365 1366 1367 1368 1369
static bool tmio_mmc_can_retune(struct tmio_mmc_host *host)
{
	return host->tap_num && mmc_can_retune(host->mmc);
}

1370 1371 1372 1373 1374
int tmio_mmc_host_runtime_resume(struct device *dev)
{
	struct mmc_host *mmc = dev_get_drvdata(dev);
	struct tmio_mmc_host *host = mmc_priv(mmc);

1375
	tmio_mmc_reset(host);
1376
	tmio_mmc_clk_enable(host);
1377

1378
	if (host->clk_cache)
1379 1380
		tmio_mmc_set_clock(host, host->clk_cache);

1381
	tmio_mmc_enable_dma(host, true);
1382

A
Ai Kyuse 已提交
1383 1384 1385
	if (tmio_mmc_can_retune(host) && host->select_tuning(host))
		dev_warn(&host->pdev->dev, "Tuning selection failed\n");

1386 1387 1388
	return 0;
}
EXPORT_SYMBOL(tmio_mmc_host_runtime_resume);
1389
#endif
1390

1391
MODULE_LICENSE("GPL v2");