Commit 363d4538 authored by Dharageswari R's avatar Dharageswari R Committed by Mark Brown

ASoC: Intel: Skylake: Add num of cores in dsp ops

Number of dsp cores may differ for different platforms hence
adding it in dsp ops.
Signed-off-by: default avatarDharageswari R <dharageswari.r@intel.com>
Signed-off-by: default avatarGuneshwor Singh <guneshwor.o.singh@intel.com>
Acked-By: default avatarVinod Koul <vinod.koul@intel.com>
Signed-off-by: default avatarMark Brown <broonie@kernel.org>
parent 0b06122f
...@@ -584,7 +584,6 @@ int bxt_sst_dsp_init(struct device *dev, void __iomem *mmio_base, int irq, ...@@ -584,7 +584,6 @@ int bxt_sst_dsp_init(struct device *dev, void __iomem *mmio_base, int irq,
/* set the D0i3 check */ /* set the D0i3 check */
skl->ipc.ops.check_dsp_lp_on = skl_ipc_check_D0i0; skl->ipc.ops.check_dsp_lp_on = skl_ipc_check_D0i0;
skl->cores.count = 2;
skl->boot_complete = false; skl->boot_complete = false;
init_waitqueue_head(&skl->boot_wait); init_waitqueue_head(&skl->boot_wait);
INIT_DELAYED_WORK(&skl->d0i3.work, bxt_set_dsp_D0i3); INIT_DELAYED_WORK(&skl->d0i3.work, bxt_set_dsp_D0i3);
......
...@@ -201,6 +201,7 @@ static struct skl_dsp_loader_ops bxt_get_loader_ops(void) ...@@ -201,6 +201,7 @@ static struct skl_dsp_loader_ops bxt_get_loader_ops(void)
static const struct skl_dsp_ops dsp_ops[] = { static const struct skl_dsp_ops dsp_ops[] = {
{ {
.id = 0x9d70, .id = 0x9d70,
.num_cores = 2,
.loader_ops = skl_get_loader_ops, .loader_ops = skl_get_loader_ops,
.init = skl_sst_dsp_init, .init = skl_sst_dsp_init,
.init_fw = skl_sst_init_fw, .init_fw = skl_sst_init_fw,
...@@ -208,6 +209,7 @@ static const struct skl_dsp_ops dsp_ops[] = { ...@@ -208,6 +209,7 @@ static const struct skl_dsp_ops dsp_ops[] = {
}, },
{ {
.id = 0x9d71, .id = 0x9d71,
.num_cores = 2,
.loader_ops = skl_get_loader_ops, .loader_ops = skl_get_loader_ops,
.init = kbl_sst_dsp_init, .init = kbl_sst_dsp_init,
.init_fw = skl_sst_init_fw, .init_fw = skl_sst_init_fw,
...@@ -215,6 +217,7 @@ static const struct skl_dsp_ops dsp_ops[] = { ...@@ -215,6 +217,7 @@ static const struct skl_dsp_ops dsp_ops[] = {
}, },
{ {
.id = 0x5a98, .id = 0x5a98,
.num_cores = 2,
.loader_ops = bxt_get_loader_ops, .loader_ops = bxt_get_loader_ops,
.init = bxt_sst_dsp_init, .init = bxt_sst_dsp_init,
.init_fw = bxt_sst_init_fw, .init_fw = bxt_sst_init_fw,
...@@ -222,6 +225,7 @@ static const struct skl_dsp_ops dsp_ops[] = { ...@@ -222,6 +225,7 @@ static const struct skl_dsp_ops dsp_ops[] = {
}, },
{ {
.id = 0x3198, .id = 0x3198,
.num_cores = 2,
.loader_ops = bxt_get_loader_ops, .loader_ops = bxt_get_loader_ops,
.init = bxt_sst_dsp_init, .init = bxt_sst_dsp_init,
.init_fw = bxt_sst_init_fw, .init_fw = bxt_sst_init_fw,
...@@ -275,6 +279,8 @@ int skl_init_dsp(struct skl *skl) ...@@ -275,6 +279,8 @@ int skl_init_dsp(struct skl *skl)
return ret; return ret;
skl->skl_sst->dsp_ops = ops; skl->skl_sst->dsp_ops = ops;
skl->skl_sst->cores.count = ops->num_cores;
dev_dbg(bus->dev, "dsp registration status=%d\n", ret); dev_dbg(bus->dev, "dsp registration status=%d\n", ret);
return ret; return ret;
......
...@@ -563,8 +563,6 @@ int skl_sst_dsp_init(struct device *dev, void __iomem *mmio_base, int irq, ...@@ -563,8 +563,6 @@ int skl_sst_dsp_init(struct device *dev, void __iomem *mmio_base, int irq,
sst->fw_ops = skl_fw_ops; sst->fw_ops = skl_fw_ops;
skl->cores.count = 2;
return 0; return 0;
} }
EXPORT_SYMBOL_GPL(skl_sst_dsp_init); EXPORT_SYMBOL_GPL(skl_sst_dsp_init);
......
...@@ -90,6 +90,7 @@ struct skl_machine_pdata { ...@@ -90,6 +90,7 @@ struct skl_machine_pdata {
struct skl_dsp_ops { struct skl_dsp_ops {
int id; int id;
unsigned int num_cores;
struct skl_dsp_loader_ops (*loader_ops)(void); struct skl_dsp_loader_ops (*loader_ops)(void);
int (*init)(struct device *dev, void __iomem *mmio_base, int (*init)(struct device *dev, void __iomem *mmio_base,
int irq, const char *fw_name, int irq, const char *fw_name,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment