drm/sun4i: use sun4i_tcon_of_table to check if a device node is a TCON
authorChen-Yu Tsai <wens@csie.org>
Mon, 27 Nov 2017 08:46:32 +0000 (16:46 +0800)
committerMaxime Ripard <maxime.ripard@free-electrons.com>
Thu, 30 Nov 2017 15:46:05 +0000 (16:46 +0100)
The sun4i DRM driver maintains a list of compatible strings it uses to
check if a device node within the display component graph is a TCON.
The TCON driver also has this list, used to bind the TCON driver to
the device. These two lists are identical.

Instead of maintaining two identical lists, export the list from the
TCON driver for the DRM driver to use.

Suggested-by: Rob Herring <robh@kernel.org>
Signed-off-by: Chen-Yu Tsai <wens@csie.org>
Signed-off-by: Maxime Ripard <maxime.ripard@free-electrons.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20171127084632.25511-1-wens@csie.org
drivers/gpu/drm/sun4i/sun4i_drv.c
drivers/gpu/drm/sun4i/sun4i_tcon.c
drivers/gpu/drm/sun4i/sun4i_tcon.h

index 75c76cdd82bc6e15fcae27aa33fe165f420c381b..49215d91c853892ef25a4a66a8c7aaba8efc0ff1 100644 (file)
@@ -187,13 +187,7 @@ static bool sun4i_drv_node_is_frontend(struct device_node *node)
 
 static bool sun4i_drv_node_is_tcon(struct device_node *node)
 {
-       return of_device_is_compatible(node, "allwinner,sun4i-a10-tcon") ||
-               of_device_is_compatible(node, "allwinner,sun5i-a13-tcon") ||
-               of_device_is_compatible(node, "allwinner,sun6i-a31-tcon") ||
-               of_device_is_compatible(node, "allwinner,sun6i-a31s-tcon") ||
-               of_device_is_compatible(node, "allwinner,sun7i-a20-tcon") ||
-               of_device_is_compatible(node, "allwinner,sun8i-a33-tcon") ||
-               of_device_is_compatible(node, "allwinner,sun8i-v3s-tcon");
+       return !!of_match_node(sun4i_tcon_of_table, node);
 }
 
 static int compare_of(struct device *dev, void *data)
index e122f5b2a395583cc14302a9bc4166fbba671071..a1ed462c24307b8b79eea334efdab6a5a17027a2 100644 (file)
@@ -900,7 +900,8 @@ static const struct sun4i_tcon_quirks sun8i_v3s_quirks = {
        /* nothing is supported */
 };
 
-static const struct of_device_id sun4i_tcon_of_table[] = {
+/* sun4i_drv uses this list to check if a device node is a TCON */
+const struct of_device_id sun4i_tcon_of_table[] = {
        { .compatible = "allwinner,sun4i-a10-tcon", .data = &sun4i_a10_quirks },
        { .compatible = "allwinner,sun5i-a13-tcon", .data = &sun5i_a13_quirks },
        { .compatible = "allwinner,sun6i-a31-tcon", .data = &sun6i_a31_quirks },
@@ -911,6 +912,7 @@ static const struct of_device_id sun4i_tcon_of_table[] = {
        { }
 };
 MODULE_DEVICE_TABLE(of, sun4i_tcon_of_table);
+EXPORT_SYMBOL(sun4i_tcon_of_table);
 
 static struct platform_driver sun4i_tcon_platform_driver = {
        .probe          = sun4i_tcon_probe,
index f61bf6d83b4a04f45e8d8c2be4f6b4615bd1e8e0..839266a3850590badb9cdfbb375c9d02ec03a24d 100644 (file)
@@ -197,4 +197,6 @@ void sun4i_tcon_mode_set(struct sun4i_tcon *tcon,
 void sun4i_tcon_set_status(struct sun4i_tcon *crtc,
                           const struct drm_encoder *encoder, bool enable);
 
+extern const struct of_device_id sun4i_tcon_of_table[];
+
 #endif /* __SUN4I_TCON_H__ */