[PATCH 1/5] drm/mgag200: Convert struct drm_device to struct mga_device with macro
Sam Ravnborg
sam at ravnborg.org
Tue May 5 16:36:29 UTC 2020
Hi Thomas.
On Tue, May 05, 2020 at 11:56:45AM +0200, Thomas Zimmermann wrote:
> Mgag200 used dev_private to look up struct mga_device for instances
> of struct drm_device. Use of dev_private is deprecated, so hide it in
> the macro to_mga_device().
>
> Signed-off-by: Thomas Zimmermann <tzimmermann at suse.de>
Reviewed-by: Sam Ravnborg <sam at ravnborg.org>
But one nit below.
Sam
> ---
> drivers/gpu/drm/mgag200/mgag200_cursor.c | 4 ++--
> drivers/gpu/drm/mgag200/mgag200_drv.c | 2 +-
> drivers/gpu/drm/mgag200/mgag200_drv.h | 1 +
> drivers/gpu/drm/mgag200/mgag200_i2c.c | 10 +++++-----
> drivers/gpu/drm/mgag200/mgag200_main.c | 4 ++--
> drivers/gpu/drm/mgag200/mgag200_mode.c | 18 +++++++++---------
> 6 files changed, 20 insertions(+), 19 deletions(-)
>
> diff --git a/drivers/gpu/drm/mgag200/mgag200_cursor.c b/drivers/gpu/drm/mgag200/mgag200_cursor.c
> index d491edd317ff3..aebc9ce43d551 100644
> --- a/drivers/gpu/drm/mgag200/mgag200_cursor.c
> +++ b/drivers/gpu/drm/mgag200/mgag200_cursor.c
> @@ -260,7 +260,7 @@ int mgag200_crtc_cursor_set(struct drm_crtc *crtc, struct drm_file *file_priv,
> uint32_t handle, uint32_t width, uint32_t height)
> {
> struct drm_device *dev = crtc->dev;
> - struct mga_device *mdev = (struct mga_device *)dev->dev_private;
> + struct mga_device *mdev = to_mga_device(dev);
> struct drm_gem_object *obj;
> struct drm_gem_vram_object *gbo = NULL;
> int ret;
> @@ -307,7 +307,7 @@ int mgag200_crtc_cursor_set(struct drm_crtc *crtc, struct drm_file *file_priv,
>
> int mgag200_crtc_cursor_move(struct drm_crtc *crtc, int x, int y)
> {
> - struct mga_device *mdev = (struct mga_device *)crtc->dev->dev_private;
> + struct mga_device *mdev = to_mga_device(crtc->dev);
>
> /* Our origin is at (64,64) */
> x += 64;
> diff --git a/drivers/gpu/drm/mgag200/mgag200_drv.c b/drivers/gpu/drm/mgag200/mgag200_drv.c
> index 3298b7ef18b03..c2f0e4b40b052 100644
> --- a/drivers/gpu/drm/mgag200/mgag200_drv.c
> +++ b/drivers/gpu/drm/mgag200/mgag200_drv.c
> @@ -120,7 +120,7 @@ int mgag200_driver_dumb_create(struct drm_file *file,
> struct drm_device *dev,
> struct drm_mode_create_dumb *args)
> {
> - struct mga_device *mdev = dev->dev_private;
> + struct mga_device *mdev = to_mga_device(dev);
> unsigned long pg_align;
>
> if (WARN_ONCE(!dev->vram_mm, "VRAM MM not initialized"))
> diff --git a/drivers/gpu/drm/mgag200/mgag200_drv.h b/drivers/gpu/drm/mgag200/mgag200_drv.h
> index 9691252d6233f..632bbb50465c9 100644
> --- a/drivers/gpu/drm/mgag200/mgag200_drv.h
> +++ b/drivers/gpu/drm/mgag200/mgag200_drv.h
> @@ -96,6 +96,7 @@
>
> #define to_mga_crtc(x) container_of(x, struct mga_crtc, base)
> #define to_mga_connector(x) container_of(x, struct mga_connector, base)
> +#define to_mga_device(x) ((struct mga_device *)(x)->dev_private)
A inline function would have been better, as this provide no typecheck.
But we assume that it is always a drm_device *.
We would most likely catch it as no one else has a ->dev_prvate.
>
> struct mga_crtc {
> struct drm_crtc base;
> diff --git a/drivers/gpu/drm/mgag200/mgag200_i2c.c b/drivers/gpu/drm/mgag200/mgag200_i2c.c
> index 9f4635916d322..09731e614e46d 100644
> --- a/drivers/gpu/drm/mgag200/mgag200_i2c.c
> +++ b/drivers/gpu/drm/mgag200/mgag200_i2c.c
> @@ -61,34 +61,34 @@ static inline void mga_i2c_set(struct mga_device *mdev, int mask, int state)
> static void mga_gpio_setsda(void *data, int state)
> {
> struct mga_i2c_chan *i2c = data;
> - struct mga_device *mdev = i2c->dev->dev_private;
> + struct mga_device *mdev = to_mga_device(i2c->dev);
> mga_i2c_set(mdev, i2c->data, state);
> }
>
> static void mga_gpio_setscl(void *data, int state)
> {
> struct mga_i2c_chan *i2c = data;
> - struct mga_device *mdev = i2c->dev->dev_private;
> + struct mga_device *mdev = to_mga_device(i2c->dev);
> mga_i2c_set(mdev, i2c->clock, state);
> }
>
> static int mga_gpio_getsda(void *data)
> {
> struct mga_i2c_chan *i2c = data;
> - struct mga_device *mdev = i2c->dev->dev_private;
> + struct mga_device *mdev = to_mga_device(i2c->dev);
> return (mga_i2c_read_gpio(mdev) & i2c->data) ? 1 : 0;
> }
>
> static int mga_gpio_getscl(void *data)
> {
> struct mga_i2c_chan *i2c = data;
> - struct mga_device *mdev = i2c->dev->dev_private;
> + struct mga_device *mdev = to_mga_device(i2c->dev);
> return (mga_i2c_read_gpio(mdev) & i2c->clock) ? 1 : 0;
> }
>
> struct mga_i2c_chan *mgag200_i2c_create(struct drm_device *dev)
> {
> - struct mga_device *mdev = dev->dev_private;
> + struct mga_device *mdev = to_mga_device(dev);
> struct mga_i2c_chan *i2c;
> int ret;
> int data, clock;
> diff --git a/drivers/gpu/drm/mgag200/mgag200_main.c b/drivers/gpu/drm/mgag200/mgag200_main.c
> index b680cf47cbb94..b705b7776d2fc 100644
> --- a/drivers/gpu/drm/mgag200/mgag200_main.c
> +++ b/drivers/gpu/drm/mgag200/mgag200_main.c
> @@ -92,7 +92,7 @@ static int mga_vram_init(struct mga_device *mdev)
> static int mgag200_device_init(struct drm_device *dev,
> uint32_t flags)
> {
> - struct mga_device *mdev = dev->dev_private;
> + struct mga_device *mdev = to_mga_device(dev);
> int ret, option;
>
> mdev->flags = mgag200_flags_from_driver_data(flags);
> @@ -195,7 +195,7 @@ int mgag200_driver_load(struct drm_device *dev, unsigned long flags)
>
> void mgag200_driver_unload(struct drm_device *dev)
> {
> - struct mga_device *mdev = dev->dev_private;
> + struct mga_device *mdev = to_mga_device(dev);
>
> if (mdev == NULL)
> return;
> diff --git a/drivers/gpu/drm/mgag200/mgag200_mode.c b/drivers/gpu/drm/mgag200/mgag200_mode.c
> index d90e83959fca1..fa91869c0db52 100644
> --- a/drivers/gpu/drm/mgag200/mgag200_mode.c
> +++ b/drivers/gpu/drm/mgag200/mgag200_mode.c
> @@ -28,7 +28,7 @@
> static void mga_crtc_load_lut(struct drm_crtc *crtc)
> {
> struct drm_device *dev = crtc->dev;
> - struct mga_device *mdev = dev->dev_private;
> + struct mga_device *mdev = to_mga_device(dev);
> struct drm_framebuffer *fb = crtc->primary->fb;
> u16 *r_ptr, *g_ptr, *b_ptr;
> int i;
> @@ -728,7 +728,7 @@ static int mga_crtc_set_plls(struct mga_device *mdev, long clock)
>
> static void mga_g200wb_prepare(struct drm_crtc *crtc)
> {
> - struct mga_device *mdev = crtc->dev->dev_private;
> + struct mga_device *mdev = to_mga_device(crtc->dev);
> u8 tmp;
> int iter_max;
>
> @@ -783,7 +783,7 @@ static void mga_g200wb_prepare(struct drm_crtc *crtc)
> static void mga_g200wb_commit(struct drm_crtc *crtc)
> {
> u8 tmp;
> - struct mga_device *mdev = crtc->dev->dev_private;
> + struct mga_device *mdev = to_mga_device(crtc->dev);
>
> /* 1- The first step is to ensure that the vrsten and hrsten are set */
> WREG8(MGAREG_CRTCEXT_INDEX, 1);
> @@ -833,7 +833,7 @@ static void mga_g200wb_commit(struct drm_crtc *crtc)
> */
> static void mga_set_start_address(struct drm_crtc *crtc, unsigned offset)
> {
> - struct mga_device *mdev = crtc->dev->dev_private;
> + struct mga_device *mdev = to_mga_device(crtc->dev);
> u32 addr;
> int count;
> u8 crtcext0;
> @@ -902,7 +902,7 @@ static int mga_crtc_mode_set(struct drm_crtc *crtc,
> int x, int y, struct drm_framebuffer *old_fb)
> {
> struct drm_device *dev = crtc->dev;
> - struct mga_device *mdev = dev->dev_private;
> + struct mga_device *mdev = to_mga_device(dev);
> const struct drm_framebuffer *fb = crtc->primary->fb;
> int hdisplay, hsyncstart, hsyncend, htotal;
> int vdisplay, vsyncstart, vsyncend, vtotal;
> @@ -1263,7 +1263,7 @@ static int mga_resume(struct drm_crtc *crtc)
> static void mga_crtc_dpms(struct drm_crtc *crtc, int mode)
> {
> struct drm_device *dev = crtc->dev;
> - struct mga_device *mdev = dev->dev_private;
> + struct mga_device *mdev = to_mga_device(dev);
> u8 seq1 = 0, crtcext1 = 0;
>
> switch (mode) {
> @@ -1317,7 +1317,7 @@ static void mga_crtc_dpms(struct drm_crtc *crtc, int mode)
> static void mga_crtc_prepare(struct drm_crtc *crtc)
> {
> struct drm_device *dev = crtc->dev;
> - struct mga_device *mdev = dev->dev_private;
> + struct mga_device *mdev = to_mga_device(dev);
> u8 tmp;
>
> /* mga_resume(crtc);*/
> @@ -1353,7 +1353,7 @@ static void mga_crtc_prepare(struct drm_crtc *crtc)
> static void mga_crtc_commit(struct drm_crtc *crtc)
> {
> struct drm_device *dev = crtc->dev;
> - struct mga_device *mdev = dev->dev_private;
> + struct mga_device *mdev = to_mga_device(dev);
> const struct drm_crtc_helper_funcs *crtc_funcs = crtc->helper_private;
> u8 tmp;
>
> @@ -1495,7 +1495,7 @@ static enum drm_mode_status mga_vga_mode_valid(struct drm_connector *connector,
> struct drm_display_mode *mode)
> {
> struct drm_device *dev = connector->dev;
> - struct mga_device *mdev = (struct mga_device*)dev->dev_private;
> + struct mga_device *mdev = to_mga_device(dev);
> int bpp = 32;
>
> if (IS_G200_SE(mdev)) {
> --
> 2.26.0
More information about the dri-devel
mailing list