1997-05-25 10:10:46 +04:00
|
|
|
/* $NetBSD: autoconf.h,v 1.8 1997/05/25 06:10:47 jonathan Exp $ */
|
1995-08-04 04:34:15 +04:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Copyright (c) 1994, 1995 Carnegie-Mellon University.
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* Author: Chris G. Demetriou
|
|
|
|
*
|
|
|
|
* Permission to use, copy, modify and distribute this software and
|
|
|
|
* its documentation is hereby granted, provided that both the copyright
|
|
|
|
* notice and this permission notice appear in all copies of the
|
|
|
|
* software, derivative works or modified versions, and any portions
|
|
|
|
* thereof, and that both notices appear in supporting documentation.
|
|
|
|
*
|
|
|
|
* CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS"
|
|
|
|
* CONDITION. CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND
|
|
|
|
* FOR ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE.
|
|
|
|
*
|
|
|
|
* Carnegie Mellon requests users of this software to return to
|
|
|
|
*
|
|
|
|
* Software Distribution Coordinator or Software.Distribution@CS.CMU.EDU
|
|
|
|
* School of Computer Science
|
|
|
|
* Carnegie Mellon University
|
|
|
|
* Pittsburgh PA 15213-3890
|
|
|
|
*
|
|
|
|
* any improvements or extensions that they make and grant Carnegie the
|
|
|
|
* rights to redistribute these changes.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Machine-dependent structures of autoconfiguration
|
|
|
|
*/
|
|
|
|
|
1996-01-30 01:52:15 +03:00
|
|
|
#include <machine/tc_machdep.h>
|
|
|
|
|
1995-08-04 04:34:15 +04:00
|
|
|
struct confargs;
|
|
|
|
|
1996-04-14 04:58:21 +04:00
|
|
|
|
1995-08-04 04:34:15 +04:00
|
|
|
/* Handle device interrupt for given unit of a driver */
|
|
|
|
|
1995-09-20 08:33:00 +04:00
|
|
|
typedef void* intr_arg_t; /* pointer to some softc */
|
|
|
|
typedef int (*intr_handler_t) __P((intr_arg_t));
|
1996-04-14 04:58:21 +04:00
|
|
|
/*
|
|
|
|
* XXX Establish interrupt on an arbitrary decstation/decsystem bus.
|
|
|
|
*/
|
|
|
|
extern void
|
|
|
|
generic_intr_establish __P(( void * parent, void * cookie,
|
|
|
|
int level,
|
|
|
|
intr_handler_t handler, intr_arg_t arg));
|
|
|
|
|
1995-08-04 04:34:15 +04:00
|
|
|
|
1996-01-30 01:52:15 +03:00
|
|
|
#define KN02_ASIC_NAME "KN02 " /* ROM name in 3max system slot */
|
1995-08-04 04:34:15 +04:00
|
|
|
|
1996-03-18 04:47:06 +03:00
|
|
|
#define INTR_ESTABLISH(parent, cookie, level, handler, val) \
|
|
|
|
generic_intr_establish((parent), (cookie), (level), (handler), (val))
|
|
|
|
|
|
|
|
#define BUS_INTR_ESTABLISH(ca, handler, val) \
|
|
|
|
generic_intr_establish( ((struct device*)(val))->dv_parent, \
|
1996-04-14 04:58:21 +04:00
|
|
|
(void*)(ca)->ca_slotpri, 0, (handler), (val))
|
1996-01-30 01:52:15 +03:00
|
|
|
|
1995-08-04 04:34:15 +04:00
|
|
|
|
|
|
|
struct confargs {
|
1996-05-29 10:19:49 +04:00
|
|
|
char *ca_name; /* Device name. */
|
1995-08-04 04:34:15 +04:00
|
|
|
int ca_slot; /* Device slot (table entry). */
|
|
|
|
int ca_offset; /* Offset into slot. */
|
1996-01-30 01:52:15 +03:00
|
|
|
tc_addr_t ca_addr; /* Device address. */
|
1996-01-11 08:57:04 +03:00
|
|
|
int ca_slotpri; /* Device interrupt "priority" */
|
1995-08-04 04:34:15 +04:00
|
|
|
};
|
|
|
|
|
1996-01-30 01:52:15 +03:00
|
|
|
extern caddr_t baseboard_cvtaddr __P((struct confargs *)); /*XXX*/
|
1995-09-20 08:33:00 +04:00
|
|
|
|
1995-08-04 04:34:15 +04:00
|
|
|
#ifndef pmax
|
|
|
|
void set_clockintr __P((void (*)(struct clockframe *)));
|
|
|
|
#endif
|
|
|
|
void set_iointr __P((void (*)(void *, int)));
|
|
|
|
int badaddr __P((void *, u_int));
|
1997-05-25 10:10:46 +04:00
|
|
|
void configure __P((void));
|
|
|
|
void makebootdev __P((char *cp));
|