[alsa-devel] [PATCH 2/14] sound: Move dereference after NULL test and drop unnecessary NULL tests
Takashi Iwai
tiwai at suse.de
Fri Oct 30 12:02:05 CET 2009
At Sat, 17 Oct 2009 08:33:22 +0200 (CEST),
Julia Lawall wrote:
>
> From: Julia Lawall <julia at diku.dk>
>
> In pcm.c, if the NULL test on pcm is needed, then the dereference should be
> after the NULL test.
>
> In dummy.c and ali5451.c, the context of the calls to
> snd_card_dummy_new_mixer and snd_ali_free_voice show that dummy and pvoice,
> respectively cannot be NULL.
>
> A simplified version of the semantic match that detects this problem is as
> follows (http://coccinelle.lip6.fr/):
>
> // <smpl>
> @match exists@
> expression x, E;
> identifier fld;
> @@
>
> * x->fld
> ... when != \(x = E\|&x\)
> * x == NULL
> // </smpl>
>
> Signed-off-by: Julia Lawall <julia at diku.dk>
Thanks, applied now.
Takashi
>
> ---
> sound/core/pcm.c | 5 +++--
> sound/drivers/dummy.c | 2 --
> sound/pci/ali5451/ali5451.c | 2 +-
>
> diff --git a/sound/core/pcm.c b/sound/core/pcm.c
> index 0c14401..c69c60b 100644
> --- a/sound/core/pcm.c
> +++ b/sound/core/pcm.c
> @@ -953,11 +953,12 @@ static int snd_pcm_dev_register(struct snd_device *device)
> struct snd_pcm_substream *substream;
> struct snd_pcm_notify *notify;
> char str[16];
> - struct snd_pcm *pcm = device->device_data;
> + struct snd_pcm *pcm;
> struct device *dev;
>
> - if (snd_BUG_ON(!pcm || !device))
> + if (snd_BUG_ON(!device || !device->device_data))
> return -ENXIO;
> + pcm = device->device_data;
> mutex_lock(®ister_mutex);
> err = snd_pcm_add(pcm);
> if (err) {
> diff --git a/sound/drivers/dummy.c b/sound/drivers/dummy.c
> index 6ba066c..146ef00 100644
> --- a/sound/drivers/dummy.c
> +++ b/sound/drivers/dummy.c
> @@ -808,8 +808,6 @@ static int __devinit snd_card_dummy_new_mixer(struct snd_dummy *dummy)
> unsigned int idx;
> int err;
>
> - if (snd_BUG_ON(!dummy))
> - return -EINVAL;
> spin_lock_init(&dummy->mixer_lock);
> strcpy(card->mixername, "Dummy Mixer");
>
> diff --git a/sound/pci/ali5451/ali5451.c b/sound/pci/ali5451/ali5451.c
> index b458d20..aaf4da6 100644
> --- a/sound/pci/ali5451/ali5451.c
> +++ b/sound/pci/ali5451/ali5451.c
> @@ -973,7 +973,7 @@ static void snd_ali_free_voice(struct snd_ali * codec,
> void *private_data;
>
> snd_ali_printk("free_voice: channel=%d\n",pvoice->number);
> - if (pvoice == NULL || !pvoice->use)
> + if (!pvoice->use)
> return;
> snd_ali_clear_voices(codec, pvoice->number, pvoice->number);
> spin_lock_irq(&codec->voice_alloc);
>
More information about the Alsa-devel
mailing list