• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 // SPDX-License-Identifier: GPL-2.0+
2 /*
3  * Copyright (C) 2006-2009 Freescale Semiconductor, Inc.
4  *
5  * Dave Liu <daveliu@freescale.com>
6  * based on source code of Shlomi Gridish
7  */
8 
9 #include <common.h>
10 #include <malloc.h>
11 #include <command.h>
12 #include <linux/errno.h>
13 #include <asm/io.h>
14 #include <linux/immap_qe.h>
15 #include <fsl_qe.h>
16 #include <mmc.h>
17 #include <u-boot/crc.h>
18 
19 #ifdef CONFIG_ARCH_LS1021A
20 #include <asm/arch/immap_ls102xa.h>
21 #endif
22 #ifdef CONFIG_ARM64
23 #include <asm/armv8/mmu.h>
24 #include <asm/arch/cpu.h>
25 #endif
26 
27 #define MPC85xx_DEVDISR_QE_DISABLE	0x1
28 
29 qe_map_t		*qe_immr = NULL;
30 #ifdef CONFIG_QE
31 static qe_snum_t	snums[QE_NUM_OF_SNUM];
32 #endif
33 
34 DECLARE_GLOBAL_DATA_PTR;
35 
qe_issue_cmd(uint cmd,uint sbc,u8 mcn,u32 cmd_data)36 void qe_issue_cmd(uint cmd, uint sbc, u8 mcn, u32 cmd_data)
37 {
38 	u32 cecr;
39 
40 	if (cmd == QE_RESET) {
41 		out_be32(&qe_immr->cp.cecr,(u32) (cmd | QE_CR_FLG));
42 	} else {
43 		out_be32(&qe_immr->cp.cecdr, cmd_data);
44 		out_be32(&qe_immr->cp.cecr, (sbc | QE_CR_FLG |
45 			 ((u32) mcn<<QE_CR_PROTOCOL_SHIFT) | cmd));
46 	}
47 	/* Wait for the QE_CR_FLG to clear */
48 	do {
49 		cecr = in_be32(&qe_immr->cp.cecr);
50 	} while (cecr & QE_CR_FLG);
51 
52 	return;
53 }
54 
55 #ifdef CONFIG_QE
qe_muram_alloc(uint size,uint align)56 uint qe_muram_alloc(uint size, uint align)
57 {
58 	uint	retloc;
59 	uint	align_mask, off;
60 	uint	savebase;
61 
62 	align_mask = align - 1;
63 	savebase = gd->arch.mp_alloc_base;
64 
65 	off = gd->arch.mp_alloc_base & align_mask;
66 	if (off != 0)
67 		gd->arch.mp_alloc_base += (align - off);
68 
69 	if ((off = size & align_mask) != 0)
70 		size += (align - off);
71 
72 	if ((gd->arch.mp_alloc_base + size) >= gd->arch.mp_alloc_top) {
73 		gd->arch.mp_alloc_base = savebase;
74 		printf("%s: ran out of ram.\n",  __FUNCTION__);
75 	}
76 
77 	retloc = gd->arch.mp_alloc_base;
78 	gd->arch.mp_alloc_base += size;
79 
80 	memset((void *)&qe_immr->muram[retloc], 0, size);
81 
82 	__asm__ __volatile__("sync");
83 
84 	return retloc;
85 }
86 #endif
87 
qe_muram_addr(uint offset)88 void *qe_muram_addr(uint offset)
89 {
90 	return (void *)&qe_immr->muram[offset];
91 }
92 
93 #ifdef CONFIG_QE
qe_sdma_init(void)94 static void qe_sdma_init(void)
95 {
96 	volatile sdma_t	*p;
97 	uint		sdma_buffer_base;
98 
99 	p = (volatile sdma_t *)&qe_immr->sdma;
100 
101 	/* All of DMA transaction in bus 1 */
102 	out_be32(&p->sdaqr, 0);
103 	out_be32(&p->sdaqmr, 0);
104 
105 	/* Allocate 2KB temporary buffer for sdma */
106 	sdma_buffer_base = qe_muram_alloc(2048, 4096);
107 	out_be32(&p->sdwbcr, sdma_buffer_base & QE_SDEBCR_BA_MASK);
108 
109 	/* Clear sdma status */
110 	out_be32(&p->sdsr, 0x03000000);
111 
112 	/* Enable global mode on bus 1, and 2KB buffer size */
113 	out_be32(&p->sdmr, QE_SDMR_GLB_1_MSK | (0x3 << QE_SDMR_CEN_SHIFT));
114 }
115 
116 /* This table is a list of the serial numbers of the Threads, taken from the
117  * "SNUM Table" chart in the QE Reference Manual. The order is not important,
118  * we just need to know what the SNUMs are for the threads.
119  */
120 static u8 thread_snum[] = {
121 /* Evthreads 16-29 are not supported in MPC8309 */
122 #if !defined(CONFIG_ARCH_MPC8309)
123 	0x04, 0x05, 0x0c, 0x0d,
124 	0x14, 0x15, 0x1c, 0x1d,
125 	0x24, 0x25, 0x2c, 0x2d,
126 	0x34, 0x35,
127 #endif
128 	0x88, 0x89, 0x98, 0x99,
129 	0xa8, 0xa9, 0xb8, 0xb9,
130 	0xc8, 0xc9, 0xd8, 0xd9,
131 	0xe8, 0xe9, 0x08, 0x09,
132 	0x18, 0x19, 0x28, 0x29,
133 	0x38, 0x39, 0x48, 0x49,
134 	0x58, 0x59, 0x68, 0x69,
135 	0x78, 0x79, 0x80, 0x81
136 };
137 
qe_snums_init(void)138 static void qe_snums_init(void)
139 {
140 	int	i;
141 
142 	for (i = 0; i < QE_NUM_OF_SNUM; i++) {
143 		snums[i].state = QE_SNUM_STATE_FREE;
144 		snums[i].num   = thread_snum[i];
145 	}
146 }
147 
qe_get_snum(void)148 int qe_get_snum(void)
149 {
150 	int	snum = -EBUSY;
151 	int	i;
152 
153 	for (i = 0; i < QE_NUM_OF_SNUM; i++) {
154 		if (snums[i].state == QE_SNUM_STATE_FREE) {
155 			snums[i].state = QE_SNUM_STATE_USED;
156 			snum = snums[i].num;
157 			break;
158 		}
159 	}
160 
161 	return snum;
162 }
163 
qe_put_snum(u8 snum)164 void qe_put_snum(u8 snum)
165 {
166 	int	i;
167 
168 	for (i = 0; i < QE_NUM_OF_SNUM; i++) {
169 		if (snums[i].num == snum) {
170 			snums[i].state = QE_SNUM_STATE_FREE;
171 			break;
172 		}
173 	}
174 }
175 
176 #ifdef CONFIG_TFABOOT
qe_init(uint qe_base)177 void qe_init(uint qe_base)
178 {
179 	enum boot_src src = get_boot_src();
180 
181 	/* Init the QE IMMR base */
182 	qe_immr = (qe_map_t *)qe_base;
183 
184 	if (src == BOOT_SOURCE_IFC_NOR) {
185 		/*
186 		 * Upload microcode to IRAM for those SOCs
187 		 * which do not have ROM in QE.
188 		 */
189 		qe_upload_firmware((const void *)(CONFIG_SYS_QE_FW_ADDR +
190 				   CONFIG_SYS_FSL_IFC_BASE));
191 
192 		/* enable the microcode in IRAM */
193 		out_be32(&qe_immr->iram.iready, QE_IRAM_READY);
194 	}
195 
196 	gd->arch.mp_alloc_base = QE_DATAONLY_BASE;
197 	gd->arch.mp_alloc_top = gd->arch.mp_alloc_base + QE_DATAONLY_SIZE;
198 
199 	qe_sdma_init();
200 	qe_snums_init();
201 }
202 #else
qe_init(uint qe_base)203 void qe_init(uint qe_base)
204 {
205 	/* Init the QE IMMR base */
206 	qe_immr = (qe_map_t *)qe_base;
207 
208 #ifdef CONFIG_SYS_QE_FMAN_FW_IN_NOR
209 	/*
210 	 * Upload microcode to IRAM for those SOCs which do not have ROM in QE.
211 	 */
212 	qe_upload_firmware((const void *)CONFIG_SYS_QE_FW_ADDR);
213 
214 	/* enable the microcode in IRAM */
215 	out_be32(&qe_immr->iram.iready,QE_IRAM_READY);
216 #endif
217 
218 	gd->arch.mp_alloc_base = QE_DATAONLY_BASE;
219 	gd->arch.mp_alloc_top = gd->arch.mp_alloc_base + QE_DATAONLY_SIZE;
220 
221 	qe_sdma_init();
222 	qe_snums_init();
223 }
224 #endif
225 #endif
226 
227 #ifdef CONFIG_U_QE
228 #ifdef CONFIG_TFABOOT
u_qe_init(void)229 void u_qe_init(void)
230 {
231 	enum boot_src src = get_boot_src();
232 
233 	qe_immr = (qe_map_t *)(CONFIG_SYS_IMMR + QE_IMMR_OFFSET);
234 
235 	void *addr = (void *)CONFIG_SYS_QE_FW_ADDR;
236 
237 	if (src == BOOT_SOURCE_IFC_NOR)
238 		addr = (void *)(CONFIG_SYS_QE_FW_ADDR + CONFIG_SYS_FSL_IFC_BASE);
239 
240 	if (src == BOOT_SOURCE_QSPI_NOR)
241 		addr = (void *)(CONFIG_SYS_QE_FW_ADDR + CONFIG_SYS_FSL_QSPI_BASE);
242 
243 	if (src == BOOT_SOURCE_SD_MMC) {
244 		int dev = CONFIG_SYS_MMC_ENV_DEV;
245 		u32 cnt = CONFIG_SYS_QE_FMAN_FW_LENGTH / 512;
246 		u32 blk = CONFIG_SYS_QE_FW_ADDR / 512;
247 
248 		if (mmc_initialize(gd->bd)) {
249 			printf("%s: mmc_initialize() failed\n", __func__);
250 			return;
251 		}
252 		addr = malloc(CONFIG_SYS_QE_FMAN_FW_LENGTH);
253 		struct mmc *mmc = find_mmc_device(CONFIG_SYS_MMC_ENV_DEV);
254 
255 		if (!mmc) {
256 			free(addr);
257 			printf("\nMMC cannot find device for ucode\n");
258 		} else {
259 			printf("\nMMC read: dev # %u, block # %u, count %u ...\n",
260 			       dev, blk, cnt);
261 			mmc_init(mmc);
262 			(void)blk_dread(mmc_get_blk_desc(mmc), blk, cnt,
263 						addr);
264 		}
265 	}
266 	if (!u_qe_upload_firmware(addr))
267 		out_be32(&qe_immr->iram.iready, QE_IRAM_READY);
268 	if (src == BOOT_SOURCE_SD_MMC)
269 		free(addr);
270 }
271 #else
u_qe_init(void)272 void u_qe_init(void)
273 {
274 	qe_immr = (qe_map_t *)(CONFIG_SYS_IMMR + QE_IMMR_OFFSET);
275 
276 	void *addr = (void *)CONFIG_SYS_QE_FW_ADDR;
277 #ifdef CONFIG_SYS_QE_FMAN_FW_IN_MMC
278 	int dev = CONFIG_SYS_MMC_ENV_DEV;
279 	u32 cnt = CONFIG_SYS_QE_FMAN_FW_LENGTH / 512;
280 	u32 blk = CONFIG_SYS_QE_FW_ADDR / 512;
281 
282 	if (mmc_initialize(gd->bd)) {
283 		printf("%s: mmc_initialize() failed\n", __func__);
284 		return;
285 	}
286 	addr = malloc(CONFIG_SYS_QE_FMAN_FW_LENGTH);
287 	struct mmc *mmc = find_mmc_device(CONFIG_SYS_MMC_ENV_DEV);
288 
289 	if (!mmc) {
290 		free(addr);
291 		printf("\nMMC cannot find device for ucode\n");
292 	} else {
293 		printf("\nMMC read: dev # %u, block # %u, count %u ...\n",
294 		       dev, blk, cnt);
295 		mmc_init(mmc);
296 		(void)blk_dread(mmc_get_blk_desc(mmc), blk, cnt,
297 						addr);
298 	}
299 #endif
300 	if (!u_qe_upload_firmware(addr))
301 		out_be32(&qe_immr->iram.iready, QE_IRAM_READY);
302 #ifdef CONFIG_SYS_QE_FMAN_FW_IN_MMC
303 	free(addr);
304 #endif
305 }
306 #endif
307 #endif
308 
309 #ifdef CONFIG_U_QE
u_qe_resume(void)310 void u_qe_resume(void)
311 {
312 	qe_map_t *qe_immrr;
313 
314 	qe_immrr = (qe_map_t *)(CONFIG_SYS_IMMR + QE_IMMR_OFFSET);
315 	u_qe_firmware_resume((const void *)CONFIG_SYS_QE_FW_ADDR, qe_immrr);
316 	out_be32(&qe_immrr->iram.iready, QE_IRAM_READY);
317 }
318 #endif
319 
qe_reset(void)320 void qe_reset(void)
321 {
322 	qe_issue_cmd(QE_RESET, QE_CR_SUBBLOCK_INVALID,
323 			 (u8) QE_CR_PROTOCOL_UNSPECIFIED, 0);
324 }
325 
326 #ifdef CONFIG_QE
qe_assign_page(uint snum,uint para_ram_base)327 void qe_assign_page(uint snum, uint para_ram_base)
328 {
329 	u32	cecr;
330 
331 	out_be32(&qe_immr->cp.cecdr, para_ram_base);
332 	out_be32(&qe_immr->cp.cecr, ((u32) snum<<QE_CR_ASSIGN_PAGE_SNUM_SHIFT)
333 					 | QE_CR_FLG | QE_ASSIGN_PAGE);
334 
335 	/* Wait for the QE_CR_FLG to clear */
336 	do {
337 		cecr = in_be32(&qe_immr->cp.cecr);
338 	} while (cecr & QE_CR_FLG );
339 
340 	return;
341 }
342 #endif
343 
344 /*
345  * brg: 0~15 as BRG1~BRG16
346    rate: baud rate
347  * BRG input clock comes from the BRGCLK (internal clock generated from
348    the QE clock, it is one-half of the QE clock), If need the clock source
349    from CLKn pin, we have te change the function.
350  */
351 
352 #define BRG_CLK		(gd->arch.brg_clk)
353 
354 #ifdef CONFIG_QE
qe_set_brg(uint brg,uint rate)355 int qe_set_brg(uint brg, uint rate)
356 {
357 	volatile uint	*bp;
358 	u32		divisor;
359 	int		div16 = 0;
360 
361 	if (brg >= QE_NUM_OF_BRGS)
362 		return -EINVAL;
363 	bp = (uint *)&qe_immr->brg.brgc1;
364 	bp += brg;
365 
366 	divisor = (BRG_CLK / rate);
367 	if (divisor > QE_BRGC_DIVISOR_MAX + 1) {
368 		div16 = 1;
369 		divisor /= 16;
370 	}
371 
372 	*bp = ((divisor - 1) << QE_BRGC_DIVISOR_SHIFT) | QE_BRGC_ENABLE;
373 	__asm__ __volatile__("sync");
374 
375 	if (div16) {
376 		*bp |= QE_BRGC_DIV16;
377 		__asm__ __volatile__("sync");
378 	}
379 
380 	return 0;
381 }
382 #endif
383 
384 /* Set ethernet MII clock master
385 */
qe_set_mii_clk_src(int ucc_num)386 int qe_set_mii_clk_src(int ucc_num)
387 {
388 	u32	cmxgcr;
389 
390 	/* check if the UCC number is in range. */
391 	if ((ucc_num > UCC_MAX_NUM - 1) || (ucc_num < 0)) {
392 		printf("%s: ucc num not in ranges\n", __FUNCTION__);
393 		return -EINVAL;
394 	}
395 
396 	cmxgcr = in_be32(&qe_immr->qmx.cmxgcr);
397 	cmxgcr &= ~QE_CMXGCR_MII_ENET_MNG_MASK;
398 	cmxgcr |= (ucc_num <<QE_CMXGCR_MII_ENET_MNG_SHIFT);
399 	out_be32(&qe_immr->qmx.cmxgcr, cmxgcr);
400 
401 	return 0;
402 }
403 
404 /* Firmware information stored here for qe_get_firmware_info() */
405 static struct qe_firmware_info qe_firmware_info;
406 
407 /*
408  * Set to 1 if QE firmware has been uploaded, and therefore
409  * qe_firmware_info contains valid data.
410  */
411 static int qe_firmware_uploaded;
412 
413 /*
414  * Upload a QE microcode
415  *
416  * This function is a worker function for qe_upload_firmware().  It does
417  * the actual uploading of the microcode.
418  */
qe_upload_microcode(const void * base,const struct qe_microcode * ucode)419 static void qe_upload_microcode(const void *base,
420 	const struct qe_microcode *ucode)
421 {
422 	const u32 *code = base + be32_to_cpu(ucode->code_offset);
423 	unsigned int i;
424 
425 	if (ucode->major || ucode->minor || ucode->revision)
426 		printf("QE: uploading microcode '%s' version %u.%u.%u\n",
427 		       (char *)ucode->id, (u16)ucode->major, (u16)ucode->minor,
428 		       (u16)ucode->revision);
429 	else
430 		printf("QE: uploading microcode '%s'\n", (char *)ucode->id);
431 
432 	/* Use auto-increment */
433 	out_be32(&qe_immr->iram.iadd, be32_to_cpu(ucode->iram_offset) |
434 		QE_IRAM_IADD_AIE | QE_IRAM_IADD_BADDR);
435 
436 	for (i = 0; i < be32_to_cpu(ucode->count); i++)
437 		out_be32(&qe_immr->iram.idata, be32_to_cpu(code[i]));
438 }
439 
440 /*
441  * Upload a microcode to the I-RAM at a specific address.
442  *
443  * See docs/README.qe_firmware for information on QE microcode uploading.
444  *
445  * Currently, only version 1 is supported, so the 'version' field must be
446  * set to 1.
447  *
448  * The SOC model and revision are not validated, they are only displayed for
449  * informational purposes.
450  *
451  * 'calc_size' is the calculated size, in bytes, of the firmware structure and
452  * all of the microcode structures, minus the CRC.
453  *
454  * 'length' is the size that the structure says it is, including the CRC.
455  */
qe_upload_firmware(const struct qe_firmware * firmware)456 int qe_upload_firmware(const struct qe_firmware *firmware)
457 {
458 	unsigned int i;
459 	unsigned int j;
460 	u32 crc;
461 	size_t calc_size = sizeof(struct qe_firmware);
462 	size_t length;
463 	const struct qe_header *hdr;
464 #ifdef CONFIG_DEEP_SLEEP
465 #ifdef CONFIG_ARCH_LS1021A
466 	struct ccsr_gur __iomem *gur = (void *)CONFIG_SYS_FSL_GUTS_ADDR;
467 #else
468 	ccsr_gur_t *gur = (void *)(CONFIG_SYS_MPC85xx_GUTS_ADDR);
469 #endif
470 #endif
471 	if (!firmware) {
472 		printf("Invalid address\n");
473 		return -EINVAL;
474 	}
475 
476 	hdr = &firmware->header;
477 	length = be32_to_cpu(hdr->length);
478 
479 	/* Check the magic */
480 	if ((hdr->magic[0] != 'Q') || (hdr->magic[1] != 'E') ||
481 	    (hdr->magic[2] != 'F')) {
482 		printf("QE microcode not found\n");
483 #ifdef CONFIG_DEEP_SLEEP
484 		setbits_be32(&gur->devdisr, MPC85xx_DEVDISR_QE_DISABLE);
485 #endif
486 		return -EPERM;
487 	}
488 
489 	/* Check the version */
490 	if (hdr->version != 1) {
491 		printf("Unsupported version\n");
492 		return -EPERM;
493 	}
494 
495 	/* Validate some of the fields */
496 	if ((firmware->count < 1) || (firmware->count > MAX_QE_RISC)) {
497 		printf("Invalid data\n");
498 		return -EINVAL;
499 	}
500 
501 	/* Validate the length and check if there's a CRC */
502 	calc_size += (firmware->count - 1) * sizeof(struct qe_microcode);
503 
504 	for (i = 0; i < firmware->count; i++)
505 		/*
506 		 * For situations where the second RISC uses the same microcode
507 		 * as the first, the 'code_offset' and 'count' fields will be
508 		 * zero, so it's okay to add those.
509 		 */
510 		calc_size += sizeof(u32) *
511 			be32_to_cpu(firmware->microcode[i].count);
512 
513 	/* Validate the length */
514 	if (length != calc_size + sizeof(u32)) {
515 		printf("Invalid length\n");
516 		return -EPERM;
517 	}
518 
519 	/*
520 	 * Validate the CRC.  We would normally call crc32_no_comp(), but that
521 	 * function isn't available unless you turn on JFFS support.
522 	 */
523 	crc = be32_to_cpu(*(u32 *)((void *)firmware + calc_size));
524 	if (crc != (crc32(-1, (const void *) firmware, calc_size) ^ -1)) {
525 		printf("Firmware CRC is invalid\n");
526 		return -EIO;
527 	}
528 
529 	/*
530 	 * If the microcode calls for it, split the I-RAM.
531 	 */
532 	if (!firmware->split) {
533 		out_be16(&qe_immr->cp.cercr,
534 			in_be16(&qe_immr->cp.cercr) | QE_CP_CERCR_CIR);
535 	}
536 
537 	if (firmware->soc.model)
538 		printf("Firmware '%s' for %u V%u.%u\n",
539 			firmware->id, be16_to_cpu(firmware->soc.model),
540 			firmware->soc.major, firmware->soc.minor);
541 	else
542 		printf("Firmware '%s'\n", firmware->id);
543 
544 	/*
545 	 * The QE only supports one microcode per RISC, so clear out all the
546 	 * saved microcode information and put in the new.
547 	 */
548 	memset(&qe_firmware_info, 0, sizeof(qe_firmware_info));
549 	strncpy(qe_firmware_info.id, (char *)firmware->id, 62);
550 	qe_firmware_info.extended_modes = firmware->extended_modes;
551 	memcpy(qe_firmware_info.vtraps, firmware->vtraps,
552 		sizeof(firmware->vtraps));
553 	qe_firmware_uploaded = 1;
554 
555 	/* Loop through each microcode. */
556 	for (i = 0; i < firmware->count; i++) {
557 		const struct qe_microcode *ucode = &firmware->microcode[i];
558 
559 		/* Upload a microcode if it's present */
560 		if (ucode->code_offset)
561 			qe_upload_microcode(firmware, ucode);
562 
563 		/* Program the traps for this processor */
564 		for (j = 0; j < 16; j++) {
565 			u32 trap = be32_to_cpu(ucode->traps[j]);
566 
567 			if (trap)
568 				out_be32(&qe_immr->rsp[i].tibcr[j], trap);
569 		}
570 
571 		/* Enable traps */
572 		out_be32(&qe_immr->rsp[i].eccr, be32_to_cpu(ucode->eccr));
573 	}
574 
575 	return 0;
576 }
577 
578 #ifdef CONFIG_U_QE
579 /*
580  * Upload a microcode to the I-RAM at a specific address.
581  *
582  * See docs/README.qe_firmware for information on QE microcode uploading.
583  *
584  * Currently, only version 1 is supported, so the 'version' field must be
585  * set to 1.
586  *
587  * The SOC model and revision are not validated, they are only displayed for
588  * informational purposes.
589  *
590  * 'calc_size' is the calculated size, in bytes, of the firmware structure and
591  * all of the microcode structures, minus the CRC.
592  *
593  * 'length' is the size that the structure says it is, including the CRC.
594  */
u_qe_upload_firmware(const struct qe_firmware * firmware)595 int u_qe_upload_firmware(const struct qe_firmware *firmware)
596 {
597 	unsigned int i;
598 	unsigned int j;
599 	u32 crc;
600 	size_t calc_size = sizeof(struct qe_firmware);
601 	size_t length;
602 	const struct qe_header *hdr;
603 #ifdef CONFIG_DEEP_SLEEP
604 #ifdef CONFIG_ARCH_LS1021A
605 	struct ccsr_gur __iomem *gur = (void *)CONFIG_SYS_FSL_GUTS_ADDR;
606 #else
607 	ccsr_gur_t __iomem *gur = (void *)(CONFIG_SYS_MPC85xx_GUTS_ADDR);
608 #endif
609 #endif
610 	if (!firmware) {
611 		printf("Invalid address\n");
612 		return -EINVAL;
613 	}
614 
615 	hdr = &firmware->header;
616 	length = be32_to_cpu(hdr->length);
617 
618 	/* Check the magic */
619 	if ((hdr->magic[0] != 'Q') || (hdr->magic[1] != 'E') ||
620 	    (hdr->magic[2] != 'F')) {
621 		printf("Not a microcode\n");
622 #ifdef CONFIG_DEEP_SLEEP
623 		setbits_be32(&gur->devdisr, MPC85xx_DEVDISR_QE_DISABLE);
624 #endif
625 		return -EPERM;
626 	}
627 
628 	/* Check the version */
629 	if (hdr->version != 1) {
630 		printf("Unsupported version\n");
631 		return -EPERM;
632 	}
633 
634 	/* Validate some of the fields */
635 	if ((firmware->count < 1) || (firmware->count > MAX_QE_RISC)) {
636 		printf("Invalid data\n");
637 		return -EINVAL;
638 	}
639 
640 	/* Validate the length and check if there's a CRC */
641 	calc_size += (firmware->count - 1) * sizeof(struct qe_microcode);
642 
643 	for (i = 0; i < firmware->count; i++)
644 		/*
645 		 * For situations where the second RISC uses the same microcode
646 		 * as the first, the 'code_offset' and 'count' fields will be
647 		 * zero, so it's okay to add those.
648 		 */
649 		calc_size += sizeof(u32) *
650 			be32_to_cpu(firmware->microcode[i].count);
651 
652 	/* Validate the length */
653 	if (length != calc_size + sizeof(u32)) {
654 		printf("Invalid length\n");
655 		return -EPERM;
656 	}
657 
658 	/*
659 	 * Validate the CRC.  We would normally call crc32_no_comp(), but that
660 	 * function isn't available unless you turn on JFFS support.
661 	 */
662 	crc = be32_to_cpu(*(u32 *)((void *)firmware + calc_size));
663 	if (crc != (crc32(-1, (const void *)firmware, calc_size) ^ -1)) {
664 		printf("Firmware CRC is invalid\n");
665 		return -EIO;
666 	}
667 
668 	/*
669 	 * If the microcode calls for it, split the I-RAM.
670 	 */
671 	if (!firmware->split) {
672 		out_be16(&qe_immr->cp.cercr,
673 			 in_be16(&qe_immr->cp.cercr) | QE_CP_CERCR_CIR);
674 	}
675 
676 	if (firmware->soc.model)
677 		printf("Firmware '%s' for %u V%u.%u\n",
678 		       firmware->id, be16_to_cpu(firmware->soc.model),
679 		       firmware->soc.major, firmware->soc.minor);
680 	else
681 		printf("Firmware '%s'\n", firmware->id);
682 
683 	/* Loop through each microcode. */
684 	for (i = 0; i < firmware->count; i++) {
685 		const struct qe_microcode *ucode = &firmware->microcode[i];
686 
687 		/* Upload a microcode if it's present */
688 		if (ucode->code_offset)
689 			qe_upload_microcode(firmware, ucode);
690 
691 		/* Program the traps for this processor */
692 		for (j = 0; j < 16; j++) {
693 			u32 trap = be32_to_cpu(ucode->traps[j]);
694 
695 			if (trap)
696 				out_be32(&qe_immr->rsp[i].tibcr[j], trap);
697 		}
698 
699 		/* Enable traps */
700 		out_be32(&qe_immr->rsp[i].eccr, be32_to_cpu(ucode->eccr));
701 	}
702 
703 	return 0;
704 }
705 #endif
706 
707 #ifdef CONFIG_U_QE
u_qe_firmware_resume(const struct qe_firmware * firmware,qe_map_t * qe_immrr)708 int u_qe_firmware_resume(const struct qe_firmware *firmware, qe_map_t *qe_immrr)
709 {
710 	unsigned int i;
711 	unsigned int j;
712 	const struct qe_header *hdr;
713 	const u32 *code;
714 #ifdef CONFIG_DEEP_SLEEP
715 #ifdef CONFIG_PPC
716 	ccsr_gur_t __iomem *gur = (void *)(CONFIG_SYS_MPC85xx_GUTS_ADDR);
717 #else
718 	struct ccsr_gur __iomem *gur = (void *)CONFIG_SYS_FSL_GUTS_ADDR;
719 #endif
720 #endif
721 
722 	if (!firmware)
723 		return -EINVAL;
724 
725 	hdr = &firmware->header;
726 
727 	/* Check the magic */
728 	if ((hdr->magic[0] != 'Q') || (hdr->magic[1] != 'E') ||
729 	    (hdr->magic[2] != 'F')) {
730 #ifdef CONFIG_DEEP_SLEEP
731 		setbits_be32(&gur->devdisr, MPC85xx_DEVDISR_QE_DISABLE);
732 #endif
733 		return -EPERM;
734 	}
735 
736 	/*
737 	 * If the microcode calls for it, split the I-RAM.
738 	 */
739 	if (!firmware->split) {
740 		out_be16(&qe_immrr->cp.cercr,
741 			 in_be16(&qe_immrr->cp.cercr) | QE_CP_CERCR_CIR);
742 	}
743 
744 	/* Loop through each microcode. */
745 	for (i = 0; i < firmware->count; i++) {
746 		const struct qe_microcode *ucode = &firmware->microcode[i];
747 
748 		/* Upload a microcode if it's present */
749 		if (!ucode->code_offset)
750 			return 0;
751 
752 		code = (const void *)firmware + be32_to_cpu(ucode->code_offset);
753 
754 		/* Use auto-increment */
755 		out_be32(&qe_immrr->iram.iadd, be32_to_cpu(ucode->iram_offset) |
756 			QE_IRAM_IADD_AIE | QE_IRAM_IADD_BADDR);
757 
758 		for (i = 0; i < be32_to_cpu(ucode->count); i++)
759 			out_be32(&qe_immrr->iram.idata, be32_to_cpu(code[i]));
760 
761 		/* Program the traps for this processor */
762 		for (j = 0; j < 16; j++) {
763 			u32 trap = be32_to_cpu(ucode->traps[j]);
764 
765 			if (trap)
766 				out_be32(&qe_immrr->rsp[i].tibcr[j], trap);
767 		}
768 
769 		/* Enable traps */
770 		out_be32(&qe_immrr->rsp[i].eccr, be32_to_cpu(ucode->eccr));
771 	}
772 
773 	return 0;
774 }
775 #endif
776 
qe_get_firmware_info(void)777 struct qe_firmware_info *qe_get_firmware_info(void)
778 {
779 	return qe_firmware_uploaded ? &qe_firmware_info : NULL;
780 }
781 
qe_cmd(cmd_tbl_t * cmdtp,int flag,int argc,char * const argv[])782 static int qe_cmd(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
783 {
784 	ulong addr;
785 
786 	if (argc < 3)
787 		return cmd_usage(cmdtp);
788 
789 	if (strcmp(argv[1], "fw") == 0) {
790 		addr = simple_strtoul(argv[2], NULL, 16);
791 
792 		if (!addr) {
793 			printf("Invalid address\n");
794 			return -EINVAL;
795 		}
796 
797 		/*
798 		 * If a length was supplied, compare that with the 'length'
799 		 * field.
800 		 */
801 
802 		if (argc > 3) {
803 			ulong length = simple_strtoul(argv[3], NULL, 16);
804 			struct qe_firmware *firmware = (void *) addr;
805 
806 			if (length != be32_to_cpu(firmware->header.length)) {
807 				printf("Length mismatch\n");
808 				return -EINVAL;
809 			}
810 		}
811 
812 		return qe_upload_firmware((const struct qe_firmware *) addr);
813 	}
814 
815 	return cmd_usage(cmdtp);
816 }
817 
818 U_BOOT_CMD(
819 	qe, 4, 0, qe_cmd,
820 	"QUICC Engine commands",
821 	"fw <addr> [<length>] - Upload firmware binary at address <addr> to "
822 		"the QE,\n"
823 	"\twith optional length <length> verification."
824 );
825