]> www.infradead.org Git - users/jedix/linux-maple.git/commitdiff
drm/mgag200: Store pointer to struct mga_device in struct mga_i2c_chan
authorThomas Zimmermann <tzimmermann@suse.de>
Mon, 13 May 2024 12:51:08 +0000 (14:51 +0200)
committerThomas Zimmermann <tzimmermann@suse.de>
Fri, 17 May 2024 15:20:05 +0000 (17:20 +0200)
Avoid upcasting to struct mga_device in i2c code by storing the
pointer directly. No functional changes.

Signed-off-by: Thomas Zimmermann <tzimmermann@suse.de>
Reviewed-by: Jocelyn Falempe <jfalempe@redhat.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20240513125620.6337-4-tzimmermann@suse.de
drivers/gpu/drm/mgag200/mgag200_drv.h
drivers/gpu/drm/mgag200/mgag200_i2c.c

index 58a0e62eaf183c924b251e411e3f4ff93de9fabb..c7d4047301bfb6f7b12f0e750a023e87acd0dc48 100644 (file)
@@ -191,7 +191,7 @@ static inline struct mgag200_crtc_state *to_mgag200_crtc_state(struct drm_crtc_s
 
 struct mga_i2c_chan {
        struct i2c_adapter adapter;
-       struct drm_device *dev;
+       struct mga_device *mdev;
        struct i2c_algo_bit_data bit;
        int data, clock;
 };
index 4caeb68f3010c92a48759efbc944f83255864a59..effd7c057fce00be6107d13e7417a73ee36bae36 100644 (file)
@@ -63,29 +63,29 @@ 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 = to_mga_device(i2c->dev);
-       mga_i2c_set(mdev, i2c->data, state);
+
+       mga_i2c_set(i2c->mdev, i2c->data, state);
 }
 
 static void mga_gpio_setscl(void *data, int state)
 {
        struct mga_i2c_chan *i2c = data;
-       struct mga_device *mdev = to_mga_device(i2c->dev);
-       mga_i2c_set(mdev, i2c->clock, state);
+
+       mga_i2c_set(i2c->mdev, i2c->clock, state);
 }
 
 static int mga_gpio_getsda(void *data)
 {
        struct mga_i2c_chan *i2c = data;
-       struct mga_device *mdev = to_mga_device(i2c->dev);
-       return (mga_i2c_read_gpio(mdev) & i2c->data) ? 1 : 0;
+
+       return (mga_i2c_read_gpio(i2c->mdev) & i2c->data) ? 1 : 0;
 }
 
 static int mga_gpio_getscl(void *data)
 {
        struct mga_i2c_chan *i2c = data;
-       struct mga_device *mdev = to_mga_device(i2c->dev);
-       return (mga_i2c_read_gpio(mdev) & i2c->clock) ? 1 : 0;
+
+       return (mga_i2c_read_gpio(i2c->mdev) & i2c->clock) ? 1 : 0;
 }
 
 static void mgag200_i2c_release(struct drm_device *dev, void *res)
@@ -109,7 +109,7 @@ int mgag200_i2c_init(struct mga_device *mdev, struct mga_i2c_chan *i2c)
        i2c->clock = BIT(info->i2c.clock_bit);
        i2c->adapter.owner = THIS_MODULE;
        i2c->adapter.dev.parent = dev->dev;
-       i2c->dev = dev;
+       i2c->mdev = mdev;
        i2c_set_adapdata(&i2c->adapter, i2c);
        snprintf(i2c->adapter.name, sizeof(i2c->adapter.name), "mga i2c");