Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/arch/arm/sunxi Allow the graphic driver to be the kernel...



details:   https://anonhg.NetBSD.org/src/rev/7591ae863a6a
branches:  trunk
changeset: 360944:7591ae863a6a
user:      bouyer <bouyer%NetBSD.org@localhost>
date:      Sat Apr 07 18:09:33 2018 +0000

description:
Allow the graphic driver to be the kernel's console.
Match either from the allwinner,pipeline entry in the simple-framebuffer
fdt entry, or from console= from the command line.
console=fb0 and console=fb1 selects display backend unit 0 or 1 respectively;
console=fb selects the first activated display backend.

diffstat:

 sys/arch/arm/sunxi/sunxi_debe.c    |  101 +++++++++++++++++++++++++++++++-----
 sys/arch/arm/sunxi/sunxi_dep.c     |   21 +++++--
 sys/arch/arm/sunxi/sunxi_display.h |    3 +-
 sys/arch/arm/sunxi/sunxi_tcon.c    |   53 ++++++++++++++++++-
 4 files changed, 155 insertions(+), 23 deletions(-)

diffs (truncated from 331 to 300 lines):

diff -r 08dc6ae5dc16 -r 7591ae863a6a sys/arch/arm/sunxi/sunxi_debe.c
--- a/sys/arch/arm/sunxi/sunxi_debe.c   Sat Apr 07 18:06:27 2018 +0000
+++ b/sys/arch/arm/sunxi/sunxi_debe.c   Sat Apr 07 18:09:33 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: sunxi_debe.c,v 1.7 2018/04/05 10:21:39 jmcneill Exp $ */
+/* $NetBSD: sunxi_debe.c,v 1.8 2018/04/07 18:09:33 bouyer Exp $ */
 
 /*-
  * Copyright (c) 2018 Manuel Bouyer <bouyer%antioche.eu.org@localhost>
@@ -38,7 +38,7 @@
 #define SUNXI_DEBE_CURMAX      64
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: sunxi_debe.c,v 1.7 2018/04/05 10:21:39 jmcneill Exp $");
+__KERNEL_RCSID(0, "$NetBSD: sunxi_debe.c,v 1.8 2018/04/07 18:09:33 bouyer Exp $");
 
 #include <sys/param.h>
 #include <sys/bus.h>
@@ -58,6 +58,8 @@
 
 #include <arm/sunxi/sunxi_debereg.h>
 #include <arm/sunxi/sunxi_display.h>
+#include <arm/sunxi/sunxi_platform.h>
+#include <machine/bootconfig.h>
 
 enum sunxi_debe_type {
        DEBE_A10 = 1,
@@ -128,6 +130,9 @@
 static void    sunxi_befb_set_videomode(device_t, u_int, u_int);
 void sunxi_debe_dump_regs(int);
 
+static struct sunxi_debe_softc *debe_console_sc;
+static int sunxi_simplefb_phandle = -1;
+
 CFATTACH_DECL_NEW(sunxi_debe, sizeof(struct sunxi_debe_softc),
        sunxi_debe_match, sunxi_debe_attach, NULL, NULL);
 
@@ -242,8 +247,6 @@
        }
 }
 
-
-
 static void
 sunxi_debe_ep_connect(device_t self, struct fdt_endpoint *ep, bool connect)
 {
@@ -337,6 +340,32 @@
        const u_int fb_height = (mode->vdisplay << interlace_p);
 
        if (mode && sc->sc_fbdev == NULL) {
+               /* see if we are the console */
+               if (sunxi_simplefb_phandle >= 0) {
+                       const char *cons_pipeline =
+                           fdtbus_get_string(sunxi_simplefb_phandle,
+                               "allwinner,pipeline");
+                       struct fdt_endpoint *ep = fdt_endpoint_get_from_index(
+                           &sc->sc_ports, SUNXI_PORT_OUTPUT, sc->sc_unit);
+                       struct fdt_endpoint *rep = fdt_endpoint_remote(ep);
+                       if (sunxi_tcon_is_console(
+                           fdt_endpoint_device(rep), cons_pipeline))
+                               debe_console_sc = sc;
+               } else if (debe_console_sc == NULL) {
+                       if (match_bootconf_option(boot_args,
+                           "console", "fb0")) {
+                               if (sc->sc_unit == 0)
+                                       debe_console_sc = sc;
+                       } else if (match_bootconf_option(boot_args,
+                           "console", "fb1")) {
+                               if (sc->sc_unit == 1)
+                                       debe_console_sc = sc;
+                       } else if (match_bootconf_option(boot_args,
+                           "console", "fb")) {
+                               /* match first activated */
+                               debe_console_sc = sc;
+                       }
+               }
                struct sunxifb_attach_args afb = {
                        .afb_fb = sc->sc_dmap,
                        .afb_width = fb_width,
@@ -684,9 +713,6 @@
        prop_dictionary_t cfg = device_properties(self);
        struct genfb_ops ops;
 
-       if (sunxi_befb_consoledev == NULL)
-               sunxi_befb_consoledev = self;
-
        sc->sc_gen.sc_dev = self;
        sc->sc_debedev = parent;
        sc->sc_dmat = afb->afb_dmat;
@@ -716,14 +742,27 @@
 
        aprint_naive("\n");
 
-       bool is_console = false;
-       prop_dictionary_set_bool(cfg, "is_console", is_console);
-
+       bool is_console = (debe_console_sc == device_private(parent));
        if (is_console)
                aprint_normal(": switching to framebuffer console\n");
        else
                aprint_normal("\n");
 
+#ifdef WSDISPLAY_MULTICONS
+       /*
+        * if we support multicons, only the first framebuffer is console,
+        * unless we already know which framebuffer will be the console
+        */
+       if (!is_console && debe_console_sc == NULL &&
+           sunxi_befb_consoledev == NULL)
+               is_console = true;
+#endif
+       prop_dictionary_set_bool(cfg, "is_console", is_console);
+       if (is_console) {
+               KASSERT(sunxi_befb_consoledev == NULL);
+               sunxi_befb_consoledev = self;
+       }
+
        genfb_attach(&sc->sc_gen, &ops);
 }
 
