denali.c 44.4 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20
/*
 * NAND Flash Controller Device Driver
 * Copyright © 2009-2010, Intel Corporation and its suppliers.
 *
 * This program is free software; you can redistribute it and/or modify it
 * under the terms and conditions of the GNU General Public License,
 * version 2, as published by the Free Software Foundation.
 *
 * This program is distributed in the hope it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
 * more details.
 *
 * You should have received a copy of the GNU General Public License along with
 * this program; if not, write to the Free Software Foundation, Inc.,
 * 51 Franklin St - Fifth Floor, Boston, MA 02110-1301 USA.
 *
 */
#include <linux/interrupt.h>
#include <linux/delay.h>
21
#include <linux/dma-mapping.h>
22 23 24 25 26 27 28 29 30
#include <linux/wait.h>
#include <linux/mutex.h>
#include <linux/mtd/mtd.h>
#include <linux/module.h>

#include "denali.h"

MODULE_LICENSE("GPL");

31 32
/*
 * We define a module parameter that allows the user to override
33 34 35 36 37 38
 * the hardware and decide what timing mode should be used.
 */
#define NAND_DEFAULT_TIMINGS	-1

static int onfi_timing_mode = NAND_DEFAULT_TIMINGS;
module_param(onfi_timing_mode, int, S_IRUGO);
39 40
MODULE_PARM_DESC(onfi_timing_mode,
	   "Overrides default ONFI setting. -1 indicates use default timings");
41 42 43

#define DENALI_NAND_NAME    "denali-nand"

44 45 46 47
/*
 * We define a macro here that combines all interrupts this driver uses into
 * a single constant value, for convenience.
 */
48 49 50 51 52 53 54 55 56 57
#define DENALI_IRQ_ALL	(INTR_STATUS__DMA_CMD_COMP | \
			INTR_STATUS__ECC_TRANSACTION_DONE | \
			INTR_STATUS__ECC_ERR | \
			INTR_STATUS__PROGRAM_FAIL | \
			INTR_STATUS__LOAD_COMP | \
			INTR_STATUS__PROGRAM_COMP | \
			INTR_STATUS__TIME_OUT | \
			INTR_STATUS__ERASE_FAIL | \
			INTR_STATUS__RST_COMP | \
			INTR_STATUS__ERASE_COMP)
58

59 60 61 62
/*
 * indicates whether or not the internal value for the flash bank is
 * valid or not
 */
63
#define CHIP_SELECT_INVALID	-1
64 65 66

#define SUPPORT_8BITECC		1

67 68 69 70
/*
 * This macro divides two integers and rounds fractional values up
 * to the nearest integer value.
 */
71 72
#define CEIL_DIV(X, Y) (((X)%(Y)) ? ((X)/(Y)+1) : ((X)/(Y)))

73 74
/*
 * this macro allows us to convert from an MTD structure to our own
75 76
 * device context (denali) structure.
 */
77 78 79 80
static inline struct denali_nand_info *mtd_to_denali(struct mtd_info *mtd)
{
	return container_of(mtd_to_nand(mtd), struct denali_nand_info, nand);
}
81

82 83 84 85
/*
 * These constants are defined by the driver to enable common driver
 * configuration options.
 */
86 87 88
#define SPARE_ACCESS		0x41
#define MAIN_ACCESS		0x42
#define MAIN_SPARE_ACCESS	0x43
89
#define PIPELINE_ACCESS		0x2000
90 91 92 93

#define DENALI_READ	0
#define DENALI_WRITE	0x100

94 95 96 97
/*
 * this is a helper macro that allows us to
 * format the bank into the proper bits for the controller
 */
98 99 100 101
#define BANK(x) ((x) << 24)

/* forward declarations */
static void clear_interrupts(struct denali_nand_info *denali);
102 103 104 105
static uint32_t wait_for_irq(struct denali_nand_info *denali,
							uint32_t irq_mask);
static void denali_irq_enable(struct denali_nand_info *denali,
							uint32_t int_mask);
106 107
static uint32_t read_interrupt_status(struct denali_nand_info *denali);

108 109 110 111
/*
 * Certain operations for the denali NAND controller use an indexed mode to
 * read/write data. The operation is performed by writing the address value
 * of the command to the device memory followed by the data. This function
112
 * abstracts this common operation.
113
 */
114 115
static void index_addr(struct denali_nand_info *denali,
				uint32_t address, uint32_t data)
116
{
117 118
	iowrite32(address, denali->flash_mem);
	iowrite32(data, denali->flash_mem + 0x10);
119 120 121 122 123 124
}

/* Perform an indexed read of the device */
static void index_addr_read_data(struct denali_nand_info *denali,
				 uint32_t address, uint32_t *pdata)
{
125
	iowrite32(address, denali->flash_mem);
126 127 128
	*pdata = ioread32(denali->flash_mem + 0x10);
}

129 130 131 132
/*
 * We need to buffer some data for some of the NAND core routines.
 * The operations manage buffering that data.
 */
133 134 135 136 137 138 139 140 141 142 143 144 145
static void reset_buf(struct denali_nand_info *denali)
{
	denali->buf.head = denali->buf.tail = 0;
}

static void write_byte_to_buf(struct denali_nand_info *denali, uint8_t byte)
{
	denali->buf.buf[denali->buf.tail++] = byte;
}

/* reads the status of the device */
static void read_status(struct denali_nand_info *denali)
{
146
	uint32_t cmd;
147 148 149 150

	/* initialize the data buffer to store status */
	reset_buf(denali);

151 152 153 154 155
	cmd = ioread32(denali->flash_reg + WRITE_PROTECT);
	if (cmd)
		write_byte_to_buf(denali, NAND_STATUS_WP);
	else
		write_byte_to_buf(denali, 0);
156 157 158 159 160
}

/* resets a specific device connected to the core */
static void reset_bank(struct denali_nand_info *denali)
{
161
	uint32_t irq_status;
162
	uint32_t irq_mask = INTR_STATUS__RST_COMP | INTR_STATUS__TIME_OUT;
163 164 165

	clear_interrupts(denali);

166
	iowrite32(1 << denali->flash_bank, denali->flash_reg + DEVICE_RESET);
167 168

	irq_status = wait_for_irq(denali, irq_mask);
169

170
	if (irq_status & INTR_STATUS__TIME_OUT)
171
		dev_err(denali->dev, "reset bank failed.\n");
172 173 174
}

/* Reset the flash controller */
175
static uint16_t denali_nand_reset(struct denali_nand_info *denali)
176
{
177
	int i;
178

179
	for (i = 0; i < denali->max_banks; i++)
180 181
		iowrite32(INTR_STATUS__RST_COMP | INTR_STATUS__TIME_OUT,
		denali->flash_reg + INTR_STATUS(i));
182

183
	for (i = 0; i < denali->max_banks; i++) {
184
		iowrite32(1 << i, denali->flash_reg + DEVICE_RESET);
185
		while (!(ioread32(denali->flash_reg + INTR_STATUS(i)) &
186
			(INTR_STATUS__RST_COMP | INTR_STATUS__TIME_OUT)))
187
			cpu_relax();
188 189
		if (ioread32(denali->flash_reg + INTR_STATUS(i)) &
			INTR_STATUS__TIME_OUT)
190
			dev_dbg(denali->dev,
191 192 193
			"NAND Reset operation timed out on bank %d\n", i);
	}

194
	for (i = 0; i < denali->max_banks; i++)
195
		iowrite32(INTR_STATUS__RST_COMP | INTR_STATUS__TIME_OUT,
196
			  denali->flash_reg + INTR_STATUS(i));
197 198 199 200

	return PASS;
}

201 202
/*
 * this routine calculates the ONFI timing values for a given mode and
203 204
 * programs the clocking register accordingly. The mode is determined by
 * the get_onfi_nand_para routine.
205
 */
206
static void nand_onfi_timing_set(struct denali_nand_info *denali,
207
								uint16_t mode)
