Lines Matching +full:firmware +full:- +full:initialized

1 // SPDX-License-Identifier: GPL-2.0-or-later
3 * Copyright (C) 2006-2010 Freescale Semiconductor, Inc. All rights reserved.
49 static phys_addr_t qebase = -1;
71 if (qebase != -1) in get_qe_base()
112 qe_iowrite32be((u32)(cmd | QE_CR_FLG), &qe_immr->cp.cecr); in qe_issue_cmd()
115 /* Here device is the SNUM, not sub-block */ in qe_issue_cmd()
129 qe_iowrite32be(cmd_input, &qe_immr->cp.cecdr); in qe_issue_cmd()
131 &qe_immr->cp.cecr); in qe_issue_cmd()
135 ret = readx_poll_timeout_atomic(qe_ioread32be, &qe_immr->cp.cecr, val, in qe_issue_cmd()
137 /* On timeout, ret is -ETIMEDOUT, otherwise it will be 0. */ in qe_issue_cmd()
151 * Baud rate clocks are zero-based in the driver code (as that maps
152 * to port numbers). Documentation uses 1-based numbering.
172 if (!of_property_read_u32(qe, "brg-frequency", &brg)) in qe_get_brg_clk()
181 brg_clk -= mod; in qe_get_brg_clk()
182 else if (mod > (CLK_GRAN - CLK_GRAN_LIMIT)) in qe_get_brg_clk()
183 brg_clk += CLK_GRAN - mod; in qe_get_brg_clk()
203 * @brg: the BRG, QE_BRG1 - QE_BRG16
215 return -EINVAL; in qe_setbrg()
225 that the BRG divisor must be even if you're not using divide-by-16 in qe_setbrg()
231 tempval = ((divisor - 1) << QE_BRGC_DIVISOR_SHIFT) | in qe_setbrg()
234 qe_iowrite32be(tempval, &qe_immr->brg.brgc[brg - QE_BRG1]); in qe_setbrg()
261 return (QE_BRG1 - 1) + i; in qe_clock_source()
269 return (QE_CLK1 - 1) + i; in qe_clock_source()
311 i = of_property_read_variable_u8_array(qe, "fsl,qe-snums", in qe_snums_init()
320 * fsl,qe-num-snums to choose one of the static arrays in qe_snums_init()
323 of_property_read_u32(qe, "fsl,qe-num-snums", &qe_num_of_snum); in qe_snums_init()
332 pr_err("QE: unsupported value of fsl,qe-num-snums: %u\n", qe_num_of_snum); in qe_snums_init()
341 int snum = -EBUSY; in qe_get_snum()
361 clear_bit(p - snums, snum_state); in qe_put_snum()
367 struct sdma __iomem *sdma = &qe_immr->sdma; in qe_sdma_init()
368 static s32 sdma_buf_offset = -ENOMEM; in qe_sdma_init()
375 return -ENOMEM; in qe_sdma_init()
379 &sdma->sdebcr); in qe_sdma_init()
381 &sdma->sdmr); in qe_sdma_init()
389 /* Firmware information stored here for qe_get_firmware_info() */
393 * Set to 1 if QE firmware has been uploaded, and therefore
407 const __be32 *code = base + be32_to_cpu(ucode->code_offset); in qe_upload_microcode()
410 if (ucode->major || ucode->minor || ucode->revision) in qe_upload_microcode()
411 printk(KERN_INFO "qe-firmware: " in qe_upload_microcode()
413 ucode->id, ucode->major, ucode->minor, ucode->revision); in qe_upload_microcode()
415 printk(KERN_INFO "qe-firmware: " in qe_upload_microcode()
416 "uploading microcode '%s'\n", ucode->id); in qe_upload_microcode()
418 /* Use auto-increment */ in qe_upload_microcode()
419 qe_iowrite32be(be32_to_cpu(ucode->iram_offset) | QE_IRAM_IADD_AIE | QE_IRAM_IADD_BADDR, in qe_upload_microcode()
420 &qe_immr->iram.iadd); in qe_upload_microcode()
422 for (i = 0; i < be32_to_cpu(ucode->count); i++) in qe_upload_microcode()
423 qe_iowrite32be(be32_to_cpu(code[i]), &qe_immr->iram.idata); in qe_upload_microcode()
425 /* Set I-RAM Ready Register */ in qe_upload_microcode()
426 qe_iowrite32be(QE_IRAM_READY, &qe_immr->iram.iready); in qe_upload_microcode()
430 * Upload a microcode to the I-RAM at a specific address.
441 * 'calc_size' is the calculated size, in bytes, of the firmware structure and
446 int qe_upload_firmware(const struct qe_firmware *firmware) in qe_upload_firmware() argument
455 if (!firmware) { in qe_upload_firmware()
456 printk(KERN_ERR "qe-firmware: invalid pointer\n"); in qe_upload_firmware()
457 return -EINVAL; in qe_upload_firmware()
460 hdr = &firmware->header; in qe_upload_firmware()
461 length = be32_to_cpu(hdr->length); in qe_upload_firmware()
464 if ((hdr->magic[0] != 'Q') || (hdr->magic[1] != 'E') || in qe_upload_firmware()
465 (hdr->magic[2] != 'F')) { in qe_upload_firmware()
466 printk(KERN_ERR "qe-firmware: not a microcode\n"); in qe_upload_firmware()
467 return -EPERM; in qe_upload_firmware()
471 if (hdr->version != 1) { in qe_upload_firmware()
472 printk(KERN_ERR "qe-firmware: unsupported version\n"); in qe_upload_firmware()
473 return -EPERM; in qe_upload_firmware()
477 if ((firmware->count < 1) || (firmware->count > MAX_QE_RISC)) { in qe_upload_firmware()
478 printk(KERN_ERR "qe-firmware: invalid data\n"); in qe_upload_firmware()
479 return -EINVAL; in qe_upload_firmware()
483 calc_size = struct_size(firmware, microcode, firmware->count); in qe_upload_firmware()
485 for (i = 0; i < firmware->count; i++) in qe_upload_firmware()
492 be32_to_cpu(firmware->microcode[i].count); in qe_upload_firmware()
496 printk(KERN_ERR "qe-firmware: invalid length\n"); in qe_upload_firmware()
497 return -EPERM; in qe_upload_firmware()
501 crc = be32_to_cpu(*(__be32 *)((void *)firmware + calc_size)); in qe_upload_firmware()
502 if (crc != crc32(0, firmware, calc_size)) { in qe_upload_firmware()
503 printk(KERN_ERR "qe-firmware: firmware CRC is invalid\n"); in qe_upload_firmware()
504 return -EIO; in qe_upload_firmware()
508 * If the microcode calls for it, split the I-RAM. in qe_upload_firmware()
510 if (!firmware->split) in qe_upload_firmware()
511 qe_setbits_be16(&qe_immr->cp.cercr, QE_CP_CERCR_CIR); in qe_upload_firmware()
513 if (firmware->soc.model) in qe_upload_firmware()
515 "qe-firmware: firmware '%s' for %u V%u.%u\n", in qe_upload_firmware()
516 firmware->id, be16_to_cpu(firmware->soc.model), in qe_upload_firmware()
517 firmware->soc.major, firmware->soc.minor); in qe_upload_firmware()
519 printk(KERN_INFO "qe-firmware: firmware '%s'\n", in qe_upload_firmware()
520 firmware->id); in qe_upload_firmware()
527 strlcpy(qe_firmware_info.id, firmware->id, sizeof(qe_firmware_info.id)); in qe_upload_firmware()
528 qe_firmware_info.extended_modes = be64_to_cpu(firmware->extended_modes); in qe_upload_firmware()
529 memcpy(qe_firmware_info.vtraps, firmware->vtraps, in qe_upload_firmware()
530 sizeof(firmware->vtraps)); in qe_upload_firmware()
533 for (i = 0; i < firmware->count; i++) { in qe_upload_firmware()
534 const struct qe_microcode *ucode = &firmware->microcode[i]; in qe_upload_firmware()
537 if (ucode->code_offset) in qe_upload_firmware()
538 qe_upload_microcode(firmware, ucode); in qe_upload_firmware()
542 u32 trap = be32_to_cpu(ucode->traps[j]); in qe_upload_firmware()
546 &qe_immr->rsp[i].tibcr[j]); in qe_upload_firmware()
550 qe_iowrite32be(be32_to_cpu(ucode->eccr), in qe_upload_firmware()
551 &qe_immr->rsp[i].eccr); in qe_upload_firmware()
561 * Get info on the currently-loaded firmware
564 * uploaded a firmware already.
568 static int initialized; in qe_get_firmware_info() local
574 * If we haven't checked yet, and a driver hasn't uploaded a firmware in qe_get_firmware_info()
580 if (initialized) in qe_get_firmware_info()
583 initialized = 1; in qe_get_firmware_info()
589 /* Find the 'firmware' child node */ in qe_get_firmware_info()
590 fw = of_get_child_by_name(qe, "firmware"); in qe_get_firmware_info()
593 /* Did we find the 'firmware' node? */ in qe_get_firmware_info()
605 of_property_read_u64(fw, "extended-modes", in qe_get_firmware_info()
608 of_property_read_u32_array(fw, "virtual-traps", qe_firmware_info.vtraps, in qe_get_firmware_info()
626 of_property_read_u32(qe, "fsl,qe-num-riscs", &num_of_risc); in qe_get_num_of_risc()
646 return -ENODEV; in qe_init()
673 .name = "fsl-qe",