[PATCH 00/19] drm: Add Allwinner A10 display engine support

From: Maxime Ripard
Date: Fri Oct 30 2015 - 10:21:16 EST


Hi everyone,

The Allwinner SoCs (except for the very latest ones) all share the
same set of controllers, loosely coupled together to form the display
pipeline.

Depending on the SoC, the number of instances of the controller will
change (2 instances of each in the A10, only one in the A13, for
example), and the output availables will change too (HDMI, composite,
VGA on the A20, none of them on the A13).

On most featured SoCs, it looks like that:

+--------------------------------------------+
| RAM |
+--------------------------------------------+
| | | |
v | | v
+----------------+ | | +----------------+
| Frontend | | | | Frontend |
+----------------+ | | +----------------+
| | | |
v | | v
+----------------+ | | +----------------+
| Backend |<+ +>| Backend |
+----------------+ +----------------+
| |
v v
+----------------+ +----------------+---> LVDS
| TCON | | TCON |---> RGB
+----------------+ +----------------+
| +---+ +---+ |
| | | |
v v v v
+------------+ +------------+ +------------+---> VGA
| TV Encoder | | HDMI | | TV Encoder |---> Composite
+------------+ +------------+ +------------+

The current code only assumes that there is a single instance of all
the controllers. It also supports only the RGB and Composite
interfaces.

A few more things are missing though, and will be supported
eventually:
- Overscan support
- Asynchronous page flip
- Multiple plane support
- Composite / VGA Hotplug detection
- More outputs
- Support for several videos pipelines

And there's one big gotcha: thhe code to parse the mode from the
kernel commandline doesn't seem to support named modes. Since we
expose the various TV standards through named modes, it means that
there's no way to use a particular standard to display something
during the kernel boot. The default will always be used, in other
words, PAL.

A few more questions that are probably going to be raised during the
review:
- How do you associate private data to a mode, for example to deal
with the non-generic, driver-specific settings required to deal
with the various TV standards? drm_display_mode seems to have a
private field, but it isn't always preserved.
- How do you setup properties in the kernel command line? In order
to have a decent display during boot on relevant interfaces, you
probably want to setup the overscan beforehand. Overscan seems to
be handled through properties, and afaik, there's no way to set
that from the cmdline. Should we use a kernel parameter to set the
default value instead?

Thanks!
Maxime

Maxime Ripard (19):
clk: sunxi: Add display clock
clk: sunxi: Add PLL3 clock
clk: sunxi: Add TCON channel0 clock
clk: sunxi: Add TCON channel1 clock
clk: sunxi: add DRAM gates
clk: sunxi: Add Allwinner R8 AHB gates support
drm/panel: simple: Add timings for the Olimex LCD-OLinuXino-4.3TS
drm: Add Allwinner A10 Display Engine support
drm: sun4i: Add DT bindings documentation
drm: sun4i: Add RGB output
drm: sun4i: Add composite output
drm: sun4i: tv: Add PAL output standard
drm: sun4i: tv: Add NTSC output standard
ARM: sun5i: dt: Add pll3 and pll7 clocks
ARM: sun5i: dt: Add display and TCON clocks
ARM: sun5i: dt: Add DRAM gates
ARM: sun5i: dt: Add display blocks to the DTSI
ARM: sun5i: r8: Add AHB gates to the DTSI
ARM: sun5i: chip: Enable the TV Encoder

