sbscdvar.h revision 1.1 1 /* $NetBSD: sbscdvar.h,v 1.1 2002/03/05 23:46:43 simonb Exp $ */
2
3 /*
4 * Copyright 2000, 2001
5 * Broadcom Corporation. All rights reserved.
6 *
7 * This software is furnished under license and may be used and copied only
8 * in accordance with the following terms and conditions. Subject to these
9 * conditions, you may download, copy, install, use, modify and distribute
10 * modified or unmodified copies of this software in source and/or binary
11 * form. No title or ownership is transferred hereby.
12 *
13 * 1) Any source code used, modified or distributed must reproduce and
14 * retain this copyright notice and list of conditions as they appear in
15 * the source file.
16 *
17 * 2) No right is granted to use any trade name, trademark, or logo of
18 * Broadcom Corporation. Neither the "Broadcom Corporation" name nor any
19 * trademark or logo of Broadcom Corporation may be used to endorse or
20 * promote products derived from this software without the prior written
21 * permission of Broadcom Corporation.
22 *
23 * 3) THIS SOFTWARE IS PROVIDED "AS-IS" AND ANY EXPRESS OR IMPLIED
24 * WARRANTIES, INCLUDING BUT NOT LIMITED TO, ANY IMPLIED WARRANTIES OF
25 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, OR
26 * NON-INFRINGEMENT ARE DISCLAIMED. IN NO EVENT SHALL BROADCOM BE LIABLE
27 * FOR ANY DAMAGES WHATSOEVER, AND IN PARTICULAR, BROADCOM SHALL NOT BE
28 * LIABLE FOR DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
29 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
30 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
31 * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
32 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
33 * OR OTHERWISE), EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
34 */
35
36 /* sbscd pseudo-offset (from base) of an SCD sub-device */
37 typedef u_int sbscd_offset;
38
39 /* type of an on-board device. Matches table in sbscd.c */
40 enum sbscd_device_type {
41 SBSCD_DEVTYPE_ICU = 0, /* Interrupt controller/mapper */
42 SBSCD_DEVTYPE_WDOG, /* watchdog timer */
43 SBSCD_DEVTYPE_TIMER, /* general-purpose timer */
44 SBSCD_DEVTYPE_JTAGCONS, /* JTAG console (mem-mapped I/O) */
45 };
46
47 /* autoconfiguration match information for zbbus children */
48 struct sbscd_attach_locs {
49 sbscd_offset sa_offset;
50 u_int sa_intr[2];
51 enum sbscd_device_type sa_type;
52 };
53
54 struct sbscd_attach_args {
55 struct sbscd_attach_locs sa_locs;
56
57 long sa_base;
58 };
59