Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/arch Add omapfb to FDT-ized TI port.
details: https://anonhg.NetBSD.org/src/rev/331df99b67e5
branches: trunk
changeset: 465000:331df99b67e5
user: jmcneill <jmcneill%NetBSD.org@localhost>
date: Thu Oct 31 17:08:54 2019 +0000
description:
Add omapfb to FDT-ized TI port.
diffstat:
sys/arch/arm/ti/files.ti | 7 +-
sys/arch/arm/ti/omap3_dss.c | 1260 ++++++++++++++++++++++++++++++++++++++++
sys/arch/arm/ti/omap3_dssreg.h | 373 +++++++++++
sys/arch/evbarm/conf/GENERIC | 3 +-
4 files changed, 1641 insertions(+), 2 deletions(-)
diffs (truncated from 1680 to 300 lines):
diff -r b64c7522596c -r 331df99b67e5 sys/arch/arm/ti/files.ti
--- a/sys/arch/arm/ti/files.ti Thu Oct 31 11:59:40 2019 +0000
+++ b/sys/arch/arm/ti/files.ti Thu Oct 31 17:08:54 2019 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: files.ti,v 1.17 2019/10/30 21:41:40 jmcneill Exp $
+# $NetBSD: files.ti,v 1.18 2019/10/31 17:08:54 jmcneill Exp $
#
file arch/arm/ti/ti_cpufreq.c soc_ti
@@ -107,6 +107,11 @@
attach tirng at fdt with ti_rng
file arch/arm/ti/ti_rng.c ti_rng
+# Display adapter
+device omapfb: rasops16, rasops8, wsemuldisplaydev, vcons, edid
+attach omapfb at fdt with omap3_dss
+file arch/arm/ti/omap3_dss.c omap3_dss
+
# SOC parameters
defflag opt_soc.h SOC_TI
defflag opt_soc.h SOC_AM33XX: SOC_TI
diff -r b64c7522596c -r 331df99b67e5 sys/arch/arm/ti/omap3_dss.c
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/sys/arch/arm/ti/omap3_dss.c Thu Oct 31 17:08:54 2019 +0000
@@ -0,0 +1,1260 @@
+/* $NetBSD: omap3_dss.c,v 1.1 2019/10/31 17:08:54 jmcneill Exp $ */
+
+/*
+ * Copyright (c) 2010 Michael Lorenz
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
+ * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
+ * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
+ * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
+ * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+ * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+ * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
+ * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ */
+
+/*
+ * A console driver for OMAP 3530's built-in video controller
+ * tested on beagleboard only so far
+ */
+
+#include "opt_wsdisplay_compat.h"
+
+#include <sys/cdefs.h>
+__KERNEL_RCSID(0, "$NetBSD: omap3_dss.c,v 1.1 2019/10/31 17:08:54 jmcneill Exp $");
+
+#include <sys/param.h>
+#include <sys/systm.h>
+#include <sys/kernel.h>
+#include <sys/device.h>
+#include <sys/malloc.h>
+#include <sys/lwp.h>
+#include <sys/kauth.h>
+#include <sys/bus.h>
+
+#include <uvm/uvm_extern.h>
+
+#include <dev/videomode/videomode.h>
+#include <dev/videomode/edidvar.h>
+
+#include <dev/fdt/fdtvar.h>
+
+#include <arm/ti/omap3_dssreg.h>
+
+#include <dev/wscons/wsdisplayvar.h>
+#include <dev/wscons/wsconsio.h>
+#include <dev/wsfont/wsfont.h>
+#include <dev/rasops/rasops.h>
+#include <dev/wscons/wsdisplay_vconsvar.h>
+
+struct omapfb_softc {
+ device_t sc_dev;
+
+ bus_space_tag_t sc_iot;
+ bus_dma_tag_t sc_dmat;
+ bus_space_handle_t sc_regh;
+ bus_dmamap_t sc_dmamap;
+ bus_dma_segment_t sc_dmamem[1];
+ size_t sc_vramsize;
+
+ int sc_width, sc_height, sc_depth, sc_stride;
+ int sc_locked;
+ void *sc_fbaddr, *sc_vramaddr;
+
+ int sc_cursor_offset;
+ uint32_t *sc_cursor_img;
+ int sc_cursor_x, sc_cursor_y;
+ int sc_hot_x, sc_hot_y;
+ uint8_t sc_cursor_bitmap[8 * 64];
+ uint8_t sc_cursor_mask[8 * 64];
+ uint32_t sc_cursor_cmap[4];
+
+ bus_addr_t sc_fbhwaddr;
+ uint32_t *sc_clut;
+ uint32_t sc_dispc_config;
+ int sc_video_is_on;
+ struct vcons_screen sc_console_screen;
+ struct wsscreen_descr sc_defaultscreen_descr;
+ const struct wsscreen_descr *sc_screens[1];
+ struct wsscreen_list sc_screenlist;
+ struct vcons_data vd;
+ int sc_mode;
+ uint8_t sc_cmap_red[256], sc_cmap_green[256], sc_cmap_blue[256];
+ void (*sc_putchar)(void *, int, int, u_int, long);
+
+ uint8_t sc_edid_data[1024];
+ size_t sc_edid_size;
+};
+
+static int omapfb_match(device_t, cfdata_t, void *);
+static void omapfb_attach(device_t, device_t, void *);
+
+CFATTACH_DECL_NEW(omap3_dss, sizeof(struct omapfb_softc),
+ omapfb_match, omapfb_attach, NULL, NULL);
+
+static int omapfb_ioctl(void *, void *, u_long, void *, int,
+ struct lwp *);
+static paddr_t omapfb_mmap(void *, void *, off_t, int);
+static void omapfb_init_screen(void *, struct vcons_screen *, int, long *);
+
+static int omapfb_putcmap(struct omapfb_softc *, struct wsdisplay_cmap *);
+static int omapfb_getcmap(struct omapfb_softc *, struct wsdisplay_cmap *);
+static void omapfb_restore_palette(struct omapfb_softc *);
+static void omapfb_putpalreg(struct omapfb_softc *, int, uint8_t,
+ uint8_t, uint8_t);
+
+static int omapfb_set_depth(struct omapfb_softc *, int);
+static void omapfb_set_video(struct omapfb_softc *, int);
+
+static void omapfb_move_cursor(struct omapfb_softc *, int, int);
+static int omapfb_do_cursor(struct omapfb_softc *,
+ struct wsdisplay_cursor *);
+
+#if NOMAPDMA > 0
+static void omapfb_init(struct omapfb_softc *);
+static void omapfb_wait_idle(struct omapfb_softc *);
+static void omapfb_rectfill(struct omapfb_softc *, int, int, int, int,
+ uint32_t);
+static void omapfb_bitblt(struct omapfb_softc *, int, int, int, int, int,
+ int, int);
+
+static void omapfb_cursor(void *, int, int, int);
+static void omapfb_putchar(void *, int, int, u_int, long);
+static void omapfb_copycols(void *, int, int, int, int);
+static void omapfb_erasecols(void *, int, int, int, long);
+static void omapfb_copyrows(void *, int, int, int);
+static void omapfb_eraserows(void *, int, int, long);
+#endif /* NOMAPDMA > 0 */
+
+struct wsdisplay_accessops omapfb_accessops = {
+ omapfb_ioctl,
+ omapfb_mmap,
+ NULL, /* alloc_screen */
+ NULL, /* free_screen */
+ NULL, /* show_screen */
+ NULL, /* load_font */
+ NULL, /* pollc */
+ NULL /* scroll */
+};
+
+uint32_t venc_mode_ntsc[] = {
+ 0x00000000, 0x00000001, 0x00008040, 0x00000359,
+ 0x0000020c, 0x00000000, 0x043f2631, 0x00000000,
+ 0x00000102, 0x0000016c, 0x0000012f, 0x00000043,
+ 0x00000038, 0x00000007, 0x00000001, 0x00000038,
+ 0x21f07c1f, 0x00000000, 0x01310011, 0x0000f003,
+ 0x00000000, 0x069300f4, 0x0016020c, 0x00060107,
+ 0x008e0350, 0x000f0359, 0x01a00000, 0x020701a0,
+ 0x01ac0024, 0x020d01ac, 0x00000006, 0x03480078,
+ 0x02060024, 0x0001008a, 0x01ac0106, 0x01060006,
+ 0x00140001, 0x00010001, 0x00f90000, 0x0000000d,
+ 0x00000000};
+
+extern const u_char rasops_cmap[768];
+
+static const char * const compatible[] = {
+ "ti,omap3-dss",
+ NULL
+};
+
+static int omapfb_console_phandle = -1;
+
+static int
+omapfb_match(device_t parent, cfdata_t match, void *aux)
+{
+ struct fdt_attach_args * const faa = aux;
+
+ return of_match_compatible(faa->faa_phandle, compatible);
+}
+
+static void
+omapfb_attach(device_t parent, device_t self, void *aux)
+{
+ struct omapfb_softc *sc = device_private(self);
+ struct fdt_attach_args *faa = aux;
+ const int phandle = faa->faa_phandle;
+ struct rasops_info *ri;
+ struct wsemuldisplaydev_attach_args aa;
+ prop_dictionary_t dict;
+ prop_data_t edid_data;
+ unsigned long defattr;
+#ifdef WSDISPLAY_MULTICONS
+ bool is_console = true;
+#else
+ bool is_console = phandle == omapfb_console_phandle;
+#endif
+ uint32_t sz, reg;
+ int segs, i, j;
+ bus_addr_t addr;
+ bus_size_t size;
+
+ if (fdtbus_get_reg(phandle, 0, &addr, &size) != 0) {
+ aprint_error(": couldn't get registers\n");
+ return;
+ }
+
+ sc->sc_dev = self;
+ sc->sc_iot = faa->faa_bst;
+ sc->sc_dmat = faa->faa_dmat;
+
+ if (bus_space_map(sc->sc_iot, addr, size, 0, &sc->sc_regh) != 0) {
+ aprint_error(": couldn't map registers\n");
+ return;
+ }
+
+ aprint_naive("\n");
+ aprint_normal(": OMAP onboard video\n");
+
+ sc->sc_video_is_on = 1;
+
+ /*
+ * XXX
+ * different u-boot versions initialize the graphics controller in
+ * different ways, so we look for the display resolution in a few
+ * different places...
+ */
+ sz = bus_space_read_4(sc->sc_iot, sc->sc_regh, OMAPFB_DISPC_GFX_SIZE);
+ if (sz == 0) {
+ sz = bus_space_read_4(sc->sc_iot, sc->sc_regh,
+ OMAPFB_DISPC_SIZE_LCD);
+ }
+ if (sz == 0) {
+ sz = bus_space_read_4(sc->sc_iot, sc->sc_regh,
+ OMAPFB_DISPC_SIZE_DIG);
+ }
+
+ /* ... and make sure it ends up where we need it */
+ bus_space_write_4(sc->sc_iot, sc->sc_regh, OMAPFB_DISPC_GFX_SIZE, sz);
+
+ sc->sc_width = (sz & 0xfff) + 1;
+ sc->sc_height = ((sz & 0x0fff0000 ) >> 16) + 1;
+ sc->sc_depth = 16;
+ sc->sc_stride = sc->sc_width << 1;
+
+ if (sc->sc_width == 1 || sc->sc_height == 1) {
+ aprint_error_dev(self, "bogus display size, not attaching\n");
+ return;
+ }
+
+ printf("%s: firmware set up %d x %d\n", device_xname(self),
+ sc->sc_width, sc->sc_height);
+#if 0
+ printf("DSS revision: %08x\n",
+ bus_space_read_4(sc->sc_iot, sc->sc_regh, OMAPFB_DSS_REVISION));
+#endif
+ dict = device_properties(self);
+ edid_data = prop_dictionary_get(dict, "EDID");
+
+ if (edid_data != NULL) {
+ struct edid_info ei;
+
+ sc->sc_edid_size = uimin(prop_data_size(edid_data), 1024);
+ memset(sc->sc_edid_data, 0, sizeof(sc->sc_edid_data));
+ memcpy(sc->sc_edid_data, prop_data_data_nocopy(edid_data),
+ sc->sc_edid_size);
+
+ edid_parse(sc->sc_edid_data, &ei);
+ edid_print(&ei);
+ }
+
+ /* setup video DMA */
+ sc->sc_vramsize = (12 << 20) + PAGE_SIZE; /* 12MB + CLUT */
+
+ if (bus_dmamem_alloc(sc->sc_dmat, sc->sc_vramsize, 0, 0,
Home |
Main Index |
Thread Index |
Old Index