This moves the nspire over to using the device tree to
set-up and probe the PL111 DRM driver and use the panels
from the simple-panel drivers.

Cc: Daniel Tang <dt.ta...@gmail.com>
Cc: Fabian Vogt <fab...@ritter-vogt.de>
Tested-by: Fabian Vogt <fab...@ritter-vogt.de>
Acked-by: Sam Ravnborg <s...@ravnborg.org>
Signed-off-by: Linus Walleij <linus.wall...@linaro.org>
---
ChangeLog v2->v3:
- Use single port instead of ports with port
ChangeLog v1->v2:
- Now tested
- This will be sent separately to ARM SoC after the rest
  of the patches land.
---
 arch/arm/boot/dts/nspire-classic.dtsi |  17 +++-
 arch/arm/boot/dts/nspire-cx.dts       |  16 +++-
 arch/arm/boot/dts/nspire.dtsi         |  10 ++-
 arch/arm/mach-nspire/Makefile         |   1 -
 arch/arm/mach-nspire/clcd.c           | 114 --------------------------
 arch/arm/mach-nspire/clcd.h           |  10 ---
 arch/arm/mach-nspire/nspire.c         |  25 ------
 7 files changed, 39 insertions(+), 154 deletions(-)
 delete mode 100644 arch/arm/mach-nspire/clcd.c
 delete mode 100644 arch/arm/mach-nspire/clcd.h

diff --git a/arch/arm/boot/dts/nspire-classic.dtsi 
b/arch/arm/boot/dts/nspire-classic.dtsi
index c53f42777851..1edb37005862 100644
--- a/arch/arm/boot/dts/nspire-classic.dtsi
+++ b/arch/arm/boot/dts/nspire-classic.dtsi
@@ -8,7 +8,13 @@
 /include/ "nspire.dtsi"
 
 &lcd {
-       lcd-type = "classic";
+       port {
+               clcd_pads: endpoint {
+                       remote-endpoint = <&panel_in>;
+                       /* Dummy values, since we are grayscale */
+                       arm,pl11x,tft-r0g0b0-pads = <0 8 16>;
+               };
+       };
 };
 
 &fast_timer {
@@ -69,6 +75,15 @@
                        #interrupt-cells = <1>;
                };
        };
+
+       panel {
+               compatible = "ti,nspire-classic-lcd-panel";
+               port {
+                       panel_in: endpoint {
+                               remote-endpoint = <&clcd_pads>;
+                       };
+               };
+       };
        chosen {
                bootargs = "debug earlyprintk console=tty0 
console=ttyS0,115200n8 root=/dev/ram0";
        };
diff --git a/arch/arm/boot/dts/nspire-cx.dts b/arch/arm/boot/dts/nspire-cx.dts
index da95c3736651..8c9c6b739a9e 100644
--- a/arch/arm/boot/dts/nspire-cx.dts
+++ b/arch/arm/boot/dts/nspire-cx.dts
@@ -9,7 +9,12 @@
 /include/ "nspire.dtsi"
 
 &lcd {
-       lcd-type = "cx";
+       port {
+               clcd_pads: endpoint {
+                       remote-endpoint = <&panel_in>;
+                       arm,pl11x,tft-r0g0b0-pads = <0 8 16>;
+               };
+       };
 };
 
 &fast_timer {
@@ -106,6 +111,15 @@
                        };
                };
        };
+
+       panel {
+               compatible = "ti,nspire-cx-lcd-panel";
+               port {
+                       panel_in: endpoint {
+                               remote-endpoint = <&clcd_pads>;
+                       };
+               };
+       };
        chosen {
                bootargs = "debug earlyprintk console=tty0 
console=ttyAMA0,115200n8 root=/dev/ram0";
        };
diff --git a/arch/arm/boot/dts/nspire.dtsi b/arch/arm/boot/dts/nspire.dtsi
index c35fd6667716..d9a0fd7524dc 100644
--- a/arch/arm/boot/dts/nspire.dtsi
+++ b/arch/arm/boot/dts/nspire.dtsi
@@ -95,8 +95,14 @@
                        reg = <0xC0000000 0x1000>;
                        interrupts = <21>;
 