208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245
{
	uint16_t Trea[6] = {40, 30, 25, 20, 20, 16};
	uint16_t Trp[6] = {50, 25, 17, 15, 12, 10};
	uint16_t Treh[6] = {30, 15, 15, 10, 10, 7};
	uint16_t Trc[6] = {100, 50, 35, 30, 25, 20};
	uint16_t Trhoh[6] = {0, 15, 15, 15, 15, 15};
	uint16_t Trloh[6] = {0, 0, 0, 0, 5, 5};
	uint16_t Tcea[6] = {100, 45, 30, 25, 25, 25};
	uint16_t Tadl[6] = {200, 100, 100, 100, 70, 70};
	uint16_t Trhw[6] = {200, 100, 100, 100, 100, 100};
	uint16_t Trhz[6] = {200, 100, 100, 100, 100, 100};
	uint16_t Twhr[6] = {120, 80, 80, 60, 60, 60};
	uint16_t Tcs[6] = {70, 35, 25, 25, 20, 15};

	uint16_t data_invalid_rhoh, data_invalid_rloh, data_invalid;
	uint16_t dv_window = 0;
	uint16_t en_lo, en_hi;
	uint16_t acc_clks;
	uint16_t addr_2_data, re_2_we, re_2_re, we_2_re, cs_cnt;

	en_lo = CEIL_DIV(Trp[mode], CLK_X);
	en_hi = CEIL_DIV(Treh[mode], CLK_X);
#if ONFI_BLOOM_TIME
	if ((en_hi * CLK_X) < (Treh[mode] + 2))
		en_hi++;
#endif

	if ((en_lo + en_hi) * CLK_X < Trc[mode])
		en_lo += CEIL_DIV((Trc[mode] - (en_lo + en_hi) * CLK_X), CLK_X);

	if ((en_lo + en_hi) < CLK_MULTI)
		en_lo += CLK_MULTI - en_lo - en_hi;

	while (dv_window < 8) {
		data_invalid_rhoh = en_lo * CLK_X + Trhoh[mode];

		data_invalid_rloh = (en_lo + en_hi) * CLK_X + Trloh[mode];

246 247
		data_invalid = data_invalid_rhoh < data_invalid_rloh ?
					data_invalid_rhoh : data_invalid_rloh;
248 249 250 251 252 253 254 255 256

		dv_window = data_invalid - Trea[mode];

		if (dv_window < 8)
			en_lo++;
	}

	acc_clks = CEIL_DIV(Trea[mode], CLK_X);

257
	while (acc_clks * CLK_X - Trea[mode] < 3)
258 259
		acc_clks++;

260
	if (data_invalid - acc_clks * CLK_X < 2)
261
		dev_warn(denali->dev, "%s, Line %d: Warning!\n",
262
			 __FILE__, __LINE__);
263 264 265 266 267 268 269 270 271 272

	addr_2_data = CEIL_DIV(Tadl[mode], CLK_X);
	re_2_we = CEIL_DIV(Trhw[mode], CLK_X);
	re_2_re = CEIL_DIV(Trhz[mode], CLK_X);
	we_2_re = CEIL_DIV(Twhr[mode], CLK_X);
	cs_cnt = CEIL_DIV((Tcs[mode] - Trp[mode]), CLK_X);
	if (cs_cnt == 0)
		cs_cnt = 1;

	if (Tcea[mode]) {
273
		while (cs_cnt * CLK_X + Trea[mode] < Tcea[mode])
274 275 276 277 278 279 280 281 282
			cs_cnt++;
	}

#if MODE5_WORKAROUND
	if (mode == 5)
		acc_clks = 5;
#endif

	/* Sighting 3462430: Temporary hack for MT29F128G08CJABAWP:B */
283 284
	if (ioread32(denali->flash_reg + MANUFACTURER_ID) == 0 &&
		ioread32(denali->flash_reg + DEVICE_ID) == 0x88)
285 286
		acc_clks = 6;

287 288 289 290 291 292 293 294
	iowrite32(acc_clks, denali->flash_reg + ACC_CLKS);
	iowrite32(re_2_we, denali->flash_reg + RE_2_WE);
	iowrite32(re_2_re, denali->flash_reg + RE_2_RE);
	iowrite32(we_2_re, denali->flash_reg + WE_2_RE);
	iowrite32(addr_2_data, denali->flash_reg + ADDR_2_DATA);
	iowrite32(en_lo, denali->flash_reg + RDWR_EN_LO_CNT);
	iowrite32(en_hi, denali->flash_reg + RDWR_EN_HI_CNT);
	iowrite32(cs_cnt, denali->flash_reg + CS_SETUP_CNT);
295 296 297 298 299 300
}

/* queries the NAND device to see what ONFI modes it supports. */
static uint16_t get_onfi_nand_para(struct denali_nand_info *denali)
{
	int i;
301 302 303

	/*
	 * we needn't to do a reset here because driver has already
304
	 * reset all the banks before
305
	 */
306 307 308 309 310
	if (!(ioread32(denali->flash_reg + ONFI_TIMING_MODE) &
		ONFI_TIMING_MODE__VALUE))
		return FAIL;

	for (i = 5; i > 0; i--) {
311 312
		if (ioread32(denali->flash_reg + ONFI_TIMING_MODE) &
			(0x01 << i))
313 314 315
			break;
	}

316
	nand_onfi_timing_set(denali, i);
317

318 319 320 321
	/*
	 * By now, all the ONFI devices we know support the page cache
	 * rw feature. So here we enable the pipeline_rw_ahead feature
	 */
322 323 324 325 326 327
	/* iowrite32(1, denali->flash_reg + CACHE_WRITE_ENABLE); */
	/* iowrite32(1, denali->flash_reg + CACHE_READ_ENABLE);  */

	return PASS;
}

328 329
static void get_samsung_nand_para(struct denali_nand_info *denali,
							uint8_t device_id)
330
{
331
	if (device_id == 0xd3) { /* Samsung K9WAG08U1A */
332
		/* Set timing register values according to datasheet */
333 334 335 336 337 338 339
		iowrite32(5, denali->flash_reg + ACC_CLKS);
		iowrite32(20, denali->flash_reg + RE_2_WE);
		iowrite32(12, denali->flash_reg + WE_2_RE);
		iowrite32(14, denali->flash_reg + ADDR_2_DATA);
		iowrite32(3, denali->flash_reg + RDWR_EN_LO_CNT);
		iowrite32(2, denali->flash_reg + RDWR_EN_HI_CNT);
		iowrite32(2, denali->flash_reg + CS_SETUP_CNT);
340 341 342 343 344 345 346
	}
}

static void get_toshiba_nand_para(struct denali_nand_info *denali)
{
	uint32_t tmp;

347 348 349 350
	/*
	 * Workaround to fix a controller bug which reports a wrong
	 * spare area size for some kind of Toshiba NAND device
	 */
351 352
	if ((ioread32(denali->flash_reg + DEVICE_MAIN_AREA_SIZE) == 4096) &&
		(ioread32(denali->flash_reg + DEVICE_SPARE_AREA_SIZE) == 64)) {
353
		iowrite32(216, denali->flash_reg + DEVICE_SPARE_AREA_SIZE);
354 355
		tmp = ioread32(denali->flash_reg + DEVICES_CONNECTED) *
			ioread32(denali->flash_reg + DEVICE_SPARE_AREA_SIZE);
356
		iowrite32(tmp,
357
				denali->flash_reg + LOGICAL_PAGE_SPARE_SIZE);
358
#if SUPPORT_15BITECC
359
		iowrite32(15, denali->flash_reg + ECC_CORRECTION);
360
#elif SUPPORT_8BITECC
361
		iowrite32(8, denali->flash_reg + ECC_CORRECTION);
362 363 364 365
#endif
	}
}

366 367
static void get_hynix_nand_para(struct denali_nand_info *denali,
							uint8_t device_id)
