tmio_mmc_core.c 35.9 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 8
 * Copyright (C) 2015-17 Renesas Electronics Corporation
 * Copyright (C) 2016-17 Sang Engineering, Wolfram Sang
 * Copyright (C) 2017 Horms Solutions, Simon Horman
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 36
 * 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 已提交
37
#include <linux/mmc/card.h>
38
#include <linux/mmc/host.h>
39
#include <linux/mmc/mmc.h>
40
#include <linux/mmc/slot-gpio.h>
41 42 43
#include <linux/module.h>
#include <linux/pagemap.h>
#include <linux/platform_device.h>
44
#include <linux/pm_qos.h>
45
#include <linux/pm_runtime.h>
46
#include <linux/regulator/consumer.h>
47
#include <linux/mmc/sdio.h>
48 49
#include <linux/scatterlist.h>
#include <linux/spinlock.h>
50
#include <linux/workqueue.h>
51 52 53

#include "tmio_mmc.h"

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 89
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);
}

90 91 92 93 94 95
static inline void tmio_mmc_dataend_dma(struct tmio_mmc_host *host)
{
	if (host->dma_ops)
		host->dma_ops->dataend(host);
}

96 97
void tmio_mmc_enable_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
}
S
Simon Horman 已提交
101
EXPORT_SYMBOL_GPL(tmio_mmc_enable_mmc_irqs);
102 103 104

void tmio_mmc_disable_mmc_irqs(struct tmio_mmc_host *host, u32 i)
{
S
Simon Horman 已提交
105
	host->sdcard_irq_mask |= (i & TMIO_MASK_IRQ);
106
	sd_ctrl_write32_as_16_and_16(host, CTL_IRQ_MASK, host->sdcard_irq_mask);
107
}
S
Simon Horman 已提交
108
EXPORT_SYMBOL_GPL(tmio_mmc_disable_mmc_irqs);
109 110 111

static void tmio_mmc_ack_mmc_irqs(struct tmio_mmc_host *host, u32 i)
{
112
	sd_ctrl_write32_as_16_and_16(host, CTL_STATUS, ~i);
113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129
}

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;
}

130 131
#define CMDREQ_TIMEOUT	5000

132 133 134 135
#ifdef CONFIG_MMC_DEBUG

#define STATUS_TO_TEXT(a, status, i) \
	do { \
136 137 138 139
		if ((status) & TMIO_STAT_##a) { \
			if ((i)++) \
				printk(KERN_DEBUG " | "); \
			printk(KERN_DEBUG #a); \
140 141 142 143 144 145
		} \
	} while (0)

static void pr_debug_status(u32 status)
{
	int i = 0;
146

147
	pr_debug("status: %08x = ", status);
148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179
	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);

180
	if (enable && !host->sdio_irq_enabled) {
181 182
		u16 sdio_status;

183 184 185
		/* Keep device active while SDIO irq is enabled */
		pm_runtime_get_sync(mmc_dev(mmc));

186
		host->sdio_irq_enabled = true;
187
		host->sdio_irq_mask = TMIO_SDIO_MASK_ALL & ~TMIO_SDIO_STAT_IOIRQ;
188 189 190 191 192 193 194

		/* 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 已提交
195
		sd_ctrl_write16(host, CTL_SDIO_IRQ_MASK, host->sdio_irq_mask);
196
	} else if (!enable && host->sdio_irq_enabled) {
S
Simon Horman 已提交
197 198
		host->sdio_irq_mask = TMIO_SDIO_MASK_ALL;
		sd_ctrl_write16(host, CTL_SDIO_IRQ_MASK, host->sdio_irq_mask);
199 200

		host->sdio_irq_enabled = false;
201 202
		pm_runtime_mark_last_busy(mmc_dev(mmc));
		pm_runtime_put_autosuspend(mmc_dev(mmc));
203 204 205
	}
}

206 207 208 209
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));
210 211 212 213

	/* HW engineers overrode docs: no sleep needed on R-Car2+ */
	if (!(host->pdata->flags & TMIO_MMC_MIN_RCAR2))
		msleep(10);
214 215 216 217 218 219 220

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

221 222 223 224 225 226 227 228 229
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));
230 231 232 233

	/* HW engineers overrode docs: no sleep needed on R-Car2+ */
	if (!(host->pdata->flags & TMIO_MMC_MIN_RCAR2))
		msleep(10);
234 235
}

236
static void tmio_mmc_set_clock(struct tmio_mmc_host *host,
237
			       unsigned int new_clock)
