1 /* Addresses, interrupt numbers, register sizes */
3 #define SLAVIO_ZS 0x00000000ULL
4 #define SLAVIO_ZS1 0x00100000ULL
7 #define SLAVIO_NVRAM 0x00200000ULL
8 #define NVRAM_SIZE 0x2000
9 #define NVRAM_IDPROM 0x1fd8
11 #define SLAVIO_FD 0x00400000ULL
15 #define SLAVIO_SCONFIG 0x00800000ULL
16 #define SCONFIG_REGS 1
21 #define AUXIO2_INTR 0x22
23 #define SLAVIO_COUNTER 0x00d00000ULL
24 #define COUNTER_REGS 0x10
26 #define SLAVIO_INTERRUPT 0x00e00000ULL
27 #define INTERRUPT_REGS 0x10
29 #define SLAVIO_RESET 0x00f00000ULL
32 #define ECC_BASE 0xf00000000ULL
35 #define SLAVIO_SIZE 0x01000000
37 #define SUN4M_NCPUS 16
39 #define CFG_ADDR 0xd00000510ULL
42 /* linux/include/asm-sparc/timer.h */
44 /* A sun4m has two blocks of registers which are probably of the same
45 * structure. LSI Logic's L64851 is told to _decrement_ from the limit
46 * value. Aurora behaves similarly but its limit value is compacted in
47 * other fashion (it's wider). Documented fields are defined here.
50 /* As with the interrupt register, we have two classes of timer registers
51 * which are per-cpu and master. Per-cpu timers only hit that cpu and are
52 * only level 14 ticks, master timer hits all cpus and is level 10.
55 #define SUN4M_PRM_CNT_L 0x80000000
56 #define SUN4M_PRM_CNT_LVALUE 0x7FFFFC00
58 struct sun4m_timer_percpu_info
{
59 __volatile__
unsigned int l14_timer_limit
; /* Initial value is 0x009c4000 */
60 __volatile__
unsigned int l14_cur_count
;
62 /* This register appears to be write only and/or inaccessible
63 * on Uni-Processor sun4m machines.
65 __volatile__
unsigned int l14_limit_noclear
; /* Data access error is here */
67 __volatile__
unsigned int cntrl
; /* =1 after POST on Aurora */
68 __volatile__
unsigned char space
[PAGE_SIZE
- 16];
71 struct sun4m_timer_regs
{
72 struct sun4m_timer_percpu_info cpu_timers
[SUN4M_NCPUS
];
73 volatile unsigned int l10_timer_limit
;
74 volatile unsigned int l10_cur_count
;
76 /* Again, this appears to be write only and/or inaccessible
77 * on uni-processor sun4m machines.
79 volatile unsigned int l10_limit_noclear
;
81 /* This register too, it must be magic. */
82 volatile unsigned int foobar
;
84 volatile unsigned int cfg
; /* equals zero at boot time... */
88 * Registers of hardware timer in sun4m.
90 struct sun4m_timer_percpu
{
91 volatile unsigned int l14_timer_limit
; /* Initial value is 0x009c4000 */
92 volatile unsigned int l14_cur_count
;
95 struct sun4m_timer_global
{
96 volatile unsigned int l10_timer_limit
;
97 volatile unsigned int l10_cur_count
;
100 /* linux/include/asm-sparc/irq.h */
102 /* These registers are used for sending/receiving irqs from/to
105 struct sun4m_intreg_percpu
{
106 unsigned int tbt
; /* Interrupts still pending for this cpu. */
108 /* These next two registers are WRITE-ONLY and are only
109 * "on bit" sensitive, "off bits" written have NO affect.
111 unsigned int clear
; /* Clear this cpus irqs here. */
112 unsigned int set
; /* Set this cpus irqs here. */
113 unsigned char space
[PAGE_SIZE
- 12];
118 * Actually the clear and set fields in this struct are misleading..
119 * according to the SLAVIO manual (and the same applies for the SEC)
120 * the clear field clears bits in the mask which will ENABLE that IRQ
121 * the set field sets bits in the mask to DISABLE the IRQ.
123 * Also the undirected_xx address in the SLAVIO is defined as
124 * RESERVED and write only..
126 * DAVEM_NOTE: The SLAVIO only specifies behavior on uniprocessor
127 * sun4m machines, for MP the layout makes more sense.
129 struct sun4m_intregs
{
130 struct sun4m_intreg_percpu cpu_intregs
[SUN4M_NCPUS
];
131 unsigned int tbt
; /* IRQ's that are still pending. */
132 unsigned int irqs
; /* Master IRQ bits. */
134 /* Again, like the above, two these registers are WRITE-ONLY. */
135 unsigned int clear
; /* Clear master IRQ's by setting bits here. */
136 unsigned int set
; /* Set master IRQ's by setting bits here. */
138 /* This register is both READ and WRITE. */
139 unsigned int undirected_target
; /* Which cpu gets undirected irqs. */
142 /* Dave Redman (djhr@tadpole.co.uk)
143 * The sun4m interrupt registers.
145 #define SUN4M_INT_ENABLE 0x80000000
146 #define SUN4M_INT_E14 0x00000080
147 #define SUN4M_INT_E10 0x00080000
149 #define SUN4M_HARD_INT(x) (0x000000001 << (x))
150 #define SUN4M_SOFT_INT(x) (0x000010000 << (x))
152 #define SUN4M_INT_MASKALL 0x80000000 /* mask all interrupts */
153 #define SUN4M_INT_MODULE_ERR 0x40000000 /* module error */
154 #define SUN4M_INT_M2S_WRITE 0x20000000 /* write buffer error */
155 #define SUN4M_INT_ECC 0x10000000 /* ecc memory error */
156 #define SUN4M_INT_FLOPPY 0x00400000 /* floppy disk */
157 #define SUN4M_INT_MODULE 0x00200000 /* module interrupt */
158 #define SUN4M_INT_VIDEO 0x00100000 /* onboard video */
159 #define SUN4M_INT_REALTIME 0x00080000 /* system timer */
160 #define SUN4M_INT_SCSI 0x00040000 /* onboard scsi */
161 #define SUN4M_INT_AUDIO 0x00020000 /* audio/isdn */
162 #define SUN4M_INT_ETHERNET 0x00010000 /* onboard ethernet */
163 #define SUN4M_INT_SERIAL 0x00008000 /* serial ports */
164 #define SUN4M_INT_KBDMS 0x00004000 /* keyboard/mouse */
165 #define SUN4M_INT_SBUSBITS 0x00003F80 /* sbus int bits */