368 369 370
{
	uint32_t main_size, spare_size;

371
	switch (device_id) {
372 373
	case 0xD5: /* Hynix H27UAG8T2A, H27UBG8U5A or H27UCG8VFA */
	case 0xD7: /* Hynix H27UDG8VEM, H27UCG8UDM or H27UCG8V5A */
374 375 376
		iowrite32(128, denali->flash_reg + PAGES_PER_BLOCK);
		iowrite32(4096, denali->flash_reg + DEVICE_MAIN_AREA_SIZE);
		iowrite32(224, denali->flash_reg + DEVICE_SPARE_AREA_SIZE);
377 378 379 380
		main_size = 4096 *
			ioread32(denali->flash_reg + DEVICES_CONNECTED);
		spare_size = 224 *
			ioread32(denali->flash_reg + DEVICES_CONNECTED);
381
		iowrite32(main_size,
382
				denali->flash_reg + LOGICAL_PAGE_DATA_SIZE);
383
		iowrite32(spare_size,
384
				denali->flash_reg + LOGICAL_PAGE_SPARE_SIZE);
385
		iowrite32(0, denali->flash_reg + DEVICE_WIDTH);
386
#if SUPPORT_15BITECC
387
		iowrite32(15, denali->flash_reg + ECC_CORRECTION);
388
#elif SUPPORT_8BITECC
389
		iowrite32(8, denali->flash_reg + ECC_CORRECTION);
390 391 392
#endif
		break;
	default:
393
		dev_warn(denali->dev,
394
			 "Unknown Hynix NAND (Device ID: 0x%x).\n"
395 396
			 "Will use default parameter values instead.\n",
			 device_id);
397 398 399
	}
}

400 401
/*
 * determines how many NAND chips are connected to the controller. Note for
402
 * Intel CE4100 devices we don't support more than one device.
403 404 405
 */
static void find_valid_banks(struct denali_nand_info *denali)
{
406
	uint32_t id[denali->max_banks];
407 408 409
	int i;

	denali->total_used_banks = 1;
410
	for (i = 0; i < denali->max_banks; i++) {
411 412
		index_addr(denali, MODE_11 | (i << 24) | 0, 0x90);
		index_addr(denali, MODE_11 | (i << 24) | 1, 0);
413
		index_addr_read_data(denali, MODE_11 | (i << 24) | 2, &id[i]);
414

415
		dev_dbg(denali->dev,
416 417 418 419 420 421 422 423 424 425 426 427 428
			"Return 1st ID for bank[%d]: %x\n", i, id[i]);

		if (i == 0) {
			if (!(id[i] & 0x0ff))
				break; /* WTF? */
		} else {
			if ((id[i] & 0x0ff) == (id[0] & 0x0ff))
				denali->total_used_banks++;
			else
				break;
		}
	}

429
	if (denali->platform == INTEL_CE4100) {
430 431
		/*
		 * Platform limitations of the CE4100 device limit
432
		 * users to a single chip solution for NAND.
433 434
		 * Multichip support is not enabled.
		 */
435
		if (denali->total_used_banks != 1) {
436
			dev_err(denali->dev,
437
				"Sorry, Intel CE4100 only supports a single NAND device.\n");
438 439 440
			BUG();
		}
	}
441
	dev_dbg(denali->dev,
442 443 444
		"denali->total_used_banks: %d\n", denali->total_used_banks);
}

445 446 447 448 449 450 451
/*
 * Use the configuration feature register to determine the maximum number of
 * banks that the hardware supports.
 */
static void detect_max_banks(struct denali_nand_info *denali)
{
	uint32_t features = ioread32(denali->flash_reg + FEATURES);
452 453 454 455 456 457
	/*
	 * Read the revision register, so we can calculate the max_banks
	 * properly: the encoding changed from rev 5.0 to 5.1
	 */
	u32 revision = MAKE_COMPARABLE_REVISION(
				ioread32(denali->flash_reg + REVISION));
458

459 460 461 462
	if (revision < REVISION_5_1)
		denali->max_banks = 2 << (features & FEATURES__N_BANKS);
	else
		denali->max_banks = 1 << (features & FEATURES__N_BANKS);
463 464
}

465
static uint16_t denali_nand_timing_set(struct denali_nand_info *denali)
466 467
{
	uint16_t status = PASS;
468
	uint32_t id_bytes[8], addr;
469 470
	uint8_t maf_id, device_id;
	int i;
471

472 473 474 475 476
	/*
	 * Use read id method to get device ID and other params.
	 * For some NAND chips, controller can't report the correct
	 * device ID by reading from DEVICE_ID register
	 */
477 478 479
	addr = MODE_11 | BANK(denali->flash_bank);
	index_addr(denali, addr | 0, 0x90);
	index_addr(denali, addr | 1, 0);
480
	for (i = 0; i < 8; i++)
481 482 483
		index_addr_read_data(denali, addr | 2, &id_bytes[i]);
	maf_id = id_bytes[0];
	device_id = id_bytes[1];
484 485 486 487 488

	if (ioread32(denali->flash_reg + ONFI_DEVICE_NO_OF_LUNS) &
		ONFI_DEVICE_NO_OF_LUNS__ONFI_DEVICE) { /* ONFI 1.0 NAND */
		if (FAIL == get_onfi_nand_para(denali))
			return FAIL;
489
	} else if (maf_id == 0xEC) { /* Samsung NAND */
490
		get_samsung_nand_para(denali, device_id);
491
	} else if (maf_id == 0x98) { /* Toshiba NAND */
492
		get_toshiba_nand_para(denali);
493 494
	} else if (maf_id == 0xAD) { /* Hynix NAND */
		get_hynix_nand_para(denali, device_id);
495 496
	}

497
	dev_info(denali->dev,
498
			"Dump timing register values:\n"
499 500
			"acc_clks: %d, re_2_we: %d, re_2_re: %d\n"
			"we_2_re: %d, addr_2_data: %d, rdwr_en_lo_cnt: %d\n"
501 502 503
			"rdwr_en_hi_cnt: %d, cs_setup_cnt: %d\n",
			ioread32(denali->flash_reg + ACC_CLKS),
			ioread32(denali->flash_reg + RE_2_WE),
504
			ioread32(denali->flash_reg + RE_2_RE),
505 506 507 508 509 510 511 512
			ioread32(denali->flash_reg + WE_2_RE),
			ioread32(denali->flash_reg + ADDR_2_DATA),
			ioread32(denali->flash_reg + RDWR_EN_LO_CNT),
			ioread32(denali->flash_reg + RDWR_EN_HI_CNT),
			ioread32(denali->flash_reg + CS_SETUP_CNT));

	find_valid_banks(denali);

513 514
	/*
	 * If the user specified to override the default timings
515
	 * with a specific ONFI mode, we apply those changes here.
516 517
	 */
	if (onfi_timing_mode != NAND_DEFAULT_TIMINGS)
518
		nand_onfi_timing_set(denali, onfi_timing_mode);
519 520 521 522

	return status;
}

523
static void denali_set_intr_modes(struct denali_nand_info *denali,
524 525 526
					uint16_t INT_ENABLE)
{
	if (INT_ENABLE)
527
		iowrite32(1, denali->flash_reg + GLOBAL_INT_ENABLE);
528
	else
529
		iowrite32(0, denali->flash_reg + GLOBAL_INT_ENABLE);
530 531
}

532 533
/*
 * validation function to verify that the controlling software is making
534
 * a valid request
535 536 537
 */
static inline bool is_flash_bank_valid(int flash_bank)
{
538
	return flash_bank >= 0 && flash_bank < 4;
539 540 541 542
}

static void denali_irq_init(struct denali_nand_info *denali)
{
543
	uint32_t int_mask;
544
	int i;
545 546

	/* Disable global interrupts */
547
	denali_set_intr_modes(denali, false);
548 549 550 551

	int_mask = DENALI_IRQ_ALL;

	/* Clear all status bits */
552
	for (i = 0; i < denali->max_banks; ++i)
553
		iowrite32(0xFFFF, denali->flash_reg + INTR_STATUS(i));
554 555 556 557 558 559

	denali_irq_enable(denali, int_mask);
}

static void denali_irq_cleanup(int irqnum, struct denali_nand_info *denali)
{
560
	denali_set_intr_modes(denali, false);
561 562
}

563 564
static void denali_irq_enable(struct denali_nand_info *denali,
							uint32_t int_mask)
565
{
566 567
	int i;

568
	for (i = 0; i < denali->max_banks; ++i)
569
		iowrite32(int_mask, denali->flash_reg + INTR_EN(i));
570 571
}

572 573
/*
 * This function only returns when an interrupt that this driver cares about
574
 * occurs. This is to reduce the overhead of servicing interrupts
575 576 577
 */
static inline uint32_t denali_irq_detected(struct denali_nand_info *denali)
{
578
	return read_interrupt_status(denali) & DENALI_IRQ_ALL;
579 580 581
}

/* Interrupts are cleared by writing a 1 to the appropriate status bit */
582 583
static inline void clear_interrupt(struct denali_nand_info *denali,
							uint32_t irq_mask)
