On Fri, Mar 23, 2018 at 12:49:47PM +0530, Sharat Masetty wrote: > The register read-modify-write construct is generic enough > that it can be used by other subsystems as needed, create > a more generic rmw() function and have the gpu_rmw() use > this new function. Reviewed-by: Jordan Crouse <jcrouse@xxxxxxxxxxxxxx> > Signed-off-by: Sharat Masetty <smasetty@xxxxxxxxxxxxxx> > --- > drivers/gpu/drm/msm/msm_drv.c | 8 ++++++++ > drivers/gpu/drm/msm/msm_drv.h | 1 + > drivers/gpu/drm/msm/msm_gpu.h | 5 +---- > 3 files changed, 10 insertions(+), 4 deletions(-) > > diff --git a/drivers/gpu/drm/msm/msm_drv.c b/drivers/gpu/drm/msm/msm_drv.c > index fbad854..a08b7d2 100644 > --- a/drivers/gpu/drm/msm/msm_drv.c > +++ b/drivers/gpu/drm/msm/msm_drv.c > @@ -149,6 +149,14 @@ u32 msm_readl(const void __iomem *addr) > return val; > } > > +void msm_rmw(void __iomem *addr, u32 mask, u32 or) > +{ > + u32 val = msm_readl(addr); > + > + val &= ~mask; > + msm_writel(val | or, addr); > +} > + > struct vblank_event { > struct list_head node; > int crtc_id; > diff --git a/drivers/gpu/drm/msm/msm_drv.h b/drivers/gpu/drm/msm/msm_drv.h > index 0a653dd..7e71354 100644 > --- a/drivers/gpu/drm/msm/msm_drv.h > +++ b/drivers/gpu/drm/msm/msm_drv.h > @@ -314,6 +314,7 @@ void __iomem *msm_ioremap(struct platform_device *pdev, const char *name, > const char *dbgname); > void msm_writel(u32 data, void __iomem *addr); > u32 msm_readl(const void __iomem *addr); > +void msm_rmw(void __iomem *addr, u32 mask, u32 or); > > struct msm_gpu_submitqueue; > int msm_submitqueue_init(struct drm_device *drm, struct msm_file_private *ctx); > diff --git a/drivers/gpu/drm/msm/msm_gpu.h b/drivers/gpu/drm/msm/msm_gpu.h > index b9b86ef..96058d2 100644 > --- a/drivers/gpu/drm/msm/msm_gpu.h > +++ b/drivers/gpu/drm/msm/msm_gpu.h > @@ -194,10 +194,7 @@ static inline u32 gpu_read(struct msm_gpu *gpu, u32 reg) > > static inline void gpu_rmw(struct msm_gpu *gpu, u32 reg, u32 mask, u32 or) > { > - uint32_t val = gpu_read(gpu, reg); > - > - val &= ~mask; > - gpu_write(gpu, reg, val | or); > + msm_rmw(gpu->mmio + (reg << 2), mask, or); > } > > static inline u64 gpu_read64(struct msm_gpu *gpu, u32 lo, u32 hi) > -- > 1.9.1 > > _______________________________________________ > Freedreno mailing list > Freedreno@xxxxxxxxxxxxxxxxxxxxx > https://lists.freedesktop.org/mailman/listinfo/freedreno -- The Qualcomm Innovation Center, Inc. is a member of Code Aurora Forum, a Linux Foundation Collaborative Project _______________________________________________ dri-devel mailing list dri-devel@xxxxxxxxxxxxxxxxxxxxx https://lists.freedesktop.org/mailman/listinfo/dri-devel