/* $OpenBSD: wscons_machdep.c,v 1.15 2008/07/16 20:03:22 miod Exp $ */ /* * Copyright (c) 2001 Aaron Campbell * 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 OR HIS RELATIVES 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 MIND, 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. */ #include #include #include #include #include #include #include #include #include "vga.h" #include "ega.h" #include "pcdisplay.h" #if (NVGA > 0) || (NEGA > 0) || (NPCDISPLAY > 0) #include #include #if (NVGA > 0) #include #include #endif #if (NEGA > 0) #include #endif #if (NPCDISPLAY > 0) #include #endif #endif #include "wsdisplay.h" #if NWSDISPLAY > 0 #include #endif #include "pckbc.h" #if (NPCKBC > 0) #include #include #include #endif #include "pckbd.h" #include "ukbd.h" #if (NPCKBD > 0) || (NUKBD > 0) #include #endif #if (NUKBD > 0) #include #endif cons_decl(ws); void wscnprobe(struct consdev *cp) { int maj; /* locate the major number */ for (maj = 0; maj < nchrdev; maj++) { if (cdevsw[maj].d_open == wsdisplayopen) break; } if (maj == nchrdev) { /* we are not in cdevsw[], give up */ panic("wsdisplay is not in cdevsw[]"); } cp->cn_dev = makedev(maj, 0); cp->cn_pri = CN_MIDPRI; } void wscninit(struct consdev *cp) { static int initted; if (initted) return; initted = 1; #if (NVGA > 0) || (NEGA > 0) || (NPCDISPLAY > 0) #if (NVGA > 0) if (!vga_cnattach(I386_BUS_SPACE_IO, I386_BUS_SPACE_MEM, -1, 1)) goto dokbd; #endif #if (NEGA > 0) if (!ega_cnattach(I386_BUS_SPACE_IO, I386_BUS_SPACE_MEM)) goto dokbd; #endif #if (NPCDISPLAY > 0) if (!pcdisplay_cnattach(I386_BUS_SPACE_IO, I386_BUS_SPACE_MEM)) goto dokbd; #endif if (0) goto dokbd; /* XXX stupid gcc */ dokbd: #if (NPCKBC > 0) if (!pckbc_cnattach(I386_BUS_SPACE_IO, IO_KBD, KBCMDP, PCKBC_KBD_SLOT, 0)) return; #endif #if (NUKBD > 0) if (!ukbd_cnattach()) return; #endif #endif /* VGA | EGA | PCDISPLAY */ return; } void wscnputc(dev_t dev, int i) { wsdisplay_cnputc(dev, i); } int wscngetc(dev_t dev) { return (wskbd_cngetc(dev)); } void wscnpollc(dev_t dev, int on) { wskbd_cnpollc(dev, on); }