238 239 240
{
	u32 clk = 0, clock;

241 242 243 244
	if (new_clock == 0) {
		tmio_mmc_clk_stop(host);
		return;
	}
245

246 247 248 249
	if (host->clk_update)
		clock = host->clk_update(host, new_clock) / 512;
	else
		clock = host->mmc->f_min;
250

251 252 253 254 255 256
	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;
257 258

	if (host->set_clk_div)
259
		host->set_clk_div(host->pdev, (clk >> 22) & 1);
260

261 262
	sd_ctrl_write16(host, CTL_SD_CARD_CLK_CTL, ~CLK_CTL_SCLKEN &
			sd_ctrl_read16(host, CTL_SD_CARD_CLK_CTL));
263
	sd_ctrl_write16(host, CTL_SD_CARD_CLK_CTL, clk & CLK_CTL_DIV_MASK);
264
	if (!(host->pdata->flags & TMIO_MMC_MIN_RCAR2))
265
		msleep(10);
266 267

	tmio_mmc_clk_start(host);
268 269 270 271 272 273
}

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);
274
	if (host->pdata->flags & TMIO_MMC_HAVE_HIGH_REG)
275
		sd_ctrl_write16(host, CTL_RESET_SDIO, 0x0000);
276 277
	msleep(10);
	sd_ctrl_write16(host, CTL_RESET_SD, 0x0001);
278
	if (host->pdata->flags & TMIO_MMC_HAVE_HIGH_REG)
279
		sd_ctrl_write16(host, CTL_RESET_SDIO, 0x0001);
280
	msleep(10);
281 282 283 284 285 286

	if (host->pdata->flags & TMIO_MMC_SDIO_IRQ) {
		sd_ctrl_write16(host, CTL_SDIO_IRQ_MASK, host->sdio_irq_mask);
		sd_ctrl_write16(host, CTL_TRANSACTION_CTL, 0x0001);
	}

287 288 289 290 291 292 293 294 295 296 297 298
}

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;

299 300 301 302 303
	/*
	 * 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)
	 */
304 305 306
	if (IS_ERR_OR_NULL(mrq) ||
	    time_is_after_jiffies(host->last_req_ts +
				  msecs_to_jiffies(CMDREQ_TIMEOUT))) {
307 308 309 310 311
		spin_unlock_irqrestore(&host->lock, flags);
		return;
	}

	dev_warn(&host->pdev->dev,
312 313
		 "timeout waiting for hardware interrupt (CMD%u)\n",
		 mrq->cmd->opcode);
314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329

	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);

330 331 332
	/* Ready for new calls */
	host->mrq = NULL;

333
	tmio_mmc_abort_dma(host);
334 335 336 337 338 339 340 341 342 343 344 345 346 347 348
	mmc_request_done(host->mmc, mrq);
}

/* 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
349
#define NO_CMD12_ISSUE 0x4000 /* TMIO_MMC_HAVE_CMD12_CTRL */
350

351 352
static int tmio_mmc_start_command(struct tmio_mmc_host *host,
				  struct mmc_command *cmd)
353 354 355
{
	struct mmc_data *data = host->data;
	int c = cmd->opcode;
356
	u32 irq_mask = TMIO_MASK_CMD;
357 358 359

	switch (mmc_resp_type(cmd)) {
	case MMC_RSP_NONE: c |= RESP_NONE; break;
W
Wolfram Sang 已提交
360 361 362
	case MMC_RSP_R1:
	case MMC_RSP_R1_NO_CRC:
			   c |= RESP_R1;   break;
363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380
	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) {
381
			sd_ctrl_write16(host, CTL_STOP_INTERNAL_ACTION, TMIO_STOP_SEC);
382
			c |= TRANSFER_MULTI;
383 384

			/*
385 386
			 * Disable auto CMD12 at IO_RW_EXTENDED and
			 * SET_BLOCK_COUNT when doing multiple block transfer
387 388
			 */
			if ((host->pdata->flags & TMIO_MMC_HAVE_CMD12_CTRL) &&
W
Wolfram Sang 已提交
389
			    (cmd->opcode == SD_IO_RW_EXTENDED || host->mrq->sbc))
390
				c |= NO_CMD12_ISSUE;
391 392 393 394 395
		}
		if (data->flags & MMC_DATA_READ)
			c |= TRANSFER_READ;
	}

396 397 398
	if (!host->native_hotplug)
		irq_mask &= ~(TMIO_STAT_CARD_REMOVE | TMIO_STAT_CARD_INSERT);
	tmio_mmc_enable_mmc_irqs(host, irq_mask);
399 400

	/* Fire off the command */