584
{
585
	uint32_t intr_status_reg;
586

587
	intr_status_reg = INTR_STATUS(denali->flash_bank);
588

589
	iowrite32(irq_mask, denali->flash_reg + intr_status_reg);
590 591 592 593
}

static void clear_interrupts(struct denali_nand_info *denali)
{
594 595
	uint32_t status;

596 597 598
	spin_lock_irq(&denali->irq_lock);

	status = read_interrupt_status(denali);
599
	clear_interrupt(denali, status);
600 601 602 603 604 605 606

	denali->irq_status = 0x0;
	spin_unlock_irq(&denali->irq_lock);
}

static uint32_t read_interrupt_status(struct denali_nand_info *denali)
{
607
	uint32_t intr_status_reg;
608

609
	intr_status_reg = INTR_STATUS(denali->flash_bank);
610 611 612 613

	return ioread32(denali->flash_reg + intr_status_reg);
}

614 615 616
/*
 * This is the interrupt service routine. It handles all interrupts
 * sent to this device. Note that on CE4100, this is a shared interrupt.
617 618 619 620
 */
static irqreturn_t denali_isr(int irq, void *dev_id)
{
	struct denali_nand_info *denali = dev_id;
621
	uint32_t irq_status;
622 623 624 625
	irqreturn_t result = IRQ_NONE;

	spin_lock(&denali->irq_lock);

626
	/* check to see if a valid NAND chip has been selected. */
627
	if (is_flash_bank_valid(denali->flash_bank)) {
628 629 630 631
		/*
		 * check to see if controller generated the interrupt,
		 * since this is a shared interrupt
		 */
632 633
		irq_status = denali_irq_detected(denali);
		if (irq_status != 0) {
634 635 636
			/* handle interrupt */
			/* first acknowledge it */
			clear_interrupt(denali, irq_status);
637 638 639 640
			/*
			 * store the status in the device context for someone
			 * to read
			 */
641 642 643 644 645 646 647 648 649 650 651 652 653
			denali->irq_status |= irq_status;
			/* notify anyone who cares that it happened */
			complete(&denali->complete);
			/* tell the OS that we've handled this */
			result = IRQ_HANDLED;
		}
	}
	spin_unlock(&denali->irq_lock);
	return result;
}

static uint32_t wait_for_irq(struct denali_nand_info *denali, uint32_t irq_mask)
{
654 655
	unsigned long comp_res;
	uint32_t intr_status;
656 657
	unsigned long timeout = msecs_to_jiffies(1000);

658
	do {
659 660
		comp_res =
			wait_for_completion_timeout(&denali->complete, timeout);
661 662 663
		spin_lock_irq(&denali->irq_lock);
		intr_status = denali->irq_status;

664
		if (intr_status & irq_mask) {
665 666 667 668 669
			denali->irq_status &= ~irq_mask;
			spin_unlock_irq(&denali->irq_lock);
			/* our interrupt was detected */
			break;
		}
670 671 672 673 674 675

		/*
		 * these are not the interrupts you are looking for -
		 * need to wait again
		 */
		spin_unlock_irq(&denali->irq_lock);
676 677
	} while (comp_res != 0);

678
	if (comp_res == 0) {
679
		/* timeout */
680
		pr_err("timeout occurred, status = 0x%x, mask = 0x%x\n",
681
				intr_status, irq_mask);
682 683 684 685 686 687

		intr_status = 0;
	}
	return intr_status;
}

688 689 690 691
/*
 * This helper function setups the registers for ECC and whether or not
 * the spare area will be transferred.
 */
692
static void setup_ecc_for_xfer(struct denali_nand_info *denali, bool ecc_en,
693 694
				bool transfer_spare)
{
695
	int ecc_en_flag, transfer_spare_flag;
696 697 698 699 700 701

	/* set ECC, transfer spare bits if needed */
	ecc_en_flag = ecc_en ? ECC_ENABLE__FLAG : 0;
	transfer_spare_flag = transfer_spare ? TRANSFER_SPARE_REG__FLAG : 0;

	/* Enable spare area/ECC per user's request. */
702
	iowrite32(ecc_en_flag, denali->flash_reg + ECC_ENABLE);
703
	iowrite32(transfer_spare_flag, denali->flash_reg + TRANSFER_SPARE_REG);
704 705
}

706 707
/*
 * sends a pipeline command operation to the controller. See the Denali NAND
708
 * controller's user guide for more information (section 4.2.3.6).
709
 */
710
static int denali_send_pipeline_cmd(struct denali_nand_info *denali,
711 712
				    bool ecc_en, bool transfer_spare,
				    int access_type, int op)
713 714
{
	int status = PASS;
715 716
	uint32_t page_count = 1;
	uint32_t addr, cmd, irq_status, irq_mask;
717

718
	if (op == DENALI_READ)
719
		irq_mask = INTR_STATUS__LOAD_COMP;
720 721 722 723
	else if (op == DENALI_WRITE)
		irq_mask = 0;
	else
		BUG();
724 725 726

	setup_ecc_for_xfer(denali, ecc_en, transfer_spare);

727
	clear_interrupts(denali);
728 729 730

	addr = BANK(denali->flash_bank) | denali->page;

731
	if (op == DENALI_WRITE && access_type != SPARE_ACCESS) {
732
		cmd = MODE_01 | addr;
733
		iowrite32(cmd, denali->flash_mem);
734
	} else if (op == DENALI_WRITE && access_type == SPARE_ACCESS) {
735
		/* read spare area */
736
		cmd = MODE_10 | addr;
737
		index_addr(denali, cmd, access_type);
738

739
		cmd = MODE_01 | addr;
740
		iowrite32(cmd, denali->flash_mem);
741
	} else if (op == DENALI_READ) {
742
		/* setup page read request for access type */
743
		cmd = MODE_10 | addr;
744
		index_addr(denali, cmd, access_type);
745

746 747 748 749
		/*
		 * page 33 of the NAND controller spec indicates we should not
		 * use the pipeline commands in Spare area only mode.
		 * So we don't.
750
		 */
751
		if (access_type == SPARE_ACCESS) {
752
			cmd = MODE_01 | addr;
753
			iowrite32(cmd, denali->flash_mem);
754
		} else {
755
			index_addr(denali, cmd,
756
					PIPELINE_ACCESS | op | page_count);
757

758 759
			/*
			 * wait for command to be accepted
760
			 * can always use status0 bit as the
761 762
			 * mask is identical for each bank.
			 */
763 764
			irq_status = wait_for_irq(denali, irq_mask);

765
			if (irq_status == 0) {
766
				dev_err(denali->dev,
767 768
					"cmd, page, addr on timeout (0x%x, 0x%x, 0x%x)\n",
					cmd, denali->page, addr);
769
				status = FAIL;
770
			} else {
771
				cmd = MODE_01 | addr;
772
				iowrite32(cmd, denali->flash_mem);
773 774 775 776 777 778 779
			}
		}
	}
	return status;
}

/* helper function that simply writes a buffer to the flash */
780
static int write_data_to_flash_mem(struct denali_nand_info *denali,
781
				   const uint8_t *buf, int len)
782
{
783 784
	uint32_t *buf32;
	int i;
785

786 787 788 789
	/*
	 * verify that the len is a multiple of 4.
	 * see comment in read_data_from_flash_mem()
	 */
790 791 792 793 794
	BUG_ON((len % 4) != 0);

	/* write the data to the flash memory */
	buf32 = (uint32_t *)buf;
	for (i = 0; i < len / 4; i++)
795
		iowrite32(*buf32++, denali->flash_mem + 0x10);
796
	return i * 4; /* intent is to return the number of bytes read */
797 798 799
}

/* helper function that simply reads a buffer from the flash */
800
static int read_data_from_flash_mem(struct denali_nand_info *denali,
801
				    uint8_t *buf, int len)
802
{
803 804
	uint32_t *buf32;
	int i;
805

806 807 808 809 810
	/*
	 * we assume that len will be a multiple of 4, if not it would be nice
	 * to know about it ASAP rather than have random failures...
	 * This assumption is based on the fact that this function is designed
	 * to be used to read flash pages, which are typically multiples of 4.
811 812 813 814 815 816 817
	 */
	BUG_ON((len % 4) != 0);

	/* transfer the data from the flash */
	buf32 = (uint32_t *)buf;
	for (i = 0; i < len / 4; i++)
		*buf32++ = ioread32(denali->flash_mem + 0x10);
818
	return i * 4; /* intent is to return the number of bytes read */
819 820 821 822 823 824
}

