summaryrefslogtreecommitdiff
path: root/sys/arch/sparc64/dev/vgafb.c
diff options
context:
space:
mode:
Diffstat (limited to 'sys/arch/sparc64/dev/vgafb.c')
-rw-r--r--sys/arch/sparc64/dev/vgafb.c74
1 files changed, 38 insertions, 36 deletions
diff --git a/sys/arch/sparc64/dev/vgafb.c b/sys/arch/sparc64/dev/vgafb.c
index 5bd27ef6686..ce3f036e334 100644
--- a/sys/arch/sparc64/dev/vgafb.c
+++ b/sys/arch/sparc64/dev/vgafb.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: vgafb.c,v 1.13 2002/03/30 00:08:14 jason Exp $ */
+/* $OpenBSD: vgafb.c,v 1.14 2002/03/31 17:34:15 jason Exp $ */
/*
* Copyright (c) 2001 Jason L. Wright (jason@thought.net)
@@ -74,6 +74,7 @@ struct vgafb_softc {
struct rcons sc_rcons;
struct raster sc_raster;
int sc_console;
+ u_int sc_mode;
u_int8_t sc_cmap_red[256];
u_int8_t sc_cmap_green[256];
u_int8_t sc_cmap_blue[256];
@@ -269,6 +270,9 @@ vgafb_ioctl(v, cmd, data, flags, p)
case WSDISPLAYIO_GTYPE:
*(u_int *)data = WSDISPLAY_TYPE_UNKNOWN;
break;
+ case WSDISPLAYIO_SMODE:
+ sc->sc_mode = *(u_int *)data;
+ break;
case WSDISPLAYIO_GINFO:
wdf = (void *)data;
wdf->height = sc->sc_height;
@@ -417,50 +421,48 @@ vgafb_mmap(v, off, prot)
int prot;
{
struct vgafb_softc *sc = v;
-#ifdef VGAFB_ALLOW_NATIVE
bus_addr_t ba;
bus_size_t bs;
-#endif
+ paddr_t pa;
+ vaddr_t va;
if (off & PGOFSET)
return (-1);
-#ifdef VGAFB_ALLOW_NATIVE
- /* See if this is a native mapping of pixel memory */
- if ((pci_mem_find(sc->sc_pci_chip, sc->sc_pci_tag, sc->sc_mem_cf,
- &ba, &bs, NULL) == 0) &&
- (off >= ba) && (off < (ba + bs))) {
- return (bus_space_mmap(sc->sc_mem_t, ba, off - ba, prot,
- BUS_SPACE_MAP_LINEAR));
- }
-
- /* See if this is a native mapping of memory mapped i/o */
- if ((pci_mem_find(sc->sc_pci_chip, sc->sc_pci_tag, sc->sc_mmio_cf,
- &ba, &bs, NULL) == 0) &&
- (off >= ba) && (off < (ba + bs))) {
- return (bus_space_mmap(sc->sc_mem_t, ba, off - ba, prot,
- BUS_SPACE_MAP_LINEAR));
- }
-#endif
+ switch (sc->sc_mode) {
+ case WSDISPLAYIO_MODE_MAPPED:
+ if ((pci_mem_find(sc->sc_pci_chip, sc->sc_pci_tag,
+ sc->sc_mem_cf, &ba, &bs, NULL) == 0) &&
+ (off >= ba) && (off < (ba + bs)))
+ return (bus_space_mmap(sc->sc_mem_t, ba, off - ba,
+ prot, BUS_SPACE_MAP_LINEAR));
+
+ if ((pci_mem_find(sc->sc_pci_chip, sc->sc_pci_tag,
+ sc->sc_mmio_cf, &ba, &bs, NULL) == 0) &&
+ (off >= ba) && (off < (ba + bs)))
+ return (bus_space_mmap(sc->sc_mem_t, ba, off - ba,
+ prot, BUS_SPACE_MAP_LINEAR));
+
+ if (sc->sc_rom_ptr != NULL &&
+ off >= sc->sc_rom_addr &&
+ off < sc->sc_rom_addr + sc->sc_rom_size) {
+ off -= sc->sc_rom_addr;
+ va = ((vaddr_t)sc->sc_rom_ptr) + off;
+ if (pmap_extract(pmap_kernel(), va, &pa) == FALSE)
+ return (-1);
+ return (pa);
+ }
+ return (-1);
- /* Lastly, this might be a request for a "dumb" framebuffer map */
- if (off >= 0 && off < sc->sc_mem_size) {
- return (bus_space_mmap(sc->sc_mem_t, sc->sc_mem_addr, off, prot,
- BUS_SPACE_MAP_LINEAR));
- }
+ case WSDISPLAYIO_MODE_DUMBFB:
+ if (off >= 0 && off < sc->sc_mem_size)
+ return (bus_space_mmap(sc->sc_mem_t, sc->sc_mem_addr,
+ off, prot, BUS_SPACE_MAP_LINEAR));
+ return (-1);
-#ifdef VGAFB_ALLOW_NATIVE
- /* Don't allow mapping of the shadow rom right now... needs work */
- if (sc->sc_rom_ptr != NULL &&
- off >= sc->sc_rom_addr &&
- off < sc->sc_rom_addr + sc->sc_rom_size) {
- off -= sc->sc_rom_addr;
- va = ((vaddr_t)sc->sc_rom_ptr) + off;
- if (pmap_extract(pmap_kernel(), va, &pa) == FALSE)
- return (-1);
- return (pa);
+ default:
+ return (-1);
}
-#endif
return (-1);
}