401
	sd_ctrl_write32_as_16_and_16(host, CTL_ARG_REG, cmd->arg);
402 403 404 405 406
	sd_ctrl_write16(host, CTL_SD_CMD, c);

	return 0;
}

407 408 409 410 411 412 413 414 415 416
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
	 */
417
	if (host->pdata->flags & TMIO_MMC_32BIT_DATA_PORT) {
418 419
		u32 data = 0;
		u32 *buf32 = (u32 *)buf;
420 421

		if (is_read)
422
			sd_ctrl_read32_rep(host, CTL_SD_DATA_PORT, buf32,
423 424
					   count >> 2);
		else
425
			sd_ctrl_write32_rep(host, CTL_SD_DATA_PORT, buf32,
426 427 428 429 430 431
					    count >> 2);

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

432
		buf32 += count >> 2;
433 434 435
		count %= 4;

		if (is_read) {
436 437
			sd_ctrl_read32_rep(host, CTL_SD_DATA_PORT, &data, 1);
			memcpy(buf32, &data, count);
438
		} else {
439 440
			memcpy(&data, buf32, count);
			sd_ctrl_write32_rep(host, CTL_SD_DATA_PORT, &data, 1);
441 442 443 444 445
		}

		return;
	}

446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469
	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);
}

470 471 472
/*
 * 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 已提交
473
 * looked into to ensure that a funny length read doesn't hose the controller.
474 475 476 477 478 479 480 481 482 483 484 485 486 487 488 489 490 491 492 493 494 495 496 497 498 499 500 501
 */
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 */
502
	tmio_mmc_transfer_data(host, buf, count);
503 504 505 506 507 508 509 510 511 512 513 514 515 516

	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);
}

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);
517

518 519 520 521 522 523 524 525 526 527 528 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
		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);
	}

W
Wolfram Sang 已提交
564
	if (stop && !host->mrq->sbc) {
565 566 567 568
		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);

569 570 571
		/* fill in response from auto CMD12 */
		stop->resp[0] = sd_ctrl_read16_and_16_as_32(host, CTL_RESPONSE);

572
		sd_ctrl_write16(host, CTL_STOP_INTERNAL_ACTION, 0);
573 574
	}

575
	schedule_work(&host->done);
576
}
S
Simon Horman 已提交
577
EXPORT_SYMBOL_GPL(tmio_mmc_do_data_irq);
578

579
static void tmio_mmc_data_irq(struct tmio_mmc_host *host, unsigned int stat)
580 581
{
	struct mmc_data *data;
582

583 584 585 586 587 588
	spin_lock(&host->lock);
	data = host->data;

	if (!data)
		goto out;

589 590 591
	if (stat & TMIO_STAT_CRCFAIL || stat & TMIO_STAT_STOPBIT_ERR ||
	    stat & TMIO_STAT_TXUNDERRUN)
		data->error = -EILSEQ;
592
	if (host->chan_tx && (data->flags & MMC_DATA_WRITE) && !host->force_pio) {
593
		u32 status = sd_ctrl_read16_and_16_as_32(host, CTL_STATUS);
594 595
		bool done = false;

596 597 598 599 600 601 602 603
		/*
		 * 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.
		 */
604
		if (host->pdata->flags & TMIO_MMC_HAS_IDLE_WAIT) {
605
			if (status & TMIO_STAT_SCLKDIVEN)
606 607 608 609 610 611 612
				done = true;
		} else {
			if (!(status & TMIO_STAT_CMD_BUSY))
				done = true;
		}

		if (done) {
613
			tmio_mmc_disable_mmc_irqs(host, TMIO_STAT_DATAEND);
614
			tmio_mmc_dataend_dma(host);
615 616 617
		}
	} else if (host->chan_rx && (data->flags & MMC_DATA_READ) && !host->force_pio) {
		tmio_mmc_disable_mmc_irqs(host, TMIO_STAT_DATAEND);
618
		tmio_mmc_dataend_dma(host);
619 620 621 622 623 624 625 626
	} else {
		tmio_mmc_do_data_irq(host);
		tmio_mmc_disable_mmc_irqs(host, TMIO_MASK_READOP | TMIO_MASK_WRITEOP);
	}
out:
	spin_unlock(&host->lock);
}

627
static void tmio_mmc_cmd_irq(struct tmio_mmc_host *host, unsigned int stat)
628 629 630 631 632 633 634 635 636 637 638 639 640 641 642 643 644
{
	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)
645
		cmd->resp[i] = sd_ctrl_read16_and_16_as_32(host, addr);
646 647 648 649 650 651 652 653 654 655 656 657

	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;
