mirror of https://gitee.com/openkylin/linux.git
drm/bridge: tpd12s015: Fix irq registering in tpd12s015_probe
gpiod_to_irq() return negative value in case of error,
the existing code doesn't handle negative error codes.
If the HPD gpio supports IRQs (gpiod_to_irq returns a
valid number), we use the IRQ. If it doesn't (gpiod_to_irq
returns an error), it gets polled via detect().
Fixes: cff5e6f7e8
("drm/bridge: Add driver for the TI TPD12S015 HDMI level shifter")
Signed-off-by: YueHaibing <yuehaibing@huawei.com>
Reviewed-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
Signed-off-by: Sam Ravnborg <sam@ravnborg.org>
Link: https://patchwork.freedesktop.org/patch/msgid/20201102143024.26216-1-yuehaibing@huawei.com
This commit is contained in:
parent
ed794057b0
commit
c2530cc961
|
@ -160,7 +160,7 @@ static int tpd12s015_probe(struct platform_device *pdev)
|
||||||
|
|
||||||
/* Register the IRQ if the HPD GPIO is IRQ-capable. */
|
/* Register the IRQ if the HPD GPIO is IRQ-capable. */
|
||||||
tpd->hpd_irq = gpiod_to_irq(tpd->hpd_gpio);
|
tpd->hpd_irq = gpiod_to_irq(tpd->hpd_gpio);
|
||||||
if (tpd->hpd_irq) {
|
if (tpd->hpd_irq >= 0) {
|
||||||
ret = devm_request_threaded_irq(&pdev->dev, tpd->hpd_irq, NULL,
|
ret = devm_request_threaded_irq(&pdev->dev, tpd->hpd_irq, NULL,
|
||||||
tpd12s015_hpd_isr,
|
tpd12s015_hpd_isr,
|
||||||
IRQF_TRIGGER_RISING |
|
IRQF_TRIGGER_RISING |
|
||||||
|
|
Loading…
Reference in New Issue