2006-05-23 06:10:54 +08:00
|
|
|
/* Addresses, interrupt numbers, register sizes */
|
|
|
|
|
|
|
|
#define SLAVIO_ZS 0x00000000
|
|
|
|
#define SLAVIO_ZS1 0x00100000
|
|
|
|
#define ZS_INTR 0x2c
|
|
|
|
#define ZS_REGS 8
|
|
|
|
|
|
|
|
#define SLAVIO_NVRAM 0x00200000
|
|
|
|
#define NVRAM_SIZE 0x2000
|
|
|
|
#define NVRAM_IDPROM 0x1fd8
|
|
|
|
|
|
|
|
#define SLAVIO_FD 0x00400000
|
|
|
|
#define FD_REGS 15
|
|
|
|
#define FD_INTR 0x2b
|
|
|
|
|
|
|
|
#define SLAVIO_SCONFIG 0x00800000
|
|
|
|
#define SCONFIG_REGS 1
|
|
|
|
|
|
|
|
#define SLAVIO_AUXIO 0x00900000
|
|
|
|
#define AUXIO_REGS 1
|
|
|
|
|
|
|
|
#define SLAVIO_POWER 0x00910000
|
|
|
|
#define POWER_REGS 1
|
|
|
|
#define POWER_INTR 0x22
|
|
|
|
|
|
|
|
#define SLAVIO_COUNTER 0x00d00000
|
|
|
|
#define COUNTER_REGS 0x10
|
|
|
|
|
|
|
|
#define SLAVIO_INTERRUPT 0x00e00000
|
|
|
|
#define INTERRUPT_REGS 0x10
|
|
|
|
|
|
|
|
#define SLAVIO_SIZE 0x01000000
|
|
|
|
|
|
|
|
struct qemu_nvram_v1 {
|
|
|
|
char id_string[16];
|
|
|
|
uint32_t version;
|
|
|
|
uint32_t nvram_size; // not used in Sun4m
|
|
|
|
char unused1[8];
|
|
|
|
char arch[12];
|
2006-06-07 06:23:04 +08:00
|
|
|
char curr_cpu;
|
2006-05-23 06:10:54 +08:00
|
|
|
char smp_cpus;
|
|
|
|
char unused2;
|
|
|
|
char nographic;
|
|
|
|
uint32_t ram_size;
|
|
|
|
char boot_device;
|
|
|
|
char unused3[3];
|
|
|
|
uint32_t kernel_image;
|
|
|
|
uint32_t kernel_size;
|
|
|
|
uint32_t cmdline;
|
|
|
|
uint32_t cmdline_size;
|
|
|
|
uint32_t initrd_image;
|
|
|
|
uint32_t initrd_size;
|
|
|
|
uint32_t nvram_image;
|
|
|
|
uint16_t width;
|
|
|
|
uint16_t height;
|
|
|
|
uint16_t depth;
|
|
|
|
char unused4[158];
|
|
|
|
uint16_t crc;
|
|
|
|
};
|
|
|
|
|
|
|
|
#define SUN4M_NCPUS 16
|
|
|
|
#define PAGE_SIZE 4096
|
|
|
|
|
|
|
|
/* linux/include/asm-sparc/timer.h */
|
|
|
|
|
|
|
|
/* A sun4m has two blocks of registers which are probably of the same
|
|
|
|
* structure. LSI Logic's L64851 is told to _decrement_ from the limit
|
|
|
|
* value. Aurora behaves similarly but its limit value is compacted in
|
|
|
|
* other fashion (it's wider). Documented fields are defined here.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* As with the interrupt register, we have two classes of timer registers
|
|
|
|
* which are per-cpu and master. Per-cpu timers only hit that cpu and are
|
|
|
|
* only level 14 ticks, master timer hits all cpus and is level 10.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#define SUN4M_PRM_CNT_L 0x80000000
|
|
|
|
#define SUN4M_PRM_CNT_LVALUE 0x7FFFFC00
|
|
|
|
|
|
|
|
struct sun4m_timer_percpu_info {
|
|
|
|
__volatile__ unsigned int l14_timer_limit; /* Initial value is 0x009c4000 */
|
|
|
|
__volatile__ unsigned int l14_cur_count;
|
|
|
|
|
|
|
|
/* This register appears to be write only and/or inaccessible
|
|
|
|
* on Uni-Processor sun4m machines.
|
|
|
|
*/
|
|
|
|
__volatile__ unsigned int l14_limit_noclear; /* Data access error is here */
|
|
|
|
|
|
|
|
__volatile__ unsigned int cntrl; /* =1 after POST on Aurora */
|
|
|
|
__volatile__ unsigned char space[PAGE_SIZE - 16];
|
|
|
|
};
|
|
|
|
|
|
|
|
struct sun4m_timer_regs {
|
|
|
|
struct sun4m_timer_percpu_info cpu_timers[SUN4M_NCPUS];
|
|
|
|
volatile unsigned int l10_timer_limit;
|
|
|
|
volatile unsigned int l10_cur_count;
|
|
|
|
|
|
|
|
/* Again, this appears to be write only and/or inaccessible
|
|
|
|
* on uni-processor sun4m machines.
|
|
|
|
*/
|
|
|
|
volatile unsigned int l10_limit_noclear;
|
|
|
|
|
|
|
|
/* This register too, it must be magic. */
|
|
|
|
volatile unsigned int foobar;
|
|
|
|
|
|
|
|
volatile unsigned int cfg; /* equals zero at boot time... */
|
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Registers of hardware timer in sun4m.
|
|
|
|
*/
|
|
|
|
struct sun4m_timer_percpu {
|
|
|
|
volatile unsigned int l14_timer_limit; /* Initial value is 0x009c4000 */
|
|
|
|
volatile unsigned int l14_cur_count;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct sun4m_timer_global {
|
|
|
|
volatile unsigned int l10_timer_limit;
|
|
|
|
volatile unsigned int l10_cur_count;
|
|
|
|
};
|
|
|
|
|
|
|
|
/* linux/include/asm-sparc/irq.h */
|
|
|
|
|
|
|
|
/* These registers are used for sending/receiving irqs from/to
|
|
|
|
* different cpu's.
|
|
|
|
*/
|
|
|
|
struct sun4m_intreg_percpu {
|
|
|
|
unsigned int tbt; /* Interrupts still pending for this cpu. */
|
|
|
|
|
|
|
|
/* These next two registers are WRITE-ONLY and are only
|
|
|
|
* "on bit" sensitive, "off bits" written have NO affect.
|
|
|
|
*/
|
|
|
|
unsigned int clear; /* Clear this cpus irqs here. */
|
|
|
|
unsigned int set; /* Set this cpus irqs here. */
|
|
|
|
unsigned char space[PAGE_SIZE - 12];
|
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
|
|
|
* djhr
|
|
|
|
* Actually the clear and set fields in this struct are misleading..
|
|
|
|
* according to the SLAVIO manual (and the same applies for the SEC)
|
|
|
|
* the clear field clears bits in the mask which will ENABLE that IRQ
|
|
|
|
* the set field sets bits in the mask to DISABLE the IRQ.
|
|
|
|
*
|
|
|
|
* Also the undirected_xx address in the SLAVIO is defined as
|
|
|
|
* RESERVED and write only..
|
|
|
|
*
|
|
|
|
* DAVEM_NOTE: The SLAVIO only specifies behavior on uniprocessor
|
|
|
|
* sun4m machines, for MP the layout makes more sense.
|
|
|
|
*/
|
|
|
|
struct sun4m_intregs {
|
|
|
|
struct sun4m_intreg_percpu cpu_intregs[SUN4M_NCPUS];
|
|
|
|
unsigned int tbt; /* IRQ's that are still pending. */
|
|
|
|
unsigned int irqs; /* Master IRQ bits. */
|
|
|
|
|
|
|
|
/* Again, like the above, two these registers are WRITE-ONLY. */
|
|
|
|
unsigned int clear; /* Clear master IRQ's by setting bits here. */
|
|
|
|
unsigned int set; /* Set master IRQ's by setting bits here. */
|
|
|
|
|
|
|
|
/* This register is both READ and WRITE. */
|
|
|
|
unsigned int undirected_target; /* Which cpu gets undirected irqs. */
|
|
|
|
};
|
|
|
|
|
|
|
|
/* Dave Redman (djhr@tadpole.co.uk)
|
|
|
|
* The sun4m interrupt registers.
|
|
|
|
*/
|
|
|
|
#define SUN4M_INT_ENABLE 0x80000000
|
|
|
|
#define SUN4M_INT_E14 0x00000080
|
|
|
|
#define SUN4M_INT_E10 0x00080000
|
|
|
|
|
|
|
|
#define SUN4M_HARD_INT(x) (0x000000001 << (x))
|
|
|
|
#define SUN4M_SOFT_INT(x) (0x000010000 << (x))
|
|
|
|
|
|
|
|
#define SUN4M_INT_MASKALL 0x80000000 /* mask all interrupts */
|
|
|
|
#define SUN4M_INT_MODULE_ERR 0x40000000 /* module error */
|
|
|
|
#define SUN4M_INT_M2S_WRITE 0x20000000 /* write buffer error */
|
|
|
|
#define SUN4M_INT_ECC 0x10000000 /* ecc memory error */
|
|
|
|
#define SUN4M_INT_FLOPPY 0x00400000 /* floppy disk */
|
|
|
|
#define SUN4M_INT_MODULE 0x00200000 /* module interrupt */
|
|
|
|
#define SUN4M_INT_VIDEO 0x00100000 /* onboard video */
|
|
|
|
#define SUN4M_INT_REALTIME 0x00080000 /* system timer */
|
|
|
|
#define SUN4M_INT_SCSI 0x00040000 /* onboard scsi */
|
|
|
|
#define SUN4M_INT_AUDIO 0x00020000 /* audio/isdn */
|
|
|
|
#define SUN4M_INT_ETHERNET 0x00010000 /* onboard ethernet */
|
|
|
|
#define SUN4M_INT_SERIAL 0x00008000 /* serial ports */
|
|
|
|
#define SUN4M_INT_KBDMS 0x00004000 /* keyboard/mouse */
|
|
|
|
#define SUN4M_INT_SBUSBITS 0x00003F80 /* sbus int bits */
|
|
|
|
|