Re: [PATCH] media: camss: move to use request_irq by IRQF_NO_AUTOEN flag

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Wed, 7 Apr 2021 at 08:24, Tian Tao <tiantao6@xxxxxxxxxxxxx> wrote:
>
> disable_irq() after request_irq() still has a time gap in which
> interrupts can come. request_irq() with IRQF_NO_AUTOEN flag will
> disable IRQ auto-enable because of requesting.
>
> this patch is made base on "add IRQF_NO_AUTOEN for request_irq" which
> is being merged: https://lore.kernel.org/patchwork/patch/1388765/
>
> Signed-off-by: Tian Tao <tiantao6@xxxxxxxxxxxxx>
> ---
>  drivers/media/platform/qcom/camss/camss-csid.c   | 5 ++---
>  drivers/media/platform/qcom/camss/camss-csiphy.c | 5 ++---
>  2 files changed, 4 insertions(+), 6 deletions(-)
>
> diff --git a/drivers/media/platform/qcom/camss/camss-csid.c b/drivers/media/platform/qcom/camss/camss-csid.c
> index 463760c..46c19bf 100644
> --- a/drivers/media/platform/qcom/camss/camss-csid.c
> +++ b/drivers/media/platform/qcom/camss/camss-csid.c
> @@ -586,14 +586,13 @@ int msm_csid_subdev_init(struct camss *camss, struct csid_device *csid,
>         snprintf(csid->irq_name, sizeof(csid->irq_name), "%s_%s%d",
>                  dev_name(dev), MSM_CSID_NAME, csid->id);
>         ret = devm_request_irq(dev, csid->irq, csid->ops->isr,
> -                              IRQF_TRIGGER_RISING, csid->irq_name, csid);
> +                              IRQF_TRIGGER_RISING | IRQF_NO_AUTOEN,
> +                              csid->irq_name, csid);
>         if (ret < 0) {
>                 dev_err(dev, "request_irq failed: %d\n", ret);
>                 return ret;
>         }
>
> -       disable_irq(csid->irq);
> -
>         /* Clocks */
>
>         csid->nclocks = 0;
> diff --git a/drivers/media/platform/qcom/camss/camss-csiphy.c b/drivers/media/platform/qcom/camss/camss-csiphy.c
> index 6ceb6d7..fefb4f3 100644
> --- a/drivers/media/platform/qcom/camss/camss-csiphy.c
> +++ b/drivers/media/platform/qcom/camss/camss-csiphy.c
> @@ -625,14 +625,13 @@ int msm_csiphy_subdev_init(struct camss *camss,
>                  dev_name(dev), MSM_CSIPHY_NAME, csiphy->id);
>
>         ret = devm_request_irq(dev, csiphy->irq, csiphy->ops->isr,
> -                              IRQF_TRIGGER_RISING, csiphy->irq_name, csiphy);
> +                              IRQF_TRIGGER_RISING | IRQF_NO_AUTOEN,
> +                              csiphy->irq_name, csiphy);
>         if (ret < 0) {
>                 dev_err(dev, "request_irq failed: %d\n", ret);
>                 return ret;
>         }
>
> -       disable_irq(csiphy->irq);
> -
>         /* Clocks */
>
>         csiphy->nclocks = 0;
> --

When IRQF_NO_AUTOEN[1] lands I'd be happy to see this patch applied as well.

[1]  https://lore.kernel.org/patchwork/patch/1388765/

Reviewed-by: Robert Foss <robert.foss@xxxxxxxxxx>



[Index of Archives]     [Linux Input]     [Video for Linux]     [Gstreamer Embedded]     [Mplayer Users]     [Linux USB Devel]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [Yosemite Backpacking]

  Powered by Linux