mirror of
git://git.yoctoproject.org/linux-yocto.git
synced 2025-08-22 00:42:01 +02:00
drm/bridge: adv7511: Allow IRQ to share GPIO pins
The IRQ registration currently assumes that the GPIO is dedicated to it, but that may not necessarily be the case. If the board has another device sharing the GPIO, it won't be registered and the hot-plug detect fails to function. Currently, the handler reads two registers and blindly assumes one of them caused the interrupt and returns IRQ_HANDLED unless there is an error. In order to properly do this, the IRQ handler needs to check if it needs to handle the IRQ and return IRQ_NONE if there is nothing to handle. With the check added and the return code properly indicating whether or not it there was an IRQ, the IRQF_SHARED can be set to share a GPIO IRQ. V2: Add check to see if there is IRQ data to handle Signed-off-by: Adam Ford <aford173@gmail.com> Reviewed-by: Laurent Pinchart <laurent.pinchart+renesas@ideasonboard.com> Reviewed-by: Dmitry Baryshkov <dmitry.baryshkov@linaro.org> Signed-off-by: Dmitry Baryshkov <dmitry.baryshkov@linaro.org> Link: https://patchwork.freedesktop.org/patch/msgid/20240305004859.201085-1-aford173@gmail.com Signed-off-by: Dmitry Baryshkov <dmitry.baryshkov@linaro.org>
This commit is contained in:
parent
45c734fdd4
commit
f3d9683346
|
@ -477,6 +477,11 @@ static int adv7511_irq_process(struct adv7511 *adv7511, bool process_hpd)
|
|||
if (ret < 0)
|
||||
return ret;
|
||||
|
||||
/* If there is no IRQ to handle, exit indicating no IRQ data */
|
||||
if (!(irq0 & (ADV7511_INT0_HPD | ADV7511_INT0_EDID_READY)) &&
|
||||
!(irq1 & ADV7511_INT1_DDC_ERROR))
|
||||
return -ENODATA;
|
||||
|
||||
regmap_write(adv7511->regmap, ADV7511_REG_INT(0), irq0);
|
||||
regmap_write(adv7511->regmap, ADV7511_REG_INT(1), irq1);
|
||||
|
||||
|
@ -1318,7 +1323,8 @@ static int adv7511_probe(struct i2c_client *i2c)
|
|||
|
||||
ret = devm_request_threaded_irq(dev, i2c->irq, NULL,
|
||||
adv7511_irq_handler,
|
||||
IRQF_ONESHOT, dev_name(dev),
|
||||
IRQF_ONESHOT | IRQF_SHARED,
|
||||
dev_name(dev),
|
||||
adv7511);
|
||||
if (ret)
|
||||
goto err_unregister_audio;
|
||||
|
|
Loading…
Reference in New Issue
Block a user