658 659 660
	else if ((stat & TMIO_STAT_CRCFAIL && cmd->flags & MMC_RSP_CRC) ||
		 stat & TMIO_STAT_STOPBIT_ERR ||
		 stat & TMIO_STAT_CMD_IDX_ERR)
661 662 663 664 665 666
		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.
	 */
667
	if (host->data && (!cmd->error || cmd->error == -EILSEQ)) {
668 669 670 671 672 673 674 675 676 677 678 679
		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 {
680
		schedule_work(&host->done);
681 682 683 684 685 686
	}

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

687
static bool __tmio_mmc_card_detect_irq(struct tmio_mmc_host *host,
688
				       int ireg, int status)
689 690
{
	struct mmc_host *mmc = host->mmc;
691

692 693 694 695
	/* 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);
696 697 698
		if ((((ireg & TMIO_STAT_CARD_REMOVE) && mmc->card) ||
		     ((ireg & TMIO_STAT_CARD_INSERT) && !mmc->card)) &&
		    !work_pending(&mmc->detect.work))
699
			mmc_detect_change(host->mmc, msecs_to_jiffies(100));
700
		return true;
701 702
	}

703 704 705
	return false;
}

706 707
static bool __tmio_mmc_sdcard_irq(struct tmio_mmc_host *host, int ireg,
				  int status)
708
{
709 710
	/* Command completion */
	if (ireg & (TMIO_STAT_CMDRESPEND | TMIO_STAT_CMDTIMEOUT)) {
711 712
		tmio_mmc_ack_mmc_irqs(host, TMIO_STAT_CMDRESPEND |
				      TMIO_STAT_CMDTIMEOUT);
713
		tmio_mmc_cmd_irq(host, status);
714
		return true;
715
	}
716

717 718 719 720
	/* 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);
721
		return true;
722
	}
723

724 725 726
	/* Data transfer completion */
	if (ireg & TMIO_STAT_DATAEND) {
		tmio_mmc_ack_mmc_irqs(host, TMIO_STAT_DATAEND);
727
		tmio_mmc_data_irq(host, status);
728
		return true;
729
	}
730

731 732 733
	return false;
}

734
static void __tmio_mmc_sdio_irq(struct tmio_mmc_host *host)
735 736 737 738
{
	struct mmc_host *mmc = host->mmc;
	struct tmio_mmc_data *pdata = host->pdata;
	unsigned int ireg, status;
739
	unsigned int sdio_status;
740 741

	if (!(pdata->flags & TMIO_MMC_SDIO_IRQ))
742
		return;
743 744

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

747
	sdio_status = status & ~TMIO_SDIO_MASK_ALL;
748
	if (pdata->flags & TMIO_MMC_SDIO_STATUS_SETBITS)
749
		sdio_status |= TMIO_SDIO_SETBITS_MASK;
750 751

	sd_ctrl_write16(host, CTL_SDIO_STATUS, sdio_status);
752 753 754 755 756 757 758 759 760 761

	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;

762
	status = sd_ctrl_read16_and_16_as_32(host, CTL_STATUS);
W
Wolfram Sang 已提交
763 764 765 766 767 768
	ireg = status & TMIO_MASK_IRQ & ~host->sdcard_irq_mask;

	pr_debug_status(status);
	pr_debug_status(ireg);

	/* Clear the status except the interrupt status */
769
	sd_ctrl_write32_as_16_and_16(host, CTL_STATUS, TMIO_MASK_IRQ);
770 771 772 773 774 775

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

776
	__tmio_mmc_sdio_irq(host);
777 778 779

	return IRQ_HANDLED;
}
S
Simon Horman 已提交
780
EXPORT_SYMBOL_GPL(tmio_mmc_irq);
781 782

static int tmio_mmc_start_data(struct tmio_mmc_host *host,
783
			       struct mmc_data *data)
784 785 786 787 788 789
{
	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 已提交
790 791 792
	/* 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) {
793 794 795
		int blksz_2bytes = pdata->flags & TMIO_MMC_BLKSZ_2BYTES;

		if (data->blksz < 2 || (data->blksz < 4 && !blksz_2bytes)) {
W
Wolfram Sang 已提交
796
			pr_err("%s: %d byte block unsupported in 4/8 bit mode\n",
797 798 799 800 801 802 803 804 805 806 807 808 809 810 811 812 813
			       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 已提交
814 815 816 817 818 819 820 821
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 已提交
822 823 824 825 826
static int tmio_mmc_execute_tuning(struct mmc_host *mmc, u32 opcode)
{
	struct tmio_mmc_host *host = mmc_priv(mmc);
	int i, ret = 0;

827 828 829
	if (!host->init_tuning || !host->select_tuning)
		/* Tuning is not supported */
		goto out;
A
Ai Kyuse 已提交
830

831 832 833 834
	host->tap_num = host->init_tuning(host);
	if (!host->tap_num)
		/* Tuning is not supported */
		goto out;
A
Ai Kyuse 已提交
835 836 837

	if (host->tap_num * 2 >= sizeof(host->taps) * BITS_PER_BYTE) {
		dev_warn_once(&host->pdev->dev,
838
			"Too many taps, skipping tuning. Please consider updating size of taps field of tmio_mmc_host\n");
A
Ai Kyuse 已提交
839 840 841 842 843 844 845 846 847 848 849 850 851 852 853 854 855 856 857 858 859 860 861 862 863 864 865 866 867 868
		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;
}

869 870
static void tmio_process_mrq(struct tmio_mmc_host *host,
			     struct mmc_request *mrq)
W
Wolfram Sang 已提交
871
{
W
Wolfram Sang 已提交
872
	struct mmc_command *cmd;
W
Wolfram Sang 已提交
873 874
	int ret;

W
Wolfram Sang 已提交
875 876 877 878 879 880 881 882 883
	if (mrq->sbc && host->cmd != mrq->sbc) {
		cmd = mrq->sbc;
	} else {
		cmd = mrq->cmd;
		if (mrq->data) {
			ret = tmio_mmc_start_data(host, mrq->data);
			if (ret)
				goto fail;
		}
W
Wolfram Sang 已提交
884 885
	}

W
Wolfram Sang 已提交
886
	ret = tmio_mmc_start_command(host, cmd);
W
Wolfram Sang 已提交
887 888 889 890 891 892 893 894 895 896 897 898 899 900
	if (ret)
		goto fail;

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

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

901 902 903 904
/* 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);
905
	unsigned long flags;
906

907 908 909
	spin_lock_irqsave(&host->lock, flags);

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

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

923 924
	spin_unlock_irqrestore(&host->lock, flags);

W
Wolfram Sang 已提交
925
	tmio_process_mrq(host, mrq);
926 927
}

928 929 930 931 932 933 934 935 936 937 938 939 940
static void tmio_mmc_finish_request(struct tmio_mmc_host *host)
{
	struct mmc_request *mrq;
	unsigned long flags;

	spin_lock_irqsave(&host->lock, flags);

	mrq = host->mrq;
	if (IS_ERR_OR_NULL(mrq)) {
		spin_unlock_irqrestore(&host->lock, flags);
		return;
	}

W
Wolfram Sang 已提交
941 942 943 944 945 946 947
	/* If not SET_BLOCK_COUNT, clear old data */
	if (host->cmd != mrq->sbc) {
		host->cmd = NULL;
		host->data = NULL;
		host->force_pio = false;
		host->mrq = NULL;
	}
948 949 950 951 952 953 954 955 956 957 958

	cancel_delayed_work(&host->delayed_reset_work);

	spin_unlock_irqrestore(&host->lock, flags);

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

	if (host->check_scc_error)
		host->check_scc_error(host);

W
Wolfram Sang 已提交
959 960 961 962 963 964
	/* If SET_BLOCK_COUNT, continue with main command */
	if (host->mrq) {
		tmio_process_mrq(host, mrq);
		return;
	}

965 966 967 968 969 970 971 972 973 974
	mmc_request_done(host->mmc, mrq);
}

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);
}

