[PATCH 2/3] gpu: ipu-v3: image-convert: Combine rotate/no-rotate irq handlers
Philipp Zabel
p.zabel at pengutronix.de
Fri Jun 26 09:36:22 UTC 2020
On Wed, 2020-06-17 at 15:40 -0700, Steve Longerbeam wrote:
> Combine the rotate_irq() and norotate_irq() handlers into a single
> eof_irq() handler.
>
> Signed-off-by: Steve Longerbeam <slongerbeam at gmail.com>
Reviewed-by: Philipp Zabel <p.zabel at pengutronix.de>
regards
Philipp
> ---
> drivers/gpu/ipu-v3/ipu-image-convert.c | 58 +++++++++-----------------
> 1 file changed, 20 insertions(+), 38 deletions(-)
>
> diff --git a/drivers/gpu/ipu-v3/ipu-image-convert.c b/drivers/gpu/ipu-v3/ipu-image-convert.c
> index eeca50d9a1ee..f8b031ded3cf 100644
> --- a/drivers/gpu/ipu-v3/ipu-image-convert.c
> +++ b/drivers/gpu/ipu-v3/ipu-image-convert.c
> @@ -1709,9 +1709,10 @@ static irqreturn_t do_irq(struct ipu_image_convert_run *run)
> return IRQ_WAKE_THREAD;
> }
>
> -static irqreturn_t norotate_irq(int irq, void *data)
> +static irqreturn_t eof_irq(int irq, void *data)
> {
> struct ipu_image_convert_chan *chan = data;
> + struct ipu_image_convert_priv *priv = chan->priv;
> struct ipu_image_convert_ctx *ctx;
> struct ipu_image_convert_run *run;
> unsigned long flags;
> @@ -1728,45 +1729,26 @@ static irqreturn_t norotate_irq(int irq, void *data)
>
> ctx = run->ctx;
>
> - if (ipu_rot_mode_is_irt(ctx->rot_mode)) {
> - /* this is a rotation operation, just ignore */
> - spin_unlock_irqrestore(&chan->irqlock, flags);
> - return IRQ_HANDLED;
> - }
> -
> - ret = do_irq(run);
> -out:
> - spin_unlock_irqrestore(&chan->irqlock, flags);
> - return ret;
> -}
> -
> -static irqreturn_t rotate_irq(int irq, void *data)
> -{
> - struct ipu_image_convert_chan *chan = data;
> - struct ipu_image_convert_priv *priv = chan->priv;
> - struct ipu_image_convert_ctx *ctx;
> - struct ipu_image_convert_run *run;
> - unsigned long flags;
> - irqreturn_t ret;
> -
> - spin_lock_irqsave(&chan->irqlock, flags);
> -
> - /* get current run and its context */
> - run = chan->current_run;
> - if (!run) {
> + if (irq == chan->out_eof_irq) {
> + if (ipu_rot_mode_is_irt(ctx->rot_mode)) {
> + /* this is a rotation op, just ignore */
> + ret = IRQ_HANDLED;
> + goto out;
> + }
> + } else if (irq == chan->rot_out_eof_irq) {
> + if (!ipu_rot_mode_is_irt(ctx->rot_mode)) {
> + /* this was NOT a rotation op, shouldn't happen */
> + dev_err(priv->ipu->dev,
> + "Unexpected rotation interrupt\n");
> + ret = IRQ_HANDLED;
> + goto out;
> + }
> + } else {
> + dev_err(priv->ipu->dev, "Received unknown irq %d\n", irq);
> ret = IRQ_NONE;
> goto out;
> }
>
> - ctx = run->ctx;
> -
> - if (!ipu_rot_mode_is_irt(ctx->rot_mode)) {
> - /* this was NOT a rotation operation, shouldn't happen */
> - dev_err(priv->ipu->dev, "Unexpected rotation interrupt\n");
> - spin_unlock_irqrestore(&chan->irqlock, flags);
> - return IRQ_HANDLED;
> - }
> -
> ret = do_irq(run);
> out:
> spin_unlock_irqrestore(&chan->irqlock, flags);
> @@ -1859,7 +1841,7 @@ static int get_ipu_resources(struct ipu_image_convert_chan *chan)
> chan->out_chan,
> IPU_IRQ_EOF);
>
> - ret = request_threaded_irq(chan->out_eof_irq, norotate_irq, do_bh,
> + ret = request_threaded_irq(chan->out_eof_irq, eof_irq, do_bh,
> 0, "ipu-ic", chan);
> if (ret < 0) {
> dev_err(priv->ipu->dev, "could not acquire irq %d\n",
> @@ -1872,7 +1854,7 @@ static int get_ipu_resources(struct ipu_image_convert_chan *chan)
> chan->rotation_out_chan,
> IPU_IRQ_EOF);
>
> - ret = request_threaded_irq(chan->rot_out_eof_irq, rotate_irq, do_bh,
> + ret = request_threaded_irq(chan->rot_out_eof_irq, eof_irq, do_bh,
> 0, "ipu-ic", chan);
> if (ret < 0) {
> dev_err(priv->ipu->dev, "could not acquire irq %d\n",
More information about the dri-devel
mailing list