/* writes OOB data to the device */
static int write_oob_data(struct mtd_info *mtd, uint8_t *buf, int page)
{
	struct denali_nand_info *denali = mtd_to_denali(mtd);
825
	uint32_t irq_status;
826 827
	uint32_t irq_mask = INTR_STATUS__PROGRAM_COMP |
						INTR_STATUS__PROGRAM_FAIL;
828 829 830 831
	int status = 0;

	denali->page = page;

832
	if (denali_send_pipeline_cmd(denali, false, false, SPARE_ACCESS,
833
							DENALI_WRITE) == PASS) {
834 835 836 837 838
		write_data_to_flash_mem(denali, buf, mtd->oobsize);

		/* wait for operation to complete */
		irq_status = wait_for_irq(denali, irq_mask);

839
		if (irq_status == 0) {
840
			dev_err(denali->dev, "OOB write failed\n");
841 842
			status = -EIO;
		}
843
	} else {
844
		dev_err(denali->dev, "unable to send pipeline command\n");
845
		status = -EIO;
846 847 848 849 850 851 852 853
	}
	return status;
}

/* reads OOB data from the device */
static void read_oob_data(struct mtd_info *mtd, uint8_t *buf, int page)
{
	struct denali_nand_info *denali = mtd_to_denali(mtd);
854 855
	uint32_t irq_mask = INTR_STATUS__LOAD_COMP;
	uint32_t irq_status, addr, cmd;
856 857 858

	denali->page = page;

859
	if (denali_send_pipeline_cmd(denali, false, true, SPARE_ACCESS,
860
							DENALI_READ) == PASS) {
861
		read_data_from_flash_mem(denali, buf, mtd->oobsize);
862

863 864 865 866 867
		/*
		 * wait for command to be accepted
		 * can always use status0 bit as the
		 * mask is identical for each bank.
		 */
868 869 870
		irq_status = wait_for_irq(denali, irq_mask);

		if (irq_status == 0)
871
			dev_err(denali->dev, "page on OOB timeout %d\n",
872
					denali->page);
873

874 875
		/*
		 * We set the device back to MAIN_ACCESS here as I observed
876 877 878
		 * instability with the controller if you do a block erase
		 * and the last transaction was a SPARE_ACCESS. Block erase
		 * is reliable (according to the MTD test infrastructure)
879
		 * if you are in MAIN_ACCESS.
880 881
		 */
		addr = BANK(denali->flash_bank) | denali->page;
882
		cmd = MODE_10 | addr;
883
		index_addr(denali, cmd, MAIN_ACCESS);
884 885 886
	}
}

887 888
/*
 * this function examines buffers to see if they contain data that
889 890
 * indicate that the buffer is part of an erased region of flash.
 */
891
static bool is_erased(uint8_t *buf, int len)
892
{
893
	int i;
894

895 896 897 898 899 900 901 902 903 904
	for (i = 0; i < len; i++)
		if (buf[i] != 0xFF)
			return false;
	return true;
}
#define ECC_SECTOR_SIZE 512

#define ECC_SECTOR(x)	(((x) & ECC_ERROR_ADDRESS__SECTOR_NR) >> 12)
#define ECC_BYTE(x)	(((x) & ECC_ERROR_ADDRESS__OFFSET))
#define ECC_CORRECTION_VALUE(x) ((x) & ERR_CORRECTION_INFO__BYTEMASK)
905 906
#define ECC_ERROR_CORRECTABLE(x) (!((x) & ERR_CORRECTION_INFO__ERROR_TYPE))
#define ECC_ERR_DEVICE(x)	(((x) & ERR_CORRECTION_INFO__DEVICE_NR) >> 8)
907 908
#define ECC_LAST_ERR(x)		((x) & ERR_CORRECTION_INFO__LAST_ERR_INFO)

909
static bool handle_ecc(struct denali_nand_info *denali, uint8_t *buf,
910
		       uint32_t irq_status, unsigned int *max_bitflips)
911 912
{
	bool check_erased_page = false;
913
	unsigned int bitflips = 0;
914

915
	if (irq_status & INTR_STATUS__ECC_ERR) {
916
		/* read the ECC errors. we'll ignore them for now */
917 918
		uint32_t err_address, err_correction_info, err_byte,
			 err_sector, err_device, err_correction_value;
919
		denali_set_intr_modes(denali, false);
920

921
		do {
922
			err_address = ioread32(denali->flash_reg +
923 924 925 926
						ECC_ERROR_ADDRESS);
			err_sector = ECC_SECTOR(err_address);
			err_byte = ECC_BYTE(err_address);

927
			err_correction_info = ioread32(denali->flash_reg +
928
						ERR_CORRECTION_INFO);
929
			err_correction_value =
930 931 932
				ECC_CORRECTION_VALUE(err_correction_info);
			err_device = ECC_ERR_DEVICE(err_correction_info);

933
			if (ECC_ERROR_CORRECTABLE(err_correction_info)) {
934 935
				/*
				 * If err_byte is larger than ECC_SECTOR_SIZE,
L
Lucas De Marchi 已提交
936
				 * means error happened in OOB, so we ignore
937 938 939 940
				 * it. It's no need for us to correct it
				 * err_device is represented the NAND error
				 * bits are happened in if there are more
				 * than one NAND connected.
941
				 */
942
				if (err_byte < ECC_SECTOR_SIZE) {
943 944
					struct mtd_info *mtd =
						nand_to_mtd(&denali->nand);
945
					int offset;
946

947 948 949 950 951
					offset = (err_sector *
							ECC_SECTOR_SIZE +
							err_byte) *
							denali->devnum +
							err_device;
952 953
					/* correct the ECC error */
					buf[offset] ^= err_correction_value;
954
					mtd->ecc_stats.corrected++;
955
					bitflips++;
956
				}
957
			} else {
958 959
				/*
				 * if the error is not correctable, need to
960 961
				 * look at the page to see if it is an erased
				 * page. if so, then it's not a real ECC error
962
				 */
963 964 965
				check_erased_page = true;
			}
		} while (!ECC_LAST_ERR(err_correction_info));
966 967
		/*
		 * Once handle all ecc errors, controller will triger
968 969
		 * a ECC_TRANSACTION_DONE interrupt, so here just wait
		 * for a while for this interrupt
970
		 */
971
		while (!(read_interrupt_status(denali) &
972
				INTR_STATUS__ECC_TRANSACTION_DONE))
973 974 975
			cpu_relax();
		clear_interrupts(denali);
		denali_set_intr_modes(denali, true);
976
	}
977
	*max_bitflips = bitflips;
978 979 980 981
	return check_erased_page;
}

/* programs the controller to either enable/disable DMA transfers */
982
static void denali_enable_dma(struct denali_nand_info *denali, bool en)
983
{
984
	iowrite32(en ? DMA_ENABLE__FLAG : 0, denali->flash_reg + DMA_ENABLE);
985 986 987 988
	ioread32(denali->flash_reg + DMA_ENABLE);
}

/* setups the HW to perform the data DMA */
989
static void denali_setup_dma(struct denali_nand_info *denali, int op)
990
{
991
	uint32_t mode;
992
	const int page_count = 1;
993
	uint32_t addr = denali->buf.dma_buf;
994 995 996 997 998 999 1000 1001 1002

	mode = MODE_10 | BANK(denali->flash_bank);

	/* DMA is a four step process */

	/* 1. setup transfer type and # of pages */
	index_addr(denali, mode | denali->page, 0x2000 | op | page_count);

	/* 2. set memory high address bits 23:8 */
1003
	index_addr(denali, mode | ((addr >> 16) << 8), 0x2200);
1004 1005

	/* 3. set memory low address bits 23:8 */
1006
	index_addr(denali, mode | ((addr & 0xffff) << 8), 0x2300);
1007

1008
	/* 4. interrupt when complete, burst len = 64 bytes */
1009 1010 1011
	index_addr(denali, mode | 0x14000, 0x2400);
}

1012 1013 1014 1015
/*
 * writes a page. user specifies type, and this function handles the
 * configuration details.
 */