@@ -829,13 +868,47 @@
                return ENODEV;
        }
        error = fdt_endpoint_activate(ep, true);
-       if (error == 0) {
-               sc->sc_out_ep = ep;
-               fdt_endpoint_enable(ep, true);
-       }
+       if (error)
+               return error;
+
+       sc->sc_out_ep = ep;
+       error = fdt_endpoint_enable(ep, true);
        return error;
 }
 
+/*
+ * we don't want to take over console at this time - simplefb will
+ * do a better job than us. We will take over later.
+ * But we want to record the /chose/framebuffer phandle if there is one
+ */
+
+static const char * const simplefb_compatible[] = {
+       "allwinner,simple-framebuffer",
+       NULL
+};
+
+static int
+sunxidebe_console_match(int phandle)
+{
+       if (of_match_compatible(phandle, simplefb_compatible)) {
+               sunxi_simplefb_phandle = phandle;
+       }
+       return 0;
+}
+
+static void
+sunxidebe_console_consinit(struct fdt_attach_args *faa, u_int uart_freq)
+{
+       panic("sunxidebe_console_consinit");
+}
+
+static const struct fdt_console sunxidebe_fdt_console = {
+       .match = sunxidebe_console_match,
+       .consinit = sunxidebe_console_consinit
+};
+
+FDT_CONSOLE(sunxidebe, &sunxidebe_fdt_console);
+
 #if defined(SUNXI_DEBE_DEBUG)
 void
 sunxi_debe_dump_regs(int u)