-                       clocks = <&apb_pclk>;
-                       clock-names = "apb_pclk";
+                       /*
+                        * We assume the same clock is fed to APB and CLCDCLK.
+                        * There is some code to scale the clock down by a 
factor
+                        * 48 for the display so likely the frequency to the
+                        * display is 1MHz and the CLCDCLK is 48 MHz.
+                        */
+                       clocks = <&apb_pclk>, <&apb_pclk>;
+                       clock-names = "clcdclk", "apb_pclk";
                };
 
                adc: adc@C4000000 {
diff --git a/arch/arm/mach-nspire/Makefile b/arch/arm/mach-nspire/Makefile
index 1d568c600452..4716b9b9aa7b 100644
--- a/arch/arm/mach-nspire/Makefile
+++ b/arch/arm/mach-nspire/Makefile
@@ -1,3 +1,2 @@
 # SPDX-License-Identifier: GPL-2.0-only
 obj-y                          += nspire.o
-obj-y                          += clcd.o
diff --git a/arch/arm/mach-nspire/clcd.c b/arch/arm/mach-nspire/clcd.c
deleted file mode 100644
index 44738dcb391d..000000000000
--- a/arch/arm/mach-nspire/clcd.c
+++ /dev/null
@@ -1,114 +0,0 @@
-// SPDX-License-Identifier: GPL-2.0-only
-/*
- *     linux/arch/arm/mach-nspire/clcd.c
- *
- *     Copyright (C) 2013 Daniel Tang <tan...@tangrs.id.au>
- */
-
-#include <linux/init.h>
-#include <linux/of.h>
-#include <linux/amba/bus.h>
-#include <linux/amba/clcd.h>
-#include <linux/dma-mapping.h>
-
-static struct clcd_panel nspire_cx_lcd_panel = {
-       .mode           = {
-               .name           = "Color LCD",
-               .refresh        = 60,
-               .xres           = 320,
-               .yres           = 240,
-               .sync           = 0,
-               .vmode          = FB_VMODE_NONINTERLACED,
-               .pixclock       = 1,
-               .hsync_len      = 6,
-               .vsync_len      = 1,
-               .right_margin   = 50,
-               .left_margin    = 38,
-               .lower_margin   = 3,
-               .upper_margin   = 17,
-       },
-       .width          = 65, /* ~6.50 cm */
-       .height         = 49, /* ~4.87 cm */
-       .tim2           = TIM2_IPC,
-       .cntl           = CNTL_LCDTFT | CNTL_LCDVCOMP(1),
-       .bpp            = 16,
-       .caps           = CLCD_CAP_565,
-};
-
-static struct clcd_panel nspire_classic_lcd_panel = {
-       .mode           = {
-               .name           = "Grayscale LCD",
-               .refresh        = 60,
-               .xres           = 320,
-               .yres           = 240,
-               .sync           = FB_SYNC_HOR_HIGH_ACT | FB_SYNC_VERT_HIGH_ACT,
-               .vmode          = FB_VMODE_NONINTERLACED,
-               .pixclock       = 1,
-               .hsync_len      = 6,
-               .vsync_len      = 1,
-               .right_margin   = 6,
-               .left_margin    = 6,
-       },
-       .width          = 71, /* 7.11cm */
-       .height         = 53, /* 5.33cm */
-       .tim2           = 0x80007d0,
-       .cntl           = CNTL_LCDMONO8,
-       .bpp            = 8,
-       .grayscale      = 1,
-       .caps           = CLCD_CAP_5551,
-};
-
-int nspire_clcd_setup(struct clcd_fb *fb)
-{
-       struct clcd_panel *panel;
-       size_t panel_size;
-       const char *type;
-       dma_addr_t dma;
-       int err;
-
-       BUG_ON(!fb->dev->dev.of_node);
-
-       err = of_property_read_string(fb->dev->dev.of_node, "lcd-type", &type);
-       if (err) {
-               pr_err("CLCD: Could not find lcd-type property\n");
-               return err;
-       }
-
-       if (!strcmp(type, "cx")) {
-               panel = &nspire_cx_lcd_panel;
-       } else if (!strcmp(type, "classic")) {
-               panel = &nspire_classic_lcd_panel;
-       } else {
-               pr_err("CLCD: Unknown lcd-type %s\n", type);
-               return -EINVAL;
-       }
-
-       panel_size = ((panel->mode.xres * panel->mode.yres) * panel->bpp) / 8;
-       panel_size = ALIGN(panel_size, PAGE_SIZE);
-
-       fb->fb.screen_base = dma_alloc_wc(&fb->dev->dev, panel_size, &dma,
-                                         GFP_KERNEL);
-
-       if (!fb->fb.screen_base) {
-               pr_err("CLCD: unable to map framebuffer\n");
-               return -ENOMEM;
-       }
-
-       fb->fb.fix.smem_start = dma;
-       fb->fb.fix.smem_len = panel_size;
-       fb->panel = panel;
-
-       return 0;
-}
-
-int nspire_clcd_mmap(struct clcd_fb *fb, struct vm_area_struct *vma)
-{
-       return dma_mmap_wc(&fb->dev->dev, vma, fb->fb.screen_base,
-                          fb->fb.fix.smem_start, fb->fb.fix.smem_len);
-}
-
-void nspire_clcd_remove(struct clcd_fb *fb)
-{
-       dma_free_wc(&fb->dev->dev, fb->fb.fix.smem_len, fb->fb.screen_base,
-                   fb->fb.fix.smem_start);
-}
diff --git a/arch/arm/mach-nspire/clcd.h b/arch/arm/mach-nspire/clcd.h
deleted file mode 100644
index 7f36bd8511c5..000000000000
--- a/arch/arm/mach-nspire/clcd.h
+++ /dev/null
@@ -1,10 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0-only */
-/*
- *     linux/arch/arm/mach-nspire/clcd.h
- *
- *     Copyright (C) 2013 Daniel Tang <tan...@tangrs.id.au>
- */
-
-int nspire_clcd_setup(struct clcd_fb *fb);
-int nspire_clcd_mmap(struct clcd_fb *fb, struct vm_area_struct *vma);
-void nspire_clcd_remove(struct clcd_fb *fb);
diff --git a/arch/arm/mach-nspire/nspire.c b/arch/arm/mach-nspire/nspire.c
index 957bd0c0fbd5..2d4abb0288b9 100644
--- a/arch/arm/mach-nspire/nspire.c
+++ b/arch/arm/mach-nspire/nspire.c
@@ -12,14 +12,12 @@
 #include <linux/irqchip/arm-vic.h>
 #include <linux/clkdev.h>
 #include <linux/amba/bus.h>
-#include <linux/amba/clcd.h>
 
 #include <asm/mach/arch.h>
 #include <asm/mach-types.h>
 #include <asm/mach/map.h>
 
 #include "mmio.h"
-#include "clcd.h"
 
 static const char *const nspire_dt_match[] __initconst = {
        "ti,nspire",
@@ -29,28 +27,6 @@ static const char *const nspire_dt_match[] __initconst = {
        NULL,
 };
 
-static struct clcd_board nspire_clcd_data = {
-       .name           = "LCD",
-       .caps           = CLCD_CAP_5551 | CLCD_CAP_565,
-       .check          = clcdfb_check,
-       .decode         = clcdfb_decode,
-       .setup          = nspire_clcd_setup,
-       .mmap           = nspire_clcd_mmap,
-       .remove         = nspire_clcd_remove,
-};
-
-
-static struct of_dev_auxdata nspire_auxdata[] __initdata = {
-       OF_DEV_AUXDATA("arm,pl111", NSPIRE_LCD_PHYS_BASE,
-                       NULL, &nspire_clcd_data),
-       { }
-};
-
-static void __init nspire_init(void)
-{
-       of_platform_default_populate(NULL, nspire_auxdata, NULL);
-}
-
 static void nspire_restart(enum reboot_mode mode, const char *cmd)
 {
        void __iomem *base = ioremap(NSPIRE_MISC_PHYS_BASE, SZ_4K);
@@ -62,6 +38,5 @@ static void nspire_restart(enum reboot_mode mode, const char 
*cmd)
 
 DT_MACHINE_START(NSPIRE, "TI-NSPIRE")
        .dt_compat      = nspire_dt_match,
-       .init_machine   = nspire_init,
        .restart        = nspire_restart,
 MACHINE_END
-- 
2.21.0

_______________________________________________
dri-devel mailing list
dri-devel@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/dri-devel

Reply via email to