1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
|
/* $OpenBSD: ebusreg.h,v 1.5 2007/04/04 18:38:54 kettenis Exp $ */
/* $NetBSD: ebusreg.h,v 1.1 1999/06/04 13:29:13 mrg Exp $ */
/*
* Copyright (c) 1999 Matthew R. Green
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* 3. The name of the author may not be used to endorse or promote products
* derived from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
* IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE.
*/
#ifndef _SPARC64_DEV_EBUSREG_H_
#define _SPARC64_DEV_EBUSREG_H_
/*
* UltraSPARC `ebus'
*
* The `ebus' bus is designed to plug traditional PC-ISA devices into
* an SPARC system with as few costs as possible, without sacrificing
* to performance. Typically, it is implemented in the PCIO IC from
* SME, which also implements a `hme-compatible' PCI network device
* (`network'). The ebus has 4 DMA channels, similar to the DMA seen
* in the ESP SCSI DMA.
*
* Typical UltraSPARC systems have a NatSemi SuperIO IC to provide
* serial ports for the keyboard and mouse (`se'), floppy disk
* controller (`fdthree'), parallel port controller (`bpp') connected
* to the ebus, and a PCI-IDE controller (connected directly to the
* PCI bus, of course), as well as a Siemens Nixdorf SAB82532 dual
* channel serial controller (`su' providing ttya and ttyb), an MK48T59
* EEPROM/clock controller (also where the idprom, including the
* ethernet address, is located), the audio system (`SUNW,CS4231', same
* as other UltraSPARC and some SPARC systems), and other various
* internal devices found on traditional SPARC systems such as the
* `power', `flashprom', etc., devices.
*
* The ebus uses an interrupt mapping scheme similar to PCI, though
* the actual structures are different.
*/
/*
* ebus PROM structures
*/
struct ebus_regs {
u_int32_t hi; /* high bits of physaddr */
u_int32_t lo;
u_int32_t size;
};
#define EBUS_PADDR_FROM_REG(reg) ((((paddr_t)((reg)->hi)) << 32UL) | ((paddr_t)(reg)->lo))
struct ebus_ranges {
u_int32_t child_hi; /* child high phys addr */
u_int32_t child_lo; /* child low phys addr */
u_int32_t phys_hi; /* parent high phys addr */
u_int32_t phys_mid; /* parent mid phys addr */
u_int32_t phys_lo; /* parent low phys addr */
u_int32_t size;
};
struct ebus_mainbus_ranges {
u_int32_t child_hi;
u_int32_t child_lo;
u_int32_t phys_hi;
u_int32_t phys_lo;
u_int32_t size;
};
struct ebus_interrupt_map {
u_int32_t hi; /* high phys addr mask */
u_int32_t lo; /* low phys addr mask */
u_int32_t intr; /* interrupt mask */
int32_t cnode; /* child node */
u_int32_t cintr; /* child interrupt */
};
struct ebus_interrupt_map_mask {
u_int32_t hi; /* high phys addr */
u_int32_t lo; /* low phys addr */
u_int32_t intr; /* interrupt */
};
/* EBUS dma registers */
#define EBDMA_DCSR 0x0 /* control/status */
#define EBDMA_DADDR 0x4 /* DMA address */
#define EBDMA_DCNT 0x8 /* DMA count */
/* EBUS DMA control/status (EBDMA_DCSR) */
#define EBDCSR_INT 0x00000001 /* interrupt pending */
#define EBDCSR_ERR 0x00000002 /* error pending */
#define EBDCSR_DRAIN 0x00000004 /* drain */
#define EBDCSR_INTEN 0x00000010 /* interrupt enable */
#define EBDCSR_RESET 0x00000080 /* reset */
#define EBDCSR_WRITE 0x00000100 /* write */
#define EBDCSR_DMAEN 0x00000200 /* dma enable */
#define EBDCSR_CYC 0x00000400 /* cyc pending */
#define EBDCSR_DIAGRD 0x00000800 /* diagnostic read done */
#define EBDCSR_DIAGWR 0x00001000 /* diagnostic write done */
#define EBDCSR_CNTEN 0x00002000 /* count enable */
#define EBDCSR_TC 0x00004000 /* terminal count */
#define EBDCSR_CSRDRNDIS 0x00010000 /* disable csr drain */
#define EBDCSR_BURSTMASK 0x000c0000 /* burst size mask */
#define EBDCSR_BURST_1 0x00080000 /* burst 1 */
#define EBDCSR_BURST_4 0x00000000 /* burst 4 */
#define EBDCSR_BURST_8 0x00040000 /* burst 8 */
#define EBDCSR_BURST_16 0x000c0000 /* burst 16 */
#define EBDCSR_DIAGEN 0x00100000 /* enable diagnostics */
#define EBDCSR_ERRDIS 0x00400000 /* disable error pending */
#define EBDCSR_TCIDIS 0x00800000 /* disable TCI */
#define EBDCSR_NEXTEN 0x01000000 /* enable next */
#define EBDCSR_DMAON 0x02000000 /* dma on */
#define EBDCSR_A_LOADED 0x04000000 /* address loaded */
#define EBDCSR_NA_LOADED 0x08000000 /* next address loaded */
#define EBDCSR_DEVMASK 0xf0000000 /* device id mask */
#endif /* _SPARC64_DEV_EBUSREG_H_ */
|