diff -r 08dc6ae5dc16 -r 7591ae863a6a sys/arch/arm/sunxi/sunxi_dep.c
--- a/sys/arch/arm/sunxi/sunxi_dep.c    Sat Apr 07 18:06:27 2018 +0000
+++ b/sys/arch/arm/sunxi/sunxi_dep.c    Sat Apr 07 18:09:33 2018 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: sunxi_dep.c,v 1.2 2018/04/03 13:38:13 bouyer Exp $     */
+/*     $NetBSD: sunxi_dep.c,v 1.3 2018/04/07 18:09:33 bouyer Exp $     */
 
 /*-
  * Copyright (c) 2018 The NetBSD Foundation, Inc.
@@ -32,7 +32,7 @@
 
 #include <sys/cdefs.h>
 
-__KERNEL_RCSID(1, "$NetBSD: sunxi_dep.c,v 1.2 2018/04/03 13:38:13 bouyer Exp $");
+__KERNEL_RCSID(1, "$NetBSD: sunxi_dep.c,v 1.3 2018/04/07 18:09:33 bouyer Exp $");
 
 #include <sys/param.h>
 #include <sys/bus.h>
@@ -57,6 +57,11 @@
        {NULL}
 };
 
+static const char *fb_compat[] = {
+       "allwinner,simple-framebuffer",
+       NULL
+};
+
 static int sunxi_dep_match(device_t, cfdata_t, void *);
 static void sunxi_dep_attach(device_t, device_t, void *);
 
@@ -68,9 +73,8 @@
 {
 #if NSUNXI_DEBE > 0
        struct fdt_attach_args * const faa = aux;
-       if (!of_match_compat_data(faa->faa_phandle, compat_data))
-               return 0;
-       return 1;
+
+       return  of_match_compat_data(faa->faa_phandle, compat_data);
 #else
        return 0;
 #endif
@@ -82,6 +86,7 @@
        struct sunxi_dep_softc * const sc = device_private(self);
        struct fdt_attach_args * const faa = aux;
        const int phandle = faa->faa_phandle;
+       int sunxi_dep_npipelines = 0;
        int len;
        const u_int *buf;
        u_int ref;
@@ -95,7 +100,6 @@
                aprint_error("bad/missing allwinner,pipelines property\n");
                return;
        }
-       aprint_naive("\n");
        aprint_normal(": ");
 #if NSUNXI_DEBE > 0
        for (int i = 0; i < (len / sizeof(ref)); i++) {
@@ -106,7 +110,12 @@
                    fdtbus_get_phandle_from_native(ref), true);
                if (error)
                        aprint_error("can't activate pipeline %d\n", i);
+               else
+                       sunxi_dep_npipelines++;
        }
+       aprint_naive("\n");
+       if (sunxi_dep_npipelines > 0)
+               fdt_remove_bycompat(fb_compat);
 #else
        aprint_error("debe not configured\n");
        return;
diff -r 08dc6ae5dc16 -r 7591ae863a6a sys/arch/arm/sunxi/sunxi_display.h
--- a/sys/arch/arm/sunxi/sunxi_display.h        Sat Apr 07 18:06:27 2018 +0000
+++ b/sys/arch/arm/sunxi/sunxi_display.h        Sat Apr 07 18:09:33 2018 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: sunxi_display.h,v 1.1 2018/04/03 12:52:16 bouyer Exp $ */
+/*     $NetBSD: sunxi_display.h,v 1.2 2018/04/07 18:09:33 bouyer Exp $ */
 
 /*-
  * Copyright (c) 2018 The NetBSD Foundation, Inc.
@@ -37,3 +37,4 @@
 int sunxi_debe_pipeline(int, bool);
 void sunxi_tcon1_set_videomode(device_t, const struct videomode *);
 void sunxi_debe_set_videomode(device_t, const struct videomode *);
+bool sunxi_tcon_is_console(device_t, const char *);
diff -r 08dc6ae5dc16 -r 7591ae863a6a sys/arch/arm/sunxi/sunxi_tcon.c
--- a/sys/arch/arm/sunxi/sunxi_tcon.c   Sat Apr 07 18:06:27 2018 +0000
+++ b/sys/arch/arm/sunxi/sunxi_tcon.c   Sat Apr 07 18:09:33 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: sunxi_tcon.c,v 1.5 2018/04/06 08:23:40 bouyer Exp $ */
+/* $NetBSD: sunxi_tcon.c,v 1.6 2018/04/07 18:09:33 bouyer Exp $ */
 
 /*-
  * Copyright (c) 2018 Manuel Bouyer <bouyer%antioche.eu.org@localhost>
@@ -30,7 +30,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: sunxi_tcon.c,v 1.5 2018/04/06 08:23:40 bouyer Exp $");
+__KERNEL_RCSID(0, "$NetBSD: sunxi_tcon.c,v 1.6 2018/04/07 18:09:33 bouyer Exp $");
 
 #include <sys/param.h>
 #include <sys/bus.h>
@@ -812,6 +812,55 @@
        }
 }
 
+/* check if this tcon is the console chosen by firmare */
+bool
+sunxi_tcon_is_console(device_t dev, const char *pipeline)
+{
+       struct sunxi_tcon_softc *sc = device_private(dev);
+       char p[64];
+       char *e, *n = p;
+       bool is_console = false;
+
+       KASSERT(device_is_a(dev, "sunxitcon"));
+       strncpy(p, pipeline, sizeof(p) - 1);
+       p[sizeof(p) - 1] = '\0';
+
+       /*
+        * pipeline is like "de_be0-lcd0-hdmi"
+        * of "de_be0-lcd1".
+        * In the first case check output type
+        * In the second check tcon unit number
+        */
+        n = p;
+        e = strsep(&n, "-");



Home | Main Index | Thread Index | Old Index