ALSA: hda/ca0132 - fix possible NULL pointer use
authorArnd Bergmann <arnd@arndb.de>
Wed, 11 Jan 2017 13:39:44 +0000 (14:39 +0100)
committerTakashi Iwai <tiwai@suse.de>
Wed, 11 Jan 2017 16:19:23 +0000 (17:19 +0100)
gcc-7 caught what it considers a NULL pointer dereference:

sound/pci/hda/patch_ca0132.c: In function 'dspio_scp.constprop':
sound/pci/hda/patch_ca0132.c:1487:4: error: argument 1 null where non-null expected [-Werror=nonnull]

This is plausible from looking at the function, as we compare 'reply'
to NULL earlier in it. I have not tried to analyze if there are constraints
that make it impossible to hit the bug, but adding another NULL check in
the end kills the warning and makes the function more robust.

Signed-off-by: Arnd Bergmann <arnd@arndb.de>
Signed-off-by: Takashi Iwai <tiwai@suse.de>
sound/pci/hda/patch_ca0132.c

index 11b9b2f17a2ef66b7555c0bbbde8d31f6ca2a070..9ec4dba8a793bf04294a61423b94d07fedf4f29f 100644 (file)
@@ -1482,6 +1482,9 @@ static int dspio_scp(struct hda_codec *codec,
                } else if (ret_size != reply_data_size) {
                        codec_dbg(codec, "RetLen and HdrLen .NE.\n");
                        return -EINVAL;
+               } else if (!reply) {
+                       codec_dbg(codec, "NULL reply\n");
+                       return -EINVAL;
                } else {
                        *reply_len = ret_size*sizeof(unsigned int);
                        memcpy(reply, scp_reply.data, *reply_len);