Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/dev/sbus fix a few 8bit tcx issues:
details: https://anonhg.NetBSD.org/src/rev/084ced2aa64c
branches: trunk
changeset: 796772:084ced2aa64c
user: macallan <macallan%NetBSD.org@localhost>
date: Tue Jun 17 14:25:17 2014 +0000
description:
fix a few 8bit tcx issues:
- set ROP when clearing the screen, tcx actually uses it
- deal with possible 2MB VRAM tcx
while there, consistently use aprint_* in tcxattach()
diffstat:
sys/dev/sbus/tcx.c | 105 +++++++++++++++++++++++++++++++---------------------
1 files changed, 62 insertions(+), 43 deletions(-)
diffs (240 lines):
diff -r 9c51b6ce2a77 -r 084ced2aa64c sys/dev/sbus/tcx.c
--- a/sys/dev/sbus/tcx.c Tue Jun 17 12:38:12 2014 +0000
+++ b/sys/dev/sbus/tcx.c Tue Jun 17 14:25:17 2014 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: tcx.c,v 1.49 2014/06/17 10:47:27 macallan Exp $ */
+/* $NetBSD: tcx.c,v 1.50 2014/06/17 14:25:17 macallan Exp $ */
/*
* Copyright (c) 1996, 1998, 2009 The NetBSD Foundation, Inc.
@@ -38,7 +38,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: tcx.c,v 1.49 2014/06/17 10:47:27 macallan Exp $");
+__KERNEL_RCSID(0, "$NetBSD: tcx.c,v 1.50 2014/06/17 14:25:17 macallan Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -86,18 +86,19 @@
bus_space_handle_t sc_bt; /* Brooktree registers */
bus_space_handle_t sc_thc; /* THC registers */
- uint8_t *sc_fbaddr; /* framebuffer */
- uint64_t *sc_rblit; /* blitspace */
- uint64_t *sc_rstip; /* stipple space */
+ uint8_t *sc_fbaddr; /* framebuffer */
+ uint64_t *sc_rblit; /* blitspace */
+ uint64_t *sc_rstip; /* stipple space */
- short sc_8bit; /* true if 8-bit hardware */
- short sc_blanked; /* true if blanked */
- u_char sc_cmap_red[256];
- u_char sc_cmap_green[256];
- u_char sc_cmap_blue[256];
- int sc_mode, sc_bg;
- int sc_cursor_x, sc_cursor_y;
- int sc_hotspot_x, sc_hotspot_y;
+ short sc_8bit; /* true if 8-bit hardware */
+ short sc_blanked; /* true if blanked */
+ uint32_t sc_fbsize; /* size of the 8bit fb */
+ u_char sc_cmap_red[256];
+ u_char sc_cmap_green[256];
+ u_char sc_cmap_blue[256];
+ int sc_mode, sc_bg;
+ int sc_cursor_x, sc_cursor_y;
+ int sc_hotspot_x, sc_hotspot_y;
struct vcons_data vd;
};
@@ -138,6 +139,15 @@
#define TCX_CTL_24_LEVEL 0x03000000 /* 24 bits, ignores color map */
#define TCX_CTL_PIXELMASK 0x00FFFFFF /* mask for index/level */
+/*
+ * differences between S24 and tcx, as far as this driver is concerned:
+ * - S24 has 4MB VRAM, 24bit + 2bit control planes, no expansion possible
+ * - tcx has 1MB VRAM, 8bit, no control planes, may have a VSIMM toat bumps
+ * VRAM to 2MB
+ * - tcx can apply ROPs to STIP operations, unlike S24
+ * - tcx has a Bt458 DAC, just like CG6. S24 has an AT&T 20C567
+ */
+
/* autoconfiguration driver */
static void tcxattach(device_t, device_t, void *);
static int tcxmatch(device_t, cfdata_t, void *);
@@ -223,7 +233,7 @@
struct wsemuldisplaydev_attach_args aa;
struct rasops_info *ri;
unsigned long defattr;
- int node, ramsize;
+ int node;
struct fbdevice *fb = &sc->sc_fb;
bus_space_handle_t bh;
int isconsole, i, j;
@@ -251,17 +261,23 @@
fb->fb_type.fb_depth = 8;
fb_setsize_obp(fb, fb->fb_type.fb_depth, 1152, 900, node);
+ /*
+ * actual FB size ( of the 8bit region )
+ * no need to restrict userland mappings to the visible VRAM
+ */
if (sc->sc_8bit) {
- printf(" (8-bit only TCX)\n");
- ramsize = 1024 * 1024;
+ aprint_normal(" (8-bit only TCX)\n");
+ /* at least the SS4 can have 2MB with a VSIMM */
+ sc->sc_fbsize = 0x100000 * prom_getpropint(node, "vram", 1);
} else {
- printf(" (S24)\n");
- ramsize = 4 * 1024 * 1024;
+ aprint_normal(" (S24)\n");
+ /* all S24 I know of have 4MB, non-expandable */
+ sc->sc_fbsize = 0x100000;
}
fb->fb_type.fb_cmsize = 256;
- fb->fb_type.fb_size = ramsize;
- printf("%s: %s, %d x %d", device_xname(self), OBPNAME,
+ fb->fb_type.fb_size = sc->sc_fbsize; /* later code assumes 8bit */
+ aprint_normal_dev(self, "%s, %d x %d\n", OBPNAME,
fb->fb_type.fb_width,
fb->fb_type.fb_height);
@@ -289,7 +305,8 @@
sc->sc_physaddr[TCX_REG_THC].oa_base,
0x1000,
BUS_SPACE_MAP_LINEAR, &sc->sc_thc) != 0) {
- printf("tcxattach: cannot map thc registers\n");
+ aprint_error_dev(self,
+ "tcxattach: cannot map thc registers\n");
return;
}
@@ -298,7 +315,7 @@
sc->sc_physaddr[TCX_REG_CMAP].oa_base,
0x1000,
BUS_SPACE_MAP_LINEAR, &sc->sc_bt) != 0) {
- printf("tcxattach: cannot map bt registers\n");
+ aprint_error_dev(self, "tcxattach: cannot map DAC registers\n");
return;
}
@@ -306,10 +323,10 @@
if (sbus_bus_map(sa->sa_bustag,
sc->sc_physaddr[TCX_REG_DFB8].oa_space,
sc->sc_physaddr[TCX_REG_DFB8].oa_base,
- 1024 * 1024,
+ sc->sc_fbsize,
BUS_SPACE_MAP_LINEAR,
&bh) != 0) {
- printf("tcxattach: cannot map framebuffer\n");
+ aprint_error_dev(self, "tcxattach: cannot map framebuffer\n");
return;
}
sc->sc_fbaddr = bus_space_vaddr(sa->sa_bustag, bh);
@@ -318,10 +335,10 @@
if (sbus_bus_map(sa->sa_bustag,
sc->sc_physaddr[TCX_REG_RBLIT].oa_space,
sc->sc_physaddr[TCX_REG_RBLIT].oa_base,
- 8 * 1024 * 1024,
+ sc->sc_fbsize << 3,
BUS_SPACE_MAP_LINEAR | BUS_SPACE_MAP_LARGE,
&bh) != 0) {
- printf("tcxattach: cannot map RBLIT space\n");
+ aprint_error_dev(self, "tcxattach: cannot map RBLIT space\n");
return;
}
sc->sc_rblit = bus_space_vaddr(sa->sa_bustag, bh);
@@ -330,10 +347,10 @@
if (sbus_bus_map(sa->sa_bustag,
sc->sc_physaddr[TCX_REG_RSTIP].oa_space,
sc->sc_physaddr[TCX_REG_RSTIP].oa_base,
- 8 * 1024 * 1024,
+ sc->sc_fbsize << 3,
BUS_SPACE_MAP_LINEAR | BUS_SPACE_MAP_LARGE,
&bh) != 0) {
- printf("tcxattach: cannot map RSTIP space\n");
+ aprint_error_dev(self, "tcxattach: cannot map RSTIP space\n");
return;
}
sc->sc_rstip = bus_space_vaddr(sa->sa_bustag, bh);
@@ -341,7 +358,7 @@
isconsole = fb_is_console(node);
confreg = bus_space_read_4(sa->sa_bustag, sc->sc_thc, THC_CONFIG);
- printf(", id %d, rev %d, sense %d",
+ aprint_normal_dev(self, "id %d, rev %d, sense %d\n",
(confreg & THC_CFG_FBID) >> THC_CFG_FBID_SHIFT,
(confreg & THC_CFG_REV) >> THC_CFG_REV_SHIFT,
(confreg & THC_CFG_SENSE) >> THC_CFG_SENSE_SHIFT
@@ -368,9 +385,8 @@
bus_space_write_4(sa->sa_bustag, sc->sc_thc, THC_MISC, confreg);
if (isconsole) {
- printf(" (console)\n");
- } else
- printf("\n");
+ aprint_error_dev(self, "(console)\n");
+ }
fb_attach(&sc->sc_fb, isconsole);
@@ -383,11 +399,11 @@
vcons_init_screen(&sc->vd, &tcx_console_screen, 1, &defattr);
tcx_console_screen.scr_flags |= VCONS_SCREEN_IS_STATIC;
- sc->sc_bg = (defattr >> 16) & 0xff;
+ ri = &tcx_console_screen.scr_ri;
+
+ sc->sc_bg = ri->ri_devcmap[(defattr >> 16) & 0xff];
tcx_clearscreen(sc, 0);
- ri = &tcx_console_screen.scr_ri;
-
tcx_defscreendesc.nrows = ri->ri_rows;
tcx_defscreendesc.ncols = ri->ri_cols;
tcx_defscreendesc.textops = &ri->ri_ops;
@@ -786,14 +802,14 @@
/* 'regular' framebuffer mmap()ing */
if (sc->sc_8bit) {
/* on 8Bit boards hand over the 8 bit aperture */
- if (offset > 1024 * 1024)
+ if (offset > sc->sc_fbsize)
return -1;
return bus_space_mmap(sc->sc_bustag,
sc->sc_physaddr[TCX_REG_DFB8].oa_base + offset, 0, prot,
BUS_SPACE_MAP_LINEAR);
} else {
/* ... but if we have a 24bit aperture we use it */
- if (offset > 1024 * 1024 * 4)
+ if (offset > sc->sc_fbsize * 4)
return -1;
return bus_space_mmap(sc->sc_bustag,
sc->sc_physaddr[TCX_REG_DFB24].oa_base + offset, 0, prot,
@@ -836,15 +852,18 @@
static void
tcx_clearscreen(struct tcx_softc *sc, int spc)
{
- uint64_t bg = ((uint64_t)sc->sc_bg << 32) | 0xffffffffLL;
+ /* ROP in the upper 4bit is necessary, tcx actually uses it */
+ uint64_t bg = 0x30000000ffffffffLL;
uint64_t spc64;
- int i;
+ int i, len;
- spc64 = spc & 3;
- spc64 = spc64 << 56;
+ bg |= ((uint64_t)sc->sc_bg << 32);
+ spc64 = (spc & 3) << 24;
+ bg |= spc64;
- for (i = 0; i < 1024 * 1024; i += 32)
- sc->sc_rstip[i] = bg | spc64;
+ len = sc->sc_fb.fb_type.fb_width * sc->sc_fb.fb_type.fb_height;
+ for (i = 0; i < len; i += 32)
+ sc->sc_rstip[i] = bg;
}
static void
Home |
Main Index |
Thread Index |
Old Index