1016
static int write_page(struct mtd_info *mtd, struct nand_chip *chip,
1017 1018 1019 1020
			const uint8_t *buf, bool raw_xfer)
{
	struct denali_nand_info *denali = mtd_to_denali(mtd);
	dma_addr_t addr = denali->buf.dma_buf;
1021
	size_t size = mtd->writesize + mtd->oobsize;
1022
	uint32_t irq_status;
1023 1024
	uint32_t irq_mask = INTR_STATUS__DMA_CMD_COMP |
						INTR_STATUS__PROGRAM_FAIL;
1025

1026 1027
	/*
	 * if it is a raw xfer, we want to disable ecc and send the spare area.
1028 1029 1030 1031 1032 1033 1034 1035
	 * !raw_xfer - enable ecc
	 * raw_xfer - transfer spare
	 */
	setup_ecc_for_xfer(denali, !raw_xfer, raw_xfer);

	/* copy buffer into DMA buffer */
	memcpy(denali->buf.buf, buf, mtd->writesize);

1036
	if (raw_xfer) {
1037
		/* transfer the data to the spare area */
1038 1039 1040
		memcpy(denali->buf.buf + mtd->writesize,
			chip->oob_poi,
			mtd->oobsize);
1041 1042
	}

1043
	dma_sync_single_for_device(denali->dev, addr, size, DMA_TO_DEVICE);
1044 1045

	clear_interrupts(denali);
1046
	denali_enable_dma(denali, true);
1047

1048
	denali_setup_dma(denali, DENALI_WRITE);
1049 1050 1051 1052

	/* wait for operation to complete */
	irq_status = wait_for_irq(denali, irq_mask);

1053
	if (irq_status == 0) {
1054 1055
		dev_err(denali->dev, "timeout on write_page (type = %d)\n",
			raw_xfer);
1056
		denali->status = NAND_STATUS_FAIL;
1057 1058
	}

1059
	denali_enable_dma(denali, false);
1060
	dma_sync_single_for_cpu(denali->dev, addr, size, DMA_TO_DEVICE);
1061 1062

	return 0;
1063 1064 1065 1066
}

/* NAND core entry points */

1067 1068
/*
 * this is the callback that the NAND core calls to write a page. Since
1069 1070
 * writing a page with ECC or without is similar, all the work is done
 * by write_page above.
1071
 */
1072
static int denali_write_page(struct mtd_info *mtd, struct nand_chip *chip,
1073
				const uint8_t *buf, int oob_required, int page)
1074
{
1075 1076 1077 1078
	/*
	 * for regular page writes, we let HW handle all the ECC
	 * data written to the device.
	 */
1079
	return write_page(mtd, chip, buf, false);
1080 1081
}

1082 1083
/*
 * This is the callback that the NAND core calls to write a page without ECC.
L
Lucas De Marchi 已提交
1084
 * raw access is similar to ECC page writes, so all the work is done in the
1085
 * write_page() function above.
1086
 */
1087
static int denali_write_page_raw(struct mtd_info *mtd, struct nand_chip *chip,
1088 1089
				 const uint8_t *buf, int oob_required,
				 int page)
1090
{
1091 1092 1093 1094
	/*
	 * for raw page writes, we want to disable ECC and simply write
	 * whatever data is in the buffer.
	 */
1095
	return write_page(mtd, chip, buf, true);
1096 1097
}

1098
static int denali_write_oob(struct mtd_info *mtd, struct nand_chip *chip,
1099 1100
			    int page)
{
1101
	return write_oob_data(mtd, chip->oob_poi, page);
1102 1103
}

1104
static int denali_read_oob(struct mtd_info *mtd, struct nand_chip *chip,
1105
			   int page)
1106 1107 1108
{
	read_oob_data(mtd, chip->oob_poi, page);

1109
	return 0;
1110 1111 1112
}

static int denali_read_page(struct mtd_info *mtd, struct nand_chip *chip,
1113
			    uint8_t *buf, int oob_required, int page)
1114
{
1115
	unsigned int max_bitflips;
1116 1117 1118
	struct denali_nand_info *denali = mtd_to_denali(mtd);

	dma_addr_t addr = denali->buf.dma_buf;
1119
	size_t size = mtd->writesize + mtd->oobsize;
1120

1121
	uint32_t irq_status;
1122 1123
	uint32_t irq_mask = INTR_STATUS__ECC_TRANSACTION_DONE |
			    INTR_STATUS__ECC_ERR;
1124 1125
	bool check_erased_page = false;

1126
	if (page != denali->page) {
1127 1128 1129
		dev_err(denali->dev,
			"IN %s: page %d is not equal to denali->page %d",
			__func__, page, denali->page);
1130 1131 1132
		BUG();
	}

1133 1134
	setup_ecc_for_xfer(denali, true, false);

1135
	denali_enable_dma(denali, true);
1136
	dma_sync_single_for_device(denali->dev, addr, size, DMA_FROM_DEVICE);
1137 1138

	clear_interrupts(denali);
1139
	denali_setup_dma(denali, DENALI_READ);
1140 1141 1142 1143

	/* wait for operation to complete */
	irq_status = wait_for_irq(denali, irq_mask);

1144
	dma_sync_single_for_cpu(denali->dev, addr, size, DMA_FROM_DEVICE);
1145 1146

	memcpy(buf, denali->buf.buf, mtd->writesize);
1147

1148
	check_erased_page = handle_ecc(denali, buf, irq_status, &max_bitflips);
1149
	denali_enable_dma(denali, false);
1150

1151
	if (check_erased_page) {
1152
		read_oob_data(mtd, chip->oob_poi, denali->page);
1153 1154

		/* check ECC failures that may have occurred on erased pages */
1155
		if (check_erased_page) {
1156 1157 1158 1159
			if (!is_erased(buf, mtd->writesize))
				mtd->ecc_stats.failed++;
			if (!is_erased(buf, mtd->oobsize))
				mtd->ecc_stats.failed++;
1160
		}
1161
	}
1162
	return max_bitflips;
1163 1164 1165
}

static int denali_read_page_raw(struct mtd_info *mtd, struct nand_chip *chip,
1166
				uint8_t *buf, int oob_required, int page)
1167 1168 1169
{
	struct denali_nand_info *denali = mtd_to_denali(mtd);
	dma_addr_t addr = denali->buf.dma_buf;
1170
	size_t size = mtd->writesize + mtd->oobsize;
1171
	uint32_t irq_mask = INTR_STATUS__DMA_CMD_COMP;
1172

1173
	if (page != denali->page) {
1174 1175 1176
		dev_err(denali->dev,
			"IN %s: page %d is not equal to denali->page %d",
			__func__, page, denali->page);
1177 1178 1179
		BUG();
	}

1180
	setup_ecc_for_xfer(denali, false, true);
1181
	denali_enable_dma(denali, true);
1182

1183
	dma_sync_single_for_device(denali->dev, addr, size, DMA_FROM_DEVICE);
1184 1185

	clear_interrupts(denali);
1186
	denali_setup_dma(denali, DENALI_READ);
1187 1188

	/* wait for operation to complete */
1189
	wait_for_irq(denali, irq_mask);
1190

1191
	dma_sync_single_for_cpu(denali->dev, addr, size, DMA_FROM_DEVICE);
1192

1193
	denali_enable_dma(denali, false);
1194 1195 1196 1197 1198 1199 1200 1201 1202 1203 1204 1205 1206 1207 1208 1209 1210 1211 1212 1213 1214

	memcpy(buf, denali->buf.buf, mtd->writesize);
	memcpy(chip->oob_poi, denali->buf.buf + mtd->writesize, mtd->oobsize);

	return 0;
}

static uint8_t denali_read_byte(struct mtd_info *mtd)
{
	struct denali_nand_info *denali = mtd_to_denali(mtd);
	uint8_t result = 0xff;

	if (denali->buf.head < denali->buf.tail)
		result = denali->buf.buf[denali->buf.head++];

	return result;
}

static void denali_select_chip(struct mtd_info *mtd, int chip)
{
	struct denali_nand_info *denali = mtd_to_denali(mtd);
1215

1216 1217 1218 1219 1220 1221 1222 1223 1224
	spin_lock_irq(&denali->irq_lock);
	denali->flash_bank = chip;
	spin_unlock_irq(&denali->irq_lock);
}

