ASoC: hdac_hdmi: Fix possible NULL pointer dereference
authorSubhransu S. Prusty <[email protected]>
Tue, 7 Nov 2017 10:46:25 +0000 (16:16 +0530)
committerMark Brown <[email protected]>
Wed, 8 Nov 2017 18:58:24 +0000 (18:58 +0000)
Pointers hdac_hdmi_pcm and hda_device_id can be NULL, so add check for
valid pointer to avoid NULL pointer dereference.

Signed-off-by: Subhransu S. Prusty <[email protected]>
Signed-off-by: Guneshwor Singh <[email protected]>
Acked-By: Vinod Koul <[email protected]>
Signed-off-by: Mark Brown <[email protected]>
sound/soc/codecs/hdac_hdmi.c

index 6f3ff15c0962070f46616f232cb14b428427c3b1..0c0aa618250223f910da7aba36ce2108aef77049 100644 (file)
@@ -1895,6 +1895,9 @@ static void hdac_hdmi_set_chmap(struct hdac_device *hdac, int pcm_idx,
        struct hdac_hdmi_pcm *pcm = get_hdmi_pcm_from_id(hdmi, pcm_idx);
        struct hdac_hdmi_port *port;
 
+       if (!pcm)
+               return;
+
        if (list_empty(&pcm->port_list))
                return;
 
@@ -1913,6 +1916,9 @@ static bool is_hdac_hdmi_pcm_attached(struct hdac_device *hdac, int pcm_idx)
        struct hdac_hdmi_priv *hdmi = edev->private_data;
        struct hdac_hdmi_pcm *pcm = get_hdmi_pcm_from_id(hdmi, pcm_idx);
 
+       if (!pcm)
+               return false;
+
        if (list_empty(&pcm->port_list))
                return false;
 
@@ -1926,6 +1932,9 @@ static int hdac_hdmi_get_spk_alloc(struct hdac_device *hdac, int pcm_idx)
        struct hdac_hdmi_pcm *pcm = get_hdmi_pcm_from_id(hdmi, pcm_idx);
        struct hdac_hdmi_port *port;
 
+       if (!pcm)
+               return 0;
+
        if (list_empty(&pcm->port_list))
                return 0;
 
@@ -1979,6 +1988,9 @@ static int hdac_hdmi_dev_probe(struct hdac_ext_device *edev)
        hdmi_priv->chmap.ops.is_pcm_attached = is_hdac_hdmi_pcm_attached;
        hdmi_priv->chmap.ops.get_spk_alloc = hdac_hdmi_get_spk_alloc;
 
+       if (!hdac_id)
+               return -ENODEV;
+
        if (hdac_id->driver_data)
                hdmi_priv->drv_data =
                        (struct hdac_hdmi_drv_data *)hdac_id->driver_data;