d471ccf3aa
dispatch mechanism to the rest of the kernel; they don't need to know. Nuke IRQSTATS entirely. XXX ofwgencfg_clock needs to taught about timecounters
130 lines
3.7 KiB
C
130 lines
3.7 KiB
C
/* $NetBSD: ofisapc.c,v 1.7 2007/03/08 20:48:39 matt Exp $ */
|
|
|
|
/*
|
|
* Copyright 1997
|
|
* Digital Equipment Corporation. All rights reserved.
|
|
*
|
|
* This software is furnished under license and may be used and
|
|
* copied only in accordance with the following terms and conditions.
|
|
* Subject to these conditions, you may download, copy, install,
|
|
* use, modify and distribute this software in source and/or binary
|
|
* form. No title or ownership is transferred hereby.
|
|
*
|
|
* 1) Any source code used, modified or distributed must reproduce
|
|
* and retain this copyright notice and list of conditions as
|
|
* they appear in the source file.
|
|
*
|
|
* 2) No right is granted to use any trade name, trademark, or logo of
|
|
* Digital Equipment Corporation. Neither the "Digital Equipment
|
|
* Corporation" name nor any trademark or logo of Digital Equipment
|
|
* Corporation may be used to endorse or promote products derived
|
|
* from this software without the prior written permission of
|
|
* Digital Equipment Corporation.
|
|
*
|
|
* 3) This software is provided "AS-IS" and any express or implied
|
|
* warranties, including but not limited to, any implied warranties
|
|
* of merchantability, fitness for a particular purpose, or
|
|
* non-infringement are disclaimed. In no event shall DIGITAL be
|
|
* liable for any damages whatsoever, and in particular, DIGITAL
|
|
* shall not be liable for special, indirect, consequential, or
|
|
* incidental damages or damages for lost profits, loss of
|
|
* revenue or loss of use, whether such damages arise in contract,
|
|
* negligence, tort, under statute, in equity, at law or otherwise,
|
|
* even if advised of the possibility of such damage.
|
|
*/
|
|
|
|
/*
|
|
* OFW Glue for PCCONS Driver
|
|
*/
|
|
|
|
#include <sys/cdefs.h>
|
|
__KERNEL_RCSID(0, "$NetBSD: ofisapc.c,v 1.7 2007/03/08 20:48:39 matt Exp $");
|
|
|
|
#include <sys/param.h>
|
|
#include <sys/device.h>
|
|
#include <sys/systm.h>
|
|
|
|
#include <machine/intr.h>
|
|
#include <machine/irqhandler.h>
|
|
|
|
#include <dev/ofw/openfirm.h>
|
|
#include <dev/isa/isavar.h>
|
|
#include <shark/shark/i8042reg.h>
|
|
#include <shark/shark/ns87307reg.h>
|
|
|
|
|
|
int ofisapcprobe __P((struct device *, struct cfdata *, void *));
|
|
void ofisapcattach __P((struct device *, struct device *, void *));
|
|
|
|
|
|
CFATTACH_DECL(ofisapc, sizeof(struct device),
|
|
ofisapcprobe, ofisapcattach, NULL, NULL);
|
|
|
|
extern struct cfdriver ofisapc_cd;
|
|
|
|
|
|
int
|
|
ofisapcprobe(parent, cf, aux)
|
|
struct device *parent;
|
|
struct cfdata *cf;
|
|
void *aux;
|
|
{
|
|
struct ofbus_attach_args *oba = aux;
|
|
char type[64];
|
|
char name[64];
|
|
|
|
/* At a minimum, must match type and name properties. */
|
|
if ( OF_getprop(oba->oba_phandle, "device_type", type,
|
|
sizeof(type)) < 0 || strcmp(type, "keyboard") != 0 ||
|
|
OF_getprop(oba->oba_phandle, "name", name, sizeof(name)) < 0 ||
|
|
strcmp(name, "keyboard") != 0)
|
|
return 0;
|
|
|
|
/* Better than a generic match. */
|
|
return 2;
|
|
}
|
|
|
|
|
|
void
|
|
ofisapcattach(parent, dev, aux)
|
|
struct device *parent, *dev;
|
|
void *aux;
|
|
{
|
|
struct ofbus_attach_args *oba = aux;
|
|
static struct isa_attach_args ia;
|
|
struct isa_io ia_io[1];
|
|
struct isa_irq ia_irq[1];
|
|
|
|
printf("\n");
|
|
|
|
#define BASE_KEYBOARD 0x60
|
|
|
|
/*
|
|
* Start with the Keyboard and mouse device configuration in the
|
|
* SuperIO H/W
|
|
*/
|
|
(void)i87307KbdConfig(&isa_io_bs_tag, BASE_KEYBOARD, IRQ_KEYBOARD);
|
|
(void)i87307MouseConfig (&isa_io_bs_tag, IRQ_MOUSE);
|
|
|
|
/* XXX - Hard-wire the ISA attach args for now. -JJK */
|
|
ia.ia_iot = &isa_io_bs_tag;
|
|
ia.ia_memt = &isa_mem_bs_tag;
|
|
ia.ia_ic = NULL; /* not used */
|
|
|
|
ia.ia_nio = 1;
|
|
ia.ia_io = ia_io;
|
|
ia.ia_io[0].ir_addr = BASE_KEYBOARD;
|
|
ia.ia_io[0].ir_size = I8042_NPORTS;
|
|
|
|
ia.ia_nirq = 1;
|
|
ia.ia_irq = ia_irq;
|
|
ia.ia_irq[0].ir_irq = IRQ_KEYBOARD;
|
|
|
|
ia.ia_niomem = 0;
|
|
ia.ia_ndrq = 0;
|
|
|
|
ia.ia_aux = (void *)oba->oba_phandle;
|
|
|
|
config_found(dev, &ia, NULL);
|
|
}
|