975
static int tmio_mmc_clk_enable(struct tmio_mmc_host *host)
976
{
977
	if (!host->clk_enable)
978 979
		return -ENOTSUPP;

980
	return host->clk_enable(host);
981 982
}

983 984 985 986 987 988
static void tmio_mmc_clk_disable(struct tmio_mmc_host *host)
{
	if (host->clk_disable)
		host->clk_disable(host);
}

989
static void tmio_mmc_power_on(struct tmio_mmc_host *host, unsigned short vdd)
990 991
{
	struct mmc_host *mmc = host->mmc;
992 993 994
	int ret = 0;

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

996 997 998
	if (host->set_pwr)
		host->set_pwr(host->pdev, 1);

999 1000 1001 1002 1003 1004 1005 1006 1007 1008 1009 1010 1011 1012 1013
	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) {
1014
		ret = regulator_enable(mmc->supply.vqmmc);
1015 1016
		udelay(200);
	}
1017 1018 1019 1020

	if (ret < 0)
		dev_dbg(&host->pdev->dev, "Regulators failed to power up: %d\n",
			ret);
1021 1022 1023 1024 1025 1026 1027 1028 1029
}

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);

1030
	if (!IS_ERR(mmc->supply.vmmc))
1031
		mmc_regulator_set_ocr(mmc, mmc->supply.vmmc, 0);
