1 /************************************************************************/
 
   3 /*      Title           :       SX/SI/XIO Board Hardware Definitions    */
 
   5 /*      Author          :       N.P.Vassallo                            */
 
   7 /*      Creation        :       16th March 1998                         */
 
  11 /*      Copyright       :       (c) Specialix International Ltd. 1998   */
 
  13 /*      Description     :       Prototypes, structures and definitions  */
 
  14 /*                              describing the SX/SI/XIO board hardware */
 
  16 /************************************************************************/
 
  20 3.0.0   16/03/98 NPV    Creation.
 
  24 #ifndef _sxboards_h                             /* If SXBOARDS.H not already defined */
 
  27 /*****************************************************************************
 
  28 *******************************                 ******************************
 
  29 *******************************   Board Types   ******************************
 
  30 *******************************                 ******************************
 
  31 *****************************************************************************/
 
  45 #define         CARD_TYPE(bus,phase)    (bus<<4|phase)
 
  46 #define         CARD_BUS(type)          ((type>>4)&0xF)
 
  47 #define         CARD_PHASE(type)        (type&0xF)
 
  49 #define         TYPE_SI1_ISA            CARD_TYPE(BUS_ISA,SI1_Z280)
 
  50 #define         TYPE_SI2_ISA            CARD_TYPE(BUS_ISA,SI2_Z280)
 
  51 #define         TYPE_SI2_EISA           CARD_TYPE(BUS_EISA,SI2_Z280)
 
  52 #define         TYPE_SI2_PCI            CARD_TYPE(BUS_PCI,SI2_Z280)
 
  54 #define         TYPE_SX_ISA             CARD_TYPE(BUS_ISA,SI3_T225)
 
  55 #define         TYPE_SX_PCI             CARD_TYPE(BUS_PCI,SI3_T225)
 
  56 /*****************************************************************************
 
  57 ******************************                  ******************************
 
  58 ******************************   Phase 1 Z280   ******************************
 
  59 ******************************                  ******************************
 
  60 *****************************************************************************/
 
  62 /* ISA board details... */
 
  63 #define         SI1_ISA_WINDOW_LEN      0x10000         /* 64 Kbyte shared memory window */
 
  64 //#define       SI1_ISA_MEMORY_LEN      0x8000          /* Usable memory  - unused define*/
 
  65 //#define               SI1_ISA_ADDR_LOW        0x0A0000        /* Lowest address = 640 Kbyte */
 
  66 //#define               SI1_ISA_ADDR_HIGH       0xFF8000        /* Highest address = 16Mbyte - 32Kbyte */
 
  67 //#define               SI2_ISA_ADDR_STEP       SI2_ISA_WINDOW_LEN/* ISA board address step */
 
  68 //#define               SI2_ISA_IRQ_MASK        0x9800          /* IRQs 15,12,11 */
 
  70 /* ISA board, register definitions... */
 
  71 //#define               SI2_ISA_ID_BASE         0x7FF8                  /* READ:  Board ID string */
 
  72 #define         SI1_ISA_RESET           0x8000          /* WRITE: Host Reset */
 
  73 #define         SI1_ISA_RESET_CLEAR     0xc000          /* WRITE: Host Reset clear*/
 
  74 #define         SI1_ISA_WAIT            0x9000          /* WRITE: Host wait */
 
  75 #define         SI1_ISA_WAIT_CLEAR      0xd000          /* WRITE: Host wait clear */
 
  76 #define         SI1_ISA_INTCL           0xa000          /* WRITE: Host Reset */
 
  77 #define         SI1_ISA_INTCL_CLEAR     0xe000          /* WRITE: Host Reset */
 
  80 /*****************************************************************************
 
  81 ******************************                  ******************************
 
  82 ******************************   Phase 2 Z280   ******************************
 
  83 ******************************                  ******************************
 
  84 *****************************************************************************/
 
  86 /* ISA board details... */
 
  87 #define         SI2_ISA_WINDOW_LEN      0x8000          /* 32 Kbyte shared memory window */
 
  88 #define         SI2_ISA_MEMORY_LEN      0x7FF8          /* Usable memory */
 
  89 #define         SI2_ISA_ADDR_LOW        0x0A0000        /* Lowest address = 640 Kbyte */
 
  90 #define         SI2_ISA_ADDR_HIGH       0xFF8000        /* Highest address = 16Mbyte - 32Kbyte */
 
  91 #define         SI2_ISA_ADDR_STEP       SI2_ISA_WINDOW_LEN/* ISA board address step */
 
  92 #define         SI2_ISA_IRQ_MASK        0x9800          /* IRQs 15,12,11 */
 
  94 /* ISA board, register definitions... */
 
  95 #define         SI2_ISA_ID_BASE         0x7FF8                  /* READ:  Board ID string */
 
  96 #define         SI2_ISA_RESET           SI2_ISA_ID_BASE         /* WRITE: Host Reset */
 
  97 #define         SI2_ISA_IRQ11           (SI2_ISA_ID_BASE+1)     /* WRITE: Set IRQ11 */
 
  98 #define         SI2_ISA_IRQ12           (SI2_ISA_ID_BASE+2)     /* WRITE: Set IRQ12 */
 
  99 #define         SI2_ISA_IRQ15           (SI2_ISA_ID_BASE+3)     /* WRITE: Set IRQ15 */
 
 100 #define         SI2_ISA_IRQSET          (SI2_ISA_ID_BASE+4)     /* WRITE: Set Host Interrupt */
 
 101 #define         SI2_ISA_INTCLEAR        (SI2_ISA_ID_BASE+5)     /* WRITE: Enable Host Interrupt */
 
 103 #define         SI2_ISA_IRQ11_SET       0x10
 
 104 #define         SI2_ISA_IRQ11_CLEAR     0x00
 
 105 #define         SI2_ISA_IRQ12_SET       0x10
 
 106 #define         SI2_ISA_IRQ12_CLEAR     0x00
 
 107 #define         SI2_ISA_IRQ15_SET       0x10
 
 108 #define         SI2_ISA_IRQ15_CLEAR     0x00
 
 109 #define         SI2_ISA_INTCLEAR_SET    0x10
 
 110 #define         SI2_ISA_INTCLEAR_CLEAR  0x00
 
 111 #define         SI2_ISA_IRQSET_CLEAR    0x10
 
 112 #define         SI2_ISA_IRQSET_SET      0x00
 
 113 #define         SI2_ISA_RESET_SET       0x00
 
 114 #define         SI2_ISA_RESET_CLEAR     0x10
 
 116 /* PCI board details... */
 
 117 #define         SI2_PCI_WINDOW_LEN      0x100000        /* 1 Mbyte memory window */
 
 119 /* PCI board register definitions... */
 
 120 #define         SI2_PCI_SET_IRQ         0x40001         /* Set Host Interrupt  */
 
 121 #define         SI2_PCI_RESET           0xC0001         /* Host Reset */
 
 123 /*****************************************************************************
 
 124 ******************************                  ******************************
 
 125 ******************************   Phase 3 T225   ******************************
 
 126 ******************************                  ******************************
 
 127 *****************************************************************************/
 
 129 /* General board details... */
 
 130 #define         SX_WINDOW_LEN           64*1024         /* 64 Kbyte memory window */
 
 132 /* ISA board details... */
 
 133 #define         SX_ISA_ADDR_LOW         0x0A0000        /* Lowest address = 640 Kbyte */
 
 134 #define         SX_ISA_ADDR_HIGH        0xFF8000        /* Highest address = 16Mbyte - 32Kbyte */
 
 135 #define         SX_ISA_ADDR_STEP        SX_WINDOW_LEN   /* ISA board address step */
 
 136 #define         SX_ISA_IRQ_MASK         0x9E00          /* IRQs 15,12,11,10,9 */
 
 138 /* Hardware register definitions... */
 
 139 #define         SX_EVENT_STATUS         0x7800          /* READ:  T225 Event Status */
 
 140 #define         SX_EVENT_STROBE         0x7800          /* WRITE: T225 Event Strobe */
 
 141 #define         SX_EVENT_ENABLE         0x7880          /* WRITE: T225 Event Enable */
 
 142 #define         SX_VPD_ROM              0x7C00          /* READ:  Vital Product Data ROM */
 
 143 #define         SX_CONFIG               0x7C00          /* WRITE: Host Configuration Register */
 
 144 #define         SX_IRQ_STATUS           0x7C80          /* READ:  Host Interrupt Status */
 
 145 #define         SX_SET_IRQ              0x7C80          /* WRITE: Set Host Interrupt */
 
 146 #define         SX_RESET_STATUS         0x7D00          /* READ:  Host Reset Status */
 
 147 #define         SX_RESET                0x7D00          /* WRITE: Host Reset */
 
 148 #define         SX_RESET_IRQ            0x7D80          /* WRITE: Reset Host Interrupt */
 
 150 /* SX_VPD_ROM definitions... */
 
 151 #define         SX_VPD_SLX_ID1          0x00
 
 152 #define         SX_VPD_SLX_ID2          0x01
 
 153 #define         SX_VPD_HW_REV           0x02
 
 154 #define         SX_VPD_HW_ASSEM         0x03
 
 155 #define         SX_VPD_UNIQUEID4        0x04
 
 156 #define         SX_VPD_UNIQUEID3        0x05
 
 157 #define         SX_VPD_UNIQUEID2        0x06
 
 158 #define         SX_VPD_UNIQUEID1        0x07
 
 159 #define         SX_VPD_MANU_YEAR        0x08
 
 160 #define         SX_VPD_MANU_WEEK        0x09
 
 161 #define         SX_VPD_IDENT            0x10
 
 162 #define         SX_VPD_IDENT_STRING     "JET HOST BY KEV#"
 
 164 /* SX unique identifiers... */
 
 165 #define         SX_UNIQUEID_MASK        0xF0
 
 166 #define         SX_ISA_UNIQUEID1        0x20
 
 167 #define         SX_PCI_UNIQUEID1        0x50
 
 169 /* SX_CONFIG definitions... */
 
 170 #define         SX_CONF_BUSEN           0x02            /* Enable T225 memory and I/O */
 
 171 #define         SX_CONF_HOSTIRQ         0x04            /* Enable board to host interrupt */
 
 173 /* SX bootstrap... */
 
 174 #define         SX_BOOTSTRAP            "\x28\x20\x21\x02\x60\x0a"
 
 175 #define         SX_BOOTSTRAP_SIZE       6
 
 176 #define         SX_BOOTSTRAP_ADDR       (0x8000-SX_BOOTSTRAP_SIZE)
 
 178 /*****************************************************************************
 
 179 **********************************          **********************************
 
 180 **********************************   EISA   **********************************
 
 181 **********************************          **********************************
 
 182 *****************************************************************************/
 
 184 #define         SI2_EISA_OFF            0x42
 
 185 #define         SI2_EISA_VAL            0x01
 
 186 #define         SI2_EISA_WINDOW_LEN     0x10000
 
 188 /*****************************************************************************
 
 189 ***********************************         **********************************
 
 190 ***********************************   PCI   **********************************
 
 191 ***********************************         **********************************
 
 192 *****************************************************************************/
 
 194 /* General definitions... */
 
 196 #define         SPX_VENDOR_ID           0x11CB          /* Assigned by the PCI SIG */
 
 197 #define         SPX_DEVICE_ID           0x4000          /* SI/XIO boards */
 
 198 #define         SPX_PLXDEVICE_ID        0x2000          /* SX boards */
 
 200 #define         SPX_SUB_VENDOR_ID       SPX_VENDOR_ID   /* Same as vendor id */
 
 201 #define         SI2_SUB_SYS_ID          0x400           /* Phase 2 (Z280) board */
 
 202 #define         SX_SUB_SYS_ID           0x200           /* Phase 3 (t225) board */
 
 204 #endif                                          /*_sxboards_h */
 
 206 /* End of SXBOARDS.H */