diff options
Diffstat (limited to 'system/alpha/h')
72 files changed, 3875 insertions, 9667 deletions
diff --git a/system/alpha/h/DEC21040.h b/system/alpha/h/DEC21040.h deleted file mode 100644 index 993964ac2..000000000 --- a/system/alpha/h/DEC21040.h +++ /dev/null @@ -1,409 +0,0 @@ -#ifndef __DECCHIP21040_H_LOADED -#define __DECCHIP21040_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: DEC21040.h,v 1.1.1.1 1997/10/30 23:27:13 verghese Exp $ - */ - -/* - * MODULE DESCRIPTION: - * - * Parameters and logicals for AM79C960 drivers in EB64 monitor - * - * HISTORY: - * - * $Log: - * - */ - -#ifdef NEEDPCI - -#include "pci.h" - -/* The embedded Ethernet controller on the EB66 and EB64+ is a - * DECchip 21040 PCI device. - * - * Please see the PCI and DECchip 21040 literature for definitive lists - * and further detail. - * - */ - - -/***************************************************************************** - * General * - *****************************************************************************/ - -/* - * Maximum number of DECchip 21040s supported in the EB66 and - * 64+ monitors. This is assuming 1 embedded device and 2 PCI - * slots. Of course this changes if a bridge card is used. - */ - -#define DECCHIP21040_MAX_DEVICES 3 - -/***************************************************************************** - * ROM ID * - *****************************************************************************/ -/* - * As the ROM ID is only used by the DECchip 21040, then this information - * can go here. Note that this information is the same for both EB66 - * and EB64P. - * - * To read this device you must first write which page you want - * into the PAGE_REGISTER. The bit settings look like: - * - * SxxA AAAA - * - * Where S = 0 = BBRAM, S = 1 = Ethernet ID ROM. - * - * A AAAA select the high order address lines of the BBRAM - * and are ignored for the Ethernet ID ROM. - */ -#define PAGE_REGISTER 0xc00 -#define SELECT_ROMID 0x80 -#define ROMID_BASE 0x800 - -/***************************************************************************** - * CSRs, these exist in PCI I/O space * - *****************************************************************************/ -/* - * CSR offsets. - */ - -#define CSR0 0x0000 /* Bus Mode Register */ -#define CSR1 0x0008 /* Transmit Poll Demand */ -#define CSR2 0x0010 /* Receive Poll Demand */ -#define CSR3 0x0018 /* Rx Ring Base Address */ -#define CSR4 0x0020 /* Tx Ring Base Address */ -#define CSR5 0x0028 /* Status Register */ -#define CSR6 0x0030 /* Serial command register */ -#define CSR7 0x0038 /* Interrupt Mask register */ -#define CSR8 0x0040 /* Missed Frame counter */ -#define CSR9 0x0048 /* ENET ROM register */ -#define CSR10 0x0050 /* Data Diagnostic register */ -#define CSR11 0x0058 /* Full duplex register */ -#define CSR12 0x0060 /* SIA Status register */ -#define CSR13 0x0068 /* SIA connectivity register */ -#define CSR14 0x0070 /* SIA Tx Rx Register */ -#define CSR15 0x0078 /* SIA General register */ - -#define TDES1_ADD 0x0088 -#define RDES1_ADD 0x00B8 -#define PCI_DIAG 0x0178 - -/* - * CSR bit definitions (see the DECchip 21040 manual for details). - */ -#define CSR0_CAL 0x0000C000 /* 15:14 Cache alignment */ -#define CSR0_PBL 0x00003F00 /* 13:18 Programmable burst length */ -#define CSR0_BLE 0x00000080 /* Big/Little endian */ -#define CSR0_DSL 0x0000007C /* Descriptor Skip Length */ -#define CSR0_BAR 0x00000020 /* Bus Arbitration */ -#define CSR0_SWR 0x00000001 /* Software Reset */ - -#define CSR1_TPD 0x00000001 /* Transmit Poll Demand */ - -#define CSR2_RPD 0x00000001 /* Receive Poll Demand */ - -#define CSR3_RXB 0xFFFFFFFC /* Rx ring base address */ - -#define CSR4_TXB 0xFFFFFFFC /* Tx ring base address */ - -#define CSR5_EB 0x03800000 /* 25:23 Error Bits */ -#define CSR5_TS 0x00700000 /* 22:20 Transmission Process State */ -#define CSR5_RS 0x000E0000 /* 19:17 Receive Process State */ -#define CSR5_NIS 0x00010000 /* Normal interrupt Summary */ -#define CSR5_AIS 0x00008000 /* Abnormal interrupt Summary */ -#define CSR5_SE 0x00002000 /* System Error */ -#define CSR5_LNF 0x00001000 /* link fail */ -#define CSR5_FD 0x00000800 /* Full duplex short frame received */ -#define CSR5_AT 0x00000400 /* AUI/TP switch */ -#define CSR5_RWT 0x00000200 /* Receive watchdog time-out */ -#define CSR5_RPS 0x00000100 /* Receive process stopped */ -#define CSR5_RU 0x00000080 /* Receive buffer unavailable */ -#define CSR5_RI 0x00000040 /* Receive Interrupt */ -#define CSR5_UNF 0x00000020 /* Transmit underflow */ -#define CSR5_TJT 0x00000008 /* Transmit jabber timeout */ -#define CSR5_TU 0x00000004 /* Transmit buffer unavailable */ -#define CSR5_TPS 0x00000002 /* Transmit process stopped */ -#define CSR5_TI 0x00000001 /* Transmit interrupt */ - -#define CSR5_TS_SUSPENDED 0x00600000 /* 110: Transmit process suspended */ -#define CSR5_RS_SUSPENDED 0x00080000 /* 100: Receive process suspended */ - -#define CSR6_TR 0x0000C000 /* 15:14 Threshold control bits */ -#define CSR6_ST 0x00002000 /* Start/stop transmission */ -#define CSR6_FC 0x00001000 /* Force collision mode */ -#define CSR6_OM 0x00000C00 /* 11:10 Operating Mode */ -#define CSR6_FD 0x00000200 /* Full duplex operating mode */ -#define CSR6_FKD 0x00000100 /* Flaky oscillator disable */ -#define CSR6_PM 0x00000080 /* Pass All Multicast */ -#define CSR6_PR 0x00000040 /* Promiscuous mode */ -#define CSR6_SB 0x00000020 /* Start/Stop Backoff counter */ -#define CSR6_IF 0x00000010 /* Inverse filtering */ -#define CSR6_PB 0x00000008 /* Pass Bad frames */ -#define CSR6_SR 0x00000002 /* Start/Stop Receive */ -#define CSR6_HP 0x00000001 /* Hash/Perfect receive filtering mode - */ - -#define CSR7_NIM 0x00010000 /* Normal interrupt summary mask */ -#define CSR7_AIM 0x00008000 /* Abnormal interrupt summary mask */ -#define CSR7_SEM 0x00002000 /* System Error Mask */ -#define CSR7_LFM 0x00001000 /* Link fail mask */ -#define CSR7_FDM 0x00000800 /* Full Duplex mask */ -#define CSR7_ATM 0x00000400 /* AUI/TP switch mask */ -#define CSR7_RWM 0x00000200 /* Receive watchdog timeout mask */ -#define CSR7_RSM 0x00000100 /* Receive stopped mask */ -#define CSR7_RUM 0x00000080 /* Receive buffer unavailable mask */ -#define CSR7_RIM 0x00000040 /* Receive interrupt mask */ -#define CSR7_UNM 0x00000020 /* Underflow interrupt mask */ -#define CSR7_TJM 0x00000008 /* transmit jabber timeout mask */ -#define CSR7_TUM 0x00000004 /* transmit buffer unavailable mask */ -#define CSR7_TSM 0x00000002 /* transmission stopped mask */ -#define CSR7_TIM 0x00000001 /* transmit interrupt mask */ - -#define CSR8_MFO 0x00010000 /* Missed frame overflow */ -#define CSR8_MFC 0x0000FFFF /* Missed frame counter */ - -#define CSR9_DT 0x000000FF /* 7:0 Data */ -#define CSR9_DN 0x80000000 /* 31 Data not valid, 0 = valid */ - -#define CSR11_FD 0x0000FFFF /* 15:0 Full duplex auto configuration - * value */ -#define CSR12_PAUI 0x00000001 -#define CSR12_NCR 0x00000002 -#define CSR12_LKF 0x00000004 - -/* - * CSR13 - SIA programming. - */ -#define CSR13_SRL 0x00000001 /* SIA Reset r/w */ -#define CSR13_PS 0x00000002 /* Pin AUI/TP Selection r/w */ -#define CSR13_CAC 0x00000004 /* CSR Auto Configuration */ -#define CSR13_AUI 0x00000008 /* 10 Base T or AUI */ -#define CSR13_EDP 0x00000010 /* SIA PLL external input enable */ -#define CSR13_ENI 0x00000020 /* Encoder Input Mux */ -#define CSR13_SIM 0x00000040 /* Serial Interface Input Mux */ - -/***************************************************************************** - * Macros * - *****************************************************************************/ -#define _21040WriteCSR(device,csr,value) \ - (outportl((device)->PCI_IO_Base + (csr), (value))) - -#define _21040ReadCSR(device,csr) \ - (inportl((device)->PCI_IO_Base + (csr))) - -#define _21040ValidBuffer(buffer,size) \ - ( \ - (((unsigned long)(buffer) & 0x3) == 0) \ - && \ - ((unsigned long)(buffer) <= 0xFFFFFFFF) \ - && \ - (PCIValidAddress((unsigned char *) (buffer))) \ - && \ - (PCIValidAddress((unsigned char *) (buffer) + (size))) \ - ) - -/***************************************************************************** - * PCI Constants * - *****************************************************************************/ -/* - * The configuration registers for DECchip 21040 exist in PCI configuration - * space. The definitions for the standard fields are in pci.h, these - * definitions are 21040 specific. - */ -#define CFID 0x0000 /* Configuration ID */ -#define CFCS 0x0004 /* Configuration command/status */ -#define CFRV 0x0008 /* Configuration revision */ -#define CFLT 0x000C /* Configuration latency timer */ -#define CBIO 0x0010 /* Configuration base IO address */ - -#define CBIO_MIO 0x00000001 /* Memory I/O. 1 = I/O. */ -#define CSR_SIZE 0x400 /* you can work this out by writing - all F's to CBIO */ - -/***************************************************************************** - * Setup Frame, if needed * - *****************************************************************************/ -#define SETUP_FRAME_NEEDED 1 /* Do we need a setup frame? */ -#define SETUP_FRAME_SIZE 192 -#define SETUP_PHYSICAL_ADDRESS_OFFSET 156 -#define SETUP_HASH_FILTER_SIZE 128 -/***************************************************************************** - * Data Structures * - *****************************************************************************/ -/* - * TX descriptor. Must be longword aligned in memory. - */ -typedef struct { - union { - unsigned int tdes0; - struct { - unsigned int DE : 1; /* deferred */ - unsigned int UF : 1; /* underflow error */ - unsigned int LF : 1; /* link fail */ - unsigned int CC : 4; /* 6:3 Collision count */ - unsigned int HF : 1; /* Heartbeat fail */ - unsigned int EC : 1; /* excessive collisions */ - unsigned int LC : 1; /* late collisions */ - unsigned int NC : 1; /* no carrier */ - unsigned int LO : 1; /* loss of carrier */ - unsigned int unused_1 : 2; /* 13:12 */ - unsigned int TO : 1; /* transmit jabber timeout */ - unsigned int ES : 1; /* error summary */ - unsigned int unused_12 : 15; - /* 30:16 */ - unsigned int OWN : 1; /* Own bit, 1 = 21040 */ - } s_tdes0; - } u_tdes0; - union { - unsigned int tdes1; - struct { - unsigned int TBS1 : 11; /* 10:0 transmit buffer size 1 */ - unsigned int TBS2 : 11; /* 21:11 transmit buffer size 2 */ - unsigned int HP : 1; /* Hash/Perfect filtering */ - unsigned int DPD : 1; /* disable padding */ - unsigned int TCH : 1; /* Second address chained */ - unsigned int TER : 1; /* transmit end of ring */ - unsigned int AC : 1; /* add CRC disable */ - unsigned int SET : 1; /* setup packet */ - unsigned int IV : 1; /* inverse filtering */ - unsigned int FS : 1; /* First segment */ - unsigned int LS : 1; /* last segment */ - unsigned int IC : 1; /* interrupt on completion */ - - } s_tdes1; - } u_tdes1; - unsigned int tdes2; - unsigned int tdes3; -} DECCHIP_21040_TX_BD; - -/* - * Receive descriptor. Must be longword aligned in memory. - */ -typedef struct { - union { - unsigned int rdes0; - struct { - unsigned int OF : 1; /* overflow */ - unsigned int CE : 1; /* CRC error */ - unsigned int DB : 1; /* dribbling bit */ - unsigned int unused_1 : 1; /* 3 */ - unsigned int RJ : 1; /* Receive watchdog */ - unsigned int FT : 1; /* frame type */ - unsigned int CS : 1; /* collision seen */ - unsigned int TL : 1; /* frame too long */ - unsigned int LS : 1; /* last descriptor */ - unsigned int FS : 1; /* First descriptor */ - unsigned int MF : 1; /* Multicast frame */ - unsigned int RF : 1; /* runt frame */ - unsigned int DT : 2; /* 13:12 Data type */ - unsigned int LE : 1; /* length error */ - unsigned int ES : 1; /* error summary */ - unsigned int FL : 15; /* Frame Length */ - unsigned int OWN : 1; /* Own bit 1 = 21040 */ - } s_rdes0; - } u_rdes0; - union { - unsigned int rdes1; - struct { - unsigned int RBS1 : 11; /* 10:0 Buffer Size 1 */ - unsigned int RBS2 : 11; /* 21:11 Buffer Size 2 */ - unsigned int unused_1 : 2; /* 23:22 */ - unsigned int RCH : 1; /* Second address chained */ - unsigned int RER : 1; /* Receive end of ring */ - unsigned int unused_2 : 6; /* 31:26 */ - } s_rdes1; - } u_rdes1; - unsigned int rdes2; - unsigned int rdes3; -} DECCHIP_21040_RX_BD; - -/* - * Each device has a block of counters associated with it. - */ -typedef struct counters { -/* - * Transmit counters. - */ - unsigned int tx_restarted; - unsigned int p_tx; - unsigned int b_tx; - unsigned int tx_err_UF; - unsigned int tx_err_EC; - unsigned int tx_err_LC; - unsigned int tx_err_NC; - unsigned int tx_err_LO; - unsigned int tx_err_TO; - unsigned int tx_err_LF; -/* - * Receive couters. - */ - unsigned int rx_restarted; - unsigned int p_rx; - unsigned int mf_rx; - unsigned int b_rx; - unsigned int rx_err_OF; - unsigned int rx_err_CE; - unsigned int rx_err_CS; - unsigned int rx_err_TL; - unsigned int rx_err_LE; - unsigned int rx_err_RF; -} counters_t; - -/* - * Describe what a particular DECchip 21040 looks like. - */ -typedef struct DECchip_21040_device { - unsigned int device; /* DBM device number */ - unsigned int index; /* Index into static structures */ - PCIDevice_t *pci; /* The PCI device */ - unsigned long PCI_IO_Base; /* Swizzled IO base address */ - unsigned int rx_index; /* Next RX buffer */ - unsigned int tx_index; /* Next TX buffer */ - struct counters *counters; /* block of counter information */ - mac_addr hw_address; /* This device's h/w address */ - char *setup_frame; /* setup frame */ - struct { - unsigned int exists : 1; /* Does this device exist? */ - unsigned int allocated : 1; /* Is this device in use? */ - unsigned int initialised : 1; /* Has the device been initialised? */ - unsigned int loopback : 1; /* loopback mode selected */ - unsigned int setup_frame : 1; /* setup frame needed? */ - unsigned int hw_valid : 1; /* Is the hardware address valid? */ - } flags; -} DECchip_21040_device_t; - -/* /ether/DEC21040.c */ -extern DECchip_21040_device_t * DECchip_21040_device_find(int device_no); -extern int DECchip_21040_device_register(int device_no); -extern void DECchip_21040_device_init_module(void ); - -#endif /* NEEDPCI */ -#endif /* __DECCHIP21040_H_LOADED */ diff --git a/system/alpha/h/Makefile b/system/alpha/h/Makefile deleted file mode 100644 index 96c66b2e2..000000000 --- a/system/alpha/h/Makefile +++ /dev/null @@ -1,20 +0,0 @@ -# $Id: Makefile,v 1.1.1.1 1997/10/30 23:27:13 verghese Exp $ -# $Log: Makefile,v $ -# Revision 1.1.1.1 1997/10/30 23:27:13 verghese -# current 10/29/97 -# -# Revision 1.2 1994/06/28 20:08:21 fdh -# Modified filenames and build precedure to fit into a FAT filesystem. -# -# Revision 1.1 1994/03/11 05:14:12 fdh -# Initial revision -# - -include ../rules.osf - -all: - -clean: - rm -f *~ \#*\# core - $(CLEAN) - diff --git a/system/alpha/h/address.h b/system/alpha/h/address.h deleted file mode 100644 index e352630f4..000000000 --- a/system/alpha/h/address.h +++ /dev/null @@ -1,121 +0,0 @@ -#ifndef __ADDRESSES_H_LOADED -#define __ADDRESSES_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: address.h,v 1.1.1.1 1997/10/30 23:27:13 verghese Exp $ - */ - -/* - * MODULE DESCRIPTION: - * - * Network addresses, and other parameters to service interface, for EB64 monitor - * - * HISTORY: - * - * $Log: address.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:13 verghese - * current 10/29/97 - * - * Revision 1.7 1994/08/05 20:13:47 fdh - * Updated Copyright header and RCS $Id: identifier. - * - * Revision 1.6 1994/06/28 20:08:21 fdh - * Modified filenames and build precedure to fit into a FAT filesystem. - * - * Revision 1.5 1994/06/22 15:10:11 rusling - * Fixed up WNT compile warnings. - * - * Revision 1.4 1994/06/20 14:18:59 fdh - * Fixup header file preprocessor #include conditionals. - * - * Revision 1.3 1994/01/21 09:45:59 rusling - * Added #ifdef <filename>_H around the module. - * Additionally, any included files are not ifdef'd - * *before* they're included (ie address.h). - * - * Revision 1.2 1994/01/20 17:56:30 rusling - * Added #ifdef ADDRESSES_H around this include file. - * - * Revision 1.1 1993/08/06 10:26:13 berent - * Initial revision - * - * - */ - - -/* Note that all the address and protocol types in this file are held in network byte order */ - -/* MAC address */ - -#define MAC_ADDRESS_SIZE 6 - -typedef unsigned char mac_addr[MAC_ADDRESS_SIZE]; - -/* Broadcast MAC address */ -static mac_addr broadcast_mac_address = {0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF}; - -/* Ethernet protocol ids */ - -#define ETHERNET_PROTOCOL_ID_SIZE 2 - -typedef unsigned char ethernet_protocol_id[ETHERNET_PROTOCOL_ID_SIZE]; - -/* Standard ethernet protocol ids - from RFC 1340 */ -static ethernet_protocol_id ether_protocol_ip = {0x08, 0x00}; -static ethernet_protocol_id ether_protocol_arp = {0x08, 0x06}; - -/* IP addresses */ - -#define IP_ADDRESS_SIZE 4 - -typedef unsigned char ip_addr[IP_ADDRESS_SIZE]; - -static ip_addr own_ip_addr_unknown_address = {0,0,0,0}; -static ip_addr local_ip_broadcast_address = {0xFF,0xFF,0xFF,0xFF}; - -/* IP protocol ids */ - -typedef unsigned char ip_protocol_id; - -/* UDP port ids */ - -#define UDP_PORT_SIZE 2 - -typedef unsigned char udp_port[UDP_PORT_SIZE]; - -/* Well known UDP port numbers - mainly from RFC 1340 */ - -static udp_port udp_port_remote_debug_connect={410 >> 8, 410 & 0xff}; /* New assignment by IANA - - Ladebug remote debug protocol = 410 */ - -/* Special for compatibility with existing remote debug implementation */ -static udp_port udp_port_old_debug={0x54, 0x07}; - -#define ETHER_BUFFER_SIZE 1600 - -#endif /* __ADDRESSES_H_LOADED */ diff --git a/system/alpha/h/am79c960.h b/system/alpha/h/am79c960.h deleted file mode 100644 index 727d99292..000000000 --- a/system/alpha/h/am79c960.h +++ /dev/null @@ -1,381 +0,0 @@ -#ifndef __AM79C960_H_LOADED -#define __AM79C960_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: am79c960.h,v 1.1.1.1 1997/10/30 23:27:13 verghese Exp $ - */ - -/* - * MODULE DESCRIPTION: - * - * Parameters and logicals for AM79C960 drivers in EB64 monitor - * - * HISTORY: - * - * $Log: am79c960.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:13 verghese - * current 10/29/97 - * - * Revision 1.8 1994/12/12 21:31:59 cruz - * Fixed bug in TMD3 constants - * - * Revision 1.7 1994/08/05 20:13:47 fdh - * Updated Copyright header and RCS $Id: identifier. - * - * Revision 1.6 1994/06/28 20:08:21 fdh - * Modified filenames and build precedure to fit into a FAT filesystem. - * - * Revision 1.5 1994/06/24 15:26:49 rusling - * Fixed initialization alignment problems. - * - * Revision 1.4 1994/06/20 14:18:59 fdh - * Fixup header file preprocessor #include conditionals. - * - * Revision 1.3 1994/06/17 19:34:01 fdh - * Clean-up... - * - * Revision 1.2 1994/06/03 20:11:11 fdh - * Replaced shorts declared in bitfields to ints. - * - * Revision 1.1 1993/08/06 10:10:05 berent - * Initial revision - * - * - */ - - - -/* The embedded Ethernet controller on the EB64 is an AMD Am79C960 device. - * - * This device integrates an Am7990 LANCE Ethernet controller with an ISA - * bus interface plus all the serial interface logic bar some discrete - * termination and isolation transformers for AUI (10base5) and twisted - * pair (10baseT) connections. - * - * The AUI port on EB64 is connected to an Am7996 thinwire transceiver to - * provide a 10base2 port (BNC) as well as the twisted pair (MMJ) - * connectivity. - * - * The device is programmed in a similar but not identical fashion to the - * LANCE. The following programming differences and features are noted: - * - * A RAP/RDP mechanism is used for register access like the LANCE, but with - * a much larger register set: - * - * Initialisation block now part of on-chip register set with new - * ...features added to the mode register. This can be set up in - * ...memory and copied by the device using the csr0_INIT bit, or - * ...programmed directly to the device using the extended CSR map. - * - * CSR3 completely changed - interrupt mask and enabling bits for - * ...new features - * - * CSR3 can be accessed while the "LANCE" running - * - * A register added for controlling the ISA bus DMA profile eg. FIFO - * ...watermarks for DMA loads and stores, TX transmission start - * ...point wrt data in TX FIFO, DMA burstsizes. - * - * Registers to overrule ring sizes in initialisation blocks allowing - * ...ring sizes from 1-64k entries. CSR76 for RX; CSR78 for TX - * - * Timer and ID registers - * - * Missed pkt and RX collision counters - * - * A similar RAP/IDP mechanism is used to program ISA DMA signal timing, ISA - * bus configuration, bits, and the functionality for the three LED drives - * provided. - * - * The Am79C960 *must* use a 16-bit DMA path, but can use an 8-bit path for - * CSR (IO) access. It also supports access to a sixteen byte area for - * keeping the MAC address in PROM. This is always byte-wide access, as is a - * shared memory mode to a larger local address space, not used on EB64. - * - * EB64 accesses to the 79C960 are through the VL82C486 ISA controller. All - * CSR accesses should be done as 16-bit words, with the VL82C486 taking care - * of the packing/unpacking issue. Enet PROM accesses are done as byte - * accesses. The EB64 memory controller will perform read_modify_write cycles - * into main memory to correctly merge the bytes/words, and preserve longword - * parity. - * - * - * Please see the Am7990 and Am79C960 literature for definitive lists and - * further detail. - * - * PLEASE NOTE: LANCE is used in many definitions for historical reasons. - */ - - - /* Maximum number of AMD79C960's supported in the EB64 monitor */ - -#define AM79C960_MAX_DEVICES 2 - - - /* Base addresses supported for 79C960 in ISA address space */ - -#define EMBEDDED_79C960_BASE 0x360 /* IOAM pins = 0b11 */ -#define OPTION_79C960_BASE 0x300 /* IOAM pins = 0b00 */ - - /* Assigned interrupt numbers for 8259 controller */ - -#define EMBEDDED_79C960_INT 9 -#define OPTION_79C960_INT 12 - - /* Assigned mask numbers for enabling appropriate DMA channel */ - -#define EMBEDDED_79C960_DMA 1 -#define OPTION_79C960_DMA 2 - - - /* CSR access offsets for 79C960 */ - -#define HW_ADDR_OFFSET 0 /* The hardware address is at the base address for the device */ -#define RDP_OFFSET 0x10 -#define RAP_OFFSET 0x12 -#define RESET_OFFSET 0x14 -#define IDP_OFFSET 0x16 -#define VSW_OFFSET 0x18 - -#define LANCE_CSR0 0 /* Main csr */ -#define LANCE_IADRL 1 /* Init block low address bits */ -#define LANCE_IADRH 2 /* Init block high address bits */ -#define LANCE_CSR3 3 /* Mask and function bits */ -#define LANCE_CSR4 4 /* Additional mask and function bits, only exists on amd 79c960 */ - - /* CSR bit definitions - CSR1 and 2 have no bit fields */ - - /* CSR0 Bit definitions */ - -#define csr0_INIT 0x0001 /* Initialize - can be set with STRT on 79C960*/ -#define csr0_STRT 0x0002 /* Start operation */ -#define csr0_STOP 0x0004 /* Stop LANCE */ -#define csr0_TDMD 0x0008 /* Transmit demand */ -#define csr0_TXON 0x0010 /* Transmitter ON */ -#define csr0_RXON 0x0020 /* Receiver ON */ -#define csr0_IENA 0x0040 /* Interrupt enable */ -#define csr0_INTR 0x0080 /* Interrupt received */ -#define csr0_IDON 0x0100 /* Initialization done */ -#define csr0_TINT 0x0200 /* Transmitter interrupt */ -#define csr0_RINT 0x0400 /* Receiver interrupt */ -#define csr0_MERR 0x0800 /* Memory error */ -#define csr0_MISS 0x1000 /* Missed packet */ -#define csr0_CERR 0x2000 /* Collision error */ -#define csr0_BABL 0x4000 /* Babbling on the wire */ -#define csr0_ERR 0x8000 /* Error logical OR */ - - - /* CSR3 Bit definitions - all undefined bits reserved */ - -#define csr3_EMBA 0x0008 /* Enable Alternate Backoff Algorithm - 79C960 */ -#define csr3_DXMT2PD 0x0010 /* Disable 2-part TX deferral - 79C960 */ -#define csr3_IDONM 0x0100 /* Initialise Done interrupt mask */ -#define csr3_TINT 0x0200 /* TX interrupt mask */ -#define csr3_RINT 0x0400 /* RX interrupt mask */ -#define csr3_MERM 0x0800 /* Memory error interrupt mask */ -#define csr3_MISSM 0x1000 /* Missed pkt interrupt mask */ -#define csr3_BABLM 0x4000 /* Babble interrupt mask */ -#define csr3_MASKALL 0x5F00 /* Mask all CSR3 maskable interrupts */ - - /* CSR4 Bit definitions - all undefined bits reserved */ - /* This register is unique to the 79C960 */ - -#define csr4_JABM 0x0001 /* Jabber interrupt mask -#define csr4_JAB 0x0002 /* set if T-MAU detects a jabber condition -#define csr4_TXSTRTM 0x0004 /* TX start (of packet) interrupt mask */ -#define csr4_TXSTRT 0x0008 /* */ -#define csr4_RCVCCOM 0x0010 /* RX Collision Counter Overflow interrupt mask */ -#define csr4_RCVCCO 0x0020 /* RX Collision Counter Overflow bit */ -#define csr4_MPCOM 0x0100 /* Missed Pkt counter overflow interrupt mask */ -#define csr4_MPCO 0x0200 /* Missed Pkt counter overflow bit */ -#define csr4_ASTRPRCV 0x0400 /* Enable Automatic Pad Stripping on RX - IEEE802.3 */ -#define csr4_APADXMT 0x0800 /* Enable Automatic Padding on TX - IEEE802.3 */ -#define csr4_DPOLL 0x1000 /* Disable polling - TX rings */ -#define csr4_TIMER 0x2000 /* */ -#define csr4_DMAPLUS 0x4000 /* Disable CSR80 DMA burst counter */ -#define csr4_ENTST 0x8000 /* Enable Test mode */ - - - - /* Receive Message Descriptor */ - /* RMD0, RMD2 and RMD3 have no bit fields */ - - /* Bits 0 -> 7 of RMD1 part of buffer address */ - -#define rmd1_ENP 0x0100 /* End of packet */ -#define rmd1_STP 0x0200 /* Start of packet */ -#define rmd1_BUFF 0x0400 /* Buffer error */ -#define rmd1_CRC 0x0800 /* CRC error */ -#define rmd1_OFLO 0x1000 /* Overflow error */ -#define rmd1_FRAM 0x2000 /* Framing error */ -#define rmd1_ERR 0x4000 /* Error logical OR */ -#define rmd1_OWN 0x8000 /* Who owns it */ - - - - /* Transmit Message Descriptor */ - /* TMD0 and TMD2 have no bit fields */ - - /* Bits 0 -> 7 of TMD1 part of buffer address */ - -#define tmd1_ENP 0x0100 /* End of packet */ -#define tmd1_STP 0x0200 /* Start of packet */ -#define tmd1_DEF 0x0400 /* Had to defer */ -#define tmd1_ONE 0x0800 /* One eretry needed */ -#define tdm1_MORE 0x1000 /* More than one retry */ -#define tmd1_ADDFCS 0x2000 /* Am79C960 specific - add FCS on pkt basis */ -#define tmd1_ERR 0x4000 /* Error logical OR */ -#define tmd1_OWN 0x8000 /* Who owns it */ - - - /* Bits 0 -> 9 of TMD3 provide a TDR counter for finding cable faults */ - -#define tmd3_RTRY 0x0400 /* Too many retries */ -#define tmd3_LCAR 0x0800 /* Loss of Carrier */ -#define tmd3_LCOL 0x1000 /* Late Collision on send */ -#define tmd3_RES 0x2000 /* RESERVED */ -#define tmd3_UFLO 0x4000 /* Underflow Error */ -#define tmd3_BUFF 0x8000 /* Buffer Error */ - - - /* For init block - operating modes */ - -#define mode_DRX 0x0001 /* Disable receiver */ -#define mode_DTX 0x0002 /* Disable transmitter */ -#define mode_LOOP 0x0004 /* Loopback mode */ -#define mode_DTCR 0x0008 /* Disable transmit CRC */ -#define mode_COLL 0x0010 /* Force collision */ -#define mode_DRTY 0x0020 /* Disable retries */ -#define mode_INTL 0x0040 /* Internal loopback */ -#define mode_PORTSEL0 0x0080 /* 0 = AUI; 1 = T-MAU */ -#define mode_PORTSEL1 0x0100 /* MBZ */ -#define mode_LRT_TSEL 0x0200 /* Low RX threshold/TX mode select */ -#define mode_MENDECL 0x0400 /* MENDEC loopback mode */ -#define mode_DAPC 0x0800 /* T-MAU: disable automatic polarity correction */ -#define mode_DLNKTST 0x1000 /* Disable link status */ -#define mode_DRCVPA 0x2000 /* Disable RX physical address */ -#define mode_DRCVBC 0x4000 /* Disable RX broadcast */ -#define mode_PROM 0x8000 /* Promiscuous mode */ - - - - /* Initialization block. */ - -#define LANCE_INIT_BLOCK_SIZE 24 -#define LANCE_INIT_BLOCK_MODE_OFFSET 0 -#define LANCE_INIT_BLOCK_PADR_OFFSET 2 -#define LANCE_INIT_BLOCK_LADRF_OFFSET 8 -#define LANCE_INIT_BLOCK_RD_OFFSET 16 -#define LANCE_INIT_BLOCK_TD_OFFSET 20 - - -typedef struct { - unsigned - radr : 24, /* Ring address. */ - : 5, - rlen : 3; /* Entries (0=1, 1=2, 2=4, 3=8...) */ -} INIT_BLOCK_DESC; - - /* Receive buffer descriptor. */ - -typedef struct{ - unsigned int - ladr : 24, /* Buffer address. */ - enp : 1, /* End of packet. */ - stp : 1, /* Start of packet. */ - buff : 1, /* Buffer error. */ - crc : 1, /* CRC error. */ - oflo : 1, /* Overflow error. */ - fram : 1, /* Framing error. */ - err : 1, /* Error summary: buff + crc + oflo + fram */ - own : 1; /* Buffer owner: host=0, lance=1. */ - uw bcnt; /* Buffer size. */ - uw mcnt; /* Message size. */ -} LANCE_RECV_BD; - - /* Transmit buffer descriptor. */ - -typedef struct{ - unsigned int - ladr : 24, /* Buffer address. */ - enp : 1, /* End of packet. */ - stp : 1, /* Start of packet. */ - def : 1, /* Deferred. */ - one : 1, /* One retry. */ - more : 1, /* More retries. */ - add_fcs : 1, /* Add FCS on packet basis - 79C960 specific feature */ - err : 1, /* Error summary: lcol + lcar + uflo + rtry */ - own : 1; /* Buffer owner: host=0, lance=1. */ - uw bcnt; /* Buffer size. */ - uw tmd3; /* TMD 3 */ -} LANCE_SEND_BD; - -#define LANCE_OWNS 1 -#define HOST_OWNS 0 - - /* Lance counters. */ - -typedef struct{ - time_t zeroed; - int b_recv; - int b_sent; - int f_recv; - int f_sent; - int mc_b_recv; - int mc_f_recv; - int f_sent_def; - int f_sent_sgl_col; - int f_sent_mult_col; - int send_fail_exs_col; - int send_fail_cc; - int send_fail_short; - int send_fail_open; - int send_fail_flen; - int send_fail_defer; - int recv_fail_fcs; - int recv_fail_f_err; - int recv_fail_flen; - int data_overrun; - int sbuf_unav; - int ubuf_unav; - int cc_fail; -} LANCE_CTRS; - -typedef struct{ - int base_addr; - int interrupt_line; - int dma_mask; -} AM79C960_CONFIG; - -#define AM79C960_FLUSH_WATCHDOG 5000 /* watchdog timeout - in ms - for TX flush routine */ - -/* /ether/am79c960.c */ -extern int am79c960_device_register(int device_no); -extern void am79c960_device_init_module(void ); - -#endif /* __AM79C960_H_LOADED */ diff --git a/system/alpha/h/arp.h b/system/alpha/h/arp.h deleted file mode 100644 index dfab7c787..000000000 --- a/system/alpha/h/arp.h +++ /dev/null @@ -1,108 +0,0 @@ -#ifndef __ARP_H_LOADED -#define __ARP_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: arp.h,v 1.1.1.1 1997/10/30 23:27:13 verghese Exp $ - */ - -/* - * MODULE DESCRIPTION: - * - * Arp interface for EB64 monitor - * - * HISTORY: - * - * $Log: arp.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:13 verghese - * current 10/29/97 - * - * Revision 1.6 1994/08/05 20:13:47 fdh - * Updated Copyright header and RCS $Id: identifier. - * - * Revision 1.5 1994/06/28 20:08:21 fdh - * Modified filenames and build precedure to fit into a FAT filesystem. - * - * Revision 1.4 1994/06/20 14:18:59 fdh - * Fixup header file preprocessor #include conditionals. - * - * Revision 1.3 1994/01/21 09:45:59 rusling - * Added #ifdef <filename>_H around the module. - * Additionally, any included files are not ifdef'd - * *before* they're included (ie address.h). - * - * Revision 1.2 1994/01/20 15:46:47 rusling - * Added new routine, arp_show(), to print out - * the contents of the current arp table. - * - * Revision 1.1 1993/08/06 10:25:46 berent - * Initial revision - * - * - */ - -#include "address.h" - - -/* arp_init - initialises the arp module; and registers it with the - * ethernet protocol handler. - * - * Argument: - * device_no - device number on which arp should be registered. - */ -extern void arp_init(int device_no); - -/* arp_set_device_addr - tells arp a device's ip address. - * - * Arguments: - * device_no - device number - * ip - ip address - */ -extern void arp_set_device_addr(int device_no,ip_addr ip); - -/* arp_resolve - converts an ip address into an ethernet address - * - * Arguments: - * device_no - device on which the message is to be sent - * ip - ip address - * mac - returned ethernet MAC address - * - * Returned value: - * TRUE - address resolved; eaddr valid - * FALSE - Unable to resolve address. - */ -extern int arp_resolve(int device_no, ip_addr ip, mac_addr mac); - -/* arp_init_module - initialise the module - */ -extern void arp_init_module(void); -/* - * arp_show - show all arp entries - */ -extern void arp_show(void); - -#endif /* __ARP_H_LOADED */ diff --git a/system/alpha/h/base.h b/system/alpha/h/base.h deleted file mode 100644 index 46b0e65ca..000000000 --- a/system/alpha/h/base.h +++ /dev/null @@ -1,78 +0,0 @@ -#ifndef __BASE_H_LOADED -#define __BASE_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: base.h,v 1.1.1.1 1997/10/30 23:27:14 verghese Exp $; - */ - -/* - * $Log: base.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:14 verghese - * current 10/29/97 - * - * Revision 1.4 1994/08/05 20:13:47 fdh - * Updated Copyright header and RCS $Id: identifier. - * - * Revision 1.3 1994/06/20 14:18:59 fdh - * Fixup header file preprocessor #include conditionals. - * - * Revision 1.2 1994/06/17 19:34:01 fdh - * Clean-up... - * - * Revision 1.1 1993/06/08 19:56:11 fdh - * Initial revision - * - */ - -#include "lib.h" - -/* priority and critical sections */ - -extern int base_ensurepriority(int priority); -extern void base_setpriority(int priority); - -/* timing */ -extern void base_msdelay(int ms); - -/* second clock */ -time_t base_seconds; -time_t base_time(int delta); -extern int base_jiffies; /* raw interrupt count */ - -/* interrupts */ - -/* process control */ -extern void base_yield(); - -/* general */ - -extern void base_kickthedog(); /* don't reboot for another XXX seconds */ -extern int base_watchdog; /* if 0, timer interrupt handles watchdog - if non-zero, user code is responsible */ - -#endif /* __BASE_H_LOADED */ diff --git a/system/alpha/h/bbram.h b/system/alpha/h/bbram.h deleted file mode 100644 index 5b29c57b4..000000000 --- a/system/alpha/h/bbram.h +++ /dev/null @@ -1,101 +0,0 @@ -#ifndef __BBRAM_H_LOADED -#define __BBRAM_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: bbram.h,v 1.1.1.1 1997/10/30 23:27:14 verghese Exp $; - */ - -/* - * $Log: bbram.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:14 verghese - * current 10/29/97 - * - * Revision 1.1 1995/06/23 16:13:56 berc - * Initial revision - * - * Revision 1.6 1995/02/10 02:20:00 fdh - * Added definitions for OSTYPE location in battary backed RAM. - * - * Revision 1.5 1994/08/05 20:13:47 fdh - * Updated Copyright header and RCS $Id: identifier. - * - * Revision 1.4 1994/07/11 19:46:38 fdh - * Remove typecast used on the value set by the BBRAM_READ macro. - * - * Revision 1.3 1994/06/22 15:10:20 rusling - * Fixed up WNT compile warnings. - * - * Revision 1.2 1994/06/20 14:18:59 fdh - * Fixup header file preprocessor #include conditionals. - * - * Revision 1.1 1994/03/16 00:13:48 fdh - * Initial revision - * - */ - - -/* - * The TOY clock contains some BBRAM that we can use to - * store useful stuff. The BBRAM that is available to us - * is in bytes 14-127. - * - * Currently, we use: - * - * Bytes Contents - * - * 14:18 bootadr + pattern - * 21:22 rmode + pattern - * 23:30 default mac address + 2 bytes of checksum. - * - * Below some macros and offsets are defined to make programming - * this area easier. - */ - -#define BBRAM_BASE 14 - -#define BBRAM_READ(offset,value) \ - { \ - outportb(RTCADDR, BBRAM_BASE + (offset)); \ - (value) = inportb(RTCDATA) & 0xFF; \ - } - -#define BBRAM_WRITE(offset,value) \ - { \ - outportb(RTCADDR, BBRAM_BASE + (offset)); \ - outportb(RTCDATA, (value) & 0xFF); \ - } - -#define BBRAM_BOOTADR 0 -#define BBRAM_BOOTADR_COOKIE 0xA1 -#define BBRAM_RMODE 7 -#define BBRAM_RMODE_COOKIE 0x1B -#define BBRAM_MACADDR 9 -#define BBRAM_MACADDR_COOKIE 0x1C -#define BBRAM_OSTYPE (0x3f-BBRAM_BASE) - -#endif /* __BBRAM_H_LOADED */ diff --git a/system/alpha/h/bootp.h b/system/alpha/h/bootp.h deleted file mode 100644 index 0b0aa85d2..000000000 --- a/system/alpha/h/bootp.h +++ /dev/null @@ -1,89 +0,0 @@ -#ifndef __BOOTP_H_LOADED -#define __BOOTP_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: bootp.h,v 1.1.1.1 1997/10/30 23:27:14 verghese Exp $ - */ - -/* - * MODULE DESCRIPTION: - * - * BOOTP protocol interface for EB64 monitor - * - * HISTORY: - * - * $Log: bootp.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:14 verghese - * current 10/29/97 - * - * Revision 1.5 1994/08/05 20:13:47 fdh - * Updated Copyright header and RCS $Id: identifier. - * - * Revision 1.4 1994/06/28 20:08:21 fdh - * Modified filenames and build precedure to fit into a FAT filesystem. - * - * Revision 1.3 1994/06/20 14:18:59 fdh - * Fixup header file preprocessor #include conditionals. - * - * Revision 1.2 1994/01/21 09:45:59 rusling - * Added #ifdef <filename>_H around the module. - * Additionally, any included files are not ifdef'd - * *before* they're included (ie address.h). - * - * Revision 1.1 1993/08/06 10:27:32 berent - * Initial revision - * - * - */ - -#include "address.h" - - -/* bootp_boot - performs a bootp transaction - * - * Arguments: - * device_no - device on which request should be sent - * input_file_name - file name supplied by caller; or null for default. Null terminated; - * server_addr - returned server IP address - * boot_file_name - returned boot file name supplied by server - * - * Returned value: - * TRUE - bootp successful; server_addr and boot_file_name valid; - * FALSE - bootp failed; server_addr and boot_file_name invalid. - */ -extern int bootp_boot(int device_no, - char input_file_name[128], - ip_addr server_addr, - char bootp_file_name[128]); - -/* bootp_init_module - initialise the module - */ -extern void bootp_init_module(void); - -#endif /* __BOOTP_H_LOADED */ - diff --git a/system/alpha/h/bptable.h b/system/alpha/h/bptable.h deleted file mode 100644 index 5be808c0f..000000000 --- a/system/alpha/h/bptable.h +++ /dev/null @@ -1,111 +0,0 @@ -#ifndef __BPTABLE_H_LOADED -#define __BPTABLE_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * This file defines the interface to the breakpoint table. - */ - -#include "lib.h" -#include "server_t.h" - - -#define BPTMAX 100 - -#define SUCCESS 1 -#define TRUE 1 -#define FALSE 0 - -#define BPTFULL (-1) /* breakpoint table is full */ -#define BPTDUP (-2) /* duplicate breakpoint */ -#define BPTNOBRK (-3) /* no such breakpoint */ -#define BPTINV (-4) /* this breakpoint number not in use */ -#define BPTILL (-5) /* illegal breakpoint number */ - -/* bptinitialize - Initialize the breakpoint table. - */ -void bptinitialize(void); - -/* bptinsert - add a breakpoint to the breakpoint table - * - * Arguments: - * addr - address of breakpoint - * savedinst - the instruction at that address - * - * Return value: - * SUCCESS if successful, otherwise a negative error code. - */ -int bptinsert(address_value addr, instruction_value savedinst); - -/* bptremote - remove a breakpoint from the breakpoint table - * - * Arguments: - * addr - address of breakpoint - * savedinst - (returned) saved instruction - * Return value: - * SUCCESS if successful, otherwise a negative error code. - */ -int bptremove(address_value addr, instruction_value *savedinst); - -/* bptgetn - get a breakpoint by number - * - * Arguments: - * n - breakpoint number - * addr - (returned) address of breakpoint - * savedinst - (returned) saved instruction - * Return value: - * SUCCESS if successful, otherwise a negative error code. - */ -int bptgetn(int n, address_value *addr, instruction_value *savedinst); - -/* bptgeta - get a breakpoint by address - * - * Arguments: - * addr - address of breakpoint - * savedinst - (returned) saved instruction - * Return value: - * SUCCESS if successful, otherwise a negative error code. - */ -int bptgeta(address_value addr, instruction_value *savedinst); - -/* bptisbreakat - checks whether there is a breakpoint at the given address - * - * Argument: - * addr - address to be checked - * Return value: - * TRUE if there is a breakpoint at that address; FALSE if not. - */ -int bptisbreakat(address_value addr); - -/* bptfull - checks whether the breakpoint table is full - * - * Return value: - * TRUE if full; FALSE if not. - */ -int bptfull(void); - -#endif /* __BPTABLE_H_LOADED */ diff --git a/system/alpha/h/buffer.h b/system/alpha/h/buffer.h deleted file mode 100644 index 35433c54a..000000000 --- a/system/alpha/h/buffer.h +++ /dev/null @@ -1,70 +0,0 @@ -#ifndef __BUFFER_H_LOADED -#define __BUFFER_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: buffer.h,v 1.1.1.1 1997/10/30 23:27:14 verghese Exp $; - */ - -/* - * $Log: buffer.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:14 verghese - * current 10/29/97 - * - * Revision 1.3 1994/08/05 20:13:47 fdh - * Updated Copyright header and RCS $Id: identifier. - * - * Revision 1.2 1994/06/20 14:18:59 fdh - * Fixup header file preprocessor #include conditionals. - * - * Revision 1.1 1993/06/08 19:56:12 fdh - * Initial revision - * - */ - - -/* buffer.h */ -/* definitions for buffer management */ - - -typedef struct Packet { - struct Packet *link; - char dest[6]; - char src[6]; - short unsigned count; - char data[1536]; - } PACKET; - -#define BSIZE (sizeof(PACKET)) -#define buffer_NIL ((PACKET *) 0) - - -extern void buffer_init(PACKET *start, int size); -extern PACKET *buffer_alloc(); -extern void buffer_free(PACKET *p); - -#endif /* __BUFFER_H_LOADED */ diff --git a/system/alpha/h/cserve.h b/system/alpha/h/cserve.h new file mode 100644 index 000000000..47a30a0a3 --- /dev/null +++ b/system/alpha/h/cserve.h @@ -0,0 +1,107 @@ +/* + * VID: [T1.2] PT: [Fri Apr 21 16:47:20 1995] SF: [cserve.h] + * TI: [/sae_users/cruz/bin/vice -iplatform.s -l// -p# -DEB164 -h -m -aeb164 ] + */ +#define __CSERVE_LOADED 1 +/* +***************************************************************************** +** * +** Copyright © 1993, 1994 * +** by Digital Equipment Corporation, Maynard, Massachusetts. * +** * +** All Rights Reserved * +** * +** Permission is hereby granted to use, copy, modify and distribute * +** this software and its documentation, in both source code and * +** object code form, and without fee, for the purpose of distribution * +** of this software or modifications of this software within products * +** incorporating an integrated circuit implementing Digital's AXP * +** architecture, regardless of the source of such integrated circuit, * +** provided that the above copyright notice and this permission notice * +** appear in all copies, and that the name of Digital Equipment * +** Corporation not be used in advertising or publicity pertaining to * +** distribution of the document or software without specific, written * +** prior permission. * +** * +** Digital Equipment Corporation disclaims all warranties and/or * +** guarantees with regard to this software, including all implied * +** warranties of fitness for a particular purpose and merchantability, * +** and makes no representations regarding the use of, or the results * +** of the use of, the software and documentation in terms of correctness, * +** accuracy, reliability, currentness or otherwise; and you rely on * +** the software, documentation and results solely at your own risk. * +** * +** AXP is a trademark of Digital Equipment Corporation. * +** * +***************************************************************************** +** +** FACILITY: +** +** DECchip 21164 OSF/1 PALcode +** +** MODULE: +** +** cserve.h +** +** MODULE DESCRIPTION: +** +** Platform specific cserve definitions. +** +** AUTHOR: ES +** +** CREATION DATE: 21-JUN-1994 +** +** $Id: cserve.h,v 1.1.1.1 1997/10/30 23:27:18 verghese Exp $ +** +** MODIFICATION HISTORY: +** +** $Log: cserve.h,v $ +** Revision 1.1.1.1 1997/10/30 23:27:18 verghese +** current 10/29/97 +** +** Revision 1.6 1995/04/03 17:29:52 samberg +** Add rd_bccfg_off +** +** Revision 1.5 1995/02/02 19:31:34 samberg +** Added WR_BCACHE, deleted WR_BCCFG and WR_BCCTL +** +** Revision 1.4 1994/12/08 17:13:34 samberg +** Add CSERVE_K_WR_BCCTL and CSERVE_K_WR_BCCFG +** +** Revision 1.3 1994/11/30 15:59:30 samberg +** Use c-style comments for c compiler use +** +** Revision 1.2 1994/11/22 19:02:46 samberg +** Add constants for ev4 backward compatibility +** +** Revision 1.2 1994/11/22 19:02:46 samberg +** Add constants for ev4 backward compatibility +** +** Revision 1.1 1994/07/08 17:01:40 samberg +** Initial revision +** +** +*/ + +/* +** Console Service (cserve) sub-function codes: +*/ +#define CSERVE_K_LDQP 0x01 +#define CSERVE_K_STQP 0x02 +#define CSERVE_K_JTOPAL 0x09 +#define CSERVE_K_WR_INT 0x0A +#define CSERVE_K_RD_IMPURE 0x0B +#define CSERVE_K_PUTC 0x0F +#define CSERVE_K_WR_ICSR 0x10 +#define CSERVE_K_WR_ICCSR 0x10 /* for ev4 backwards compatibility */ +#define CSERVE_K_RD_ICSR 0x11 +#define CSERVE_K_RD_ICCSR 0x11 /* for ev4 backwards compatibility */ +#define CSERVE_K_RD_BCCTL 0x12 +#define CSERVE_K_RD_BCCFG 0x13 + +#define CSERVE_K_WR_BCACHE 0x16 + +#define CSERVE_K_RD_BCCFG_OFF 0x17 +#define CSERVE_K_JTOKERN 0x18 + + diff --git a/system/alpha/h/dc21164FromGasSources.h b/system/alpha/h/dc21164FromGasSources.h new file mode 100644 index 000000000..9b3389269 --- /dev/null +++ b/system/alpha/h/dc21164FromGasSources.h @@ -0,0 +1,965 @@ +#ifndef DC21164FROMGASSOURCES_INCLUDED +#define DC21164FROMGASSOURCES_INCLUDED 1 + +/* +***************************************************************************** +** * +** Copyright © 1993, 1994 * +** by Digital Equipment Corporation, Maynard, Massachusetts. * +** * +** All Rights Reserved * +** * +** Permission is hereby granted to use, copy, modify and distribute * +** this software and its documentation, in both source code and * +** object code form, and without fee, for the purpose of distribution * +** of this software or modifications of this software within products * +** incorporating an integrated circuit implementing Digital's AXP * +** architecture, regardless of the source of such integrated circuit, * +** provided that the above copyright notice and this permission notice * +** appear in all copies, and that the name of Digital Equipment * +** Corporation not be used in advertising or publicity pertaining to * +** distribution of the document or software without specific, written * +** prior permission. * +** * +** Digital Equipment Corporation disclaims all warranties and/or * +** guarantees with regard to this software, including all implied * +** warranties of fitness for a particular purpose and merchantability, * +** and makes no representations regarding the use of, or the results * +** of the use of, the software and documentation in terms of correctness, * +** accuracy, reliability, currentness or otherwise; and you rely on * +** the software, documentation and results solely at your own risk. * +** * +** AXP is a trademark of Digital Equipment Corporation. * +** * +***************************************************************************** +** +** FACILITY: +** +** DECchip 21164 PALcode +** +** MODULE: +** +** dc21164.h +** +** MODULE DESCRIPTION: +** +** DECchip 21164 specific definitions +** +** AUTHOR: ER +** +** CREATION DATE: 24-Nov-1993 +** +** $Id: dc21164FromGasSources.h,v 1.1.1.1 1997/10/30 23:27:19 verghese Exp $ +** +** MODIFICATION HISTORY: +** +** $Log: dc21164FromGasSources.h,v $ +** Revision 1.1.1.1 1997/10/30 23:27:19 verghese +** current 10/29/97 +** +** Revision 1.1 1995/11/18 01:45:46 boyle +** Initial revision +** +** Revision 1.15 1995/04/21 02:06:30 fdh +** Replaced C++ style comments with Standard C style comments. +** +** Revision 1.14 1995/03/20 14:55:23 samberg +** Add flushIc to make Roger Cruz's life easier. +** +** Revision 1.13 1994/12/14 15:52:48 samberg +** Add slXmit and slRcv bit definitions +** +** Revision 1.12 1994/09/07 15:43:49 samberg +** Changes for Makefile.vpp, take out OSF definition +** +** Revision 1.11 1994/07/26 17:38:35 samberg +** Changes for SD164. +** +** Revision 1.10 1994/07/08 17:02:12 samberg +** Changes to support platform specific additions +** +** Revision 1.8 1994/05/31 15:49:21 ericr +** Moved ptKdebug from pt10 to pt13; pt10 is used in MCHK flows +** +** Revision 1.7 1994/05/26 19:29:51 ericr +** Added BC_CONFIG definitions +** +** Revision 1.6 1994/05/25 14:27:25 ericr +** Added physical bit to ldq_lp and stq_cp macros +** +** Revision 1.5 1994/05/20 18:07:50 ericr +** Changed line comments to C++ style comment character +** +** Revision 1.4 1994/01/17 21:46:54 ericr +** Added floating point register definitions +** +** Revision 1.3 1994/01/03 19:31:49 ericr +** Added cache parity error status register definitions +** +** Revision 1.2 1993/12/22 20:42:35 eric +** Added ptTrap, ptMisc and flag definitions +** Added PAL shadow regsiter definitions +** +** Revision 1.1 1993/12/16 21:55:05 eric +** Initial revision +** +** +**-- +*/ + + +/* +** +** INTERNAL PROCESSOR REGISTER DEFINITIONS +** +** The internal processor register definitions below are annotated +** with one of the following symbols: +** +** RW - The register may be read and written +** RO - The register may only be read +** WO - The register may only be written +** +** For RO and WO registers, all bits and fields within the register are +** also read-only or write-only. For RW registers, each bit or field +** within the register is annotated with one of the following: +** +** RW - The bit/field may be read and written +** RO - The bit/field may be read; writes are ignored +** WO - The bit/field may be written; reads return UNPREDICTABLE +** WZ - The bit/field may be written; reads return a zero value +** W0C - The bit/field may be read; write-zero-to-clear +** W1C - The bit/field may be read; write-one-to-clear +** WA - The bit/field may be read; write-anything-to-clear +** RC - The bit/field may be read, causing state to clear; +** writes are ignored +** +*/ + + +/* +** +** Ibox IPR Definitions: +** +*/ + +// replaced by ev5_defs.h #define isr 0x100 /* RO - Interrupt Summary */ +#define itbTag 0x101 /* WO - ITB Tag */ +#define itbPte 0x102 /* RW - ITB Page Table Entry */ +#define itbAsn 0x103 /* RW - ITB Address Space Number */ +#define itbPteTemp 0x104 /* RO - ITB Page Table Entry Temporary */ +#define itbIa 0x105 /* WO - ITB Invalidate All */ +#define itbIap 0x106 /* WO - ITB Invalidate All Process */ +#define itbIs 0x107 /* WO - ITB Invalidate Single */ +// replaced by ev5_defs.h #define sirr 0x108 /* RW - Software Interrupt Request */ +// replaced by ev5_defs.h #define astrr 0x109 /* RW - Async. System Trap Request */ +// replaced by ev5_defs.h #define aster 0x10A /* RW - Async. System Trap Enable */ +#define excAddr 0x10B /* RW - Exception Address */ +#define excSum 0x10C /* RW - Exception Summary */ +#define excMask 0x10D /* RO - Exception Mask */ +#define palBase 0x10E /* RW - PAL Base */ +#define ips 0x10F /* RW - Processor Status */ +// replaced by ev5_defs.h #define ipl 0x110 /* RW - Interrupt Priority Level */ +#define intId 0x111 /* RO - Interrupt ID */ +#define iFaultVaForm 0x112 /* RO - Formatted Faulting VA */ +#define iVptBr 0x113 /* RW - I-Stream Virtual Page Table Base */ +#define hwIntClr 0x115 /* WO - Hardware Interrupt Clear */ +#define slXmit 0x116 /* WO - Serial Line Transmit */ +#define slRcv 0x117 /* RO - Serial Line Receive */ +// replaced by ev5_defs.h #define icsr 0x118 /* RW - Ibox Control/Status */ +#define icFlush 0x119 /* WO - I-Cache Flush Control */ +#define flushIc 0x119 /* WO - I-Cache Flush Control (DC21064 Symbol) */ +#define icPerr 0x11A /* RW - I-Cache Parity Error Status */ +#define PmCtr 0x11C /* RW - Performance Counter */ + +/* +** +** Ibox Control/Status Register (ICSR) Bit Summary +** +** Extent Size Name Type Function +** ------ ---- ---- ---- ------------------------------------ +** <39> 1 TST RW,0 Assert Test Status +** <38> 1 ISTA RO I-Cache BIST Status +** <37> 1 DBS RW,1 Debug Port Select +** <36> 1 FBD RW,0 Force Bad I-Cache Data Parity +** <35> 1 FBT RW,0 Force Bad I-Cache Tag Parity +** <34> 1 FMS RW,0 Force I-Cache Miss +** <33> 1 SLE RW,0 Enable Serial Line Interrupts +** <32> 1 CRDE RW,0 Enable Correctable Error Interrupts +** <30> 1 SDE RW,0 Enable PAL Shadow Registers +** <29:28> 2 SPE RW,0 Enable I-Stream Super Page Mode +** <27> 1 HWE RW,0 Enable PALRES Instrs in Kernel Mode +** <26> 1 FPE RW,0 Enable Floating Point Instructions +** <25> 1 TMD RW,0 Disable Ibox Timeout Counter +** <24> 1 TMM RW,0 Timeout Counter Mode +** +*/ + +#define ICSR_V_TST 39 +#define ICSR_M_TST (1<<ICSR_V_TST) +#define ICSR_V_ISTA 38 +#define ICSR_M_ISTA (1<<ICSR_V_ISTA) +#define ICSR_V_DBS 37 +#define ICSR_M_DBS (1<<ICSR_V_DBS) +#define ICSR_V_FBD 36 +#define ICSR_M_FBD (1<<ICSR_V_FBD) +#define ICSR_V_FBT 35 +#define ICSR_M_FBT (1<<ICSR_V_FBT) +#define ICSR_V_FMS 34 +#define ICSR_M_FMS (1<<ICSR_V_FMS) +#define ICSR_V_SLE 33 +#define ICSR_M_SLE (1<<ICSR_V_SLE) +#define ICSR_V_CRDE 32 +#define ICSR_M_CRDE (1<<ICSR_V_CRDE) +#define ICSR_V_SDE 30 +#define ICSR_M_SDE (1<<ICSR_V_SDE) +#define ICSR_V_SPE 28 +#define ICSR_M_SPE (3<<ICSR_V_SPE) +#define ICSR_V_HWE 27 +#define ICSR_M_HWE (1<<ICSR_V_HWE) +#define ICSR_V_FPE 26 +#define ICSR_M_FPE (1<<ICSR_V_FPE) +#define ICSR_V_TMD 25 +#define ICSR_M_TMD (1<<ICSR_V_TMD) +#define ICSR_V_TMM 24 +#define ICSR_M_TMM (1<<ICSR_V_TMM) + +/* +** +** Serial Line Tranmit Register (SL_XMIT) +** +** Extent Size Name Type Function +** ------ ---- ---- ---- ------------------------------------ +** <7> 1 TMT WO,1 Serial line transmit data +** +*/ + +#define SLXMIT_V_TMT 7 +#define SLXMIT_M_TMT (1<<SLXMIT_V_TMT) + +/* +** +** Serial Line Receive Register (SL_RCV) +** +** Extent Size Name Type Function +** ------ ---- ---- ---- ------------------------------------ +** <6> 1 RCV RO Serial line receive data +** +*/ + +#define SLRCV_V_RCV 6 +#define SLRCV_M_RCV (1<<SLRCV_V_RCV) + +/* +** +** Icache Parity Error Status Register (ICPERR) Bit Summary +** +** Extent Size Name Type Function +** ------ ---- ---- ---- ------------------------------------ +** <13> 1 TMR W1C Timeout reset error +** <12> 1 TPE W1C Tag parity error +** <11> 1 DPE W1C Data parity error +** +*/ + +#define ICPERR_V_TMR 13 +#define ICPERR_M_TMR (1<<ICPERR_V_TMR) +#define ICPERR_V_TPE 12 +#define ICPERR_M_TPE (1<<ICPERR_V_TPE) +#define ICPERR_V_DPE 11 +#define ICPERR_M_DPE (1<<ICPERR_V_DPE) + +#define ICPERR_M_ALL (ICPERR_M_TMR | ICPERR_M_TPE | ICPERR_M_DPE) + +/* +** +** Exception Summary Register (EXC_SUM) Bit Summary +** +** Extent Size Name Type Function +** ------ ---- ---- ---- ------------------------------------ +** <16> 1 IOV WA Integer overflow +** <15> 1 INE WA Inexact result +** <14> 1 UNF WA Underflow +** <13> 1 FOV WA Overflow +** <12> 1 DZE WA Division by zero +** <11> 1 INV WA Invalid operation +** <10> 1 SWC WA Software completion +** +*/ + +#define EXC_V_IOV 16 +#define EXC_M_IOV (1<<EXC_V_IOV) +#define EXC_V_INE 15 +#define EXC_M_INE (1<<EXC_V_INE) +#define EXC_V_UNF 14 +#define EXC_M_UNF (1<<EXC_V_UNF) +#define EXC_V_FOV 13 +#define EXC_M_FOV (1<<EXC_V_FOV) +#define EXC_V_DZE 12 +#define EXC_M_DZE (1<<EXC_V_DZE) +#define EXC_V_INV 11 +#define EXC_M_INV (1<<EXC_V_INV) +#define EXC_V_SWC 10 +#define EXC_M_SWC (1<<EXC_V_SWC) + +/* +** +** Hardware Interrupt Clear Register (HWINT_CLR) Bit Summary +** +** Extent Size Name Type Function +** ------ ---- ---- ---- --------------------------------- +** <33> 1 SLC W1C Clear Serial Line interrupt +** <32> 1 CRDC W1C Clear Correctable Read Data interrupt +** <29> 1 PC2C W1C Clear Performance Counter 2 interrupt +** <28> 1 PC1C W1C Clear Performance Counter 1 interrupt +** <27> 1 PC0C W1C Clear Performance Counter 0 interrupt +** +*/ + +#define HWINT_V_SLC 33 +#define HWINT_M_SLC (1<<HWINT_V_SLC) +#define HWINT_V_CRDC 32 +#define HWINT_M_CRDC (1<<HWINT_V_CRDC) +#define HWINT_V_PC2C 29 +#define HWINT_M_PC2C (1<<HWINT_V_PC2C) +#define HWINT_V_PC1C 28 +#define HWINT_M_PC1C (1<<HWINT_V_PC1C) +#define HWINT_V_PC0C 27 +#define HWINT_M_PC0C (1<<HWINT_V_PC0C) + +/* +** +** Interrupt Summary Register (ISR) Bit Summary +** +** Extent Size Name Type Function +** ------ ---- ---- ---- --------------------------------- +** <34> 1 HLT RO External Halt interrupt +** <33> 1 SLI RO Serial Line interrupt +** <32> 1 CRD RO Correctable ECC errors +** <31> 1 MCK RO System Machine Check +** <30> 1 PFL RO Power Fail +** <29> 1 PC2 RO Performance Counter 2 interrupt +** <28> 1 PC1 RO Performance Counter 1 interrupt +** <27> 1 PC0 RO Performance Counter 0 interrupt +** <23> 1 I23 RO External Hardware interrupt +** <22> 1 I22 RO External Hardware interrupt +** <21> 1 I21 RO External Hardware interrupt +** <20> 1 I20 RO External Hardware interrupt +** <19> 1 ATR RO Async. System Trap request +** <18:4> 15 SIRR RO,0 Software Interrupt request +** <3:0> 4 ASTRR RO Async. System Trap request (USEK) +** +**/ + +#define ISR_V_HLT 34 +#define ISR_M_HLT (1<<ISR_V_HLT) +#define ISR_V_SLI 33 +#define ISR_M_SLI (1<<ISR_V_SLI) +#define ISR_V_CRD 32 +#define ISR_M_CRD (1<<ISR_V_CRD) +#define ISR_V_MCK 31 +#define ISR_M_MCK (1<<ISR_V_MCK) +#define ISR_V_PFL 30 +#define ISR_M_PFL (1<<ISR_V_PFL) +#define ISR_V_PC2 29 +#define ISR_M_PC2 (1<<ISR_V_PC2) +#define ISR_V_PC1 28 +#define ISR_M_PC1 (1<<ISR_V_PC1) +#define ISR_V_PC0 27 +#define ISR_M_PC0 (1<<ISR_V_PC0) +#define ISR_V_I23 23 +#define ISR_M_I23 (1<<ISR_V_I23) +#define ISR_V_I22 22 +#define ISR_M_I22 (1<<ISR_V_I22) +#define ISR_V_I21 21 +#define ISR_M_I21 (1<<ISR_V_I21) +#define ISR_V_I20 20 +#define ISR_M_I20 (1<<ISR_V_I20) +#define ISR_V_ATR 19 +#define ISR_M_ATR (1<<ISR_V_ATR) +#define ISR_V_SIRR 4 +#define ISR_M_SIRR (0x7FFF<<ISR_V_SIRR) +#define ISR_V_ASTRR 0 +#define ISR_M_ASTRR (0xF<<ISR_V_ASTRR) + +/* +** +** Mbox and D-Cache IPR Definitions: +** +*/ + +#define dtbAsn 0x200 /* WO - DTB Address Space Number */ +#define dtbCm 0x201 /* WO - DTB Current Mode */ +#define dtbTag 0x202 /* WO - DTB Tag */ +#define dtbPte 0x203 /* RW - DTB Page Table Entry */ +#define dtbPteTemp 0x204 /* RO - DTB Page Table Entry Temporary */ +#define mmStat 0x205 /* RO - D-Stream MM Fault Status */ +// replaced by ev5_defs.h #define va 0x206 /* RO - Faulting Virtual Address */ +#define vaForm 0x207 /* RO - Formatted Virtual Address */ +#define mVptBr 0x208 /* WO - Mbox Virtual Page Table Base */ +#define dtbIap 0x209 /* WO - DTB Invalidate All Process */ +#define dtbIa 0x20A /* WO - DTB Invalidate All */ +#define dtbIs 0x20B /* WO - DTB Invalidate Single */ +#define altMode 0x20C /* WO - Alternate Mode */ +// replaced by ev5_defs.h #define cc 0x20D /* WO - Cycle Counter */ +#define ccCtl 0x20E /* WO - Cycle Counter Control */ +// replaced by ev5_defs.h #define mcsr 0x20F /* RW - Mbox Control Register */ +#define dcFlush 0x210 /* WO - Dcache Flush */ +#define dcPerr 0x212 /* RW - Dcache Parity Error Status */ +#define dcTestCtl 0x213 /* RW - Dcache Test Tag Control */ +#define dcTestTag 0x214 /* RW - Dcache Test Tag */ +#define dcTestTagTemp 0x215 /* RW - Dcache Test Tag Temporary */ +#define dcMode 0x216 /* RW - Dcache Mode */ +#define mafMode 0x217 /* RW - Miss Address File Mode */ + +/* +** +** D-Stream MM Fault Status Register (MM_STAT) Bit Summary +** +** Extent Size Name Type Function +** ------ ---- ---- ---- --------------------------------- +** <16:11> 6 OPCODE RO Opcode of faulting instruction +** <10:06> 5 RA RO Ra field of faulting instruction +** <5> 1 BAD_VA RO Bad virtual address +** <4> 1 DTB_MISS RO Reference resulted in DTB miss +** <3> 1 FOW RO Fault on write +** <2> 1 FOR RO Fault on read +** <1> 1 ACV RO Access violation +** <0> 1 WR RO Reference type +** +*/ + +#define MMSTAT_V_OPC 11 +#define MMSTAT_M_OPC (0x3F<<MMSTAT_V_OPC) +#define MMSTAT_V_RA 6 +#define MMSTAT_M_RA (0x1F<<MMSTAT_V_RA) +#define MMSTAT_V_BAD_VA 5 +#define MMSTAT_M_BAD_VA (1<<MMSTAT_V_BAD_VA) +#define MMSTAT_V_DTB_MISS 4 +#define MMSTAT_M_DTB_MISS (1<<MMSTAT_V_DTB_MISS) +#define MMSTAT_V_FOW 3 +#define MMSTAT_M_FOW (1<<MMSTAT_V_FOW) +#define MMSTAT_V_FOR 2 +#define MMSTAT_M_FOR (1<<MMSTAT_V_FOR) +#define MMSTAT_V_ACV 1 +#define MMSTAT_M_ACV (1<<MMSTAT_V_ACV) +#define MMSTAT_V_WR 0 +#define MMSTAT_M_WR (1<<MMSTAT_V_WR) + + +/* +** +** Mbox Control Register (MCSR) Bit Summary +** +** Extent Size Name Type Function +** ------ ---- ---- ---- --------------------------------- +** <5> 1 DBG1 RW,0 Mbox Debug Packet Select +** <4> 1 E_BE RW,0 Ebox Big Endian mode enable +** <3> 1 DBG0 RW,0 Debug Test Select +** <2:1> 2 SP RW,0 Superpage mode enable +** <0> 1 M_BE RW,0 Mbox Big Endian mode enable +** +*/ + +#define MCSR_V_DBG1 5 +#define MCSR_M_DBG1 (1<<MCSR_V_DBG1) +#define MCSR_V_E_BE 4 +#define MCSR_M_E_BE (1<<MCSR_V_E_BE) +#define MCSR_V_DBG0 3 +#define MCSR_M_DBG0 (1<<MCSR_V_DBG0) +#define MCSR_V_SP 1 +#define MCSR_M_SP (3<<MCSR_V_SP) +#define MCSR_V_M_BE 0 +#define MCSR_M_M_BE (1<<MCSR_V_M_BE) + +/* +** +** Dcache Parity Error Status Register (DCPERR) Bit Summary +** +** Extent Size Name Type Function +** ------ ---- ---- ---- ------------------------------------ +** <5> 1 TP1 RO Dcache bank 1 tag parity error +** <4> 1 TP0 RO Dcache bank 0 tag parity error +** <3> 1 DP1 RO Dcache bank 1 data parity error +** <2> 1 DP0 RO Dcache bank 0 data parity error +** <1> 1 LOCK W1C Locks/clears bits <5:2> +** <0> 1 SEO W1C Second Dcache parity error occurred +** +*/ + +#define DCPERR_V_TP1 5 +#define DCPERR_M_TP1 (1<<DCPERR_V_TP1) +#define DCPERR_V_TP0 4 +#define DCPERR_M_TP0 (1<<DCPERR_V_TP0) +#define DCPERR_V_DP1 3 +#define DCPERR_M_DP1 (1<<DCPERR_V_DP1) +#define DCPERR_V_DP0 2 +#define DCPERR_M_DP0 (1<<DCPERR_V_DP0) +#define DCPERR_V_LOCK 1 +#define DCPERR_M_LOCK (1<<DCPERR_V_LOCK) +#define DCPERR_V_SEO 0 +#define DCPERR_M_SEO (1<<DCPERR_V_SEO) + +#define DCPERR_M_ALL (DCPERR_M_LOCK | DCPERR_M_SEO) + +/* +** +** Dcache Mode Register (DC_MODE) Bit Summary +** +** Extent Size Name Type Function +** ------ ---- ---- ---- --------------------------------- +** <4> 1 DOA RO Hardware Dcache Disable +** <3> 1 PERR_DIS RW,0 Disable Dcache Parity Error reporting +** <2> 1 BAD_DP RW,0 Force Dcache data bad parity +** <1> 1 FHIT RW,0 Force Dcache hit +** <0> 1 ENA RW,0 Software Dcache Enable +** +*/ + +#define DC_V_DOA 4 +#define DC_M_DOA (1<<DC_V_DOA) +#define DC_V_PERR_DIS 3 +#define DC_M_PERR_DIS (1<<DC_V_PERR_DIS) +#define DC_V_BAD_DP 2 +#define DC_M_BAD_DP (1<<DC_V_BAD_DP) +#define DC_V_FHIT 1 +#define DC_M_FHIT (1<<DC_V_FHIT) +#define DC_V_ENA 0 +#define DC_M_ENA (1<<DC_V_ENA) + +/* +** +** Miss Address File Mode Register (MAF_MODE) Bit Summay +** +** Extent Size Name Type Function +** ------ ---- ---- ---- --------------------------------- +** <7> 1 WB RO,0 If set, pending WB request +** <6> 1 DREAD RO,0 If set, pending D-read request +** +*/ + +#define MAF_V_WB_PENDING 7 +#define MAF_M_WB_PENDING (1<<MAF_V_WB_PENDING) +#define MAF_V_DREAD_PENDING 6 +#define MAF_M_DREAD_PENDING (1<<MAF_V_DREAD_PENDING) + +/* +** +** Cbox IPR Definitions: +** +*/ + +#define scCtl 0x0A8 /* RW - Scache Control */ +#define scStat 0x0E8 /* RO - Scache Error Status */ +#define scAddr 0x188 /* RO - Scache Error Address */ +#define bcCtl 0x128 /* WO - Bcache/System Interface Control */ +#define bcCfg 0x1C8 /* WO - Bcache Configuration Parameters */ +#define bcTagAddr 0x108 /* RO - Bcache Tag */ +#define eiStat 0x168 /* RO - Bcache/System Error Status */ +#define eiAddr 0x148 /* RO - Bcache/System Error Address */ +#define fillSyn 0x068 /* RO - Fill Syndrome */ +#define ldLock 0x1E8 /* RO - LDx_L Address */ + +/* +** +** Scache Control Register (SC_CTL) Bit Summary +** +** Extent Size Name Type Function +** ------ ---- ---- ---- --------------------------------- +** <15:13> 3 SET_EN RW,1 Set enable +** <12> 1 BLK_SIZE RW,1 Scache/Bcache block size select +** <11:08> 4 FB_DP RW,0 Force bad data parity +** <07:02> 6 TAG_STAT RW Tag status and parity +** <1> 1 FLUSH RW,0 If set, clear all tag valid bits +** <0> 1 FHIT RW,0 Force hits +** +*/ + +#define SC_V_SET_EN 13 +#define SC_M_SET_EN (7<<SC_V_SET_EN) +#define SC_V_BLK_SIZE 12 +#define SC_M_BLK_SIZE (1<<SC_V_BLK_SIZE) +#define SC_V_FB_DP 8 +#define SC_M_FB_DP (0xF<<SC_V_FB_DP) +#define SC_V_TAG_STAT 2 +#define SC_M_TAG_STAT (0x3F<<SC_V_TAG_STAT) +#define SC_V_FLUSH 1 +#define SC_M_FLUSH (1<<SC_V_FLUSH) +#define SC_V_FHIT 0 +#define SC_M_FHIT (1<<SC_V_FHIT) + +/* +** +** Bcache Control Register (BC_CTL) Bit Summary +** +** Extent Size Name Type Function +** ------ ---- ---- ---- --------------------------------- +** <27> 1 DIS_VIC_BUF WO,0 Disable Scache victim buffer +** <26> 1 DIS_BAF_BYP WO,0 Disable speculative Bcache reads +** <25> 1 DBG_MUX_SEL WO,0 Debug MUX select +** <24:19> 6 PM_MUX_SEL WO,0 Performance counter MUX select +** <18:17> 2 BC_WAVE WO,0 Number of cycles of wave pipelining +** <16> 1 TL_PIPE_LATCH WO,0 Pipe system control pins +** <15> 1 EI_DIS_ERR WO,1 Disable ECC (parity) error +** <14:13> 2 BC_BAD_DAT WO,0 Force bad data +** <12:08> 5 BC_TAG_STAT WO Bcache tag status and parity +** <7> 1 BC_FHIT WO,0 Bcache force hit +** <6> 1 EI_ECC WO,1 ECC or byte parity mode +** <5> 1 VTM_FIRST WO,1 Drive out victim block address first +** <4> 1 CORR_FILL_DAT WO,1 Correct fill data +** <3> 1 EI_CMD_GRP3 WO,0 Drive MB command to external pins +** <2> 1 EI_CMD_GRP2 WO,0 Drive LOCK & SET_DIRTY to ext. pins +** <1> 1 ALLOC_CYC WO,0 Allocate cycle for non-cached LDs. +** <0> 1 BC_ENA W0,0 Bcache enable +** +*/ +#define BC_V_DIS_SC_VIC_BUF 27 +#define BC_M_DIS_SC_VIC_BUF (1<<BC_V_DIS_SC_VIC_BUF) +#define BC_V_DIS_BAF_BYP 26 +#define BC_M_DIS_BAF_BYP (1<<BC_V_DIS_BAF_BYP) +#define BC_V_DBG_MUX_SEL 25 +#define BC_M_DBG_MUX_SEL (1<<BC_V_DBG_MUX_SEL) +#define BC_V_PM_MUX_SEL 19 +#define BC_M_PM_MUX_SEL (0x3F<<BC_V_PM_MUX_SEL) +#define BC_V_BC_WAVE 17 +#define BC_M_BC_WAVE (3<<BC_V_BC_WAVE) +#define BC_V_TL_PIPE_LATCH 16 +#define BC_M_TL_PIPE_LATCH (1<<BC_V_TL_PIPE_LATCH) +#define BC_V_EI_DIS_ERR 15 +#define BC_M_EI_DIS_ERR (1<<BC_V_EI_DIS_ERR) +#define BC_V_BC_BAD_DAT 13 +#define BC_M_BC_BAD_DAT (3<<BC_V_BC_BAD_DAT) +#define BC_V_BC_TAG_STAT 8 +#define BC_M_BC_TAG_STAT (0x1F<<BC_V_BC_TAG_STAT) +#define BC_V_BC_FHIT 7 +#define BC_M_BC_FHIT (1<<BC_V_BC_FHIT) +#define BC_V_EI_ECC_OR_PARITY 6 +#define BC_M_EI_ECC_OR_PARITY (1<<BC_V_EI_ECC_OR_PARITY) +#define BC_V_VTM_FIRST 5 +#define BC_M_VTM_FIRST (1<<BC_V_VTM_FIRST) +#define BC_V_CORR_FILL_DAT 4 +#define BC_M_CORR_FILL_DAT (1<<BC_V_CORR_FILL_DAT) +#define BC_V_EI_CMD_GRP3 3 +#define BC_M_EI_CMD_GRP3 (1<<BC_V_EI_CMD_GRP3) +#define BC_V_EI_CMD_GRP2 2 +#define BC_M_EI_CMD_GRP2 (1<<BC_V_EI_CMD_GRP2) +#define BC_V_ALLOC_CYC 1 +#define BC_M_ALLOC_CYC (1<<BC_V_ALLOC_CYC) +#define BC_V_BC_ENA 0 +#define BC_M_BC_ENA (1<<BC_V_BC_ENA) + +#define BC_K_DFAULT \ + (((BC_M_EI_DIS_ERR) | \ + (BC_M_EI_ECC_OR_PARITY) | \ + (BC_M_VTM_FIRST) | \ + (BC_M_CORR_FILL_DAT))>>1) +/* +** +** Bcache Configuration Register (BC_CONFIG) Bit Summary +** +** Extent Size Name Type Function +** ------ ---- ---- ---- --------------------------------- +** <35:29> 7 RSVD WO Reserved - Must Be Zero +** <28:20> 9 WE_CTL WO,0 Bcache write enable control +** <19:19> 1 RSVD WO,0 Reserved - Must Be Zero +** <18:16> 3 WE_OFF WO,1 Bcache fill write enable pulse offset +** <15:15> 1 RSVD WO,0 Reserved - Must Be Zero +** <14:12> 3 RD_WR_SPC WO,7 Bcache private read/write spacing +** <11:08> 4 WR_SPD WO,4 Bcache write speed in CPU cycles +** <07:04> 4 RD_SPD WO,4 Bcache read speed in CPU cycles +** <03:03> 1 RSVD WO,0 Reserved - Must Be Zero +** <02:00> 3 SIZE WO,1 Bcache size +*/ +#define BC_V_WE_CTL 20 +#define BC_M_WE_CTL (0x1FF<<BC_V_WE_CTL) +#define BC_V_WE_OFF 16 +#define BC_M_WE_OFF (0x7<<BC_V_WE_OFF) +#define BC_V_RD_WR_SPC 12 +#define BC_M_RD_WR_SPC (0x7<<BC_V_RD_WR_SPC) +#define BC_V_WR_SPD 8 +#define BC_M_WR_SPD (0xF<<BC_V_WR_SPD) +#define BC_V_RD_SPD 4 +#define BC_M_RD_SPD (0xF<<BC_V_RD_SPD) +#define BC_V_SIZE 0 +#define BC_M_SIZE (0x7<<BC_V_SIZE) + +#define BC_K_CONFIG \ + ((0x1<<BC_V_WE_OFF) | \ + (0x7<<BC_V_RD_WR_SPC) | \ + (0x4<<BC_V_WR_SPD) | \ + (0x4<<BC_V_RD_SPD) | \ + (0x1<<BC_V_SIZE)) + +/* +** +** DECchip 21164 Privileged Architecture Library Entry Offsets: +** +** Entry Name Offset (Hex) +** +** RESET 0000 +** IACCVIO 0080 +** INTERRUPT 0100 +** ITB_MISS 0180 +** DTB_MISS (Single) 0200 +** DTB_MISS (Double) 0280 +** UNALIGN 0300 +** D_FAULT 0380 +** MCHK 0400 +** OPCDEC 0480 +** ARITH 0500 +** FEN 0580 +** CALL_PAL (Privileged) 2000 +** CALL_PAL (Unprivileged) 3000 +** +*/ + +#define PAL_RESET_ENTRY 0x0000 +#define PAL_IACCVIO_ENTRY 0x0080 +#define PAL_INTERRUPT_ENTRY 0x0100 +#define PAL_ITB_MISS_ENTRY 0x0180 +#define PAL_DTB_MISS_ENTRY 0x0200 +#define PAL_DOUBLE_MISS_ENTRY 0x0280 +#define PAL_UNALIGN_ENTRY 0x0300 +#define PAL_D_FAULT_ENTRY 0x0380 +#define PAL_MCHK_ENTRY 0x0400 +#define PAL_OPCDEC_ENTRY 0x0480 +#define PAL_ARITH_ENTRY 0x0500 +#define PAL_FEN_ENTRY 0x0580 +#define PAL_CALL_PAL_PRIV_ENTRY 0x2000 +#define PAL_CALL_PAL_UNPRIV_ENTRY 0x3000 + +/* +** +** Architecturally Reserved Opcode (PALRES) Definitions: +** +*/ + +#define mtpr hw_mtpr +#define mfpr hw_mfpr + +#define ldl_a hw_ldl/a +#define ldq_a hw_ldq/a +#define stq_a hw_stq/a +#define stl_a hw_stl/a + +#define ldl_p hw_ldl/p +#define ldq_p hw_ldq/p +#define stl_p hw_stl/p +#define stq_p hw_stq/p + +/* +** Virtual PTE fetch variants of HW_LD. +*/ +#define ld_vpte hw_ldq/v + +/* +** Physical mode load-lock and store-conditional variants of +** HW_LD and HW_ST. +*/ + +#define ldq_lp hw_ldq/pl +#define stq_cp hw_stq/pc + +/* +** +** General Purpose Register Definitions: +** +*/ + +#define r0 $0 +#define r1 $1 +#define r2 $2 +#define r3 $3 +#define r4 $4 +#define r5 $5 +#define r6 $6 +#define r7 $7 +#define r8 $8 +#define r9 $9 +#define r10 $10 +#define r11 $11 +#define r12 $12 +#define r13 $13 +#define r14 $14 +#define r15 $15 +#define r16 $16 +#define r17 $17 +#define r18 $18 +#define r19 $19 +#define r20 $20 +#define r21 $21 +#define r22 $22 +#define r23 $23 +#define r24 $24 +#define r25 $25 +#define r26 $26 +#define r27 $27 +#define r28 $28 +#define r29 $29 +#define r30 $30 +#define r31 $31 + +/* +** +** Floating Point Register Definitions: +** +*/ + +#define f0 $f0 +#define f1 $f1 +#define f2 $f2 +#define f3 $f3 +#define f4 $f4 +#define f5 $f5 +#define f6 $f6 +#define f7 $f7 +#define f8 $f8 +#define f9 $f9 +#define f10 $f10 +#define f11 $f11 +#define f12 $f12 +#define f13 $f13 +#define f14 $f14 +#define f15 $f15 +#define f16 $f16 +#define f17 $f17 +#define f18 $f18 +#define f19 $f19 +#define f20 $f20 +#define f21 $f21 +#define f22 $f22 +#define f23 $f23 +#define f24 $f24 +#define f25 $f25 +#define f26 $f26 +#define f27 $f27 +#define f28 $f28 +#define f29 $f29 +#define f30 $f30 +#define f31 $f31 + +/* +** +** PAL Temporary Register Definitions: +** +*/ + +// covered by fetch distribution..pb Nov/95 + +// #define pt0 0x140 +// #define pt1 0x141 +// #define pt2 0x142 +// #define pt3 0x143 +// #define pt4 0x144 +// #define pt5 0x145 +// #define pt6 0x146 +// #define pt7 0x147 +// #define pt8 0x148 +// #define pt9 0x149 +// #define pt10 0x14A +// #define pt11 0x14B +// #define pt12 0x14C +// #define pt13 0x14D +// #define pt14 0x14E +// #define pt15 0x14F +// #define pt16 0x150 +// #define pt17 0x151 +// #define pt18 0x152 +// #define pt19 0x153 +// #define pt20 0x154 +// #define pt21 0x155 +// #define pt22 0x156 +// #define pt23 0x157 + +/* +** PAL Shadow Registers: +** +** The DECchip 21164 shadows r8-r14 and r25 when in PALmode and +** ICSR<SDE> = 1. +*/ + +#define p0 r8 /* ITB/DTB Miss Scratch */ +#define p1 r9 /* ITB/DTB Miss Scratch */ +#define p2 r10 /* ITB/DTB Miss Scratch */ +#define p3 r11 +// #define ps r11 /* Processor Status */ +#define p4 r12 /* Local Scratch */ +#define p5 r13 /* Local Scratch */ +#define p6 r14 /* Local Scratch */ +#define p7 r25 /* Local Scratch */ + +/* +** SRM Defined State Definitions: +*/ + +/* +** This table is an accounting of the DECchip 21164 storage used to +** implement the SRM defined state for OSF/1. +** +** IPR Name Internal Storage +** -------- ---------------- +** Processor Status ps, dtbCm, ipl, r11 +** Program Counter Ibox +** Interrupt Entry ptEntInt +** Arith Trap Entry ptEntArith +** MM Fault Entry ptEntMM +** Unaligned Access Entry ptEntUna +** Instruction Fault Entry ptEntIF +** Call System Entry ptEntSys +** User Stack Pointer ptUsp +** Kernel Stack Pointer ptKsp +** Kernel Global Pointer ptKgp +** System Value ptSysVal +** Page Table Base Register ptPtbr +** Virtual Page Table Base iVptBr, mVptBr +** Process Control Block Base ptPcbb +** Address Space Number itbAsn, dtbAsn +** Cycle Counter cc, ccCtl +** Float Point Enable icsr +** Lock Flag Cbox/System +** Unique PCB +** Who-Am-I ptWhami +*/ + +#define ptEntUna pt2 /* Unaligned Access Dispatch Entry */ +#define ptImpure pt3 /* Pointer To PAL Scratch Area */ +#define ptEntIF pt7 /* Instruction Fault Dispatch Entry */ +#define ptIntMask pt8 /* Interrupt Enable Mask */ +#define ptEntSys pt9 /* Call System Dispatch Entry */ +#define ptTrap pt11 +#define ptEntInt pt11 /* Hardware Interrupt Dispatch Entry */ +#define ptEntArith pt12 /* Arithmetic Trap Dispatch Entry */ +#if defined(KDEBUG) +#define ptEntDbg pt13 /* Kernel Debugger Dispatch Entry */ +#endif /* KDEBUG */ +#define ptMisc pt16 /* Miscellaneous Flags */ +#define ptWhami pt16 /* Who-Am-I Register Pt16<15:8> */ +#define ptMces pt16 /* Machine Check Error Summary Pt16<4:0> */ +#define ptSysVal pt17 /* Per-Processor System Value */ +#define ptUsp pt18 /* User Stack Pointer */ +#define ptKsp pt19 /* Kernel Stack Pointer */ +#define ptPtbr pt20 /* Page Table Base Register */ +#define ptEntMM pt21 /* MM Fault Dispatch Entry */ +#define ptKgp pt22 /* Kernel Global Pointer */ +#define ptPcbb pt23 /* Process Control Block Base */ + +/* +** +** Miscellaneous PAL State Flags (ptMisc) Bit Summary +** +** Extent Size Name Function +** ------ ---- ---- --------------------------------- +** <55:48> 8 SWAP Swap PALcode flag -- character 'S' +** <47:32> 16 MCHK Machine Check Error code +** <31:16> 16 SCB System Control Block vector +** <15:08> 8 WHAMI Who-Am-I identifier +** <04:00> 5 MCES Machine Check Error Summary bits +** +*/ + +#define PT16_V_MCES 0 +#define PT16_V_WHAMI 8 +#define PT16_V_SCB 16 +#define PT16_V_MCHK 32 +#define PT16_V_SWAP 48 + +#endif /* DC21164FROMGASSOURCES_INCLUDED */ diff --git a/system/alpha/h/eb164mem.h b/system/alpha/h/eb164mem.h deleted file mode 100644 index 0e35de570..000000000 --- a/system/alpha/h/eb164mem.h +++ /dev/null @@ -1,71 +0,0 @@ -#ifndef __EB164MEM_H_LOADED -#define __EB164MEM_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: eb164mem.h,v 1.1.1.1 1997/10/30 23:27:14 verghese Exp $; - */ - -/* - * $Log: eb164mem.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:14 verghese - * current 10/29/97 - * - * Revision 1.2 1995/04/20 16:37:48 cruz - * Made some macro definition changes. - * - * Revision 1.1 1994/12/19 18:33:33 cruz - * Initial revision - * - * - */ - -#ifdef EB164 - -#include "system.h" -#include "lib.h" -#include "cia.h" - -#ifndef MAKEDEPEND -#include "cserve.h" -#endif - - -/* - * Macros used to access the memory controller - * csr's. - */ -#define MEM_MCR(x) (((ul)MC_MCR_BASE<<MC_MCR_BASE_SHIFT)|(ul)(x)) -#define _IN_MEM_MCR(p) (ReadL(MEM_MCR(p))) -#define _OUT_MEM_MCR(p,d) WriteL((MEM_MCR(p)),d);mb(); - -#define MEM_GCR(x) (((ul)MC_GCR_BASE<<MC_GCR_BASE_SHIFT)|(ul)(x)) -#define _IN_MEM_GCR(p) (ReadL(MEM_GCR(p))) -#define _OUT_MEM_GCR(p,d) WriteL((MEM_GCR(p)),d);mb(); - -#endif /* EB164 */ -#endif /* __EB164MEM_H_LOADED */ diff --git a/system/alpha/h/eb64.h b/system/alpha/h/eb64.h deleted file mode 100644 index e79e09ee2..000000000 --- a/system/alpha/h/eb64.h +++ /dev/null @@ -1,180 +0,0 @@ -#ifndef __EB64_H_LOADED -#define __EB64_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: eb64.h,v 1.1.1.1 1997/10/30 23:27:14 verghese Exp $; - */ - -/* - * $Log: eb64.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:14 verghese - * current 10/29/97 - * - * Revision 1.19 1995/03/05 12:06:43 fdh - * Adjusted ROMINC to access ROM bytes at - * longword boundaries as required. - * - * Revision 1.18 1995/03/05 04:18:20 fdh - * Changed ROMBASE and ROMINC definitions to use the - * I/O bus addresses by using inrom(). - * - * Revision 1.17 1995/02/10 02:56:08 fdh - * Disabled bootopt command because the current SROM doesn't support it. - * - * Revision 1.16 1994/11/28 18:26:46 fdh - * Added definition to enable the special ROM access - * required for the EB64. - * - * Revision 1.15 1994/11/08 21:36:10 fdh - * Added ROM definitions. Moved from rom.c - * - * Revision 1.14 1994/08/05 20:13:47 fdh - * Updated Copyright header and RCS $Id: identifier. - * - * Revision 1.13 1994/07/21 18:09:32 fdh - * Added MAXIMUM_SYSTEM_CACHE definition. - * - * Revision 1.12 1994/06/20 14:18:59 fdh - * Fixup header file preprocessor #include conditionals. - * - * Revision 1.11 1994/04/06 05:09:11 fdh - * Removed an ethernet driver. - * - * Revision 1.10 1994/04/04 15:15:44 fdh - * Added definition for LEDPORT. - * - * Revision 1.9 1994/04/01 13:57:22 fdh - * Added MINIMUM_SYSTEM_MEMORY definition and - * removed obsoleted PAL_IMPURE definition. - * - * Revision 1.8 1994/03/24 21:42:14 fdh - * Removed unnecessary compile-time conditionals. - * - * Revision 1.7 1994/02/14 16:25:01 rusling - * Allow remote debug support in the NT build case. - * - * Revision 1.6 1994/01/19 10:22:28 rusling - * Ported to ALpha Windows NT. - * - * Revision 1.5 1993/11/22 15:24:30 rusling - * Fixed up am79c960 embedded definitions. - * - * Revision 1.4 1993/11/22 14:20:41 rusling - * Modified am79c960 definitions. - * - * Revision 1.3 1993/11/22 13:17:13 rusling - * Merged with PCI/21040 changes. - * - * Revision 1.2 1993/11/22 12:16:20 rusling - * Added in further definitions - * - * Revision 1.1 1993/11/22 11:42:50 rusling - * Initial revision - * - */ - -#ifdef EB64 - -#define BANNER "DECchip 21064 Evaluation Board (EB64) Debug Monitor" -#define PROMPT "EB64> " - -/**************************************************************************** - * Basic * - ****************************************************************************/ - -#define NEEDSCTL -#define NEEDDEBUGGER -#define NEEDAM79C960 -#define NEEDFLOPPY -#define NEEDEB64SPECIALROMACCESS -#define DISABLEBOOTOPTION /* Current SROM does not support this */ - -/**************************************************************************** - * Plug in cards, what does it have? * - ****************************************************************************/ -/* - * The Allied Telesis card is an ISA card based on the am79c960 - * chip. - */ -#define ALLIED_TELESIS_AT_1500T - -/* - * The DEC Etherworks ISA card is a LANCE like device. - */ -#define DEC_ETHERWORKS - -/**************************************************************************** - * ISA Address Space * - ****************************************************************************/ - -#define LEDPORT 0x80 /* JDR Microdevices P.O.S.T. Diagnostics Card. */ - -/* - * am79c960 definitions, see /h/am79c960.h for more definitions - * and /ether/am79c960_driver.c for the device driver. - */ -#ifdef NEEDAM79C960 -#define EMBEDDED_AM79C960 -#define EMBEDDED_AM79C960_BASE 0x360 -#define EMBEDDED_AM79C960_INT 9 -#define EMBEDDED_AM79C960_DMA 1 -#endif - -/* - * Allied telesis is optional. We treat it like an optional - * am79c960 as far as the driver is concerned, see /h/am79c960.h - * for more definitions. - */ -#ifdef ALLIED_TELESIS_AT_1500T -#define OPTIONAL_AM79C960 /* warning only define this once */ -#define OPTIONAL_AM79C960_BASE 0x340 -#define OPTIONAL_AM79C960_INT 12 -#define OPTIONAL_AM79C960_DMA 2 -#endif - -#ifdef DEC_ETHERWORKS -#define DEC_ETHERWORKS_BASE 0x300 -#endif - -/**************************************************************************** - * System Address Space * - ****************************************************************************/ - -#define MINIMUM_SYSTEM_MEMORY 0x400000 -#define MAXIMUM_SYSTEM_CACHE 0x80000 -#define DMA_BUFF_BASE 0x100000 - -#define ROMBASE 0x0 -#define ROMSIZE 0x80000 -#define ROMINC 0x4 - -#endif /* EB64 */ -#endif /* __EB64_H_LOADED */ - - - diff --git a/system/alpha/h/eb64l.h b/system/alpha/h/eb64l.h deleted file mode 100644 index c709e3c32..000000000 --- a/system/alpha/h/eb64l.h +++ /dev/null @@ -1,66 +0,0 @@ -#ifndef __EB64L_H_LOADED -#define __EB64L_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: eb64l.h,v 1.1.1.1 1997/10/30 23:27:14 verghese Exp $; - */ - -/* - * $Log: eb64l.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:14 verghese - * current 10/29/97 - * - * Revision 1.2 1995/02/10 02:21:59 fdh - * Corrected AlphaPC64 banner and prompt. - * - * Revision 1.1 1994/12/08 16:42:29 fdh - * Initial revision - * - */ - -#ifdef EB64L -/* - * Declare special definitions for systems with only - * minor variations from the standard system described - * by this file. To build for a variant board, declare - * the variant definition in addition to the standard - * definition. example... -DEB64P -DEB64L - */ -#include "eb64p.h" - -#undef BANNER -#define BANNER "AlphaPC64 Evaluation Board Debug Monitor" -#undef PROMPT -#define PROMPT "AlphaPC64> " -#undef ROMSIZE -#define ROMSIZE 0x100000 -#define NEEDFLASHMEMORY -#define INTEL_28F008SA - -#endif /* EB64L */ -#endif /* __EB64L_H_LOADED */ diff --git a/system/alpha/h/eb64mem.h b/system/alpha/h/eb64mem.h deleted file mode 100644 index 7debf03bb..000000000 --- a/system/alpha/h/eb64mem.h +++ /dev/null @@ -1,73 +0,0 @@ -#ifndef __EB64MEM_H_LOADED -#define __EB64MEM_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: eb64mem.h,v 1.1.1.1 1997/10/30 23:27:14 verghese Exp $; - */ - -/* - * $Log: eb64mem.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:14 verghese - * current 10/29/97 - * - * Revision 1.4 1994/11/22 23:47:01 fdh - * Don't include PALcode include files for make depend. - * - * Revision 1.3 1994/11/07 11:58:55 rusling - * Include system.h and lib.h in the correct order. - * - * Revision 1.2 1994/08/05 20:13:47 fdh - * Updated Copyright header and RCS $Id: identifier. - * - * Revision 1.1 1994/07/21 18:11:01 fdh - * Initial revision - * - */ - -#ifdef EB64 - -#include "system.h" -#include "lib.h" - -#ifndef MAKEDEPEND -#include "cserve.h" -#include "dc21064.h" -#endif - -#define SCTL_M_BCE (1<<25) -#define BYTE_ENABLE_SHIFT 7 -#define TRANSFER_LENGTH_SHIFT 5 -#define IO (((ul)(-1)<<42)|((ul)1<<33)) /* CPU Adr[33]=1 select I/O space. */ -#define Lng ((ui)3<<TRANSFER_LENGTH_SHIFT) -#define ROM(x) (IO|Lng|(((ul)(x)&0x7fffff)<<BYTE_ENABLE_SHIFT)) - -#define _IN_SCTL ((ReadL(ROM(0)))&0xFFFFFF00) -#define _OUT_SCTL(d) WriteL(ROM(0),(d&0xFFFFFF00));mb(); - -#endif /* EB64 */ -#endif /* __EB64MEM_H_LOADED */ diff --git a/system/alpha/h/eb64p.h b/system/alpha/h/eb64p.h deleted file mode 100644 index 06ff71c3a..000000000 --- a/system/alpha/h/eb64p.h +++ /dev/null @@ -1,265 +0,0 @@ -#ifndef __EB64P_H_LOADED -#define __EB64P_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: eb64p.h,v 1.1.1.1 1997/10/30 23:27:14 verghese Exp $; - */ - -/* - * $Log: eb64p.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:14 verghese - * current 10/29/97 - * - * Revision 1.24 1995/02/10 02:56:08 fdh - * Disabled bootopt command because the current SROM doesn't support it. - * - * Revision 1.23 1994/12/08 16:42:29 fdh - * Removed Cabriolet (EB64L) definitions. Moved to eb64l.h - * - * Revision 1.22 1994/11/17 14:15:05 fdh - * Modified definitions for EB64LC - * - * Revision 1.21 1994/11/08 21:36:39 fdh - * Added ROM definitions. Moved from rom.c - * Also added Flash ROM definitions to support - * a variant of the EB64+ design. - * - * Revision 1.20 1994/08/05 20:13:47 fdh - * Updated Copyright header and RCS $Id: identifier. - * - * Revision 1.19 1994/07/21 18:09:32 fdh - * Added MAXIMUM_SYSTEM_CACHE definition. - * - * Revision 1.18 1994/06/28 20:08:21 fdh - * Modified filenames and build precedure to fit into a FAT filesystem. - * - * Revision 1.17 1994/06/20 14:18:59 fdh - * Fixup header file preprocessor #include conditionals. - * - * Revision 1.16 1994/04/06 05:09:55 fdh - * Removed and ethernet driver. - * - * Revision 1.15 1994/04/04 15:16:18 fdh - * Added definition for LEDPORT. - * - * Revision 1.14 1994/04/01 13:58:13 fdh - * Added MINIMUM_SYSTEM_MEMORY definition and - * removed obsoleted PAL_IMPURE definition. - * Modified BANNER definition - * - * Revision 1.13 1994/03/24 21:42:37 fdh - * Removed unnecessary compile-time conditionals. - * - * Revision 1.12 1994/03/16 14:28:28 rusling - * Let WNT versions have the debug code in them. - * - * Revision 1.11 1994/03/05 22:22:20 fdh - * Added Apecs pass2.0 support. Use -DAPECS_PASS1to support pass 1.0. - * - * Revision 1.10 1994/01/27 20:36:23 fdh - * Modified the Amd79c960 definitions to accomodate Ladebug. - * - * Revision 1.9 1994/01/27 18:12:14 fdh - * Modify PCI Target window definitions for a - * 1 megabyte window at 1 megabyte mapping into 1 megabyte. - * - * Revision 1.8 1994/01/19 10:22:28 rusling - * Ported to ALpha Windows NT. - * - * Revision 1.7 1993/11/30 15:29:22 rusling - * Mostly complete versions. I've integrated changes to - * the PCI to system address space mappings with all the - * definitions in the system specific include file. - * - * Revision 1.6 1993/11/23 10:43:50 rusling - * Added in APECS information (taking it from pci.h). - * - * Revision 1.5 1993/11/22 16:30:23 rusling - * Fixed up (#ifdef EB64p -> EB64P). - * - * Revision 1.4 1993/11/22 14:23:03 rusling - * Modified the am8=79c960 definitions. - * - * Revision 1.3 1993/11/22 13:17:55 rusling - * *** empty log message *** - * - * Revision 1.2 1993/11/22 12:16:20 rusling - * Added in further definitions - * - * Revision 1.2 1993/11/22 12:16:20 rusling - * Added in further definitions - * - * Revision 1.1 1993/11/22 11:43:11 rusling - * Initial revision - * - */ - -#ifdef EB64P - -#define BANNER "DECchip 21064 PCI Evaluation Board (EB64+) Debug Monitor" -#define PROMPT "EB64+ " - -/**************************************************************************** - * Basic * - ****************************************************************************/ - -#define NEEDPCI -#define NEEDDEBUGGER -#define NEEDFLOPPY -#define DISABLEBOOTOPTION /* Current SROM does not support this */ - -/**************************************************************************** - * EPIC (Part of APECS) definitions * - ****************************************************************************/ -#define EPIC_CSR 0x000 -#define EPIC_PCI_TBASE_1 0x0C0 -#define EPIC_PCI_TBASE_2 0x0E0 -#define EPIC_PCI_BASE_1 0x100 -#define EPIC_PCI_BASE_2 0x120 -#define EPIC_PCI_MASK_1 0x140 -#define EPIC_PCI_MASK_2 0x160 -#define EPIC_HAXR0 0x180 -#define EPIC_HAXR1 0x1A0 -#define EPIC_HAXR2 0x1C0 - -#define EPIC_CSR_M_NDEV 0x800 - -#ifdef APECS_PASS1 -#define EPIC_CSR_M_RWC 0xFFE0 -#else -#define EPIC_CSR_M_RWC 0xFF60 -#endif - -#define EPIC_PCI_BASE_M_WENB 0x80000 - -/**************************************************************************** - * Plug in cards, what does it have? * - ****************************************************************************/ -/* - * The Allied Telesis card is an ISA card based on the am79c960 - * chip. - */ -#define ALLIED_TELESIS_AT_1500T - -/* - * The DEC Etherworks ISA card is a LANCE like device. - */ -#define DEC_ETHERWORKS - -#define NEED21040 - -/**************************************************************************** - * ISA Address Space * - ****************************************************************************/ - -#define RTCBASE 0x70 -#define LEDPORT 0x80 /* JDR Microdevices P.O.S.T. Diagnostics Card. */ - - -/* - * Allied telesis is optional. We treat it like an optional - * am79c960 as far as the driver is concerned, see /h/am79c960.h - * for more definitions and /ether/am79c960.c for the device - * driver. - */ -#ifdef ALLIED_TELESIS_AT_1500T -#define OPTIONAL_AM79C960 /* warning only define this once */ -#define NEEDAM79C960 /* same for this */ -#define OPTIONAL_AM79C960_BASE 0x360 -#define OPTIONAL_AM79C960_INT 9 - -/* - * This parameter determines the - * DMA Mask for the DMA2 controller. - * Mask Channel - * ---- ------- - * 1 5 - * 2 6 - * 3 7 - * 4 8 - */ -#define OPTIONAL_AM79C960_DMA 1 /* Selects DMA Channel 5 */ -#endif - -#ifdef DEC_ETHERWORKS -#define DEC_ETHERWORKS_BASE 0x300 -#endif - -#ifdef DEC_ETHERWORKS -#define DEC_ETHERWORKS_BASE 0x300 -#endif - - -/**************************************************************************** - * System Address Space * - ****************************************************************************/ - -#define MINIMUM_SYSTEM_MEMORY 0x1000000 -#define MAXIMUM_SYSTEM_CACHE 0x200000 -#define DMA_BUFF_BASE 0x100000 - - -/**************************************************************************** - * PCI I/O Address Space * - ****************************************************************************/ -/* - * Definitions for the windows mapping PCI addresses into - * system addresses - * - * 1 megabyte window at 1 megabyte mapping into 1 megabyte. - */ -#define PCI_BASE_1_USED 1 -#define PCI_BASE_1 0x000100000 -#define PCI_MASK_1 0x000000000 -#define PCI_TBASE_1 0x000100000 - -#define PCI_BASE_2_USED 0 -#define PCI_BASE_2 0x010000000 -#define PCI_MASK_2 0x00FF00000 -#define PCI_TBASE_2 0x000000000 - -/* - * Each mask translates to a number of these units. For - * APECS this unit is 1Kbyte. - */ -#define PCI_MASK_UNIT 0x100000 - -/* - * Where do we start allocating addresses from in PCI I/O space? - */ -#define PCI_IO_BASE 0xB000 - -/* - * ROM definitions. - */ -#define ROMBASE 0xFFF80000 -#define ROMSIZE 0x80000 -#define ROMINC 0x1 - -#endif /* EB64P */ -#endif /* __EB64P_H_LOADED */ diff --git a/system/alpha/h/eb64pmem.h b/system/alpha/h/eb64pmem.h deleted file mode 100644 index 892d0dbe5..000000000 --- a/system/alpha/h/eb64pmem.h +++ /dev/null @@ -1,77 +0,0 @@ -#ifndef __EB64PMEM_H_LOADED -#define __EB64PMEM_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: eb64pmem.h,v 1.1.1.1 1997/10/30 23:27:15 verghese Exp $; - */ - -/* - * $Log: eb64pmem.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:15 verghese - * current 10/29/97 - * - * Revision 1.4 1994/11/22 23:47:01 fdh - * Don't include PALcode include files for make depend. - * - * Revision 1.3 1994/11/07 11:59:41 rusling - * Include system.h and lib.h in the correct order. - * - * Revision 1.2 1994/08/05 20:13:47 fdh - * Updated Copyright header and RCS $Id: identifier. - * - * Revision 1.1 1994/07/21 18:11:01 fdh - * Initial revision - * - */ - -#ifdef EB64P - -#include "system.h" -#include "lib.h" - -#ifndef MAKEDEPEND -#include "cserve.h" -#include "dc21064.h" -#endif - -/* - * Definition for the General Control Register (GCR): - */ -#define GCR_OFFSET 0x00 -#define GCR_M_BCE 0x20 - -/* - * Macros used to access the memory controller - * csr's. - */ -#define MEM_CSR(x) (((ul)0x18<<28)|(ul)(x)) -#define _IN_MEM_CSR(p) (ReadL(MEM_CSR(p))) -#define _OUT_MEM_CSR(p,d) WriteL((MEM_CSR(p)),d);mb(); - -#endif /* EB64P */ -#endif /* __EB64PMEM_H_LOADED */ diff --git a/system/alpha/h/eb66.h b/system/alpha/h/eb66.h deleted file mode 100644 index 484c583c8..000000000 --- a/system/alpha/h/eb66.h +++ /dev/null @@ -1,257 +0,0 @@ -#ifndef __EB66_H_LOADED -#define __EB66_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: eb66.h,v 1.1.1.1 1997/10/30 23:27:15 verghese Exp $; - */ - -/* - * $Log: eb66.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:15 verghese - * current 10/29/97 - * - * Revision 1.21 1995/02/10 02:56:08 fdh - * Disabled bootopt command because the current SROM doesn't support it. - * - * Revision 1.20 1994/12/08 16:42:29 fdh - * Removed EB66P definitions. Moved to eb66p.h - * - * Revision 1.19 1994/11/17 14:15:30 fdh - * Modified definitions for EB66P - * - * Revision 1.18 1994/11/08 21:38:33 fdh - * Added ROM definitions. Moved from rom.c - * Also added Flash ROM definitions to support - * a variant of the EB66 design. - * - * Revision 1.17 1994/08/05 20:13:47 fdh - * Updated Copyright header and RCS $Id: identifier. - * - * Revision 1.16 1994/07/21 18:09:32 fdh - * Added MAXIMUM_SYSTEM_CACHE definition. - * - * Revision 1.15 1994/06/28 20:08:21 fdh - * Modified filenames and build precedure to fit into a FAT filesystem. - * - * Revision 1.14 1994/06/20 14:18:59 fdh - * Fixup header file preprocessor #include conditionals. - * - * Revision 1.13 1994/04/06 05:10:07 fdh - * Removed and ethernet driver. - * - * Revision 1.12 1994/04/04 15:16:29 fdh - * Added definition for LEDPORT. - * - * Revision 1.11 1994/04/01 13:58:53 fdh - * Added MINIMUM_SYSTEM_MEMORY definition and - * removed obsoleted PAL_IMPURE definition. - * - * Revision 1.10 1994/03/24 21:42:48 fdh - * Removed unnecessary compile-time conditionals. - * - * Revision 1.9 1994/03/11 02:55:24 fdh - * Modified the Amd79c960 definitions to accomodate Ladebug. - * - * Revision 1.8 1994/02/14 16:18:14 rusling - * Allow remote debug support in NT build case. - * - * Revision 1.7 1994/01/19 10:22:28 rusling - * Ported to ALpha Windows NT. - * - * Revision 1.6 1993/11/30 15:29:22 rusling - * Mostly complete versions. I've integrated changes to - * the PCI to system address space mappings with all the - * definitions in the system specific include file. - * - * Revision 1.5 1993/11/23 10:43:50 rusling - * Added in IOC information (taken from pci.h). - * - * Revision 1.4 1993/11/22 14:23:03 rusling - * Modified the am8=79c960 definitions. - * - * Revision 1.3 1993/11/22 13:17:55 rusling - * *** empty log message *** - * - * Revision 1.2 1993/11/22 12:16:20 rusling - * Added in further definitions - * - * Revision 1.2 1993/11/22 12:16:20 rusling - * Added in further definitions - * - * Revision 1.1 1993/11/22 11:43:22 rusling - * Initial revision - * - */ - -#ifdef EB66 - -#define BANNER "DECchip 21066 Evaluation Board (EB66) Debug Monitor" -#define PROMPT "EB66> " - -/**************************************************************************** - * Basic * - ****************************************************************************/ - -#define NEEDPCI -#define NEEDDEBUGGER -#define NEEDFLOPPY -#define NEED21040 -#define DISABLEBOOTOPTION /* Current SROM does not support this */ - -/**************************************************************************** - * The IOC registers * - ****************************************************************************/ - -/* - * Status Register. - */ -#define IOC_REG_STATUS_0 0x40 -#define IOC_STATUS_0_M_ERR 0x00000010 - /* 4 = error */ -#define IOC_STATUS_0_M_CODE 0x00000700 - /* 10:8 = error code */ -#define IOC_STATUS_0_ERROR_RETRY 0 -#define IOC_STATUS_0_ERROR_NODEV 1 -#define IOC_STATUS_0_ERROR_BADDATA 2 -#define IOC_STATUS_0_ERROR_ABORT 3 -#define IOC_STATUS_0_ERROR_BADADDR 4 -#define IOC_STATUS_0_ERROR_PAGERD 5 -#define IOC_STATUS_0_ERROR_BADPAGE 6 -#define IOC_STATUS_0_ERROR_DATA 7 - -/* - * PCI Target Window Registers (64bits wide). - */ -#define IOC_W_BASE_0 0x100 -#define IOC_W_BASE_1 0x120 -#define IOC_W_MASK_0 0x140 -#define IOC_W_MASK_1 0x160 -#define IOC_W_T_BASE_0 0x180 -#define IOC_W_T_BASE_1 0x1A0 - -#define IOC_W_BASE_M_WEN 0x0000000200000000 /* bit 33 */ - -/**************************************************************************** - * Plug in cards, what does it have? * - ****************************************************************************/ -/* - * The Allied Telesis card is an ISA card based on the am79c960 - * chip. - */ -#define ALLIED_TELESIS_AT_1500T - -/* - * The DEC Etherworks ISA card is a LANCE like device. - */ -#define DEC_ETHERWORKS - - -/**************************************************************************** - * ISA Address Space * - ****************************************************************************/ - -#define RTCBASE 0x70 -#define LEDPORT 0x80 /* JDR Microdevices P.O.S.T. Diagnostics Card. */ - -/* - * Allied telesis is optional. We treat it like an optional - * am79c960 as far as the driver is concerned, see /h/am79c960.h - * for more definitions and /ether/am79c960.c for the device - * driver. - */ -#ifdef ALLIED_TELESIS_AT_1500T -#define OPTIONAL_AM79C960 /* warning only define this once */ -#define NEEDAM79C960 /* same for this */ -#define OPTIONAL_AM79C960_BASE 0x360 -#define OPTIONAL_AM79C960_INT 9 - -/* - * This parameter determines the - * DMA Mask for the DMA2 controller. - * Mask Channel - * ---- ------- - * 1 5 - * 2 6 - * 3 7 - * 4 8 - */ -#define OPTIONAL_AM79C960_DMA 1 /* Selects DMA Channel 5 */ -#endif - -#ifdef DEC_ETHERWORKS -#define DEC_ETHERWORKS_BASE 0x300 -#endif - -/**************************************************************************** - * System Address Space * - ****************************************************************************/ - -#define MINIMUM_SYSTEM_MEMORY 0x800000 -#define MAXIMUM_SYSTEM_CACHE 0x100000 -#define DMA_BUFF_BASE 0x100000 - - -/**************************************************************************** - * PCI Address Space * - ****************************************************************************/ -/* - * Definitions for the windows mapping PCI addresses into - * system addresses. - * - * 1 megabyte window at 1 megabyte mapping into 1 megabyte. - */ -#define PCI_BASE_1_USED 1 -#define PCI_BASE_1 0x00100000 -#define PCI_MASK_1 0x00000000 -#define PCI_TBASE_1 0x00100000 - -#define PCI_BASE_2_USED 0 -#define PCI_BASE_2 0x00000000 -#define PCI_MASK_2 0x00000000 -#define PCI_TBASE_2 0x00000000 - -/* - * Each mask translates to a number of these units. For - * 21066 this unit is 1Mbyte. - */ -#define PCI_MASK_UNIT 0x100000 - -/* - * Where do we start allocating addresses from in PCI I/O space? - */ -#define PCI_IO_BASE 0xB000 - -/* - * ROM definitions. - */ -#define ROMBASE 0xFFF80000 -#define ROMSIZE 0x80000 -#define ROMINC 0x1 - -#endif /* EB66 */ -#endif /* __EB66_H_LOADED */ diff --git a/system/alpha/h/eb66mem.h b/system/alpha/h/eb66mem.h deleted file mode 100644 index 133dce0ab..000000000 --- a/system/alpha/h/eb66mem.h +++ /dev/null @@ -1,75 +0,0 @@ -#ifndef __EB66MEM_H_LOADED -#define __EB66MEM_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: eb66mem.h,v 1.1.1.1 1997/10/30 23:27:15 verghese Exp $; - */ - -/* - * $Log: eb66mem.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:15 verghese - * current 10/29/97 - * - * Revision 1.2 1994/08/05 20:13:47 fdh - * Updated Copyright header and RCS $Id: identifier. - * - * Revision 1.1 1994/07/21 18:11:01 fdh - * Initial revision - * - */ - -#ifdef EB66 - -#include "system.h" -#include "prtrace.h" -#include "lib.h" - -/* - * Definition for the Cache Register (CAR): - */ -#define CAR_OFFSET 0x78 -#define CAR_M_BCE 0x1 - -/* - * Macros used to access the memory controller - * csr's. - */ -#define MEM_CSR(x) (((ul)0x12<<28)|(ul)(x)) -#define _IN_MEM_CSR(p) (ReadQ(MEM_CSR(p))) -#define _OUT_MEM_CSR(p,d) WriteQ((MEM_CSR(p)),d);mb(); - -#define BANKSIZE_MAX 128 -#define BANKSIZE_MIN 8 -#define _max(a,b) (a>b ? a : b) -#define _min(a,b) (a>b ? b : a) -#define NONCACHEABLE (0x2<<28) -#define PATTERN (ui) 0x5A5A5A5A -#define MEM_RW1C 0x1686 - -#endif /* EB66 */ -#endif /* __EB66MEM_H_LOADED */ diff --git a/system/alpha/h/eb66p.h b/system/alpha/h/eb66p.h deleted file mode 100644 index bb84a99d4..000000000 --- a/system/alpha/h/eb66p.h +++ /dev/null @@ -1,66 +0,0 @@ -#ifndef __EB66P_H_LOADED -#define __EB66P_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: eb66p.h,v 1.1.1.1 1997/10/30 23:27:15 verghese Exp $; - */ - -/* - * $Log: eb66p.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:15 verghese - * current 10/29/97 - * - * Revision 1.2 1995/02/10 02:22:26 fdh - * corrected EB66+ banner. - * - * Revision 1.1 1994/12/08 16:42:29 fdh - * Initial revision - * - */ - -#ifdef EB66P -/* - * Declare special definitions for systems with only - * minor variations from the standard system described - * by this file. To build for a variant board, declare - * the variant definition in addition to the standard - * definition. example... -DEB66 -DEB66P - */ -#include "eb66.h" - -#undef BANNER -#define BANNER "Alpha 21066A Evaluation Board (EB66+) Debug Monitor" -#undef PROMPT -#define PROMPT "EB66+ " -#undef ROMSIZE -#define ROMSIZE 0x100000 -#define NEEDFLASHMEMORY -#define INTEL_28F008SA - -#endif /* EB66P */ -#endif /* __EB66P_H_LOADED */ diff --git a/system/alpha/h/edevice.h b/system/alpha/h/edevice.h deleted file mode 100644 index d1162b7b8..000000000 --- a/system/alpha/h/edevice.h +++ /dev/null @@ -1,249 +0,0 @@ -#ifndef __ETHER_DEVICE_H_LOADED -#define __ETHER_DEVICE_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: edevice.h,v 1.1.1.1 1997/10/30 23:27:15 verghese Exp $ - */ - -/* - * MODULE DESCRIPTION: - * - * Ethernet device interface for EB64 monitor - * - * HISTORY: - * - * $Log: edevice.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:15 verghese - * current 10/29/97 - * - * Revision 1.7 1994/08/05 20:13:47 fdh - * Updated Copyright header and RCS $Id: identifier. - * - * Revision 1.6 1994/06/28 20:08:21 fdh - * Modified filenames and build precedure to fit into a FAT filesystem. - * - * Revision 1.5 1994/06/20 14:18:59 fdh - * Fixup header file preprocessor #include conditionals. - * - * Revision 1.4 1994/01/21 09:45:59 rusling - * Added #ifdef <filename>_H around the module. - * Additionally, any included files are not ifdef'd - * *before* they're included (ie address.h). - * - * Revision 1.3 1993/11/22 13:17:13 rusling - * Merged with PCI/21040 changes. - * - * Revision 1.2 1993/10/01 16:05:27 berent - * Added module initialisation function - * - * Revision 1.1 1993/08/06 10:30:01 berent - * Initial revision - * - * - */ - -#include "address.h" - - -/* ether_device_init - initialises an ethernet device - * - * Arguments: - * - * device_no - device number - * - * Returned value - * TRUE - initialised succesfully - * FALSE - error on initialisation - */ -extern int ether_device_init(int device_no); - -/* ether_device_read - reads a frame from an ethernet device - * - * Arguments: - * - * device_no - device number - * balance_buffer - spare buffer to maintain buffer balance - * frame_buffer - returned buffer containing frame - * - * Returned value: - * - * positive - size of frame read; frame copied into buffer if <= size. - * 0 - nothing to read - * negative - error on read - * - * DESCRIPTION: - * This function reads a frame from the device if there is one ready to be read. The - * frame read is returned in frame_buffer. To maintain the driver's pool of buffers - * the caller must give the driver an unused buffer (balance_buffer) before the - * driver returns the frame. Once this function has been called balance_buffer must - * not be used by the calling software. - * - * On return frame_buffer will always point to a valid buffer. If the read has failed - * (result <= 0) the contents of this buffer will not be valid. Note that whether or - * not the read succeeds it is undefined whether the same buffer will be returned as - * frame_buffer as was passed down as balance_buffer. - */ -extern int ether_device_read(int device_no, - unsigned char balance_buffer[ETHER_BUFFER_SIZE], - unsigned char ** frame_buffer); - -/* ether_device_write - queue a frame to be sent on an ethernet device - * - * Arguments: - * - * device_no - device number - * frame_buffer - buffer containing frame - * frame - the frame itself - * size - size of frame - * balance_buffer - returned buffer to maintain buffer balance - * - * Returned value: - * - * TRUE - succefully queued for sending - * FALSE - unable to send - * - * DESCRIPTION: - * This function writes a frame to the device To maintain the caller's pool of buffers - * the driver must give the caller an unused buffer (balance_buffer) in return for - * the buffer containing the frame to be transmitted. - * - * If the send succeeds then frame_buffer must not be accessed by the caller after this - * call. If the send can't be queued then frame_buffer will remain valid and - * the returned value of balance_buffer is undefined and must not be used. - * - */ -extern int ether_device_write(int device_no, - unsigned char * frame, - int size, - unsigned char frame_buffer[ETHER_BUFFER_SIZE], - unsigned char ** balance_buffer); - -/* ether_device_flush - wait for all writes on an ethernet device to complete - * - * Argument: - * - * device_no - device to be flushed - */ -extern int ether_device_flush(int device_no); - -/* ether_device_print_stats - print device statistics - * - * Argument: - * - * device_no - device number - */ -extern void ether_device_print_stats(int device_no); - -/* ether_device_preg - print device registers - * - * Argument: - * - * device_no - device number - */ -extern void ether_device_preg(int device_no); - - -/* ether_device_clear_interrupts - clear all interrupts from an ethernet device - * - * Argument: - * - * device_no - device number, -1 means all devices - */ -extern void ether_device_clear_interrupts(int device_no); - -/* ether_device_get_hw_address - gets the hardware mac address of the device - * - * Arguments: - * - * device_no - device_number - * hw_address - returned hardware address - */ -extern void ether_device_get_hw_address(int device_no, mac_addr hw_address); - -/* ether_device_next - get the next valid device number - * - * Argument: - * - * previous_device_number - previous device number; or -1 if no previous device. - * - * Result: - * - * next valid device number or -1 if no more devices. - * - * Description: - * The purpose of this function it to allow the device table to be scanned. - * If it called initially with -1 and then repeatedly called with its previous - * return value as its argument it will return each valid device number - * precisely once before returning -1. - * - * Notes: - * 1) The device numbers will not neccesary be returned in assending order - * 2) If previous_device_number is not the number of a valid device (or -1) the - * result is undefined. - */ -extern int ether_device_number(int previous_device_number); - -/* ether_device_register - register a new ethernet device - * - * Arguments: - * device_no - device_number - * init_func - initialisation function - * read_func - read function - * write_func - write function - * flush_func - flush function - * stats_func - print statistics function - * preg_func - print device registers function - * clear_interrupts_func - clear interrupts function - * hw_addr_func - get hardware address function - * description - description of the device. - */ -extern void ether_device_register(int device_no, - int (* init_func)(int device_no), - int (* read_func)(int device_no, - unsigned char balance_buffer[ETHER_BUFFER_SIZE], - unsigned char ** frame_buffer), - int (* write_func)(int device_no, - unsigned char * frame, - int size, - unsigned char frame_buffer[ETHER_BUFFER_SIZE], - unsigned char ** balance_buffer), - int (* flush_func)(int device_no), - void (* stats_func)(int device_no), - void (* preg_func)(int device_no), - void (* clear_interrupts_func)(int device_no), - void (* hw_addr_func)(int device_no, mac_addr hw_address) , - char *description - ); - -/* ether_device_init_module - initialise or reinitialise the ether_device module - */ -extern void ether_device_init_module(void); - -extern void ether_device_show(); - -#endif /* __ETHER_DEVICE_H_LOADED */ diff --git a/system/alpha/h/ether.h b/system/alpha/h/ether.h deleted file mode 100644 index b9103ff68..000000000 --- a/system/alpha/h/ether.h +++ /dev/null @@ -1,96 +0,0 @@ -#ifndef __ETHER_H_LOADED -#define __ETHER_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: ether.h,v 1.1.1.1 1997/10/30 23:27:15 verghese Exp $; - */ - -/* - * $Log: ether.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:15 verghese - * current 10/29/97 - * - * Revision 1.4 1994/08/05 20:13:47 fdh - * Updated Copyright header and RCS $Id: identifier. - * - * Revision 1.3 1994/06/28 20:08:21 fdh - * Modified filenames and build precedure to fit into a FAT filesystem. - * - * Revision 1.2 1994/06/20 14:18:59 fdh - * Fixup header file preprocessor #include conditionals. - * - * Revision 1.1 1994/06/20 12:54:45 fdh - * Initial revision - * - */ - -#include "address.h" -#include "arp.h" -#include "base.h" -#include "bootp.h" -#include "buffer.h" -#include "edevice.h" -#include "ethernet.h" -#include "ip.h" -#include "isa_buff.h" -#include "net_buff.h" -#include "netman.h" -#include "tftp.h" -#include "udp.h" -#include "am79c960.h" -#include "DEC21040.h" - - -/* /ether/arp.c */ -extern void arp_show(); - -/* /ether/edevice.c */ -extern void ether_device_show(); -extern void ether_device_clear_interrupts(int device_no); -extern int ethernet_process_one_packet(int device_no , ub input_buffer[1600] , ub * * output_buffer); - -/* /ether/tftp.c */ -extern void tftp_init_module(void); - -/* /ether/bootp.c */ -extern void bootp_init_module(void); - -/* ladbx/server_init_module */ -extern void ladbx_server_init_module(void); - -/* /ether/ethernet.c */ -extern int ethernet_process_one_packet(int, ub *, ub **); - -/* /ether/eaddr.c */ -extern void get_eaddr(void); -extern int ethernet_address(ui argc , ub * s); - -/* /ether/netboot.c */ -extern int netboot(int argc , char * file); - -#endif /* __ETHER_H_LOADED */ diff --git a/system/alpha/h/ethernet.h b/system/alpha/h/ethernet.h deleted file mode 100644 index e8c72af07..000000000 --- a/system/alpha/h/ethernet.h +++ /dev/null @@ -1,218 +0,0 @@ -#ifndef __ETHERNET_H_LOADED -#define __ETHERNET_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: ethernet.h,v 1.1.1.1 1997/10/30 23:27:15 verghese Exp $ - */ - -/* - * MODULE DESCRIPTION: - * - * Ethernet protocol interface for EB64 monitor - * - * HISTORY: - * - * $Log: ethernet.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:15 verghese - * current 10/29/97 - * - * Revision 1.6 1994/08/05 20:13:47 fdh - * Updated Copyright header and RCS $Id: identifier. - * - * Revision 1.5 1994/06/28 20:08:21 fdh - * Modified filenames and build precedure to fit into a FAT filesystem. - * - * Revision 1.4 1994/06/20 14:18:59 fdh - * Fixup header file preprocessor #include conditionals. - * - * Revision 1.3 1994/01/21 09:45:59 rusling - * Added #ifdef <filename>_H around the module. - * Additionally, any included files are not ifdef'd - * *before* they're included (ie address.h). - * - * Revision 1.2 1993/10/01 16:05:45 berent - * made interface to ethernet_init public - * - * Revision 1.1 1993/08/06 10:30:23 berent - * Initial revision - * - * - */ - -#include "address.h" - - -/* - * Prototype for packet processing functions - * - * Arguments to packet processing functions: - * protocol_data - protocol data passed to module when protocol registered - * device_no - device on which packet was received; - * packet - packet, with ethernet header removed; - * size - size of packet; - * source - source MAC address of packet; - * frame_buffer - original buffer containing packet. - * balance_buffer- buffer returned to maintain buffer balance buffer. - * - * DESCRIPTION: - * The packet processing functions process a received protocol packet. To avoid - * buffer shortages they are always passed the buffer containing the packet in - * frame_buffer. They must return either this buffer, or another buffer, in - * balance buffer. The ethernet module will never access frame_buffer after - * calling a packet processing function; and the protocol modules must not - * access the returned balance_buffer after returning from this function. - * - */ -typedef void (* ethernet_packet_handler)(void * protocol_data, - int device_no, - unsigned char * packet, - int size, - mac_addr source, - unsigned char frame_buffer[ETHER_BUFFER_SIZE], - unsigned char ** balance_buffer); - -/* ethernet_register_protocol - registers an ethernet protocol to be recognised in received frames by this module - * - * Arguments: - * - * device_no - device on which the protocol is to be registered - * protocol_id - protocol id to be recognised by this module - * processing_function - function to process received packets; if NULL cancels registration of protocol. - * protocol_data - arbitrary data to be passed back when a packet is received - * - * Returned value: - * TRUE - protocol registered - * FALSE - unable to register protocol - */ -extern int ethernet_register_protocol(int device_no, - ethernet_protocol_id protocol_id, - ethernet_packet_handler processing_function, - void * protocol_data); - -/* ethernet_process_one_packet - reads and processes one packet from the ethernet - * - * Arguments: - * - * device_no - device to poll, -1 means poll all devices - * input_buffer - free buffer usable by the ethernet module - * output_buffer - returned free buffer that may be used by the caller. - * - * Return value: - * TRUE - packet received and processed - * FALSE - nothing to receive. - * - * DESCRIPTION: - * This function checks whether there are any packets available to be processed on - * the ethernet device. If there are it reads and processes one packet. The caller - * must give it a buffer to work with (input_buffer) and will be returned a, possibly - * different, buffer (output_buffer) Note that this returned buffer does not contain the - * received packet, or any other meaningfull data; it is returned simply to ensure that caller - * does not run short of buffers. By calling this function the caller gives up ownership - * of input_buffer. The caller must not access input_buffer after calling this function. - * - */ -extern int ethernet_process_one_packet(int device_no, - unsigned char input_buffer[ETHER_BUFFER_SIZE], - unsigned char ** output_buffer ); - -/* ethernet_input - processes the packet passed to it as an ethernet frame - * - * Arguments: - * - * device_no - device on which frame was received - * frame - the frame to be processed - * size - size of frame - * input_buffer - the buffer containing the frame - * balance_buffer - returned free buffer that may be used by the caller. - * - */ -extern void ethernet_input(int device_no, - unsigned char * frame, - int size, - unsigned char input_buffer[ETHER_BUFFER_SIZE], - unsigned char ** balance_buffer ); - -/* ethernet_write - sends a packet on an ethernet - * - * Arguments: - * - * device_no - device on which to send the packet - * packet - pointer to data packet to be sent - * destination - destination address for packet - * protocol_id - protocol id for packet - * size - size of packet - * frame_buffer - buffer containing packet - * balance_buffer - buffer returned to maintain buffer balance - * - * Return values: - * - * TRUE - send successfull - * FALSE - Error occured - * - * DESCRIPTION: - * This function writes an ethernet data packet to the device To maintain the caller's - * pool of buffers the driver must give the caller an unused buffer (balance_buffer) - * in return for the buffer containing the frame to be transmitted. - * - * If the send succeeds then frame_buffer must not be accessed by the caller after this - * call. If the send can't be queued then frame_buffer will remain valid and - * the returned value of balance_buffer is undefined and must not be used. - * - */ -extern int ethernet_write(int device_no, - unsigned char * packet, - mac_addr destination, - ethernet_protocol_id protocol_id, - int size, - unsigned char frame_buffer[ETHER_BUFFER_SIZE], - unsigned char ** balance_buffer); - - -/* ethernet_data_offset - returns the offset of the data in an ethernet frame - * - * Return value: - * Offset. - */ -extern int ethernet_data_offset(void); - -/* ethernet_printpacket - print the contents of an ethernet frame - * - * Arguments: - * p - the frame - * frame_size - its size - */ -extern void ethernet_printpacket(unsigned char *p, int frame_size); - -/* ethernet_printaddress - utility to print an ethernet address - * - * Argument: - * address - MAC address to be printed - */ -extern void ethernet_printaddress(mac_addr address); - -#endif /* __ETHERNET_H_LOADED */ diff --git a/system/alpha/h/ev4.h b/system/alpha/h/ev4.h deleted file mode 100644 index afe5d2ec0..000000000 --- a/system/alpha/h/ev4.h +++ /dev/null @@ -1,704 +0,0 @@ -#ifndef __EV4_H_LOADED -#define __EV4_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: ev4.h,v 1.1.1.1 1997/10/30 23:27:15 verghese Exp $; - */ - -/* - * $Log: ev4.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:15 verghese - * current 10/29/97 - * - * Revision 1.3 1994/08/05 20:13:47 fdh - * Updated Copyright header and RCS $Id: identifier. - * - * Revision 1.2 1994/06/20 14:18:59 fdh - * Fixup header file preprocessor #include conditionals. - * - * Revision 1.1 1993/06/08 19:56:13 fdh - * Initial revision - * - */ - - - -/* -**++ -***************************************************************************** -** * -** Copyright (c) 1992, 1993 * -** by Digital Equipment Corporation, Maynard, Ma. * -** * -** This software is furnished under a license and may be used and copied * -** only in accordance with the terms of such license and with the * -** inclusion of the above copyright notice. This software or any other * -** copies thereof may not be provided or otherwise made available to any * -** other person. No title to and ownership of the software is hereby * -** transferred. * -** * -** The information in this software is subject to change without notice * -** and should not be construed as a commitment by Digital Equipment * -** Corporation. * -** * -** Digital assumes no responsibility for the use or reliability of its * -** software on equipment which is not supplied by Digital. * -** * -***************************************************************************** -** -** FACILITY: -** -** ev4.h -** -** MODULE DESCRIPTION: -** -** DECchip 21064 (EV4) specific definitions -** -** CREATION DATE: 29-Oct-1992 -** -** DESIGN ISSUES: -** -** {@tbs@} -** -** [@optional module tags@]... -** -** MODIFICATION HISTORY: -** -** Who When What -** ----- ----------- --------------------------------------------- -** ES 10-Feb-1993 Need physical load lock and store conditional -** ER 05-Feb-1993 Add HWPCB offset definitions. -** ES 12-Jan-1993 Some HIRR additions -** ES 04-Jan-1993 Changed names of BIU_STAT bits -** ES 16-Dec-1992 Added BIU_STAT and SL_CLR definitions. -** ER 10-Dec-1992 Added xtbAsm to invalidate all ITB & DTB -** entries with ASM=0. -** ER 03-Dec-1992 Added definitions for architecturally reserved -** opcodes. -** ER 16-Nov-1992 Changed BIU$M_INIT definition. -** ER 12-Nov-1992 Added FPR definitions. -** ER 09-Nov-1992 Added GPR and BIU$M_INIT definitions. -** ES 09-Nov-1992 Added privileged and unprivileged CALL_PAL -** entry points. -** ER 02-Nov-1992 Added MMCSR$M_FAULT bit mask. -** ER 30-Oct-1992 Added xtbZap to invalidate all ITB & DTB -** entries. -** -**-- -*/ - -/* -** -** INTERNAL PROCESSOR REGISTER DEFINITIONS -** -*/ - -#define IPR$V_PAL 7 -#define IPR$M_PAL 0x80 -#define IPR$V_ABX 6 -#define IPR$M_ABX 0x40 -#define IPR$V_IBX 5 -#define IPR$M_IBX 0x20 -#define IPR$V_INDEX 0 -#define IPR$M_INDEX 0x1F - -/* -** -** Ibox IPR Definitions -** -*/ - -#define tbTag IPR$M_IBX + 0x0 -#define itbPte IPR$M_IBX + 0x1 -#define iccsr IPR$M_IBX + 0x2 -#define itbPteTemp IPR$M_IBX + 0x3 -#define excAddr IPR$M_IBX + 0x4 -#define slRcv IPR$M_IBX + 0x5 -#define itbZap IPR$M_IBX + 0x6 -#define itbAsm IPR$M_IBX + 0x7 -#define itbIs IPR$M_IBX + 0x8 -#define ps IPR$M_IBX + 0x9 -#define excSum IPR$M_IBX + 0xA -#define palBase IPR$M_IBX + 0xB -#define hirr IPR$M_IBX + 0xC -#define sirr IPR$M_IBX + 0xD -#define astrr IPR$M_IBX + 0xE -#define hier IPR$M_IBX + 0x10 -#define sier IPR$M_IBX + 0x11 -#define aster IPR$M_IBX + 0x12 -#define slClr IPR$M_IBX + 0x13 -#define slXmit IPR$M_IBX + 0x16 - -/* -** -** Instruction Cache Control and Status Register (ICCSR) Bit Summary -** -** Loc Size Name Function -** ----- ---- ---- --------------------------------- -** <42> 1 FPE Floating Point Enable -** <41> 1 MAP I-stream superpage mapping enable -** <40> 1 HWE Allow PALRES to be issued in kernel mode -** <39> 1 DI Dual Issue enable -** <38> 1 BHE Branch History Enable -** <37> 1 JSE JSR Stack Enable -** <36> 1 BPE Branch Prediction Enable -** <35> 1 PIPE Pipeline enable -** -*/ - -#define ICCSR$V_FPE 42 -#define ICCSR$M_FPE 0x0400 -#define ICCSR$V_MAP 41 -#define ICCSR$M_MAP 0x0200 -#define ICCSR$V_HWE 40 -#define ICCSR$M_HWE 0x0100 -#define ICCSR$V_DI 39 -#define ICCSR$M_DI 0x0080 -#define ICCSR$V_BHE 38 -#define ICCSR$M_BHE 0x0040 -#define ICCSR$V_JSE 37 -#define ICCSR$M_JSE 0x0020 -#define ICCSR$V_BPE 36 -#define ICCSR$M_BPE 0x0010 -#define ICCSR$V_PIPE 35 -#define ICCSR$M_PIPE 0x0008 - -/* -** We may want to move the ICCSR$M_INIT definition to another module -** that contains user configurable options. -*/ -#define ICCSR$M_INIT (ICCSR$M_FPE | ICCSR$M_MAP | ICCSR$M_DI | \ - ICCSR$M_BHE | ICCSR$M_JSE | ICCSR$M_BPE | \ - ICCSR$M_PIPE) -/* -** -** Exception Summary Register (EXC_SUM) Bit Summary -** -** Loc Size Name Function -** ----- ---- ---- ------------------------------------ -** <33> 1 MSK Exception Register Write Mask window -** <8> 1 IOV Integer overflow -** <7> 1 INE Inexact result -** <6> 1 UNF Underflow -** <5> 1 OVF Overflow -** <4> 1 DZE Division by zero -** <3> 1 INV Invalid operation -** <2> 1 SWC Software completion -** -*/ - -#define EXC$V_MSK 33 -#define EXC$M_MSK 0x0002 -#define EXC$V_IOV 8 -#define EXC$M_IOV 0x0100 -#define EXC$V_INE 7 -#define EXC$M_INE 0x0080 -#define EXC$V_UNF 6 -#define EXC$M_UNF 0x0040 -#define EXC$V_OVF 5 -#define EXC$M_OVF 0x0020 -#define EXC$V_DZE 4 -#define EXC$M_DZE 0x0010 -#define EXC$V_INV 3 -#define EXC$M_INV 0x0008 -#define EXC$V_SWC 2 -#define EXC$M_SWC 0x0004 - -/* -** -** Hardware Interrupt Request Register (HIRR) Bit Summary -** -** Loc Size Name Function -** ----- ---- ---- --------------------------------- -** <13> 1 SLR Serial Line interrupt -** <9> 1 PC0 Performance Counter 0 interrupt -** <8> 1 PC1 Performance Counter 1 interrupt -** <4> 1 CRR Correctable read data interrupt -** <3> 1 ATR AST interrupt -** <2> 1 SWR Software interrupt -** <1> 1 HWR Hardware interrupt -** -**/ - -#define HIRR$V_SLR 13 -#define HIRR$M_SLR 0x2000 -#define HIRR$V_PC0 9 -#define HIRR$M_PC0 0x0200 -#define HIRR$V_PC1 8 -#define HIRR$M_PC1 0x0100 -#define HIRR$V_CRR 4 -#define HIRR$M_CRR 0x0010 -#define HIRR$V_ATR 3 -#define HIRR$M_ATR 0x0008 -#define HIRR$V_SWR 2 -#define HIRR$M_SWR 0x0004 -#define HIRR$V_HWR 1 -#define HIRR$M_HWR 0x0002 - -#define HIRR$V_IRQ0 10 -#define HIRR$V_IRQ1 11 -#define HIRR$V_IRQ2 12 -#define HIRR$V_IRQ3 5 -#define HIRR$V_IRQ4 6 -#define HIRR$V_IRQ5 7 - -/* -** -** Hardware Interrupt Enable Register (HIER) Write Bit Summary -** -** Loc Size Name Function -** ----- ---- ---- --------------------------------- -** <32> 1 SLE Serial Line interrupt enable -** <15> 1 PC1 Performance Counter 1 interrupt enable -** <14:9> 6 HIER Interrupt enables for Irq_h<5:0> -** <8> 1 PC0 Performance Counter 0 interrupt enable -** <2> 1 CRE Correctable read data interrupt enable -** -**/ - -#define HIERW$V_SLE 32 -#define HIERW$V_PC1 15 -#define HIERW$V_PC0 8 -#define HIERW$V_CRE 2 - -/* -** -** Clear Serial Line Interrupt Register (SL_CLR) Bit Summary -** -** Loc Size Name Function -** ----- ---- ---- --------------------------------- -** <32> 1 SLC W0C -- Clear serial line int request -** <15> 1 PC1 W0C -- Clear PC1 interrupt request -** <8> 1 PC0 W0C -- Clear PC0 interrupt request -** <2> 1 CRD W0C -- Clear CRD interrupt request -** -*/ - -#define SL_CLR$V_SLC 32 -#define SL_CLR$V_PC1 15 -#define SL_CLR$V_PC0 8 -#define SL_CLR$V_CRD 2 - -/* -** -** Abox IPR Definitions -** -*/ - -#define dtbCtl IPR$M_ABX + 0x0 -#define tbCtl IPR$M_ABX + 0x0 -#define dtbPte IPR$M_ABX + 0x2 -#define dtbPteTemp IPR$M_ABX + 0x3 -#define mmcsr IPR$M_ABX + 0x4 -#define va IPR$M_ABX + 0x5 -#define dtbZap IPR$M_ABX + 0x6 -#define dtbAsm IPR$M_ABX + 0x7 -#define dtbIs IPR$M_ABX + 0x8 -#define biuAddr IPR$M_ABX + 0x9 -#define biuStat IPR$M_ABX + 0xA -#define dcAddr IPR$M_ABX + 0xB -#define dcStat IPR$M_ABX + 0xC -#define fillAddr IPR$M_ABX + 0xD -#define aboxCtl IPR$M_ABX + 0xE -#define altMode IPR$M_ABX + 0xF -#define cc IPR$M_ABX + 0x10 -#define ccCtl IPR$M_ABX + 0x11 -#define biuCtl IPR$M_ABX + 0x12 -#define fillSyndrome IPR$M_ABX + 0x13 -#define bcTag IPR$M_ABX + 0x14 -#define flushIc IPR$M_ABX + 0x15 -#define flushIcAsm IPR$M_ABX + 0x17 -#define xtbZap IPR$M_ABX + IPR$M_IBX + 0x6 -#define xtbAsm IPR$M_ABX + IPR$M_IBX + 0x7 - -/* -** -** Memory Management Control and Status Register (MM_CSR) Bit Summary -** -** Loc Size Name Function -** ----- ---- ---- --------------------------------- -** <14:9> 6 OPC Opcode of faulting instruction -** <8:4> 5 RA Ra field of faulting instruction -** <3> 1 FOW Fault on write -** <2> 1 FOR Fault on read -** <1> 1 ACV Access violation -** <0> 1 WR Faulting reference is a write -** -*/ - -#define MMCSR$V_OPC 9 -#define MMCSR$M_OPC 0x7E00 -#define MMCSR$V_RA 4 -#define MMCSR$M_RA 0x01F0 -#define MMCSR$V_FOW 3 -#define MMCSR$M_FOW 0x0008 -#define MMCSR$V_FOR 2 -#define MMCSR$M_FOR 0x0004 -#define MMCSR$V_ACV 1 -#define MMCSR$M_ACV 0x0002 -#define MMCSR$V_WR 0 -#define MMCSR$M_WR 0x0001 - -#define MMCSR$M_FAULT 0x000E - -/* -** -** Abox Control Register (ABOX_CTL) Bit Summary -** -** Loc Size Name Function -** ----- ---- ---- --------------------------------- -** <11> 1 DC_FHIT Dcache Force Hit -** <10> 1 DC_ENA Dcache Enable -** <6> 1 EMD_EN Limited big endian support enable -** <5> 1 SPE_2 D-stream superpage 1 enable -** <4> 1 SPE_1 D-stream superpage 2 enable -** <3> 1 IC_SBUF_EN Icache Stream Buffer Enable -** <2> 1 CRD_EN Corrected Read Data Enable -** <1> 1 MCHK_EN Machine Check Enable -** <0> 1 WB_DIS Write Buffer unload Disable -** -*/ - -#define ABOX$V_DC_FHIT 11 -#define ABOX$M_DC_FHIT 0x0800 -#define ABOX$V_DC_ENA 10 -#define ABOX$M_DC_ENA 0x0400 -#define ABOX$V_EMD_EN 6 -#define ABOX$M_EMD_EN 0x0040 -#define ABOX$V_SPE_2 5 -#define ABOX$M_SPE_2 0x0020 -#define ABOX$V_SPE_1 4 -#define ABOX$M_SPE_1 0x0010 -#define ABOX$V_IC_SBUF_EN 3 -#define ABOX$M_IC_SBUF_EN 0x0008 -#define ABOX$V_CRD_EN 2 -#define ABOX$M_CRD_EN 0x0004 -#define ABOX$V_MCHK_EN 1 -#define ABOX$M_MCHK_EN 0x0002 -#define ABOX$V_WB_DIS 0 -#define ABOX$M_WB_DIS 0x0001 - -/* -** We may want to move the ABOX$M_INIT definition to another module -** that contains user configurable options. -*/ -#define ABOX$M_INIT (ABOX$M_DC_ENA | ABOX$M_SPE_2 | ABOX$M_IC_SBUF_EN) - -/* -** -** Bus Interface Unit Control Register (BIU_CTL) Bit Summary -** -** Loc Size Name Function -** ----- ---- ---- --------------------------------- -** <36> 1 BAD_DP Force bad data parity/ECC check bits -** <35:32> 4 BC_PA_DIS Don't cache PA quadrant specified -** <31> 1 BAD_TCP Force bad tag parity -** <30:28> 3 BC_SIZE External cache size -** <27:13> 16 BC_WE_CTL External cache write enable control -** <11:8> 4 BC_WR_SPD External cache write speed -** <7:4> 4 BC_RD_SPD External cache read speed -** <3> 1 BC_FHIT External cache force hit -** <2> 1 OE Output enable -** <1> 1 ECC Enable ECC -** <0> 1 BC_ENA External cache enable -** -*/ - -#define BIU$V_BAD_DP 36 -#define BIU$M_BAD_DP 0x0010 -#define BIU$V_BC_PA_DIS 32 -#define BIU$M_BC_PA_DIS 0x000F -#define BIU$V_BAD_TCP 31 -#define BIU$M_BAD_TCP 0x8000 -#define BIU$V_BC_SIZE 28 -#define BIU$M_BC_SIZE 0x7000 -#define BIU$V_BC_WE_CTL 13 -#define BIU$M_BC_WE_CTL 0xFFFE -#define BIU$V_BC_WR_SPD 8 -#define BIU$M_BC_WR_SPD 0x0F00 -#define BIU$V_BC_RD_SPD 4 -#define BIU$M_BC_RD_SPD 0x00F0 -#define BIU$V_BC_FHIT 3 -#define BIU$M_BC_FHIT 0x0008 -#define BIU$V_OE 2 -#define BIU$M_OE 0x0004 -#define BIU$V_ECC 1 -#define BIU$M_ECC 0x0002 -#define BIU$V_BC_ENA 0 -#define BIU$M_BC_ENA 0x0001 - -/* -** We may want to move the BIU$M_INIT definition to another module -** that contains user configurable options. -*/ -#define BIU$M_INIT BIU$M_OE - -/* -** -** Bus Interface Unit Status Register (BIU_STAT) Bit Summary -** -** Loc Size Name Function -** ----- ---- ---- --------------------------------- -** <14> 1 FILL_SEO Second error while FILL_ECC or FILL_DPERR -** <13:12> 2 FILL_QW Used with FILL_ADDR for physical address -** <11> 1 FILL_IRD Icache fill when FILL_ECC or FILL_DPERR -** <10> 1 FILL_DPERR Fill parity error or double bit ECC -** <9> 1 FILL_CRD Corrected read data -** <8> 1 FILL_ECC ECC error -** <7> 1 BIU_SEO Second error while BIU or BC error -** <6:4> 3 BIU_CMD Cycle type -** <3> 1 BC_TCPERR Tag control parity error on external cache -** <2> 1 BC_TPERR Tag address parity error on external cache -** <1> 1 BIU_SERR cAck_h pins indicate SOFT_ERROR -** <0> 1 BIU_HERR cAck_h pins indicate HARD_ERROR -** -*/ - -#define BIU_STAT$V_FILL_SEO 14 -#define BIU_STAT$M_FILL_SEO 0x4000 -#define BIU_STAT$V_FILL_CRD 9 -#define BIU_STAT$M_FILL_CRD 0x0200 -#define BIU_STAT$V_FILL_ECC 8 -#define BIU_STAT$M_FILL_ECC 0x0100 -#define BIU_STAT$V_BC_TCPERR 3 -#define BIU_STAT$M_BC_TCPERR 0x0008 -#define BIU_STAT$V_BC_TPERR 2 -#define BIU_STAT$M_BC_TPERR 0x0004 -#define BIU_STAT$V_BIU_SERR 1 -#define BIU_STAT$M_BIU_SERR 0x0002 -#define BIU_STAT$V_BIU_HERR 0 -#define BIU_STAT$M_BIU_HERR 0x0001 - -/* -** -** General Register Definitions -** -*/ - -#define r0 $0 -#define r1 $1 -#define r2 $2 -#define r3 $3 -#define r4 $4 -#define r5 $5 -#define r6 $6 -#define r7 $7 -#define r8 $8 -#define r9 $9 -#define r10 $10 -#define r11 $11 -#define r12 $12 -#define r13 $13 -#define r14 $14 -#define r15 $15 -#define r16 $16 -#define r17 $17 -#define r18 $18 -#define r19 $19 -#define r20 $20 -#define r21 $21 -#define r22 $22 -#define r23 $23 -#define r24 $24 -#define r25 $25 -#define r26 $26 -#define r27 $27 -#define r28 $28 -#define r29 $29 -#define r30 $30 -#define r31 $31 - -/* -** -** Floating Point Register Definitions -** -*/ - -#define f0 $f0 -#define f1 $f1 -#define f2 $f2 -#define f3 $f3 -#define f4 $f4 -#define f5 $f5 -#define f6 $f6 -#define f7 $f7 -#define f8 $f8 -#define f9 $f9 -#define f10 $f10 -#define f11 $f11 -#define f12 $f12 -#define f13 $f13 -#define f14 $f14 -#define f15 $f15 -#define f16 $f16 -#define f17 $f17 -#define f18 $f18 -#define f19 $f19 -#define f20 $f20 -#define f21 $f21 -#define f22 $f22 -#define f23 $f23 -#define f24 $f24 -#define f25 $f25 -#define f26 $f26 -#define f27 $f27 -#define f28 $f28 -#define f29 $f29 -#define f30 $f30 -#define f31 $f31 - -/* -** -** PAL Temporary Register Definitions -** -*/ - -#define pt0 IPR$M_PAL + 0x0 -#define pt1 IPR$M_PAL + 0x1 -#define pt2 IPR$M_PAL + 0x2 -#define pt3 IPR$M_PAL + 0x3 -#define pt4 IPR$M_PAL + 0x4 -#define pt5 IPR$M_PAL + 0x5 -#define pt6 IPR$M_PAL + 0x6 -#define pt7 IPR$M_PAL + 0x7 -#define pt8 IPR$M_PAL + 0x8 -#define pt9 IPR$M_PAL + 0x9 -#define pt10 IPR$M_PAL + 0xA -#define pt11 IPR$M_PAL + 0xB -#define pt12 IPR$M_PAL + 0xC -#define pt13 IPR$M_PAL + 0xD -#define pt14 IPR$M_PAL + 0XE -#define pt15 IPR$M_PAL + 0xF -#define pt16 IPR$M_PAL + 0x10 -#define pt17 IPR$M_PAL + 0x11 -#define pt18 IPR$M_PAL + 0x12 -#define pt19 IPR$M_PAL + 0x13 -#define pt20 IPR$M_PAL + 0x14 -#define pt21 IPR$M_PAL + 0x15 -#define pt22 IPR$M_PAL + 0x16 -#define pt23 IPR$M_PAL + 0x17 -#define pt24 IPR$M_PAL + 0x18 -#define pt25 IPR$M_PAL + 0x19 -#define pt26 IPR$M_PAL + 0x1A -#define pt27 IPR$M_PAL + 0x1B -#define pt28 IPR$M_PAL + 0x1C -#define pt29 IPR$M_PAL + 0x1D -#define pt30 IPR$M_PAL + 0x1E -#define pt31 IPR$M_PAL + 0x1F - -/* -** -** DECchip 21064 Privileged Architecture Library Entry Points -** -** Entry Name Offset (Hex) Length (Instructions) -** -** RESET 0000 8 -** MCHK 0020 16 -** ARITH 0060 32 -** INTERRUPT 00E0 64 -** D_FAULT 01E0 128 -** ITB_MISS 03E0 256 -** ITB_ACV 07E0 64 -** DTB_MISS (Native) 08E0 64 -** DTB_MISS (PAL) 09E0 512 -** UNALIGN 11E0 128 -** OPCDEC 13E0 256 -** FEN 17E0 520 -** CALL_PAL 2000 -** -*/ - -#define PAL$RESET_ENTRY 0x0000 -#define PAL$MCHK_ENTRY 0x0020 -#define PAL$ARITH_ENTRY 0x0060 -#define PAL$INTERRUPT_ENTRY 0x00E0 -#define PAL$D_FAULT_ENTRY 0x01E0 -#define PAL$ITB_MISS_ENTRY 0x03E0 -#define PAL$ITB_ACV_ENTRY 0x07E0 -#define PAL$NDTB_MISS_ENTRY 0x08E0 -#define PAL$PDTB_MISS_ENTRY 0x09E0 -#define PAL$UNALIGN_ENTRY 0x11E0 -#define PAL$OPCDEC_ENTRY 0x13E0 -#define PAL$FEN_ENTRY 0x17E0 -#define PAL$CALL_PAL_PRIV_ENTRY 0x2000 -#define PAL$CALL_PAL_UNPRIV_ENTRY 0x3000 - -/* -** -** DECchip 21064 Parameters -** -*/ - -#define CACHE_SIZE 8192 -#define CACHE_BLOCK_SIZE 32 - -/* -** -** Architecturally Reserved Opcode Definitions -** -*/ -#define mtpr hw_mtpr -#define mfpr hw_mfpr - -#define ldl_a hw_ldl/a -#define ldq_a hw_ldq/a -#define stq_a hw_stq/a -#define stl_a hw_stl/a - -#define ldl_p hw_ldl/p -#define ldq_p hw_ldq/p -#define stl_p hw_stl/p -#define stq_p hw_stq/p - -/* -** This set defines the physical versions of load locked and store conditional -*/ -#define ldl_pa hw_ldl/pa -#define ldq_pa hw_ldq/pa -#define stl_pa hw_stl/pa -#define stq_pa hw_stq/pa - -/* -** -** Hardware Privileged Process Context Block (HWPCB) offsets -** -*/ - -#define HWPCB$Q_KSP 0x00 -#define HWPCB$Q_ESP 0x08 -#define HWPCB$Q_SSP 0x10 -#define HWPCB$Q_USP 0x18 -#define HWPCB$Q_PTBR 0x20 -#define HWPCB$Q_ASN 0x28 -#define HWPCB$Q_AST 0x30 -#define HWPCB$Q_FEN 0x38 -#define HWPCB$Q_PCC 0x40 -#define HWPCB$Q_UNIQUE 0x48 -#define HWPCB$Q_IMPURE 0x50 - -#endif /* __EV4_H_LOADED */ diff --git a/system/alpha/h/ev5_alpha_defs.h b/system/alpha/h/ev5_alpha_defs.h new file mode 100644 index 000000000..96769de04 --- /dev/null +++ b/system/alpha/h/ev5_alpha_defs.h @@ -0,0 +1,323 @@ +#ifndef EV5_ALPHA_DEFS_INCLUDED +#define EV5_ALPHA_DEFS_INCLUDED 1 + +// from ev5_alpha_defs.mar from Lance's fetch directory +// Lower-caseified and $ signs removed ... pb Nov/95 + +// .MACRO _ALPHADEFS +// ALPHADEF_VER == 6 ; Flag the version number of this file. +// .ENDM +// .MACRO _PSDEF,_GBL +// _DEFINI PS,_GBL +//;+ +//; PS Layout - PS +//; Loc Size name function +//; ------ ------ ______ ----------------------------------- +//; <31:29> 3 SA stack alignment +//; <31:13> 24 RES Reserved MBZ +//; <12:8> 5 IPL Priority level +//; <7> 1 VMM Virtual Mach Monitor +//; <6:5> 2 RES Reserved MBZ +//; <4:3> 2 CM Current Mode +//; <2> 1 IP Interrupt Pending +//; <1:0> 2 SW Software bits +//;- + +#define ps_v_sw 0 +#define ps_m_sw (3<<ps_v_sw) + +#define ps_v_ip 2 +#define ps_m_ip (1<<ps_v_ip) + +#define ps_v_cm 3 +#define ps_m_cm (3<<ps_v_cm) + +#define ps_v_vmm 7 +#define ps_m_vmm (1<<ps_v_vmm) + +#define ps_v_ipl 8 +#define ps_m_ipl (0x1f<<ps_v_ipl) + +#define ps_v_sp (0x38) +#define ps_m_sp (0x3f<<ps_v_sp) + + +#define ps_c_kern (0x00) +#define ps_c_exec (0x08) +#define ps_c_supr (0x10) +#define ps_c_user (0x18) +#define ps_c_ipl0 (0x0000) +#define ps_c_ipl1 (0x0100) +#define ps_c_ipl2 (0x0200) +#define ps_c_ipl3 (0x0300) +#define ps_c_ipl4 (0x0400) +#define ps_c_ipl5 (0x0500) +#define ps_c_ipl6 (0x0600) +#define ps_c_ipl7 (0x0700) +#define ps_c_ipl8 (0x0800) +#define ps_c_ipl9 (0x0900) +#define ps_c_ipl10 (0x0A00) +#define ps_c_ipl11 (0x0B00) +#define ps_c_ipl12 (0x0C00) +#define ps_c_ipl13 (0x0D00) +#define ps_c_ipl14 (0x0E00) +#define ps_c_ipl15 (0x0F00) +#define ps_c_ipl16 (0x1000) +#define ps_c_ipl17 (0x1100) +#define ps_c_ipl18 (0x1200) +#define ps_c_ipl19 (0x1300) +#define ps_c_ipl20 (0x1400) +#define ps_c_ipl21 (0x1500) +#define ps_c_ipl22 (0x1600) +#define ps_c_ipl23 (0x1700) +#define ps_c_ipl24 (0x1800) +#define ps_c_ipl25 (0x1900) +#define ps_c_ipl26 (0x1A00) +#define ps_c_ipl27 (0x1B00) +#define ps_c_ipl28 (0x1C00) +#define ps_c_ipl29 (0x1D00) +#define ps_c_ipl30 (0x1E00) +#define ps_c_ipl31 (0x1F00) + +// _DEFEND PS,_GBL,DEF +// .ENDM +//;+ +//; PTE layout - symbol prefix PTE_ +//; +//; Loc Size name function +//; ------ ------ ------ ----------------------------------- +//; <63:32> 32 PFN Page Frame Number +//; <31:16> 16 SOFT Bits reserved for software use +//; <15> 1 UWE User write enable +//; <14> 1 SWE Super write enable +//; <13> 1 EWE Exec write enable +//; <12> 1 KWE Kernel write enable +//; <11> 1 URE User read enable +//; <10> 1 SRE Super read enable +//; <9> 1 ERE Exec read enable +//; <8> 1 KRE Kernel read enable +//; <7:6> 2 RES Reserved SBZ +//; <5> 1 HPF Huge Page Flag +//; <4> 1 ASM Wild card address space number match +//; <3> 1 FOE Fault On execute +//; <2> 1 FOW Fault On Write +//; <1> 1 FOR Fault On Read +//; <0> 1 V valid bit +//;- +// .MACRO _PTEDEF,_GBL +// _DEFINI PTE,_GBL + +#define pte_v_pfn 32 +#define pte_m_soft (0xFFFF0000) +#define pte_v_soft 16 +#define pte_m_uwe (0x8000) +#define pte_v_uwe 15 +#define pte_m_swe (0x4000) +#define pte_v_swe 14 +#define pte_m_ewe (0x2000) +#define pte_v_ewe 13 +#define pte_m_kwe (0x1000) +#define pte_v_kwe 12 +#define pte_m_ure (0x0800) +#define pte_v_ure 11 +#define pte_m_sre (0x0400) +#define pte_v_sre 10 +#define pte_m_ere (0x0200) +#define pte_v_ere 9 +#define pte_m_kre (0x0100) +#define pte_v_kre 8 +#define pte_m_hpf (0x0020) +#define pte_v_hpf 5 +#define pte_m_asm (0x0010) +#define pte_v_asm 4 +#define pte_m_foe (0x0008) +#define pte_v_foe 3 +#define pte_m_fow (0x0004) +#define pte_v_fow 2 +#define pte_m_for (0x0002) +#define pte_v_for 1 +#define pte_m_v (0x0001) +#define pte_v_v 0 + +// _DEFEND PTE,_GBL,DEF +// .ENDM +//;+ +//; VA layout - symbol prefix VA_ +//; +//; Loc Size name function +//; ------ ------ ------- ----------------------------------- +//; <42:33> 10 SEG1 First seg table offset for mapping +//; <32:23> 10 SEG2 Second seg table offset for mapping +//; <22:13> 10 SEG3 Third seg table offset for mapping +//; <12:0> 13 OFFSET Byte within page +//;- +// .MACRO _VADEF,_GBL +// _DEFINI VA,_GBL + +#define va_m_offset (0x000000001FFF) +#define va_v_offset 0 +#define va_m_seg3 (0x0000007FE000) +#define va_v_seg3 13 +#define va_m_seg2 (0x0001FF800000) +#define va_v_seg2 23 +#define va_m_seg1 (0x7FE00000000) +#define va_v_seg1 33 + +// _DEFEND VA,_GBL,DEF +// .ENDM +//;+ +//; PRIVILEGED CONTEXT BLOCK (PCB) +//;- +// .MACRO _PCBDEF,_GBL +// _DEFINI PCB,_GBL +#define pcb_q_ksp 0 +#define pcb_q_esp 8 +#define pcb_q_ssp 16 +#define pcb_q_usp 24 +#define pcb_q_ptbr 32 +#define pcb_q_asn 40 +#define pcb_q_ast 48 +#define pcb_q_fen 56 +#define pcb_q_cc 64 +#define pcb_q_unq 72 +#define pcb_q_sct 80 + +#define pcb_v_asten 0 +#define pcb_m_asten (0x0f<<pcb_v_asten) +#define pcb_v_astsr 4 +#define pcb_m_astsr (0x0f<<pcb_v_astsr) +#define pcb_v_dat 63 +#define pcb_v_pme 62 + +// _DEFEND PCB,_GBL,DEF +// .ENDM +//;+ +//; SYSTEM CONTROL BLOCK (SCB) +//;- +// .MACRO _SCBDEF,_GBL +// _DEFINI SCB,_GBL + +#define scb_v_fen (0x0010) +#define scb_v_acv (0x0080) +#define scb_v_tnv (0x0090) +#define scb_v_for (0x00A0) +#define scb_v_fow (0x00B0) +#define scb_v_foe (0x00C0) +#define scb_v_arith (0x0200) +#define scb_v_kast (0x0240) +#define scb_v_east (0x0250) +#define scb_v_sast (0x0260) +#define scb_v_uast (0x0270) +#define scb_v_unalign (0x0280) +#define scb_v_bpt (0x0400) +#define scb_v_bugchk (0x0410) +#define scb_v_opcdec (0x0420) +#define scb_v_illpal (0x0430) +#define scb_v_trap (0x0440) +#define scb_v_chmk (0x0480) +#define scb_v_chme (0x0490) +#define scb_v_chms (0x04A0) +#define scb_v_chmu (0x04B0) +#define scb_v_sw0 (0x0500) +#define scb_v_sw1 (0x0510) +#define scb_v_sw2 (0x0520) +#define scb_v_sw3 (0x0530) +#define scb_v_sw4 (0x0540) +#define scb_v_sw5 (0x0550) +#define scb_v_sw6 (0x0560) +#define scb_v_sw7 (0x0570) +#define scb_v_sw8 (0x0580) +#define scb_v_sw9 (0x0590) +#define scb_v_sw10 (0x05A0) +#define scb_v_sw11 (0x05B0) +#define scb_v_sw12 (0x05C0) +#define scb_v_sw13 (0x05D0) +#define scb_v_sw14 (0x05E0) +#define scb_v_sw15 (0x05F0) +#define scb_v_clock (0x0600) +#define scb_v_inter (0x0610) +#define scb_v_sys_corr_err (0x0620) +#define scb_v_proc_corr_err (0x0630) +#define scb_v_pwrfail (0x0640) +#define scb_v_perfmon (0x0650) +#define scb_v_sysmchk (0x0660) +#define scb_v_procmchk (0x0670) +#define scb_v_passive_rel (0x06F0) + +// _DEFEND SCB,_GBL,DEF +// .ENDM +//;+ +//; Stack frame (FRM) +//;- +// .MACRO _FRMDEF,_GBL +// _DEFINI FRM,_GBL + +#define frm_v_r2 (0x0000) +#define frm_v_r3 (0x0008) +#define frm_v_r4 (0x0010) +#define frm_v_r5 (0x0018) +#define frm_v_r6 (0x0020) +#define frm_v_r7 (0x0028) +#define frm_v_pc (0x0030) +#define frm_v_ps (0x0038) + +// _DEFEND FRM,_GBL,DEF +// .ENDM +//;+ +//; Exeception summary register (EXS) +//;- +// .MACRO _EXSDEF,_GBL +// _DEFINI EXS,_GBL +// exs_v_swc <0> ; Software completion +// exs_v_inv <1> ; Ivalid operation +// exs_v_dze <2> ; Div by zero +// exs_v_fov <3> ; Floating point overflow +// exs_v_unf <4> ; Floating point underflow +// exs_v_ine <5> ; Floating point inexact +// exs_v_iov <6> ; Floating convert to integer overflow +#define exs_v_swc 0 +#define exs_v_inv 1 +#define exs_v_dze 2 +#define exs_v_fov 3 +#define exs_v_unf 4 +#define exs_v_ine 5 +#define exs_v_iov 6 + +#define exs_m_swc (1<<exs_v_swc) +#define exs_m_inv (1<<exs_v_inv) +#define exs_m_dze (1<<exs_v_dze) +#define exs_m_fov (1<<exs_v_fov) +#define exs_m_unf (1<<exs_v_unf) +#define exs_m_ine (1<<exs_v_ine) +#define exs_m_iov (1<<exs_v_iov) + +// _defend exs,_gbl,def +// .endm +//;+ +//; machine check error summary register (mces) +//;- +// .macro _mcesdef,_gbl +// _defini mces,_gbl +// mces_v_mchk <0> ; machine check in progress +// mces_v_sce <1> ; system correctable error +// mces_v_pce <2> ; processor correctable error +// mces_v_dpc <3> ; disable reporting of processor correctable errors +// mces_v_dsc <4> ; disable reporting of system correctable errors +#define mces_v_mchk 0 +#define mces_v_sce 1 +#define mces_v_pce 2 +#define mces_v_dpc 3 +#define mces_v_dsc 4 + +#define mces_m_mchk (1<<mces_v_mchk) +#define mces_m_sce (1<<mces_v_sce) +#define mces_m_pce (1<<mces_v_pce) +#define mces_m_dpc (1<<mces_v_dpc) +#define mces_m_dsc (1<<mces_v_dsc) +#define mces_m_all ((1<<mces_v_mchk) | (1<<mces_v_sce) | (1<<mces_v_pce) | (1<<mces_v_dpc) | (1<<mces_v_dsc)) +// _defend mces,_gbl,def +// .endm + + + +#endif diff --git a/system/alpha/h/ev5_defs.h b/system/alpha/h/ev5_defs.h new file mode 100644 index 000000000..110d338e0 --- /dev/null +++ b/system/alpha/h/ev5_defs.h @@ -0,0 +1,575 @@ +#ifndef EV5_DEFS_INCLUDED +#define EV5_DEFS_INCLUDED 1 + +// adapted from the version emailed to lance..pb Nov/95 + + +// ******************************************************************************************************************************** +// Created 25-JUL-1995 14:21:23 by VAX SDL V3.2-12 Source: 21-JUL-1995 11:03:08 EV5$:[EV5.DVT.SUP]EV5_DEFS.SDL;24 +// ******************************************************************************************************************************** + +// .MACRO $EV5DEF,..EQU=<=>,..COL=<:> +// EV5$K_REVISION'..equ'34 +// In the definitions below, registers are annotated with one of the following +// symbols: +// +// RW - The register may be read and written +// RO - The register may only be read +// WO - The register may only be written +// +// For RO and WO registers, all bits and fields within the register are also +// read-only or write-only. For RW registers, each bit or field within +// the register is annotated with one of the following: +// +// RW - The bit/field may be read and written +// RO - The bit/field may be read; writes are ignored +// WO - The bit/field may be written; reads return an UNPREDICTABLE result. +// WZ - The bit/field may be written; reads return a 0 +// WC - The bit/field may be read; writes cause state to clear +// RC - The bit/field may be read, which also causes state to clear; writes are ignored +// Architecturally-defined (SRM) registers for EVMS +#define pt0 320 +#define pt1 321 +#define pt2 322 +#define pt3 323 +#define pt4 324 +#define pt5 325 +#define pt6 326 +#define pt7 327 +#define pt8 328 +#define pt9 329 +#define pt10 330 +#define pt11 331 +#define pt12 332 +#define pt13 333 +#define pt14 334 +#define pt15 335 +#define pt16 336 +#define pt17 337 +#define pt18 338 +#define pt19 339 +#define pt20 340 +#define pt21 341 +#define pt22 342 +#define pt23 343 +#define cbox_ipr_offset 16777200 +#define sc_ctl 168 +#define sc_stat 232 +#define sc_addr 392 +#define sc_addr_nm 392 +#define sc_addr_fhm 392 +#define bc_ctl 296 +#define bc_config 456 +#define ei_stat 360 +#define ei_addr 328 +#define fill_syn 104 +#define bc_tag_addr 264 +#define ld_lock 488 +#define aster 266 +#define astrr 265 +#define exc_addr 267 +#define exc_sum 268 +#define exc_mask 269 +#define hwint_clr 277 +#define ic_flush_ctl 281 +#define icperr_stat 282 +#define ic_perr_stat 282 +#define ic_row_map 283 +#define icsr 280 +#define ifault_va_form 274 +#define intid 273 +#define ipl 272 +#define isr 256 +#define itb_is 263 +#define itb_asn 259 +#define itb_ia 261 +#define itb_iap 262 +#define itb_pte 258 +#define itb_pte_temp 260 +#define itb_tag 257 +#define ivptbr 275 +#define pal_base 270 +#define pmctr 284 +// this is not the register ps .. pb #define ps 271 +#define sirr 264 +#define sl_txmit 278 +#define sl_rcv 279 +#define alt_mode 524 +#define cc 525 +#define cc_ctl 526 +#define dc_flush 528 +#define dcperr_stat 530 +#define dc_test_ctl 531 +#define dc_test_tag 532 +#define dc_test_tag_temp 533 +#define dtb_asn 512 +#define dtb_cm 513 +#define dtb_ia 522 +#define dtb_iap 521 +#define dtb_is 523 +#define dtb_pte 515 +#define dtb_pte_temp 516 +#define dtb_tag 514 +#define mcsr 527 +#define dc_mode 534 +#define maf_mode 535 +#define mm_stat 517 +#define mvptbr 520 +#define va 518 +#define va_form 519 +#define ev5_srm__ps 0 +#define ev5_srm__pc 0 +#define ev5_srm__asten 0 +#define ev5_srm__astsr 0 +#define ev5_srm__ipir 0 +#define ev5_srm__ipl 0 +#define ev5_srm__mces 0 +#define ev5_srm__pcbb 0 +#define ev5_srm__prbr 0 +#define ev5_srm__ptbr 0 +#define ev5_srm__scbb 0 +#define ev5_srm__sirr 0 +#define ev5_srm__sisr 0 +#define ev5_srm__tbchk 0 +#define ev5_srm__tb1a 0 +#define ev5_srm__tb1ap 0 +#define ev5_srm__tb1ad 0 +#define ev5_srm__tb1ai 0 +#define ev5_srm__tbis 0 +#define ev5_srm__ksp 0 +#define ev5_srm__esp 0 +#define ev5_srm__ssp 0 +#define ev5_srm__usp 0 +#define ev5_srm__vptb 0 +#define ev5_srm__whami 0 +#define ev5_srm__cc 0 +#define ev5_srm__unq 0 +// processor-specific iprs. +#define ev5__sc_ctl 168 +#define ev5__sc_stat 232 +#define ev5__sc_addr 392 +#define ev5__bc_ctl 296 +#define ev5__bc_config 456 +#define bc_config_k_size_1mb 1 +#define bc_config_k_size_2mb 2 +#define bc_config_k_size_4mb 3 +#define bc_config_k_size_8mb 4 +#define bc_config_k_size_16mb 5 +#define bc_config_k_size_32mb 6 +#define bc_config_k_size_64mb 7 +#define ev5__ei_stat 360 +#define ev5__ei_addr 328 +#define ev5__fill_syn 104 +#define ev5__bc_tag_addr 264 +#define ev5__aster 266 +#define ev5__astrr 265 +#define ev5__exc_addr 267 +#define exc_addr_v_pa 2 +#define exc_addr_s_pa 62 +#define ev5__exc_sum 268 +#define ev5__exc_mask 269 +#define ev5__hwint_clr 277 +#define ev5__ic_flush_ctl 281 +#define ev5__icperr_stat 282 +#define ev5__ic_perr_stat 282 +#define ev5__ic_row_map 283 +#define ev5__icsr 280 +#define ev5__ifault_va_form 274 +#define ev5__ifault_va_form_nt 274 +#define ifault_va_form_nt_v_vptb 30 +#define ifault_va_form_nt_s_vptb 34 +#define ev5__intid 273 +#define ev5__ipl 272 +#define ev5__itb_is 263 +#define ev5__itb_asn 259 +#define ev5__itb_ia 261 +#define ev5__itb_iap 262 +#define ev5__itb_pte 258 +#define ev5__itb_pte_temp 260 +#define ev5__itb_tag 257 +#define ev5__ivptbr 275 +#define ivptbr_v_vptb 30 +#define ivptbr_s_vptb 34 +#define ev5__pal_base 270 +#define ev5__pmctr 284 +#define ev5__ps 271 +#define ev5__isr 256 +#define ev5__sirr 264 +#define ev5__sl_txmit 278 +#define ev5__sl_rcv 279 +#define ev5__alt_mode 524 +#define ev5__cc 525 +#define ev5__cc_ctl 526 +#define ev5__dc_flush 528 +#define ev5__dcperr_stat 530 +#define ev5__dc_test_ctl 531 +#define ev5__dc_test_tag 532 +#define ev5__dc_test_tag_temp 533 +#define ev5__dtb_asn 512 +#define ev5__dtb_cm 513 +#define ev5__dtb_ia 522 +#define ev5__dtb_iap 521 +#define ev5__dtb_is 523 +#define ev5__dtb_pte 515 +#define ev5__dtb_pte_temp 516 +#define ev5__dtb_tag 514 +#define ev5__mcsr 527 +#define ev5__dc_mode 534 +#define ev5__maf_mode 535 +#define ev5__mm_stat 517 +#define ev5__mvptbr 520 +#define ev5__va 518 +#define ev5__va_form 519 +#define ev5__va_form_nt 519 +#define va_form_nt_s_va 19 +#define va_form_nt_v_vptb 30 +#define va_form_nt_s_vptb 34 +#define ev5s_ev5_def 10 +#define ev5_def 0 +// cbox registers. +#define sc_ctl_v_sc_fhit 0 +#define sc_ctl_v_sc_flush 1 +#define sc_ctl_s_sc_tag_stat 6 +#define sc_ctl_v_sc_tag_stat 2 +#define sc_ctl_s_sc_fb_dp 4 +#define sc_ctl_v_sc_fb_dp 8 +#define sc_ctl_v_sc_blk_size 12 +#define sc_ctl_s_sc_set_en 3 +#define sc_ctl_v_sc_set_en 13 +#define sc_ctl_s_sc_soft_repair 3 +#define sc_ctl_v_sc_soft_repair 16 +#define sc_stat_s_sc_tperr 3 +#define sc_stat_v_sc_tperr 0 +#define sc_stat_s_sc_dperr 8 +#define sc_stat_v_sc_dperr 3 +#define sc_stat_s_cbox_cmd 5 +#define sc_stat_v_cbox_cmd 11 +#define sc_stat_v_sc_scnd_err 16 +#define sc_addr_fhm_v_sc_tag_parity 4 +#define sc_addr_fhm_s_tag_stat_sb0 3 +#define sc_addr_fhm_v_tag_stat_sb0 5 +#define sc_addr_fhm_s_tag_stat_sb1 3 +#define sc_addr_fhm_v_tag_stat_sb1 8 +#define sc_addr_fhm_s_ow_mod0 2 +#define sc_addr_fhm_v_ow_mod0 11 +#define sc_addr_fhm_s_ow_mod1 2 +#define sc_addr_fhm_v_ow_mod1 13 +#define sc_addr_fhm_s_tag_lo 17 +#define sc_addr_fhm_v_tag_lo 15 +#define sc_addr_fhm_s_tag_hi 7 +#define sc_addr_fhm_v_tag_hi 32 +#define bc_ctl_v_bc_enabled 0 +#define bc_ctl_v_alloc_cyc 1 +#define bc_ctl_v_ei_opt_cmd 2 +#define bc_ctl_v_ei_opt_cmd_mb 3 +#define bc_ctl_v_corr_fill_dat 4 +#define bc_ctl_v_vtm_first 5 +#define bc_ctl_v_ei_ecc_or_parity 6 +#define bc_ctl_v_bc_fhit 7 +#define bc_ctl_s_bc_tag_stat 5 +#define bc_ctl_v_bc_tag_stat 8 +#define bc_ctl_s_bc_bad_dat 2 +#define bc_ctl_v_bc_bad_dat 13 +#define bc_ctl_v_ei_dis_err 15 +#define bc_ctl_v_tl_pipe_latch 16 +#define bc_ctl_s_bc_wave_pipe 2 +#define bc_ctl_v_bc_wave_pipe 17 +#define bc_ctl_s_pm_mux_sel 6 +#define bc_ctl_v_pm_mux_sel 19 +#define bc_ctl_v_dbg_mux_sel 25 +#define bc_ctl_v_dis_baf_byp 26 +#define bc_ctl_v_dis_sc_vic_buf 27 +#define bc_ctl_v_dis_sys_addr_par 28 +#define bc_ctl_v_read_dirty_cln_shr 29 +#define bc_ctl_v_write_read_bubble 30 +#define bc_ctl_v_bc_wave_pipe_2 31 +#define bc_ctl_v_auto_dack 32 +#define bc_ctl_v_dis_byte_word 33 +#define bc_ctl_v_stclk_delay 34 +#define bc_ctl_v_write_under_miss 35 +#define bc_config_s_bc_size 3 +#define bc_config_v_bc_size 0 +#define bc_config_s_bc_rd_spd 4 +#define bc_config_v_bc_rd_spd 4 +#define bc_config_s_bc_wr_spd 4 +#define bc_config_v_bc_wr_spd 8 +#define bc_config_s_bc_rd_wr_spc 3 +#define bc_config_v_bc_rd_wr_spc 12 +#define bc_config_s_fill_we_offset 3 +#define bc_config_v_fill_we_offset 16 +#define bc_config_s_bc_we_ctl 9 +#define bc_config_v_bc_we_ctl 20 +// cbox registers, continued +#define ei_stat_s_sys_id 4 +#define ei_stat_v_sys_id 24 +#define ei_stat_v_bc_tperr 28 +#define ei_stat_v_bc_tc_perr 29 +#define ei_stat_v_ei_es 30 +#define ei_stat_v_cor_ecc_err 31 +#define ei_stat_v_unc_ecc_err 32 +#define ei_stat_v_ei_par_err 33 +#define ei_stat_v_fil_ird 34 +#define ei_stat_v_seo_hrd_err 35 +// +#define bc_tag_addr_v_hit 12 +#define bc_tag_addr_v_tagctl_p 13 +#define bc_tag_addr_v_tagctl_d 14 +#define bc_tag_addr_v_tagctl_s 15 +#define bc_tag_addr_v_tagctl_v 16 +#define bc_tag_addr_v_tag_p 17 +#define bc_tag_addr_s_bc_tag 19 +#define bc_tag_addr_v_bc_tag 20 +// ibox and icache registers. +#define aster_v_kar 0 +#define aster_v_ear 1 +#define aster_v_sar 2 +#define aster_v_uar 3 +#define astrr_v_kar 0 +#define astrr_v_ear 1 +#define astrr_v_sar 2 +#define astrr_v_uar 3 +#define exc_addr_v_pal 0 +#define exc_sum_v_swc 10 +#define exc_sum_v_inv 11 +#define exc_sum_v_dze 12 +#define exc_sum_v_fov 13 +#define exc_sum_v_unf 14 +#define exc_sum_v_ine 15 +#define exc_sum_v_iov 16 +#define hwint_clr_v_pc0c 27 +#define hwint_clr_v_pc1c 28 +#define hwint_clr_v_pc2c 29 +#define hwint_clr_v_crdc 32 +#define hwint_clr_v_slc 33 +// ibox and icache registers, continued +#define icperr_stat_v_dpe 11 +#define icperr_stat_v_tpe 12 +#define icperr_stat_v_tmr 13 +#define ic_perr_stat_v_dpe 11 +#define ic_perr_stat_v_tpe 12 +#define ic_perr_stat_v_tmr 13 +#define icsr_v_pma 8 +#define icsr_v_pmp 9 +#define icsr_v_byt 17 +#define icsr_v_fmp 18 +#define icsr_v_im0 20 +#define icsr_v_im1 21 +#define icsr_v_im2 22 +#define icsr_v_im3 23 +#define icsr_v_tmm 24 +#define icsr_v_tmd 25 +#define icsr_v_fpe 26 +#define icsr_v_hwe 27 +#define icsr_s_spe 2 +#define icsr_v_spe 28 +#define icsr_v_sde 30 +#define icsr_v_crde 32 +#define icsr_v_sle 33 +#define icsr_v_fms 34 +#define icsr_v_fbt 35 +#define icsr_v_fbd 36 +#define icsr_v_dbs 37 +#define icsr_v_ista 38 +#define icsr_v_tst 39 +#define ifault_va_form_s_va 30 +#define ifault_va_form_v_va 3 +#define ifault_va_form_s_vptb 31 +#define ifault_va_form_v_vptb 33 +#define ifault_va_form_nt_s_va 19 +#define ifault_va_form_nt_v_va 3 +#define intid_s_intid 5 +#define intid_v_intid 0 +// ibox and icache registers, continued +#define ipl_s_ipl 5 +#define ipl_v_ipl 0 +#define itb_is_s_va 30 +#define itb_is_v_va 13 +#define itb_asn_s_asn 7 +#define itb_asn_v_asn 4 +#define itb_pte_v_asm 4 +#define itb_pte_s_gh 2 +#define itb_pte_v_gh 5 +#define itb_pte_v_kre 8 +#define itb_pte_v_ere 9 +#define itb_pte_v_sre 10 +#define itb_pte_v_ure 11 +#define itb_pte_s_pfn 27 +#define itb_pte_v_pfn 32 +#define itb_pte_temp_v_asm 13 +#define itb_pte_temp_v_kre 18 +#define itb_pte_temp_v_ere 19 +#define itb_pte_temp_v_sre 20 +#define itb_pte_temp_v_ure 21 +#define itb_pte_temp_s_gh 3 +#define itb_pte_temp_v_gh 29 +#define itb_pte_temp_s_pfn 27 +#define itb_pte_temp_v_pfn 32 +// ibox and icache registers, continued +#define itb_tag_s_va 30 +#define itb_tag_v_va 13 +#define pal_base_s_pal_base 26 +#define pal_base_v_pal_base 14 +#define pmctr_s_sel2 4 +#define pmctr_v_sel2 0 +#define pmctr_s_sel1 4 +#define pmctr_v_sel1 4 +#define pmctr_v_killk 8 +#define pmctr_v_killp 9 +#define pmctr_s_ctl2 2 +#define pmctr_v_ctl2 10 +#define pmctr_s_ctl1 2 +#define pmctr_v_ctl1 12 +#define pmctr_s_ctl0 2 +#define pmctr_v_ctl0 14 +#define pmctr_s_ctr2 14 +#define pmctr_v_ctr2 16 +#define pmctr_v_killu 30 +#define pmctr_v_sel0 31 +#define pmctr_s_ctr1 16 +#define pmctr_v_ctr1 32 +#define pmctr_s_ctr0 16 +#define pmctr_v_ctr0 48 +#define ps_v_cm0 3 +#define ps_v_cm1 4 +#define isr_s_astrr 4 +#define isr_v_astrr 0 +#define isr_s_sisr 15 +#define isr_v_sisr 4 +#define isr_v_atr 19 +#define isr_v_i20 20 +#define isr_v_i21 21 +#define isr_v_i22 22 +#define isr_v_i23 23 +#define isr_v_pc0 27 +#define isr_v_pc1 28 +#define isr_v_pc2 29 +#define isr_v_pfl 30 +#define isr_v_mck 31 +#define isr_v_crd 32 +#define isr_v_sli 33 +#define isr_v_hlt 34 +#define sirr_s_sirr 15 +#define sirr_v_sirr 4 +// ibox and icache registers, continued +#define sl_txmit_v_tmt 7 +#define sl_rcv_v_rcv 6 +// mbox and dcache registers. +#define alt_mode_v_am0 3 +#define alt_mode_v_am1 4 +#define cc_ctl_v_cc_ena 32 +#define dcperr_stat_v_seo 0 +#define dcperr_stat_v_lock 1 +#define dcperr_stat_v_dp0 2 +#define dcperr_stat_v_dp1 3 +#define dcperr_stat_v_tp0 4 +#define dcperr_stat_v_tp1 5 +// the following two registers are used exclusively for test and diagnostics. +// they should not be referenced in normal operation. +#define dc_test_ctl_v_bank0 0 +#define dc_test_ctl_v_bank1 1 +#define dc_test_ctl_v_fill_0 2 +#define dc_test_ctl_s_index 10 +#define dc_test_ctl_v_index 3 +#define dc_test_ctl_s_fill_1 19 +#define dc_test_ctl_v_fill_1 13 +#define dc_test_ctl_s_fill_2 32 +#define dc_test_ctl_v_fill_2 32 +// mbox and dcache registers, continued. +#define dc_test_tag_v_tag_par 2 +#define dc_test_tag_v_ow0 11 +#define dc_test_tag_v_ow1 12 +#define dc_test_tag_s_tag 26 +#define dc_test_tag_v_tag 13 +#define dc_test_tag_temp_v_tag_par 2 +#define dc_test_tag_temp_v_d0p0 3 +#define dc_test_tag_temp_v_d0p1 4 +#define dc_test_tag_temp_v_d1p0 5 +#define dc_test_tag_temp_v_d1p1 6 +#define dc_test_tag_temp_v_ow0 11 +#define dc_test_tag_temp_v_ow1 12 +#define dc_test_tag_temp_s_tag 26 +#define dc_test_tag_temp_v_tag 13 +#define dtb_asn_s_asn 7 +#define dtb_asn_v_asn 57 +#define dtb_cm_v_cm0 3 +#define dtb_cm_v_cm1 4 +#define dtbis_s_va0 30 +#define dtbis_v_va0 13 +#define dtb_pte_v_for 1 +#define dtb_pte_v_fow 2 +#define dtb_pte_v_asm 4 +#define dtb_pte_s_gh 2 +#define dtb_pte_v_gh 5 +#define dtb_pte_v_kre 8 +#define dtb_pte_v_ere 9 +#define dtb_pte_v_sre 10 +#define dtb_pte_v_ure 11 +#define dtb_pte_v_kwe 12 +#define dtb_pte_v_ewe 13 +#define dtb_pte_v_swe 14 +#define dtb_pte_v_uwe 15 +#define dtb_pte_s_pfn 27 +#define dtb_pte_v_pfn 32 +// mbox and dcache registers, continued. +#define dtb_pte_temp_v_for 0 +#define dtb_pte_temp_v_fow 1 +#define dtb_pte_temp_v_kre 2 +#define dtb_pte_temp_v_ere 3 +#define dtb_pte_temp_v_sre 4 +#define dtb_pte_temp_v_ure 5 +#define dtb_pte_temp_v_kwe 6 +#define dtb_pte_temp_v_ewe 7 +#define dtb_pte_temp_v_swe 8 +#define dtb_pte_temp_v_uwe 9 +#define dtb_pte_temp_v_asm 10 +#define dtb_pte_temp_s_fill_0 2 +#define dtb_pte_temp_v_fill_0 11 +#define dtb_pte_temp_s_pfn 27 +#define dtb_pte_temp_v_pfn 13 +#define dtb_tag_s_va 30 +#define dtb_tag_v_va 13 +// most mcsr bits are used for testability and diagnostics only. +// for normal operation, they will be supported in the following configuration: +// split_dcache = 1, maf_nomerge = 0, wb_flush_always = 0, wb_nomerge = 0, +// dc_ena<1:0> = 1, dc_fhit = 0, dc_bad_parity = 0 +#define mcsr_v_big_endian 0 +#define mcsr_v_sp0 1 +#define mcsr_v_sp1 2 +#define mcsr_v_mbox_sel 3 +#define mcsr_v_e_big_endian 4 +#define mcsr_v_dbg_packet_sel 5 +#define dc_mode_v_dc_ena 0 +#define dc_mode_v_dc_fhit 1 +#define dc_mode_v_dc_bad_parity 2 +#define dc_mode_v_dc_perr_dis 3 +#define dc_mode_v_dc_doa 4 +#define maf_mode_v_maf_nomerge 0 +#define maf_mode_v_wb_flush_always 1 +#define maf_mode_v_wb_nomerge 2 +#define maf_mode_v_io_nomerge 3 +#define maf_mode_v_wb_cnt_disable 4 +#define maf_mode_v_maf_arb_disable 5 +#define maf_mode_v_dread_pending 6 +#define maf_mode_v_wb_pending 7 +// mbox and dcache registers, continued. +#define mm_stat_v_wr 0 +#define mm_stat_v_acv 1 +#define mm_stat_v_for 2 +#define mm_stat_v_fow 3 +#define mm_stat_v_dtb_miss 4 +#define mm_stat_v_bad_va 5 +#define mm_stat_s_ra 5 +#define mm_stat_v_ra 6 +#define mm_stat_s_opcode 6 +#define mm_stat_v_opcode 11 +#define mvptbr_s_vptb 31 +#define mvptbr_v_vptb 33 +#define va_form_s_va 30 +#define va_form_v_va 3 +#define va_form_s_vptb 31 +#define va_form_v_vptb 33 +#define va_form_nt_s_va 19 +#define va_form_nt_v_va 3 +//.endm + +#endif diff --git a/system/alpha/h/ev5_impure.h b/system/alpha/h/ev5_impure.h new file mode 100644 index 000000000..ffa910ce2 --- /dev/null +++ b/system/alpha/h/ev5_impure.h @@ -0,0 +1,423 @@ +#ifndef EV5_IMPURE_INCLUDED +#define EV5_IMPURE_INCLUDED + +/* +// This uses the Hudson file format from "impure.h" but with the fields from +// the distrubuted palcode "ev5_impure.sdl" .. pboyle Nov/95 + +//orig file: impure.sdl +//orig +//orig Abstract: PAL impure scratch area and logout area data structure definitions for +//orig Alpha firmware. +//orig +//orig +//orig module $pal_impure; +//orig +//orig Edit Date Who Description +//orig ---- --------- --- --------------------- +//orig 1 7-Jul-93 JEM Initial Entry +//orig 2 18-nov-93 JEM Add shadow bc_ctl and pmctr_ctl to impure area +//orig Delete mvptbr +//orig Calculate pal$logout from end of impure area +//orig 3 6-dec-93 JEM Add pmctr_ctl bitfield definitions +//orig 4 3-feb-94 JEM Remove f31,r31 from impure area; Remove bc_ctl, pmctr_ctl; +//orig add ic_perr_stat, pmctr, dc_perr_stat, sc_stat, sc_addr, sc_ctl, +//orig bc_tag_addr, ei_stat, ei_addr, fill_syn, ld_lock +//orig 5 19-feb-94 JEM add gpr constants, and add f31,r31 back in to be consistent with ev4 +//orig add cns$ipr_offset +//orig 6 18-apr-94 JEM Add shadow bc_ctl and pmctr_ctl to impure area again. +//orig 7 18-jul-94 JEM Add bc_config shadow. Add mchk$sys_base constant to mchk logout frame +//orig +//orig +//orig constant REVISION equals 7 prefix IMPURE$; // Revision number of this file +//orig + +** Macros for saving/restoring data to/from the PAL impure scratch +** area. +** +** The console save state area is larger than the addressibility +** of the HW_LD/ST instructions (10-bit signed byte displacement), +** so some adjustments to the base offsets, as well as the offsets +** within each base region, are necessary. +** +** The console save state area is divided into two segments; the +** CPU-specific segment and the platform-specific segment. The +** state that is saved in the CPU-specific segment includes GPRs, +** FPRs, IPRs, halt code, MCHK flag, etc. All other state is saved +** in the platform-specific segment. +** +** The impure pointer will need to be adjusted by a different offset +** value for each region within a given segment. The SAVE and RESTORE +** macros will auto-magically adjust the offsets accordingly. +** +*/ +#if 0 +#define SAVE_GPR(reg,offset,base) \ + stq_p reg, ((offset-0x200)&0x3FF)(base) + +#define RESTORE_GPR(reg,offset,base) \ + ldq_p reg, ((offset-0x200)&0x3FF)(base) + + +#define SAVE_FPR(reg,offset,base) \ + stt reg, ((offset-0x200)&0x3FF)(base) + +#define RESTORE_FPR(reg,offset,base) \ + ldt reg, ((offset-0x200)&0x3FF)(base) + +#define SAVE_IPR(reg,offset,base) \ + mfpr v0, reg; \ + stq_p v0, ((offset-CNS_Q_IPR)&0x3FF)(base) + +#define RESTORE_IPR(reg,offset,base) \ + ldq_p v0, ((offset-CNS_Q_IPR)&0x3FF)(base); \ + mtpr v0, reg + +#define SAVE_SHADOW(reg,offset,base) \ + stq_p reg, ((offset-CNS_Q_IPR)&0x3FF)(base) + +#define RESTORE_SHADOW(reg,offset,base)\ + ldq_p reg, ((offset-CNS_Q_IPR)&0x3FF)(base) +#else +//#define SEXT10(X) (((X) & 0x200) ? ((X) | 0xfffffffffffffc00) : (X)) +#define SEXT10(X) ((X) & 0x3ff) +//#define SEXT10(X) (((X) << 55) >> 55) + +#define SAVE_GPR(reg,offset,base) \ + stq_p reg, (SEXT10(offset-0x200))(base) + +#define RESTORE_GPR(reg,offset,base) \ + ldq_p reg, (SEXT10(offset-0x200))(base) + + +#define SAVE_FPR(reg,offset,base) \ + stt reg, (SEXT10(offset-0x200))(base) + +#define RESTORE_FPR(reg,offset,base) \ + ldt reg, (SEXT10(offset-0x200))(base) + +#define SAVE_IPR(reg,offset,base) \ + mfpr v0, reg; \ + stq_p v0, (SEXT10(offset-CNS_Q_IPR))(base) + +#define RESTORE_IPR(reg,offset,base) \ + ldq_p v0, (SEXT10(offset-CNS_Q_IPR))(base); \ + mtpr v0, reg + +#define SAVE_SHADOW(reg,offset,base) \ + stq_p reg, (SEXT10(offset-CNS_Q_IPR))(base) + +#define RESTORE_SHADOW(reg,offset,base)\ + ldq_p reg, (SEXT10(offset-CNS_Q_IPR))(base) +#endif +/* orig Structure of the processor-specific impure area */ + +/* orig aggregate impure struct prefix "" tag ""; + * orig cns$flag quadword; + * orig cns$hlt quadword; +*/ + +/* Define base for debug monitor compatibility */ +#define CNS_Q_BASE 0x000 +#define CNS_Q_FLAG 0x100 +#define CNS_Q_HALT 0x108 + + +/* orig constant ( + * orig cns$r0,cns$r1,cns$r2,cns$r3,cns$r4,cns$r5,cns$r6,cns$r7, + * orig cns$r8,cns$r9,cns$r10,cns$r11,cns$r12,cns$r13,cns$r14,cns$r15, + * orig cns$r16,cns$r17,cns$r18,cns$r19,cns$r20,cns$r21,cns$r22,cns$r23, + * orig cns$r24,cns$r25,cns$r26,cns$r27,cns$r28,cns$r29,cns$r30,cns$r31 + * orig ) equals . increment 8 prefix "" tag ""; + * orig cns$gpr quadword dimension 32; +*/ +/* Offset to base of saved GPR area - 32 quadword */ +#define CNS_Q_GPR 0x110 +#define cns_gpr CNS_Q_GPR + +/* orig constant ( + * orig cns$f0,cns$f1,cns$f2,cns$f3,cns$f4,cns$f5,cns$f6,cns$f7, + * orig cns$f8,cns$f9,cns$f10,cns$f11,cns$f12,cns$f13,cns$f14,cns$f15, + * orig cns$f16,cns$f17,cns$f18,cns$f19,cns$f20,cns$f21,cns$f22,cns$f23, + * orig cns$f24,cns$f25,cns$f26,cns$f27,cns$f28,cns$f29,cns$f30,cns$f31 + * orig ) equals . increment 8 prefix "" tag ""; + * orig cns$fpr quadword dimension 32; +*/ +/* Offset to base of saved FPR area - 32 quadwords */ +#define CNS_Q_FPR 0x210 + +/* orig #t=.; + * orig cns$mchkflag quadword; +*/ +#define CNS_Q_MCHK 0x310 + +/* orig constant cns$pt_offset equals .; + * orig constant ( + * orig cns$pt0,cns$pt1,cns$pt2,cns$pt3,cns$pt4,cns$pt5,cns$pt6, + * orig cns$pt7,cns$pt8,cns$pt9,cns$pt10,cns$pt11,cns$pt12,cns$pt13, + * orig cns$pt14,cns$pt15,cns$pt16,cns$pt17,cns$pt18,cns$pt19,cns$pt20, + * orig cns$pt21,cns$pt22,cns$pt23 + * orig ) equals . increment 8 prefix "" tag ""; + * orig cns$pt quadword dimension 24; +*/ +/* Offset to base of saved PALtemp area - 25 quadwords */ +#define CNS_Q_PT 0x318 + +/* orig cns$shadow8 quadword; + * orig cns$shadow9 quadword; + * orig cns$shadow10 quadword; + * orig cns$shadow11 quadword; + * orig cns$shadow12 quadword; + * orig cns$shadow13 quadword; + * orig cns$shadow14 quadword; + * orig cns$shadow25 quadword; +*/ +/* Offset to base of saved PALshadow area - 8 quadwords */ +#define CNS_Q_SHADOW 0x3D8 + +/* Offset to base of saved IPR area */ +#define CNS_Q_IPR 0x418 + +/* orig constant cns$ipr_offset equals .; */ +/* orig cns$exc_addr quadword; */ +#define CNS_Q_EXC_ADDR 0x418 +/* orig cns$pal_base quadword; */ +#define CNS_Q_PAL_BASE 0x420 +/* orig cns$mm_stat quadword; */ +#define CNS_Q_MM_STAT 0x428 +/* orig cns$va quadword; */ +#define CNS_Q_VA 0x430 +/* orig cns$icsr quadword; */ +#define CNS_Q_ICSR 0x438 +/* orig cns$ipl quadword; */ +#define CNS_Q_IPL 0x440 +/* orig cns$ps quadword; // Ibox current mode */ +#define CNS_Q_IPS 0x448 +/* orig cns$itb_asn quadword; */ +#define CNS_Q_ITB_ASN 0x450 +/* orig cns$aster quadword; */ +#define CNS_Q_ASTER 0x458 +/* orig cns$astrr quadword; */ +#define CNS_Q_ASTRR 0x460 +/* orig cns$isr quadword; */ +#define CNS_Q_ISR 0x468 +/* orig cns$ivptbr quadword; */ +#define CNS_Q_IVPTBR 0x470 +/* orig cns$mcsr quadword; */ +#define CNS_Q_MCSR 0x478 +/* orig cns$dc_mode quadword; */ +#define CNS_Q_DC_MODE 0x480 +/* orig cns$maf_mode quadword; */ +#define CNS_Q_MAF_MODE 0x488 +/* orig cns$sirr quadword; */ +#define CNS_Q_SIRR 0x490 +/* orig cns$fpcsr quadword; */ +#define CNS_Q_FPCSR 0x498 +/* orig cns$icperr_stat quadword; */ +#define CNS_Q_ICPERR_STAT 0x4A0 +/* orig cns$pmctr quadword; */ +#define CNS_Q_PM_CTR 0x4A8 +/* orig cns$exc_sum quadword; */ +#define CNS_Q_EXC_SUM 0x4B0 +/* orig cns$exc_mask quadword; */ +#define CNS_Q_EXC_MASK 0x4B8 +/* orig cns$intid quadword; */ +#define CNS_Q_INT_ID 0x4C0 +/* orig cns$dcperr_stat quadword; */ +#define CNS_Q_DCPERR_STAT 0x4C8 +/* orig cns$sc_stat quadword; */ +#define CNS_Q_SC_STAT 0x4D0 +/* orig cns$sc_addr quadword; */ +#define CNS_Q_SC_ADDR 0x4D8 +/* orig cns$sc_ctl quadword; */ +#define CNS_Q_SC_CTL 0x4E0 +/* orig cns$bc_tag_addr quadword; */ +#define CNS_Q_BC_TAG_ADDR 0x4E8 +/* orig cns$ei_stat quadword; */ +#define CNS_Q_EI_STAT 0x4F0 +/* orig cns$ei_addr quadword; */ +#define CNS_Q_EI_ADDR 0x4F8 +/* orig cns$fill_syn quadword; */ +#define CNS_Q_FILL_SYN 0x500 +/* orig cns$ld_lock quadword; */ +#define CNS_Q_LD_LOCK 0x508 +/* orig cns$bc_ctl quadword; // shadow of on chip bc_ctl */ +#define CNS_Q_BC_CTL 0x510 +/* orig cns$pmctr_ctl quadword; // saved frequency select info for performance monitor counter */ +#define CNS_Q_PM_CTL 0x518 +/* orig cns$bc_config quadword; // shadow of on chip bc_config */ +#define CNS_Q_BC_CFG 0x520 + +/* orig constant cns$size equals .; + * orig + * orig constant pal$impure_common_size equals (%x0200 +7) & %xfff8; + * orig constant pal$impure_specific_size equals (.+7) & %xfff8; + * orig constant cns$mchksize equals (.+7-#t) & %xfff8; + * orig constant pal$logout_area equals pal$impure_specific_size ; + * orig end impure; +*/ + +/* This next set of stuff came from the old code ..pb */ +#define CNS_Q_SROM_REV 0x528 +#define CNS_Q_PROC_ID 0x530 +#define CNS_Q_MEM_SIZE 0x538 +#define CNS_Q_CYCLE_CNT 0x540 +#define CNS_Q_SIGNATURE 0x548 +#define CNS_Q_PROC_MASK 0x550 +#define CNS_Q_SYSCTX 0x558 + + + +#define MACHINE_CHECK_CRD_BASE 0 +#define MACHINE_CHECK_SIZE ((CNS_Q_SYSCTX + 7 - CNS_Q_MCHK) & 0xfff8) + + + +/* orig + * orig aggregate EV5PMCTRCTL_BITS structure fill prefix PMCTR_CTL$; + * orig SPROCESS bitfield length 1 ; + * orig FILL_0 bitfield length 3 fill tag $$; + * orig FRQ2 bitfield length 2 ; + * orig FRQ1 bitfield length 2 ; + * orig FRQ0 bitfield length 2 ; + * orig CTL2 bitfield length 2 ; + * orig CTL1 bitfield length 2 ; + * orig CTL0 bitfield length 2 ; + * orig FILL_1 bitfield length 16 fill tag $$; + * orig FILL_2 bitfield length 32 fill tag $$; + * orig end EV5PMCTRCTL_BITS; + * orig + * orig end_module $pal_impure; + * orig + * orig module $pal_logout; + * orig + * orig // + * orig // Start definition of Corrected Error Frame + * orig // + */ + +/* + * orig aggregate crd_logout struct prefix "" tag ""; + */ + +#ifdef SIMOS +#define pal_logout_area 0x600 +#define mchk_crd_base 0 +#endif + +/* orig mchk$crd_flag quadword; */ +#define mchk_crd_flag 0 +/* orig mchk$crd_offsets quadword; */ +#define mchk_crd_offsets 8 +/* orig + * orig // Pal-specific information */ +#define mchk_crd_mchk_code 0x10 +/* orig mchk$crd_mchk_code quadword; + * orig + * orig // CPU-specific information + * orig constant mchk$crd_cpu_base equals . ; + * orig mchk$crd_ei_addr quadword; */ +#define mchk_crd_ei_addr 0x18 +/* orig mchk$crd_fill_syn quadword; */ +#define mchk_crd_fill_syn 0x20 +/* orig mchk$crd_ei_stat quadword; */ +#define mchk_crd_ei_stat 0x28 +/* orig mchk$crd_isr quadword; */ +#define mchk_crd_isr 0x30 + +/* + * Hacked up constants for the turbolaser build. Hope + * this is moreless correct + */ + +#define mchk_crd_whami 0x38 +#define mchk_crd_tldev 0x40 +#define mchk_crd_tlber 0x48 +#define mchk_crd_tlesr0 0x50 +#define mchk_crd_tlesr1 0x58 +#define mchk_crd_tlesr2 0x60 +#define mchk_crd_tlesr3 0x68 +#define mchk_crd_rsvd 0x70 + + +#ifdef SIMOS +/* + * mchk area seems different for tlaser + */ + +#define mchk_crd_size 0x80 +#define mchk_mchk_base (mchk_crd_size) + +#define mchk_tlber 0x0 +#define mchk_tlepaerr 0x8 +#define mchk_tlepderr 0x10 +#define mchk_tlepmerr 0x18 + + +#endif + + +/* orig + * orig // System-specific information + * orig constant mchk$crd_sys_base equals . ; + * orig constant mchk$crd_size equals (.+7) & %xfff8; + * orig + * orig end crd_logout; + * orig // + * orig // Start definition of Machine check logout Frame + * orig // + * orig aggregate logout struct prefix "" tag ""; + * orig mchk$flag quadword; */ +/* orig mchk$offsets quadword; */ +/* orig + * orig // Pal-specific information + * orig mchk$mchk_code quadword; */ +/* + + * orig mchk$pt quadword dimension 24; + * orig + * orig // CPU-specific information + * orig constant mchk$cpu_base equals . ; + * orig mchk$exc_addr quadword; + * orig mchk$exc_sum quadword; + * orig mchk$exc_mask quadword; + * orig mchk$pal_base quadword; + * orig mchk$isr quadword; + * orig mchk$icsr quadword; + * orig mchk$ic_perr_stat quadword; + * orig mchk$dc_perr_stat quadword; + * orig mchk$va quadword; + * orig mchk$mm_stat quadword; + * orig mchk$sc_addr quadword; + * orig mchk$sc_stat quadword; + * orig mchk$bc_tag_addr quadword; + * orig mchk$ei_addr quadword; + * orig mchk$fill_syn quadword; + * orig mchk$ei_stat quadword; + * orig mchk$ld_lock quadword; + * orig + * orig // System-specific information + * orig + * orig constant mchk$sys_base equals . ; + * orig mchk$sys_ipr1 quadword ; // Holder for system-specific stuff + * orig + * orig constant mchk$size equals (.+7) & %xfff8; + * orig + * orig + * orig constant mchk$crd_base equals 0 ; + * orig constant mchk$mchk_base equals mchk$crd_size ; + * orig + * orig + * orig end logout; + * orig + * orig end_module $pal_logout; +*/ + + + + +/* this is lingering in the old ladbx code but looks like it was from ev4 days. + * This was 0x160 in the old days..pb +*/ +#define LAF_K_SIZE MACHINE_CHECK_SIZE +#endif diff --git a/system/alpha/h/ev5_osfalpha_defs.h b/system/alpha/h/ev5_osfalpha_defs.h new file mode 100644 index 000000000..08a110075 --- /dev/null +++ b/system/alpha/h/ev5_osfalpha_defs.h @@ -0,0 +1,160 @@ +#ifndef EV5_OSFALPHA_DEFS_INCLUDED +#define EV5_OSFALPHA_DEFS_INCLUDED 1 + + +// from ev5_osfalpha_defs.mar from Lance's fetch directory +// lowercaseified and $ changed to _ and reformatting for gas...pb Nov/95 + +//orig .MACRO $OSF_ALPHADEFS +//orig OSF_ALPHADEF_VER == 5 ; Flag the version number of this file. +//orig .ENDM +//orig .MACRO $OSF_PSDEF,$GBL +//orig $DEFINI OSFPS,$GBL +//orig;+ +//orig; PS Layout - PS +//orig; Loc Size name function +//orig; ------ ------ ----- ----------------------------------- +//orig; <0:2> 3 IPL Prio level +//orig; <3> 1 CM Current Mode +//orig;- + +#define osfps_v_mode 3 +#define osfps_m_mode (1<<osfps_v_mode) +#define osfps_v_ipl 0 +#define osfps_m_ipl (7<<osfps_v_ipl) + +#define osfipl_c_mchk 7 +#define osfipl_c_rt 6 +#define osfipl_c_clk 5 +#define osfipl_c_dev1 4 +#define osfipl_c_dev0 3 +#define osfipl_c_sw1 2 +#define osfipl_c_sw0 1 +#define osfipl_c_zero 0 + +#define osfint_c_mchk 2 +#define osfint_c_clk 1 +#define osfint_c_dev 3 +#define osfint_c_ip 0 +#define osfint_c_perf 4 +#define osfint_c_passrel 5 + +//orig _DEFEND OSFPS,_GBL,DEF +//orig .ENDM + +//orig;+ +//orig; PTE layout - symbol prefix osfpte_ +//orig; +//orig; Loc Size name function +//orig; ------ ------ ------ ----------------------------------- +//orig; <63:32> 32 PFN Page Frame Number +//orig; <31:16> 16 SOFT Bits reserved for software use +//orig; <15:14> 2 +//orig; <13> 1 UWE User write enable +//orig; <12> 1 KWE Kernel write enable +//orig; <11:10> 2 +//orig; <9> 1 URE User read enable +//orig; <8> 1 KRE Kernel read enable +//orig; <7:6> 2 RES Reserved SBZ +//orig; <5> 1 HPF Huge Page Flag +//orig; <4> 1 ASM Wild card address space number match +//orig; <3> 1 FOE Fault On execute +//orig; <2> 1 FOW Fault On Write +//orig; <1> 1 FOR Fault On Read +//orig; <0> 1 V valid bit +//orig;- + +//orig .MACRO _OSF_PTEDEF,_GBL +//orig _DEFINI OSFPTE,_GBL + +#define osfpte_v_pfn 32 +#define osfpte_m_soft (0xFFFF0000) +#define osfpte_v_soft 16 +#define osfpte_m_uwe (0x2000) +#define osfpte_v_uwe 13 +#define osfpte_m_kwe (0x1000) +#define osfpte_v_kwe 12 +#define osfpte_m_ure (0x0200) +#define osfpte_v_ure 9 +#define osfpte_m_kre (0x0100) +#define osfpte_v_kre 8 +#define osfpte_m_hpf (0x0020) +#define osfpte_v_hpf 5 +#define osfpte_m_asm (0x0010) +#define osfpte_v_asm 4 +#define osfpte_m_foe (0x0008) +#define osfpte_v_foe 3 +#define osfpte_m_fow (0x0004) +#define osfpte_v_fow 2 +#define osfpte_m_for (0x0002) +#define osfpte_v_for 1 +#define osfpte_m_v (0x0001) +#define osfpte_v_v 0 + +#define osfpte_m_ksegbits (osfpte_m_kre | osfpte_m_kwe | osfpte_m_v | osfpte_m_asm) +#define osfpte_m_prot (osfpte_m_ure+osfpte_m_uwe | osfpte_m_kre | osfpte_m_kwe) + +//orig _DEFEND OSFPTE,_GBL,DEF +//orig .ENDM + +//orig;+ +//orig; VA layout - symbol prefix VA_ +//orig; +//orig; Loc Size name function +//orig; ------ ------ ------- ----------------------------------- +//orig; <42:33> 10 SEG1 First seg table offset for mapping +//orig; <32:23> 10 SEG2 Second seg table offset for mapping +//orig; <22:13> 10 SEG3 Third seg table offset for mapping +//orig; <12:0> 13 OFFSET Byte within page +//orig;- +//orig .MACRO _OSF_VADEF,_GBL +//orig _DEFINI OSFVA,_GBL + +#define osfva_m_offset (0x000000001FFF) +#define osfva_v_offset 0 +#define osfva_m_seg3 (0x0000007FE000) +#define osfva_v_seg3 13 +#define osfva_m_seg2 (0x0001FF800000) +#define osfva_v_seg2 23 +#define osfva_m_seg1 (0x7FE00000000) +#define osfva_v_seg1 33 + +//orig _DEFEND OSFVA,_GBL,DEF +//orig .ENDM +//orig;+ +//orig; PRIVILEGED CONTEXT BLOCK (PCB) +//orig;- +//orig .MACRO _OSF_PCBDEF,_GBL +//orig _DEFINI OSFPCB,_GBL + +#define osfpcb_q_ksp (0x0000) +#define osfpcb_q_usp (0x0008) +#define osfpcb_q_Usp (0x0008) +#define osfpcb_q_mmptr (0x0010) +#define osfpcb_q_Mmptr (0x0010) +#define osfpcb_l_cc (0x0018) +#define osfpcb_l_asn (0x001C) +#define osfpcb_q_unique (0x0020) +#define osfpcb_q_fen (0x0028) +#define osfpcb_v_pme 62 + +//orig _DEFEND OSFPCB,_GBL,DEF +//orig .ENDM +//orig;+ +//orig; Stack Frame +//orig;- +//orig .MACRO _OSF_SFDEF,_GBL +//orig _DEFINI OSFSF,_GBL + +#define osfsf_ps (0x00) +#define osfsf_pc (0x08) +#define osfsf_gp (0x10) +#define osfsf_a0 (0x18) +#define osfsf_a1 (0x20) +#define osfsf_a2 (0x28) +#define osfsf_c_size (0x30) + +//orig _DEFEND OSFSF,_GBL,DEF +//orig .ENDM + +#endif diff --git a/system/alpha/h/ev5_paldef.h b/system/alpha/h/ev5_paldef.h new file mode 100644 index 000000000..5f9241b12 --- /dev/null +++ b/system/alpha/h/ev5_paldef.h @@ -0,0 +1,185 @@ +#ifndef EV5_PALDEF_INCLUDED +#define EV5_PALDEF_INCLUDED 1 + +// from ev5_paldef.mar from Lance's fetch directory...pb Nov/95 +// some entries have been superceeded by the more recent evt_defs.h + +// These are lower-caseified and have the $ signs (unnecessarily we now discover) removed. + +// Note that at the bottom of this file is the version of ev5_defs.mar +// which is more recent than the top part of the file and contains overlapping information...pb Nov/95 + +// .MACRO PALDEFS +// PALDEF_VER == 1 ; Flag the version number of this file. +// .ENDM +// +// +// .MACRO _HALT_CODES,_GBL +// _DEFINI HALT_CODES,_GBL + +#define hlt_c_reset 0 +#define hlt_c_hw_halt 1 +#define hlt_c_ksp_inval 2 +#define hlt_c_scbb_inval 3 +#define hlt_c_ptbr_inval 4 +#define hlt_c_sw_halt 5 +#define hlt_c_dbl_mchk 6 +#define hlt_c_mchk_from_pal 7 +#define hlt_c_start 32 +#define hlt_c_callback 33 +#define hlt_c_mpstart 34 +#define hlt_c_lfu_start 35 + +// halt codes above 255 reserved for platform specific errors +// _DEFEND HALT_CODES,_GBL,DEF +// .ENDM +// .MACRO _MCHK_CODES,_GBL +// _DEFINI MCHK_CODES,_GBL + +#define mchk_c_tperr (64<<1) +#define mchk_c_tcperr (65<<1) +#define mchk_c_herr (66<<1) +#define mchk_c_ecc_c (67<<1) +#define mchk_c_ecc_nc (68<<1) +#define mchk_c_unknown (69<<1) +#define mchk_c_cacksoft (70<<1) +#define mchk_c_bugcheck (71<<1) +#define mchk_c_os_bugcheck (72<<1) +#define mchk_c_dcperr (73<<1) +#define mchk_c_icperr (74<<1) +#define mchk_c_retryable_ird (75<<1) +#define mchk_c_proc_hrd_error (76<<1) +#define mchk_c_scperr (77<<1) +#define mchk_c_bcperr (78<<1) +//; mchk codes above 255 reserved for platform specific errors + + +#define mchk_c_read_nxm (256<<1) +#define mchk_c_sys_hrd_error (257<<1) +#define mchk_c_sys_ecc (258<<1) + +// _DEFEND MCHK_CODES,_GBL,DEF +// .ENDM + +// .MACRO _EV5_MM,_GBL +// _DEFINI _EV5_MM,_GBL + +#define page_seg_size_bits 10 +#define page_offset_size_bits 13 +#define page_size_bytes 8192 +#define va_size_bits 43 +#define pa_size_bits 45 + +// _DEFEND _EV5_MM,_GBL,DEF +// .ENDM + +// .MACRO _PALTEMP,_GBL +// _DEFINI _PALTEMP,_GBL + +// replaced by ev5_defs.h #define pt0 (0x140) +// replaced by ev5_defs.h #define pt1 (0x141) +// replaced by ev5_defs.h #define pt2 (0x142) +#define pt_entuna (0x142) +// replaced by ev5_defs.h #define pt3 (0x143) +#define pt_impure (0x143) +// replaced by ev5_defs.h #define pt4 (0x144) +// replaced by ev5_defs.h #define pt5 (0x145) +// replaced by ev5_defs.h #define pt6 (0x146) +// replaced by ev5_defs.h #define pt7 (0x147) +#define pt_entif (0x147) +// replaced by ev5_defs.h #define pt8 (0x148) +#define pt_intmask (0x148) +// replaced by ev5_defs.h #define pt9 (0x149) +#define pt_entsys (0x149) +#define pt_ps (0x149) +// replaced by ev5_defs.h #define pt10 (0x14a) +// replaced by ev5_defs.h #define pt11 (0x14b) +#define pt_trap (0x14b) +#define pt_entint (0x14b) +// replaced by ev5_defs.h #define pt12 (0x14c) +#define pt_entarith (0x14c) +// replaced by ev5_defs.h #define pt13 (0x14d) +#define pt_sys0 (0x14d) +// replaced by ev5_defs.h #define pt14 (0x14e) +#define pt_sys1 (0x14e) +// replaced by ev5_defs.h #define pt15 (0x14f) +#define pt_sys2 (0x14f) +// replaced by ev5_defs.h #define pt16 (0x150) +#define pt_whami (0x150) +#define pt_mces (0x150) +#define pt_misc (0x150) +// replaced by ev5_defs.h #define pt17 (0x151) +#define pt_scc (0x151) +#define pt_sysval (0x151) +// replaced by ev5_defs.h #define pt18 (0x152) +#define pt_prbr (0x152) +#define pt_usp (0x152) +// replaced by ev5_defs.h #define pt19 (0x153) +#define pt_ksp (0x153) +// replaced by ev5_defs.h #define pt20 (0x154) +#define pt_ptbr (0x154) +// replaced by ev5_defs.h #define pt21 (0x155) +#define pt_vptbr (0x155) +#define pt_entmm (0x155) +// replaced by ev5_defs.h #define pt22 (0x156) +#define pt_scbb (0x156) +#define pt_kgp (0x156) +// replaced by ev5_defs.h #define pt23 (0x157) +#define pt_pcbb (0x157) + + +#define pt_misc_v_switch 48 +#define pt_misc_v_cm 56 + +// _DEFEND _PALTEMP,_GBL,DEF +// .ENDM + +// .MACRO _OSF_MMCSR_DEF,_GBL +// _DEFINI OSFMMCSR,_GBL + +#define mmcsr_c_tnv 0 +#define mmcsr_c_acv 1 +#define mmcsr_c_for 2 +#define mmcsr_c_foe 3 +#define mmcsr_c_fow 4 + +// _DEFEND OSFMMCSR,_GBL,DEF +// .ENDM + +// .MACRO _MM_STAT_DEF,_GBL +// _DEFINI MMSTATDEF,_GBL + +#define mm_stat_m_opcode (0x3F) +#define mm_stat_m_ra (0x1F) +#define evx_opc_sync (0x18) +#define EVX_OPC_SYNC (0x18) +#define evx_opc_hw_ld (0x1B) + +// _DEFEND MMSTATDEF,_GBL,DEF +// .ENDM + +// .MACRO _OSF_A0_DEF,_GBL +// _DEFINI OSFA0DEF,_GBL + +#define osf_a0_bpt (0x0) +#define osf_a0_bugchk (0x1) +#define osf_a0_gentrap (0x2) +#define osf_a0_fen (0x3) +#define osf_a0_opdec (0x4) + +// _DEFEND OSFA0DEF,_GBL,DEF +// .ENDM + +// .MACRO _EV5_IPLDEF,_GBL +// _DEFINI EV5_IPLDEF,_GBL + +#define ipl_machine_check 31 +#define ipl_powerfail 30 +#define ipl_perf_count 29 +#define ipl_clock 22 +#define ipl_interprocessor 22 + +// _DEFEND EV5_IPLDEF,_GBL,DEF +// .ENDM + +#endif diff --git a/system/alpha/h/fat.h b/system/alpha/h/fat.h deleted file mode 100644 index 0c5df519d..000000000 --- a/system/alpha/h/fat.h +++ /dev/null @@ -1,88 +0,0 @@ -#ifndef __FAT_H_LOADED -#define __FAT_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: fat.h,v 1.1.1.1 1997/10/30 23:27:15 verghese Exp $; - */ - -/* - * $Log: fat.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:15 verghese - * current 10/29/97 - * - * Revision 1.4 1994/08/05 20:13:47 fdh - * Updated Copyright header and RCS $Id: identifier. - * - * Revision 1.3 1994/06/20 14:18:59 fdh - * Fixup header file preprocessor #include conditionals. - * - * Revision 1.2 1994/06/17 19:34:01 fdh - * Clean-up... - * - * Revision 1.1 1993/06/08 19:56:13 fdh - * Initial revision - * - */ - - - -#define BOOT_SECTOR 0 -#define FAT 12 -#define FILES 20 -#define DATA 100 -#define BINTYPE 0 -#define FATTYPE 1 -#define DIRTYPE 2 -#define EXERTYPE 3 -struct _fat { - ub jmp[3]; - ub oem[8]; - ub bps[2]; - ub spc[1]; - ub rs[2]; - ub numfat[1]; - ub numdir[2]; - ub totsec[2]; - ub medsc[1]; - ub spf[2]; - ub spt[2]; - ub nhead[2]; -}; - -struct _file { - ub fname[8]; - ub ext[3]; - ub attrib[1]; - ub reserv[10]; - ub time[2]; - ub date[2]; - ub cluster[2]; - ub fsize[4]; -}; - -#endif /* __FAT_H_LOADED */ diff --git a/system/alpha/h/flash.h b/system/alpha/h/flash.h deleted file mode 100644 index b34838557..000000000 --- a/system/alpha/h/flash.h +++ /dev/null @@ -1,101 +0,0 @@ -#ifndef __FLASH_H_LOADED -#define __FLASH_H_LOADED - -/***************************************************************************** - -Copyright © 1994, Digital Equipment Corporation, Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ -#define FLASH_H_RCSID "$Id: flash.h,v 1.1.1.1 1997/10/30 23:27:15 verghese Exp $" - -/* - * Defines constants and macros for controlling the flash memory device. - * - * $Log: flash.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:15 verghese - * current 10/29/97 - * - * Revision 1.2 1995/02/02 21:42:06 cruz - * Changed prototype for two flash functions. - * - * Revision 1.1 1994/11/08 21:40:02 fdh - * Initial revision - * - * - */ - -#define FLASH_BYTE 1 -#define FLASH_WORD 2 -#define FLASH_LONG 4 -#define FLASH_QUAD 8 - -#if (defined INTEL_28F008SA || defined INTEL_28F004BX_T) -/* Flash commands */ -#define READ_RESET 0xff -#define IID 0x90 -#define READ_STATUS 0x70 -#define CLEAR_STATUS 0x50 -#define ERASE_SETUP 0x20 -#define ERASE_CONFIRM 0xd0 -#define ERASE_SUSPEND 0xB0 -#define BYTE_WRITE 0x40 -#define ALT_WR_SET_WR 0x10 - -/* Status bits */ -#define SR_READY (1 << 7) -#define SR_ERASE_SUSP (1 << 6) -#define SR_ERASE_ERR (1 << 5) -#define SR_WRITE_ERR (1 << 4) -#define SR_VPP_LOW (1 << 3) -#define SR_CMD_SEQ_ERR (SR_WRITE_ERR | SR_ERASE_ERR) -#endif - -#ifdef INTEL_28F008SA -#define BX_T_M_CODE 0x89 -#define BX_T_D_CODE 0xA2 -#define DEVICE_NAME "Intel 28F008SA" - -#define NUMSEGS 16 -#define SEGSIZE (64 * 1024) -#endif /* INTEL_28F008SA */ - -#ifdef INTEL_28F004BX_T -#define BX_T_M_CODE 0x89 -#define BX_T_D_CODE 0x78 -#define DEVICE_NAME "Intel 28F004BX-T" - -#define NUMSEGS 4 -#define SEGSIZE (128 * 1024) -#endif /* INTEL_28F004BX_T */ - -/* prototypes */ -static ui inflash(ui size , ui offset); -static void outflash(ui size , ui offset , ui d); -static int flash_present(void); -static int flash_write_segs (ui segstart, ui segcnt, ui total_size, unsigned char *buf); -static int read_status(void); -static int flash_decode(int status); -static int flash_erase(ui segnum); -static int flash_program (ui offset, ui size, unsigned char *buf); -static int clear_status(void); - -#endif /* __FLASH_H_LOADED */ diff --git a/system/alpha/h/floppy.h b/system/alpha/h/floppy.h deleted file mode 100644 index 4c3ac023c..000000000 --- a/system/alpha/h/floppy.h +++ /dev/null @@ -1,171 +0,0 @@ -#ifndef __FLOPPY_H_LOADED -#define __FLOPPY_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: floppy.h,v 1.1.1.1 1997/10/30 23:27:15 verghese Exp $; - */ - -/* - * $Log: floppy.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:15 verghese - * current 10/29/97 - * - * Revision 1.5 1994/08/05 20:13:47 fdh - * Updated Copyright header and RCS $Id: identifier. - * - * Revision 1.4 1994/06/22 15:22:35 rusling - * Fixed up minor OSF build problem. Changed fdacmd() - * definition. - * - * Revision 1.3 1994/06/20 14:18:59 fdh - * Fixup header file preprocessor #include conditionals. - * - * Revision 1.2 1994/06/17 19:34:01 fdh - * Clean-up... - * - * Revision 1.1 1993/06/08 19:56:13 fdh - * Initial revision - * - */ - - - -#define TRUE 1 -#define FALSE 0 -#define REALFLOPPY 1 - -/* pic */ -#define PICBOCW 0x20 -#define PICBIRR 0x20 -#define READIRR 0x0A -#define FDAMASK 0x40 - -/* dma */ -#define DMACMD03 0x08 -#define DMACMD47 0xD0 -#define DMAMODE03 0x0B -#define DMAMODE47 0xD6 -#define DMAXMODE03 0x40B -#define DMAXMODE47 0x4D6 -#define DMAOFFS 0x04 -#define DMALPAG 0x81 -#define DMAHPAG 0x481 -#define DMACNT 0x05 -#define DMAHCNT 0x405 -#define DMACBP 0x0C -#define DMAMASK03 0x0A -#define DMAMASK47 0xD4 - -/* fda */ -#define FDADCR 0x03F2 -#define FDAMSR 0x03F4 -#define FDADR 0x03F5 -#define FDADRR 0x03F7 -#define FDADCB 0x03F7 - -/* dcr */ -#define DCRSELA 0x00 -#define DCRSELB 0x01 -#define DCRSELC 0x02 -#define DCRSELD 0x03 -#define DCRNRES 0x04 -#define DCRENAB 0x08 -#define DCRMTRA 0x10 -#define DCRMTRB 0x20 -#define DCRMTRC 0x40 -#define DCRMTRD 0x80 - -/* msr */ -#define MSRDIO 0x40 -#define MSRRQM 0x80 - -/* drr */ -#define DRR500 0x00 -#define DRR250 0x02 - -/* dcb */ -#define DCBNCHG 0x80 - -/* st0 */ -#define ST0IC 0xC0 -#define ST0NT 0x00 -#define ST0NR 0x08 - -/* st1 */ -#define ST1NW 0x02 - -/* cmd */ -#define NREAD 0x66 -#define NWRITE 0x45 -#define NRECAL 0x07 -#define NSEEK 0x0F -#define NSINTS 0x08 -#define NSPEC 0x03 - -#define FDTOMEM 0 -#define MEMTOFD 1 - -#define NCMD 9 -#define NSTS 7 - -#define UNITNUM 0 -#define UNITSEL (DCRSELA) -#define UNITMTR (DCRMTRA) - -#define lSRT 0xE0 /* 4 mS */ -#define lHUT 0x08 /* 256 mS */ - -#define hSRT 0xC0 /* 4 mS */ -#define hHUT 0x0F /* 256 mS */ - -#define HLT 0x02 /* 4 mS */ -#define ND 0x00 /* Use DMA */ - -int fdactrk; - -static void read_sector(int sec , int loc); -static int get_file_info(char * file2load , int flag); -static void prep_filename(ub * fn , ub * nfn , ub * ext); -static int get_boot_info(void ); -static void load_file(void ); -static int get_sec(int gcluster); -static int get_next_cluster(ui gcluster , ui ifat); -static void fdainit(int rate); -static void fdaspinup(void ); -static void fdaspindown(void ); -static int fdaio(char * buf , int sec , int type); -static void fdacmd(unsigned char cmd[] , int ncmd); -static int fdasts(void ); -static void fdawait(void ); -static void fdasleep(int nmsec); -static void init_pic(void ); - -#define fdREAD 0 /* read command */ -#define fdWRITE 1 /* write command */ - -#endif /* __FLOPPY_H_LOADED */ diff --git a/system/alpha/h/fregs.h b/system/alpha/h/fregs.h deleted file mode 100644 index a829301df..000000000 --- a/system/alpha/h/fregs.h +++ /dev/null @@ -1,80 +0,0 @@ -#ifndef __FREGS_H_LOADED -#define __FREGS_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: fregs.h,v 1.1.1.1 1997/10/30 23:27:15 verghese Exp $; - */ - -/* - * $Log: fregs.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:15 verghese - * current 10/29/97 - * - * Revision 1.1 1994/11/24 04:21:32 fdh - * Initial revision - * - */ - -/*======================================================================*/ -/* FLOATING POINT REGISTER DEFINITIONS */ -/*======================================================================*/ - -#define f0 $f0 -#define f1 $f1 -#define f2 $f2 -#define f3 $f3 -#define f4 $f4 -#define f5 $f5 -#define f6 $f6 -#define f7 $f7 -#define f8 $f8 -#define f9 $f9 -#define f10 $f10 -#define f11 $f11 -#define f12 $f12 -#define f13 $f13 -#define f14 $f14 -#define f15 $f15 -#define f16 $f16 -#define f17 $f17 -#define f18 $f18 -#define f19 $f19 -#define f20 $f20 -#define f21 $f21 -#define f22 $f22 -#define f23 $f23 -#define f24 $f24 -#define f25 $f25 -#define f26 $f26 -#define f27 $f27 -#define f28 $f28 -#define f29 $f29 -#define f30 $f30 -#define f31 $f31 - -#endif /* __FREGS_H_LOADED */ diff --git a/system/alpha/h/fromHudsonMacros.h b/system/alpha/h/fromHudsonMacros.h new file mode 100644 index 000000000..4b22d87ac --- /dev/null +++ b/system/alpha/h/fromHudsonMacros.h @@ -0,0 +1,145 @@ +#ifndef HUDSON_MACROS_LOADED +#define HUDSON_MACROS_LOADED 1 + +/* + * VID: [T1.2] PT: [Fri Apr 21 16:47:16 1995] SF: [macros.h] + * TI: [/sae_users/cruz/bin/vice -iplatform.s -l// -p# -DEB164 -h -m -aeb164 ] + */ +/* +***************************************************************************** +** * +** Copyright © 1993, 1994 * +** by Digital Equipment Corporation, Maynard, Massachusetts. * +** * +** All Rights Reserved * +** * +** Permission is hereby granted to use, copy, modify and distribute * +** this software and its documentation, in both source code and * +** object code form, and without fee, for the purpose of distribution * +** of this software or modifications of this software within products * +** incorporating an integrated circuit implementing Digital's AXP * +** architecture, regardless of the source of such integrated circuit, * +** provided that the above copyright notice and this permission notice * +** appear in all copies, and that the name of Digital Equipment * +** Corporation not be used in advertising or publicity pertaining to * +** distribution of the document or software without specific, written * +** prior permission. * +** * +** Digital Equipment Corporation disclaims all warranties and/or * +** guarantees with regard to this software, including all implied * +** warranties of fitness for a particular purpose and merchantability, * +** and makes no representations regarding the use of, or the results * +** of the use of, the software and documentation in terms of correctness, * +** accuracy, reliability, currentness or otherwise; and you rely on * +** the software, documentation and results solely at your own risk. * +** * +** AXP is a trademark of Digital Equipment Corporation. * +** * +***************************************************************************** +** +** FACILITY: +** +** DECchip 21164 PALcode +** +** MODULE: +** +** macros.h +** +** MODULE DESCRIPTION: +** +** DECchip 21164 PALcode macro definitions +** +** AUTHOR: ER +** +** CREATION DATE: 29-Nov-1993 +** +** $Id: fromHudsonMacros.h,v 1.1.1.1 1997/10/30 23:27:19 verghese Exp $ +** +** MODIFICATION HISTORY: +** +** $Log: fromHudsonMacros.h,v $ +** Revision 1.1.1.1 1997/10/30 23:27:19 verghese +** current 10/29/97 +** +** Revision 1.1 1995/11/18 01:46:23 boyle +** Initial revision +** +** Revision 1.5 1994/07/08 17:03:12 samberg +** Changes to support platform specific additions +** +** Revision 1.4 1994/05/20 19:24:19 ericr +** Moved STALL macro from osfpal.s to here +** Added LDLI macro +** +** Revision 1.3 1994/05/20 18:08:14 ericr +** Changed line comments to C++ style comment character +** +** Revision 1.2 1994/02/28 18:45:51 ericr +** Fixed EGORE related bugs +** +** Revision 1.1 1993/12/16 21:55:05 eric +** Initial revision +** +** +**-- +*/ + +#define STALL \ + mfpr r31, pt0 + +#define NOP \ + bis $31, $31, $31 + +/* +** Align code on an 8K byte page boundary. +*/ + +#define ALIGN_PAGE \ + .align 13 + +/* +** Align code on a 32 byte block boundary. +*/ + +#define ALIGN_BLOCK \ + .align 5 + +/* +** Align code on a quadword boundary. +*/ + +#define ALIGN_BRANCH \ + .align 3 + +/* +** Hardware vectors go in .text 0 sub-segment. +*/ + +#define HDW_VECTOR(offset) \ + . = offset + +/* +** Privileged CALL_PAL functions are in .text 1 sub-segment. +*/ + +#define CALL_PAL_PRIV(vector) \ + . = (PAL_CALL_PAL_PRIV_ENTRY+(vector<<6)) + +/* +** Unprivileged CALL_PAL functions are in .text 1 sub-segment, +** the privileged bit is removed from these vectors. +*/ + +#define CALL_PAL_UNPRIV(vector) \ + . = (PAL_CALL_PAL_UNPRIV_ENTRY+((vector&0x3F)<<6)) + +/* +** Implements a load "immediate" longword function +*/ +#define LDLI(reg,val) \ + ldah reg, ((val+0x8000) >> 16)(zero); \ + lda reg, (val&0xffff)(reg) + + + +#endif diff --git a/system/alpha/h/fromHudsonOsf.h b/system/alpha/h/fromHudsonOsf.h new file mode 100644 index 000000000..f9cb2f747 --- /dev/null +++ b/system/alpha/h/fromHudsonOsf.h @@ -0,0 +1,554 @@ +#ifndef FROMHUDSONOSF_INCLUDED +#define FROMHUDSONOSF_INCLUDED 1 +/* + * VID: [T1.2] PT: [Fri Apr 21 16:47:14 1995] SF: [osf.h] + * TI: [/sae_users/cruz/bin/vice -iplatform.s -l// -p# -DEB164 -h -m -aeb164 ] + */ +#define __OSF_LOADED 1 +/* +***************************************************************************** +** * +** Copyright © 1993, 1994 * +** by Digital Equipment Corporation, Maynard, Massachusetts. * +** * +** All Rights Reserved * +** * +** Permission is hereby granted to use, copy, modify and distribute * +** this software and its documentation, in both source code and * +** object code form, and without fee, for the purpose of distribution * +** of this software or modifications of this software within products * +** incorporating an integrated circuit implementing Digital's AXP * +** architecture, regardless of the source of such integrated circuit, * +** provided that the above copyright notice and this permission notice * +** appear in all copies, and that the name of Digital Equipment * +** Corporation not be used in advertising or publicity pertaining to * +** distribution of the document or software without specific, written * +** prior permission. * +** * +** Digital Equipment Corporation disclaims all warranties and/or * +** guarantees with regard to this software, including all implied * +** warranties of fitness for a particular purpose and merchantability, * +** and makes no representations regarding the use of, or the results * +** of the use of, the software and documentation in terms of correctness, * +** accuracy, reliability, currentness or otherwise; and you rely on * +** the software, documentation and results solely at your own risk. * +** * +** AXP is a trademark of Digital Equipment Corporation. * +** * +***************************************************************************** +** +** FACILITY: +** +** DECchip 21164 PALcode +** +** MODULE: +** +** osf.h +** +** MODULE DESCRIPTION: +** +** OSF/1 specific definitions +** +** AUTHOR: ER +** +** CREATION DATE: 24-Nov-1993 +** +** $Id: fromHudsonOsf.h,v 1.1.1.1 1997/10/30 23:27:19 verghese Exp $ +** +** MODIFICATION HISTORY: +** +** $Log: fromHudsonOsf.h,v $ +** Revision 1.1.1.1 1997/10/30 23:27:19 verghese +** current 10/29/97 +** +** Revision 1.1 1995/11/18 01:46:31 boyle +** Initial revision +** +** Revision 1.11 1995/04/21 02:06:30 fdh +** Replaced C++ style comments with Standard C style comments. +** +** Revision 1.10 1994/09/26 14:17:47 samberg +** Complete VICE work and EB164/SD164 breakout. +** +** Revision 1.9 1994/07/26 17:39:10 samberg +** Changes for SD164. +** +** Revision 1.8 1994/07/08 17:03:48 samberg +** Changes to support platform specific additions +** +** Revision 1.7 1994/05/20 19:23:51 ericr +** Moved STACK_FRAME macro from osfpal.s to here +** +** Revision 1.6 1994/05/20 18:08:19 ericr +** Changed line comments to C++ style comment character +** +** Revision 1.5 1994/01/11 18:43:33 ericr +** Removed PAL version/revision and size constants +** +** Revision 1.4 1994/01/05 16:22:32 ericr +** Added more SCB vector offsets and MCHK error code +** +** Revision 1.3 1994/01/03 19:35:40 ericr +** Derive mask definitions from field constants +** +** Revision 1.2 1993/12/22 20:43:01 eric +** Added mask definitions for MCES bits +** +** Revision 1.1 1993/12/16 21:55:05 eric +** Initial revision +** +** +**-- +*/ + +/* +** Seg0 and Seg1 Virtual Address (VA) Format +** +** Loc Size Name Function +** ----- ---- ---- --------------------------------- +** <42:33> 10 SEG1 First level page table offset +** <32:23> 10 SEG2 Second level page table offset +** <22:13> 10 SEG3 Third level page table offset +** <12:00> 13 OFFSET Byte within page offset +*/ + +#define VA_V_SEG1 33 +#define VA_M_SEG1 (0x3FF<<VA_V_SEG1) +#define VA_V_SEG2 23 +#define VA_M_SEG2 (0x3FF<<VA_V_SEG2) +#define VA_V_SEG3 13 +#define VA_M_SEG3 (0x3FF<<VA_V_SEG3) +#define VA_V_OFFSET 0 +#define VA_M_OFFSET 0x1FFF + +/* +** Virtual Address Options: 8K byte page size +*/ + +#define VA_S_SIZE 43 +#define VA_S_OFF 13 +#define va_s_off 13 +#define VA_S_SEG 10 +#define VA_S_PAGE_SIZE 8192 + +/* +** Page Table Entry (PTE) Format +** +** Extent Size Name Function +** ------ ---- ---- --------------------------------- +** <63:32> 32 PFN Page Frame Number +** <31:16> 16 SW Reserved for software +** <15:14> 2 RSV0 Reserved for hardware SBZ +** <13> 1 UWE User Write Enable +** <12> 1 KWE Kernel Write Enable +** <11:10> 2 RSV1 Reserved for hardware SBZ +** <9> 1 URE User Read Enable +** <8> 1 KRE Kernel Read Enable +** <7> 1 RSV2 Reserved for hardware SBZ +** <6:5> 2 GH Granularity Hint +** <4> 1 ASM Address Space Match +** <3> 1 FOE Fault On Execute +** <2> 1 FOW Fault On Write +** <1> 1 FOR Fault On Read +** <0> 1 V Valid +*/ + +#define PTE_V_PFN 32 +#define PTE_M_PFN 0xFFFFFFFF00000000 +#define PTE_V_SW 16 +#define PTE_M_SW 0x00000000FFFF0000 +#define PTE_V_UWE 13 +#define PTE_M_UWE (1<<PTE_V_UWE) +#define PTE_V_KWE 12 +#define PTE_M_KWE (1<<PTE_V_KWE) +#define PTE_V_URE 9 +#define PTE_M_URE (1<<PTE_V_URE) +#define PTE_V_KRE 8 +#define PTE_M_KRE (1<<PTE_V_KRE) +#define PTE_V_GH 5 +#define PTE_M_GH (3<<PTE_V_GH) +#define PTE_V_ASM 4 +#define PTE_M_ASM (1<<PTE_V_ASM) +#define PTE_V_FOE 3 +#define PTE_M_FOE (1<<PTE_V_FOE) +#define PTE_V_FOW 2 +#define PTE_M_FOW (1<<PTE_V_FOW) +#define PTE_V_FOR 1 +#define PTE_M_FOR (1<<PTE_V_FOR) +#define PTE_V_VALID 0 +#define PTE_M_VALID (1<<PTE_V_VALID) + +#define PTE_M_KSEG 0x1111 +#define PTE_M_PROT 0x3300 +#define pte_m_prot 0x3300 + +/* +** System Entry Instruction Fault (entIF) Constants: +*/ + +#define IF_K_BPT 0x0 +#define IF_K_BUGCHK 0x1 +#define IF_K_GENTRAP 0x2 +#define IF_K_FEN 0x3 +#define IF_K_OPCDEC 0x4 + +/* +** System Entry Hardware Interrupt (entInt) Constants: +*/ + +#define INT_K_IP 0x0 +#define INT_K_CLK 0x1 +#define INT_K_MCHK 0x2 +#define INT_K_DEV 0x3 +#define INT_K_PERF 0x4 + +/* +** System Entry MM Fault (entMM) Constants: +*/ + +#define MM_K_TNV 0x0 +#define MM_K_ACV 0x1 +#define MM_K_FOR 0x2 +#define MM_K_FOE 0x3 +#define MM_K_FOW 0x4 + +/* +** Process Control Block (PCB) Offsets: +*/ + +#define PCB_Q_KSP 0x0000 +#define PCB_Q_USP 0x0008 +#define PCB_Q_PTBR 0x0010 +#define PCB_L_PCC 0x0018 +#define PCB_L_ASN 0x001C +#define PCB_Q_UNIQUE 0x0020 +#define PCB_Q_FEN 0x0028 +#define PCB_Q_RSV0 0x0030 +#define PCB_Q_RSV1 0x0038 + +/* +** Processor Status Register (PS) Bit Summary +** +** Extent Size Name Function +** ------ ---- ---- --------------------------------- +** <3> 1 CM Current Mode +** <2:0> 3 IPL Interrupt Priority Level +**/ + +#define PS_V_CM 3 +#define PS_M_CM (1<<PS_V_CM) +#define PS_V_IPL 0 +#define PS_M_IPL (7<<PS_V_IPL) + +#define PS_K_KERN (0<<PS_V_CM) +#define PS_K_USER (1<<PS_V_CM) + +#define IPL_K_ZERO 0x0 +#define IPL_K_SW0 0x1 +#define IPL_K_SW1 0x2 +#define IPL_K_DEV0 0x3 +#define IPL_K_DEV1 0x4 +#define IPL_K_CLK 0x5 +#define IPL_K_RT 0x6 +#define IPL_K_PERF 0x6 +#define IPL_K_PFAIL 0x6 +#define IPL_K_MCHK 0x7 + +#define IPL_K_LOW 0x0 +#define IPL_K_HIGH 0x7 + +/* +** SCB Offset Definitions: +*/ + +#define SCB_Q_FEN 0x0010 +#define SCB_Q_ACV 0x0080 +#define SCB_Q_TNV 0x0090 +#define SCB_Q_FOR 0x00A0 +#define SCB_Q_FOW 0x00B0 +#define SCB_Q_FOE 0x00C0 +#define SCB_Q_ARITH 0x0200 +#define SCB_Q_KAST 0x0240 +#define SCB_Q_EAST 0x0250 +#define SCB_Q_SAST 0x0260 +#define SCB_Q_UAST 0x0270 +#define SCB_Q_UNALIGN 0x0280 +#define SCB_Q_BPT 0x0400 +#define SCB_Q_BUGCHK 0x0410 +#define SCB_Q_OPCDEC 0x0420 +#define SCB_Q_ILLPAL 0x0430 +#define SCB_Q_TRAP 0x0440 +#define SCB_Q_CHMK 0x0480 +#define SCB_Q_CHME 0x0490 +#define SCB_Q_CHMS 0x04A0 +#define SCB_Q_CHMU 0x04B0 +#define SCB_Q_SW0 0x0500 +#define SCB_Q_SW1 0x0510 +#define SCB_Q_SW2 0x0520 +#define SCB_Q_SW3 0x0530 +#define SCB_Q_SW4 0x0540 +#define SCB_Q_SW5 0x0550 +#define SCB_Q_SW6 0x0560 +#define SCB_Q_SW7 0x0570 +#define SCB_Q_SW8 0x0580 +#define SCB_Q_SW9 0x0590 +#define SCB_Q_SW10 0x05A0 +#define SCB_Q_SW11 0x05B0 +#define SCB_Q_SW12 0x05C0 +#define SCB_Q_SW13 0x05D0 +#define SCB_Q_SW14 0x05E0 +#define SCB_Q_SW15 0x05F0 +#define SCB_Q_CLOCK 0x0600 +#define SCB_Q_INTER 0x0610 +#define SCB_Q_SYSERR 0x0620 +#define SCB_Q_PROCERR 0x0630 +#define SCB_Q_PWRFAIL 0x0640 +#define SCB_Q_PERFMON 0x0650 +#define SCB_Q_SYSMCHK 0x0660 +#define SCB_Q_PROCMCHK 0x0670 +#define SCB_Q_PASSREL 0x0680 + +/* +** Stack Frame (FRM) Offsets: +** +** There are two types of system entries for OSF/1 - those for the +** callsys CALL_PAL function and those for exceptions and interrupts. +** Both entry types use the same stack frame layout. The stack frame +** contains space for the PC, the PS, the saved GP, and the saved +** argument registers a0, a1, and a2. On entry, SP points to the +** saved PS. +*/ + +#define FRM_Q_PS 0x0000 +#define FRM_Q_PC 0x0008 +#define FRM_Q_GP 0x0010 +#define FRM_Q_A0 0x0018 +#define FRM_Q_A1 0x0020 +#define FRM_Q_A2 0x0028 + +#define FRM_K_SIZE 48 + +#define STACK_FRAME(tmp1,tmp2) \ + sll ps, 63-PS_V_CM, p7; \ + bge p7, 0f; \ + bis zero, zero, ps; \ + mtpr sp, ptUsp; \ + mfpr sp, ptKsp; \ +0: lda sp, 0-FRM_K_SIZE(sp); \ + stq tmp1, FRM_Q_PS(sp); \ + stq tmp2, FRM_Q_PC(sp); \ + stq gp, FRM_Q_GP(sp); \ + stq a0, FRM_Q_A0(sp); \ + stq a1, FRM_Q_A1(sp); \ + stq a2, FRM_Q_A2(sp) + +/* +** Halt Codes: +*/ + +#define HLT_K_RESET 0x0000 +#define HLT_K_HW_HALT 0x0001 +#define HLT_K_KSP_INVAL 0x0002 +#define HLT_K_SCBB_INVAL 0x0003 +#define HLT_K_PTBR_INVAL 0x0004 +#define HLT_K_SW_HALT 0x0005 +#define HLT_K_DBL_MCHK 0x0006 +#define HLT_K_MCHK_FROM_PAL 0x0007 + +/* +** Machine Check Codes: +*/ + +#define MCHK_K_TPERR 0x0080 +#define MCHK_K_TCPERR 0x0082 +#define MCHK_K_HERR 0x0084 +#define MCHK_K_ECC_C 0x0086 +#define MCHK_K_ECC_NC 0x0088 +#define MCHK_K_UNKNOWN 0x008A +#define MCHK_K_CACKSOFT 0x008C +#define MCHK_K_BUGCHECK 0x008E +#define MCHK_K_OS_BUGCHECK 0x0090 +#define MCHK_K_DCPERR 0x0092 +#define MCHK_K_ICPERR 0x0094 +#define MCHK_K_RETRY_IRD 0x0096 +#define MCHK_K_PROC_HERR 0x0098 + +/* +** System Machine Check Codes: +*/ + +#define MCHK_K_READ_NXM 0x0200 +#define MCHK_K_SYS_HERR 0x0202 + +/* +** Machine Check Error Status Summary (MCES) Register Format +** +** Extent Size Name Function +** ------ ---- ---- --------------------------------- +** <0> 1 MIP Machine check in progress +** <1> 1 SCE System correctable error in progress +** <2> 1 PCE Processor correctable error in progress +** <3> 1 DPC Disable PCE error reporting +** <4> 1 DSC Disable SCE error reporting +*/ + +#define MCES_V_MIP 0 +#define MCES_M_MIP (1<<MCES_V_MIP) +#define MCES_V_SCE 1 +#define MCES_M_SCE (1<<MCES_V_SCE) +#define MCES_V_PCE 2 +#define MCES_M_PCE (1<<MCES_V_PCE) +#define MCES_V_DPC 3 +#define MCES_M_DPC (1<<MCES_V_DPC) +#define MCES_V_DSC 4 +#define MCES_M_DSC (1<<MCES_V_DSC) + +#define MCES_M_ALL (MCES_M_MIP | MCES_M_SCE | MCES_M_PCE | MCES_M_DPC \ + | MCES_M_DSC) + +/* +** Who-Am-I (WHAMI) Register Format +** +** Extent Size Name Function +** ------ ---- ---- --------------------------------- +** <7:0> 8 ID Who-Am-I identifier +** <15:8> 1 SWAP Swap PALcode flag - character 'S' +*/ + +#define WHAMI_V_SWAP 8 +#define WHAMI_M_SWAP (1<<WHAMI_V_SWAP) +#define WHAMI_V_ID 0 +#define WHAMI_M_ID 0xFF + +#define WHAMI_K_SWAP 0x53 /* Character 'S' */ + +/* +** Conventional Register Usage Definitions +** +** Assembler temporary `at' is `AT' so it doesn't conflict with the +** `.set at' assembler directive. +*/ + +#define v0 $0 /* Function Return Value Register */ +#define t0 $1 /* Scratch (Temporary) Registers ... */ +#define t1 $2 +#define t2 $3 +#define t3 $4 +#define t4 $5 +#define t5 $6 +#define t6 $7 +#define t7 $8 +#define s0 $9 /* Saved (Non-Volatile) Registers ... */ +#define s1 $10 +#define s2 $11 +#define s3 $12 +#define s4 $13 +#define s5 $14 +#define fp $15 /* Frame Pointer Register, Or S6 */ +#define s6 $15 +#define a0 $16 /* Argument Registers ... */ +#define a1 $17 +#define a2 $18 +#define a3 $19 +#define a4 $20 +#define a5 $21 +#define t8 $22 /* Scratch (Temporary) Registers ... */ +#define t9 $23 +#define t10 $24 +#define t11 $25 +#define ra $26 /* Return Address Register */ +#define pv $27 /* Procedure Value Register, Or T12 */ +#define t12 $27 +#define AT $28 /* Assembler Temporary (Volatile) Register */ +#define gp $29 /* Global Pointer Register */ +#define sp $30 /* Stack Pointer Register */ +#define zero $31 /* Zero Register */ + +/* +** OSF/1 Unprivileged CALL_PAL Entry Offsets: +** +** Entry Name Offset (Hex) +** +** bpt 0080 +** bugchk 0081 +** callsys 0083 +** imb 0086 +** rdunique 009E +** wrunique 009F +** gentrap 00AA +** dbgstop 00AD +*/ + +#define UNPRIV 0x80 +#define PAL_BPT_ENTRY 0x80 +#define PAL_BUGCHK_ENTRY 0x81 +#define PAL_CALLSYS_ENTRY 0x83 +#define PAL_IMB_ENTRY 0x86 +#define PAL_RDUNIQUE_ENTRY 0x9E +#define PAL_WRUNIQUE_ENTRY 0x9F +#define PAL_GENTRAP_ENTRY 0xAA + +#if defined(KDEBUG) +#define PAL_DBGSTOP_ENTRY 0xAD +/* #define NUM_UNPRIV_CALL_PALS 10 */ +#else +/* #define NUM_UNPRIV_CALL_PALS 9 */ +#endif /* KDEBUG */ + +/* +** OSF/1 Privileged CALL_PAL Entry Offsets: +** +** Entry Name Offset (Hex) +** +** halt 0000 +** cflush 0001 +** draina 0002 +** cserve 0009 +** swppal 000A +** rdmces 0010 +** wrmces 0011 +** wrfen 002B +** wrvptptr 002D +** swpctx 0030 +** wrval 0031 +** rdval 0032 +** tbi 0033 +** wrent 0034 +** swpipl 0035 +** rdps 0036 +** wrkgp 0037 +** wrusp 0038 +** rdusp 003A +** whami 003C +** retsys 003D +** rti 003F +*/ + +#define PAL_HALT_ENTRY 0x0000 +#define PAL_CFLUSH_ENTRY 0x0001 +#define PAL_DRAINA_ENTRY 0x0002 +#define PAL_CSERVE_ENTRY 0x0009 +#define PAL_SWPPAL_ENTRY 0x000A +#define PAL_WRIPIR_ENTRY 0x000D +#define PAL_RDMCES_ENTRY 0x0010 +#define PAL_WRMCES_ENTRY 0x0011 +#define PAL_WRFEN_ENTRY 0x002B +#define PAL_WRVPTPTR_ENTRY 0x002D +#define PAL_SWPCTX_ENTRY 0x0030 +#define PAL_WRVAL_ENTRY 0x0031 +#define PAL_RDVAL_ENTRY 0x0032 +#define PAL_TBI_ENTRY 0x0033 +#define PAL_WRENT_ENTRY 0x0034 +#define PAL_SWPIPL_ENTRY 0x0035 +#define PAL_RDPS_ENTRY 0x0036 +#define PAL_WRKGP_ENTRY 0x0037 +#define PAL_WRUSP_ENTRY 0x0038 +#define PAL_RDUSP_ENTRY 0x003A +#define PAL_WHAMI_ENTRY 0x003C +#define PAL_RETSYS_ENTRY 0x003D +#define PAL_RTI_ENTRY 0x003F + +#define NUM_PRIV_CALL_PALS 23 + +#endif + diff --git a/system/alpha/h/ip.h b/system/alpha/h/ip.h deleted file mode 100644 index c4ccc5de3..000000000 --- a/system/alpha/h/ip.h +++ /dev/null @@ -1,192 +0,0 @@ -#ifndef __IP_H_LOADED -#define __IP_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: ip.h,v 1.1.1.1 1997/10/30 23:27:15 verghese Exp $ - */ - -/* - * MODULE DESCRIPTION: - * - * IP protocol interface for EB64 monitor - * - * HISTORY: - * - * $Log: ip.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:15 verghese - * current 10/29/97 - * - * Revision 1.5 1994/08/05 20:13:47 fdh - * Updated Copyright header and RCS $Id: identifier. - * - * Revision 1.4 1994/06/28 20:08:21 fdh - * Modified filenames and build precedure to fit into a FAT filesystem. - * - * Revision 1.3 1994/06/20 14:18:59 fdh - * Fixup header file preprocessor #include conditionals. - * - * Revision 1.2 1994/01/21 09:45:59 rusling - * Added #ifdef <filename>_H around the module. - * Additionally, any included files are not ifdef'd - * *before* they're included (ie address.h). - * - * Revision 1.1 1993/08/06 10:30:54 berent - * Initial revision - * - * - */ - -#include "address.h" - - -/* ip_init - initialise ip protocol for an ethernet device - * - * Argument: - * device_no - device for which IP is to be initialised. - */ -extern void ip_init(int device_no); - -/* ip_set_device_addr - tells ip a device's ip address. - * - * Arguments: - * device_no - device number - * ip - ip address - */ -extern void ip_set_device_addr(int device_no,ip_addr ip); - -/* - * Prototype for packet processing functions - * - * Arguments to packet processing functions: - * protocol_data - protocol data passed to module when protocol registered - * device_no - device on which packet was received; - * packet - packet, with IP header removed; - * size - size of packet; - * source - source IP address of packet; - * destination - IP address to which the packet was addressed; this is needed by UDP. - * frame_buffer - original buffer containing packet. - * balance_buffer- buffer returned to maintain buffer balance. - * - * DESCRIPTION: - * The packet processing functions process a received protocol packet. To avoid - * buffer shortages they are always passed the buffer containing the packet in - * frame_buffer. They must return either this buffer, or another buffer, in - * balance buffer. The ip module will never access frame_buffer after - * calling a packet processing function; and the protocol modules must not - * access the returned balance_buffer after returning from this function. - * - */ -typedef void (* ip_packet_handler)(void * protocol_data, - int device_no, - unsigned char * packet, - int size, - ip_addr source, - ip_addr destination, - unsigned char frame_buffer[ETHER_BUFFER_SIZE], - unsigned char ** balance_buffer); - -/* ip_register_protocol - registers an IP protocol to be recognised in received frames by this module - * - * Arguments: - * - * device_no - device number on which this protocol can be received - * protocol_id - protocol id to be recognised by this module - * processing_function - function to process received packets; if NULL cancels registration of protocol. - * protocol_data - arbitrary data to be passed back when a packet is received - * - * Returned value: - * TRUE - protocol registered - * FALSE - unable to register protocol - */ -extern int ip_register_protocol(int device_no, - ip_protocol_id protocol_id, - ip_packet_handler processing_function, - void * protocol_data); - -/* ip_write - sends a packet on an IP network - * - * Arguments: - * - * device_no - device on which to send the packet - * packet - pointer to data packet to be sent - * destination - destination address for packet - * protocol_id - protocol id for packet - * size - size of packet - * frame_buffer - buffer containing packet - * balance_buffer - buffer returned to maintain buffer balance - * - * Return values: - * - * TRUE - send successfull - * FALSE - Error occured - * - * DESCRIPTION: - * This function writes an ip data packet to the device To maintain the caller's - * pool of buffers the driver must give the caller an unused buffer (balance_buffer) - * in return for the buffer containing the frame to be transmitted. - * - * If the send succeeds then frame_buffer must not be accessed by the caller after this - * call. If the send can't be queued then frame_buffer will remain valid and - * the returned value of balance_buffer is undefined and must not be used. - * - */ -extern int ip_write(int device_no, - unsigned char * packet, - ip_addr destination, - ip_protocol_id protocol_id, - int size, - unsigned char frame_buffer[ETHER_BUFFER_SIZE], - unsigned char ** balance_buffer); - - -/* ip_data_offset - returns the offset at which ip data should be placed in a new ethernet frame - * - * Return value: - * Offset. - */ -extern int ip_data_offset(void); - -/* ip_get_address - gets the address that will be used as the source address of transmitted packets. - * - * Arguments: - * device_no - device number of device on which packet is to be sent. - * ip - returned ip address - * - * Note: - * This function exists so that UDP can calculate header checksums. - */ -extern void ip_get_device_address(int device_no, ip_addr ip); - -/* ip_printaddress - utility to print an ethernet address - * - * Argument: - * address - IP address to be printed - */ -extern void ip_printaddress(mac_addr address); - -#endif /* __IP_H_LOADED */ diff --git a/system/alpha/h/isa_buff.h b/system/alpha/h/isa_buff.h deleted file mode 100644 index 8ea648ac5..000000000 --- a/system/alpha/h/isa_buff.h +++ /dev/null @@ -1,72 +0,0 @@ -#ifndef __ISA_BUFFER_H_LOADED -#define __ISA_BUFFER_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: isa_buff.h,v 1.1.1.1 1997/10/30 23:27:15 verghese Exp $ - */ - -/* - * MODULE DESCRIPTION: - * - * Buffer allocator for ISA DMA buffers. Note that this buffer allocator - * does not allow buffers to be freed. - * - * HISTORY: - * - * $Log: isa_buff.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:15 verghese - * current 10/29/97 - * - * Revision 1.3 1994/08/05 20:13:47 fdh - * Updated Copyright header and RCS $Id: identifier. - * - * Revision 1.2 1994/06/20 14:18:59 fdh - * Fixup header file preprocessor #include conditionals. - * - * Revision 1.1 1993/08/06 10:31:10 berent - * Initial revision - * - * - */ - - -/* isa_buffer_init_module - initialise the module - */ -extern void isa_buffer_init_module(void); - -/* isa_buffer_alloc - allocate a region of memory accessable by ISA DMA devices - * - * Argument: - * size - number of bytes to allocate - * - * Result: - * Pointer to start of buffer - */ -extern void * isa_buffer_alloc(int size); - -#endif /* __ISA_BUFFER_H_LOADED */ diff --git a/system/alpha/h/k_extra.h b/system/alpha/h/k_extra.h deleted file mode 100644 index 2b1c40070..000000000 --- a/system/alpha/h/k_extra.h +++ /dev/null @@ -1,89 +0,0 @@ -#ifndef __KERNEL_EXTRA_H_LOADED -#define __KERNEL_EXTRA_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: k_extra.h,v 1.1.1.1 1997/10/30 23:27:16 verghese Exp $; - */ - -/* - * $Log: k_extra.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:16 verghese - * current 10/29/97 - * - * Revision 1.4 1994/08/05 20:13:47 fdh - * Updated Copyright header and RCS $Id: identifier. - * - * Revision 1.3 1994/06/28 20:08:21 fdh - * Modified filenames and build precedure to fit into a FAT filesystem. - * - * Revision 1.2 1994/06/20 14:18:59 fdh - * Fixup header file preprocessor #include conditionals. - * - * Revision 1.1 1994/03/09 12:48:33 berent - * Initial revision - * - * - * Derived from old kernel.h by splitting out the extra functions that are not part of - * the target independent debug kernel interface. - * - * Log of kernel.h,v: - * Revision 1.3 1993/10/03 00:19:49 berent - * Merge in development by Anthony Berent - * - *>> Revision 1.4 1993/10/01 15:47:00 berent - *>> Added saved_user_pc; used to avoid need for special ethernet PAL code - *>> - *>> Revision 1.3 1993/08/09 11:43:38 berent - *>> Correct return types of some functions - * - * Revision 1.2 1993/06/08 22:32:06 berent - * Changed to improve ladbx server communications - * - * Revision 1.1 1993/06/08 19:56:36 fdh - * Initial revision - * - */ - -#include "system.h" -#include "server_t.h" - -void kinitpalentry(void); - -void kstart(void); - -int kwait(void); - -void kinstall_breakpoints(void); - -void kprint_breakpoints(void); - -void kenableserver(void); - -extern address_value saved_user_pc; - -#endif /* KERNEL_EXTRA_H_LOADED */ diff --git a/system/alpha/h/kbdscan.h b/system/alpha/h/kbdscan.h deleted file mode 100644 index 5e364f448..000000000 --- a/system/alpha/h/kbdscan.h +++ /dev/null @@ -1,86 +0,0 @@ -#ifndef __KBDSCAN_H_LOADED -#define __KBDSCAN_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: kbdscan.h,v 1.1.1.1 1997/10/30 23:27:16 verghese Exp $; - */ - -/* - * $Log: kbdscan.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:16 verghese - * current 10/29/97 - * - * Revision 1.3 1994/08/05 20:13:47 fdh - * Updated Copyright header and RCS $Id: identifier. - * - * Revision 1.2 1994/06/20 14:18:59 fdh - * Fixup header file preprocessor #include conditionals. - * - * Revision 1.1 1993/06/08 19:56:14 fdh - * Initial revision - * - */ - - - - -/* Some Key Defs */ -/* Function keys */ -#define F1 (0x80|0x00) -#define F2 (0x80|0x01) -#define F3 (0x80|0x02) -#define F4 (0x80|0x03) -#define F5 (0x80|0x04) -#define F6 (0x80|0x05) -#define F7 (0x80|0x06) -#define F8 (0x80|0x07) -#define F9 (0x80|0x08) -#define F10 (0x80|0x09) -#define F11 (0x80|0x0a) -#define F12 (0x80|0x0b) - -/* Num lock affects these */ -#define END (0x80|0x0c) -#define DOWN (0x80|0x0d) -#define PGDWN (0x80|0x0e) -#define LEFT (0x80|0x0f) -#define MIDDLE (0x80|0x10) -#define RIGHT (0x80|0x11) -#define HOME (0x80|0x12) -#define UP (0x80|0x13) -#define PGUP (0x80|0x14) -#define INS (0x80|0x15) -#define DEL (0x80|0x16) - -/* Others */ -#define PRTSC (0x80|0x17) -#define PAUSE (0x80|0x18) -#define ALTDWN (0x80|0x19) -#define ALTUP (0x80|0x1a) - -#endif /* __KBDSCAN_H_LOADED */ diff --git a/system/alpha/h/kernel.h b/system/alpha/h/kernel.h deleted file mode 100644 index 1fd6f0101..000000000 --- a/system/alpha/h/kernel.h +++ /dev/null @@ -1,278 +0,0 @@ -#ifndef __KERNEL_H_LOADED -#define __KERNEL_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: kernel.h,v 1.1.1.1 1997/10/30 23:27:16 verghese Exp $; - */ - -/* - * Derived from EB64 version; history of EB64 version: - * - * $Log: kernel.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:16 verghese - * current 10/29/97 - * - * Revision 1.7 1994/08/05 20:13:47 fdh - * Updated Copyright header and RCS $Id: identifier. - * - * Revision 1.6 1994/06/28 20:08:21 fdh - * Modified filenames and build precedure to fit into a FAT filesystem. - * - * Revision 1.5 1994/06/20 14:18:59 fdh - * Fixup header file preprocessor #include conditionals. - * - * Revision 1.4 1994/03/09 12:48:33 berent - * Made NT compilable and tidied up - * - * Revision 1.4 1993/10/01 15:47:00 berent - * Added saved_user_pc; used to avoid need for special ethernet PAL code - * - * Revision 1.3 1993/08/09 11:43:38 berent - * Correct return types of some functions - * - * Revision 1.2 1993/06/08 22:32:06 berent - * Changed to improve ladbx server communications - * - * Revision 1.1 1993/06/08 19:56:36 fdh - * Initial revision - * - */ - -#include "system.h" -#include "server_t.h" - - -/* kload_implemented - check whether the kernel will load new processes. - * - * Returns TRUE if this kernel supports the loading of new processes, - * FALSE if not. - */ -extern kload_implemented(void); - -/* kload - load a new process. - * - * Arguments: - * name - file name of new process. - * argv - argument array for new process, NULL terminated. - * standardIn - file name of standard input. - * standardOut - file name of standard output. - * standardError - file name of standard error. - * loadAddress - address at which client expects process to be loaded; or - * all bits 1 if unknown. - * startAddress - address at which client expects process to start executing. - * ignored if the load address is not set. - * - * The format and interpretation of file name arguments is kernel dependent except - * in that an empty string always means use the default (if any). The - * standard input, standard output and standard error file names may be ignored by - * some kernels. Kernels will only use the load and start addresses if they have - * direct control over where programs are loaded or started. - * - * Return Value: - * TRUE if successful, FALSE if not. - */ -extern int kload(char * name, - char * argv[], - char * standardIn, - char * standardOut, - char * standardError, - address_value loadAddress, - address_value startAddress); - -/* kconnect_implemented - check whether the kernel will connect to existing processes. - * - * Returns TRUE if this kernel supports connecting to existing processes, - * FALSE if not. - */ - -extern int kconnect_implemented(void); - -/* kconnect - connect to an existing process - * - * Argument: - * pid - process id of process to which the kernel is to be connected. The interpretation - * of this value is kernel dependent. It may be ignored by kernels running - * in a non multiprocessing environment. - * - * Return Value: - * TRUE if successful, FALSE if not. - */ -extern int kconnect(ui pid); - -/* kkill_possible - checks whether this kernel can kill the current process. - * - * Return Value: - * TRUE if possible; false if not. - */ -extern int kkill_possible(void); - -/* kkill - kill the current process. - */ -extern void kkill(void); - -/* kdetach_possible - checks whether this kernel can detach from the current process - * without killing it. - * - * Return Value: - * TRUE if possible; false if not. - */ -extern int kdetach_possible(void); - -/* kdetach - detach from the current process without killing it. If possible the kernel will - * not remove any breakpoints or continue the process if it is stopped ; but - * there may be kernels on which detaching can only be implemented such that - * it does one or both of these. - */ -extern void kdetach(void); - -/* kpid - return the pid of the current process. - */ -extern ui kpid(void); - -/* kgo - run the current process until it hits a breakpoint or stops for some - * other reason. - */ -extern void kgo(void); - -/* kstop - stop the current process as soon as possible. - */ -extern void kstop(void); - -/* kaddressok - check whether an address is readable - * - * Argument: - * address - the address to be checked. - * - * Return value: - * TRUE if readable, FALSE if not. - */ -extern int kaddressok(address_value address); - -/* kcexamine - get a value from memory. - * - * Argument: - * address - the address from which the value is to be fetched. Must be - * 8 byte alligned. - * - * Return value: - * The 8 byte value at address. If there is a breakpoint within this 8 byte - * region the value returned is the value that would be at that address if the - * breakpoint were removed. - */ -extern ul kcexamine(address_value address); - - -/* kcdeposit - deposit a value in memory. - * - * Arguments: - * address - the address at which the value is to be deposited. Must be - * 8 byte alligned. - * value - the 8 byte value to be deposited. If there is a breakpoint within - * the 8 byte region the new value should not overwrite any breakpoint - * instruction; but instead should change the value that will be written - * back when any such instruction is removed. - * - * Return value: - * TRUE if successful. FALSE if the kernel was unable to deposit the data. - */ -extern int kcdeposit(address_value address, ul value); - -/* kstep - step one instruction. If there is a breakpoint at the current program counter - * the instruction that would be at that address if the breakpoint were removed is - * executed. - */ -extern void kstep(void); - -/* kpc - get the current program counter. - * - * Return value: - * current program counter. - */ -extern address_value kpc(void); - -/* ksetpc - update the program counter. - * - * Argument: - * address - new value of program counter. - */ -extern void ksetpc(address_value address); - -/* kregister - get the contents of a register - * - * Argument: - * reg - the register number. If reg is in the range 0 to 31 the function fetches the - * contents of fixed point register reg. If reg is the range 32 to 63 it - * fetches (as an 8 byte bit pattern) the contents of floating point register - * reg-32. - * - * Return value: - * The 8 byte bit pattern in the selected register. - */ -extern register_value kregister(int reg); - -/* ksetreg - writes a bit pattern to a register - * - * Arguments: - * reg - the register number, as for kregister. - * value - the 8 byte bit pattern to be written. - */ -extern void ksetreg(int reg, register_value value); - -/* kbreak - sets a breakpoint. - * - * Argument: - * address - the address at which a breakpoint is to be set. Must be 4 byte alligned. - * - * Return value: - * The result that should be sent back to the client. - */ -extern short int kbreak(address_value address); - -/* kremovebreak - sets a breakpoint. - * - * Argument: - * address - the address of the breakpoint. Must be 4 byte alligned. - * - * Return value: - * The result that should be sent back to the client. - */ -extern short int kremovebreak(address_value address); - -/* kpoll - get the state of the current process. - * - * Return value: - * PROCESS_STATE_PROCESS_RUNNING - the process is running, - * PROCESS_STATE_PROCESS_AT_BREAK - the process has stopped at a breakpoint, - * PROCESS_STATE_PROCESS_SUSPENDED - the process has stopped elsewhere, - * PROCESS_STATE_PROCESS_TERMINATED - the process no longer exists, - * PROCESS_STATE_PROCESS_LOADING - the process is loading, - * PROCESS_STATE_LOAD_FAILED - the process failed to load. - */ -extern int kpoll(void); - -#endif /* __KERNEL_H_LOADED */ diff --git a/system/alpha/h/ladbx.h b/system/alpha/h/ladbx.h deleted file mode 100644 index 6375aed9d..000000000 --- a/system/alpha/h/ladbx.h +++ /dev/null @@ -1,74 +0,0 @@ -#ifndef __LADBX_H_LOADED -#define __LADBX_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: ladbx.h,v 1.1.1.1 1997/10/30 23:27:16 verghese Exp $; - */ - -/* - * $Log: ladbx.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:16 verghese - * current 10/29/97 - * - * Revision 1.5 1994/08/05 20:13:47 fdh - * Updated Copyright header and RCS $Id: identifier. - * - * Revision 1.4 1994/06/30 09:39:18 berent - * Added kwrmces to write the machine check error summary register - * - * Revision 1.3 1994/06/28 20:08:21 fdh - * Modified filenames and build precedure to fit into a FAT filesystem. - * - * Revision 1.2 1994/06/20 14:18:59 fdh - * Fixup header file preprocessor #include conditionals. - * - * Revision 1.1 1994/06/20 12:54:55 fdh - * Initial revision - * - */ - -#include "ladbxapp.h" -#include "kernel.h" -#include "k_extra.h" -#include "bptable.h" - -/* /ladbx/kutil.s */ -extern void kutilib(void); -extern void kwrmces(ul); - -/* /ladbx/readloop.c */ -extern void enable_ladbx_msg(void); - -/* /ladbx/kernel.c */ -extern void kinitpalentry(void); -extern void kenableserver(void); -extern void kprint_breakpoints(void); -extern void kgo(void); -extern void kstep(void); - -#endif /* __LADBX_H_LOADED */ diff --git a/system/alpha/h/ladbxapp.h b/system/alpha/h/ladbxapp.h deleted file mode 100644 index ca942382c..000000000 --- a/system/alpha/h/ladbxapp.h +++ /dev/null @@ -1,56 +0,0 @@ -#ifndef __LADBX_APP_INTERFACE_H_LOADED -#define __LADBX_APP_INTERFACE_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: ladbxapp.h,v 1.1.1.1 1997/10/30 23:27:16 verghese Exp $; - */ - -/* - * This module provides the interface between the ladebug server and the - * application. - * - * $Log: ladbxapp.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:16 verghese - * current 10/29/97 - * - * Revision 1.3 1994/08/05 20:13:47 fdh - * Updated Copyright header and RCS $Id: identifier. - * - * Revision 1.2 1994/06/20 14:18:59 fdh - * Fixup header file preprocessor #include conditionals. - * - * Revision 1.1 1993/10/01 15:49:15 berent - * Initial revision - * - */ - -/* The following address is known to both the application and the monitor. - * If it changes both must be rebuilt */ -#define POLL_DBM_PTR_ADDR (0x3ff0) - -#endif /* __LADBX_APP_INTERFACE_H_LOADED */ diff --git a/system/alpha/h/ledcodes.h b/system/alpha/h/ledcodes.h deleted file mode 100644 index e4bc58242..000000000 --- a/system/alpha/h/ledcodes.h +++ /dev/null @@ -1,62 +0,0 @@ -#ifndef __LEDCODES_H_LOADED -#define __LEDCODES_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: ledcodes.h,v 1.1.1.1 1997/10/30 23:27:16 verghese Exp $; - */ - -/* - * $Log: ledcodes.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:16 verghese - * current 10/29/97 - * - * Revision 1.2 1994/11/28 19:39:44 fdh - * Added Startup LED codes. - * - * Revision 1.1 1994/11/08 21:42:29 fdh - * Initial revision - * - */ - -#define led_k_ksp_initialized 0xFF /* Kernel Stack Pointer Initialized */ -#define led_k_sysdata_inited 0xFE /* System Data Structure Initialized */ -#define led_k_init_IO 0xFD /* About to complete IO bus initialization */ -#define led_k_IO_inited 0xFC /* IO bus initialization complete */ -#define led_k_uart_inited 0xFB /* UARTs initialized */ - -/* - * Flash ROM Utility LED codes. - */ -#define led_k_flash_entered 0xB0 /* Flash Utility Entered */ -#define led_k_flash_found 0xB2 /* A FLASH ROM was found. */ -#define led_k_erase_flash 0xB3 /* About to erase flash. */ -#define led_k_write_flash 0xB4 /* About to write flash. */ -#define led_k_verify_flash 0xB5 /* About to verify flash. */ -#define led_k_flash_exit 0xBF /* Program finished. */ - -#endif /* __LEDCODES_H_LOADED */ diff --git a/system/alpha/h/libc.h b/system/alpha/h/libc.h deleted file mode 100644 index 52a35f915..000000000 --- a/system/alpha/h/libc.h +++ /dev/null @@ -1,204 +0,0 @@ -#ifndef __LIBC_H_LOADED -#define __LIBC_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: libc.h,v 1.1.1.1 1997/10/30 23:27:16 verghese Exp $; - * - * $Log: libc.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:16 verghese - * current 10/29/97 - * - * Revision 1.2 1995/02/27 19:21:55 fdh - * Change the name of the Ctype Macros. - * - * Revision 1.1 1995/02/14 18:53:21 fdh - * Initial revision - * - */ - -#define _ISMACRO(c,x) ((int) (_CTYPES[c] & (x))) - -#define _isalnum(c) _ISMACRO(c,_ISALNUM_) -#define _isalpha(c) _ISMACRO(c,_ISALPHA_) -#define _isascii(c) _ISMACRO(c,_ISASCII_) -#define _iscntrl(c) _ISMACRO(c,_ISCNTRL_) -#define _isdigit(c) _ISMACRO(c,_ISDIGIT_) -#define _isgraph(c) _ISMACRO(c,_ISGRAPH_) -#define _islower(c) _ISMACRO(c,_ISLOWER_) -#define _isprint(c) _ISMACRO(c,_ISPRINT_) -#define _ispunct(c) _ISMACRO(c,_ISPUNCT_) -#define _isspace(c) _ISMACRO(c,_ISSPACE_) -#define _isupper(c) _ISMACRO(c,_ISUPPER_) -#define _isxdigit(c) _ISMACRO(c,_ISXDIGIT_) - -#define _ISALNUM_ 0x0001 -#define _ISALPHA_ 0x0002 -#define _ISASCII_ 0x0004 -#define _ISCNTRL_ 0x0008 -#define _ISDIGIT_ 0x0010 -#define _ISGRAPH_ 0x0020 -#define _ISLOWER_ 0x0040 -#define _ISPRINT_ 0x0080 -#define _ISPUNCT_ 0x0100 -#define _ISSPACE_ 0x0200 -#define _ISUPPER_ 0x0400 -#define _ISXDIGIT_ 0x0800 - -const uw _CTYPES[] = -{ -/* 0 '\000'*/ _ISASCII_|_ISCNTRL_, -/* 1 '\001'*/ _ISASCII_|_ISCNTRL_, -/* 2 '\002'*/ _ISASCII_|_ISCNTRL_, -/* 3 '\003'*/ _ISASCII_|_ISCNTRL_, -/* 4 '\004'*/ _ISASCII_|_ISCNTRL_, -/* 5 '\005'*/ _ISASCII_|_ISCNTRL_, -/* 6 '\006'*/ _ISASCII_|_ISCNTRL_, -/* 7 '\007'*/ _ISASCII_|_ISCNTRL_, -/* 8 '\010'*/ _ISASCII_|_ISCNTRL_, -/* 9 '\011'*/ _ISASCII_|_ISCNTRL_|_ISSPACE_, -/* 10 '\012'*/ _ISASCII_|_ISCNTRL_|_ISSPACE_, -/* 11 '\013'*/ _ISASCII_|_ISCNTRL_|_ISSPACE_, -/* 12 '\014'*/ _ISASCII_|_ISCNTRL_|_ISSPACE_, -/* 13 '\015'*/ _ISASCII_|_ISCNTRL_|_ISSPACE_, -/* 14 '\016'*/ _ISASCII_|_ISCNTRL_, -/* 15 '\017'*/ _ISASCII_|_ISCNTRL_, -/* 16 '\020'*/ _ISASCII_|_ISCNTRL_, -/* 17 '\021'*/ _ISASCII_|_ISCNTRL_, -/* 18 '\022'*/ _ISASCII_|_ISCNTRL_, -/* 19 '\023'*/ _ISASCII_|_ISCNTRL_, -/* 20 '\024'*/ _ISASCII_|_ISCNTRL_, -/* 21 '\025'*/ _ISASCII_|_ISCNTRL_, -/* 22 '\026'*/ _ISASCII_|_ISCNTRL_, -/* 23 '\027'*/ _ISASCII_|_ISCNTRL_, -/* 24 '\030'*/ _ISASCII_|_ISCNTRL_, -/* 25 '\031'*/ _ISASCII_|_ISCNTRL_, -/* 26 '\032'*/ _ISASCII_|_ISCNTRL_, -/* 27 '\033'*/ _ISASCII_|_ISCNTRL_, -/* 28 '\034'*/ _ISASCII_|_ISCNTRL_, -/* 29 '\035'*/ _ISASCII_|_ISCNTRL_, -/* 30 '\036'*/ _ISASCII_|_ISCNTRL_, -/* 31 '\037'*/ _ISASCII_|_ISCNTRL_, -/* 32 '\040'*/ _ISASCII_|_ISPRINT_|_ISSPACE_, -/* 33 '!'*/ _ISASCII_|_ISGRAPH_|_ISPRINT_|_ISPUNCT_, -/* 34 '"'*/ _ISASCII_|_ISGRAPH_|_ISPRINT_|_ISPUNCT_, -/* 35 '#'*/ _ISASCII_|_ISGRAPH_|_ISPRINT_|_ISPUNCT_, -/* 36 '$'*/ _ISASCII_|_ISGRAPH_|_ISPRINT_|_ISPUNCT_, -/* 37 '%'*/ _ISASCII_|_ISGRAPH_|_ISPRINT_|_ISPUNCT_, -/* 38 '&'*/ _ISASCII_|_ISGRAPH_|_ISPRINT_|_ISPUNCT_, -/* 39 '''*/ _ISASCII_|_ISGRAPH_|_ISPRINT_|_ISPUNCT_, -/* 40 '('*/ _ISASCII_|_ISGRAPH_|_ISPRINT_|_ISPUNCT_, -/* 41 ')'*/ _ISASCII_|_ISGRAPH_|_ISPRINT_|_ISPUNCT_, -/* 42 '*'*/ _ISASCII_|_ISGRAPH_|_ISPRINT_|_ISPUNCT_, -/* 43 '+'*/ _ISASCII_|_ISGRAPH_|_ISPRINT_|_ISPUNCT_, -/* 44 ','*/ _ISASCII_|_ISGRAPH_|_ISPRINT_|_ISPUNCT_, -/* 45 '-'*/ _ISASCII_|_ISGRAPH_|_ISPRINT_|_ISPUNCT_, -/* 46 '.'*/ _ISASCII_|_ISGRAPH_|_ISPRINT_|_ISPUNCT_, -/* 47 '/'*/ _ISASCII_|_ISGRAPH_|_ISPRINT_|_ISPUNCT_, -/* 48 '0'*/ _ISALNUM_|_ISASCII_|_ISDIGIT_|_ISGRAPH_|_ISPRINT_|_ISXDIGIT_, -/* 49 '1'*/ _ISALNUM_|_ISASCII_|_ISDIGIT_|_ISGRAPH_|_ISPRINT_|_ISXDIGIT_, -/* 50 '2'*/ _ISALNUM_|_ISASCII_|_ISDIGIT_|_ISGRAPH_|_ISPRINT_|_ISXDIGIT_, -/* 51 '3'*/ _ISALNUM_|_ISASCII_|_ISDIGIT_|_ISGRAPH_|_ISPRINT_|_ISXDIGIT_, -/* 52 '4'*/ _ISALNUM_|_ISASCII_|_ISDIGIT_|_ISGRAPH_|_ISPRINT_|_ISXDIGIT_, -/* 53 '5'*/ _ISALNUM_|_ISASCII_|_ISDIGIT_|_ISGRAPH_|_ISPRINT_|_ISXDIGIT_, -/* 54 '6'*/ _ISALNUM_|_ISASCII_|_ISDIGIT_|_ISGRAPH_|_ISPRINT_|_ISXDIGIT_, -/* 55 '7'*/ _ISALNUM_|_ISASCII_|_ISDIGIT_|_ISGRAPH_|_ISPRINT_|_ISXDIGIT_, -/* 56 '8'*/ _ISALNUM_|_ISASCII_|_ISDIGIT_|_ISGRAPH_|_ISPRINT_|_ISXDIGIT_, -/* 57 '9'*/ _ISALNUM_|_ISASCII_|_ISDIGIT_|_ISGRAPH_|_ISPRINT_|_ISXDIGIT_, -/* 58 ':'*/ _ISASCII_|_ISGRAPH_|_ISPRINT_|_ISPUNCT_, -/* 59 ';'*/ _ISASCII_|_ISGRAPH_|_ISPRINT_|_ISPUNCT_, -/* 60 '<'*/ _ISASCII_|_ISGRAPH_|_ISPRINT_|_ISPUNCT_, -/* 61 '='*/ _ISASCII_|_ISGRAPH_|_ISPRINT_|_ISPUNCT_, -/* 62 '>'*/ _ISASCII_|_ISGRAPH_|_ISPRINT_|_ISPUNCT_, -/* 63 '?'*/ _ISASCII_|_ISGRAPH_|_ISPRINT_|_ISPUNCT_, -/* 64 '@'*/ _ISASCII_|_ISGRAPH_|_ISPRINT_|_ISPUNCT_, -/* 65 'A'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISPRINT_|_ISUPPER_|_ISXDIGIT_, -/* 66 'B'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISPRINT_|_ISUPPER_|_ISXDIGIT_, -/* 67 'C'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISPRINT_|_ISUPPER_|_ISXDIGIT_, -/* 68 'D'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISPRINT_|_ISUPPER_|_ISXDIGIT_, -/* 69 'E'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISPRINT_|_ISUPPER_|_ISXDIGIT_, -/* 70 'F'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISPRINT_|_ISUPPER_|_ISXDIGIT_, -/* 71 'G'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISPRINT_|_ISUPPER_, -/* 72 'H'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISPRINT_|_ISUPPER_, -/* 73 'I'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISPRINT_|_ISUPPER_, -/* 74 'J'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISPRINT_|_ISUPPER_, -/* 75 'K'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISPRINT_|_ISUPPER_, -/* 76 'L'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISPRINT_|_ISUPPER_, -/* 77 'M'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISPRINT_|_ISUPPER_, -/* 78 'N'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISPRINT_|_ISUPPER_, -/* 79 'O'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISPRINT_|_ISUPPER_, -/* 80 'P'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISPRINT_|_ISUPPER_, -/* 81 'Q'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISPRINT_|_ISUPPER_, -/* 82 'R'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISPRINT_|_ISUPPER_, -/* 83 'S'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISPRINT_|_ISUPPER_, -/* 84 'T'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISPRINT_|_ISUPPER_, -/* 85 'U'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISPRINT_|_ISUPPER_, -/* 86 'V'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISPRINT_|_ISUPPER_, -/* 87 'W'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISPRINT_|_ISUPPER_, -/* 88 'X'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISPRINT_|_ISUPPER_, -/* 89 'Y'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISPRINT_|_ISUPPER_, -/* 90 'Z'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISPRINT_|_ISUPPER_, -/* 91 '['*/ _ISASCII_|_ISGRAPH_|_ISPRINT_|_ISPUNCT_, -/* 92 '\'*/ _ISASCII_|_ISGRAPH_|_ISPRINT_|_ISPUNCT_, -/* 93 ']'*/ _ISASCII_|_ISGRAPH_|_ISPRINT_|_ISPUNCT_, -/* 94 '^'*/ _ISASCII_|_ISGRAPH_|_ISPRINT_|_ISPUNCT_, -/* 95 '_'*/ _ISASCII_|_ISGRAPH_|_ISPRINT_|_ISPUNCT_, -/* 96 '`'*/ _ISASCII_|_ISGRAPH_|_ISPRINT_|_ISPUNCT_, -/* 97 'a'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISLOWER_|_ISPRINT_|_ISXDIGIT_, -/* 98 'b'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISLOWER_|_ISPRINT_|_ISXDIGIT_, -/* 99 'c'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISLOWER_|_ISPRINT_|_ISXDIGIT_, -/* 100 'd'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISLOWER_|_ISPRINT_|_ISXDIGIT_, -/* 101 'e'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISLOWER_|_ISPRINT_|_ISXDIGIT_, -/* 102 'f'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISLOWER_|_ISPRINT_|_ISXDIGIT_, -/* 103 'g'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISLOWER_|_ISPRINT_, -/* 104 'h'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISLOWER_|_ISPRINT_, -/* 105 'i'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISLOWER_|_ISPRINT_, -/* 106 'j'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISLOWER_|_ISPRINT_, -/* 107 'k'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISLOWER_|_ISPRINT_, -/* 108 'l'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISLOWER_|_ISPRINT_, -/* 109 'm'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISLOWER_|_ISPRINT_, -/* 110 'n'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISLOWER_|_ISPRINT_, -/* 111 'o'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISLOWER_|_ISPRINT_, -/* 112 'p'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISLOWER_|_ISPRINT_, -/* 113 'q'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISLOWER_|_ISPRINT_, -/* 114 'r'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISLOWER_|_ISPRINT_, -/* 115 's'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISLOWER_|_ISPRINT_, -/* 116 't'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISLOWER_|_ISPRINT_, -/* 117 'u'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISLOWER_|_ISPRINT_, -/* 118 'v'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISLOWER_|_ISPRINT_, -/* 119 'w'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISLOWER_|_ISPRINT_, -/* 120 'x'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISLOWER_|_ISPRINT_, -/* 121 'y'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISLOWER_|_ISPRINT_, -/* 122 'z'*/ _ISALNUM_|_ISALPHA_|_ISASCII_|_ISGRAPH_|_ISLOWER_|_ISPRINT_, -/* 123 '{'*/ _ISASCII_|_ISGRAPH_|_ISPRINT_|_ISPUNCT_, -/* 124 '|'*/ _ISASCII_|_ISGRAPH_|_ISPRINT_|_ISPUNCT_, -/* 125 '}'*/ _ISASCII_|_ISGRAPH_|_ISPRINT_|_ISPUNCT_, -/* 126 '~'*/ _ISASCII_|_ISGRAPH_|_ISPRINT_|_ISPUNCT_, -/* 127 '\177'*/ _ISASCII_|_ISCNTRL_ -}; - -#endif /* __LIBC_H_LOADED */ diff --git a/system/alpha/h/local.h b/system/alpha/h/local.h deleted file mode 100644 index 57915278f..000000000 --- a/system/alpha/h/local.h +++ /dev/null @@ -1,58 +0,0 @@ -#ifndef __LOCAL_H_LOADED -#define __LOCAL_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: local.h,v 1.1.1.1 1997/10/30 23:27:16 verghese Exp $; - */ - -/* - * $Log: local.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:16 verghese - * current 10/29/97 - * - * Revision 1.1 1995/02/10 02:23:49 fdh - * Initial revision - * - */ - -/* - * Source files that are common between the ebfw source - * tree and the ebtools source tree could have inherent - * conflicts in their requirements for libraries, definitions, - * etc. The basic difference is that ebtools are built - * to run natively with an operating system where the ebfw - * tree is built to run in a freestanding environment on, - * typically, an evaluation board target. Therefore, this - * file is used to provide the proper environment for building - * those common files in the ebfw source tree. - */ - -#include "lib.h" -#include "system.h" - -#endif /* __LOCAL_H_LOADED */ diff --git a/system/alpha/h/mem.h b/system/alpha/h/mem.h deleted file mode 100644 index 6d71b54c8..000000000 --- a/system/alpha/h/mem.h +++ /dev/null @@ -1,54 +0,0 @@ -#ifndef __MEM_H_LOADED -#define __MEM_H_LOADED - -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: mem.h,v 1.1.1.1 1997/10/30 23:27:16 verghese Exp $; - */ - -/* - * $Log: mem.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:16 verghese - * current 10/29/97 - * - * Revision 1.2 1994/08/05 20:13:47 fdh - * Updated Copyright header and RCS $Id: identifier. - * - * Revision 1.1 1994/07/21 18:11:01 fdh - * Initial revision - * - */ - -/* - * Per evaluation board include files - */ -#include "eb64mem.h" -#include "eb66mem.h" -#include "eb64pmem.h" - -#endif /* __MEM_H_LOADED */ diff --git a/system/alpha/h/mon.h b/system/alpha/h/mon.h deleted file mode 100644 index 3611de57f..000000000 --- a/system/alpha/h/mon.h +++ /dev/null @@ -1,158 +0,0 @@ -#ifndef __MON_H_LOADED -#define __MON_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: mon.h,v 1.1.1.1 1997/10/30 23:27:16 verghese Exp $; - */ - -/* - * $Log: mon.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:16 verghese - * current 10/29/97 - * - * Revision 1.1 1995/11/30 18:01:05 berc - * Initial revision - * - * Revision 1.15 1995/02/23 21:49:05 fdh - * Added prototype for CompareMem(). - * - * Revision 1.14 1994/11/08 21:43:55 fdh - * Added include for lib.h - * - * Revision 1.13 1994/08/05 20:13:47 fdh - * Updated Copyright header and RCS $Id: identifier. - * - * Revision 1.12 1994/06/23 13:43:18 rusling - * Fixed up WNT compiler warnings. - * - * Revision 1.11 1994/06/20 14:18:59 fdh - * Fixup header file preprocessor #include conditionals. - * - * Revision 1.10 1994/06/17 19:34:01 fdh - * Clean-up... - * - * Revision 1.9 1994/06/13 15:15:03 rusling - * Added more function prototypes. - * - * Revision 1.8 1994/06/03 20:15:43 fdh - * Removed lib.h include and declaration for memtest. - * - * Revision 1.7 1994/04/03 00:35:49 fdh - * Modified PrintMem() prototype. - * - * Revision 1.6 1994/04/01 22:41:46 fdh - * Removed obsoleted global variable. - * - * Revision 1.5 1994/03/16 00:12:01 fdh - * Added some prototypes... - * - * Revision 1.4 1994/03/13 14:37:45 fdh - * Modified memtest prototype. - * - * Revision 1.3 1994/01/19 10:22:28 rusling - * Ported to ALpha Windows NT. - * - * Revision 1.2 1993/10/02 23:37:53 berent - * Merge in development by Anthony Berent - * - *>> Revision 1.2 1993/08/06 10:45:27 berent - *>> Added MONITOR_ETHER_DEVICE constant. This defines which ethernet device the - *>> monitor uses. - * - * Revision 1.1 1993/06/08 19:56:15 fdh - * Initial revision - * - */ - -/* definitions for basic things */ - -#include "system.h" -#include "lib.h" - -extern ul bootadr; - -/* some constants */ -#define RDFILE 0 -#define VERIFY 1 -#define MONITOR_ETHER_DEVICE 0 /* Ethernet port number to be used by monitor */ - -/*:::::::::::::: -cmd.c -::::::::::::::*/ -extern void user_main(void); -extern int main(void); - -/*:::::::::::::: -crt.c -::::::::::::::*/ -extern void exit(void); - -/*:::::::::::::: -dis.c -::::::::::::::*/ -extern void dis(int argc , ul first , ul last); - -/*:::::::::::::: -ffexec.c -::::::::::::::*/ -extern void PutDotChar(register char c); -extern void CallIt(int (* adr)(int argc, ul val1, ul val2, ul val3, ul val4) , - int argc , ul val1 , ul val2 , ul val3 , ul val4); -extern void ExecuteProgram(int (* place)(void)); -extern ul CurrentDefault(void); -extern void PrintMem(int size , ul first , ul last , ul iterations , int silent, int virtual); -extern void CompareMem(ul first, ul last, ul copy); -extern void ChecksumMem(ul first , ul last); -extern void ChangeMem(int size , ul place, int virtual); -extern void FillMem(ul first , ul last , ui value); -extern void ctty(int x); -extern void tip(int port); -extern void PrintVersion(void); -extern void StackTrace(void); -extern void jToPal(ul bootadr); -extern ul csrv(ul data , ul address , int select); -extern int get_bootadr(void); - -/*:::::::::::::: -ffsrec.c -::::::::::::::*/ -extern void GetRecord(int port); -extern int Download(void); -extern ui GetHex1(void); -extern ui GetHex2(ui in); -extern ui GetHex4(ui in); -extern void GetData(void); -extern void CheckChecksum(void); - -/*:::::::::::::: -pReg.c -::::::::::::::*/ -extern void printReg(ul * register_array , int group); -extern void changeReg(ul * register_array , int group , int index , ul data); - -#endif /* __MON_H_LOADED */ diff --git a/system/alpha/h/net_buff.h b/system/alpha/h/net_buff.h deleted file mode 100644 index cb86203cd..000000000 --- a/system/alpha/h/net_buff.h +++ /dev/null @@ -1,75 +0,0 @@ -#ifndef __NET_BUFFER_H_LOADED -#define __NET_BUFFER_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: net_buff.h,v 1.1.1.1 1997/10/30 23:27:16 verghese Exp $ - */ - -/* - * MODULE DESCRIPTION: - * - * Buffer allocator for ISA DMA buffers. Note that this buffer allocator - * does not allow buffers to be freed. - * - * HISTORY: - * - * $Log: net_buff.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:16 verghese - * current 10/29/97 - * - * Revision 1.3 1994/08/05 20:13:47 fdh - * Updated Copyright header and RCS $Id: identifier. - * - * Revision 1.2 1994/06/20 14:18:59 fdh - * Fixup header file preprocessor #include conditionals. - * - * Revision 1.1 1993/11/30 10:15:36 rusling - * Initial revision - * - * Revision 1.1 1993/08/06 10:31:10 berent - * Initial revision - * - * - */ - -/* net_buffer_init_module - initialise the module - */ -extern void net_buffer_init_module(void); - -/* net_buffer_alloc - allocate a region of memory accessable by - * network DMA devices - * - * Argument: - * size - number of bytes to allocate - * - * Result: - * Pointer to start of buffer - */ -extern void * net_buffer_alloc(int size); - -#endif /* __NET_BUFFER_H_LOADED */ diff --git a/system/alpha/h/netman.h b/system/alpha/h/netman.h deleted file mode 100644 index 32d0bb934..000000000 --- a/system/alpha/h/netman.h +++ /dev/null @@ -1,79 +0,0 @@ -#ifndef __NETMAN_H_LOADED -#define __NETMAN_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* "$Id: netman.h,v 1.1.1.1 1997/10/30 23:27:16 verghese Exp $" */ - -/* - * This module provides functions for selecting which ethernet device is used and - * for initialising it when neccessary. - * - * $Log: netman.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:16 verghese - * current 10/29/97 - * - * Revision 1.3 1994/08/05 20:13:47 fdh - * Updated Copyright header and RCS $Id: identifier. - * - * Revision 1.2 1994/06/20 14:18:59 fdh - * Fixup header file preprocessor #include conditionals. - * - * Revision 1.1 1993/08/11 10:18:33 berent - * Initial revision - * - */ - -extern int monitor_ether_device; - -/* netman_setup - initialise the networking modules and register the devices - */ -extern void netman_setup(void); - -/* netman_set_monitor_device - set up the device to be used by the monitor - * - * Argument: - * device_no - The monitor device number. - * - * Return value: - * TRUE - successful - * FALSE - bad device number - */ -extern int netman_set_monitor_device(int device_no); - -/* netman_start_monitor_device - start the monitor device and all protocol handlers for it - */ -extern void netman_start_monitor_device(void); - -/* netman_monitor_device_started - tells other modules whether the monitor device has been started - * - * Return value: - * TRUE - it has been initialised before - * FALSE - it has never been initialised - */ -extern int netman_monitor_device_started(void); - -#endif /* __NETMAN_H_LOADED */ diff --git a/system/alpha/h/paldefs.h b/system/alpha/h/paldefs.h deleted file mode 100644 index 0d39c973a..000000000 --- a/system/alpha/h/paldefs.h +++ /dev/null @@ -1,76 +0,0 @@ -#ifndef __PALDEFS_H_LOADED -#define __PALDEFS_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: paldefs.h,v 1.1.1.1 1997/10/30 23:27:16 verghese Exp $; - */ - -/* - * $Log: paldefs.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:16 verghese - * current 10/29/97 - * - * Revision 1.1 1995/02/24 15:54:10 fdh - * Initial revision - * - */ - -#define PAL_halt 0x0000 -#define PAL_cflush 0x0001 -#define PAL_draina 0x0002 -#define PAL_cobratt 0x0009 -#define PAL_ipir 0x000d -#define PAL_mtpr_mces 0x0011 -#define PAL_wrfen 0x002b -#define PAL_wrvptptr 0x002d -#define PAL_jtopal 0x002e -#define PAL_swpctx 0x0030 -#define PAL_wrval 0x0031 -#define PAL_rdval 0x0032 -#define PAL_tbi 0x0033 -#define PAL_wrent 0x0034 -#define PAL_swpipl 0x0035 -#define PAL_rdps 0x0036 -#define PAL_wrkgp 0x0037 -#define PAL_wrusp 0x0038 -#define PAL_wrperfmon 0x0039 -#define PAL_rdusp 0x003a -#define PAL_whami 0x003c -#define PAL_rtsys 0x003d -#define PAL_rti 0x003f -#define PAL_bpt 0x0080 -#define PAL_bugchk 0x0081 -#define PAL_chmk 0x0083 -#define PAL_callsys 0x0083 -#define PAL_imb 0x0086 -#define PAL_rduniq 0x009e -#define PAL_wruniq 0x009f -#define PAL_gentrap 0x00aa -#define PAL_nphalt 0x00be - -#endif /* __PALDEFS_H_LOADED */ diff --git a/system/alpha/h/pci.h b/system/alpha/h/pci.h deleted file mode 100644 index 17bae06d8..000000000 --- a/system/alpha/h/pci.h +++ /dev/null @@ -1,203 +0,0 @@ -#ifndef __PCI_H_LOADED -#define __PCI_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: - * - * This file contains all of the PCI specific definitions required for - * the PCI bus support within the debug monitor. - */ - -/* - * $Log: pci.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:17 verghese - * current 10/29/97 - * - * Revision 1.1 1996/04/15 16:26:54 berc - * Initial revision - * - * Revision 1.11 1994/11/01 11:30:18 rusling - * Added PCI-PCI bridge support. - * - * Revision 1.10 1994/08/05 20:13:47 fdh - * Updated Copyright header and RCS $Id: identifier. - * - * $Log: pci.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:17 verghese - * current 10/29/97 - * - * Revision 1.1 1996/04/15 16:26:54 berc - * Initial revision - * - * Revision 1.11 1994/11/01 11:30:18 rusling - * Added PCI-PCI bridge support. - * - * Revision 1.9 1994/06/20 14:18:59 fdh - * Fixup header file preprocessor #include conditionals. - * - * Revision 1.8 1994/06/19 15:48:04 fdh - * Changed PCI_H to __PCI_H_LOADED - * - * Revision 1.7 1994/06/17 19:34:01 fdh - * Clean-up... - * - * Revision 1.6 1994/01/19 10:22:28 rusling - * Ported to ALpha Windows NT. - * - * Revision 1.5 1993/11/29 14:58:42 rusling - * Added PCI address checking and conversion routines, - * PCIMapAddress() and PCIValidAddress(). - * - * Revision 1.4 1993/11/24 15:23:29 rusling - * Added PCI_CFG_REG_VENDOR_DEVICE for offset to - * first longword of the PCI configuration header. - * - * Revision 1.3 1993/11/23 10:43:50 rusling - * Remove per system information. - * - * Revision 1.2 1993/11/22 13:17:13 rusling - * Merged with PCI/21040 changes. - * - * Revision 1.1 1993/11/22 12:16:56 rusling - * Initial revision - * - * - */ - -#ifdef NEEDPCI - - -/* - * Define the PCI device data structure. - */ -typedef struct PCIDevice { - struct PCIBus *parent; /* parent bus */ - struct PCIDevice *next; /* in device chain */ - struct PCIDevice *sibling; /* for this bus */ - ui slot; - uw vendor; - uw device; - ui class; - - ui PCI_IO_Reg; - ui PCI_IO_Base; - ui PCI_IO_Size; - ui PCI_Mem_Reg; - ui PCI_Mem_Base; - ui PCI_Mem_Size; - - void (*print)(struct PCIDevice *device); - struct { - ui IO : 1; - ui MEM : 1; - ui bridge : 1; - ui allocated : 1; - } flags; -} PCIDevice_t; - -typedef struct PCIBus { - struct PCIBus *parent; - struct PCIBus *next; - struct PCIDevice *bridge; - struct PCIDevice *devices; - struct PCIBus *children; - - ui PCI_IO_Reg; - ui PCI_IO_Base; - ui PCI_IO_Size; - ui PCI_Mem_Reg; - ui PCI_Mem_Base; - ui PCI_Mem_Size; - - unsigned char number; - unsigned char primary; - unsigned char secondary; - unsigned char subordinate; -} PCIBus_t; - - -/* - * Define some macros for getting at fields in the - * PCIDevice_t and PCIBus_t typedefs. - */ -#define _PCI_IO_Base(device) (device)->PCI_IO_Base -#define _PCI_IO_Size(device) (device)->PCI_IO_Size -#define _PCI_Mem_Base(device) (device)->PCI_Mem_Base -#define _PCI_Mem_Size(device) (device)->PCI_Mem_Size -#define _PCI_Slot(device) (device)->slot -#define _PCI_Print(device) (device)->print -#define _PCI_Bus(device) (device)->parent->number - -/* - * Declare some maximums. - */ -#define PCI_MAX_DEVICES 6 /* bits 31:11 of type 0 */ -#define PCI_21050_MAX_DEVICES 16 /* bits 14:11 of type 1 */ -#define PCI_MAX_BRIDGES 6 - -/* - * The PCI configuration registers. - */ -#define PCI_CFG_REG_VENDOR_DEVICE 0x0 -#define PCI_CFG_REG_STATUS_COMMAND 0x4 - /* LONG */ -#define PCI_CFG_REG_REVISION_ID 0x8 - /* BYTE */ -#define PCI_CFG_REG_CLASS_CODE 0x9 -#define PCI_CFG_REG_LATENCY_TIMER 0xD - /* BYTE */ -#define PCI_CFG_REG_BAR0 0x10 - /* Long */ -#define PCI_CFG_REG_BRIDGE_PRIMARY 0x18 -#define PCI_CFG_REG_BRIDGE_SECONDARY 0x19 -#define PCI_CFG_REG_BRIDGE_SUBORDINATE 0x1a - -#define PCI_CFG_REG_EROM_BASE 0x30 - /* Long */ - -/* - * PCI Vendors and devices. - */ -#define DIGITAL 0x1011 -#define DECCHIP_21040 0x0002 -#define DECCHIP_21030 0x0004 - -#define PCI_BRIDGE_CLASS 0x060400 -/* - * Declare all of the externally visible routines in pci.c - */ -extern void PCIShow(void); -extern ui PCIValidAddress(ub * address); -extern ui PCIMapAddress(ub * address); -extern void PCIInit(void); -extern PCIDevice_t *PCIDeviceFind(uw vendor, uw device); -extern PCIDevice_t *PCIDeviceFindNext(PCIDevice_t *device); -extern void PCISetDeviceConfig(PCIDevice_t *device); - -#endif /* NEEDPCI */ -#endif /* __PCI_H_LOADED */ diff --git a/system/alpha/h/platform.h b/system/alpha/h/platform.h new file mode 100644 index 000000000..a7777d941 --- /dev/null +++ b/system/alpha/h/platform.h @@ -0,0 +1,251 @@ +/* + * VID: [T1.2] PT: [Fri Apr 21 16:47:18 1995] SF: [platform.h] + * TI: [/sae_users/cruz/bin/vice -iplatform.s -l// -p# -DEB164 -h -m -aeb164 ] + */ +#define __PLATFORM_LOADED 1 +/* +***************************************************************************** +** * +** Copyright © 1993, 1994 * +** by Digital Equipment Corporation, Maynard, Massachusetts. * +** * +** All Rights Reserved * +** * +** Permission is hereby granted to use, copy, modify and distribute * +** this software and its documentation, in both source code and * +** object code form, and without fee, for the purpose of distribution * +** of this software or modifications of this software within products * +** incorporating an integrated circuit implementing Digital's AXP * +** architecture, regardless of the source of such integrated circuit, * +** provided that the above copyright notice and this permission notice * +** appear in all copies, and that the name of Digital Equipment * +** Corporation not be used in advertising or publicity pertaining to * +** distribution of the document or software without specific, written * +** prior permission. * +** * +** Digital Equipment Corporation disclaims all warranties and/or * +** guarantees with regard to this software, including all implied * +** warranties of fitness for a particular purpose and merchantability, * +** and makes no representations regarding the use of, or the results * +** of the use of, the software and documentation in terms of correctness, * +** accuracy, reliability, currentness or otherwise; and you rely on * +** the software, documentation and results solely at your own risk. * +** * +** AXP is a trademark of Digital Equipment Corporation. * +** * +***************************************************************************** +** +** FACILITY: +** +** DECchip 21164 OSF/1 PALcode +** +** MODULE: +** +** platform.h +** +** MODULE DESCRIPTION: +** +** Platform specific definitions. +** +** AUTHOR: Lance Berc (taken from EB164 code) +** +** CREATION DATE: 14-Jun-1995 +** +** $Id: platform.h,v 1.1.1.1 1997/10/30 23:27:20 verghese Exp $ +** +** MODIFICATION HISTORY: +** +** $Log: platform.h,v $ +** Revision 1.1.1.1 1997/10/30 23:27:20 verghese +** current 10/29/97 +** + * Revision 1.1 1995/06/14 18:50:42 berc + * Initial revision + * +*/ + +#if !defined(CONSOLE_ENTRY) +#define CONSOLE_ENTRY 0x10000 +#endif /* CONSOLE_ENTRY */ + +#define DEBUGDEATH(c) \ + lda a0, c(zero) ; \ + br DebugDeath + +#define DEBUGSTORE(c) \ + stq_p t0,0(zero) ; \ + stq_p t1,8(zero) ; \ + lda t0, 0x400(zero) ; \ + sll t0, 29, t0 ; \ + ldah t0, 0x280(t0) ; \ +9: lda t1, 0x140(t0) ; \ + ldl_p t1, 0(t1) ; \ + srl t1, 16, t1 ; \ + and t1, 0x20, t1 ; \ + beq t1, 9b ; \ + lda t1, c(zero) ; \ + stl_p t1, 0(t0) ; \ + mb ; \ + ldq_p t1, 8(zero) ; \ + ldq_p t0, 0(zero) + + +/* +** IPL translation table definitions: +** +** EB164 specific IRQ pins are +** +** Line IPL Source OSF/1 IPL +** ---- --- ------ --------- +** IRQ0 20 Corrected ECC error 7 +** IRQ1 21 PCI/ISA 3 +** IRQ2 22 Real Time Clock 5 +** IRQ3 23 SIO NMI, CIA errors 7 +** +** The mask contains one byte for each IPL level, with IPL0 in the +** least significant (right-most) byte and IPL7 in the most +** significant (left-most) byte. Each byte in the mask maps the +** OSF/1 IPL to the DC21164 IPL. +** +** OSF/1 IPL IPL +** --------- --- +** 0 0 +** 1 1 +** 2 2 +** 3 21 (to account for PCI/ISA at IPL 21) +** 4 21 +** 5 22 (to account for clock at IPL 21) +** 6 30 (to account for powerfail) +** 7 31 +*/ + +#define INT_K_MASK_HIGH 0x1F1E1615 +#define INT_K_MASK_LOW 0x15020100 + +#define BYTE_ENABLE_SHIFT 5 + +/* +** Dallas DS1287A Real-Time Clock (RTC) Definitions: +*/ +#define RTCADD 0x160000 +#define RTCDAT 0x170000 + + +/* +** Serial Port (COM) Definitions: +*/ + +#define DLA_K_BRG 12 /* Baud Rate Divisor = 9600 */ + +#define LSR_V_THRE 5 /* Xmit Holding Register Empty Bit */ + +#define LCR_M_WLS 3 /* Word Length Select Mask */ +#define LCR_M_STB 4 /* Number Of Stop Bits Mask */ +#define LCR_M_PEN 8 /* Parity Enable Mask */ +#define LCR_M_DLAB 128 /* Divisor Latch Access Bit Mask */ + +#define LCR_K_INIT (LCR_M_WLS | LCR_M_STB) + +#define MCR_M_DTR 1 /* Data Terminal Ready Mask */ +#define MCR_M_RTS 2 /* Request To Send Mask */ +#define MCR_M_OUT1 4 /* Output 1 Control Mask */ +#define MCR_M_OUT2 8 /* UART Interrupt Mask Enable */ + +#define MCR_K_INIT (MCR_M_DTR | \ + MCR_M_RTS | \ + MCR_M_OUT1 | \ + MCR_M_OUT2) + +/* CPU Adr[39:29]=0x500 select PCI Mem. */ +#define PCI_MEM 0x400 +#define SLOT_D_COM1 (0x140000) +#define SLOT_D_COM2 (0x150000) + +#define COM1_RBR (SLOT_D_COM1 | (0x0 << 1)) /* Receive Buffer Register Offset */ +#define COM1_THR (SLOT_D_COM1 | (0x0 << 1)) /* Xmit Holding Register Offset */ +#define COM1_IER (SLOT_D_COM1 | (0x1 << 1)) /* Interrupt Enable Register Offset */ +#define COM1_IIR (SLOT_D_COM1 | (0x2 << 1)) /* Interrupt ID Register Offset */ +#define COM1_LCR (SLOT_D_COM1 | (0x3 << 1)) /* Line Control Register Offset */ +#define COM1_MCR (SLOT_D_COM1 | (0x4 << 1)) /* Modem Control Register Offset */ +#define COM1_LSR (SLOT_D_COM1 | (0x5 << 1)) /* Line Status Register Offset */ +#define COM1_MSR (SLOT_D_COM1 | (0x6 << 1)) /* Modem Status Register Offset */ +#define COM1_SCR (SLOT_D_COM1 | (0x7 << 1)) /* Scratch Register Offset */ +#define COM1_DLL (SLOT_D_COM1 | (0x8 << 1)) /* Divisor Latch (LS) Offset */ +#define COM1_DLH (SLOT_D_COM1 | (0x9 << 1)) /* Divisor Latch (MS) Offset */ + +#define COM2_RBR (SLOT_D_COM2 | (0x0 << 1)) +#define COM2_THR (SLOT_D_COM2 | (0x0 << 1)) +#define COM2_IER (SLOT_D_COM2 | (0x1 << 1)) +#define COM2_IIR (SLOT_D_COM2 | (0x2 << 1)) +#define COM2_LCR (SLOT_D_COM2 | (0x3 << 1)) +#define COM2_MCR (SLOT_D_COM2 | (0x4 << 1)) +#define COM2_LSR (SLOT_D_COM2 | (0x5 << 1)) +#define COM2_MSR (SLOT_D_COM2 | (0x6 << 1)) +#define COM2_SCR (SLOT_D_COM2 | (0x7 << 1)) +#define COM2_DLL (SLOT_D_COM2 | (0x8 << 1)) +#define COM2_DLH (SLOT_D_COM2 | (0x9 << 1)) + + +/* +** Macro to define a port address +*/ +#define IO_MASK 0x7FFFFFF + +/* NOTE ON ADDITIONAL PORT DEFINITION: +** +** We also need to set bit 39! Since the span between bit 39 +** and the byte enable field is more than 32, we set bit 39 in the +** port macros. +*/ + +/* +** Macro to write a byte literal to a specified port +*/ +#define OutPortByte(port,val,tmp0,tmp1) \ + LDLI (tmp0, port); \ + sll tmp0, BYTE_ENABLE_SHIFT, tmp0; \ + lda tmp1, PCI_MEM(zero); \ + sll tmp1, 29, tmp1; \ + bis tmp0, tmp1, tmp0; \ + lda tmp1, (val)(zero); \ + sll tmp1, 8*(port & 3), tmp1; \ + stl_p tmp1, 0x00(tmp0); \ + mb + +/* +** Macro to write a byte from a register to a specified port +*/ +#define OutPortByteReg(port,reg,tmp0,tmp1) \ + LDLI (tmp0, port); \ + sll tmp0, BYTE_ENABLE_SHIFT, tmp0; \ + lda tmp1, PCI_MEM(zero); \ + sll tmp1, 29, tmp1; \ + bis tmp0, tmp1, tmp0; \ + sll reg, 8*(port & 3), tmp1; \ + stl_p tmp1, 0x00(tmp0); \ + mb + +/* +** Macro to write a longword from a register to a specified port +*/ +#define OutPortLongReg(port,reg,tmp0,tmp1) \ + LDLI (tmp0, port); \ + sll tmp0, BYTE_ENABLE_SHIFT, tmp0; \ + lda tmp1, PCI_MEM(zero); \ + sll tmp1, 29, tmp1; \ + bis tmp0, tmp1, tmp0; \ + stl_p tmp1, 0x18(tmp0); \ + mb + +/* +** Macro to read a byte from a specified port +*/ +#define InPortByte(port,tmp0,tmp1) \ + LDLI (tmp0, port); \ + sll tmp0, BYTE_ENABLE_SHIFT, tmp0; \ + lda tmp1, PCI_MEM(zero); \ + sll tmp1, 29, tmp1; \ + bis tmp0, tmp1, tmp0; \ + ldl_p tmp0, 0x00(tmp0); \ + srl tmp0, (8 * (port & 3)), tmp0; \ + zap tmp0, 0xfe, tmp0 diff --git a/system/alpha/h/ppec.h b/system/alpha/h/ppec.h deleted file mode 100644 index fc9aff492..000000000 --- a/system/alpha/h/ppec.h +++ /dev/null @@ -1,33 +0,0 @@ -#include "lib.h" -#include "xxm.h" - -unsigned char ppecRegRead(int, unsigned char); -void ppecRegWrite(int, unsigned char, unsigned char); -int ppecOpen(int); -void ppecClose(int); -ul ppecMemAddr(int); -ul ppecIOAddr(int, int, unsigned long, int); - -typedef unsigned char char2[2]; -struct pcmcia { - int socket; - char2 *cor; - char2 *cis; -}; - -struct _pcmciaTuples { - int count; - unsigned char *tuples[32]; - unsigned char buf[256]; -}; - -struct _ppecSlotInfo { - int cardPresent; - struct _pcmciaTuples tuples; -}; - -extern struct _ppecSlotInfo ppecSlotInfo[]; - - - - diff --git a/system/alpha/h/prtrace.h b/system/alpha/h/prtrace.h deleted file mode 100644 index 9500ea1cc..000000000 --- a/system/alpha/h/prtrace.h +++ /dev/null @@ -1,99 +0,0 @@ -#ifndef __PRTRACE_H_LOADED -#define __PRTRACE_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: prtrace.h,v 1.1.1.1 1997/10/30 23:27:17 verghese Exp $ - */ - -/* - * MODULE DESCRIPTION: - * - * Tracing macros for EB64 monitor - * - * HISTORY: - * $Log: prtrace.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:17 verghese - * current 10/29/97 - * - * Revision 1.5 1994/08/08 00:27:52 fdh - * Added TRACE_ENABLE conditional. - * - * Revision 1.4 1994/08/05 20:13:47 fdh - * Updated Copyright header and RCS $Id: identifier. - * - * Revision 1.3 1994/06/20 14:18:59 fdh - * Fixup header file preprocessor #include conditionals. - * - * Revision 1.2 1994/03/09 12:47:12 berent - * Added PRINTERR macros - * - * Revision 1.1 1993/06/22 11:19:52 berent - * Tracing macros implemementing PRTRACE compile time - * option. - * - */ - -/* The following macros are used for printing out status information and internal error */ -/* messages; such messages go to standard error in environments in which there is a */ -/* standard error file */ -#define PRINTERR1(x) printf(x) -#define PRINTERR2(x,y) printf(x,y) -#define PRINTERR3(x,y,z) printf(x,y,z) - - -/* - * Tracing with debug prints using the PRTRACE - * macros (see prtrace.h) can be performed by - * two different means. (1) Defining PRTRACE - * will build in the tracing at compile time. - * (2) Defining TRACE_ENABLE will also build - * in tracing at compile time. However, most - * of it can be enabled or disabled at run - * time with the debug monitor prtrace command. - */ - -#ifdef TRACE_ENABLE -#define PRTRACE - -extern int prtrace_enable; -#define _PRTRACE_PRINTF if (prtrace_enable) printf -#else -#define _PRTRACE_PRINTF printf -#endif - -#ifdef PRTRACE -#define PRTRACE1(x) _PRTRACE_PRINTF(x) -#define PRTRACE2(x,y) _PRTRACE_PRINTF(x,y) -#define PRTRACE3(x,y,z) _PRTRACE_PRINTF(x,y,z) -#else -#define PRTRACE1(x) -#define PRTRACE2(x,y) -#define PRTRACE3(x,y,z) -#endif - -#endif /* __PRTRACE_H_LOADED */ diff --git a/system/alpha/h/rom.h b/system/alpha/h/rom.h deleted file mode 100644 index 3c7f59403..000000000 --- a/system/alpha/h/rom.h +++ /dev/null @@ -1,53 +0,0 @@ -#ifndef __ROM_H_LOADED -#define __ROM_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: rom.h,v 1.1.1.1 1997/10/30 23:27:17 verghese Exp $; - */ - -/* - * $Log: rom.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:17 verghese - * current 10/29/97 - * - * Revision 1.1 1995/02/28 03:06:09 fdh - * Initial revision - * - */ - -#include "romhead.h" /* Includes required typedefs. */ - -/*:::::::::::::: -rom.c -::::::::::::::*/ -extern int read_rom(int argc , char *arg, ul address); -extern void list_rom_headers(void ); -extern void set_romboot(char * arg); -extern ui romimage_size(romheader_t * rhead); - -#endif /* __ROM_H_LOADED */ diff --git a/system/alpha/h/romhead.h b/system/alpha/h/romhead.h deleted file mode 100644 index 5be8dd7d9..000000000 --- a/system/alpha/h/romhead.h +++ /dev/null @@ -1,354 +0,0 @@ -#ifndef __ROMHEAD_H_LOADED -#define __ROMHEAD_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: romhead.h,v 1.1.1.1 1997/10/30 23:27:17 verghese Exp $; - */ - -/* - * $Log: romhead.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:17 verghese - * current 10/29/97 - * - * Revision 1.16 1995/03/05 00:51:01 fdh - * Fixed up a couple of MACROS. - * - * Revision 1.15 1995/03/04 05:55:57 fdh - * Bracket COMPUTE_CHECKSUM Macro. - * - * Revision 1.14 1995/02/27 15:36:21 fdh - * Removed ul definitions. Replaced with structs of ui's. - * - * Revision 1.13 1995/02/16 22:06:06 fdh - * Changed Open VMS to OpenVMS because of some trademark junk. - * - * Revision 1.12 1995/02/14 21:19:33 cruz - * Fixed up header picture to match implementation. - * - * Revision 1.11 1995/02/10 02:19:03 fdh - * Created COMPUTE_CHECKSUM Macro. - * Corrected prototypes. - * - * Revision 1.10 1995/02/08 00:34:44 fdh - * Added ROMH_VERSION and ROTATE_RIGHT macros. - * - * Revision 1.9 1995/02/07 22:28:09 fdh - * Changed Windows NT alias from "WNT" to "NT". - * - * Revision 1.8 1995/02/07 04:54:33 fdh - * Added ostype definitions. - * Modified ROM_HEADER_CHECKSUM Macro. - * - * Revision 1.7 1995/02/06 02:47:40 fdh - * Added prototypes for romhead.c routines. - * - * Revision 1.6 1995/02/05 01:53:05 fdh - * Modified the definition for the ROM header. - * Added a MACRO that can be used to access the - * ROM header checksum which can be in different location - * for different versions of the header. - * - * Revision 1.5 1995/02/02 20:05:31 fdh - * Moved fwid_array[] initialization to header file. - * - * Revision 1.4 1995/01/31 23:44:00 fdh - * Added field for "OPTIONAL FW ID, continued" to make - * the optional field really 7 bytes. - * - * Revision 1.3 1995/01/31 23:21:25 fdh - * Updated... - * - * Revision 1.2 1995/01/23 22:34:32 fdh - * Extended the ROM header spec. This is now version one - * which is a super-set of the version 0 header. - * - * Revision 1.1 1994/11/19 03:47:29 fdh - * Initial revision - * - * - * - * Special ROM header - * ================== - * The System ROM can contain multiple ROM images, each with - * its own header. That header tells the SROM where to load - * the image and also if it has been compressed with the - * "makerom" tool. For System ROMs which contain a single - * image, the header is optional. If the header does not - * exist the complete System ROM is loaded and executed at - * physical address zero. - * - * 31 0 - * +---------------------------------------------+ - * | VALIDATION PATTERN 0x5A5AC3C3 | 0x00 - * +---------------------------------------------+ - * | INVERSE VALIDATION PATTERN 0xA5A53C3C | 0x04 - * +---------------------------------------------+ - * | HEADER SIZE (Bytes) | 0x08 - * +---------------------------------------------+ - * | IMAGE CHECKSUM | 0x0C - * +---------------------------------------------+ - * | IMAGE SIZE (Memory Footprint) | 0x10 - * +---------------------------------------------+ - * | DECOMPRESSION FLAG | 0x14 - * +---------------------------------------------+ - * | DESTINATION ADDRESS LOWER LONGWORD | 0x18 - * +---------------------------------------------+ - * | DESTINATION ADDRESS UPPER LONGWORD | 0x1C - * +---------------------------------------------+ - * | RSVD<31:16>| ID <15:8>| HEADER REV <7:0> | 0x20 \ - * +---------------------------------------------+ \ - * | ROM IMAGE SIZE | 0x24 | - * +---------------------------------------------+ | New for - * | OPTIONAL FIRMWARE ID <31:0> | 0x28 +- Rev 1 - * +---------------------------------------------+ | headers. - * | OPTIONAL FIRMWARE ID <63:32> | 0x2C | - * +---------------------------------------------+ / - * | HEADER CHECKSUM (excluding this field) | 0x30 / - * +---------------------------------------------+ - * - * VALIDATION PATTERN - * ------------------ - * The first quadword contains a special signature pattern - * that is used to verify that this "special" ROM header - * has been located. The pattern is 0x5A5AC3C3A5A53C3C. - * - * HEADER SIZE (Bytes) - * ------------------- - * The header size is the next longword. This is provided - * to allow for some backward compatibility in the event that - * the header is extended in the future. When the header - * is located, current versions of SROM code determine where - * the image begins based on the header size. Additional data - * added to the header in the future will simply be ignored - * by current SROM code. Additionally, the header size = 0x20 - * implies version 0 of this header spec. For any other size - * see HEADER REVISION to determine header version. - * - * - * IMAGE CHECKSUM - * -------------- - * The next longword contains the image checksum. This is - * used to verify the integrity of the ROM. Checksum is computed - * in the same fashion as the header checksum. - * - * IMAGE SIZE (Memory Footprint) - * ----------------------------- - * The image size reflects the size of the image after it has - * been loaded into memory from the ROM. See ROM IMAGE SIZE. - * - * DECOMPRESSION FLAG - * ------------------ - * The decompression flag tells the SROM code if the makerom - * tool was used to compress the ROM image with a "trivial - * repeating byte algorithm". The SROM code contains routines - * which perform this decompression algorithm. Other - * compression/decompression schemes may be employed which work - * independently from this one. - * - * DESTINATION ADDRESS - * ------------------- - * This quadword contains the destination address for the - * image. The SROM code will begin loading the image at this - * address and subsequently begin its execution there. - * - * HEADER REV - * ---------- - * The revision of the header specifications used in this - * header. This is necessary to provide compatibility to - * future changes to this header spec. Version 0 headers - * are identified by the size of the header. See HEADER - * SIZE. - * - * FIRMWARE ID - * ----------- - * The firmware ID is a byte that specifies the firmware type. - * This facilitates image boot options necessary to boot - * different operating systems. - * - * firmware - * firmware type - * -------- -------- - * DBM 0 Alpha Evaluation Boards Debug Monitor - * WNT 1 Windows NT Firmware - * SRM 2 Alpha System Reference Manual Console - * - * ROM IMAGE SIZE - * -------------- - * The ROM image size reflects the size of the image as it is - * contained in the ROM. See IMAGE SIZE. - * - * OPTIONAL FW ID - * -------------- - * This is an optional field that can be used to provide - * additional firmware information such as firmware revision - * or a character descriptive string up to 8 characters. - * - * HEADER CHECKSUM - * --------------- - * The checksum of the header. This is used to validate - * the presence of a header beyond the validation provided - * by the validation pattern. See VALIDATION PATTERN. - * The header checksum is computed from the beginning of - * the header up to but excluding the header checksum - * field itself. If there are future versions of this - * header the header checksum should always be the last - * field defined in the header. The checksum algorithm used - * is compatible with the standard BSD4.3 algorithm provided - * on most implementations of Unix. Algorithm: The checksum - * is rotated right by one bit around a 16 bit field before - * adding in the value of each byte. - * - */ - -#include "local.h" /* Include environment specific definitions */ - -#define ROM_H_SIGNATURE 0x5A5AC3C3 -#define ROM_H_REVISION 1 - - -typedef union { - struct { - /* - * Version 0 definition of the ROM header. - */ - struct { - ui signature; /* validation signature */ - ui csignature; /* inverse validation signature */ - ui hsize; /* header size */ - ui checksum; /* checksum */ - ui size; /* image size (Memory Footprint) */ - ui decomp; /* decompression algorithm */ - struct { - ui low; - ui high; - } destination; /* destination address */ - } V0; - - /* - * Version 1 extensions to the ROM header. - */ - struct { - char hversion; /* ROM header version (Byte 0) */ - char fw_id; /* Firmware ID (Byte 1) */ - char reserved[2]; /* Reserved (Bytes 3:2) */ - ui rimage_size; /* ROM image size */ - union { - char id[8]; /* Optional Firmware ID (character array) */ - struct { - ui low; - ui high; - } id_S; - } fwoptid; - } V1; - - /* - * Future extensions to the header should be included before - * this header checksum. (See HEADER CHECKSUM description) - */ - ui hchecksum; /* Header checksum, (Always last entry) */ - } romh; - ui romh_array[1]; /* To allow longword access to the data */ -} romheader_t; - -/* - * Registered Firmware types. - */ -#define FW_DBM 0 -#define FW_WNT 1 -#define FW_SRM 2 - -#define FW_DBM_STRINGS "Alpha Evaluation Board Debug Monitor", "DBM", "Debug Monitor", "Monitor", NULL -#define FW_WNT_STRINGS "Windows NT Firmware", "WNT", "NTFW", "ARC", "NT", NULL -#define FW_SRM_STRINGS "Alpha SRM Console", "SRM", "VMS", "OSF", NULL - -typedef struct fw_id { - int firmware_id; - char **id_string; -} fw_id_t; - -extern fw_id_t fwid_array[]; - -#define FW_OSTYPE_DBM 0 -#define FW_OSTYPE_WNT 1 -#define FW_OSTYPE_VMS 2 -#define FW_OSTYPE_OSF 3 - -#define OS_DBM_STRINGS "Alpha Evaluation Board Debug Monitor", "DBM" -#define OS_WNT_STRINGS "The Windows NT Operating System", "NT" -#define OS_VMS_STRINGS "OpenVMS", "VMS" -#define OS_OSF_STRINGS "DEC OSF/1", "OSF" - -typedef struct os_types { - int ostype; - int firmware_id; - char **id_string; -} ostype_t; - -extern ostype_t ostype_array[]; - -/* - * The ROM header checksum should always be assigned to the last - * field in the header. Therefore, when reading headers created - * by various versions of makerom the ROM header checksum can be - * in different locations. This macro can be used to access the - * ROM header checksum in the proper location. - */ -#define ROM_HEADER_CHECKSUM(x) \ - ((x)->romh_array[((x)->romh.V0.hsize - sizeof((x)->romh.hchecksum))/sizeof(ui)]) - -/* - * Macro to provide the header version number - */ -#define ROMH_VERSION(x) ((x)->romh.V0.hsize == 0x20 ? 0 : (x)->romh.V1.hversion) - -/* - * Macro to assist in computing the BSD4.3 style checksum. - */ -#define ROTATE_RIGHT(x) if ((x) & 1) (x) = ((x) >>1) + 0x8000; else (x) = (x) >>1; - -/* - * Macro used to increment the checksum - * by a new byte while keeping the total - * checksum within the 16 bit range. - */ -#define COMPUTE_CHECKSUM(c,k) \ - {ROTATE_RIGHT(k); k += (ub) c; k &= 0xffff;} - -/* - * romheader.c prototypes - */ -extern fw_id_t * fwid_match(char * arg); -extern fw_id_t * fwid_match_i(int fwid); -extern void fwid_dump(char * pre); -extern ostype_t * ostype_match(char * arg); -extern ostype_t * ostype_match_i(int ostype); -extern void ostype_dump(char * pre); -extern ui compute_romh_chksum(romheader_t * header); -extern int dumpHeader(romheader_t * header); - -#endif /* __ROMHEAD_H_LOADED */ diff --git a/system/alpha/h/server_t.h b/system/alpha/h/server_t.h deleted file mode 100644 index 5775a9522..000000000 --- a/system/alpha/h/server_t.h +++ /dev/null @@ -1,61 +0,0 @@ -#ifndef __SERVERTYPES_H_LOADED -#define __SERVERTYPES_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: server_t.h,v 1.1.1.1 1997/10/30 23:27:17 verghese Exp $; - */ -/* - * This file contains named types used by the server. - * $Log: server_t.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:17 verghese - * current 10/29/97 - * - * Revision 1.5 1994/11/08 21:44:17 fdh - * Include lib.h - * - * Revision 1.4 1994/08/05 20:13:47 fdh - * Updated Copyright header and RCS $Id: identifier. - * - * Revision 1.3 1994/06/20 14:18:59 fdh - * Fixup header file preprocessor #include conditionals. - * - * Revision 1.2 1994/06/03 20:13:54 fdh - * Properly handle this header file when included multiple times. - * - * Revision 1.1 1994/03/09 12:48:33 berent - * Initial revision - * - */ - -#include "lib.h" - -typedef ul address_value; -typedef ul register_value; -typedef ui instruction_value; - -#endif /* __SERVERTYPES_H_LOADED */ diff --git a/system/alpha/h/simos.h b/system/alpha/h/simos.h new file mode 100644 index 000000000..be5a5a93b --- /dev/null +++ b/system/alpha/h/simos.h @@ -0,0 +1,16 @@ + + +/* + * this contains the random stuff that is not defined + * elsewhere + * probably hacked up + */ + + +#include "tlaser.h" /* from the simulation tree */ + +/* + * wierd. different ways of referencing ips + */ + +#define ps ips diff --git a/system/alpha/h/ssb.h b/system/alpha/h/ssb.h deleted file mode 100644 index 057f2dca5..000000000 --- a/system/alpha/h/ssb.h +++ /dev/null @@ -1,183 +0,0 @@ -#ifndef __SSB_H_LOADED -#define __SSB_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: ssb.h,v 1.1.1.1 1997/10/30 23:27:17 verghese Exp $; - */ - -/* - * $Log: ssb.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:17 verghese - * current 10/29/97 - * - * Revision 1.3 1994/08/05 20:13:47 fdh - * Updated Copyright header and RCS $Id: identifier. - * - * Revision 1.2 1994/06/20 14:18:59 fdh - * Fixup header file preprocessor #include conditionals. - * - * Revision 1.1 1993/06/08 19:56:16 fdh - * Initial revision - * - */ - - - -/* ssbinit */ -/* Set up SSB definitions */ -/* Last modified on 1/3/91 by L. Stewart */ - -#define SSB_stcreset1 0x0800 /* CR_DIR */ -#define SSB_stcreset2 0x3820 /* CR_CABEN | CR_AUTO | CR_DIR */ - /* | CR_FIFOMR */ - -#define SSB_TagCable 0 -#define SSB_TagSlot 3 -#define SSB_TagTVA 2 -#define SSB_TagRFA 1 -#define SSB_TagORF 5 -#define SSB_TagStartTV 4 -#define SSB_TagTVStat 6 -#define SSB_TagLocalStat 7 - -#define SSB_AdrLocalStat 0x4000 -#define SSB_AdrSRA 0x8000 -#define SSB_AdrSRB 0x8001 - -#define SSB_LCRenable 0x1 -#define SSB_LCRclrstat 0x2 -#define SSB_LCRfifomr 0x4 -#define SSB_LCRreset 0x8 -#define SSB_LCRled 0x10 - -#define SSB_LSTfifoff 0x100 -#define SSB_LSTfifohf 0x200 -#define SSB_LSTfifoef 0x400 -#define SSB_LSTinst 0x800 -#define SSB_LSTid 0x1000 -#define SSB_LSTotherinst 0x2000 -#define SSB_LSTcnfg0 0x4000 -#define SSB_LSTcnfg1 0x8000 -#define SSB_LSTnode 0xf000 - -#define SSB_CRrParityS 0x01 -#define SSB_CRdataWP 0x02 -#define SSB_CRadrWP 0x04 -#define SSB_CRerrEnable 0x08 -#define SSB_CRreset 0x10 -#define SSB_CRdoConfig 0x20 -#define SSB_CRnodeClock 0x40 - -#define SSB_SRAshared 0x00000080 -#define SSB_SRAdirty 0x00100000 -#define SSB_SRAnType 0x80000000 - -#define SSB_PSRinst 0x001 -#define SSB_PSRmerror 0x002 -#define SSB_PSRreset 0x004 -#define SSB_PSRerror 0x008 -#define SSB_PSRserror 0x010 -#define SSB_PSRisr 0x7e0 - -struct SSB_lsrtype { - unsigned sequence : 8; - unsigned slot : 8; - unsigned mix : 4; - unsigned inst : 1; - unsigned ef : 1; - unsigned hf : 1; - unsigned ff : 1; - unsigned crpad : 3; - unsigned crled : 1; - unsigned crreset : 1; - unsigned crfifomr : 1; - unsigned crclrstat : 1; - unsigned crenable : 1; -}; - -struct SSB_pstattype { - unsigned pad : 21; - unsigned isr : 6; - unsigned serror : 1; - unsigned error : 1; - unsigned reset : 1; - unsigned merror : 1; - unsigned inst : 1; -}; - -struct SSB_sratype { - unsigned nodeType : 1; - unsigned p0stat: 11; - unsigned dirty : 1; - unsigned p1stat : 11; - unsigned shared : 1; - unsigned cr : 7; -}; - -struct SSB_srbtype { - unsigned p1count : 8; - unsigned p0count : 8; - unsigned arbcount : 16; -}; - -extern int ssb_sequence; -extern int ssb_localcr; -extern int ssb_maincr; -extern int ssb_port; -extern int ssb_node; -extern int ssb_config1; -extern int ssb_config0; -extern int ssb_lastsra; -extern int ssb_lastsrb; -extern int ssb_lastlsr; -extern int ssb_lastieecc; -extern struct SSB_lsrtype ssb_lsr; -extern int ssb_mix; -extern struct SSB_sratype ssb_sra; -extern struct SSB_srbtype ssb_srb; -extern int ssb_resid; -extern struct SSB_pstattype ssb_portstatus; - - -/* ssb routines */ -#define SSB_CR SSB_stcreset2 -#define SSBCH 1020 - -#define SSB_CABLE(x) (wfifo(x, SSB_TagCable)) -#define SSB_LDSLOT(x) (wfifo(x, SSB_TagSlot)) -#define SSB_LDTVA(x, w) (wfifo((x) | ((w) ? 0x80000000 : 0), SSB_TagTVA)) -#define SSB_LDRFA(a, c) (wfifo(((255 - c) << 16) + a, SSB_TagRFA)) -#define SSB_LDORF(x) (wfifo(x, SSB_TagORF)) -#define SSB_STARTTV(a, c, w) (wfifo(( (w << 15) | ((255 - c) << 16) | a), SSB_TagStartTV )) -#define SSB_TVSTAT(x) (wfifo(x, SSB_TagTVStat)) -#define SSB_LOCALSTAT(x) (wfifo(x, SSB_TagLocalStat)) - -#define SSB_CFF() ( STC_SETCR(tvp->crmask & ~STC_CRFIFOMR), \ - STC_SETCR(tvp->crmask | STC_CRFIFOMR) ) - -#endif /* __SSB_H_LOADED */ diff --git a/system/alpha/h/sys.h b/system/alpha/h/sys.h deleted file mode 100644 index cc72ec1e6..000000000 --- a/system/alpha/h/sys.h +++ /dev/null @@ -1,253 +0,0 @@ -#ifndef __SYS_H_LOADED -#define __SYS_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: sys.h,v 1.1.1.1 1997/10/30 23:27:17 verghese Exp $; - */ - -/* - * $Log: sys.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:17 verghese - * current 10/29/97 - * - * Revision 1.3 1994/08/05 20:13:47 fdh - * Updated Copyright header and RCS $Id: identifier. - * - * Revision 1.2 1994/06/20 14:18:59 fdh - * Fixup header file preprocessor #include conditionals. - * - * Revision 1.1 1993/06/08 19:56:16 fdh - * Initial revision - * - */ - -/* -**++ -***************************************************************************** -** * -** Copyright (c) 1992 * -** by Digital Equipment Corporation, Maynard, Ma. * -** * -** This software is furnished under a license and may be used and copied * -** only in accordance with the terms of such license and with the * -** inclusion of the above copyright notice. This software or any other * -** copies thereof may not be provided or otherwise made available to any * -** other person. No title to and ownership of the software is hereby * -** transferred. * -** * -** The information in this software is subject to change without notice * -** and should not be construed as a commitment by Digital Equipment * -** Corporation. * -** * -** Digital assumes no responsibility for the use or reliability of its * -** software on equipment which is not supplied by Digital. * -** * -***************************************************************************** -** -** FACILITY: -** -** sys.h -** -** MODULE DESCRIPTION: -** -** DECchip 21064 Evaluation and Development System (ED64) -** specific definitions. -** -** CREATION DATE: 17-Nov-1992 -** -** DESIGN ISSUES: -** -** {@tbs@} -** -** [@optional module tags@]... -** -** MODIFICATION HISTORY: -** -** Who When What -** ----- ----------- --------------------------------------------- -** ES 12-Jan-1993 Add SYS$K_HIER_CRE -** ES 14-Jan-1993 Add some impure area symbols -** ES 15-Jan-1993 Can't use # for comments on defines -** ES 20-Jan-1993 Put in intmask -** ES 27-Jan-1993 SYS$K_HIERW_CRE is covered by abox control -**-- -*/ - -/* -** -** External cache (Bcache) definitions: -** -*/ -#define BC$M_PA_DIS 0x000E /* Cache only 1st quadrant of PA space */ -#define BC$M_SIZE 0x2000 /* External cache size = 512K bytes */ -#define BC$M_WE_CTL4 0x0000 /* External cache write control */ -#define BC$M_WE_CTL3 0x0000 /* Write pulse on 3rd, 4th & 5th cycle */ -#define BC$M_WE_CTL2 0x0001 -#define BC$M_WE_CTL1 0xC000 -#define BC$M_WR_SPD 0x0600 /* External cache write speed = 7 cycles */ -#define BC$M_RD_SPD 0x0040 /* External cache read speed = 5 cycles */ -#define BC$M_ENA 0x0001 /* External cache enable */ - -/* -** We may want to move the BIU$M_INIT definitions to another module -** that contains user configurable options. -*/ -#define BIU$M_INIT_47_32 BC$M_PA_DIS - -#define BIU$M_INIT_31_16 BC$M_SIZE | \ - BC$M_WE_CTL4 | \ - BC$M_WE_CTL3 | \ - BC$M_WE_CTL2 - -#define BIU$M_INIT_15_00 BC$M_WE_CTL1 | \ - BC$M_WR_SPD | \ - BC$M_RD_SPD | \ - BC$M_ENA -/* -** Interrupt Mask -** ED64 specific IRQ pins are: -** IRQ0 PIC ipl <=2 -** IRQ1 NMI disabled -** IRQ2 RTC ipl <= 4 -*/ -#define SYS$M_HIGHINTMASK 0x00000008 -#define SYS$M_LOWINTMASK 0x080A0A0A - -/* -** -** SCB offsets -** -*/ -#define SCB$Q_PROCMCHK 0x0670 /* Offset for mchk */ -#define SCB$Q_SYSERR 0x0620 /* Offset for sce */ - - -/* -** -** Machine Check Rev level -** -*/ -#define MCHK$K_REV 0x0001 - -/* -** -** Short logout frame -** -*/ -#define LAS$Q_BASE 0x0000 /* Base relative to logout area */ - -#define LAS$L_FRAME 0x0000 -#define LAS$L_FLAG 0x0004 -#define LAS$L_CPU 0x0008 -#define LAS$L_SYS 0x000C -#define LAS$Q_MCHK_CODE 0x0010 - -#define LAS$Q_BIU_STAT 0x0018 -#define LAS$Q_BIU_ADDR 0x0020 -#define LAS$Q_DC_STAT 0x0028 -#define LAS$Q_FILL_SYNDROME 0x0030 -#define LAS$Q_FILL_ADDR 0x0038 -#define LAS$Q_BC_TAG 0x0040 - -#define LAS$K_SIZE 0x0048 /* Frame size */ - -/* -** -** Long logout frame -** -*/ -#define LAF$Q_BASE LAS$K_SIZE /* Base relative to logout area */ - -#define LAF$L_FRAME 0x0000 -#define LAF$L_FLAG 0x0004 -#define LAF$L_CPU 0x0008 -#define LAF$L_SYS 0x000C - -#define LAF$Q_PT0 0x0010 -#define LAF$Q_PT1 0x0018 -#define LAF$Q_PT2 0x0020 -#define LAF$Q_PT3 0x0028 -#define LAF$Q_PT4 0x0030 -#define LAF$Q_PT5 0x0038 -#define LAF$Q_PT6 0x0040 -#define LAF$Q_PT7 0x0048 -#define LAF$Q_PT8 0x0050 -#define LAF$Q_PT9 0x0058 -#define LAF$Q_PT10 0x0060 -#define LAF$Q_PT11 0x0068 -#define LAF$Q_PT12 0x0070 -#define LAF$Q_PT13 0x0078 -#define LAF$Q_PT14 0x0080 -#define LAF$Q_PT15 0x0088 -#define LAF$Q_PT16 0x0090 -#define LAF$Q_PT17 0x0098 -#define LAF$Q_PT18 0x00A0 -#define LAF$Q_PT19 0x00A8 -#define LAF$Q_PT20 0x00B0 -#define LAF$Q_PT21 0x00B8 -#define LAF$Q_PT22 0x00C0 -#define LAF$Q_PT23 0x00C8 -#define LAF$Q_PT24 0x00D0 -#define LAF$Q_PT25 0x00D8 -#define LAF$Q_PT26 0x00E0 -#define LAF$Q_PT27 0x00E8 -#define LAF$Q_PT28 0x00F0 -#define LAF$Q_PT29 0x00F8 -#define LAF$Q_PT30 0x0100 -#define LAF$Q_PT31 0x0108 - -#define LAF$Q_EXC_ADDR 0x0110 -#define LAF$Q_PAL_BASE 0x0130 -#define LAF$Q_HIER 0x0138 -#define LAF$Q_HIRR 0x0140 -#define LAF$Q_MM_CSR 0x0148 -#define LAF$Q_DC_STAT 0x0150 -#define LAF$Q_DC_ADDR 0x0158 -#define LAF$Q_ABOX_CTL 0x0160 -#define LAF$Q_BIU_STAT 0x0168 -#define LAF$Q_BIU_ADDR 0x0170 -#define LAF$Q_BIU_CTL 0x0178 -#define LAF$Q_FILL_SYNDROME 0x0180 -#define LAF$Q_FILL_ADDR 0x0188 -#define LAF$Q_VA 0x0190 -#define LAF$Q_BC_TAG 0x0198 - -#define LAF$K_SIZE 0x01A0 /* Frame size */ - -#define LAF$Q_SYS_BASE 0x01A0 /* Currently no system stuff */ - -/* -** -** Impure Area Offset Definitions -** -*/ -#define IMP$Q_ABOX_CTL 0x0380 -#define IMP$Q_BIU_CTL 0x0388 -#define IMP$Q_LOGOUT_AREA 0x2000 - -#endif /* __SYS_H_LOADED */ diff --git a/system/alpha/h/system.h b/system/alpha/h/system.h deleted file mode 100644 index de35b4451..000000000 --- a/system/alpha/h/system.h +++ /dev/null @@ -1,89 +0,0 @@ -#ifndef __SYSTEM_H_LOADED -#define __SYSTEM_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: system.h,v 1.1.1.1 1997/10/30 23:27:17 verghese Exp $; - */ - -/* - * $Log: system.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:17 verghese - * current 10/29/97 - * - * Revision 1.1 1995/06/08 18:42:05 berc - * Initial revision - * - * Revision 1.10 1994/12/08 16:42:29 fdh - * Added includes for eb66p.h and eb64l.h - * - * Revision 1.9 1994/11/23 19:45:52 cruz - * Added eb164.h - * - * Revision 1.8 1994/11/08 21:44:50 fdh - * Removed special compiler definitions. They now only - * appear in lib.h - * - * Revision 1.7 1994/08/05 20:13:47 fdh - * Updated Copyright header and RCS $Id: identifier. - * - * Revision 1.6 1994/06/20 14:18:59 fdh - * Fixup header file preprocessor #include conditionals. - * - * Revision 1.5 1994/06/17 19:34:01 fdh - * Clean-up... - * - * Revision 1.4 1994/03/16 00:12:31 fdh - * Use TRUE and FALSE defines for all environments. - * - * Revision 1.3 1994/01/19 10:22:28 rusling - * Ported to ALpha Windows NT. - * - * Revision 1.2 1993/11/22 13:17:13 rusling - * Merged with PCI/21040 changes. - * - * Revision 1.1 1993/11/22 11:44:09 rusling - * Initial revision - * - * Revision 1.1 1993/11/22 11:44:09 rusling - * Initial revision - * - */ - - -/* - * Per evaluation board include files - */ -#include "eb64.h" -#include "eb66.h" -#include "eb66p.h" -#include "eb64p.h" -#include "eb64l.h" -#include "eb164.h" -#include "xxm.h" - -#endif /* __SYSTEM_H_LOADED */ diff --git a/system/alpha/h/tftp.h b/system/alpha/h/tftp.h deleted file mode 100644 index 7fd6b6ae4..000000000 --- a/system/alpha/h/tftp.h +++ /dev/null @@ -1,87 +0,0 @@ -#ifndef __TFTP_H_LOADED -#define __TFTP_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: tftp.h,v 1.1.1.1 1997/10/30 23:27:17 verghese Exp $ - */ - -/* - * MODULE DESCRIPTION: - * - * TFTP protocol interface for EB64 monitor - * - * HISTORY: - * - * $Log: tftp.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:17 verghese - * current 10/29/97 - * - * Revision 1.5 1994/08/05 20:13:47 fdh - * Updated Copyright header and RCS $Id: identifier. - * - * Revision 1.4 1994/06/28 20:08:21 fdh - * Modified filenames and build precedure to fit into a FAT filesystem. - * - * Revision 1.3 1994/06/20 14:18:59 fdh - * Fixup header file preprocessor #include conditionals. - * - * Revision 1.2 1994/01/21 09:45:59 rusling - * Added #ifdef <filename>_H around the module. - * Additionally, any included files are not ifdef'd - * *before* they're included (ie address.h). - * - * Revision 1.1 1993/08/06 10:46:21 berent - * Initial revision - * - * - */ - -#include "address.h" - -/* tftp_load - load a file from a remote host - * - * Arguments: - * device_no - device on which request should be sent - * file_name - name of file to be loaded. Null terminated; - * server_addr - server IP address - * load_addr - address of start of region into which the file should be loaded. - * - * Returned value: - * TRUE - tftp successful. - * FALSE - tftp failed. - */ -extern int tftp_load(int device_no, - char file_name[128], - ip_addr server_addr, - unsigned char * load_addr); -/* tftp_init_module - initialise the module - */ -extern void tftp_init_module(void); - - -#endif /* __TFTP_H_LOADED */ diff --git a/system/alpha/h/tga.h b/system/alpha/h/tga.h deleted file mode 100644 index d3abb359a..000000000 --- a/system/alpha/h/tga.h +++ /dev/null @@ -1,716 +0,0 @@ -/* - * @DEC_COPYRIGHT@ - */ -/* - * HISTORY - * $Log: tga.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:18 verghese - * current 10/29/97 - * - * Revision 1.1.9.2 1995/04/24 23:34:47 Jeff_Colburn - * Add support for shared interrupts, ISR's now have a return value - * of INTR_SERVICED or INTR_NOT_SERVICED. Changed return type from "void" - * to "int" for interrupt return type in "tga_info_t". - * [1995/04/24 23:24:12 Jeff_Colburn] - * - * Revision 1.1.7.2 1994/11/07 23:31:23 Jeff_Colburn - * Added defines for putting TGA in Copy mode to support console scrolling fix. - * [1994/10/26 22:32:00 Jeff_Colburn] - * - * Revision 1.1.5.5 1994/05/16 19:29:08 Monty_Brandenberg - * Add dma_map_info_t to the info struct. - * [1994/05/12 05:31:19 Monty_Brandenberg] - * - * Revision 1.1.5.4 1994/04/19 21:59:33 Stuart_Hollander - * merge agoshw2 bl5 to gold bl10 - * Revision 1.1.2.4 1994/04/14 20:17:15 Monty_Brandenberg - * T32-88 Framebuffer offset was incorrect causing obscure z buffering - * problems in pex. - * [1994/04/14 19:17:10 Monty_Brandenberg] - * - * Revision 1.1.5.3 1994/04/11 12:58:27 Stuart_Hollander - * Revision 1.1.2.3 1994/02/28 16:53:52 Monty_Brandenberg - * Removed a few magic numbers from the code and made symbolics out of - * them. - * [1994/02/23 21:09:10 Monty_Brandenberg] - * - * Add header files we need to define structures. Added two new ioctls - * to extract direct dma mapping info. SFB+ and TGA ioctl structures - * are now incompatible. Fixed truecolor index and private ioctl code. - * [1994/02/04 21:10:07 Monty_Brandenberg] - * - * Removed two interrupt sources as per spec. Fixed the RAMDAC access - * macros to actually work. Imagine. - * [1994/02/02 23:16:55 Monty_Brandenberg] - * - * Converted to use io_handles. Needs work on DMA - * [1994/01/07 21:14:33 Monty_Brandenberg] - * - * Added support for 24-plane option using BT463 and custom cursor chip. - * Converted to fully prototyped functions. Started conversion to - * io_handle structure. - * [1994/01/06 21:15:14 Monty_Brandenberg] - * - * Revision 1.1.5.2 1994/01/23 21:16:19 Stuart_Hollander - * merge from hw2 to goldbl8 - * [1993/12/29 12:57:23 Stuart_Hollander] - * - * Revision 1.1.2.2 1993/12/21 13:42:28 Monty_Brandenberg - * Initial version of the TGA device driver. - * [1993/12/14 00:22:06 Monty_Brandenberg] - * - * $EndLog$ - */ -/* - * @(#)$RCSfile: tga.h,v $ $Revision: 1.1.1.1 $ (DEC) $Date: 1997/10/30 23:27:18 $ - */ - -/************************************************************************ - * * - * Copyright (c) 1993 by * - * Digital Equipment Corporation, Maynard, MA * - * All rights reserved. * - * * - * This software is furnished under a license and may be used and * - * copied only in accordance with the terms of such license and * - * with the inclusion of the above copyright notice. This * - * software or any other copies thereof may not be provided or * - * otherwise made available to any other person. No title to and * - * ownership of the software is hereby transferred. * - * * - * The information in this software is subject to change without * - * notice and should not be construed as a commitment by Digital * - * Equipment Corporation. * - * * - * Digital assumes no responsibility for the use or reliability * - * of its software on equipment which is not supplied by Digital. * - * * - ************************************************************************/ - -/* - * RAMDAC is a trademark of Brooktree Corporation - */ - -#ifndef TGA_DEFINED -#define TGA_DEFINED - -/* - * Header files - */ -#if 0 -#include <sys/types.h> -#include <sys/ioctl.h> -#include <sys/workstation.h> -#include <sys/inputdevice.h> -#include <sys/wsdevice.h> -#include <io/common/devdriver.h> -#endif /* 0 */ - -/* - * Special offsets within the PCI configuration header - */ -#define TGA_CONFIG_PVRR_OFFSET 0x00000040 -#define TGA_CONFIG_PAER_OFFSET 0x00000044 - -/* - * PAER values - */ -#define TGA_CONFIG_PAER_32MB 0x00000000 -#define TGA_CONFIG_PAER_64MB 0x00010000 -#define TGA_CONFIG_PAER_128MB 0x00030000 - -/* - * Offsets within Memory Space - */ -#define TGA_ROM_OFFSET 0x000000 -#define TGA_ASIC_OFFSET 0x100000 -#define TGA_RAMDAC_SETUP_OFFSET 0x1000c0 -#define TGA_RAMDAC_DATA_OFFSET 0x1001f0 -#define TGA_XY_REG_OFFSET 0x100074 -#define TGA_VALID_REG_OFFSET 0x100070 - -#define TGA_0_0_FB_OFFSET 0x00200000 -#define TGA_0_0_FB_SIZE 0x00200000 -#define TGA_0_1_FB_OFFSET 0x00400000 -#define TGA_0_1_FB_SIZE 0x00400000 -#define TGA_0_3_FB_OFFSET 0x00800000 -#define TGA_0_3_FB_SIZE 0x00800000 -#define TGA_1_3_FB_OFFSET 0x00800000 -#define TGA_1_3_FB_SIZE 0x00800000 -#define TGA_1_7_FB_OFFSET 0x01000000 -#define TGA_1_7_FB_SIZE 0x01000000 -#define TGA_INVALID_FB_OFFSET 0 -#define TGA_INVALID_FB_SIZE 0 - -/* - * TGA card types - */ -#define TGA_TYPE_T801 0 -#define TGA_TYPE_T802 1 -#define TGA_TYPE_T822 2 -#define TGA_TYPE_T844 3 -#define TGA_TYPE_T3204 4 -#define TGA_TYPE_T3208 5 -#define TGA_TYPE_T3288 6 -#define TGA_TYPE_INVALID 7 -#define TGA_TYPE_NUM 8 - -#ifndef NDEPTHS -#define NDEPTHS 1 /* all current hardware just has one */ -#define NVISUALS 1 -#endif /* NDEPTHS */ - -typedef unsigned char tga_pix8_t; -typedef unsigned int tga_pix32_t; -typedef unsigned int tga_reg_t; - -/* - * Window tags definitions - */ -#define TGA_TRUECOLOR_WID_INDEX 0xc -#define TGA_TRUECOLOR_WID_MASK 0xc0000000 - -#if 0 -/* - * Device-private ioctls - */ -#define TGA_IOCTL_PRIVATE _IOWR('w', (0|IOC_S), tga_ioc_t) -#define TGA_IOC_LOAD_WINDOW_TAGS 0 -#define TGA_IOC_ENABLE_DMA_OPS 1 -#define TGA_IOC_SET_STEREO_MODE 2 -#define TGA_IOC_GET_STEREO_MODE 3 -#define TGA_IOC_GET_DIRECT_DMA_COUNT 4 -#define TGA_IOC_GET_DIRECT_DMA_INFO 5 - -typedef struct { - char windex; - unsigned char low; - unsigned char mid; - unsigned char high; -} tga_window_tag_cell_t; - -typedef struct { - short ncells; - short start; - tga_window_tag_cell_t *p_cells; -} tga_ioc_window_tag_t; - -typedef struct { - vm_offset_t phys_base; - vm_offset_t bus_base; - vm_size_t map_size; -} tga_dma_map_t; - -typedef struct { - int alloc_map_num; /* input */ - int actual_map_num; /* output */ - tga_dma_map_t *maps; /* input & output */ -} tga_ioc_dma_info_t; - -typedef struct { - short screen; - short cmd; - union { - tga_ioc_window_tag_t window_tag; - unsigned int stereo_mode; -#define TGA_IOC_STEREO_NONE 0 -#define TGA_IOC_STEREO_24 1 - -int direct_dma_count; - tga_ioc_dma_info_t direct_dma_info; - } data; -} tga_ioc_t; -#endif /* 0 */ - -typedef struct { - unsigned deep : 1; - unsigned mbz0 : 1; - unsigned mask : 3; - unsigned block : 4; - unsigned col_size : 1; - unsigned sam_size : 1; - unsigned parity : 1; - unsigned write_en : 1; - unsigned ready : 1; - unsigned slow_dac : 1; - unsigned dma_size : 1; - unsigned sync_type : 1; - unsigned mbz1 : 15; -} tga_deep_reg_t; - -#define TGA_DEEP_DEEP_8PLANE 0 -#define TGA_DEEP_DEEP_32PLANE 1 - -#define TGA_DEEP_MASK_4MB 0x00 -#define TGA_DEEP_MASK_8MB 0x01 -#define TGA_DEEP_MASK_16MB 0x03 -#define TGA_DEEP_MASK_32MB 0x07 - -#define TGA_DEEP_PARITY_ODD 0 -#define TGA_DEEP_PARITY_EVEN 1 - -#define TGA_DEEP_READY_ON_8 0 -#define TGA_DEEP_READY_ON_2 1 - -#define TGA_DEEP_DMA_64 0 -#define TGA_DEEP_DMA_128 1 - -typedef struct { - unsigned s_wr_mask : 8; - unsigned s_rd_mask : 8; - unsigned s_test : 3; - unsigned s_fail : 3; - unsigned d_fail : 3; - unsigned d_pass : 3; - unsigned z_test : 3; - unsigned z : 1; -} tga_stencil_mode_reg_t; - -#define TGA_SM_TEST_GEQ 0x00 -#define TGA_SM_TEST_TRUE 0x01 -#define TGA_SM_TEST_FALSE 0x02 -#define TGA_SM_TEST_LS 0x03 -#define TGA_SM_TEST_EQ 0x04 -#define TGA_SM_TEST_LEQ 0x05 -#define TGA_SM_TEST_GT 0x06 -#define TGA_SM_TEST_NEQ 0x07 - -#define TGA_SM_RESULT_KEEP 0x00 -#define TGA_SM_RESULT_ZERO 0x01 -#define TGA_SM_RESULT_REPLACE 0x02 -#define TGA_SM_RESULT_INCR 0x03 -#define TGA_SM_RESULT_DECR 0x04 -#define TGA_SM_RESULT_INV 0x05 - -#define TGA_SM_Z_REPLACE 0 -#define TGA_SM_Z_KEEP 1 - -typedef struct { - unsigned mode : 8; - unsigned visual : 3; - unsigned rotate : 2; - unsigned line : 1; - unsigned z16 : 1; - unsigned cap_ends : 1; - unsigned mbz : 16; -} tga_mode_reg_t; - -#define TGA_MODE_MODE_SIMPLE 0x00 -#define TGA_MODE_MODE_Z_SIMPLE 0x10 -#define TGA_MODE_MODE_OPA_STIP 0x01 -#define TGA_MODE_MODE_OPA_FILL 0x21 -#define TGA_MODE_MODE_TRA_STIP 0x05 -#define TGA_MODE_MODE_TRA_FILL 0x25 -#define TGA_MODE_MODE_TRA_BLK_STIP 0x0d -#define TGA_MODE_MODE_TRA_BLK_FILL 0x2d -#define TGA_MODE_MODE_OPA_LINE 0x02 -#define TGA_MODE_MODE_TRA_LINE 0x06 -#define TGA_MODE_MODE_CINT_TRA_LINE 0x0e -#define TGA_MODE_MODE_CINT_TRA_DITH_LINE 0x2e -#define TGA_MODE_MODE_Z_OPA_LINE 0x12 -#define TGA_MODE_MODE_Z_TRA_LINE 0x16 -#define TGA_MODE_MODE_Z_CINT_OPA_LINE 0x1a -#define TGA_MODE_MODE_Z_SINT_OPA 0x5a -#define TGA_MODE_MODE_Z_CINT_OPA_DITH_LINE 0x3a -#define TGA_MODE_MODE_Z_CINT_TRA_LINE 0x1e -#define TGA_MODE_MODE_Z_SINT_TRA 0x5e -#define TGA_MODE_MODE_Z_CINT_TRA_DITH_LINE 0x3e -#define TGA_MODE_MODE_COPY 0x07 -#define TGA_MODE_MODE_COPY24 0x307 -#define TGA_MODE_MODE_DMA_READ 0x17 -#define TGA_MODE_MODE_DMA_READ_DITH 0x37 -#define TGA_MODE_MODE_DMA_WRITE 0x1f - -#define TGA_MODE_VISUAL_8_PACKED 0x00 -#define TGA_MODE_VISUAL_8_UNPACKED 0x01 -#define TGA_MODE_VISUAL_12_LOW 0x02 -#define TGA_MODE_VISUAL_12_HIGH 0x06 -#define TGA_MODE_VISUAL_24 0x03 - -#define TGA_MODE_PM_IS_PERS 0x00800000 -#define TGA_MODE_ADDR_IS_NEW 0x00400000 -#define TGA_MODE_BRES3_IS_NEW 0x00200000 -#define TGA_MODE_COPY_WILL_DRAIN 0x00100000 - -typedef struct { - unsigned opcode : 4; - unsigned mbz : 4; - unsigned visual : 2; - unsigned rotate : 2; -} tga_raster_op_t; - -#define TGA_ROP_OP_CLEAR 0 -#define TGA_ROP_OP_AND 1 -#define TGA_ROP_OP_AND_REVERSE 2 -#define TGA_ROP_OP_COPY 3 -#define TGA_ROP_OP_COPY24 0x303 -#define TGA_ROP_OP_AND_INVERTED 4 -#define TGA_ROP_OP_NOOP 5 -#define TGA_ROP_OP_XOR 6 -#define TGA_ROP_OP_OR 7 -#define TGA_ROP_OP_NOR 8 -#define TGA_ROP_OP_EQUIV 9 -#define TGA_ROP_OP_INVERT 10 -#define TGA_ROP_OP_OR_REVERSE 11 -#define TGA_ROP_OP_COPY_INVERTED 12 -#define TGA_ROP_OP_OR_INVERTED 13 -#define TGA_ROP_OP_NAND 14 -#define TGA_ROP_OP_SET 15 - -#define TGA_ROP_VISUAL_8_PACKED 0x00 -#define TGA_ROP_VISUAL_8_UNPACKED 0x01 -#define TGA_ROP_VISUAL_12 0x02 -#define TGA_ROP_VISUAL_24 0x03 - -#define TGA_INTR_VSYNC 0x00000001 -#define TGA_INTR_SHIFT_ADDR 0x00000002 -#define TGA_INTR_TIMER 0x00000010 -#define TGA_INTR_ALL 0x00000013 -#define TGA_INTR_ENABLE_SHIFT 16 - -#define TGA_RAMDAC_INTERF_WRITE_SHIFT 0 -#define TGA_RAMDAC_INTERF_READ0_SHIFT 16 -#define TGA_RAMDAC_INTERF_READ1_SHIFT 24 - -#define TGA_RAMDAC_485_READ 0x01 -#define TGA_RAMDAC_485_WRITE 0x00 - -#define TGA_RAMDAC_485_ADDR_PAL_WRITE 0x00 -#define TGA_RAMDAC_485_DATA_PAL 0x02 -#define TGA_RAMDAC_485_PIXEL_MASK 0x04 -#define TGA_RAMDAC_485_ADDR_PAL_READ 0x06 -#define TGA_RAMDAC_485_ADDR_CUR_WRITE 0x08 -#define TGA_RAMDAC_485_DATA_CUR 0x0a -#define TGA_RAMDAC_485_CMD_0 0x0c -#define TGA_RAMDAC_485_ADDR_CUR_READ 0x0e -#define TGA_RAMDAC_485_CMD_1 0x10 -#define TGA_RAMDAC_485_CMD_2 0x12 -#define TGA_RAMDAC_485_STATUS 0x14 -#define TGA_RAMDAC_485_CMD_3 0x14 -#define TGA_RAMDAC_485_CUR_RAM 0x16 -#define TGA_RAMDAC_485_CUR_LOW_X 0x18 -#define TGA_RAMDAC_485_CUR_HIGH_X 0x1a -#define TGA_RAMDAC_485_CUR_LOW_Y 0x1c -#define TGA_RAMDAC_485_CUR_HIGH_Y 0x1e - -#define TGA_RAMDAC_485_ADDR_EPSR_SHIFT 0 -#define TGA_RAMDAC_485_ADDR_EPDR_SHIFT 8 - -#define TGA_RAMDAC_463_HEAD_MASK 0x01 -#define TGA_RAMDAC_463_READ 0x02 -#define TGA_RAMDAC_463_WRITE 0x00 -#define TGA_RAMDAC_463_ADDR_LOW 0x00 -#define TGA_RAMDAC_463_ADDR_HIGH 0x04 -#define TGA_RAMDAC_463_CMD_CURS 0x08 -#define TGA_RAMDAC_463_CMD_CMAP 0x0c - -#define TGA_RAMDAC_463_ADDR_EPSR_SHIFT 0 -#define TGA_RAMDAC_463_ADDR_EPDR_SHIFT 8 - -#define TGA_RAMDAC_463_CURSOR_COLOR0 0x0100 -#define TGA_RAMDAC_463_CURSOR_COLOR1 0x0101 -#define TGA_RAMDAC_463_COMMAND_REG_0 0x0201 -#define TGA_RAMDAC_463_COMMAND_REG_1 0x0202 -#define TGA_RAMDAC_463_COMMAND_REG_2 0x0203 -#define TGA_RAMDAC_463_READ_MASK 0x0205 -#define TGA_RAMDAC_463_BLINK_MASK 0x0209 -#define TGA_RAMDAC_463_WINDOW_TYPE_TABLE 0x0300 - -typedef union { - struct { - unsigned int pixels : 9; - unsigned int front_porch : 5; - unsigned int sync : 7; - unsigned int back_porch : 7; - unsigned int ignore : 3; - unsigned int odd : 1; - } horizontal_setup; - unsigned int h_setup; -} tga_horizontal_setup_t; - -typedef union { - struct { - unsigned int scan_lines : 11; - unsigned int front_porch : 5; - unsigned int sync : 6; - unsigned int back_porch : 6; - } vertical_setup; - unsigned int v_setup; -} tga_vertical_setup_t; - -typedef volatile struct { - tga_reg_t buffer[8]; - -tga_reg_t foreground; -tga_reg_t background; -tga_reg_t planemask; -tga_reg_t pixelmask; -tga_reg_t mode; -tga_reg_t rop; -tga_reg_t shift; -tga_reg_t address; - -tga_reg_t bres1; -tga_reg_t bres2; -tga_reg_t bres3; -tga_reg_t brescont; -tga_reg_t deep; -tga_reg_t start; -tga_reg_t stencil_mode; -tga_reg_t pers_pixelmask; - -tga_reg_t cursor_base_address; -tga_reg_t horizontal_setup; -tga_reg_t vertical_setup; - -#define TGA_VERT_STEREO_EN 0x80000000 -tga_reg_t base_address; -tga_reg_t video_valid; - -#define TGA_VIDEO_VALID_SCANNING 0x00000001 -#define TGA_VIDEO_VALID_BLANK 0x00000002 -#define TGA_VIDEO_VALID_CURSOR_ENABLE 0x00000004 -tga_reg_t cursor_xy; -tga_reg_t video_shift_addr; -tga_reg_t intr_status; - -tga_reg_t pixel_data; -tga_reg_t red_incr; -tga_reg_t green_incr; -tga_reg_t blue_incr; -tga_reg_t z_incr_low; -tga_reg_t z_incr_high; -tga_reg_t dma_address; -tga_reg_t bres_width; - -tga_reg_t z_value_low; -tga_reg_t z_value_high; -tga_reg_t z_base_address; -tga_reg_t address2; -tga_reg_t red_value; -tga_reg_t green_value; -tga_reg_t blue_value; -tga_reg_t _jnk12; - -tga_reg_t ramdac_setup; -struct { - tga_reg_t junk; -} _junk[8 * 2 - 1]; - -struct { - tga_reg_t data; -} slope_no_go[8]; - -struct { - tga_reg_t data; -} slope[8]; - -tga_reg_t bm_color_0; -tga_reg_t bm_color_1; -tga_reg_t bm_color_2; -tga_reg_t bm_color_3; -tga_reg_t bm_color_4; -tga_reg_t bm_color_5; -tga_reg_t bm_color_6; -tga_reg_t bm_color_7; - -tga_reg_t c64_src; -tga_reg_t c64_dst; -tga_reg_t c64_src2; -tga_reg_t c64_dst2; -tga_reg_t _jnk45; -tga_reg_t _jnk46; -tga_reg_t _jnk47; -tga_reg_t _jnk48; - -struct { - tga_reg_t junk; -} _junk2[8 * 3]; - -tga_reg_t eprom_write; -tga_reg_t _res0; -tga_reg_t clock; -tga_reg_t _res1; -tga_reg_t ramdac; -tga_reg_t _res2; -tga_reg_t command_status; -tga_reg_t command_status2; - -} - tga_rec_t, *tga_ptr_t; - -#if 0 -typedef struct { - ws_screen_descriptor screen; /* MUST be first!!! */ - ws_depth_descriptor depth[NDEPTHS]; - ws_visual_descriptor visual[NVISUALS]; - ws_cursor_functions cf; - ws_color_map_functions cmf; - ws_screen_functions sf; - int (*attach)(); - int (*bootmsg)(); - int (*map)(); - int (*interrupt)(); - int (*setup)(); - vm_offset_t base; - tga_ptr_t asic; - vm_offset_t fb; - size_t fb_size; - unsigned int bt485_present; - unsigned int bits_per_pixel; - unsigned int core_size; - unsigned int paer_value; - tga_reg_t deep; - tga_reg_t head_mask; - tga_reg_t refresh_count; - tga_reg_t horizontal_setup; - tga_reg_t vertical_setup; - tga_reg_t base_address; - caddr_t info_area; - vm_offset_t virtual_dma_buffer; - vm_offset_t physical_dma_buffer; - int wt_min_dirty; - int wt_max_dirty; - int wt_dirty; - tga_window_tag_cell_t wt_cell[16]; /* magic number */ - unsigned int stereo_mode; - io_handle_t io_handle; - dma_map_info_t p_map_info; -} tga_info_t; - -#define TGA_USER_MAPPING_COUNT 4 - -typedef struct { - vm_offset_t fb_alias_increment; - vm_offset_t option_base; - unsigned int planemask; - vm_offset_t virtual_dma_buffer; - vm_offset_t physical_dma_buffer; -} tga_server_info_t; -#endif /* 0 */ - -typedef struct { - unsigned char dirty_cell; - unsigned char red; /* only need 8 bits */ - unsigned char green; - unsigned char blue; -} tga_bt485_color_cell_t; - -typedef struct { - volatile unsigned int *setup; - volatile unsigned int *data; - unsigned int head_mask; - short fb_xoffset; - short fb_yoffset; - short min_dirty; - short max_dirty; - caddr_t reset; - u_int mask; -} tga_bt485_type_t; - -#if 0 -typedef struct { - volatile unsigned int *setup; - volatile unsigned int *data; - unsigned int head_mask; - short fb_xoffset; - short fb_yoffset; - short min_dirty; - short max_dirty; - caddr_t reset; - u_int mask; - - /*************************************************************** fields - * above this line MUST match struct bt485type - * exactly!***************************************************************/ - u_int unit; - char screen_on; - char on_off; - char dirty_cursor; - char dirty_colormap; - short x_hot; - short y_hot; - ws_color_cell cursor_fg; - ws_color_cell cursor_bg; - void (*enable_interrupt)(); - u_long bits[256]; - tga_bt485_color_cell_t cells[256]; -} tga_bt485_info_t; -#endif /* 0 */ - -#define TGA_RAMDAC_463_WINDOW_TAG_COUNT 16 -#define TGA_RAMDAC_463_CMAP_ENTRY_COUNT 528 - -typedef struct { - unsigned char dirty_cell; - unsigned char red; - unsigned char green; - unsigned char blue; -} tga_bt463_color_cell_t; - -typedef struct { - unsigned char low_byte; - unsigned char middle_byte; - unsigned char high_byte; - unsigned char unused; -} tga_bt463_wid_cell_t; - -typedef struct { - volatile unsigned int *setup; - volatile unsigned int *data; - unsigned int head_mask; - short fb_xoffset; - short fb_yoffset; -} tga_bt463_type_t; - -#if 0 -typedef struct { - volatile unsigned int *setup; - volatile unsigned int *data; - unsigned int head_mask; - short fb_xoffset; - short fb_yoffset; - char type; - char screen_on; - char dirty_colormap; - char dirty_cursormap; - int unit; - void (*enable_interrupt)(); - caddr_t cursor_closure; - ws_color_cell cursor_fg; - ws_color_cell cursor_bg; - short min_dirty; - short max_dirty; - tga_bt463_color_cell_t cells[TGA_RAMDAC_463_CMAP_ENTRY_COUNT]; -} tga_bt463_info_t; -#endif /* 0 */ - -typedef struct { - volatile unsigned int *xy_reg; - volatile unsigned int *valid; - short fb_xoffset; - short fb_yoffset; -} tga_curs_type_t; - -#if 0 -typedef struct { - volatile unsigned int *xy_reg; - volatile unsigned int *valid; - short fb_xoffset; - short fb_yoffset; - u_int unit; - char on_off; - char dirty_cursor; - char dirty_cursormap; - short x_hot; - short y_hot; - short last_row; - ws_color_cell cursor_fg; - ws_color_cell cursor_bg; - void (*enable_interrupt)(); - unsigned int bits[256]; -} tga_curs_info_t; -#endif /* 0 */ - -#endif /* TGA_DEFINED */ - diff --git a/system/alpha/h/tga_crystal.h b/system/alpha/h/tga_crystal.h deleted file mode 100644 index 060c78e80..000000000 --- a/system/alpha/h/tga_crystal.h +++ /dev/null @@ -1,760 +0,0 @@ -#define OPTION_130 0 -#define OPTION_119 1 -#define OPTION_108 2 -#define OPTION_104 3 -#define OPTION_92 4 -#define OPTION_75 5 -#define OPTION_74 6 -#define OPTION_69 7 -#define OPTION_65 8 -#define OPTION_50 9 -#define OPTION_40 10 -#define OPTION_32 11 -#define OPTION_25 12 -#define OPTION_135 13 -#define OPTION_110 14 - -#define PIXEL_BIAS 0 - -struct isc_data { - unsigned char data[56]; -}; - - -typedef struct isc_data ISC; - -struct monitor_data { - int option; - int monitor_rows; - int monitor_columns; - int sold_freq; - int refresh_rate; - int v_scanlines; - int v_front_porch; - int v_sync; - int v_back_porch; - int d_pixels; - int h_pixels; - int h_front_porch; - int h_sync; - int h_back_porch; - int cursor_x; - int cursor_y; - ISC isc_data; -}; - -static struct monitor_data crystal_table[] = -{ -{ - /* 130.808 Mhz */ -OPTION_130, /* Option number 1 */ -1024, /* rows */ -1280, /* columns */ -130, /* 130.8 Mhz */ -72, /* refresh rate */ -1024, /* v scanlines */ -3, /* v front porch */ -3, /* v sync */ -33, /* v back porch */ -1280, /* display pixels */ -1280, /* h pixels */ -32, /* h front porch */ -160, /* h sync */ -224, /* h back porch */ -0, /* cursor x placeholder */ -0, /* cursor y placeholder */ - - /* ISC serial load information */ - -{ -1,0,0, /* 0:2 N1 modulus */ -0,0, /* 3:4 set to zero */ -0, /* 5 tristates PLL */ -0, /* 6 toggle for ramdac reset */ -0, /* 7 1 to pass reference frequency */ -0, /* 8 1 for N1 and N2 dividers */ -0, /* 9 VRAM shift clock enable */ -0, /* 10 External PLL feedback */ -0, /* 11 phase detect reset */ -0,0, /* 12:13 PLL post scaler bits */ -0, /* 14 aux clock differential */ -0, /* 15 auxen clock mode */ -1,0,0,0,0,0,0,0, /* 16:23 N2 modulus */ -1,0,1, /* 24:26 sets the gain of VCO */ -0, /* 27 bit 28 for N2 */ -0,1, /* 28:29 sets gain of phase detector */ -0, /* 30 reserved */ -0, /* 31 phase detector timing */ -0,0,0,0,0,1, /* 32:37 M counter bits */ -0, /* 38 reserved */ -0, /* 39 doubles the modulus prescale */ -1,1,0,0, /* 40:43 A counter */ -0,0,0,0, /* 44:47 reserved */ -1,0,1,0,1,0,0, /* 48:54 Reference divider */ -0, /* 55 reserved */ -} -}, -{ /* 119.84 Mhz */ -OPTION_119, /* Option number 2 */ -1024, /* rows */ -1280, /* columns */ -119, /* 119 Mhz */ -66, /* refresh rate */ -1024, /* v scanlines */ -3, /* v front porch */ -3, /* v sync */ -33, /* v back porch */ -1280, /* display pixels */ -1280, /* h pixels */ -32, /* h front porch */ -160, /* h sync */ -224, /* h back porch */ -0, /* cursor x placeholder */ -0, /* cursor y placeholder */ - -{ -1,0,0, /* 0:2 N1 modulus */ -0,0, /* 3:4 set to zero */ -0, /* 5 tristates PLL */ -0, /* 6 toggle for ramdac reset */ -0, /* 7 1 to pass reference frequency */ -0, /* 8 1 for N1 and N2 dividers */ -0, /* 9 VRAM shift clock enable */ -0, /* 10 External PLL feedback */ -0, /* 11 phase detect reset */ -0,0, /* 12:13 PLL post scaler bits */ -0, /* 14 aux clock differential */ -0, /* 15 auxen clock mode */ -1,0,0,0,0,0,0,0, /* 16:23 N2 modulus */ -0,0,1, /* 24:26 sets the gain of VCO */ -0, /* 27 bit 28 for N2 */ -0,1, /* 28:29 sets gain of phase detector */ -0, /* 30 reserved */ -0, /* 31 phase detector timing */ -1,0,0,1,1,0, /* 32:37 M counter bits */ -0, /* 38 reserved */ -0, /* 39 doubles the modulus prescale */ -1,1,0,0, /* 40:43 A counter */ -0,0,0,0, /* 44:47 reserved */ -0,1,0,0,1,0,0, /* 48:54 Reference divider */ -0, /* 55 reserved */ -} -}, -{ /* 108.18 Mhz */ -OPTION_108, -1024, /* rows */ -1280, /* columns */ -108, /* 108 Mhz */ -60, /* refresh rate */ -1024, /* v scanlines */ -3, /* v front porch */ -3, /* v sync */ -26, /* v back porch */ -1280, /* display pixels */ -1280, /* h pixels */ -44, /* h front porch */ -184, /* h sync */ -200, /* h back porch */ -0, /* cursor x placeholder */ -0, /* cursor y placeholder */ - /* ISC serial load information */ - -{ -1,0,0, /* 0:2 N1 modulus */ -0,0, /* 3:4 set to zero */ -0, /* 5 tristates PLL */ -0, /* 6 toggle for ramdac reset */ -0, /* 7 1 to pass reference frequency */ -0, /* 8 1 for N1 and N2 dividers */ -0, /* 9 VRAM shift clock enable */ -0, /* 10 External PLL feedback */ -0, /* 11 phase detect reset */ -0,0, /* 12:13 PLL post scaler bits */ -0, /* 14 aux clock differential */ -0, /* 15 auxen clock mode */ -1,0,0,0,0,0,0,0, /* 16:23 N2 modulus */ -0,0,1, /* 24:26 sets the gain of VCO */ -0, /* 27 bit 28 for N2 */ -0,1, /* 28:29 sets gain of phase detector */ -0, /* 30 reserved */ -0, /* 31 phase detector timing */ -1,0,1,0,1,0, /* 32:37 M counter bits */ -0, /* 38 reserved */ -0, /* 39 doubles the modulus prescale */ -0,0,1,0, /* 40:43 A counter */ -0,0,0,0, /* 44:47 reserved */ -1,0,0,0,1,0,0, /* 48:54 Reference divider */ -0, /* 55 reserved */ -} -}, -{ /* 104.00 Mhz */ -OPTION_104, -900, /* rows */ -1152, /* columns */ -104, /* 104 Mhz */ -72, /* refresh rate */ -900, /* v scanlines */ -6, /* v front porch */ -10, /* v sync */ -44, /* v back porch */ -1152, /* display pixels */ -1152, /* h pixels */ -64, /* h front porch */ -112, /* h sync */ -176, /* h back porch */ -0, /* cursor x placeholder */ -0, /* cursor y placeholder */ - /* ISC serial load information */ - -{ -1,0,0, /* 0:2 N1 modulus */ -0,0, /* 3:4 set to zero */ -0, /* 5 tristates PLL */ -0, /* 6 toggle for ramdac reset */ -0, /* 7 1 to pass reference frequency */ -0, /* 8 1 for N1 and N2 dividers */ -0, /* 9 VRAM shift clock enable */ -0, /* 10 External PLL feedback */ -0, /* 11 phase detect reset */ -0,0, /* 12:13 PLL post scaler bits */ -0, /* 14 aux clock differential */ -0, /* 15 auxen clock mode */ -1,0,0,0,0,0,0,0, /* 16:23 N2 modulus */ -0,0,1, /* 24:26 sets the gain of VCO */ -0, /* 27 bit 28 for N2 */ -0,1, /* 28:29 sets gain of phase detector */ -0, /* 30 reserved */ -0, /* 31 phase detector timing */ -1,0,1,0,1,0, /* 32:37 M counter bits */ -0, /* 38 reserved */ -0, /* 39 doubles the modulus prescale */ -0,1,1,0, /* 40:43 A counter */ -0,0,0,0, /* 44:47 reserved */ -0,1,0,0,1,0,0, /* 48:54 Reference divider */ -0, /* 55 reserved */ -} -}, -{ /* 92.98 Mhz */ -OPTION_92, -900, /* rows */ -1152, /* columns */ -92, /* 92.98 Mhz */ -66, /* refresh rate */ -900, /* v scanlines */ -2, /* v front porch */ -4, /* v sync */ -31, /* v back porch */ -1152, /* display pixels */ -1152, /* h pixels */ -20, /* h front porch */ -132, /* h sync */ -200, /* h back porch */ -0, /* cursor x placeholder */ -0, /* cursor y placeholder */ - - /* ISC serial load information */ - -{ -1,0,0, /* 0:2 N1 modulus */ -0,0, /* 3:4 set to zero */ -0, /* 5 tristates PLL */ -0, /* 6 toggle for ramdac reset */ -0, /* 7 1 to pass reference frequency */ -0, /* 8 1 for N1 and N2 dividers */ -0, /* 9 VRAM shift clock enable */ -0, /* 10 External PLL feedback */ -0, /* 11 phase detect reset */ -0,0, /* 12:13 PLL post scaler bits */ -0, /* 14 aux clock differential */ -0, /* 15 auxen clock mode */ -1,0,0,0,0,0,0,0, /* 16:23 N2 modulus */ -0,0,1, /* 24:26 sets the gain of VCO */ -0, /* 27 bit 28 for N2 */ -0,1, /* 28:29 sets gain of phase detector */ -0, /* 30 reserved */ -0, /* 31 phase detector timing */ -0,0,1,1,0,0, /* 32:37 M counter bits */ -0, /* 38 reserved */ -0, /* 39 doubles the modulus prescale */ -0,0,0,0, /* 40:43 A counter */ -0,0,0,0, /* 44:47 reserved */ -1,0,1,1,0,0,0, /* 48:54 Reference divider */ -0, /* 55 reserved */ -} -}, -{ /* 75.00 Mhz */ -OPTION_75, -768, /* rows */ -1024, /* columns */ -75, /* 74 Mhz */ -70, /* refresh rate */ -768, /* v scanlines */ -3, /* v front porch */ -6, /* v sync */ -29, /* v back porch */ -1024, /* display pixels */ -1024, /* h pixels */ -24, /* h front porch */ -136, /* h sync */ -144, /* h back porch */ -0, /* cursor x placeholder */ -0, /* cursor y placeholder */ - - /* ISC serial load information */ - -{ -1,0,0, /* 0:2 N1 modulus */ -0,0, /* 3:4 set to zero */ -0, /* 5 tristates PLL */ -0, /* 6 toggle for ramdac reset */ -0, /* 7 1 to pass reference frequency */ -0, /* 8 1 for N1 and N2 dividers */ -0, /* 9 VRAM shift clock enable */ -0, /* 10 External PLL feedback */ -0, /* 11 phase detect reset */ -0,0, /* 12:13 PLL post scaler bits */ -0, /* 14 aux clock differential */ -0, /* 15 auxen clock mode */ -1,0,0,0,0,0,0,0, /* 16:23 N2 modulus */ -0,0,1, /* 24:26 sets the gain of VCO */ -0, /* 27 bit 28 for N2 */ -0,1, /* 28:29 sets gain of phase detector */ -0, /* 30 reserved */ -0, /* 31 phase detector timing */ -1,0,0,0,1,0, /* 32:37 M counter bits */ -0, /* 38 reserved */ -0, /* 39 doubles the modulus prescale */ -0,1,0,0, /* 40:43 A counter */ -0,0,0,0, /* 44:47 reserved */ -0,0,1,0,1,0,0, /* 48:54 Reference divider */ -0, /* 55 reserved */ -} -}, -{ /* 74.37 Mhz */ -OPTION_74, -768, /* rows */ -1024, /* columns */ -74, /* 74 Mhz */ -72, /* refresh rate */ -768, /* v scanlines */ -1, /* v front porch */ -6, /* v sync */ -22, /* v back porch */ -1024, /* display pixels */ -1024, /* h pixels */ -16, /* h front porch */ -128, /* h sync */ -128, /* h back porch */ -0, /* cursor x placeholder */ -0, /* cursor y placeholder */ - - /* ISC serial load information */ - -{ -1,0,0, /* 0:2 N1 modulus */ -0,0, /* 3:4 set to zero */ -0, /* 5 tristates PLL */ -0, /* 6 toggle for ramdac reset */ -0, /* 7 1 to pass reference frequency */ -0, /* 8 1 for N1 and N2 dividers */ -0, /* 9 VRAM shift clock enable */ -0, /* 10 External PLL feedback */ -0, /* 11 phase detect reset */ -0,0, /* 12:13 PLL post scaler bits */ -0, /* 14 aux clock differential */ -0, /* 15 auxen clock mode */ -1,0,0,0,0,0,0,0, /* 16:23 N2 modulus */ -0,0,1, /* 24:26 sets the gain of VCO */ -0, /* 27 bit 28 for N2 */ -0,1, /* 28:29 sets gain of phase detector */ -0, /* 30 reserved */ -0, /* 31 phase detector timing */ -0,1,1,1,1,0, /* 32:37 M counter bits */ -0, /* 38 reserved */ -0, /* 39 doubles the modulus prescale */ -1,0,0,0, /* 40:43 A counter */ -0,0,0,0, /* 44:47 reserved */ -1,1,0,0,0,1,0, /* 48:54 Reference divider */ -0, /* 55 reserved */ -} -}, -{ /* 69 Mhz DEC 72 Hz */ -OPTION_69, /* Option number 3 */ -864, /* rows */ -1024+PIXEL_BIAS, /* columns */ -69, /* 69.x Mhz */ -60, /* refresh rate */ -864, /* v scanlines */ -0, /* v front porch */ -3, /* v sync */ -34, /* v back porch */ -1024, /* display pixels */ -1024+PIXEL_BIAS, /* h pixels */ -12, /* h front porch */ -116, /* h sync */ -128, /* h back porch */ -0, /* cursor x placeholder */ -0, /* cursor y placeholder */ - -{ -1,0,0, /* 0:1 N1 modulus */ -0,0, /* 3:4 set to zero */ -0, /* 5 tristates PLL */ -0, /* 6 toggle for ramdac reset */ -0, /* 7 1 to pass reference frequency */ -0, /* 8 1 for N1 and N2 dividers */ -0, /* 9 VRAM shift clock enable */ -0, /* 10 External PLL feedback */ -0, /* 11 phase detect reset */ -0,0, /* 12:13 PLL post scaler bits */ -0, /* 14 aux clock differential */ -0, /* 15 auxen clock mode */ -1,0,0,0,0,0,0,0, /* 16:23 N2 modulus */ -0,0,1, /* 24:26 sets the gain of VCO */ -0, /* 27 bit 28 for N2 */ -0,1, /* 28:29 sets gain of phase detector */ -0, /* 30 reserved */ -0, /* 31 phase detector timing */ -1,0,1,1,0,0, /* 32:37 M counter bits */ -0, /* 38 reserved */ -0, /* 39 doubles the modulus prescale */ -1,1,0,0, /* 40:43 A counter */ -0,0,0,0, /* 44:47 reserved */ -1,0,0,0,1,0,0, /* 48:54 Reference divider */ -0, /* 55 reserved */ -} -}, -{ /* 65 Mhz */ -OPTION_65, -768, /* rows */ -1024, /* columns */ -65, /* 65 Mhz */ -60, /* refresh rate */ -768, /* v scanlines */ -7, /* v front porch */ -9, /* v sync */ -26, /* v back porch */ -1024, /* display pixels */ -1024, /* h pixels */ -56, /* h front porch */ -64, /* h sync */ -200, /* h back porch */ -0, /* cursor x placeholder */ -0, /* cursor y placeholder */ - - /* ISC serial load information */ - -{ -1,0,0, /* 0:2 N1 modulus */ -0,0, /* 3:4 set to zero */ -0, /* 5 tristates PLL */ -0, /* 6 toggle for ramdac reset */ -0, /* 7 1 to pass reference frequency */ -0, /* 8 1 for N1 and N2 dividers */ -0, /* 9 VRAM shift clock enable */ -0, /* 10 External PLL feedback */ -0, /* 11 phase detect reset */ -0,0, /* 12:13 PLL post scaler bits */ -0, /* 14 aux clock differential */ -0, /* 15 auxen clock mode */ -1,0,0,0,0,0,0,0, /* 16:23 N2 modulus */ -0,0,1, /* 24:26 sets the gain of VCO */ -0, /* 27 bit 28 for N2 */ -0,1, /* 28:29 sets gain of phase detector */ -0, /* 30 reserved */ -0, /* 31 phase detector timing */ -0,1,0,0,1,0, /* 32:37 M counter bits */ -0, /* 38 reserved */ -0, /* 39 doubles the modulus prescale */ -0,0,1,0, /* 40:43 A counter */ -0,0,0,0, /* 44:47 reserved */ -1,0,0,1,1,0,0, /* 48:54 Reference divider */ -0, /* 55 reserved */ -} -}, -{ /* 50 Mhz ergo SVGA */ -OPTION_50, -600, /* rows */ -800, /* columns */ -50, /* 50 Mhz */ -72, /* refresh rate */ -600, /* v scanlines */ -31, /* v front porch */ -6, /* v sync */ -29, /* v back porch */ -800 , /* display pixels */ -800, /* h pixels */ -56, /* h front porch */ -120, /* h sync */ -64, /* h back porch */ -0, /* cursor x placeholder */ -0, /* cursor y placeholder */ - /* ISC serial load information */ - -{ -1,0,0, /* 0:2 N1 modulus */ -0,0, /* 3:4 set to zero */ -0, /* 5 tristates PLL */ -0, /* 6 toggle for ramdac reset */ -0, /* 7 1 to pass reference frequency */ -0, /* 8 1 for N1 and N2 dividers */ -0, /* 9 VRAM shift clock enable */ -0, /* 10 External PLL feedback */ -0, /* 11 phase detect reset */ -0,0, /* 12:13 PLL post scaler bits */ -0, /* 14 aux clock differential */ -0, /* 15 auxen clock mode */ -1,0,0,0,0,0,0,0, /* 16:23 N2 modulus */ -0,0,1, /* 24:26 sets the gain of VCO */ -0, /* 27 bit 28 for N2 */ -0,1, /* 28:29 sets gain of phase detector */ -0, /* 30 reserved */ -0, /* 31 phase detector timing */ -1,0,0,0,1,0, /* 32:37 M counter bits */ -0, /* 38 reserved */ -0, /* 39 doubles the modulus prescale */ -1,0,0,0, /* 40:43 A counter */ -0,0,0,0, /* 44:47 reserved */ -0,1,1,1,1,0,0, /* 48:54 Reference divider */ -0, /* 55 reserved */ -} -}, -{ /* 40 Mhz SVGA */ -OPTION_40, -600, /* rows */ -800, /* columns */ -40, /* 36 Mhz */ -60, /* refresh rate */ -600, /* v scanlines */ -1, /* v front porch */ -4, /* v sync */ -23, /* v back porch */ -800, /* display pixels */ -800, /* h pixels */ -40, /* h front porch */ -128, /* h sync */ -88, /* h back porch */ -0, /* cursor x placeholder */ -0, /* cursor y placeholder */ - /* ISC serial load information */ - -{ -1,0,0, /* 0:2 N1 modulus */ -0,0, /* 3:4 set to zero */ -0, /* 5 tristates PLL */ -0, /* 6 toggle for ramdac reset */ -0, /* 7 1 to pass reference frequency */ -0, /* 8 1 for N1 and N2 dividers */ -0, /* 9 VRAM shift clock enable */ -0, /* 10 External PLL feedback */ -0, /* 11 phase detect reset */ -0,0, /* 12:13 PLL post scaler bits */ -0, /* 14 aux clock differential */ -0, /* 15 auxen clock mode */ -1,0,0,0,0,0,0,0, /* 16:23 N2 modulus */ -0,0,1, /* 24:26 sets the gain of VCO */ -0, /* 27 bit 28 for N2 */ -0,1, /* 28:29 sets gain of phase detector */ -0, /* 30 reserved */ -0, /* 31 phase detector timing */ -0,1,1,1,0,0, /* 32:37 M counter bits */ -0, /* 38 reserved */ -0, /* 39 doubles the modulus prescale */ -1,0,1,0, /* 40:43 A counter */ -0,0,0,0, /* 44:47 reserved */ -1,0,0,0,0,1,0, /* 48:54 Reference divider */ -0, /* 55 reserved */ -} -}, -{ /* 31.5 Mhz ergo VGA */ -OPTION_32, -480, /* rows */ -640, /* columns */ -32, /* 32 Mhz */ -72, /* refresh rate */ -480, /* v scanlines */ -9, /* v front porch */ -3, /* v sync */ -28, /* v back porch */ -640, /* display pixels */ -640, /* h pixels */ -24, /* h front porch */ -40, /* h sync */ -128, /* h back porch */ -0, /* cursor x placeholder */ -0, /* cursor y placeholder */ - - /* ISC serial load information */ - -{ -1,0,0, /* 0:2 N1 modulus */ -0,0, /* 3:4 set to zero */ -0, /* 5 tristates PLL */ -0, /* 6 toggle for ramdac reset */ -0, /* 7 1 to pass reference frequency */ -0, /* 8 1 for N1 and N2 dividers */ -0, /* 9 VRAM shift clock enable */ -0, /* 10 External PLL feedback */ -0, /* 11 phase detect reset */ -1,0, /* 12:13 PLL post scaler bits */ -0, /* 14 aux clock differential */ -0, /* 15 auxen clock mode */ -1,0,0,0,0,0,0,0, /* 16:23 N2 modulus */ -0,0,1, /* 24:26 sets the gain of VCO */ -0, /* 27 bit 28 for N2 */ -0,1, /* 28:29 sets gain of phase detector */ -0, /* 30 reserved */ -0, /* 31 phase detector timing */ -1,0,1,1,0,0, /* 32:37 M counter bits */ -0, /* 38 reserved */ -0, /* 39 doubles the modulus prescale */ -0,0,1,0, /* 40:43 A counter */ -0,0,0,0, /* 44:47 reserved */ -1,1,0,0,1,0,0, /* 48:54 Reference divider */ -0, /* 55 reserved */ -} -}, -{ /* 25.175 Mhz VGA */ -OPTION_25, /* Option Information */ -480, /* rows */ -640, /* columns */ -25, /* 25.175 Mhz */ -60, /* refresh rate */ -480, /* v scanlines */ -10, /* v front porch */ -2, /* v sync */ -33, /* v back porch */ -640, /* display pixels */ -640, /* h pixels */ -16, /* h front porch */ -96, /* h sync */ -48, /* h back porch */ -0, /* cursor x placeholder */ -0, /* cursor y placeholder */ - /* ISC serial load information */ - -{ -1,0,0, /* 0:2 N1 modulus */ -0,0, /* 3:4 set to zero */ -0, /* 5 tristates PLL */ -0, /* 6 toggle for ramdac reset */ -0, /* 7 1 to pass reference frequency */ -0, /* 8 1 for N1 and N2 dividers */ -0, /* 9 VRAM shift clock enable */ -0, /* 10 External PLL feedback */ -0, /* 11 phase detect reset */ -1,0, /* 12:13 PLL post scaler bits */ -0, /* 14 aux clock differential */ -0, /* 15 auxen clock mode */ -1,0,0,0,0,0,0,0, /* 16:23 N2 modulus */ -0,0,1, /* 24:26 sets the gain of VCO */ -0, /* 27 bit 28 for N2 */ -0,1, /* 28:29 sets gain of phase detector */ -0, /* 30 reserved */ -0, /* 31 phase detector timing */ -1,0,0,0,1,0, /* 32:37 M counter bits */ -0, /* 38 reserved */ -0, /* 39 doubles the modulus prescale */ -1,0,0,0, /* 40:43 A counter */ -0,0,0,0, /* 44:47 reserved */ -0,1,1,1,1,0,0, /* 48:54 Reference divider */ -0, /* 55 reserved */ -} - }, -{ /* 135 Mhz */ -OPTION_135, /* Option number D */ -1024, /* rows */ -1280, /* columns */ -135, /* 135 Mhz */ -75, /* refresh rate */ -1024, /* v scanlines */ -1, /* v front porch */ -3, /* v sync */ -38, /* v back porch */ -1280, /* display pixels */ -1280, /* h pixels */ -16, /* h front porch */ -144, /* h sync */ -248, /* h back porch */ -0, /* cursor x placeholder */ -0, /* cursor y placeholder */ - - /* ISC serial load information */ - -{ -1,0,0, /* 0:2 N1 modulus */ -0,0, /* 3:4 set to zero */ -0, /* 5 tristates PLL */ -0, /* 6 toggle for ramdac reset */ -0, /* 7 1 to pass reference frequency */ -0, /* 8 1 for N1 and N2 dividers */ -0, /* 9 VRAM shift clock enable */ -0, /* 10 External PLL feedback */ -0, /* 11 phase detect reset */ -0,0, /* 12:13 PLL post scaler bits */ -0, /* 14 aux clock differential */ -0, /* 15 auxen clock mode */ -1,0,0,0,0,0,0,0, /* 16:23 N2 modulus */ -1,0,1, /* 24:26 sets the gain of VCO */ -0, /* 27 bit 28 for N2 */ -0,1, /* 28:29 sets gain of phase detector */ -0, /* 30 reserved */ -0, /* 31 phase detector timing */ -0,0,1,0,1,0, /* 32:37 M counter bits */ -0, /* 38 reserved */ -0, /* 39 doubles the modulus prescale */ -0,1,1,0, /* 40:43 A counter */ -0,0,0,0, /* 44:47 reserved */ -1,0,1,1,0,0,0, /* 48:54 Reference divider */ -0, /* 55 reserved */ -} -}, -{ /* 110 Mhz */ -OPTION_110, /* Option number E */ -1024, /* rows */ -1280, /* columns */ -110, /* 110 Mhz */ -60, /* refresh rate */ -1024, /* v scanlines */ -6, /* v front porch */ -7, /* v sync */ -44, /* v back porch */ -1280, /* display pixels */ -1280, /* h pixels */ -19, /* h front porch */ -163, /* h sync */ -234, /* h back porch */ -0, /* cursor x placeholder */ -0, /* cursor y placeholder */ - - /* ISC serial load information */ - -{ -1,0,0, /* 0:2 N1 modulus */ -0,0, /* 3:4 set to zero */ -0, /* 5 tristates PLL */ -0, /* 6 toggle for ramdac reset */ -0, /* 7 1 to pass reference frequency */ -0, /* 8 1 for N1 and N2 dividers */ -0, /* 9 VRAM shift clock enable */ -0, /* 10 External PLL feedback */ -0, /* 11 phase detect reset */ -0,0, /* 12:13 PLL post scaler bits */ -0, /* 14 aux clock differential */ -0, /* 15 auxen clock mode */ -1,0,0,0,0,0,0,0, /* 16:23 N2 modulus */ -0,0,1, /* 24:26 sets the gain of VCO */ -0, /* 27 bit 28 for N2 */ -0,1, /* 28:29 sets gain of phase detector */ -0, /* 30 reserved */ -0, /* 31 phase detector timing */ -1,1,1,1,0,0, /* 32:37 M counter bits */ -0, /* 38 reserved */ -0, /* 39 doubles the modulus prescale */ -0,0,1,0, /* 40:43 A counter */ -0,0,0,0, /* 44:47 reserved */ -0,0,1,1,0,0,0, /* 48:54 Reference divider */ -0, /* 55 reserved */ -} -} -}; diff --git a/system/alpha/h/tlaserreg.h b/system/alpha/h/tlaserreg.h new file mode 100644 index 000000000..7a8d9d9cc --- /dev/null +++ b/system/alpha/h/tlaserreg.h @@ -0,0 +1,171 @@ +/* $Id: tlaserreg.h,v 1.3 2002/10/27 14:28:17 binkertn Exp $ */ +/* + * Copyright (C) 1998 by the Board of Trustees + * of Leland Stanford Junior University. + * Copyright (C) 1998 Digital Equipment Corporation + * + * This file is part of the SimOS distribution. + * See LICENSE file for terms of the license. + * + */ + +#ifndef __TLASERREG_H__ +#define __TLASERREG_H__ + +/////////////////////////////////////////////////////////////////////// +// +// This file is also included to build the palcode +// + +// Common module defines +#define TLDEV_REG 0x00 +#define TLBER_REG 0x40 +#define TLCNR_REG 0x80 +#define TLFADR0_REG 0x600 +#define TLFADR1_REG 0x640 +#define TLESR0_REG 0x680 +#define TLESR1_REG 0x6c0 +#define TLESR2_REG 0x700 +#define TLESR3_REG 0x740 + +// I/O Module defines +#define TLMMR0_REG 0x200 +#define TLMMR1_REG 0x240 +#define TLMMR2_REG 0x280 +#define TLMMR3_REG 0x2c0 +#define TLMMR4_REG 0x300 +#define TLMMR5_REG 0x340 +#define TLMMR6_REG 0x380 +#define TLMMR7_REG 0x3c0 +#define TLCPUMASK_REG 0x0b00 +#define TLILID0_REG 0xa00 +#define TLILID1_REG 0xa40 +#define TLILID2_REG 0xa80 +#define TLILID3_REG 0xac0 +#define TLMBPR_REG 0xc00 +#define ICCMSR_REG 0x2000 +#define ICCMTR_REG 0x20c0 +#define ICCWTR_REG 0x2100 +#define ICCNSE_REG 0x2040 +#define IDPNSE0_REG 0x2a40 +#define IDPNSE1_REG 0x2140 +#define IDPNSE2_REG 0x2240 +#define IDPNSE3_REG 0x2340 +#define IDPVR_REG 0x2b40 +#define IDPDR0_REG 0x2a80 +#define IDPDR1_REG 0x2180 +#define IDPDR2_REG 0x2280 +#define IDPDR3_REG 0x2380 + +// CPU Module defines +#define CPU0_OFFSET 0x0000 +#define CPU1_OFFSET 0x0040 +#define TLVID_REG 0x00c0 +#define TLDIAG_REG 0x1000 +#define TLMODCONFIG_REG 0x10c0 +#define TLINTRMASK0_REG 0x1100 +#define TLINTRMASK1_REG 0x1140 +#define TLINTRSUM0_REG 0x1180 +#define TLINTRSUM1_REG 0x11c0 +#define TLEPAERR_REG 0x1500 +#define TLEPDERR_REG 0x1540 +#define TLEPMERR_REG 0x1580 +#define TLEP_VMG_REG 0x15c0 +#define TLEPWERR_REG 0x1600 + +// Memory Module defines +#define MCR_REG 0x1880 +#define MIR_REG 0x1840 +#define MDRA_REG 0x1980 +#define MER_REG 0x1940 +#define DDR0_REG 0x10140 +#define DDR1_REG 0x14140 +#define DDR2_REG 0x18140 +#define DDR3_REG 0x1c140 + +// Broadcast defines +#define BROADCAST_NODE 0x18 +#define TLIPINTR_REG 0x40 + +// GBUS defines +#define GBUS_BASE ULL(0xfffffcff90000000) +#define GBUS_BIT_SHIFT 0x06 +#define FLASH_BASE 0x07000000 +#define UART_BASE 0x10000000 +#define WATCH_CSR_BASE 0x20000000 +#define WHATAMI_REG 0x30000000 +#define MISCR_REG 0x34000000 +#define SERNUM_REG 0x37000000 + +// RTC defines +#define RTC_SECOND 0 // second of minute [0..59] +#define RTC_SECOND_ALARM 1 // seconds to alarm +#define RTC_MINUTE 2 // minute of hour [0..59] +#define RTC_MINUTE_ALARM 3 // minutes to alarm +#define RTC_HOUR 4 // hour of day [0..23] +#define RTC_HOUR_ALARM 5 // hours to alarm +#define RTC_DAY_OF_WEEK 6 // day of week [1..7] +#define RTC_DAY_OF_MONTH 7 // day of month [1..31] +#define RTC_MONTH 8 // month of year [1..12] +#define RTC_YEAR 9 // year [00..99] +#define RTC_CONTROL_REGISTERA 10 // control register A +#define RTC_CONTROL_REGISTERB 11 // control register B +#define RTC_CONTROL_REGISTERC 12 // control register C +#define RTC_CONTROL_REGISTERD 13 // control register D +#define RTC_REGNUMBER_RTC_CR1 0x6A // control register 1 + +// Other defines +#define DEVICE_TYPE_TIOP 0x2000 +#define DEVICE_TYPE_MEM 0x4000 +#define DEVICE_TYPE_CPU 0x8000 + + +/////////////////////////////////////////////////////////////////////// +// +// litterals used in the platform_tlaser.s file. +// +// -DBUILD_PALCODE is only defined then. The compilation does include +// this file from the simulation source tree. +// +// It is NOT an obsolete compilation option +// + +#ifdef BUILD_PALCODE + +#define tlep_lintrsum0_offset 0x1180 +#define tlep_lintrsum1_offset 0x11c0 +#define tlep_tlintrsum0_offset tlep_lintrsum0_offset +#define tlep_tlintrsum1_offset tlep_lintrsum1_offset +#define tlep_watch_csrc_offset (RTC_CONTROL_REGISTERC <<GBUS_BIT_SHIFT) + +#define tlsb_tlber TLBER_REG +#define tlsb_tlber_offset tlsb_tlber /* ??? */ +#define tlsb_tldev TLDEV_REG +#define tlsb_tlesr0 TLESR0_REG +#define tlsb_tlesr1 TLESR1_REG +#define tlsb_tlesr2 TLESR2_REG +#define tlsb_tlesr3 TLESR3_REG + + +#define tlsb_tlilid0_offset TLILID0_REG +#define tlsb_tlilid1_offset TLILID1_REG +#define tlsb_tlilid2_offset TLILID2_REG +#define tlsb_tlilid3_offset TLILID3_REG + +#define TLSB_TLIPINTR_OFFSET TLIPINTR_REG + +#endif // BUILD_PALCODE + + + +/////////////////////////////////////////////////////////////////////// +// +// Codes used to probe/clear the TLINTRSUM register +// + +#define TLASER_INTRSUM_UART 1 // uart +#define TLASER_INTRSUM_IPI 0x20 // IPI +#define TLASER_INTRSUM_INTIM 0x40 // clock + +#endif // __TLASERREG_H__ + diff --git a/system/alpha/h/uart.h b/system/alpha/h/uart.h deleted file mode 100644 index 92ab972bb..000000000 --- a/system/alpha/h/uart.h +++ /dev/null @@ -1,108 +0,0 @@ -#ifndef __UART_H_LOADED -#define __UART_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: uart.h,v 1.1.1.1 1997/10/30 23:27:18 verghese Exp $; - */ - -/* - * $Log: uart.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:18 verghese - * current 10/29/97 - * - * Revision 1.1 1995/06/07 04:33:20 berc - * Initial revision - * - * Revision 1.3 1994/08/05 20:13:47 fdh - * Updated Copyright header and RCS $Id: identifier. - * - * Revision 1.2 1994/06/20 14:18:59 fdh - * Fixup header file preprocessor #include conditionals. - * - * Revision 1.1 1993/06/08 19:56:16 fdh - * Initial revision - * - */ - - - -#include "kbdscan.h" - -#define COM1 1 -#define COM2 2 -#define LPT 3 -#define KBD 4 -#define VGA 4 -#define P8514 5 -#define TGA 6 - -#ifdef XXM - -#include <xxm.h> - -#else /* XXM */ - -#define com1Rbr 0x3f8 -#define com1Thr 0x3f8 -#define com1Ier 0x3f9 -#define com1Iir 0x3fa -#define com1Lcr 0x3fb -#define com1Mcr 0x3fc -#define com1Lsr 0x3fd -#define com1Msr 0x3fe -#define com1Scr 0x3ff -#define com1Dll 0x3f8 -#define com1Dlm 0x3f9 - -#define com2Rbr 0x2f8 -#define com2Thr 0x2f8 -#define com2Ier 0x2f9 -#define com2Iir 0x2fa -#define com2Lcr 0x2fb -#define com2Mcr 0x2fc -#define com2Lsr 0x2fd -#define com2Msr 0x2fe -#define com2Scr 0x2ff -#define com2Dll 0x2f8 -#define com2Dlm 0x2f9 - -#define lptDr 0x0 -#define lptSr 0x0 -#define lptCr 0x0 - -#define lptSTB 0x01 -#define lptAFD 0x02 -#define lptnInit 0x04 -#define lptSlct 0x08 -#define lptIrq 0x10 -#define lptDir 0x20 - -#define lptDly 100000 -#endif /* XXM */ - -#endif /* __UART_H_LOADED */ diff --git a/system/alpha/h/udp.h b/system/alpha/h/udp.h deleted file mode 100644 index c7378a943..000000000 --- a/system/alpha/h/udp.h +++ /dev/null @@ -1,197 +0,0 @@ -#ifndef UDP_H_LOADED -#define UDP_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: udp.h,v 1.1.1.1 1997/10/30 23:27:18 verghese Exp $ - */ - -/* - * MODULE DESCRIPTION: - * - * UDP protocol interface for EB64 monitor - * - * HISTORY: - * - * $Log: udp.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:18 verghese - * current 10/29/97 - * - * Revision 1.5 1994/08/05 20:13:47 fdh - * Updated Copyright header and RCS $Id: identifier. - * - * Revision 1.4 1994/06/28 20:08:21 fdh - * Modified filenames and build precedure to fit into a FAT filesystem. - * - * Revision 1.3 1994/06/20 14:18:59 fdh - * Fixup header file preprocessor #include conditionals. - * - * Revision 1.2 1994/01/21 09:45:59 rusling - * Added #ifdef <filename>_H around the module. - * Additionally, any included files are not ifdef'd - * *before* they're included (ie address.h). - * - * Revision 1.1 1993/08/06 10:46:45 berent - * Initial revision - * - * - */ - -#include "address.h" - - -/* udp_init - initialise udp protocol module - * - * Argument: - * device_no - device number on which udp should be enabled. - */ -extern void udp_init(int device_no); - -/* - * Prototype for packet processing functions - * - * Arguments to packet processing functions: - * protocol_data - protocol data passed to module when protocol registered - * device_no - device on which packet was received; - * packet - packet, with UDP header removed; - * size - size of packet; - * source_port - source udp port of packet; - * source_address- source ip address of packet; - * frame_buffer - original buffer containing packet; - * balance_buffer- buffer returned to maintain buffer balance. - * - * DESCRIPTION: - * The packet processing functions process a received protocol packet. To avoid - * buffer shortages they are always passed the buffer containing the packet in - * frame_buffer. They must return either this buffer, or another buffer, in - * balance buffer. The udp module will never access frame_buffer after - * calling a packet processing function; and the protocol modules must not - * access the returned balance_buffer after returning from this function. - * - */ -typedef void (* udp_packet_handler)(void * protocol_data, - int device_no, - unsigned char * packet, - int size, - udp_port source_port, - ip_addr source_address, - unsigned char frame_buffer[ETHER_BUFFER_SIZE], - unsigned char ** balance_buffer); - -/* udp_register_well_known_port - tells the udp module what to do with packets received for a particular - * well known port number. - * - * Arguments: - * - * device_no - device number on which port should be registered. - * port - port to register. - * processing_function - function to process received packets; if NULL cancels registration of protocol. - * protocol_data - arbitrary data to be passed back when a packet is received - * - * Returned value: - * TRUE - protocol registered - * FALSE - unable to register protocol - */ -extern int udp_register_well_known_port(int device_no, - udp_port port, - udp_packet_handler processing_function, - void * protocol_data); - -/* udp_create_new_port - tells the udp module to create a new port; and what to do with data received - * on that port. The created port number will be outside the well known port - * number range. - * - * Arguments: - * - * device_no - device number on which port should be created. - * processing_function - function to process received packets - * protocol_data - arbitrary data to be passed back when a packet is received - * port - returned port number - * - * Returned value: - * TRUE - protocol registered - * FALSE - unable to register protocol - */ -extern int udp_create_port(int device_no, - udp_packet_handler processing_function, - void * protocol_data, - udp_port port); - -/* udp_delete_port - deletes a previously created port - * - * Argument: - * device_no - device number on which port is registered. - * port - port to be deleted. - */ -extern void udp_delete_port(int device_no, udp_port port); - -/* udp_write - sends a packet on a UDP port - * - * Arguments: - * - * device_no - device on which to send the packet - * packet - pointer to data packet to be sent - * destination_port - UDP port to which the packet should be sent - * destination_addr - IP address to which the packet should be sent - * source_port - UDP source port - * size - size of packet - * frame_buffer - buffer containing packet - * balance_buffer - buffer returned to maintain buffer balance - * - * Return values: - * - * TRUE - send successfull - * FALSE - Error occured - * - * DESCRIPTION: - * This function writes an udp data packet to the device. To maintain the caller's - * pool of buffers the driver must give the caller an unused buffer (balance_buffer) - * in return for the buffer containing the frame to be transmitted. - * - * If the send succeeds then frame_buffer must not be accessed by the caller after this - * call. If the send can't be queued then frame_buffer will remain valid and - * the returned value of balance_buffer is undefined and must not be used. - * - */ -extern int udp_write(int device_no, - unsigned char * packet, - udp_port destination_port, - ip_addr destination_addr, - udp_port source_port, - int size, - unsigned char frame_buffer[ETHER_BUFFER_SIZE], - unsigned char ** balance_buffer); - - -/* udp_data_offset - returns the offset at which udp data should be placed in a new ethernet frame - * - * Return value: - * Offset. - */ -extern int udp_data_offset(void); - -#endif /* UDP_H_LOADED */ diff --git a/system/alpha/h/wga.h b/system/alpha/h/wga.h deleted file mode 100644 index e88b9aced..000000000 --- a/system/alpha/h/wga.h +++ /dev/null @@ -1,160 +0,0 @@ -#ifndef _WGA_H_LOADED -#define _WGA_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: wga.h,v 1.1.1.1 1997/10/30 23:27:18 verghese Exp $; - */ - -/* - * $Log: wga.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:18 verghese - * current 10/29/97 - * - * Revision 1.3 1994/08/05 20:13:47 fdh - * Updated Copyright header and RCS $Id: identifier. - * - * Revision 1.2 1994/06/20 14:18:59 fdh - * Fixup header file preprocessor #include conditionals. - * - * Revision 1.1 1993/06/08 19:56:17 fdh - * Initial revision - * - */ - - - -/* ALU to MERGE translation table */ -extern unsigned char mergexlate[]; - -/* Color Palette Registers */ -#define PALMASK 0x02EA -#define PALREAD_ADDR 0x02EB -#define PALWRITE_ADDR 0x02EC -#define PALDATA 0x02ED - -/* Video Timing Registers */ -#define H_TOTAL 0x02E8 /* Horizontal Total */ -#define H_DISP 0x06E8 /* Horizontal Displayed */ -#define H_SYNC_START 0x0AE8 /* Horizontal Sync Start */ -#define H_SYNC_WID 0x0EE8 /* Horizontal Sync Width and Polarity */ -#define V_TOTAL 0x12E8 /* Vertical Total */ -#define V_DISP 0x16E8 /* Vertical Displayed */ -#define V_SYNC_START 0x1AE8 /* Vertical Sync Start */ -#define V_SYNC_WID 0x1EE8 /* Vertical Sync Width and Polarity */ - - -#define DISP_CNTL 0x22E8 /* Display Control */ -#define SUBSYS_CNTL 0x42E8 /* Subsystem Control */ -#define ADVFUNC_CNTL 0x4AE8 /* Advanced Function Control */ -#define SUBSYS_STAT 0x42E8 /* Subsystem Status */ -#define GP_STAT 0x9AE8 /* Graphics Processor Status */ - -/* this block gets the 0x4000 bit turned on */ -#define CUR_Y (0x82E8 | 0x0000) -#define CUR_X (0x86E8 | 0x0000) -#define MULTIFUNC_CNTL (0xBEE8 | 0x0000) -#define ERR_TERM (0x92E8 | 0x0000) -#define DESTY_AXSTP (0x8AE8 | 0x0000) -#define DESTX_DIASTP (0x8EE8 | 0x0000) -#define MAJ_AXIS_PCNT (0x96E8 | 0x0000) -#define FG_COLOR (0xA6E8 | 0x0000) -#define BG_COLOR (0xA2E8 | 0x0000) -#define WR_MASK (0xAAE8 | 0x0000) -#define FG_MIX (0xBAE8 | 0x0000) -#define BG_MIX (0xB6E8 | 0x0000) -#define RD_MASK (0xAEE8 | 0x0000) -#define COLOR_CMP (0xB2E8 | 0x0000) -#define SHORT_STROKE (0x9EE8 | 0x0000) -#define CMD (0x9AE8 | 0x0000) - - -#define PIX_TRANS 0xE2E8 - -#define EXT_FIFO_STAT 0x9AEE - -/************** Command Register (0x9AE8) bit definitions ***************/ -/* - * Bits 15-13 - Drawing Function Command - */ -#define CMD_NOOP 0x0000 -#define CMD_LINE 0x2000 -#define CMD_XRECT 0x4000 -#define CMD_YRECT 0x6000 -#define CMD_FRECT 0x8000 -#define CMD_OUTLINE 0xA000 -#define CMD_COPYRECT 0xC000 -/* - * Bit 12 - Word Byte Order - */ -#define CMD_LSBFIRST 0x1000 -/* - * Bit 9 - Bus Width - */ -#define CMD_WORDBUS 0x0200 -#define CMD_BYTEBUS 0x0000 -/* - * Bit 8 - Variable Data Select - */ -#define CMD_VDATA 0x0100 -#define CMD_FDATA 0x0000 -/* - * Bit 7 - Y Direction - */ -#define CMD_INCY 0x0080 -/* - * Bit 6 - Major Axis - */ -#define CMD_YMAJOR 0x0040 -/* - * Bit 5 - X Direction - */ -#define CMD_INCX 0x0020 -/* - * Bit 4 - Draw Enable - */ -#define CMD_DRAW 0x0010 -/* - * Bit 3 - Coded Direction / Short Stroke - */ -#define CMD_SHORTSTROKE 0x0008 -/* - * Bit 2 - Draw Last Pixel - */ -#define CMD_NOLASTPIXEL 0x0004 -/* - * Bit 1 - Plane Mode - */ -#define CMD_ACROSS 0x0002 -#define CMD_THROUGH 0x0000 -/* - * Bit 0 - Read/Write - */ -#define CMD_WRITE 0x0001 -#define CMD_READ 0x0000 - -#endif /* _WGA_H_LOADED */ diff --git a/system/alpha/h/xlate.h b/system/alpha/h/xlate.h deleted file mode 100644 index f63d0bdfc..000000000 --- a/system/alpha/h/xlate.h +++ /dev/null @@ -1,80 +0,0 @@ -#ifndef __XLATE_H_LOADED -#define __XLATE_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: xlate.h,v 1.1.1.1 1997/10/30 23:27:18 verghese Exp $; - */ - -/* - * $Log: xlate.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:18 verghese - * current 10/29/97 - * - * Revision 1.4 1994/08/05 20:13:47 fdh - * Updated Copyright header and RCS $Id: identifier. - * - * Revision 1.3 1994/06/21 14:56:47 rusling - * fixed up WNT compile warnings. - * - * Revision 1.2 1994/06/20 14:18:59 fdh - * Fixup header file preprocessor #include conditionals. - * - * Revision 1.1 1993/06/08 19:56:17 fdh - * Initial revision - * - */ - - - -#include "kbdscan.h" - -#define MCTRL(x) ((x)&0x1f) - -#define ASCII 0 -#define SCROLL 1 -#define CAPS 2 -#define LSHIFT 3 -#define LCTRL 4 -#define RSHIFT 5 -#define RCTRL 6 -#define IGNORE 7 -#define ALT 8 -#define FUNCTION 9 -#define NUMLOCK 10 -#define NUMPAD 11 -#define UNKNOWN 12 - -typedef struct { - unsigned char unshifted; - unsigned char shifted; - unsigned char char_type; -} xlate_t; - -extern xlate_t xlate[]; - -#endif /* __XLATE_H_LOADED */ diff --git a/system/alpha/h/xxm.h b/system/alpha/h/xxm.h deleted file mode 100644 index aad824435..000000000 --- a/system/alpha/h/xxm.h +++ /dev/null @@ -1,233 +0,0 @@ -#ifndef __XXM_H_LOADED -#define __XXM_H_LOADED -/***************************************************************************** - -Copyright © 1993, Digital Equipment Corporation, Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: xxm.h,v 1.1.1.1 1997/10/30 23:27:18 verghese Exp $; - */ - -/* - * $Log: xxm.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:18 verghese - * current 10/29/97 - * - * Revision 1.3 1996/04/15 16:28:36 berc - * adding PCI ifdefs - * - * Revision 1.1 1995/06/07 03:27:16 berc - * Initial revision - * - */ - -#ifdef XXM - -#define KSEG ((ul)0xfffffc0000000000) -#define PHYS_TO_KSEG(x)(((ul)x) | KSEG) -#define KSEG_TO_PHYS(x)(((ul)x) & ~KSEG) - -#define BANNER "SRC XXX Debug Monitor - Se Habla Peligro" -#define PROMPT "XXX> " - -/**************************************************************************** - * Basic * - ****************************************************************************/ - -#define NEEDPCI -/*#define NEEDDEBUGGER*/ -/*#define NO_ETHERNET*/ -/*#define NEEDWAVELAN*/ -#define NEEDDEPCM -#define NEED21040 -/*#define TRACE_ENABLE*/ - -/**************************************************************************** - * System Address Space * - ****************************************************************************/ - -#define MINIMUM_SYSTEM_MEMORY 0x4000000 /* 64MB */ -#define DMA_BUFF_BASE (KSEG | (ul)0x3000000) /* Ether buffers */ -#define AOUT_LOAD_ADDR (KSEG | (ul)0x2000000) /* Kernel image */ - -/**************************************************************************** - * PCI I/O Address Space * - ****************************************************************************/ - -/* - * Allocate PCI IO space above the 10-bit ISA space - */ -#define PCI_IO_BASE 0x0400 -/* 2 gig + 16mb for slot D + two 16 meg windows for the PCMCIA cards (if any) */ -#define PCI_MEM_BASE (1 << 31) + (3 * (1 << 24)) -/* - * Where does the SROM leave PCMCIA slot D? - */ -#define PCMCIA_SLOT_D_BASE 0x0 - -/* - * ROM definitions. - */ -#ifdef undef -#define NEEDFLASHMEMORY -#define INTEL_28F008SA -#define ROMBASE 0xFFF80000 -#define ROMSIZE 0x100000 -#define ROMINC 0x1 -#endif - -/**************************************************************************** - * PCI I/O Address Space Access * - ****************************************************************************/ - -/* XXM ADDRESS BIT DEFINITIONS - * - * PCI Sparse Memory Space (2GB) - * - * 3 3 3 3|3 3 3 3|3 3 2 2|2 2 2 2|2 2 2 2|1 1 1 1|1 1 1 1|1 1 - * 9 8 7 6|5 4 3 2|1 0 9 8|7 6 5 4|3 2 1 0|9 8 7 6|5 4 3 2|1 0 9 8|7 6 5 4|3 2 1 0 - * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ - * |1|0|0| |A|A|A|A|A|A|A|A|A|A|A|A|A|A|A|A|A|A|A|A|A|A|A|A|A|A|A|A|A|S|S|S|S|0| | | - * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ - * | \_/ \________________________________________________________/ \_____/ | - * | | Address (pA[31] ==1, pA[30..02]) | MBZ - * | +-Space identifier | - * +-- IO space, not cached Transfer Length --+ - * - * - * PCI Sparce Other Space (16MB) - * - * 3 3 3 3|3 3 3 3|3 3 2 2|2 2 2 2|2 2 2 2|1 1 1 1|1 1 1 1|1 1 - * 9 8 7 6|5 4 3 2|1 0 9 8|7 6 5 4|3 2 1 0|9 8 7 6|5 4 3 2|1 0 9 8|7 6 5 4|3 2 1 0 - * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ - * |1|0|1| | | | | |T|T|T|A|A|A|A|A|A|A|A|A|A|A|A|A|A|A|A|A|A|A|A|A|A|S|S|S|S|0| | | - * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ - * | \_/ \___/ \_________________________________________/ \_____/ | - * | | | Address (pA[31..24] == 0 pA[23..02]) | MBZ - * | +-Space +x00 - memory, x01 - I/O x10 - Type0, x11 - Type1 | - * +-- IO space, not cached Transfer Length --+ - * - * - * PCI Dense Memory Space (2GB) - * - * 3 3 3 3|3 3 3 3|3 3 2 2|2 2 2 2|2 2 2 2|1 1 1 1|1 1 1 1|1 1 - * 9 8 7 6|5 4 3 2|1 0 9 8|7 6 5 4|3 2 1 0|9 8 7 6|5 4 3 2|1 0 9 8|7 6 5 4|3 2 1 0 - * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ - * |1|1|0| | | | | | |A|A|A|A|A|A|A|A|A|A|A|A|A|A|A|A|A|A|A|A|A|A|A|A|A|A|A|A|A| | | - * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ - * | \_/ \________________________________________________________/ - * | | Address (pA[31] ==1, pA[30..02]) - * | +-Space identifier - * +-- IO space, not cached - * - */ - -#define BYTE_ENABLE_SHIFT 5 -#define TRANSFER_LENGTH_SHIFT 3 -#define IO_MASK 0xffffff /* IO mask is 24 bits */ -#define PCI_MEM ((ul)0x400<<29) /* CPU Adr[39:29]=0x400 select PCI Mem. */ -#define PCI_IO ((ul)0x501<<29) /* CPU Adr[39:29]=0x501 select PCI I/O. */ -#define PCI_CFG0 ((ul)0x502<<29) /* CPU Adr[39:29]=0x502 select PCI Cfg. */ -#define PCI_CFG1 ((ul)0x503<<29) /* CPU Adr[39:29]=0x503 select PCI Cfg. */ - -#define PCI_MEM_BITS(a) ((PCI_MEM >> BYTE_ENABLE_SHIFT) | a) -#define PCI_IO_BITS(a) ((PCI_IO >> BYTE_ENABLE_SHIFT) | a) -#define PCI_CFG0_BITS(a) ((PCI_CFG0 >> BYTE_ENABLE_SHIFT) | a) -#define PCI_CFG1_BITS(a) ((PCI_CFG1 >> BYTE_ENABLE_SHIFT) | a) - -/**************************************************************************** - * Slot D Physical Address Map * - ****************************************************************************/ - -#define SLOT_D_ROM PCI_MEM_BITS(0x000000) -#define SLOT_D_AUDIO_RAM PCI_MEM_BITS(0x100000) -#define SLOT_D_KEYBOARD PCI_MEM_BITS(0x120000) -#define SLOT_D_AUDIO_CODEC PCI_MEM_BITS(0x130000) -#define SLOT_D_COM1 PCI_MEM_BITS(0x140000) -#define SLOT_D_COM2 PCI_MEM_BITS(0x150000) -#define SLOT_D_CLOCK_ADDR PCI_MEM_BITS(0x160000) -#define SLOT_D_CLOCK_DATA PCI_MEM_BITS(0x170000) -#define SLOT_D_PCI_ERROR_REGISTER PCI_MEM_BITS(0x180000) -#define SLOT_D_SCSI PCI_MEM_BITS(0x190000) -#define SLOT_D_AUDIO_PLAY_ADDR PCI_MEM_BITS(0x1a0000) -#define SLOT_D_AUDIO_PLAY_LIMIT PCI_MEM_BITS(0x1b0000) -#define SLOT_D_AUDIO_CAPTURE_ADDR PCI_MEM_BITS(0x1c0000) -#define SLOT_D_AUDIO_CAPTURE_LIMIT PCI_MEM_BITS(0x1d0000) -#define SLOT_D_INTERRUPT_STATUS PCI_MEM_BITS(0x1e0000) -#define SLOT_D_INTERRUPT_ENABLE PCI_MEM_BITS(0x1f0000) - -/**************************************************************************** - * UART Definitions * - ****************************************************************************/ - -#define com1Rbr (SLOT_D_COM1 | (0x0 << 1)) -#define com1Thr (SLOT_D_COM1 | (0x0 << 1)) -#define com1Ier (SLOT_D_COM1 | (0x1 << 1)) -#define com1Iir (SLOT_D_COM1 | (0x2 << 1)) -#define com1Lcr (SLOT_D_COM1 | (0x3 << 1)) -#define com1Mcr (SLOT_D_COM1 | (0x4 << 1)) -#define com1Lsr (SLOT_D_COM1 | (0x5 << 1)) -#define com1Msr (SLOT_D_COM1 | (0x6 << 1)) -#define com1Scr (SLOT_D_COM1 | (0x7 << 1)) -#define com1Dll (SLOT_D_COM1 | (0x8 << 1)) -#define com1Dlm (SLOT_D_COM1 | (0x9 << 1)) - -#define com2Rbr (SLOT_D_COM2 | (0x0 << 1)) -#define com2Thr (SLOT_D_COM2 | (0x0 << 1)) -#define com2Ier (SLOT_D_COM2 | (0x1 << 1)) -#define com2Iir (SLOT_D_COM2 | (0x2 << 1)) -#define com2Lcr (SLOT_D_COM2 | (0x3 << 1)) -#define com2Mcr (SLOT_D_COM2 | (0x4 << 1)) -#define com2Lsr (SLOT_D_COM2 | (0x5 << 1)) -#define com2Msr (SLOT_D_COM2 | (0x6 << 1)) -#define com2Scr (SLOT_D_COM2 | (0x7 << 1)) -#define com2Dll (SLOT_D_COM2 | (0x8 << 1)) -#define com2Dlm (SLOT_D_COM2 | (0x9 << 1)) - -#define lptDr 0x0 -#define lptSr 0x0 -#define lptCr 0x0 - -#define lptSTB 0x0 -#define lptAFD 0x0 -#define lptnInit 0x0 -#define lptSlct 0x0 -#define lptIrq 0x0 -#define lptDir 0x0 - -#define lptDly 100000 - -#define RTCADDR SLOT_D_CLOCK_ADDR -#define RTCDATA SLOT_D_CLOCK_DATA -/* 114 bytes of NVRAM in the clock chip */ -#define RTCRAM 114 -#define ROMBASE SLOT_D_ROM -#define ROMINC 2 /* Byte wide, with bytes in low half of 16-bit word */ -#define ROMSIZE (512 * 1024) - -/* Map 16MB of slot A space at offset 16MB of IO space */ -#define SLOT_A_IO_BASE PCI_IO_BITS(0x1000000) - -#endif /* XXM */ -#endif /* __XXM_H_LOADED */ diff --git a/system/alpha/h/xxmmem.h b/system/alpha/h/xxmmem.h deleted file mode 100644 index a4d3ff090..000000000 --- a/system/alpha/h/xxmmem.h +++ /dev/null @@ -1,60 +0,0 @@ -#ifndef __XXMMEM_H_LOADED -#define __XXMMEM_H_LOADED -/***************************************************************************** - - Copyright © 1993, 1994 Digital Equipment Corporation, - Maynard, Massachusetts. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee is hereby granted, provided -that the copyright notice and this permission notice appear in all copies -of software and supporting documentation, and that the name of Digital not -be used in advertising or publicity pertaining to distribution of the software -without specific, written prior permission. Digital grants this permission -provided that you prominently mark, as not part of the original, any -modifications made to this software or documentation. - -Digital Equipment Corporation disclaims all warranties and/or guarantees -with regard to this software, including all implied warranties of fitness for -a particular purpose and merchantability, and makes no representations -regarding the use of, or the results of the use of, the software and -documentation in terms of correctness, accuracy, reliability, currentness or -otherwise; and you rely on the software, documentation and results solely at -your own risk. - -******************************************************************************/ - -/* - * $Id: xxmmem.h,v 1.1.1.1 1997/10/30 23:27:18 verghese Exp $; - */ - -/* - * $Log: xxmmem.h,v $ - * Revision 1.1.1.1 1997/10/30 23:27:18 verghese - * current 10/29/97 - * - * Revision 1.1 1995/06/08 01:25:56 berc - * Initial revision - * - * Revision 1.2 1995/04/20 16:37:48 cruz - * Made some macro definition changes. - * - * Revision 1.1 1994/12/19 18:33:33 cruz - * Initial revision - * - * - */ - -#ifdef XXM - -#include "system.h" -#include "lib.h" - -#ifndef MAKEDEPEND -#include "cserve.h" -#endif - -#endif /* XXM */ -#endif /* __XXMMEM_H_LOADED */ |