You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
187 lines
6.6 KiB
187 lines
6.6 KiB
/*----------------------------------------------------------------------*
|
|
* cyclomz.h: Cyclades-Z hardware-related definitions. *
|
|
* *
|
|
* Copyright (C) Cyclades Corporation, 1996. *
|
|
* All Rights Reserved. *
|
|
* *
|
|
* revision 1.0 03/14/95 Marcio Saito *
|
|
* revision 2.0 01/04/96 Marcio Saito Changes due to HW design *
|
|
* alterations. *
|
|
* revision 2.1 03/15/96 Marcio Saito Changes due to HW design *
|
|
* alterations. *
|
|
* revision 3.0 04/11/97 Ivan Passos Changes to support the *
|
|
* new boards (8Zo and Ze). *
|
|
*----------------------------------------------------------------------*/
|
|
|
|
/*
|
|
* The data types defined below are used in all ZFIRM interface
|
|
* data structures. They accomodate differences between HW
|
|
* architectures and compilers.
|
|
*/
|
|
|
|
typedef unsigned long uclong; /* 32 bits, unsigned */
|
|
typedef unsigned short ucshort; /* 16 bits, unsigned */
|
|
typedef unsigned char ucchar; /* 8 bits, unsigned */
|
|
|
|
/*
|
|
* Memory Window Sizes
|
|
*/
|
|
|
|
#define DP_WINDOW_SIZE (0x00080000) /* window size 512 Kb */
|
|
#define ZE_DP_WINDOW_SIZE (0x00100000) /* window size 1 Mb (for the
|
|
Ze V_1 and 8Zo V_2) */
|
|
#define CTRL_WINDOW_SIZE (0x00000080) /* runtime regs 128 bytes */
|
|
|
|
/*
|
|
* CUSTOM_REG - Cyclades-8Zo/PCI Custom Registers Set. The driver
|
|
* normally will access only interested on the fpga_id, fpga_version,
|
|
* start_cpu and stop_cpu.
|
|
*/
|
|
|
|
struct CUSTOM_REG {
|
|
uclong fpga_id; /* FPGA Identification Register */
|
|
uclong fpga_version; /* FPGA Version Number Register */
|
|
uclong cpu_start; /* CPU start Register (write) */
|
|
uclong cpu_stop; /* CPU stop Register (write) */
|
|
uclong misc_reg; /* Miscelaneous Register */
|
|
uclong idt_mode; /* IDT mode Register */
|
|
uclong uart_irq_status; /* UART IRQ status Register */
|
|
uclong clear_timer0_irq; /* Clear timer interrupt Register */
|
|
uclong clear_timer1_irq; /* Clear timer interrupt Register */
|
|
uclong clear_timer2_irq; /* Clear timer interrupt Register */
|
|
uclong test_register; /* Test Register */
|
|
uclong test_count; /* Test Count Register */
|
|
uclong timer_select; /* Timer select register */
|
|
uclong pr_uart_irq_status; /* Prioritized UART IRQ stat Reg */
|
|
uclong ram_wait_state; /* RAM wait-state Register */
|
|
uclong uart_wait_state; /* UART wait-state Register */
|
|
uclong timer_wait_state; /* timer wait-state Register */
|
|
uclong ack_wait_state; /* ACK wait State Register */
|
|
};
|
|
|
|
/*
|
|
* CUSTOM_REG_ZE - Cyclades-Ze/PCI Custom Registers Set. The driver
|
|
* normally will access only interested on the fpga_id, fpga_version,
|
|
* start_cpu and stop_cpu.
|
|
*/
|
|
|
|
struct CUSTOM_REG_ZE {
|
|
uclong fpga_id; /* FPGA Identification Register */
|
|
uclong fpga_version; /* FPGA Version Number Register */
|
|
uclong cpu_start; /* CPU start Register (write) */
|
|
uclong cpu_stop; /* CPU stop Register (write) */
|
|
uclong cpu_ctrl;
|
|
uclong zbus_wait; /* Z-Bus wait states */
|
|
uclong timer_div; /* Timer divider */
|
|
uclong timer_irq_ack; /* Write anything to ack/clear Timer
|
|
Interrupt Register */
|
|
};
|
|
|
|
|
|
/*
|
|
* RUNTIME_9060 - PLX PCI9060ES local configuration and shared runtime
|
|
* registers. This structure can be used to access the 9060 registers
|
|
* (memory mapped).
|
|
*/
|
|
|
|
struct RUNTIME_9060 {
|
|
uclong loc_addr_range; /* 00h - Local Address Range */
|
|
uclong loc_addr_base; /* 04h - Local Address Base */
|
|
uclong loc_arbitr; /* 08h - Local Arbitration */
|
|
uclong endian_descr; /* 0Ch - Big/Little Endian Descriptor */
|
|
uclong loc_rom_range; /* 10h - Local ROM Range */
|
|
uclong loc_rom_base; /* 14h - Local ROM Base */
|
|
uclong loc_bus_descr; /* 18h - Local Bus descriptor */
|
|
uclong loc_range_mst; /* 1Ch - Local Range for Master to PCI */
|
|
uclong loc_base_mst; /* 20h - Local Base for Master PCI */
|
|
uclong loc_range_io; /* 24h - Local Range for Master IO */
|
|
uclong pci_base_mst; /* 28h - PCI Base for Master PCI */
|
|
uclong pci_conf_io; /* 2Ch - PCI configuration for Master IO */
|
|
uclong filler1; /* 30h */
|
|
uclong filler2; /* 34h */
|
|
uclong filler3; /* 38h */
|
|
uclong filler4; /* 3Ch */
|
|
uclong mail_box_0; /* 40h - Mail Box 0 */
|
|
uclong mail_box_1; /* 44h - Mail Box 1 */
|
|
uclong mail_box_2; /* 48h - Mail Box 2 */
|
|
uclong mail_box_3; /* 4Ch - Mail Box 3 */
|
|
uclong filler5; /* 50h */
|
|
uclong filler6; /* 54h */
|
|
uclong filler7; /* 58h */
|
|
uclong filler8; /* 5Ch */
|
|
uclong pci_doorbell; /* 60h - PCI to Local Doorbell */
|
|
uclong loc_doorbell; /* 64h - Local to PCI Doorbell */
|
|
uclong intr_ctrl_stat; /* 68h - Interrupt Control/Status */
|
|
uclong init_ctrl; /* 6Ch - EEPROM control, Init Control, etc */
|
|
};
|
|
|
|
/* Values for the Local Base Address re-map register */
|
|
|
|
#define WIN_RAM 0x00000001L /* set the sliding window to RAM */
|
|
#define WIN_CREG 0x14000001L /* set the window to custom Registers */
|
|
|
|
/* Values timer select registers */
|
|
|
|
#define TIMER_BY_1M 0x00 /* clock divided by 1M */
|
|
#define TIMER_BY_256K 0x01 /* clock divided by 256k */
|
|
#define TIMER_BY_128K 0x02 /* clock divided by 128k */
|
|
#define TIMER_BY_32K 0x03 /* clock divided by 32k */
|
|
|
|
/*
|
|
* Starting from here, the compilation is conditional to the definition
|
|
* of FIRMWARE
|
|
*/
|
|
|
|
#ifdef FIRMWARE
|
|
|
|
struct RUNTIME_9060_FW {
|
|
uclong mail_box_0; /* 40h - Mail Box 0 */
|
|
uclong mail_box_1; /* 44h - Mail Box 1 */
|
|
uclong mail_box_2; /* 48h - Mail Box 2 */
|
|
uclong mail_box_3; /* 4Ch - Mail Box 3 */
|
|
uclong filler5; /* 50h */
|
|
uclong filler6; /* 54h */
|
|
uclong filler7; /* 58h */
|
|
uclong filler8; /* 5Ch */
|
|
uclong pci_doorbell; /* 60h - PCI to Local Doorbell */
|
|
uclong loc_doorbell; /* 64h - Local to PCI Doorbell */
|
|
uclong intr_ctrl_stat; /* 68h - Interrupt Control/Status */
|
|
uclong init_ctrl; /* 6Ch - EEPROM control, Init Control, etc */
|
|
};
|
|
|
|
/* Hardware related constants */
|
|
|
|
#define ZF_UART_PTR (0xb0000000UL)
|
|
#define ZF_UART_SPACE 0x00000080UL
|
|
#define ZF_UART_CLOCK 7372800
|
|
|
|
#define ZO_V1_FPGA_ID 0x95
|
|
#define ZO_V2_FPGA_ID 0x84
|
|
#define ZE_V1_FPGA_ID 0x89
|
|
|
|
#define ZF_TIMER_PTR (0xb2000000UL)
|
|
|
|
#define ZF_9060_PTR (0xb6000000UL)
|
|
#define ZF_9060_ZE_PTR (0xb8000000UL)
|
|
#define ZF_CUSTOM_PTR (0xb4000000UL)
|
|
|
|
#define ZF_NO_CACHE (0xa0000000UL)
|
|
#define ZF_CACHE (0x80000000UL)
|
|
|
|
#define ZF_I_TIMER (EXT_INT0)
|
|
#define ZF_I_SERIAL (EXT_INT2)
|
|
#define ZF_I_HOST (EXT_INT3)
|
|
#define ZF_I_ALL (EXT_INT0|EXT_INT2|EXT_INT3)
|
|
#define ZF_I_TOTAL (EXT_INT0|EXT_INT1|EXT_INT2|EXT_INT3|EXT_INT4|EXT_INT5)
|
|
|
|
#define ZF_IRQ03 0xfffffffeUL
|
|
#define ZF_IRQ05 0xfffffffdUL
|
|
#define ZF_IRQ09 0xfffffffbUL
|
|
#define ZF_IRQ10 0xfffffff7UL
|
|
#define ZF_IRQ11 0xffffffefUL
|
|
#define ZF_IRQ12 0xffffffdfUL
|
|
#define ZF_IRQ15 0xffffffbfUL
|
|
|
|
#endif /* FIRMWARE */
|
|
|
|
|