static int denali_waitfunc(struct mtd_info *mtd, struct nand_chip *chip)
{
	struct denali_nand_info *denali = mtd_to_denali(mtd);
	int status = denali->status;
1225

1226 1227 1228 1229 1230
	denali->status = 0;

	return status;
}

1231
static int denali_erase(struct mtd_info *mtd, int page)
1232 1233 1234
{
	struct denali_nand_info *denali = mtd_to_denali(mtd);

1235
	uint32_t cmd, irq_status;
1236

1237
	clear_interrupts(denali);
1238 1239 1240

	/* setup page read request for access type */
	cmd = MODE_10 | BANK(denali->flash_bank) | page;
1241
	index_addr(denali, cmd, 0x1);
1242 1243

	/* wait for erase to complete or failure to occur */
1244 1245
	irq_status = wait_for_irq(denali, INTR_STATUS__ERASE_COMP |
					INTR_STATUS__ERASE_FAIL);
1246

1247
	return irq_status & INTR_STATUS__ERASE_FAIL ? NAND_STATUS_FAIL : PASS;
1248 1249
}

1250
static void denali_cmdfunc(struct mtd_info *mtd, unsigned int cmd, int col,
1251 1252 1253
			   int page)
{
	struct denali_nand_info *denali = mtd_to_denali(mtd);
1254 1255
	uint32_t addr, id;
	int i;
1256

1257
	switch (cmd) {
1258 1259 1260 1261 1262 1263
	case NAND_CMD_PAGEPROG:
		break;
	case NAND_CMD_STATUS:
		read_status(denali);
		break;
	case NAND_CMD_READID:
1264
	case NAND_CMD_PARAM:
1265
		reset_buf(denali);
1266 1267
		/*
		 * sometimes ManufactureId read from register is not right
1268 1269
		 * e.g. some of Micron MT29F32G08QAA MLC NAND chips
		 * So here we send READID cmd to NAND insteand
1270
		 */
1271 1272
		addr = MODE_11 | BANK(denali->flash_bank);
		index_addr(denali, addr | 0, 0x90);
1273
		index_addr(denali, addr | 1, col);
1274
		for (i = 0; i < 8; i++) {
1275
			index_addr_read_data(denali, addr | 2, &id);
1276
			write_byte_to_buf(denali, id);
1277 1278 1279 1280 1281 1282 1283 1284 1285 1286 1287 1288 1289
		}
		break;
	case NAND_CMD_READ0:
	case NAND_CMD_SEQIN:
		denali->page = page;
		break;
	case NAND_CMD_RESET:
		reset_bank(denali);
		break;
	case NAND_CMD_READOOB:
		/* TODO: Read OOB data */
		break;
	default:
1290
		pr_err(": unsupported command received 0x%x\n", cmd);
1291
		break;
1292 1293 1294 1295 1296 1297 1298
	}
}
/* end NAND core entry points */

/* Initialization code to bring the device up to a known good state */
static void denali_hw_init(struct denali_nand_info *denali)
{
1299 1300
	/*
	 * tell driver how many bit controller will skip before
1301 1302 1303
	 * writing ECC code in OOB, this register may be already
	 * set by firmware. So we read this value out.
	 * if this value is 0, just let it be.
1304
	 */
1305 1306
	denali->bbtskipbytes = ioread32(denali->flash_reg +
						SPARE_AREA_SKIP_BYTES);
1307
	detect_max_banks(denali);
1308
	denali_nand_reset(denali);
1309 1310
	iowrite32(0x0F, denali->flash_reg + RB_PIN_ENABLED);
	iowrite32(CHIP_EN_DONT_CARE__FLAG,
1311
			denali->flash_reg + CHIP_ENABLE_DONT_CARE);
1312

1313
	iowrite32(0xffff, denali->flash_reg + SPARE_AREA_MARKER);
1314 1315

	/* Should set value for these registers when init */
1316 1317
	iowrite32(0, denali->flash_reg + TWO_ROW_ADDR_CYCLES);
	iowrite32(1, denali->flash_reg + ECC_ENABLE);
1318 1319
	denali_nand_timing_set(denali);
	denali_irq_init(denali);
1320 1321
}

1322 1323
/*
 * Althogh controller spec said SLC ECC is forceb to be 4bit,
1324 1325
 * but denali controller in MRST only support 15bit and 8bit ECC
 * correction
1326
 */
1327 1328
#define ECC_8BITS	14
#define ECC_15BITS	26
1329 1330 1331 1332 1333 1334 1335 1336 1337 1338 1339 1340 1341 1342 1343 1344 1345 1346 1347 1348 1349 1350 1351 1352 1353 1354 1355 1356 1357 1358 1359 1360 1361 1362

static int denali_ooblayout_ecc(struct mtd_info *mtd, int section,
				struct mtd_oob_region *oobregion)
{
	struct denali_nand_info *denali = mtd_to_denali(mtd);
	struct nand_chip *chip = mtd_to_nand(mtd);

	if (section)
		return -ERANGE;

	oobregion->offset = denali->bbtskipbytes;
	oobregion->length = chip->ecc.total;

	return 0;
}

static int denali_ooblayout_free(struct mtd_info *mtd, int section,
				 struct mtd_oob_region *oobregion)
{
	struct denali_nand_info *denali = mtd_to_denali(mtd);
	struct nand_chip *chip = mtd_to_nand(mtd);

	if (section)
		return -ERANGE;

	oobregion->offset = chip->ecc.total + denali->bbtskipbytes;
	oobregion->length = mtd->oobsize - oobregion->offset;

	return 0;
}

static const struct mtd_ooblayout_ops denali_ooblayout_ops = {
	.ecc = denali_ooblayout_ecc,
	.free = denali_ooblayout_free,
1363 1364 1365 1366 1367 1368 1369 1370 1371 1372 1373 1374 1375 1376 1377 1378 1379 1380 1381 1382 1383 1384 1385 1386 1387
};

static uint8_t bbt_pattern[] = {'B', 'b', 't', '0' };
static uint8_t mirror_pattern[] = {'1', 't', 'b', 'B' };

static struct nand_bbt_descr bbt_main_descr = {
	.options = NAND_BBT_LASTBLOCK | NAND_BBT_CREATE | NAND_BBT_WRITE
		| NAND_BBT_2BIT | NAND_BBT_VERSION | NAND_BBT_PERCHIP,
	.offs =	8,
	.len = 4,
	.veroffs = 12,
	.maxblocks = 4,
	.pattern = bbt_pattern,
};

static struct nand_bbt_descr bbt_mirror_descr = {
	.options = NAND_BBT_LASTBLOCK | NAND_BBT_CREATE | NAND_BBT_WRITE
		| NAND_BBT_2BIT | NAND_BBT_VERSION | NAND_BBT_PERCHIP,
	.offs =	8,
	.len = 4,
	.veroffs = 12,
	.maxblocks = 4,
	.pattern = mirror_pattern,
};

1388
/* initialize driver data structures */
1389
static void denali_drv_init(struct denali_nand_info *denali)
1390
{
1391 1392 1393 1394
	/*
	 * the completion object will be used to notify
	 * the callee that the interrupt is done
	 */
1395 1396
	init_completion(&denali->complete);

1397 1398 1399 1400
	/*
	 * the spinlock will be used to synchronize the ISR with any
	 * element that might be access shared data (interrupt status)
	 */
1401 1402 1403 1404 1405 1406 1407 1408 1409
	spin_lock_init(&denali->irq_lock);

	/* indicate that MTD has not selected a valid bank yet */
	denali->flash_bank = CHIP_SELECT_INVALID;

	/* initialize our irq_status variable to indicate no interrupts */
	denali->irq_status = 0;
}