.../devicetree/bindings/drm/sunxi/sun4i-drm.txt | 122 ++++
arch/arm/boot/dts/sun5i-a10s.dtsi | 9 +-
arch/arm/boot/dts/sun5i-a13.dtsi | 3 +-
arch/arm/boot/dts/sun5i-r8.dtsi | 46 +-
arch/arm/boot/dts/sun5i.dtsi | 137 +++++
drivers/clk/sunxi/Makefile | 4 +
drivers/clk/sunxi/clk-simple-gates.c | 4 +
drivers/clk/sunxi/clk-sun4i-display.c | 199 +++++++
drivers/clk/sunxi/clk-sun4i-pll3.c | 84 +++
drivers/clk/sunxi/clk-sun4i-tcon-ch0.c | 173 ++++++
drivers/clk/sunxi/clk-sun4i-tcon-ch1.c | 167 ++++++
drivers/gpu/drm/Kconfig | 2 +
drivers/gpu/drm/Makefile | 3 +-
drivers/gpu/drm/panel/panel-simple.c | 26 +
drivers/gpu/drm/sun4i/Kconfig | 14 +
drivers/gpu/drm/sun4i/Makefile | 11 +
drivers/gpu/drm/sun4i/sun4i_backend.c | 271 +++++++++
drivers/gpu/drm/sun4i/sun4i_backend.h | 159 ++++++
drivers/gpu/drm/sun4i/sun4i_crtc.c | 117 ++++
drivers/gpu/drm/sun4i/sun4i_crtc.h | 31 ++
drivers/gpu/drm/sun4i/sun4i_drv.c | 296 ++++++++++
drivers/gpu/drm/sun4i/sun4i_drv.h | 30 +
drivers/gpu/drm/sun4i/sun4i_framebuffer.c | 54 ++
drivers/gpu/drm/sun4i/sun4i_framebuffer.h | 19 +
drivers/gpu/drm/sun4i/sun4i_layer.c | 111 ++++
drivers/gpu/drm/sun4i/sun4i_layer.h | 30 +
drivers/gpu/drm/sun4i/sun4i_rgb.c | 243 ++++++++
drivers/gpu/drm/sun4i/sun4i_rgb.h | 18 +
drivers/gpu/drm/sun4i/sun4i_tcon.c | 478 ++++++++++++++++
drivers/gpu/drm/sun4i/sun4i_tcon.h | 182 ++++++
drivers/gpu/drm/sun4i/sun4i_tv.c | 619 +++++++++++++++++++++
drivers/gpu/drm/sun4i/sun4i_tv.h | 18 +
32 files changed, 3673 insertions(+), 7 deletions(-)
create mode 100644 Documentation/devicetree/bindings/drm/sunxi/sun4i-drm.txt
create mode 100644 drivers/clk/sunxi/clk-sun4i-display.c
create mode 100644 drivers/clk/sunxi/clk-sun4i-pll3.c
create mode 100644 drivers/clk/sunxi/clk-sun4i-tcon-ch0.c
create mode 100644 drivers/clk/sunxi/clk-sun4i-tcon-ch1.c
create mode 100644 drivers/gpu/drm/sun4i/Kconfig
create mode 100644 drivers/gpu/drm/sun4i/Makefile
create mode 100644 drivers/gpu/drm/sun4i/sun4i_backend.c
create mode 100644 drivers/gpu/drm/sun4i/sun4i_backend.h
create mode 100644 drivers/gpu/drm/sun4i/sun4i_crtc.c
create mode 100644 drivers/gpu/drm/sun4i/sun4i_crtc.h
create mode 100644 drivers/gpu/drm/sun4i/sun4i_drv.c
create mode 100644 drivers/gpu/drm/sun4i/sun4i_drv.h
create mode 100644 drivers/gpu/drm/sun4i/sun4i_framebuffer.c
create mode 100644 drivers/gpu/drm/sun4i/sun4i_framebuffer.h
create mode 100644 drivers/gpu/drm/sun4i/sun4i_layer.c
create mode 100644 drivers/gpu/drm/sun4i/sun4i_layer.h
create mode 100644 drivers/gpu/drm/sun4i/sun4i_rgb.c
create mode 100644 drivers/gpu/drm/sun4i/sun4i_rgb.h
create mode 100644 drivers/gpu/drm/sun4i/sun4i_tcon.c
create mode 100644 drivers/gpu/drm/sun4i/sun4i_tcon.h
create mode 100644 drivers/gpu/drm/sun4i/sun4i_tv.c
create mode 100644 drivers/gpu/drm/sun4i/sun4i_tv.h

--
2.6.2

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/