On 28/05/2026 16:05, Karunika Choo wrote: > panthor_device.h should describe the panthor device state, not provide > generic MMIO helpers. > > Move the register accessors and poll-timeout wrappers to a dedicated > panthor_device_io.h header and include it from the users that need MMIO > access. This makes the dependency explicit and avoids pulling the full > device definition into code that only needs register helpers. > > No functional change. > > Signed-off-by: Karunika Choo <[email protected]> > --- > drivers/gpu/drm/panthor/panthor_device.h | 72 ------------------ > drivers/gpu/drm/panthor/panthor_device_io.h | 81 +++++++++++++++++++++ > drivers/gpu/drm/panthor/panthor_fw.c | 1 + > drivers/gpu/drm/panthor/panthor_gpu.c | 1 + > drivers/gpu/drm/panthor/panthor_hw.c | 1 + > drivers/gpu/drm/panthor/panthor_mmu.c | 1 + > drivers/gpu/drm/panthor/panthor_pwr.c | 1 + > 7 files changed, 86 insertions(+), 72 deletions(-) > create mode 100644 drivers/gpu/drm/panthor/panthor_device_io.h > > diff --git a/drivers/gpu/drm/panthor/panthor_device.h > b/drivers/gpu/drm/panthor/panthor_device.h > index 4e4607bca7cc..c376e52e8564 100644 > --- a/drivers/gpu/drm/panthor/panthor_device.h > +++ b/drivers/gpu/drm/panthor/panthor_device.h > @@ -6,7 +6,6 @@ > #ifndef __PANTHOR_DEVICE_H__ > #define __PANTHOR_DEVICE_H__ > > -#include <linux/atomic.h> > #include <linux/io-pgtable.h> > #include <linux/regulator/consumer.h> > #include <linux/pm_runtime.h> > @@ -630,75 +629,4 @@ static inline void panthor_ ## __name ## > _irq_disable_events(struct panthor_irq > > extern struct workqueue_struct *panthor_cleanup_wq; > > -static inline void gpu_write(void __iomem *iomem, u32 reg, u32 data) > -{ > - writel(data, iomem + reg); > -} > - > -static inline u32 gpu_read(void __iomem *iomem, u32 reg) > -{ > - return readl(iomem + reg); > -}
This is a bit ugly at the moment because further down in this file you've still got calls to gpu_read() (in the PANTHOR_IRQ_HANDLER macro). This of course does build but means that macros are broken unless panthor_device_io.h is also included. I think once Boris' change[1] to the IRQ macro machinery lands this will resolve itself. Thanks, Steve [1] https://lore.kernel.org/all/[email protected]/ > - > -static inline u32 gpu_read_relaxed(void __iomem *iomem, u32 reg) > -{ > - return readl_relaxed(iomem + reg); > -} > - > -static inline void gpu_write64(void __iomem *iomem, u32 reg, u64 data) > -{ > - gpu_write(iomem, reg, lower_32_bits(data)); > - gpu_write(iomem, reg + 4, upper_32_bits(data)); > -} > - > -static inline u64 gpu_read64(void __iomem *iomem, u32 reg) > -{ > - return (gpu_read(iomem, reg) | ((u64)gpu_read(iomem, reg + 4) << 32)); > -} > - > -static inline u64 gpu_read64_relaxed(void __iomem *iomem, u32 reg) > -{ > - return (gpu_read_relaxed(iomem, reg) | > - ((u64)gpu_read_relaxed(iomem, reg + 4) << 32)); > -} > - > -static inline u64 gpu_read64_counter(void __iomem *iomem, u32 reg) > -{ > - u32 lo, hi1, hi2; > - do { > - hi1 = gpu_read(iomem, reg + 4); > - lo = gpu_read(iomem, reg); > - hi2 = gpu_read(iomem, reg + 4); > - } while (hi1 != hi2); > - return lo | ((u64)hi2 << 32); > -} > - > -#define gpu_read_poll_timeout(iomem, reg, val, cond, delay_us, timeout_us) > \ > - read_poll_timeout(gpu_read, val, cond, delay_us, timeout_us, false, > \ > - iomem, reg) > - > -#define gpu_read_poll_timeout_atomic(iomem, reg, val, cond, delay_us, > \ > - timeout_us) > \ > - read_poll_timeout_atomic(gpu_read, val, cond, delay_us, timeout_us, > \ > - false, iomem, reg) > - > -#define gpu_read64_poll_timeout(iomem, reg, val, cond, delay_us, timeout_us) > \ > - read_poll_timeout(gpu_read64, val, cond, delay_us, timeout_us, false, > \ > - iomem, reg) > - > -#define gpu_read64_poll_timeout_atomic(iomem, reg, val, cond, delay_us, > \ > - timeout_us) > \ > - read_poll_timeout_atomic(gpu_read64, val, cond, delay_us, timeout_us, > \ > - false, iomem, reg) > - > -#define gpu_read_relaxed_poll_timeout_atomic(iomem, reg, val, cond, > delay_us, \ > - timeout_us) > \ > - read_poll_timeout_atomic(gpu_read_relaxed, val, cond, delay_us, > \ > - timeout_us, false, iomem, reg) > - > -#define gpu_read64_relaxed_poll_timeout(iomem, reg, val, cond, delay_us, > \ > - timeout_us) > \ > - read_poll_timeout(gpu_read64_relaxed, val, cond, delay_us, timeout_us, > \ > - false, iomem, reg) > - > #endif > diff --git a/drivers/gpu/drm/panthor/panthor_device_io.h > b/drivers/gpu/drm/panthor/panthor_device_io.h > new file mode 100644 > index 000000000000..54e206c6aaa5 > --- /dev/null > +++ b/drivers/gpu/drm/panthor/panthor_device_io.h > @@ -0,0 +1,81 @@ > +/* SPDX-License-Identifier: GPL-2.0 or MIT */ > +/* Copyright 2026 ARM Limited. All rights reserved. */ > + > +#ifndef __PANTHOR_DEVICE_IO_H__ > +#define __PANTHOR_DEVICE_IO_H__ > + > +#include <linux/atomic.h> > +#include <linux/io.h> > + > +static inline void gpu_write(void __iomem *iomem, u32 reg, u32 data) > +{ > + writel(data, iomem + reg); > +} > + > +static inline u32 gpu_read(void __iomem *iomem, u32 reg) > +{ > + return readl(iomem + reg); > +} > + > +static inline u32 gpu_read_relaxed(void __iomem *iomem, u32 reg) > +{ > + return readl_relaxed(iomem + reg); > +} > + > +static inline void gpu_write64(void __iomem *iomem, u32 reg, u64 data) > +{ > + gpu_write(iomem, reg, lower_32_bits(data)); > + gpu_write(iomem, reg + 4, upper_32_bits(data)); > +} > + > +static inline u64 gpu_read64(void __iomem *iomem, u32 reg) > +{ > + return (gpu_read(iomem, reg) | ((u64)gpu_read(iomem, reg + 4) << 32)); > +} > + > +static inline u64 gpu_read64_relaxed(void __iomem *iomem, u32 reg) > +{ > + return (gpu_read_relaxed(iomem, reg) | > + ((u64)gpu_read_relaxed(iomem, reg + 4) << 32)); > +} > + > +static inline u64 gpu_read64_counter(void __iomem *iomem, u32 reg) > +{ > + u32 lo, hi1, hi2; > + do { > + hi1 = gpu_read(iomem, reg + 4); > + lo = gpu_read(iomem, reg); > + hi2 = gpu_read(iomem, reg + 4); > + } while (hi1 != hi2); > + return lo | ((u64)hi2 << 32); > +} > + > +#define gpu_read_poll_timeout(iomem, reg, val, cond, delay_us, timeout_us) > \ > + read_poll_timeout(gpu_read, val, cond, delay_us, timeout_us, false, > \ > + iomem, reg) > + > +#define gpu_read_poll_timeout_atomic(iomem, reg, val, cond, delay_us, > \ > + timeout_us) > \ > + read_poll_timeout_atomic(gpu_read, val, cond, delay_us, timeout_us, > \ > + false, iomem, reg) > + > +#define gpu_read64_poll_timeout(iomem, reg, val, cond, delay_us, timeout_us) > \ > + read_poll_timeout(gpu_read64, val, cond, delay_us, timeout_us, false, > \ > + iomem, reg) > + > +#define gpu_read64_poll_timeout_atomic(iomem, reg, val, cond, delay_us, > \ > + timeout_us) > \ > + read_poll_timeout_atomic(gpu_read64, val, cond, delay_us, timeout_us, > \ > + false, iomem, reg) > + > +#define gpu_read_relaxed_poll_timeout_atomic(iomem, reg, val, cond, > delay_us, \ > + timeout_us) > \ > + read_poll_timeout_atomic(gpu_read_relaxed, val, cond, delay_us, > \ > + timeout_us, false, iomem, reg) > + > +#define gpu_read64_relaxed_poll_timeout(iomem, reg, val, cond, delay_us, > \ > + timeout_us) > \ > + read_poll_timeout(gpu_read64_relaxed, val, cond, delay_us, timeout_us, > \ > + false, iomem, reg) > + > +#endif /* __PANTHOR_DEVICE_IO_H__ */ > diff --git a/drivers/gpu/drm/panthor/panthor_fw.c > b/drivers/gpu/drm/panthor/panthor_fw.c > index 986151681b24..52f176644aa6 100644 > --- a/drivers/gpu/drm/panthor/panthor_fw.c > +++ b/drivers/gpu/drm/panthor/panthor_fw.c > @@ -19,6 +19,7 @@ > #include <drm/drm_print.h> > > #include "panthor_device.h" > +#include "panthor_device_io.h" > #include "panthor_fw.h" > #include "panthor_fw_regs.h" > #include "panthor_gem.h" > diff --git a/drivers/gpu/drm/panthor/panthor_gpu.c > b/drivers/gpu/drm/panthor/panthor_gpu.c > index e52c5675981f..b63a33fe155e 100644 > --- a/drivers/gpu/drm/panthor/panthor_gpu.c > +++ b/drivers/gpu/drm/panthor/panthor_gpu.c > @@ -18,6 +18,7 @@ > #include <drm/drm_print.h> > > #include "panthor_device.h" > +#include "panthor_device_io.h" > #include "panthor_gpu.h" > #include "panthor_gpu_regs.h" > #include "panthor_hw.h" > diff --git a/drivers/gpu/drm/panthor/panthor_hw.c > b/drivers/gpu/drm/panthor/panthor_hw.c > index 4c96573b649a..5cf54028f606 100644 > --- a/drivers/gpu/drm/panthor/panthor_hw.c > +++ b/drivers/gpu/drm/panthor/panthor_hw.c > @@ -7,6 +7,7 @@ > #include <drm/drm_print.h> > > #include "panthor_device.h" > +#include "panthor_device_io.h" > #include "panthor_gpu.h" > #include "panthor_gpu_regs.h" > #include "panthor_hw.h" > diff --git a/drivers/gpu/drm/panthor/panthor_mmu.c > b/drivers/gpu/drm/panthor/panthor_mmu.c > index 452d0b6d4668..48127313332f 100644 > --- a/drivers/gpu/drm/panthor/panthor_mmu.c > +++ b/drivers/gpu/drm/panthor/panthor_mmu.c > @@ -31,6 +31,7 @@ > #include <linux/sizes.h> > > #include "panthor_device.h" > +#include "panthor_device_io.h" > #include "panthor_gem.h" > #include "panthor_gpu.h" > #include "panthor_gpu_regs.h" > diff --git a/drivers/gpu/drm/panthor/panthor_pwr.c > b/drivers/gpu/drm/panthor/panthor_pwr.c > index 7c7f424a1436..1cba093a2452 100644 > --- a/drivers/gpu/drm/panthor/panthor_pwr.c > +++ b/drivers/gpu/drm/panthor/panthor_pwr.c > @@ -11,6 +11,7 @@ > #include <drm/drm_print.h> > > #include "panthor_device.h" > +#include "panthor_device_io.h" > #include "panthor_gpu_regs.h" > #include "panthor_hw.h" > #include "panthor_pwr.h"
