From 8a4ceb4beb72047a126b9d970faee845149f60d5 Mon Sep 17 00:00:00 2001 From: Liam Girdwood <liam.r.girdwood@linux.intel.com> Date: Mon, 5 May 2014 13:20:23 +0100 Subject: [PATCH] ASoC: Intel: Fix check for pdata usage before dereference. This patch fixes the following dereference check ordering. sound/soc/intel/sst-haswell-pcm.c:749 hsw_pcm_probe() warn: variable dereferenced before check 'pdata' (see line 746) git remote add asoc git://git.kernel.org/pub/scm/linux/kernel/git/broonie/sound.git git remote update asoc git checkout 7ea94fb4d117a3c481a9d92229bcdee21fc32696 vim +/pdata +749 sound/soc/intel/sst-haswell-pcm.c b91c8f2c Mark Brown 2014-03-12 740 }; b91c8f2c Mark Brown 2014-03-12 741 b91c8f2c Mark Brown 2014-03-12 742 static int hsw_pcm_probe(struct snd_soc_platform *platform) b91c8f2c Mark Brown 2014-03-12 743 { b91c8f2c Mark Brown 2014-03-12 744 struct sst_pdata *pdata = dev_get_platdata(platform->dev); b91c8f2c Mark Brown 2014-03-12 745 struct hsw_priv_data *priv_data; 7ea94fb4 Liam Girdwood 2014-05-02 @746 struct device *dma_dev = pdata->dma_dev; 7ea94fb4 Liam Girdwood 2014-05-02 747 int i, ret = 0; b91c8f2c Mark Brown 2014-03-12 748 b91c8f2c Mark Brown 2014-03-12 @749 if (!pdata) b91c8f2c Mark Brown 2014-03-12 750 return -ENODEV; b91c8f2c Mark Brown 2014-03-12 751 b91c8f2c Mark Brown 2014-03-12 752 priv_data = devm_kzalloc(platform->dev, sizeof(*priv_data), GFP_KERNEL); Reported-by: Dan Carpenter <dan.carpenter@oracle.com> Signed-off-by: Liam Girdwood <liam.r.girdwood@linux.intel.com> Signed-off-by: Mark Brown <broonie@linaro.org> --- sound/soc/intel/sst-haswell-pcm.c | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/sound/soc/intel/sst-haswell-pcm.c b/sound/soc/intel/sst-haswell-pcm.c index 8c6bd33dd375a..9d5f64a583a38 100644 --- a/sound/soc/intel/sst-haswell-pcm.c +++ b/sound/soc/intel/sst-haswell-pcm.c @@ -772,12 +772,14 @@ static int hsw_pcm_probe(struct snd_soc_platform *platform) { struct sst_pdata *pdata = dev_get_platdata(platform->dev); struct hsw_priv_data *priv_data; - struct device *dma_dev = pdata->dma_dev; + struct device *dma_dev; int i, ret = 0; if (!pdata) return -ENODEV; + dma_dev = pdata->dma_dev; + priv_data = devm_kzalloc(platform->dev, sizeof(*priv_data), GFP_KERNEL); priv_data->hsw = pdata->dsp; snd_soc_platform_set_drvdata(platform, priv_data); -- 2.39.5