diff options
author | Aaron Campbell <aaron@cvs.openbsd.org> | 2001-01-30 00:00:35 +0000 |
---|---|---|
committer | Aaron Campbell <aaron@cvs.openbsd.org> | 2001-01-30 00:00:35 +0000 |
commit | 0fcf6044f0a074f64508c0d71efd3d647550aa31 (patch) | |
tree | 4bdd07108bfee7e2d46c5ef1538012ffc4656e2b /sys/arch | |
parent | bc11062938d970b18c2a7bd8e8fcb49873d875a2 (diff) |
Support for the wscons machine-independent console driver on the i386. To
become default in a few moments once deraadt commits new kernel config files.
IMPORTANT NOTE: A few important pieces are still required to be worked out
over the next few days. Users (and developers) relying on X should probably
stay away from -current until further notice. This should not take long, but
here is your first heads up. If you decide to upgrade your kernel anyway,
be sure to update your /etc/ttys file to use vt100 instead of vt220. The
rest of the fallout from this should be minor.
Diffstat (limited to 'sys/arch')
-rw-r--r-- | sys/arch/i386/conf/files.i386 | 26 | ||||
-rw-r--r-- | sys/arch/i386/i386/conf.c | 19 | ||||
-rw-r--r-- | sys/arch/i386/i386/machdep.c | 82 | ||||
-rw-r--r-- | sys/arch/i386/include/pccons.h | 11 | ||||
-rw-r--r-- | sys/arch/i386/include/types.h | 4 |
5 files changed, 123 insertions, 19 deletions
diff --git a/sys/arch/i386/conf/files.i386 b/sys/arch/i386/conf/files.i386 index 69141251db9..a8ced2ef537 100644 --- a/sys/arch/i386/conf/files.i386 +++ b/sys/arch/i386/conf/files.i386 @@ -1,4 +1,4 @@ -# $OpenBSD: files.i386,v 1.73 2001/01/24 09:38:00 hugh Exp $ +# $OpenBSD: files.i386,v 1.74 2001/01/30 00:00:29 aaron Exp $ # $NetBSD: files.i386,v 1.73 1996/05/07 00:58:36 thorpej Exp $ # # new style config file for i386 architecture @@ -126,7 +126,7 @@ include "../../../gnu/arch/i386/fpemul/files.fpemul" # attribute used to represent the "keyboard controller" # XXX should be a real device -define pckbd { [irq = -1], [port = -1] } +define pckbcport { [irq = -1], [port = -1] } # 8250/16[45]50-based "com" ports, optimized for the i386 interrupt system device pccom: tty @@ -135,12 +135,14 @@ attach pccom at commulti with pccom_commulti file arch/i386/isa/pccom.c pccom & (pccom_isa | pccom_isapnp | pccom_commulti | pccom_pcmcia | pccom_cardbus | pccom_puc) needs-flag # PC console support a la "pccons" -device pc: tty, pckbd +device pc: tty, pckbcport attach pc at isa -file arch/i386/isa/pccons.c pc needs-flag +device pcconskbd +attach pcconskbd at pckbc +file arch/i386/isa/pccons.c pc | pcconskbd needs-flag # PC console support a la "pcvt" -device vt: tty, pckbd +device vt: tty, pckbcport attach vt at isa file arch/i386/isa/pcvt/pcvt_drv.c vt needs-flag file arch/i386/isa/pcvt/pcvt_ext.c vt needs-flag @@ -151,15 +153,19 @@ file arch/i386/isa/pcvt/pcvt_sup.c vt needs-flag file arch/i386/isa/pcvt/pcvt_vtf.c vt needs-flag # PC Mice; Logitech-style, Microsoft-style, and PS/2-style -device lms +device lms: wsmousedev attach lms at isa file arch/i386/isa/lms.c lms needs-flag -device mms +device mms: wsmousedev attach mms at isa file arch/i386/isa/mms.c mms needs-flag -device pms -attach pms at pckbd -file arch/i386/isa/pms.c pms needs-flag +device opms +attach opms at pckbcport with opms_hack +attach opms at pckbc with opms_pckbc +file arch/i386/isa/pms.c opms | opms_hack | opms_pckbc needs-flag + +include "dev/wscons/files.wscons" +include "dev/pckbc/files.pckbc" device sysbeep attach sysbeep at pcppi diff --git a/sys/arch/i386/i386/conf.c b/sys/arch/i386/i386/conf.c index 2e36d246dab..73ba65edcca 100644 --- a/sys/arch/i386/i386/conf.c +++ b/sys/arch/i386/i386/conf.c @@ -1,4 +1,4 @@ -/* $OpenBSD: conf.c,v 1.62 2000/09/26 14:03:53 art Exp $ */ +/* $OpenBSD: conf.c,v 1.63 2001/01/30 00:00:31 aaron Exp $ */ /* $NetBSD: conf.c,v 1.75 1996/05/03 19:40:20 christos Exp $ */ /* @@ -167,7 +167,7 @@ cdev_decl(spkr); cdev_decl(mms); #include "lms.h" cdev_decl(lms); -#include "pms.h" +#include "opms.h" cdev_decl(pms); #include "cy.h" cdev_decl(cy); @@ -221,6 +221,11 @@ cdev_decl(ucom); #error vt and pc are mutually exclusive. Sorry. #endif +#include "wsdisplay.h" +#include "wskbd.h" +#include "wsmouse.h" +#include "wsmux.h" +cdev_decl(wsmux); struct cdevsw cdevsw[] = { @@ -240,7 +245,11 @@ struct cdevsw cdevsw[] = cdev_disk_init(NFD,fd), /* 9: floppy disk */ cdev_tape_init(NWT,wt), /* 10: QIC-02/QIC-36 tape */ cdev_disk_init(NSCD,scd), /* 11: Sony CD-ROM */ +#if 0 cdev_pc_init(NPC + NVT,pc), /* 12: PC console */ +#endif + cdev_wsdisplay_init(NWSDISPLAY, /* 12: frame buffers, etc. */ + wsdisplay), cdev_disk_init(NSD,sd), /* 13: SCSI disk */ cdev_tape_init(NST,st), /* 14: SCSI tape */ cdev_disk_init(NCD,cd), /* 15: SCSI CD-ROM */ @@ -269,7 +278,7 @@ struct cdevsw cdevsw[] = cdev_lkm_dummy(), /* 34 */ cdev_mouse_init(NMMS,mms), /* 35: Microsoft mouse */ cdev_mouse_init(NLMS,lms), /* 36: Logitech mouse */ - cdev_mousewr_init(NPMS,pms), /* 37: Extended PS/2 mouse */ + cdev_mousewr_init(NOPMS,pms), /* 37: Extended PS/2 mouse */ cdev_tty_init(NCY,cy), /* 38: Cyclom serial port */ cdev_disk_init(NMCD,mcd), /* 39: Mitsumi CD-ROM */ cdev_bpftun_init(NTUN,tun), /* 40: network tunnel */ @@ -309,6 +318,10 @@ struct cdevsw cdevsw[] = cdev_ulpt_init(NULPT,ulpt), /* 64: USB printers */ cdev_usbdev_init(NURIO,urio), /* 65: USB Diamond Rio 500 */ cdev_tty_init(NUCOM,ucom), /* 66: USB tty */ + cdev_mouse_init(NWSKBD, wskbd), /* 67: keyboards */ + cdev_mouse_init(NWSMOUSE, /* 68: mice */ + wsmouse), + cdev_mouse_init(NWSMUX, wsmux), /* 69: ws multiplexor */ }; int nchrdev = sizeof(cdevsw) / sizeof(cdevsw[0]); diff --git a/sys/arch/i386/i386/machdep.c b/sys/arch/i386/i386/machdep.c index f2beaff611e..4848eec8e58 100644 --- a/sys/arch/i386/i386/machdep.c +++ b/sys/arch/i386/i386/machdep.c @@ -1,4 +1,4 @@ -/* $OpenBSD: machdep.c,v 1.146 2001/01/25 18:49:33 mickey Exp $ */ +/* $OpenBSD: machdep.c,v 1.147 2001/01/30 00:00:31 aaron Exp $ */ /* $NetBSD: machdep.c,v 1.214 1996/11/10 03:16:17 thorpej Exp $ */ /*- @@ -172,6 +172,37 @@ extern struct proc *npxproc; #endif +#include "vga.h" +#include "ega.h" +#include "pcdisplay.h" +#if (NVGA > 0) || (NEGA > 0) || (NPCDISPLAY > 0) +#include <dev/ic/mc6845reg.h> +#include <dev/ic/pcdisplayvar.h> +#if (NVGA > 0) +#include <dev/ic/vgareg.h> +#include <dev/ic/vgavar.h> +#endif +#if (NEGA > 0) +#include <dev/isa/egavar.h> +#endif +#if (NPCDISPLAY > 0) +#include <dev/isa/pcdisplayvar.h> +#endif +#endif + +#include "pckbc.h" +#if (NPCKBC > 0) +#include <dev/isa/isareg.h> +#include <dev/ic/i8042reg.h> +#include <dev/ic/pckbcvar.h> +#endif +#include "pckbd.h" /* for pckbc_machdep_cnattach */ + +#include "pc.h" +#if (NPC > 0) +#include <machine/pccons.h> +#endif + #include "bios.h" #include "com.h" #include "pccom.h" @@ -2067,9 +2098,6 @@ init386(first_avail) (caddr_t)iomem_ex_storage, sizeof(iomem_ex_storage), EX_NOCOALESCE|EX_NOWAIT); - consinit(); /* XXX SHOULD NOT BE DONE HERE */ - /* XXX here, until we can use bios for printfs */ - /* make gdt gates and memory segments */ setsegment(&gdt[GCODE_SEL].sd, 0, 0xfffff, SDT_MEMERA, SEL_KPL, 1, 1); setsegment(&gdt[GICODE_SEL].sd, 0, 0xfffff, SDT_MEMERA, SEL_KPL, 1, 1); @@ -2121,6 +2149,9 @@ init386(first_avail) isa_defaultirq(); #endif + consinit(); /* XXX SHOULD NOT BE DONE HERE */ + /* XXX here, until we can use bios for printfs */ + /* call pmap initialization to make new kernel address space */ pmap_bootstrap((vm_offset_t)atdevbase + IOM_SIZE); @@ -2359,9 +2390,52 @@ consinit() if (initted) return; initted = 1; +#if 0 cninit(); +#endif + +#if (NPC > 0) || (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 (NPC > 0) + pccnattach(); +#endif + if (0) goto dokbd; /* XXX stupid gcc */ +dokbd: +#if (NPCKBC > 0) + pckbc_cnattach(I386_BUS_SPACE_IO, IO_KBD, KBCMDP, PCKBC_KBD_SLOT); +#endif /* PC | VT | VGA | PCDISPLAY */ } +#if (NPCKBC > 0) && (NPCKBD == 0) +/* + * glue code to support old console code with the + * mi keyboard controller driver + */ +int +pckbc_machdep_cnattach(kbctag, kbcslot) + pckbc_tag_t kbctag; + pckbc_slot_t kbcslot; +{ +#if (NPC > 0) && (NPCCONSKBD > 0) + return (pcconskbd_cnattach(kbctag, kbcslot)); +#else + return (ENXIO); +#endif +} +#endif +#endif + #ifdef KGDB void kgdb_port_init() diff --git a/sys/arch/i386/include/pccons.h b/sys/arch/i386/include/pccons.h index c20385c4831..372f9ab331c 100644 --- a/sys/arch/i386/include/pccons.h +++ b/sys/arch/i386/include/pccons.h @@ -1,4 +1,4 @@ -/* $OpenBSD: pccons.h,v 1.5 1997/03/03 12:01:17 downsj Exp $ */ +/* $OpenBSD: pccons.h,v 1.6 2001/01/30 00:00:32 aaron Exp $ */ /* $NetBSD: pccons.h,v 1.4 1996/02/02 18:06:06 mycroft Exp $ */ /* @@ -43,4 +43,13 @@ typedef struct { #define CONSOLE_SET_KEYMAP _IOW('t',129,pccons_keymap_t[KB_NUM_KEYS]) #define CONSOLE_SET_BLANK _IOW('t',130,int) +#ifdef _KERNEL +int pccnattach __P((void)); + +#if (NPCCONSKBD > 0) +int pcconskbd_cnattach _P((pckbc_tag_t, pckbc_slot_t)); +#endif + +#endif /* _KERNEL */ + #endif /* _PCCONS_H_ */ diff --git a/sys/arch/i386/include/types.h b/sys/arch/i386/include/types.h index 9a2548558f8..e634cc7ceaf 100644 --- a/sys/arch/i386/include/types.h +++ b/sys/arch/i386/include/types.h @@ -1,5 +1,5 @@ /* $NetBSD: types.h,v 1.12 1995/12/24 01:08:03 mycroft Exp $ */ -/* $OpenBSD: types.h,v 1.7 1999/07/07 23:16:40 art Exp $ */ +/* $OpenBSD: types.h,v 1.8 2001/01/30 00:00:32 aaron Exp $ */ /*- * Copyright (c) 1990 The Regents of the University of California. @@ -82,4 +82,6 @@ typedef unsigned long long uint64_t; typedef int32_t register_t; +#define __HAVE_NWSCONS + #endif /* _MACHTYPES_H_ */ |