drm/ast: Pass AST device to ast_ddc_create()
authorThomas Zimmermann <tzimmermann@suse.de>
Mon, 25 Mar 2024 20:06:52 +0000 (21:06 +0100)
committerThomas Zimmermann <tzimmermann@suse.de>
Tue, 2 Apr 2024 08:40:48 +0000 (10:40 +0200)
The DDC code needs the AST device. Pass it to ast_ddc_create() and
avoid an internal upcast. Improves type safety within the DDC code.

Signed-off-by: Thomas Zimmermann <tzimmermann@suse.de>
Reviewed-by: Sui Jingfeng <sui.jingfeng@linux.dev>
Reviewed-by: Jocelyn Falempe <jfalempe@redhat.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20240325200855.21150-8-tzimmermann@suse.de
drivers/gpu/drm/ast/ast_ddc.c
drivers/gpu/drm/ast/ast_ddc.h
drivers/gpu/drm/ast/ast_mode.c

index c0e5d03c028d8eccde219a2f6c2e815d45e08422..24b7d589f0d4cefbfd5cd055ebc74ba9f3515cc4 100644 (file)
@@ -110,8 +110,9 @@ static void ast_ddc_release(struct drm_device *dev, void *res)
        i2c_del_adapter(&ddc->adapter);
 }
 
-struct ast_ddc *ast_ddc_create(struct drm_device *dev)
+struct ast_ddc *ast_ddc_create(struct ast_device *ast)
 {
+       struct drm_device *dev = &ast->base;
        struct ast_ddc *ddc;
        struct i2c_adapter *adapter;
        struct i2c_algo_bit_data *bit;
index 071f9be3e27def26f3b20a9c8c0a52596e68b6fa..d423b144a3458c8f91a06f8fd96dcab6f282b257 100644 (file)
@@ -6,6 +6,7 @@
 #include <linux/i2c.h>
 #include <linux/i2c-algo-bit.h>
 
+struct ast_device;
 struct drm_device;
 
 struct ast_ddc {
@@ -14,6 +15,6 @@ struct ast_ddc {
        struct i2c_algo_bit_data bit;
 };
 
-struct ast_ddc *ast_ddc_create(struct drm_device *dev);
+struct ast_ddc *ast_ddc_create(struct ast_device *ast);
 
 #endif
index 40cb495acc908aacfa77070c6c6cf178037e8c4c..fc73d3b65b2a1133573190ce03a5d2cd685c6fc1 100644 (file)
@@ -1388,10 +1388,11 @@ static const struct drm_connector_funcs ast_vga_connector_funcs = {
 
 static int ast_vga_connector_init(struct drm_device *dev, struct drm_connector *connector)
 {
+       struct ast_device *ast = to_ast_device(dev);
        struct ast_ddc *ddc;
        int ret;
 
-       ddc = ast_ddc_create(dev);
+       ddc = ast_ddc_create(ast);
        if (IS_ERR(ddc)) {
                ret = PTR_ERR(ddc);
                drm_err(dev, "failed to add DDC bus for connector; ret=%d\n", ret);
@@ -1485,10 +1486,11 @@ static const struct drm_connector_funcs ast_sil164_connector_funcs = {
 
 static int ast_sil164_connector_init(struct drm_device *dev, struct drm_connector *connector)
 {
+       struct ast_device *ast = to_ast_device(dev);
        struct ast_ddc *ddc;
        int ret;
 
-       ddc = ast_ddc_create(dev);
+       ddc = ast_ddc_create(ast);
        if (IS_ERR(ddc)) {
                ret = PTR_ERR(ddc);
                drm_err(dev, "failed to add DDC bus for connector; ret=%d\n", ret);