Lines Matching refs:dsp
284 bool (*validate_version)(struct cs_dsp *dsp, unsigned int version);
285 unsigned int (*parse_sizes)(struct cs_dsp *dsp,
289 int (*setup_algs)(struct cs_dsp *dsp);
293 void (*show_fw_status)(struct cs_dsp *dsp);
294 void (*stop_watchdog)(struct cs_dsp *dsp);
296 int (*enable_memory)(struct cs_dsp *dsp);
297 void (*disable_memory)(struct cs_dsp *dsp);
298 int (*lock_memory)(struct cs_dsp *dsp, unsigned int lock_regions);
300 int (*enable_core)(struct cs_dsp *dsp);
301 void (*disable_core)(struct cs_dsp *dsp);
303 int (*start_core)(struct cs_dsp *dsp);
304 void (*stop_core)(struct cs_dsp *dsp);
381 static void cs_dsp_debugfs_save_wmfwname(struct cs_dsp *dsp, const char *s) in cs_dsp_debugfs_save_wmfwname() argument
385 kfree(dsp->wmfw_file_name); in cs_dsp_debugfs_save_wmfwname()
386 dsp->wmfw_file_name = tmp; in cs_dsp_debugfs_save_wmfwname()
389 static void cs_dsp_debugfs_save_binname(struct cs_dsp *dsp, const char *s) in cs_dsp_debugfs_save_binname() argument
393 kfree(dsp->bin_file_name); in cs_dsp_debugfs_save_binname()
394 dsp->bin_file_name = tmp; in cs_dsp_debugfs_save_binname()
397 static void cs_dsp_debugfs_clear(struct cs_dsp *dsp) in cs_dsp_debugfs_clear() argument
399 kfree(dsp->wmfw_file_name); in cs_dsp_debugfs_clear()
400 kfree(dsp->bin_file_name); in cs_dsp_debugfs_clear()
401 dsp->wmfw_file_name = NULL; in cs_dsp_debugfs_clear()
402 dsp->bin_file_name = NULL; in cs_dsp_debugfs_clear()
409 struct cs_dsp *dsp = file->private_data; in cs_dsp_debugfs_wmfw_read() local
412 mutex_lock(&dsp->pwr_lock); in cs_dsp_debugfs_wmfw_read()
414 if (!dsp->wmfw_file_name || !dsp->booted) in cs_dsp_debugfs_wmfw_read()
418 dsp->wmfw_file_name, in cs_dsp_debugfs_wmfw_read()
419 strlen(dsp->wmfw_file_name)); in cs_dsp_debugfs_wmfw_read()
421 mutex_unlock(&dsp->pwr_lock); in cs_dsp_debugfs_wmfw_read()
429 struct cs_dsp *dsp = file->private_data; in cs_dsp_debugfs_bin_read() local
432 mutex_lock(&dsp->pwr_lock); in cs_dsp_debugfs_bin_read()
434 if (!dsp->bin_file_name || !dsp->booted) in cs_dsp_debugfs_bin_read()
438 dsp->bin_file_name, in cs_dsp_debugfs_bin_read()
439 strlen(dsp->bin_file_name)); in cs_dsp_debugfs_bin_read()
441 mutex_unlock(&dsp->pwr_lock); in cs_dsp_debugfs_bin_read()
471 void cs_dsp_init_debugfs(struct cs_dsp *dsp, struct dentry *debugfs_root) in cs_dsp_init_debugfs() argument
476 root = debugfs_create_dir(dsp->name, debugfs_root); in cs_dsp_init_debugfs()
478 debugfs_create_bool("booted", 0444, root, &dsp->booted); in cs_dsp_init_debugfs()
479 debugfs_create_bool("running", 0444, root, &dsp->running); in cs_dsp_init_debugfs()
480 debugfs_create_x32("fw_id", 0444, root, &dsp->fw_id); in cs_dsp_init_debugfs()
481 debugfs_create_x32("fw_version", 0444, root, &dsp->fw_id_version); in cs_dsp_init_debugfs()
485 dsp, &cs_dsp_debugfs_fops[i].fops); in cs_dsp_init_debugfs()
487 dsp->debugfs_root = root; in cs_dsp_init_debugfs()
495 void cs_dsp_cleanup_debugfs(struct cs_dsp *dsp) in cs_dsp_cleanup_debugfs() argument
497 cs_dsp_debugfs_clear(dsp); in cs_dsp_cleanup_debugfs()
498 debugfs_remove_recursive(dsp->debugfs_root); in cs_dsp_cleanup_debugfs()
499 dsp->debugfs_root = NULL; in cs_dsp_cleanup_debugfs()
503 void cs_dsp_init_debugfs(struct cs_dsp *dsp, struct dentry *debugfs_root) in cs_dsp_init_debugfs() argument
508 void cs_dsp_cleanup_debugfs(struct cs_dsp *dsp) in cs_dsp_cleanup_debugfs() argument
513 static inline void cs_dsp_debugfs_save_wmfwname(struct cs_dsp *dsp, in cs_dsp_debugfs_save_wmfwname() argument
518 static inline void cs_dsp_debugfs_save_binname(struct cs_dsp *dsp, in cs_dsp_debugfs_save_binname() argument
523 static inline void cs_dsp_debugfs_clear(struct cs_dsp *dsp) in cs_dsp_debugfs_clear() argument
528 static const struct cs_dsp_region *cs_dsp_find_region(struct cs_dsp *dsp, in cs_dsp_find_region() argument
533 for (i = 0; i < dsp->num_mems; i++) in cs_dsp_find_region()
534 if (dsp->mem[i].type == type) in cs_dsp_find_region()
535 return &dsp->mem[i]; in cs_dsp_find_region()
575 static void cs_dsp_read_fw_status(struct cs_dsp *dsp, in cs_dsp_read_fw_status() argument
582 ret = regmap_read(dsp->regmap, dsp->base + offs[i], &offs[i]); in cs_dsp_read_fw_status()
584 cs_dsp_err(dsp, "Failed to read SCRATCH%u: %d\n", i, ret); in cs_dsp_read_fw_status()
590 static void cs_dsp_adsp2_show_fw_status(struct cs_dsp *dsp) in cs_dsp_adsp2_show_fw_status() argument
596 cs_dsp_read_fw_status(dsp, ARRAY_SIZE(offs), offs); in cs_dsp_adsp2_show_fw_status()
598 cs_dsp_dbg(dsp, "FW SCRATCH 0:0x%x 1:0x%x 2:0x%x 3:0x%x\n", in cs_dsp_adsp2_show_fw_status()
602 static void cs_dsp_adsp2v2_show_fw_status(struct cs_dsp *dsp) in cs_dsp_adsp2v2_show_fw_status() argument
606 cs_dsp_read_fw_status(dsp, ARRAY_SIZE(offs), offs); in cs_dsp_adsp2v2_show_fw_status()
608 cs_dsp_dbg(dsp, "FW SCRATCH 0:0x%x 1:0x%x 2:0x%x 3:0x%x\n", in cs_dsp_adsp2v2_show_fw_status()
613 static void cs_dsp_halo_show_fw_status(struct cs_dsp *dsp) in cs_dsp_halo_show_fw_status() argument
619 cs_dsp_read_fw_status(dsp, ARRAY_SIZE(offs), offs); in cs_dsp_halo_show_fw_status()
621 cs_dsp_dbg(dsp, "FW SCRATCH 0:0x%x 1:0x%x 2:0x%x 3:0x%x\n", in cs_dsp_halo_show_fw_status()
628 struct cs_dsp *dsp = ctl->dsp; in cs_dsp_coeff_base_reg() local
631 mem = cs_dsp_find_region(dsp, alg_region->type); in cs_dsp_coeff_base_reg()
633 cs_dsp_err(dsp, "No base for region %x\n", in cs_dsp_coeff_base_reg()
638 *reg = dsp->ops->region_to_reg(mem, ctl->alg_region.base + ctl->offset); in cs_dsp_coeff_base_reg()
657 struct cs_dsp *dsp = ctl->dsp; in cs_dsp_coeff_write_acked_control() local
662 if (!dsp->running) in cs_dsp_coeff_write_acked_control()
669 cs_dsp_dbg(dsp, "Sending 0x%x to acked control alg 0x%x %s:0x%x\n", in cs_dsp_coeff_write_acked_control()
673 ret = regmap_raw_write(dsp->regmap, reg, &val, sizeof(val)); in cs_dsp_coeff_write_acked_control()
675 cs_dsp_err(dsp, "Failed to write %x: %d\n", reg, ret); in cs_dsp_coeff_write_acked_control()
697 ret = regmap_raw_read(dsp->regmap, reg, &val, sizeof(val)); in cs_dsp_coeff_write_acked_control()
699 cs_dsp_err(dsp, "Failed to read %x: %d\n", reg, ret); in cs_dsp_coeff_write_acked_control()
704 cs_dsp_dbg(dsp, "Acked control ACKED at poll %u\n", i); in cs_dsp_coeff_write_acked_control()
709 cs_dsp_warn(dsp, "Acked control @0x%x alg:0x%x %s:0x%x timed out\n", in cs_dsp_coeff_write_acked_control()
721 struct cs_dsp *dsp = ctl->dsp; in cs_dsp_coeff_write_ctrl_raw() local
734 ret = regmap_raw_write(dsp->regmap, reg, scratch, in cs_dsp_coeff_write_ctrl_raw()
737 cs_dsp_err(dsp, "Failed to write %zu bytes to %x: %d\n", in cs_dsp_coeff_write_ctrl_raw()
742 cs_dsp_dbg(dsp, "Wrote %zu bytes to %x\n", len, reg); in cs_dsp_coeff_write_ctrl_raw()
769 if (ctl->enabled && ctl->dsp->running) in cs_dsp_coeff_write_ctrl()
778 struct cs_dsp *dsp = ctl->dsp; in cs_dsp_coeff_read_ctrl_raw() local
791 ret = regmap_raw_read(dsp->regmap, reg, scratch, len); in cs_dsp_coeff_read_ctrl_raw()
793 cs_dsp_err(dsp, "Failed to read %zu bytes from %x: %d\n", in cs_dsp_coeff_read_ctrl_raw()
798 cs_dsp_dbg(dsp, "Read %zu bytes from %x\n", len, reg); in cs_dsp_coeff_read_ctrl_raw()
821 if (ctl->enabled && ctl->dsp->running) in cs_dsp_coeff_read_ctrl()
826 if (!ctl->flags && ctl->enabled && ctl->dsp->running) in cs_dsp_coeff_read_ctrl()
837 static int cs_dsp_coeff_init_control_caches(struct cs_dsp *dsp) in cs_dsp_coeff_init_control_caches() argument
842 list_for_each_entry(ctl, &dsp->ctl_list, list) { in cs_dsp_coeff_init_control_caches()
863 static int cs_dsp_coeff_sync_controls(struct cs_dsp *dsp) in cs_dsp_coeff_sync_controls() argument
868 list_for_each_entry(ctl, &dsp->ctl_list, list) { in cs_dsp_coeff_sync_controls()
882 static void cs_dsp_signal_event_controls(struct cs_dsp *dsp, in cs_dsp_signal_event_controls() argument
888 list_for_each_entry(ctl, &dsp->ctl_list, list) { in cs_dsp_signal_event_controls()
897 cs_dsp_warn(dsp, in cs_dsp_signal_event_controls()
910 static int cs_dsp_create_control(struct cs_dsp *dsp, in cs_dsp_create_control() argument
919 list_for_each_entry(ctl, &dsp->ctl_list, list) { in cs_dsp_create_control()
920 if (ctl->fw_name == dsp->fw_name && in cs_dsp_create_control()
936 ctl->fw_name = dsp->fw_name; in cs_dsp_create_control()
938 if (subname && dsp->fw_ver >= 2) { in cs_dsp_create_control()
949 ctl->dsp = dsp; in cs_dsp_create_control()
961 list_add(&ctl->list, &dsp->ctl_list); in cs_dsp_create_control()
963 if (dsp->client_ops->control_add) { in cs_dsp_create_control()
964 ret = dsp->client_ops->control_add(ctl); in cs_dsp_create_control()
1042 static inline void cs_dsp_coeff_parse_alg(struct cs_dsp *dsp, const u8 **data, in cs_dsp_coeff_parse_alg() argument
1047 switch (dsp->fw_ver) { in cs_dsp_coeff_parse_alg()
1067 cs_dsp_dbg(dsp, "Algorithm ID: %#x\n", blk->id); in cs_dsp_coeff_parse_alg()
1068 cs_dsp_dbg(dsp, "Algorithm name: %.*s\n", blk->name_len, blk->name); in cs_dsp_coeff_parse_alg()
1069 cs_dsp_dbg(dsp, "# of coefficient descriptors: %#x\n", blk->ncoeff); in cs_dsp_coeff_parse_alg()
1072 static inline void cs_dsp_coeff_parse_coeff(struct cs_dsp *dsp, const u8 **data, in cs_dsp_coeff_parse_coeff() argument
1079 switch (dsp->fw_ver) { in cs_dsp_coeff_parse_coeff()
1110 cs_dsp_dbg(dsp, "\tCoefficient type: %#x\n", blk->mem_type); in cs_dsp_coeff_parse_coeff()
1111 cs_dsp_dbg(dsp, "\tCoefficient offset: %#x\n", blk->offset); in cs_dsp_coeff_parse_coeff()
1112 cs_dsp_dbg(dsp, "\tCoefficient name: %.*s\n", blk->name_len, blk->name); in cs_dsp_coeff_parse_coeff()
1113 cs_dsp_dbg(dsp, "\tCoefficient flags: %#x\n", blk->flags); in cs_dsp_coeff_parse_coeff()
1114 cs_dsp_dbg(dsp, "\tALSA control type: %#x\n", blk->ctl_type); in cs_dsp_coeff_parse_coeff()
1115 cs_dsp_dbg(dsp, "\tALSA control len: %#x\n", blk->len); in cs_dsp_coeff_parse_coeff()
1118 static int cs_dsp_check_coeff_flags(struct cs_dsp *dsp, in cs_dsp_check_coeff_flags() argument
1125 cs_dsp_err(dsp, "Illegal flags 0x%x for control type 0x%x\n", in cs_dsp_check_coeff_flags()
1133 static int cs_dsp_parse_coeff(struct cs_dsp *dsp, in cs_dsp_parse_coeff() argument
1142 cs_dsp_coeff_parse_alg(dsp, &data, &alg_blk); in cs_dsp_parse_coeff()
1144 cs_dsp_coeff_parse_coeff(dsp, &data, &coeff_blk); in cs_dsp_parse_coeff()
1153 ret = cs_dsp_check_coeff_flags(dsp, &coeff_blk, in cs_dsp_parse_coeff()
1162 ret = cs_dsp_check_coeff_flags(dsp, &coeff_blk, in cs_dsp_parse_coeff()
1172 ret = cs_dsp_check_coeff_flags(dsp, &coeff_blk, in cs_dsp_parse_coeff()
1181 cs_dsp_err(dsp, "Unknown control type: %d\n", in cs_dsp_parse_coeff()
1189 ret = cs_dsp_create_control(dsp, &alg_region, in cs_dsp_parse_coeff()
1197 cs_dsp_err(dsp, "Failed to create control: %.*s, %d\n", in cs_dsp_parse_coeff()
1204 static unsigned int cs_dsp_adsp1_parse_sizes(struct cs_dsp *dsp, in cs_dsp_adsp1_parse_sizes() argument
1213 cs_dsp_dbg(dsp, "%s: %d DM, %d PM, %d ZM\n", file, in cs_dsp_adsp1_parse_sizes()
1220 static unsigned int cs_dsp_adsp2_parse_sizes(struct cs_dsp *dsp, in cs_dsp_adsp2_parse_sizes() argument
1229 cs_dsp_dbg(dsp, "%s: %d XM, %d YM %d PM, %d ZM\n", file, in cs_dsp_adsp2_parse_sizes()
1236 static bool cs_dsp_validate_version(struct cs_dsp *dsp, unsigned int version) in cs_dsp_validate_version() argument
1240 cs_dsp_warn(dsp, "Deprecated file format %d\n", version); in cs_dsp_validate_version()
1250 static bool cs_dsp_halo_validate_version(struct cs_dsp *dsp, unsigned int version) in cs_dsp_halo_validate_version() argument
1260 static int cs_dsp_load(struct cs_dsp *dsp, const struct firmware *firmware, in cs_dsp_load() argument
1264 struct regmap *regmap = dsp->regmap; in cs_dsp_load()
1282 cs_dsp_err(dsp, "%s: file too short, %zu bytes\n", in cs_dsp_load()
1290 cs_dsp_err(dsp, "%s: invalid magic\n", file); in cs_dsp_load()
1294 if (!dsp->ops->validate_version(dsp, header->ver)) { in cs_dsp_load()
1295 cs_dsp_err(dsp, "%s: unknown file format %d\n", in cs_dsp_load()
1300 cs_dsp_info(dsp, "Firmware version: %d\n", header->ver); in cs_dsp_load()
1301 dsp->fw_ver = header->ver; in cs_dsp_load()
1303 if (header->core != dsp->type) { in cs_dsp_load()
1304 cs_dsp_err(dsp, "%s: invalid core %d != %d\n", in cs_dsp_load()
1305 file, header->core, dsp->type); in cs_dsp_load()
1310 pos = dsp->ops->parse_sizes(dsp, file, pos, firmware); in cs_dsp_load()
1316 cs_dsp_err(dsp, "%s: unexpected header length %d\n", in cs_dsp_load()
1321 cs_dsp_dbg(dsp, "%s: timestamp %llu\n", file, in cs_dsp_load()
1341 ret = cs_dsp_parse_coeff(dsp, region); in cs_dsp_load()
1362 mem = cs_dsp_find_region(dsp, type); in cs_dsp_load()
1364 cs_dsp_err(dsp, "No region of type: %x\n", type); in cs_dsp_load()
1370 reg = dsp->ops->region_to_reg(mem, offset); in cs_dsp_load()
1373 cs_dsp_warn(dsp, in cs_dsp_load()
1379 cs_dsp_dbg(dsp, "%s.%d: %d bytes at %d in %s\n", file, in cs_dsp_load()
1385 cs_dsp_err(dsp, in cs_dsp_load()
1395 cs_dsp_info(dsp, "%s: %s\n", file, text); in cs_dsp_load()
1405 cs_dsp_err(dsp, "Out of memory\n"); in cs_dsp_load()
1413 cs_dsp_err(dsp, in cs_dsp_load()
1428 cs_dsp_err(dsp, "Failed to complete async write: %d\n", ret); in cs_dsp_load()
1433 cs_dsp_warn(dsp, "%s.%d: %zu bytes at end of file\n", in cs_dsp_load()
1436 cs_dsp_debugfs_save_wmfwname(dsp, file); in cs_dsp_load()
1457 struct cs_dsp_coeff_ctl *cs_dsp_get_ctl(struct cs_dsp *dsp, const char *name, int type, in cs_dsp_get_ctl() argument
1462 list_for_each_entry(pos, &dsp->ctl_list, list) { in cs_dsp_get_ctl()
1466 pos->fw_name == dsp->fw_name && in cs_dsp_get_ctl()
1478 static void cs_dsp_ctl_fixup_base(struct cs_dsp *dsp, in cs_dsp_ctl_fixup_base() argument
1483 list_for_each_entry(ctl, &dsp->ctl_list, list) { in cs_dsp_ctl_fixup_base()
1484 if (ctl->fw_name == dsp->fw_name && in cs_dsp_ctl_fixup_base()
1492 static void *cs_dsp_read_algs(struct cs_dsp *dsp, size_t n_algs, in cs_dsp_read_algs() argument
1502 cs_dsp_err(dsp, "No algorithms\n"); in cs_dsp_read_algs()
1507 cs_dsp_err(dsp, "Algorithm count %zx excessive\n", n_algs); in cs_dsp_read_algs()
1512 reg = dsp->ops->region_to_reg(mem, pos + len); in cs_dsp_read_algs()
1514 ret = regmap_raw_read(dsp->regmap, reg, &val, sizeof(val)); in cs_dsp_read_algs()
1516 cs_dsp_err(dsp, "Failed to read algorithm list end: %d\n", in cs_dsp_read_algs()
1522 cs_dsp_warn(dsp, "Algorithm list end %x 0x%x != 0xbedead\n", in cs_dsp_read_algs()
1532 reg = dsp->ops->region_to_reg(mem, pos); in cs_dsp_read_algs()
1534 ret = regmap_raw_read(dsp->regmap, reg, alg, len); in cs_dsp_read_algs()
1536 cs_dsp_err(dsp, "Failed to read algorithm list: %d\n", ret); in cs_dsp_read_algs()
1552 struct cs_dsp_alg_region *cs_dsp_find_alg_region(struct cs_dsp *dsp, in cs_dsp_find_alg_region() argument
1557 list_for_each_entry(alg_region, &dsp->alg_regions, list) { in cs_dsp_find_alg_region()
1566 static struct cs_dsp_alg_region *cs_dsp_create_region(struct cs_dsp *dsp, in cs_dsp_create_region() argument
1580 list_add_tail(&alg_region->list, &dsp->alg_regions); in cs_dsp_create_region()
1582 if (dsp->fw_ver > 0) in cs_dsp_create_region()
1583 cs_dsp_ctl_fixup_base(dsp, alg_region); in cs_dsp_create_region()
1588 static void cs_dsp_free_alg_regions(struct cs_dsp *dsp) in cs_dsp_free_alg_regions() argument
1592 while (!list_empty(&dsp->alg_regions)) { in cs_dsp_free_alg_regions()
1593 alg_region = list_first_entry(&dsp->alg_regions, in cs_dsp_free_alg_regions()
1601 static void cs_dsp_parse_wmfw_id_header(struct cs_dsp *dsp, in cs_dsp_parse_wmfw_id_header() argument
1604 dsp->fw_id = be32_to_cpu(fw->id); in cs_dsp_parse_wmfw_id_header()
1605 dsp->fw_id_version = be32_to_cpu(fw->ver); in cs_dsp_parse_wmfw_id_header()
1607 cs_dsp_info(dsp, "Firmware: %x v%d.%d.%d, %d algorithms\n", in cs_dsp_parse_wmfw_id_header()
1608 dsp->fw_id, (dsp->fw_id_version & 0xff0000) >> 16, in cs_dsp_parse_wmfw_id_header()
1609 (dsp->fw_id_version & 0xff00) >> 8, dsp->fw_id_version & 0xff, in cs_dsp_parse_wmfw_id_header()
1613 static void cs_dsp_parse_wmfw_v3_id_header(struct cs_dsp *dsp, in cs_dsp_parse_wmfw_v3_id_header() argument
1616 dsp->fw_id = be32_to_cpu(fw->id); in cs_dsp_parse_wmfw_v3_id_header()
1617 dsp->fw_id_version = be32_to_cpu(fw->ver); in cs_dsp_parse_wmfw_v3_id_header()
1618 dsp->fw_vendor_id = be32_to_cpu(fw->vendor_id); in cs_dsp_parse_wmfw_v3_id_header()
1620 cs_dsp_info(dsp, "Firmware: %x vendor: 0x%x v%d.%d.%d, %d algorithms\n", in cs_dsp_parse_wmfw_v3_id_header()
1621 dsp->fw_id, dsp->fw_vendor_id, in cs_dsp_parse_wmfw_v3_id_header()
1622 (dsp->fw_id_version & 0xff0000) >> 16, in cs_dsp_parse_wmfw_v3_id_header()
1623 (dsp->fw_id_version & 0xff00) >> 8, dsp->fw_id_version & 0xff, in cs_dsp_parse_wmfw_v3_id_header()
1627 static int cs_dsp_create_regions(struct cs_dsp *dsp, __be32 id, int nregions, in cs_dsp_create_regions() argument
1634 alg_region = cs_dsp_create_region(dsp, type[i], id, base[i]); in cs_dsp_create_regions()
1642 static int cs_dsp_adsp1_setup_algs(struct cs_dsp *dsp) in cs_dsp_adsp1_setup_algs() argument
1652 mem = cs_dsp_find_region(dsp, WMFW_ADSP1_DM); in cs_dsp_adsp1_setup_algs()
1656 ret = regmap_raw_read(dsp->regmap, mem->base, &adsp1_id, in cs_dsp_adsp1_setup_algs()
1659 cs_dsp_err(dsp, "Failed to read algorithm info: %d\n", in cs_dsp_adsp1_setup_algs()
1666 cs_dsp_parse_wmfw_id_header(dsp, &adsp1_id.fw, n_algs); in cs_dsp_adsp1_setup_algs()
1668 alg_region = cs_dsp_create_region(dsp, WMFW_ADSP1_ZM, in cs_dsp_adsp1_setup_algs()
1673 alg_region = cs_dsp_create_region(dsp, WMFW_ADSP1_DM, in cs_dsp_adsp1_setup_algs()
1682 adsp1_alg = cs_dsp_read_algs(dsp, n_algs, mem, pos, len); in cs_dsp_adsp1_setup_algs()
1687 cs_dsp_info(dsp, "%d: ID %x v%d.%d.%d DM@%x ZM@%x\n", in cs_dsp_adsp1_setup_algs()
1695 alg_region = cs_dsp_create_region(dsp, WMFW_ADSP1_DM, in cs_dsp_adsp1_setup_algs()
1702 if (dsp->fw_ver == 0) { in cs_dsp_adsp1_setup_algs()
1707 cs_dsp_create_control(dsp, alg_region, 0, in cs_dsp_adsp1_setup_algs()
1711 cs_dsp_warn(dsp, "Missing length info for region DM with ID %x\n", in cs_dsp_adsp1_setup_algs()
1716 alg_region = cs_dsp_create_region(dsp, WMFW_ADSP1_ZM, in cs_dsp_adsp1_setup_algs()
1723 if (dsp->fw_ver == 0) { in cs_dsp_adsp1_setup_algs()
1728 cs_dsp_create_control(dsp, alg_region, 0, in cs_dsp_adsp1_setup_algs()
1732 cs_dsp_warn(dsp, "Missing length info for region ZM with ID %x\n", in cs_dsp_adsp1_setup_algs()
1743 static int cs_dsp_adsp2_setup_algs(struct cs_dsp *dsp) in cs_dsp_adsp2_setup_algs() argument
1753 mem = cs_dsp_find_region(dsp, WMFW_ADSP2_XM); in cs_dsp_adsp2_setup_algs()
1757 ret = regmap_raw_read(dsp->regmap, mem->base, &adsp2_id, in cs_dsp_adsp2_setup_algs()
1760 cs_dsp_err(dsp, "Failed to read algorithm info: %d\n", in cs_dsp_adsp2_setup_algs()
1767 cs_dsp_parse_wmfw_id_header(dsp, &adsp2_id.fw, n_algs); in cs_dsp_adsp2_setup_algs()
1769 alg_region = cs_dsp_create_region(dsp, WMFW_ADSP2_XM, in cs_dsp_adsp2_setup_algs()
1774 alg_region = cs_dsp_create_region(dsp, WMFW_ADSP2_YM, in cs_dsp_adsp2_setup_algs()
1779 alg_region = cs_dsp_create_region(dsp, WMFW_ADSP2_ZM, in cs_dsp_adsp2_setup_algs()
1788 adsp2_alg = cs_dsp_read_algs(dsp, n_algs, mem, pos, len); in cs_dsp_adsp2_setup_algs()
1793 cs_dsp_info(dsp, in cs_dsp_adsp2_setup_algs()
1803 alg_region = cs_dsp_create_region(dsp, WMFW_ADSP2_XM, in cs_dsp_adsp2_setup_algs()
1810 if (dsp->fw_ver == 0) { in cs_dsp_adsp2_setup_algs()
1815 cs_dsp_create_control(dsp, alg_region, 0, in cs_dsp_adsp2_setup_algs()
1819 cs_dsp_warn(dsp, "Missing length info for region XM with ID %x\n", in cs_dsp_adsp2_setup_algs()
1824 alg_region = cs_dsp_create_region(dsp, WMFW_ADSP2_YM, in cs_dsp_adsp2_setup_algs()
1831 if (dsp->fw_ver == 0) { in cs_dsp_adsp2_setup_algs()
1836 cs_dsp_create_control(dsp, alg_region, 0, in cs_dsp_adsp2_setup_algs()
1840 cs_dsp_warn(dsp, "Missing length info for region YM with ID %x\n", in cs_dsp_adsp2_setup_algs()
1845 alg_region = cs_dsp_create_region(dsp, WMFW_ADSP2_ZM, in cs_dsp_adsp2_setup_algs()
1852 if (dsp->fw_ver == 0) { in cs_dsp_adsp2_setup_algs()
1857 cs_dsp_create_control(dsp, alg_region, 0, in cs_dsp_adsp2_setup_algs()
1861 cs_dsp_warn(dsp, "Missing length info for region ZM with ID %x\n", in cs_dsp_adsp2_setup_algs()
1872 static int cs_dsp_halo_create_regions(struct cs_dsp *dsp, __be32 id, in cs_dsp_halo_create_regions() argument
1881 return cs_dsp_create_regions(dsp, id, ARRAY_SIZE(types), types, bases); in cs_dsp_halo_create_regions()
1884 static int cs_dsp_halo_setup_algs(struct cs_dsp *dsp) in cs_dsp_halo_setup_algs() argument
1893 mem = cs_dsp_find_region(dsp, WMFW_ADSP2_XM); in cs_dsp_halo_setup_algs()
1897 ret = regmap_raw_read(dsp->regmap, mem->base, &halo_id, in cs_dsp_halo_setup_algs()
1900 cs_dsp_err(dsp, "Failed to read algorithm info: %d\n", in cs_dsp_halo_setup_algs()
1907 cs_dsp_parse_wmfw_v3_id_header(dsp, &halo_id.fw, n_algs); in cs_dsp_halo_setup_algs()
1909 ret = cs_dsp_halo_create_regions(dsp, halo_id.fw.id, in cs_dsp_halo_setup_algs()
1918 halo_alg = cs_dsp_read_algs(dsp, n_algs, mem, pos, len); in cs_dsp_halo_setup_algs()
1923 cs_dsp_info(dsp, in cs_dsp_halo_setup_algs()
1932 ret = cs_dsp_halo_create_regions(dsp, halo_alg[i].alg.id, in cs_dsp_halo_setup_algs()
1944 static int cs_dsp_load_coeff(struct cs_dsp *dsp, const struct firmware *firmware, in cs_dsp_load_coeff() argument
1948 struct regmap *regmap = dsp->regmap; in cs_dsp_load_coeff()
1963 cs_dsp_err(dsp, "%s: coefficient file too short, %zu bytes\n", in cs_dsp_load_coeff()
1970 cs_dsp_err(dsp, "%s: invalid coefficient magic\n", file); in cs_dsp_load_coeff()
1978 cs_dsp_err(dsp, "%s: Unsupported coefficient file format %d\n", in cs_dsp_load_coeff()
1984 cs_dsp_dbg(dsp, "%s: v%d.%d.%d\n", file, in cs_dsp_load_coeff()
1999 cs_dsp_dbg(dsp, "%s.%d: %x v%d.%d.%d\n", in cs_dsp_load_coeff()
2004 cs_dsp_dbg(dsp, "%s.%d: %d bytes at 0x%x in %x\n", in cs_dsp_load_coeff()
2019 if (le32_to_cpu(blk->id) == dsp->fw_id && in cs_dsp_load_coeff()
2022 mem = cs_dsp_find_region(dsp, type); in cs_dsp_load_coeff()
2024 cs_dsp_err(dsp, "No ZM\n"); in cs_dsp_load_coeff()
2027 reg = dsp->ops->region_to_reg(mem, 0); in cs_dsp_load_coeff()
2042 cs_dsp_dbg(dsp, "%s.%d: %d bytes in %x for %x\n", in cs_dsp_load_coeff()
2046 mem = cs_dsp_find_region(dsp, type); in cs_dsp_load_coeff()
2048 cs_dsp_err(dsp, "No base for region %x\n", type); in cs_dsp_load_coeff()
2052 alg_region = cs_dsp_find_alg_region(dsp, type, in cs_dsp_load_coeff()
2056 reg = dsp->ops->region_to_reg(mem, reg); in cs_dsp_load_coeff()
2059 cs_dsp_err(dsp, "No %x for algorithm %x\n", in cs_dsp_load_coeff()
2065 cs_dsp_err(dsp, "%s.%d: Unknown region type %x at %d\n", in cs_dsp_load_coeff()
2073 cs_dsp_err(dsp, in cs_dsp_load_coeff()
2086 cs_dsp_err(dsp, "Out of memory\n"); in cs_dsp_load_coeff()
2091 cs_dsp_dbg(dsp, "%s.%d: Writing %d bytes at %x\n", in cs_dsp_load_coeff()
2097 cs_dsp_err(dsp, in cs_dsp_load_coeff()
2109 cs_dsp_err(dsp, "Failed to complete async write: %d\n", ret); in cs_dsp_load_coeff()
2112 cs_dsp_warn(dsp, "%s.%d: %zu bytes at end of file\n", in cs_dsp_load_coeff()
2115 cs_dsp_debugfs_save_binname(dsp, file); in cs_dsp_load_coeff()
2123 static int cs_dsp_create_name(struct cs_dsp *dsp) in cs_dsp_create_name() argument
2125 if (!dsp->name) { in cs_dsp_create_name()
2126 dsp->name = devm_kasprintf(dsp->dev, GFP_KERNEL, "DSP%d", in cs_dsp_create_name()
2127 dsp->num); in cs_dsp_create_name()
2128 if (!dsp->name) in cs_dsp_create_name()
2135 static int cs_dsp_common_init(struct cs_dsp *dsp) in cs_dsp_common_init() argument
2139 ret = cs_dsp_create_name(dsp); in cs_dsp_common_init()
2143 INIT_LIST_HEAD(&dsp->alg_regions); in cs_dsp_common_init()
2144 INIT_LIST_HEAD(&dsp->ctl_list); in cs_dsp_common_init()
2146 mutex_init(&dsp->pwr_lock); in cs_dsp_common_init()
2157 int cs_dsp_adsp1_init(struct cs_dsp *dsp) in cs_dsp_adsp1_init() argument
2159 dsp->ops = &cs_dsp_adsp1_ops; in cs_dsp_adsp1_init()
2161 return cs_dsp_common_init(dsp); in cs_dsp_adsp1_init()
2176 int cs_dsp_adsp1_power_up(struct cs_dsp *dsp, in cs_dsp_adsp1_power_up() argument
2184 mutex_lock(&dsp->pwr_lock); in cs_dsp_adsp1_power_up()
2186 dsp->fw_name = fw_name; in cs_dsp_adsp1_power_up()
2188 regmap_update_bits(dsp->regmap, dsp->base + ADSP1_CONTROL_30, in cs_dsp_adsp1_power_up()
2195 if (dsp->sysclk_reg) { in cs_dsp_adsp1_power_up()
2196 ret = regmap_read(dsp->regmap, dsp->sysclk_reg, &val); in cs_dsp_adsp1_power_up()
2198 cs_dsp_err(dsp, "Failed to read SYSCLK state: %d\n", ret); in cs_dsp_adsp1_power_up()
2202 val = (val & dsp->sysclk_mask) >> dsp->sysclk_shift; in cs_dsp_adsp1_power_up()
2204 ret = regmap_update_bits(dsp->regmap, in cs_dsp_adsp1_power_up()
2205 dsp->base + ADSP1_CONTROL_31, in cs_dsp_adsp1_power_up()
2208 cs_dsp_err(dsp, "Failed to set clock rate: %d\n", ret); in cs_dsp_adsp1_power_up()
2213 ret = cs_dsp_load(dsp, wmfw_firmware, wmfw_filename); in cs_dsp_adsp1_power_up()
2217 ret = cs_dsp_adsp1_setup_algs(dsp); in cs_dsp_adsp1_power_up()
2221 ret = cs_dsp_load_coeff(dsp, coeff_firmware, coeff_filename); in cs_dsp_adsp1_power_up()
2226 ret = cs_dsp_coeff_init_control_caches(dsp); in cs_dsp_adsp1_power_up()
2231 ret = cs_dsp_coeff_sync_controls(dsp); in cs_dsp_adsp1_power_up()
2235 dsp->booted = true; in cs_dsp_adsp1_power_up()
2238 regmap_update_bits(dsp->regmap, dsp->base + ADSP1_CONTROL_30, in cs_dsp_adsp1_power_up()
2242 dsp->running = true; in cs_dsp_adsp1_power_up()
2244 mutex_unlock(&dsp->pwr_lock); in cs_dsp_adsp1_power_up()
2249 regmap_update_bits(dsp->regmap, dsp->base + ADSP1_CONTROL_30, in cs_dsp_adsp1_power_up()
2252 mutex_unlock(&dsp->pwr_lock); in cs_dsp_adsp1_power_up()
2261 void cs_dsp_adsp1_power_down(struct cs_dsp *dsp) in cs_dsp_adsp1_power_down() argument
2265 mutex_lock(&dsp->pwr_lock); in cs_dsp_adsp1_power_down()
2267 dsp->running = false; in cs_dsp_adsp1_power_down()
2268 dsp->booted = false; in cs_dsp_adsp1_power_down()
2271 regmap_update_bits(dsp->regmap, dsp->base + ADSP1_CONTROL_30, in cs_dsp_adsp1_power_down()
2274 regmap_update_bits(dsp->regmap, dsp->base + ADSP1_CONTROL_19, in cs_dsp_adsp1_power_down()
2277 regmap_update_bits(dsp->regmap, dsp->base + ADSP1_CONTROL_30, in cs_dsp_adsp1_power_down()
2280 list_for_each_entry(ctl, &dsp->ctl_list, list) in cs_dsp_adsp1_power_down()
2283 cs_dsp_free_alg_regions(dsp); in cs_dsp_adsp1_power_down()
2285 mutex_unlock(&dsp->pwr_lock); in cs_dsp_adsp1_power_down()
2289 static int cs_dsp_adsp2v2_enable_core(struct cs_dsp *dsp) in cs_dsp_adsp2v2_enable_core() argument
2296 ret = regmap_read(dsp->regmap, dsp->base + ADSP2_STATUS1, &val); in cs_dsp_adsp2v2_enable_core()
2307 cs_dsp_err(dsp, "Failed to start DSP RAM\n"); in cs_dsp_adsp2v2_enable_core()
2311 cs_dsp_dbg(dsp, "RAM ready after %d polls\n", count); in cs_dsp_adsp2v2_enable_core()
2316 static int cs_dsp_adsp2_enable_core(struct cs_dsp *dsp) in cs_dsp_adsp2_enable_core() argument
2320 ret = regmap_update_bits_async(dsp->regmap, dsp->base + ADSP2_CONTROL, in cs_dsp_adsp2_enable_core()
2325 return cs_dsp_adsp2v2_enable_core(dsp); in cs_dsp_adsp2_enable_core()
2328 static int cs_dsp_adsp2_lock(struct cs_dsp *dsp, unsigned int lock_regions) in cs_dsp_adsp2_lock() argument
2330 struct regmap *regmap = dsp->regmap; in cs_dsp_adsp2_lock()
2337 lock_reg = dsp->base + ADSP2_LOCK_REGION_1_LOCK_REGION_0; in cs_dsp_adsp2_lock()
2358 static int cs_dsp_adsp2_enable_memory(struct cs_dsp *dsp) in cs_dsp_adsp2_enable_memory() argument
2360 return regmap_update_bits(dsp->regmap, dsp->base + ADSP2_CONTROL, in cs_dsp_adsp2_enable_memory()
2364 static void cs_dsp_adsp2_disable_memory(struct cs_dsp *dsp) in cs_dsp_adsp2_disable_memory() argument
2366 regmap_update_bits(dsp->regmap, dsp->base + ADSP2_CONTROL, in cs_dsp_adsp2_disable_memory()
2370 static void cs_dsp_adsp2_disable_core(struct cs_dsp *dsp) in cs_dsp_adsp2_disable_core() argument
2372 regmap_write(dsp->regmap, dsp->base + ADSP2_RDMA_CONFIG_1, 0); in cs_dsp_adsp2_disable_core()
2373 regmap_write(dsp->regmap, dsp->base + ADSP2_WDMA_CONFIG_1, 0); in cs_dsp_adsp2_disable_core()
2374 regmap_write(dsp->regmap, dsp->base + ADSP2_WDMA_CONFIG_2, 0); in cs_dsp_adsp2_disable_core()
2376 regmap_update_bits(dsp->regmap, dsp->base + ADSP2_CONTROL, in cs_dsp_adsp2_disable_core()
2380 static void cs_dsp_adsp2v2_disable_core(struct cs_dsp *dsp) in cs_dsp_adsp2v2_disable_core() argument
2382 regmap_write(dsp->regmap, dsp->base + ADSP2_RDMA_CONFIG_1, 0); in cs_dsp_adsp2v2_disable_core()
2383 regmap_write(dsp->regmap, dsp->base + ADSP2_WDMA_CONFIG_1, 0); in cs_dsp_adsp2v2_disable_core()
2384 regmap_write(dsp->regmap, dsp->base + ADSP2V2_WDMA_CONFIG_2, 0); in cs_dsp_adsp2v2_disable_core()
2387 static int cs_dsp_halo_configure_mpu(struct cs_dsp *dsp, unsigned int lock_regions) in cs_dsp_halo_configure_mpu() argument
2390 { dsp->base + HALO_MPU_LOCK_CONFIG, 0x5555 }, in cs_dsp_halo_configure_mpu()
2391 { dsp->base + HALO_MPU_LOCK_CONFIG, 0xAAAA }, in cs_dsp_halo_configure_mpu()
2392 { dsp->base + HALO_MPU_XMEM_ACCESS_0, 0xFFFFFFFF }, in cs_dsp_halo_configure_mpu()
2393 { dsp->base + HALO_MPU_YMEM_ACCESS_0, 0xFFFFFFFF }, in cs_dsp_halo_configure_mpu()
2394 { dsp->base + HALO_MPU_WINDOW_ACCESS_0, lock_regions }, in cs_dsp_halo_configure_mpu()
2395 { dsp->base + HALO_MPU_XREG_ACCESS_0, lock_regions }, in cs_dsp_halo_configure_mpu()
2396 { dsp->base + HALO_MPU_YREG_ACCESS_0, lock_regions }, in cs_dsp_halo_configure_mpu()
2397 { dsp->base + HALO_MPU_XMEM_ACCESS_1, 0xFFFFFFFF }, in cs_dsp_halo_configure_mpu()
2398 { dsp->base + HALO_MPU_YMEM_ACCESS_1, 0xFFFFFFFF }, in cs_dsp_halo_configure_mpu()
2399 { dsp->base + HALO_MPU_WINDOW_ACCESS_1, lock_regions }, in cs_dsp_halo_configure_mpu()
2400 { dsp->base + HALO_MPU_XREG_ACCESS_1, lock_regions }, in cs_dsp_halo_configure_mpu()
2401 { dsp->base + HALO_MPU_YREG_ACCESS_1, lock_regions }, in cs_dsp_halo_configure_mpu()
2402 { dsp->base + HALO_MPU_XMEM_ACCESS_2, 0xFFFFFFFF }, in cs_dsp_halo_configure_mpu()
2403 { dsp->base + HALO_MPU_YMEM_ACCESS_2, 0xFFFFFFFF }, in cs_dsp_halo_configure_mpu()
2404 { dsp->base + HALO_MPU_WINDOW_ACCESS_2, lock_regions }, in cs_dsp_halo_configure_mpu()
2405 { dsp->base + HALO_MPU_XREG_ACCESS_2, lock_regions }, in cs_dsp_halo_configure_mpu()
2406 { dsp->base + HALO_MPU_YREG_ACCESS_2, lock_regions }, in cs_dsp_halo_configure_mpu()
2407 { dsp->base + HALO_MPU_XMEM_ACCESS_3, 0xFFFFFFFF }, in cs_dsp_halo_configure_mpu()
2408 { dsp->base + HALO_MPU_YMEM_ACCESS_3, 0xFFFFFFFF }, in cs_dsp_halo_configure_mpu()
2409 { dsp->base + HALO_MPU_WINDOW_ACCESS_3, lock_regions }, in cs_dsp_halo_configure_mpu()
2410 { dsp->base + HALO_MPU_XREG_ACCESS_3, lock_regions }, in cs_dsp_halo_configure_mpu()
2411 { dsp->base + HALO_MPU_YREG_ACCESS_3, lock_regions }, in cs_dsp_halo_configure_mpu()
2412 { dsp->base + HALO_MPU_LOCK_CONFIG, 0 }, in cs_dsp_halo_configure_mpu()
2415 return regmap_multi_reg_write(dsp->regmap, config, ARRAY_SIZE(config)); in cs_dsp_halo_configure_mpu()
2427 int cs_dsp_set_dspclk(struct cs_dsp *dsp, unsigned int freq) in cs_dsp_set_dspclk() argument
2431 ret = regmap_update_bits(dsp->regmap, dsp->base + ADSP2_CLOCKING, in cs_dsp_set_dspclk()
2435 cs_dsp_err(dsp, "Failed to set clock rate: %d\n", ret); in cs_dsp_set_dspclk()
2441 static void cs_dsp_stop_watchdog(struct cs_dsp *dsp) in cs_dsp_stop_watchdog() argument
2443 regmap_update_bits(dsp->regmap, dsp->base + ADSP2_WATCHDOG, in cs_dsp_stop_watchdog()
2447 static void cs_dsp_halo_stop_watchdog(struct cs_dsp *dsp) in cs_dsp_halo_stop_watchdog() argument
2449 regmap_update_bits(dsp->regmap, dsp->base + HALO_WDT_CONTROL, in cs_dsp_halo_stop_watchdog()
2470 int cs_dsp_power_up(struct cs_dsp *dsp, in cs_dsp_power_up() argument
2477 mutex_lock(&dsp->pwr_lock); in cs_dsp_power_up()
2479 dsp->fw_name = fw_name; in cs_dsp_power_up()
2481 if (dsp->ops->enable_memory) { in cs_dsp_power_up()
2482 ret = dsp->ops->enable_memory(dsp); in cs_dsp_power_up()
2487 if (dsp->ops->enable_core) { in cs_dsp_power_up()
2488 ret = dsp->ops->enable_core(dsp); in cs_dsp_power_up()
2493 ret = cs_dsp_load(dsp, wmfw_firmware, wmfw_filename); in cs_dsp_power_up()
2497 ret = dsp->ops->setup_algs(dsp); in cs_dsp_power_up()
2501 ret = cs_dsp_load_coeff(dsp, coeff_firmware, coeff_filename); in cs_dsp_power_up()
2506 ret = cs_dsp_coeff_init_control_caches(dsp); in cs_dsp_power_up()
2510 if (dsp->ops->disable_core) in cs_dsp_power_up()
2511 dsp->ops->disable_core(dsp); in cs_dsp_power_up()
2513 dsp->booted = true; in cs_dsp_power_up()
2515 mutex_unlock(&dsp->pwr_lock); in cs_dsp_power_up()
2519 if (dsp->ops->disable_core) in cs_dsp_power_up()
2520 dsp->ops->disable_core(dsp); in cs_dsp_power_up()
2522 if (dsp->ops->disable_memory) in cs_dsp_power_up()
2523 dsp->ops->disable_memory(dsp); in cs_dsp_power_up()
2525 mutex_unlock(&dsp->pwr_lock); in cs_dsp_power_up()
2538 void cs_dsp_power_down(struct cs_dsp *dsp) in cs_dsp_power_down() argument
2542 mutex_lock(&dsp->pwr_lock); in cs_dsp_power_down()
2544 cs_dsp_debugfs_clear(dsp); in cs_dsp_power_down()
2546 dsp->fw_id = 0; in cs_dsp_power_down()
2547 dsp->fw_id_version = 0; in cs_dsp_power_down()
2549 dsp->booted = false; in cs_dsp_power_down()
2551 if (dsp->ops->disable_memory) in cs_dsp_power_down()
2552 dsp->ops->disable_memory(dsp); in cs_dsp_power_down()
2554 list_for_each_entry(ctl, &dsp->ctl_list, list) in cs_dsp_power_down()
2557 cs_dsp_free_alg_regions(dsp); in cs_dsp_power_down()
2559 mutex_unlock(&dsp->pwr_lock); in cs_dsp_power_down()
2561 cs_dsp_dbg(dsp, "Shutdown complete\n"); in cs_dsp_power_down()
2565 static int cs_dsp_adsp2_start_core(struct cs_dsp *dsp) in cs_dsp_adsp2_start_core() argument
2567 return regmap_update_bits(dsp->regmap, dsp->base + ADSP2_CONTROL, in cs_dsp_adsp2_start_core()
2572 static void cs_dsp_adsp2_stop_core(struct cs_dsp *dsp) in cs_dsp_adsp2_stop_core() argument
2574 regmap_update_bits(dsp->regmap, dsp->base + ADSP2_CONTROL, in cs_dsp_adsp2_stop_core()
2586 int cs_dsp_run(struct cs_dsp *dsp) in cs_dsp_run() argument
2590 mutex_lock(&dsp->pwr_lock); in cs_dsp_run()
2592 if (!dsp->booted) { in cs_dsp_run()
2597 if (dsp->ops->enable_core) { in cs_dsp_run()
2598 ret = dsp->ops->enable_core(dsp); in cs_dsp_run()
2604 ret = cs_dsp_coeff_sync_controls(dsp); in cs_dsp_run()
2608 if (dsp->ops->lock_memory) { in cs_dsp_run()
2609 ret = dsp->ops->lock_memory(dsp, dsp->lock_regions); in cs_dsp_run()
2611 cs_dsp_err(dsp, "Error configuring MPU: %d\n", ret); in cs_dsp_run()
2616 if (dsp->ops->start_core) { in cs_dsp_run()
2617 ret = dsp->ops->start_core(dsp); in cs_dsp_run()
2622 dsp->running = true; in cs_dsp_run()
2624 if (dsp->client_ops->post_run) { in cs_dsp_run()
2625 ret = dsp->client_ops->post_run(dsp); in cs_dsp_run()
2630 mutex_unlock(&dsp->pwr_lock); in cs_dsp_run()
2635 if (dsp->ops->stop_core) in cs_dsp_run()
2636 dsp->ops->stop_core(dsp); in cs_dsp_run()
2637 if (dsp->ops->disable_core) in cs_dsp_run()
2638 dsp->ops->disable_core(dsp); in cs_dsp_run()
2639 mutex_unlock(&dsp->pwr_lock); in cs_dsp_run()
2651 void cs_dsp_stop(struct cs_dsp *dsp) in cs_dsp_stop() argument
2654 cs_dsp_signal_event_controls(dsp, CS_DSP_FW_EVENT_SHUTDOWN); in cs_dsp_stop()
2656 if (dsp->ops->stop_watchdog) in cs_dsp_stop()
2657 dsp->ops->stop_watchdog(dsp); in cs_dsp_stop()
2660 if (dsp->ops->show_fw_status) in cs_dsp_stop()
2661 dsp->ops->show_fw_status(dsp); in cs_dsp_stop()
2663 mutex_lock(&dsp->pwr_lock); in cs_dsp_stop()
2665 dsp->running = false; in cs_dsp_stop()
2667 if (dsp->ops->stop_core) in cs_dsp_stop()
2668 dsp->ops->stop_core(dsp); in cs_dsp_stop()
2669 if (dsp->ops->disable_core) in cs_dsp_stop()
2670 dsp->ops->disable_core(dsp); in cs_dsp_stop()
2672 if (dsp->client_ops->post_stop) in cs_dsp_stop()
2673 dsp->client_ops->post_stop(dsp); in cs_dsp_stop()
2675 mutex_unlock(&dsp->pwr_lock); in cs_dsp_stop()
2677 cs_dsp_dbg(dsp, "Execution stopped\n"); in cs_dsp_stop()
2681 static int cs_dsp_halo_start_core(struct cs_dsp *dsp) in cs_dsp_halo_start_core() argument
2683 return regmap_update_bits(dsp->regmap, in cs_dsp_halo_start_core()
2684 dsp->base + HALO_CCM_CORE_CONTROL, in cs_dsp_halo_start_core()
2689 static void cs_dsp_halo_stop_core(struct cs_dsp *dsp) in cs_dsp_halo_stop_core() argument
2691 regmap_update_bits(dsp->regmap, dsp->base + HALO_CCM_CORE_CONTROL, in cs_dsp_halo_stop_core()
2695 regmap_update_bits(dsp->regmap, dsp->base + HALO_CORE_SOFT_RESET, in cs_dsp_halo_stop_core()
2705 int cs_dsp_adsp2_init(struct cs_dsp *dsp) in cs_dsp_adsp2_init() argument
2709 switch (dsp->rev) { in cs_dsp_adsp2_init()
2715 ret = regmap_update_bits(dsp->regmap, dsp->base + ADSP2_CONTROL, in cs_dsp_adsp2_init()
2718 cs_dsp_err(dsp, in cs_dsp_adsp2_init()
2723 dsp->ops = &cs_dsp_adsp2_ops[0]; in cs_dsp_adsp2_init()
2726 dsp->ops = &cs_dsp_adsp2_ops[1]; in cs_dsp_adsp2_init()
2729 dsp->ops = &cs_dsp_adsp2_ops[2]; in cs_dsp_adsp2_init()
2733 return cs_dsp_common_init(dsp); in cs_dsp_adsp2_init()
2743 int cs_dsp_halo_init(struct cs_dsp *dsp) in cs_dsp_halo_init() argument
2745 dsp->ops = &cs_dsp_halo_ops; in cs_dsp_halo_init()
2747 return cs_dsp_common_init(dsp); in cs_dsp_halo_init()
2755 void cs_dsp_remove(struct cs_dsp *dsp) in cs_dsp_remove() argument
2759 while (!list_empty(&dsp->ctl_list)) { in cs_dsp_remove()
2760 ctl = list_first_entry(&dsp->ctl_list, struct cs_dsp_coeff_ctl, list); in cs_dsp_remove()
2762 if (dsp->client_ops->control_remove) in cs_dsp_remove()
2763 dsp->client_ops->control_remove(ctl); in cs_dsp_remove()
2785 int cs_dsp_read_raw_data_block(struct cs_dsp *dsp, int mem_type, unsigned int mem_addr, in cs_dsp_read_raw_data_block() argument
2788 struct cs_dsp_region const *mem = cs_dsp_find_region(dsp, mem_type); in cs_dsp_read_raw_data_block()
2795 reg = dsp->ops->region_to_reg(mem, mem_addr); in cs_dsp_read_raw_data_block()
2797 ret = regmap_raw_read(dsp->regmap, reg, data, in cs_dsp_read_raw_data_block()
2815 int cs_dsp_read_data_word(struct cs_dsp *dsp, int mem_type, unsigned int mem_addr, u32 *data) in cs_dsp_read_data_word() argument
2820 ret = cs_dsp_read_raw_data_block(dsp, mem_type, mem_addr, 1, &raw); in cs_dsp_read_data_word()
2839 int cs_dsp_write_data_word(struct cs_dsp *dsp, int mem_type, unsigned int mem_addr, u32 data) in cs_dsp_write_data_word() argument
2841 struct cs_dsp_region const *mem = cs_dsp_find_region(dsp, mem_type); in cs_dsp_write_data_word()
2848 reg = dsp->ops->region_to_reg(mem, mem_addr); in cs_dsp_write_data_word()
2850 return regmap_raw_write(dsp->regmap, reg, &val, sizeof(val)); in cs_dsp_write_data_word()
2884 void cs_dsp_adsp2_bus_error(struct cs_dsp *dsp) in cs_dsp_adsp2_bus_error() argument
2887 struct regmap *regmap = dsp->regmap; in cs_dsp_adsp2_bus_error()
2890 mutex_lock(&dsp->pwr_lock); in cs_dsp_adsp2_bus_error()
2892 ret = regmap_read(regmap, dsp->base + ADSP2_LOCK_REGION_CTRL, &val); in cs_dsp_adsp2_bus_error()
2894 cs_dsp_err(dsp, in cs_dsp_adsp2_bus_error()
2900 cs_dsp_err(dsp, "watchdog timeout error\n"); in cs_dsp_adsp2_bus_error()
2901 dsp->ops->stop_watchdog(dsp); in cs_dsp_adsp2_bus_error()
2902 if (dsp->client_ops->watchdog_expired) in cs_dsp_adsp2_bus_error()
2903 dsp->client_ops->watchdog_expired(dsp); in cs_dsp_adsp2_bus_error()
2908 cs_dsp_err(dsp, "bus error: address error\n"); in cs_dsp_adsp2_bus_error()
2910 cs_dsp_err(dsp, "bus error: region lock error\n"); in cs_dsp_adsp2_bus_error()
2912 ret = regmap_read(regmap, dsp->base + ADSP2_BUS_ERR_ADDR, &val); in cs_dsp_adsp2_bus_error()
2914 cs_dsp_err(dsp, in cs_dsp_adsp2_bus_error()
2920 cs_dsp_err(dsp, "bus error address = 0x%x\n", in cs_dsp_adsp2_bus_error()
2924 dsp->base + ADSP2_PMEM_ERR_ADDR_XMEM_ERR_ADDR, in cs_dsp_adsp2_bus_error()
2927 cs_dsp_err(dsp, in cs_dsp_adsp2_bus_error()
2933 cs_dsp_err(dsp, "xmem error address = 0x%x\n", in cs_dsp_adsp2_bus_error()
2935 cs_dsp_err(dsp, "pmem error address = 0x%x\n", in cs_dsp_adsp2_bus_error()
2940 regmap_update_bits(regmap, dsp->base + ADSP2_LOCK_REGION_CTRL, in cs_dsp_adsp2_bus_error()
2944 mutex_unlock(&dsp->pwr_lock); in cs_dsp_adsp2_bus_error()
2954 void cs_dsp_halo_bus_error(struct cs_dsp *dsp) in cs_dsp_halo_bus_error() argument
2956 struct regmap *regmap = dsp->regmap; in cs_dsp_halo_bus_error()
2959 { dsp->base + HALO_MPU_XM_VIO_STATUS, 0x0 }, in cs_dsp_halo_bus_error()
2960 { dsp->base + HALO_MPU_YM_VIO_STATUS, 0x0 }, in cs_dsp_halo_bus_error()
2961 { dsp->base + HALO_MPU_PM_VIO_STATUS, 0x0 }, in cs_dsp_halo_bus_error()
2965 mutex_lock(&dsp->pwr_lock); in cs_dsp_halo_bus_error()
2967 ret = regmap_read(regmap, dsp->base_sysinfo + HALO_AHBM_WINDOW_DEBUG_1, in cs_dsp_halo_bus_error()
2970 cs_dsp_warn(dsp, "Failed to read AHB DEBUG_1: %d\n", ret); in cs_dsp_halo_bus_error()
2974 cs_dsp_warn(dsp, "AHB: STATUS: 0x%x ADDR: 0x%x\n", in cs_dsp_halo_bus_error()
2979 ret = regmap_read(regmap, dsp->base_sysinfo + HALO_AHBM_WINDOW_DEBUG_0, in cs_dsp_halo_bus_error()
2982 cs_dsp_warn(dsp, "Failed to read AHB DEBUG_0: %d\n", ret); in cs_dsp_halo_bus_error()
2986 cs_dsp_warn(dsp, "AHB: SYS_ADDR: 0x%x\n", *fault); in cs_dsp_halo_bus_error()
2988 ret = regmap_bulk_read(regmap, dsp->base + HALO_MPU_XM_VIO_ADDR, in cs_dsp_halo_bus_error()
2991 cs_dsp_warn(dsp, "Failed to read MPU fault info: %d\n", ret); in cs_dsp_halo_bus_error()
2995 cs_dsp_warn(dsp, "XM: STATUS:0x%x ADDR:0x%x\n", fault[1], fault[0]); in cs_dsp_halo_bus_error()
2996 cs_dsp_warn(dsp, "YM: STATUS:0x%x ADDR:0x%x\n", fault[3], fault[2]); in cs_dsp_halo_bus_error()
2997 cs_dsp_warn(dsp, "PM: STATUS:0x%x ADDR:0x%x\n", fault[5], fault[4]); in cs_dsp_halo_bus_error()
2999 ret = regmap_multi_reg_write(dsp->regmap, clear, ARRAY_SIZE(clear)); in cs_dsp_halo_bus_error()
3001 cs_dsp_warn(dsp, "Failed to clear MPU status: %d\n", ret); in cs_dsp_halo_bus_error()
3004 mutex_unlock(&dsp->pwr_lock); in cs_dsp_halo_bus_error()
3014 void cs_dsp_halo_wdt_expire(struct cs_dsp *dsp) in cs_dsp_halo_wdt_expire() argument
3016 mutex_lock(&dsp->pwr_lock); in cs_dsp_halo_wdt_expire()
3018 cs_dsp_warn(dsp, "WDT Expiry Fault\n"); in cs_dsp_halo_wdt_expire()
3020 dsp->ops->stop_watchdog(dsp); in cs_dsp_halo_wdt_expire()
3021 if (dsp->client_ops->watchdog_expired) in cs_dsp_halo_wdt_expire()
3022 dsp->client_ops->watchdog_expired(dsp); in cs_dsp_halo_wdt_expire()
3024 mutex_unlock(&dsp->pwr_lock); in cs_dsp_halo_wdt_expire()