fhpibreg.h revision 1.4 1 /* $NetBSD: fhpibreg.h,v 1.4 1994/10/26 07:23:45 cgd Exp $ */
2
3 /*
4 * Copyright (c) 1982, 1990, 1993
5 * The Regents of the University of California. All rights reserved.
6 *
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted provided that the following conditions
9 * are met:
10 * 1. Redistributions of source code must retain the above copyright
11 * notice, this list of conditions and the following disclaimer.
12 * 2. Redistributions in binary form must reproduce the above copyright
13 * notice, this list of conditions and the following disclaimer in the
14 * documentation and/or other materials provided with the distribution.
15 * 3. All advertising materials mentioning features or use of this software
16 * must display the following acknowledgement:
17 * This product includes software developed by the University of
18 * California, Berkeley and its contributors.
19 * 4. Neither the name of the University nor the names of its contributors
20 * may be used to endorse or promote products derived from this software
21 * without specific prior written permission.
22 *
23 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
24 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
25 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
26 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
27 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
28 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
29 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
30 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
31 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
32 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
33 * SUCH DAMAGE.
34 *
35 * @(#)fhpibreg.h 8.1 (Berkeley) 6/10/93
36 */
37
38 #include <hp300/dev/iotypes.h> /* XXX */
39
40 struct fhpibdevice {
41 u_char hpib_pad0;
42 vu_char hpib_cid;
43 u_char hpib_pad1;
44 #define hpib_ie hpib_ids
45 vu_char hpib_ids;
46 u_char hpib_pad2;
47 vu_char hpib_ctrl2;
48 u_char hpib_pad3;
49 vu_char hpib_latch;
50 u_char hpib_pad4[9];
51 vu_char hpib_intr;
52 u_char hpib_pad5;
53 vu_char hpib_imask;
54 u_char hpib_pad6;
55 vu_char hpib_data;
56 u_char hpib_pad7;
57 vu_char hpib_stat;
58 u_char hpib_pad8;
59 vu_char hpib_cmd;
60 u_char hpib_pad9;
61 vu_char hpib_ar;
62 u_char hpib_pad10;
63 vu_char hpib_pmask;
64 u_char hpib_pad11;
65 vu_char hpib_psense;
66 };
67
68 /* status bits */
69 #define ST_READ0 0xC0
70 #define ST_READ1 0x80
71 #define ST_IENAB 0x80
72 #define ST_EOI 0x80
73 #define ST_ATN 0x40
74 #define ST_WRITE 0x00
75
76 /* control bits */
77 #define CT_8BIT 0x80
78 #define CT_REN 0x20
79 #define CT_IFC 0x10
80 #define CT_FIFOSEL 0x02
81 #define CT_INITFIFO 0x01
82
83 #define IM_PABORT 0x40
84 #define IM_PPRESP 0x20
85 #define IM_ROOM 0x08
86 #define IM_BYTE 0x04
87 #define IM_IDLE 0x02
88
89 #define AR_ARONC 0x80
90