ALSA: x86: fix error return code in hdmi_lpe_audio_probe()
authorGustavo A. R. Silva <garsilva@embeddedor.com>
Fri, 30 Jun 2017 20:18:41 +0000 (15:18 -0500)
committerTakashi Iwai <tiwai@suse.de>
Fri, 30 Jun 2017 20:38:18 +0000 (22:38 +0200)
platform_get_irq() returns an error code, but the intel_hdmi_audio
driver ignores it and always returns -ENODEV. This is not correct,
and prevents -EPROBE_DEFER from being propagated properly. Also,
notice that platform_get_irq() no longer returns 0 on error.

Print error message and propagate the return value of platform_get_irq
on failure.

Signed-off-by: Gustavo A. R. Silva <garsilva@embeddedor.com>
Signed-off-by: Takashi Iwai <tiwai@suse.de>
sound/x86/intel_hdmi_audio.c

index b11d3920b9a521b95142481106d420ac75643b26..37f06ffdf1e6bad9715c8b96b94a664c27ad2e53 100644 (file)
@@ -1699,8 +1699,8 @@ static int hdmi_lpe_audio_probe(struct platform_device *pdev)
        /* get resources */
        irq = platform_get_irq(pdev, 0);
        if (irq < 0) {
-               dev_err(&pdev->dev, "Could not get irq resource\n");
-               return -ENODEV;
+               dev_err(&pdev->dev, "Could not get irq resource: %d\n", irq);
+               return irq;
        }
 
        res_mmio = platform_get_resource(pdev, IORESOURCE_MEM, 0);