1410
int denali_init(struct denali_nand_info *denali)
1411
{
1412
	struct mtd_info *mtd = nand_to_mtd(&denali->nand);
1413
	int ret;
1414

1415
	if (denali->platform == INTEL_CE4100) {
1416 1417
		/*
		 * Due to a silicon limitation, we can only support
1418 1419
		 * ONFI timing mode 1 and below.
		 */
1420
		if (onfi_timing_mode < -1 || onfi_timing_mode > 1) {
1421 1422
			pr_err("Intel CE4100 only supports ONFI timing mode 1 or below\n");
			return -EINVAL;
1423 1424 1425
		}
	}

1426 1427 1428 1429 1430
	/* allocate a temporary buffer for nand_scan_ident() */
	denali->buf.buf = devm_kzalloc(denali->dev, PAGE_SIZE,
					GFP_DMA | GFP_KERNEL);
	if (!denali->buf.buf)
		return -ENOMEM;
1431

1432
	mtd->dev.parent = denali->dev;
1433 1434 1435
	denali_hw_init(denali);
	denali_drv_init(denali);

1436 1437 1438 1439
	/* Request IRQ after all the hardware initialization is finished */
	ret = devm_request_irq(denali->dev, denali->irq, denali_isr,
			       IRQF_SHARED, DENALI_NAND_NAME, denali);
	if (ret) {
1440
		dev_err(denali->dev, "Unable to request IRQ\n");
1441
		return ret;
1442 1443 1444
	}

	/* now that our ISR is registered, we can enable interrupts */
1445
	denali_set_intr_modes(denali, true);
1446
	mtd->name = "denali-nand";
1447 1448 1449 1450 1451 1452 1453

	/* register the driver with the NAND core subsystem */
	denali->nand.select_chip = denali_select_chip;
	denali->nand.cmdfunc = denali_cmdfunc;
	denali->nand.read_byte = denali_read_byte;
	denali->nand.waitfunc = denali_waitfunc;

1454 1455
	/*
	 * scan for NAND devices attached to the controller
1456
	 * this is the first stage in a two step process to register
1457 1458
	 * with the nand subsystem
	 */
1459 1460
	ret = nand_scan_ident(mtd, denali->max_banks, NULL);
	if (ret)
1461
		goto failed_req_irq;
1462

1463 1464 1465
	/* allocate the right size buffer now */
	devm_kfree(denali->dev, denali->buf.buf);
	denali->buf.buf = devm_kzalloc(denali->dev,
1466
			     mtd->writesize + mtd->oobsize,
1467 1468 1469 1470 1471 1472 1473 1474 1475
			     GFP_KERNEL);
	if (!denali->buf.buf) {
		ret = -ENOMEM;
		goto failed_req_irq;
	}

	/* Is 32-bit DMA supported? */
	ret = dma_set_mask(denali->dev, DMA_BIT_MASK(32));
	if (ret) {
1476
		dev_err(denali->dev, "No usable DMA configuration\n");
1477 1478 1479 1480
		goto failed_req_irq;
	}

	denali->buf.dma_buf = dma_map_single(denali->dev, denali->buf.buf,
1481
			     mtd->writesize + mtd->oobsize,
1482 1483
			     DMA_BIDIRECTIONAL);
	if (dma_mapping_error(denali->dev, denali->buf.dma_buf)) {
1484
		dev_err(denali->dev, "Failed to map DMA buffer\n");
1485
		ret = -EIO;
1486
		goto failed_req_irq;
1487 1488
	}

1489 1490 1491 1492
	/*
	 * support for multi nand
	 * MTD known nothing about multi nand, so we should tell it
	 * the real pagesize and anything necessery
1493 1494
	 */
	denali->devnum = ioread32(denali->flash_reg + DEVICES_CONNECTED);
1495 1496
	denali->nand.chipsize <<= denali->devnum - 1;
	denali->nand.page_shift += denali->devnum - 1;
1497 1498
	denali->nand.pagemask = (denali->nand.chipsize >>
						denali->nand.page_shift) - 1;
1499
	denali->nand.bbt_erase_shift += denali->devnum - 1;
1500
	denali->nand.phys_erase_shift = denali->nand.bbt_erase_shift;
1501 1502 1503 1504
	denali->nand.chip_shift += denali->devnum - 1;
	mtd->writesize <<= denali->devnum - 1;
	mtd->oobsize <<= denali->devnum - 1;
	mtd->erasesize <<= denali->devnum - 1;
1505
	mtd->size = denali->nand.numchips * denali->nand.chipsize;
1506 1507
	denali->bbtskipbytes *= denali->devnum;

1508 1509
	/*
	 * second stage of the NAND scan
1510
	 * this stage requires information regarding ECC and
1511 1512
	 * bad block management.
	 */
1513 1514 1515 1516 1517 1518

	/* Bad block management */
	denali->nand.bbt_td = &bbt_main_descr;
	denali->nand.bbt_md = &bbt_mirror_descr;

	/* skip the scan for now until we have OOB read and write support */
1519
	denali->nand.bbt_options |= NAND_BBT_USE_FLASH;
1520
	denali->nand.options |= NAND_SKIP_BBTSCAN;
1521 1522
	denali->nand.ecc.mode = NAND_ECC_HW_SYNDROME;

1523 1524 1525
	/* no subpage writes on denali */
	denali->nand.options |= NAND_NO_SUBPAGE_WRITE;

1526 1527
	/*
	 * Denali Controller only support 15bit and 8bit ECC in MRST,
1528 1529 1530
	 * so just let controller do 15bit ECC for MLC and 8bit ECC for
	 * SLC if possible.
	 * */
1531
	if (!nand_is_slc(&denali->nand) &&
1532 1533
			(mtd->oobsize > (denali->bbtskipbytes +
			ECC_15BITS * (mtd->writesize /
1534 1535
			ECC_SECTOR_SIZE)))) {
		/* if MLC OOB size is large enough, use 15bit ECC*/
M
Mike Dunn 已提交
1536
		denali->nand.ecc.strength = 15;
1537
		denali->nand.ecc.bytes = ECC_15BITS;
1538
		iowrite32(15, denali->flash_reg + ECC_CORRECTION);
1539 1540
	} else if (mtd->oobsize < (denali->bbtskipbytes +
			ECC_8BITS * (mtd->writesize /
1541
			ECC_SECTOR_SIZE))) {
1542
		pr_err("Your NAND chip OOB is not large enough to contain 8bit ECC correction codes");
1543
		goto failed_req_irq;
1544
	} else {
M
Mike Dunn 已提交
1545
		denali->nand.ecc.strength = 8;
1546
		denali->nand.ecc.bytes = ECC_8BITS;
1547
		iowrite32(8, denali->flash_reg + ECC_CORRECTION);
1548 1549
	}

1550
	mtd_set_ooblayout(mtd, &denali_ooblayout_ops);
1551
	denali->nand.ecc.bytes *= denali->devnum;
M
Mike Dunn 已提交
1552
	denali->nand.ecc.strength *= denali->devnum;
1553

1554
	/* override the default read operations */
1555
	denali->nand.ecc.size = ECC_SECTOR_SIZE * denali->devnum;
1556 1557 1558 1559 1560 1561
	denali->nand.ecc.read_page = denali_read_page;
	denali->nand.ecc.read_page_raw = denali_read_page_raw;
	denali->nand.ecc.write_page = denali_write_page;
	denali->nand.ecc.write_page_raw = denali_write_page_raw;
	denali->nand.ecc.read_oob = denali_read_oob;
	denali->nand.ecc.write_oob = denali_write_oob;
1562
	denali->nand.erase = denali_erase;
1563

1564 1565
	ret = nand_scan_tail(mtd);
	if (ret)
1566
		goto failed_req_irq;
1567

1568
	ret = mtd_device_register(mtd, NULL, 0);
1569
	if (ret) {
1570
		dev_err(denali->dev, "Failed to register MTD: %d\n", ret);
1571
		goto failed_req_irq;
1572 1573 1574
	}
	return 0;

1575
failed_req_irq:
1576 1577
	denali_irq_cleanup(denali->irq, denali);

1578 1579
	return ret;
}
1580
EXPORT_SYMBOL(denali_init);
1581 1582

/* driver exit point */
1583
void denali_remove(struct denali_nand_info *denali)
1584
{
1585
	struct mtd_info *mtd = nand_to_mtd(&denali->nand);
1586 1587 1588 1589 1590
	/*
	 * Pre-compute DMA buffer size to avoid any problems in case
	 * nand_release() ever changes in a way that mtd->writesize and
	 * mtd->oobsize are not reliable after this call.
	 */
1591
	int bufsize = mtd->writesize + mtd->oobsize;
1592

1593
	nand_release(mtd);
1594
	denali_irq_cleanup(denali->irq, denali);
1595
	dma_unmap_single(denali->dev, denali->buf.dma_buf, bufsize,
1596
			 DMA_BIDIRECTIONAL);
1597
}
1598
EXPORT_SYMBOL(denali_remove);