|
@@ -1871,9 +1871,11 @@ static void wm_adsp_ctl_fixup_base(struct wm_adsp *dsp,
|
|
}
|
|
}
|
|
|
|
|
|
static void *wm_adsp_read_algs(struct wm_adsp *dsp, size_t n_algs,
|
|
static void *wm_adsp_read_algs(struct wm_adsp *dsp, size_t n_algs,
|
|
|
|
+ const struct wm_adsp_region *mem,
|
|
unsigned int pos, unsigned int len)
|
|
unsigned int pos, unsigned int len)
|
|
{
|
|
{
|
|
void *alg;
|
|
void *alg;
|
|
|
|
+ unsigned int reg;
|
|
int ret;
|
|
int ret;
|
|
__be32 val;
|
|
__be32 val;
|
|
|
|
|
|
@@ -1888,7 +1890,9 @@ static void *wm_adsp_read_algs(struct wm_adsp *dsp, size_t n_algs,
|
|
}
|
|
}
|
|
|
|
|
|
/* Read the terminator first to validate the length */
|
|
/* Read the terminator first to validate the length */
|
|
- ret = regmap_raw_read(dsp->regmap, pos + len, &val, sizeof(val));
|
|
|
|
|
|
+ reg = wm_adsp_region_to_reg(mem, pos + len);
|
|
|
|
+
|
|
|
|
+ ret = regmap_raw_read(dsp->regmap, reg, &val, sizeof(val));
|
|
if (ret != 0) {
|
|
if (ret != 0) {
|
|
adsp_err(dsp, "Failed to read algorithm list end: %d\n",
|
|
adsp_err(dsp, "Failed to read algorithm list end: %d\n",
|
|
ret);
|
|
ret);
|
|
@@ -1897,13 +1901,18 @@ static void *wm_adsp_read_algs(struct wm_adsp *dsp, size_t n_algs,
|
|
|
|
|
|
if (be32_to_cpu(val) != 0xbedead)
|
|
if (be32_to_cpu(val) != 0xbedead)
|
|
adsp_warn(dsp, "Algorithm list end %x 0x%x != 0xbedead\n",
|
|
adsp_warn(dsp, "Algorithm list end %x 0x%x != 0xbedead\n",
|
|
- pos + len, be32_to_cpu(val));
|
|
|
|
|
|
+ reg, be32_to_cpu(val));
|
|
|
|
+
|
|
|
|
+ /* Convert length from DSP words to bytes */
|
|
|
|
+ len *= sizeof(u32);
|
|
|
|
|
|
alg = kcalloc(len, 2, GFP_KERNEL | GFP_DMA);
|
|
alg = kcalloc(len, 2, GFP_KERNEL | GFP_DMA);
|
|
if (!alg)
|
|
if (!alg)
|
|
return ERR_PTR(-ENOMEM);
|
|
return ERR_PTR(-ENOMEM);
|
|
|
|
|
|
- ret = regmap_raw_read(dsp->regmap, pos, alg, len * 2);
|
|
|
|
|
|
+ reg = wm_adsp_region_to_reg(mem, pos);
|
|
|
|
+
|
|
|
|
+ ret = regmap_raw_read(dsp->regmap, reg, alg, len);
|
|
if (ret != 0) {
|
|
if (ret != 0) {
|
|
adsp_err(dsp, "Failed to read algorithm list: %d\n", ret);
|
|
adsp_err(dsp, "Failed to read algorithm list: %d\n", ret);
|
|
kfree(alg);
|
|
kfree(alg);
|
|
@@ -2002,10 +2011,11 @@ static int wm_adsp1_setup_algs(struct wm_adsp *dsp)
|
|
if (IS_ERR(alg_region))
|
|
if (IS_ERR(alg_region))
|
|
return PTR_ERR(alg_region);
|
|
return PTR_ERR(alg_region);
|
|
|
|
|
|
- pos = sizeof(adsp1_id) / 2;
|
|
|
|
- len = (sizeof(*adsp1_alg) * n_algs) / 2;
|
|
|
|
|
|
+ /* Calculate offset and length in DSP words */
|
|
|
|
+ pos = sizeof(adsp1_id) / sizeof(u32);
|
|
|
|
+ len = (sizeof(*adsp1_alg) * n_algs) / sizeof(u32);
|
|
|
|
|
|
- adsp1_alg = wm_adsp_read_algs(dsp, n_algs, mem->base + pos, len);
|
|
|
|
|
|
+ adsp1_alg = wm_adsp_read_algs(dsp, n_algs, mem, pos, len);
|
|
if (IS_ERR(adsp1_alg))
|
|
if (IS_ERR(adsp1_alg))
|
|
return PTR_ERR(adsp1_alg);
|
|
return PTR_ERR(adsp1_alg);
|
|
|
|
|
|
@@ -2113,10 +2123,11 @@ static int wm_adsp2_setup_algs(struct wm_adsp *dsp)
|
|
if (IS_ERR(alg_region))
|
|
if (IS_ERR(alg_region))
|
|
return PTR_ERR(alg_region);
|
|
return PTR_ERR(alg_region);
|
|
|
|
|
|
- pos = sizeof(adsp2_id) / 2;
|
|
|
|
- len = (sizeof(*adsp2_alg) * n_algs) / 2;
|
|
|
|
|
|
+ /* Calculate offset and length in DSP words */
|
|
|
|
+ pos = sizeof(adsp2_id) / sizeof(u32);
|
|
|
|
+ len = (sizeof(*adsp2_alg) * n_algs) / sizeof(u32);
|
|
|
|
|
|
- adsp2_alg = wm_adsp_read_algs(dsp, n_algs, mem->base + pos, len);
|
|
|
|
|
|
+ adsp2_alg = wm_adsp_read_algs(dsp, n_algs, mem, pos, len);
|
|
if (IS_ERR(adsp2_alg))
|
|
if (IS_ERR(adsp2_alg))
|
|
return PTR_ERR(adsp2_alg);
|
|
return PTR_ERR(adsp2_alg);
|
|
|
|
|