This adds a pointer to the base framebuffer to struct fb_info
in case the framebuffer is an overlay. As overlays do not have modes,
accept them in fb_enable() even when it doesn't have a mode.

Signed-off-by: Sascha Hauer <s.ha...@pengutronix.de>
---
 drivers/video/fb.c | 20 ++++++++++++++------
 include/fb.h       |  3 +++
 2 files changed, 17 insertions(+), 6 deletions(-)

diff --git a/drivers/video/fb.c b/drivers/video/fb.c
index a752c114e2..ccc755322e 100644
--- a/drivers/video/fb.c
+++ b/drivers/video/fb.c
@@ -138,7 +138,7 @@ static int fb_enable_set(struct param_d *param, void *priv)
 {
        struct fb_info *info = priv;
 
-       if (!info->mode)
+       if (!info->mode && !info->base_plane)
                return -EINVAL;
 
        if (info->p_enable)
@@ -284,7 +284,7 @@ static int fb_set_shadowfb(struct param_d *p, void *priv)
 
 int register_framebuffer(struct fb_info *info)
 {
-       int id = get_free_deviceid("fb");
+       int id;
        struct device *dev;
        int ret, num_modes, i;
        const char **names;
@@ -304,7 +304,18 @@ int register_framebuffer(struct fb_info *info)
                info->line_length = info->xres * (info->bits_per_pixel >> 3);
 
        info->cdev.ops = &fb_ops;
-       info->cdev.name = basprintf("fb%d", id);
+       if (info->base_plane) {
+               int ovl_id = info->base_plane->n_overlays++;
+
+               info->cdev.name = basprintf("%s_%d", 
dev_name(&info->base_plane->dev), ovl_id);
+               dev->id = DEVICE_ID_SINGLE;
+               dev_set_name(dev, info->cdev.name);
+       } else {
+               id = get_free_deviceid("fb");
+               dev->id = id;
+               dev_set_name(dev, "fb");
+               info->cdev.name = basprintf("fb%d", id);
+       }
        info->cdev.size = info->line_length * info->yres;
        info->cdev.dev = dev;
        info->cdev.priv = info;
@@ -315,11 +326,8 @@ int register_framebuffer(struct fb_info *info)
        dev->num_resources = 1;
 
        dev->priv = info;
-       dev->id = id;
        dev->info = fb_info;
 
-       dev_set_name(dev, "fb");
-
        ret = register_device(&info->dev);
        if (ret)
                goto err_free;
diff --git a/include/fb.h b/include/fb.h
index 574a66a396..76f0c99449 100644
--- a/include/fb.h
+++ b/include/fb.h
@@ -175,6 +175,9 @@ struct fb_info {
                                         * be created.
                                         */
        int shadowfb;
+
+       struct fb_info *base_plane;
+       int n_overlays;
 };
 
 int of_get_display_timing(const struct device_node *np, const char *name,

-- 
2.39.5


Reply via email to