On 26/03/2024 11:12, Boris Brezillon wrote:
> There's no reason for _irq_suspend/resume() to be called after the
> device has been unplugged, and keeping this dev_enter/exit()
> section in _irq_suspend() is turns _irq_suspend() into a NOP
> when called from the _unplug() functions, which we don't want.
> 
> v3:
> - New patch
> 
> Fixes: 5fe909cae118 ("drm/panthor: Add the device logical block")
> Signed-off-by: Boris Brezillon <boris.brezil...@collabora.com>

LGTM

Reviewed-by: Steven Price <steven.pr...@arm.com>

> ---
>  drivers/gpu/drm/panthor/panthor_device.h | 17 ++++-------------
>  1 file changed, 4 insertions(+), 13 deletions(-)
> 
> diff --git a/drivers/gpu/drm/panthor/panthor_device.h 
> b/drivers/gpu/drm/panthor/panthor_device.h
> index 3a930a368ae1..99ddc41f2626 100644
> --- a/drivers/gpu/drm/panthor/panthor_device.h
> +++ b/drivers/gpu/drm/panthor/panthor_device.h
> @@ -326,13 +326,8 @@ static inline void panthor_ ## __name ## 
> _irq_suspend(struct panthor_irq *pirq)
>       int cookie;                                                             
>                 \
>                                                                               
>                 \
>       pirq->mask = 0;                                                         
>                 \
> -                                                                             
>                 \
> -     if (drm_dev_enter(&pirq->ptdev->base, &cookie)) {                       
>                 \
> -             gpu_write(pirq->ptdev, __reg_prefix ## _INT_MASK, 0);           
>                 \
> -             synchronize_irq(pirq->irq);                                     
>                 \
> -             drm_dev_exit(cookie);                                           
>                 \
> -     }                                                                       
>                 \
> -                                                                             
>                 \
> +     gpu_write(pirq->ptdev, __reg_prefix ## _INT_MASK, 0);                   
>                 \
> +     synchronize_irq(pirq->irq);                                             
>                 \
>       atomic_set(&pirq->suspended, true);                                     
>                 \
>  }                                                                            
>                 \
>                                                                               
>                 \
> @@ -342,12 +337,8 @@ static inline void panthor_ ## __name ## 
> _irq_resume(struct panthor_irq *pirq, u
>                                                                               
>                 \
>       atomic_set(&pirq->suspended, false);                                    
>                 \
>       pirq->mask = mask;                                                      
>                 \
> -                                                                             
>                 \
> -     if (drm_dev_enter(&pirq->ptdev->base, &cookie)) {                       
>                 \
> -             gpu_write(pirq->ptdev, __reg_prefix ## _INT_CLEAR, mask);       
>                 \
> -             gpu_write(pirq->ptdev, __reg_prefix ## _INT_MASK, mask);        
>                 \
> -             drm_dev_exit(cookie);                                           
>                 \
> -     }                                                                       
>                 \
> +     gpu_write(pirq->ptdev, __reg_prefix ## _INT_CLEAR, mask);               
>                 \
> +     gpu_write(pirq->ptdev, __reg_prefix ## _INT_MASK, mask);                
>                 \
>  }                                                                            
>                 \
>                                                                               
>                 \
>  static int panthor_request_ ## __name ## _irq(struct panthor_device *ptdev,  
>                 \

Reply via email to