1032 1033 1034

	if (host->set_pwr)
		host->set_pwr(host->pdev, 0);
1035 1036
}

1037
static void tmio_mmc_set_bus_width(struct tmio_mmc_host *host,
1038
				   unsigned char bus_width)
1039
{
W
Wolfram Sang 已提交
1040 1041 1042 1043 1044 1045 1046 1047 1048 1049
	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);
1050 1051
}

1052 1053 1054 1055 1056 1057 1058 1059 1060
/* 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);
1061
	struct device *dev = &host->pdev->dev;
1062 1063
	unsigned long flags;

1064 1065
	mutex_lock(&host->ios_lock);

1066 1067 1068
	spin_lock_irqsave(&host->lock, flags);
	if (host->mrq) {
		if (IS_ERR(host->mrq)) {
1069
			dev_dbg(dev,
1070 1071 1072 1073 1074
				"%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 {
1075
			dev_dbg(dev,
1076 1077
				"%s.%d: CMD%u active since %lu, now %lu!\n",
				current->comm, task_pid_nr(current),
1078 1079
				host->mrq->cmd->opcode, host->last_req_ts,
				jiffies);
1080 1081
		}
		spin_unlock_irqrestore(&host->lock, flags);
1082 1083

		mutex_unlock(&host->ios_lock);
1084 1085 1086 1087 1088 1089
		return;
	}

	host->mrq = ERR_PTR(-EBUSY);

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

1091 1092 1093 1094 1095 1096 1097
	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);
1098
		tmio_mmc_set_clock(host, ios->clock);
1099
		tmio_mmc_set_bus_width(host, ios->bus_width);
1100 1101 1102 1103 1104 1105
		break;
	case MMC_POWER_ON:
		tmio_mmc_set_clock(host, ios->clock);
		tmio_mmc_set_bus_width(host, ios->bus_width);
		break;
	}
1106 1107 1108

	/* Let things settle. delay taken from winCE driver */
	udelay(140);
1109 1110 1111 1112 1113 1114
	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;
1115

1116 1117
	host->clk_cache = ios->clock;

1118
	mutex_unlock(&host->ios_lock);
1119 1120 1121 1122 1123 1124
}

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;
1125
	int ret = mmc_gpio_get_ro(mmc);
1126

1127 1128
	if (ret >= 0)
		return ret;
1129

1130
	ret = !((pdata->flags & TMIO_MMC_WRPROTECT_DISABLE) ||
1131
		(sd_ctrl_read16_and_16_as_32(host, CTL_STATUS) & TMIO_STAT_WRPROTECT));
1132 1133

	return ret;
1134 1135
}

1136 1137 1138 1139 1140
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);

1141 1142
	if (host->multi_io_quirk)
		return host->multi_io_quirk(card, direction, blk_size);
1143 1144 1145 1146

	return blk_size;
}

W
Wolfram Sang 已提交
1147
static struct mmc_host_ops tmio_mmc_ops = {
1148 1149 1150
	.request	= tmio_mmc_request,
	.set_ios	= tmio_mmc_set_ios,
	.get_ro         = tmio_mmc_get_ro,
1151
	.get_cd		= mmc_gpio_get_cd,
1152
	.enable_sdio_irq = tmio_mmc_enable_sdio_irq,
1153
	.multi_io_quirk	= tmio_multi_io_quirk,
A
Ai Kyuse 已提交
1154
	.hw_reset	= tmio_mmc_hw_reset,
A
Ai Kyuse 已提交
1155
	.execute_tuning = tmio_mmc_execute_tuning,
1156 1157
};

1158
static int tmio_mmc_init_ocr(struct tmio_mmc_host *host)
1159 1160 1161 1162 1163 1164
{
	struct tmio_mmc_data *pdata = host->pdata;
	struct mmc_host *mmc = host->mmc;

	mmc_regulator_get_supply(mmc);

1165
	/* use ocr_mask if no regulator */
1166
	if (!mmc->ocr_avail)
1167 1168 1169 1170 1171 1172 1173 1174 1175 1176
		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;
1177 1178
}

