ASoC: Intel: sst-acpi: Fix Oops in case of missing firmware
authorJarkko Nikula <jarkko.nikula@linux.intel.com>
Tue, 25 Feb 2014 14:37:47 +0000 (16:37 +0200)
committerMark Brown <broonie@linaro.org>
Tue, 25 Feb 2014 23:45:35 +0000 (08:45 +0900)
I swear I tested missing firmware in commit e5161d7987f1 ("ASoC: Intel:
sst-acpi: Request firmware before SST platform driver probing").

Unfortunately same wasn't done in commit 6dda27cbbd1d ("ASoC: Intel:
sst-acpi: Add support for multiple machine drivers per platform") which
will cause NULL pointer dereference in sst_acpi_fw_cb() when printing the
error since sst_acpi->mach is not set.

Fix this obvious error by setting the sst_acpi->mach in sst_acpi_probe().

Reported-by: Mika Westerberg <mika.westerberg@linux.intel.com>
Signed-off-by: Jarkko Nikula <jarkko.nikula@linux.intel.com>
Acked-by: Liam Girdwood <liam.r.girdwood@linux.intel.com>
Signed-off-by: Mark Brown <broonie@linaro.org>
sound/soc/intel/sst-acpi.c

index 0bb43169e1461d9e09e693311cabce24d962e8b8..5d06eecb61986da272fcda4858db56c91d285153 100644 (file)
@@ -139,6 +139,7 @@ static int sst_acpi_probe(struct platform_device *pdev)
        sst_pdata = &sst_acpi->sst_pdata;
        sst_pdata->id = desc->sst_id;
        sst_acpi->desc = desc;
+       sst_acpi->mach = mach;
 
        if (desc->resindex_dma_base >= 0) {
                sst_pdata->dma_engine = desc->dma_engine;