1179 1180 1181 1182
static void tmio_mmc_of_parse(struct platform_device *pdev,
			      struct tmio_mmc_data *pdata)
{
	const struct device_node *np = pdev->dev.of_node;
1183

1184 1185 1186 1187 1188 1189 1190
	if (!np)
		return;

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

1191 1192
struct tmio_mmc_host*
tmio_mmc_host_alloc(struct platform_device *pdev)
1193
{
1194
	struct tmio_mmc_host *host;
1195
	struct mmc_host *mmc;
1196 1197 1198 1199 1200 1201 1202 1203 1204 1205 1206

	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;
}
S
Simon Horman 已提交
1207
EXPORT_SYMBOL_GPL(tmio_mmc_host_alloc);
1208 1209 1210 1211 1212

void tmio_mmc_host_free(struct tmio_mmc_host *host)
{
	mmc_free_host(host->mmc);
}
S
Simon Horman 已提交
1213
EXPORT_SYMBOL_GPL(tmio_mmc_host_free);
1214 1215

int tmio_mmc_host_probe(struct tmio_mmc_host *_host,
1216 1217
			struct tmio_mmc_data *pdata,
			const struct tmio_mmc_dma_ops *dma_ops)
1218 1219 1220
{
	struct platform_device *pdev = _host->pdev;
	struct mmc_host *mmc = _host->mmc;
1221 1222 1223 1224
	struct resource *res_ctl;
	int ret;
	u32 irq_mask = TMIO_MASK_CMD;

1225 1226
	tmio_mmc_of_parse(pdev, pdata);

1227
	if (!(pdata->flags & TMIO_MMC_HAS_IDLE_WAIT))
1228
		_host->write16_hook = NULL;
1229

1230 1231 1232 1233
	res_ctl = platform_get_resource(pdev, IORESOURCE_MEM, 0);
	if (!res_ctl)
		return -EINVAL;

1234 1235
	ret = mmc_of_parse(mmc);
	if (ret < 0)
1236
		return ret;
1237

1238 1239 1240
	_host->pdata = pdata;
	platform_set_drvdata(pdev, mmc);

1241
	_host->set_pwr = pdata->set_pwr;
1242 1243
	_host->set_clk_div = pdata->set_clk_div;

1244 1245
	ret = tmio_mmc_init_ocr(_host);
	if (ret < 0)
1246
		return ret;
1247

1248 1249
	_host->ctl = devm_ioremap(&pdev->dev,
				  res_ctl->start, resource_size(res_ctl));
1250 1251
	if (!_host->ctl)
		return -ENOMEM;
1252

1253
	tmio_mmc_ops.card_busy = _host->card_busy;
1254 1255
	tmio_mmc_ops.start_signal_voltage_switch =
		_host->start_signal_voltage_switch;
1256
	mmc->ops = &tmio_mmc_ops;
W
Wolfram Sang 已提交
1257

1258
	mmc->caps |= MMC_CAP_4_BIT_DATA | pdata->capabilities;
1259
	mmc->caps2 |= pdata->capabilities2;
1260
	mmc->max_segs = pdata->max_segs ? : 32;
1261
	mmc->max_blk_size = 512;
1262 1263
	mmc->max_blk_count = pdata->max_blk_count ? :
		(PAGE_SIZE / mmc->max_blk_size) * mmc->max_segs;
1264 1265 1266
	mmc->max_req_size = mmc->max_blk_size * mmc->max_blk_count;
	mmc->max_seg_size = mmc->max_req_size;

1267
	_host->native_hotplug = !(pdata->flags & TMIO_MMC_USE_GPIO_CD ||
1268
				  mmc->caps & MMC_CAP_NEEDS_POLL ||
1269
				  !mmc_card_is_removable(mmc));
1270

W
Wolfram Sang 已提交
1271 1272 1273 1274 1275 1276 1277 1278 1279
	/*
	 * 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;

1280
	if (tmio_mmc_clk_enable(_host) < 0) {
1281 1282 1283 1284
		mmc->f_max = pdata->hclk;
		mmc->f_min = mmc->f_max / 512;
	}

1285 1286 1287 1288
	/*
	 * Check the sanity of mmc->f_min to prevent tmio_mmc_set_clock() from
	 * looping forever...
	 */
1289 1290
	if (mmc->f_min == 0)
		return -EINVAL;
1291

1292
	/*
1293 1294
	 * While using internal tmio hardware logic for card detection, we need
	 * to ensure it stays powered for it to work.
1295
	 */
1296
	if (_host->native_hotplug)
1297 1298
		pm_runtime_get_noresume(&pdev->dev);

1299 1300 1301 1302
	_host->sdio_irq_enabled = false;
	if (pdata->flags & TMIO_MMC_SDIO_IRQ)
		_host->sdio_irq_mask = TMIO_SDIO_MASK_ALL;

1303 1304 1305
	tmio_mmc_clk_stop(_host);
	tmio_mmc_reset(_host);

1306
	_host->sdcard_irq_mask = sd_ctrl_read16_and_16_as_32(_host, CTL_IRQ_MASK);
1307
	tmio_mmc_disable_mmc_irqs(_host, TMIO_MASK_ALL);
1308 1309 1310 1311 1312 1313 1314 1315 1316 1317 1318

	/* 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;

1319
	spin_lock_init(&_host->lock);
1320
	mutex_init(&_host->ios_lock);
1321 1322 1323

	/* Init delayed work for request timeouts */
	INIT_DELAYED_WORK(&_host->delayed_reset_work, tmio_mmc_reset_work);
1324
	INIT_WORK(&_host->done, tmio_mmc_done_work);
1325 1326

	/* See if we also get DMA */
1327
	_host->dma_ops = dma_ops;
1328 1329
	tmio_mmc_request_dma(_host, pdata);

1330 1331 1332 1333 1334
	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);

1335 1336 1337 1338 1339
	ret = mmc_add_host(mmc);
	if (ret < 0) {
		tmio_mmc_host_remove(_host);
		return ret;
	}
1340

1341 1342
	dev_pm_qos_expose_latency_limit(&pdev->dev, 100);

1343
	if (pdata->flags & TMIO_MMC_USE_GPIO_CD) {
1344
		ret = mmc_gpio_request_cd(mmc, pdata->cd_gpio, 0);
1345 1346 1347 1348
		if (ret < 0) {
			tmio_mmc_host_remove(_host);
			return ret;
		}
1349
		mmc_gpiod_request_cd_irq(mmc);
1350 1351
	}

1352 1353
	return 0;
}
S
Simon Horman 已提交
1354
EXPORT_SYMBOL_GPL(tmio_mmc_host_probe);
1355 1356 1357

void tmio_mmc_host_remove(struct tmio_mmc_host *host)
{
1358
	struct platform_device *pdev = host->pdev;
1359 1360
	struct mmc_host *mmc = host->mmc;

1361 1362 1363
	if (host->pdata->flags & TMIO_MMC_SDIO_IRQ)
		sd_ctrl_write16(host, CTL_TRANSACTION_CTL, 0x0000);

1364
	if (!host->native_hotplug)
1365 1366
		pm_runtime_get_sync(&pdev->dev);

1367 1368
	dev_pm_qos_hide_latency_limit(&pdev->dev);

1369
	mmc_remove_host(mmc);
1370
	cancel_work_sync(&host->done);
1371 1372
	cancel_delayed_work_sync(&host->delayed_reset_work);
	tmio_mmc_release_dma(host);
1373 1374 1375

	pm_runtime_put_sync(&pdev->dev);
	pm_runtime_disable(&pdev->dev);
1376 1377

	tmio_mmc_clk_disable(host);
1378
}
S
Simon Horman 已提交
1379
EXPORT_SYMBOL_GPL(tmio_mmc_host_remove);
1380

1381
#ifdef CONFIG_PM
1382 1383
int tmio_mmc_host_runtime_suspend(struct device *dev)
{
1384 1385 1386
	struct mmc_host *mmc = dev_get_drvdata(dev);
	struct tmio_mmc_host *host = mmc_priv(mmc);

1387 1388
	tmio_mmc_disable_mmc_irqs(host, TMIO_MASK_ALL);

1389 1390 1391
	if (host->clk_cache)
		tmio_mmc_clk_stop(host);

1392
	tmio_mmc_clk_disable(host);
1393

1394 1395
	return 0;
}
S
Simon Horman 已提交
1396
EXPORT_SYMBOL_GPL(tmio_mmc_host_runtime_suspend);
1397

A
Ai Kyuse 已提交
1398 1399 1400 1401 1402
static bool tmio_mmc_can_retune(struct tmio_mmc_host *host)
{
	return host->tap_num && mmc_can_retune(host->mmc);
}

1403 1404 1405 1406 1407
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);

1408
	tmio_mmc_reset(host);
1409
	tmio_mmc_clk_enable(host);
1410

1411
	if (host->clk_cache)
1412 1413
		tmio_mmc_set_clock(host, host->clk_cache);

1414
	tmio_mmc_enable_dma(host, true);
1415

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

1419 1420
	return 0;
}
S
Simon Horman 已提交
1421
EXPORT_SYMBOL_GPL(tmio_mmc_host_runtime_resume);
1422
#endif
1423

1424
MODULE_LICENSE("GPL v2");