riospace.h 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154
  1. /*
  2. ** -----------------------------------------------------------------------------
  3. **
  4. ** Perle Specialix driver for Linux
  5. ** Ported from existing RIO Driver for SCO sources.
  6. *
  7. * (C) 1990 - 2000 Specialix International Ltd., Byfleet, Surrey, UK.
  8. *
  9. * This program is free software; you can redistribute it and/or modify
  10. * it under the terms of the GNU General Public License as published by
  11. * the Free Software Foundation; either version 2 of the License, or
  12. * (at your option) any later version.
  13. *
  14. * This program is distributed in the hope that it will be useful,
  15. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  16. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  17. * GNU General Public License for more details.
  18. *
  19. * You should have received a copy of the GNU General Public License
  20. * along with this program; if not, write to the Free Software
  21. * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
  22. **
  23. ** Module : riospace.h
  24. ** SID : 1.2
  25. ** Last Modified : 11/6/98 11:34:13
  26. ** Retrieved : 11/6/98 11:34:22
  27. **
  28. ** ident @(#)riospace.h 1.2
  29. **
  30. ** -----------------------------------------------------------------------------
  31. */
  32. #ifndef __rio_riospace_h__
  33. #define __rio_riospace_h__
  34. #define RIO_LOCATOR_LEN 16
  35. #define MAX_RIO_BOARDS 4
  36. /*
  37. ** DONT change this file. At all. Unless you can rebuild the entire
  38. ** device driver, which you probably can't, then the rest of the
  39. ** driver won't see any changes you make here. So don't make any.
  40. ** In particular, it won't be able to see changes to RIO_SLOTS
  41. */
  42. struct Conf {
  43. char Locator[24];
  44. unsigned int StartupTime;
  45. unsigned int SlowCook;
  46. unsigned int IntrPollTime;
  47. unsigned int BreakInterval;
  48. unsigned int Timer;
  49. unsigned int RtaLoadBase;
  50. unsigned int HostLoadBase;
  51. unsigned int XpHz;
  52. unsigned int XpCps;
  53. char *XpOn;
  54. char *XpOff;
  55. unsigned int MaxXpCps;
  56. unsigned int MinXpCps;
  57. unsigned int SpinCmds;
  58. unsigned int FirstAddr;
  59. unsigned int LastAddr;
  60. unsigned int BufferSize;
  61. unsigned int LowWater;
  62. unsigned int LineLength;
  63. unsigned int CmdTime;
  64. };
  65. /*
  66. ** Board types - these MUST correspond to product codes!
  67. */
  68. #define RIO_EMPTY 0x0
  69. #define RIO_EISA 0x3
  70. #define RIO_RTA_16 0x9
  71. #define RIO_AT 0xA
  72. #define RIO_MCA 0xB
  73. #define RIO_PCI 0xD
  74. #define RIO_RTA 0xE
  75. /*
  76. ** Board data structure. This is used for configuration info
  77. */
  78. struct Brd {
  79. unsigned char Type; /* RIO_EISA, RIO_MCA, RIO_AT, RIO_EMPTY... */
  80. unsigned char Ivec; /* POLLED or ivec number */
  81. unsigned char Mode; /* Control stuff, see below */
  82. };
  83. struct Board {
  84. char Locator[RIO_LOCATOR_LEN];
  85. int NumSlots;
  86. struct Brd Boards[MAX_RIO_BOARDS];
  87. };
  88. #define BOOT_FROM_LINK 0x00
  89. #define BOOT_FROM_RAM 0x01
  90. #define EXTERNAL_BUS_OFF 0x00
  91. #define EXTERNAL_BUS_ON 0x02
  92. #define INTERRUPT_DISABLE 0x00
  93. #define INTERRUPT_ENABLE 0x04
  94. #define BYTE_OPERATION 0x00
  95. #define WORD_OPERATION 0x08
  96. #define POLLED INTERRUPT_DISABLE
  97. #define IRQ_15 (0x00 | INTERRUPT_ENABLE)
  98. #define IRQ_12 (0x10 | INTERRUPT_ENABLE)
  99. #define IRQ_11 (0x20 | INTERRUPT_ENABLE)
  100. #define IRQ_9 (0x30 | INTERRUPT_ENABLE)
  101. #define SLOW_LINKS 0x00
  102. #define FAST_LINKS 0x40
  103. #define SLOW_AT_BUS 0x00
  104. #define FAST_AT_BUS 0x80
  105. #define SLOW_PCI_TP 0x00
  106. #define FAST_PCI_TP 0x80
  107. /*
  108. ** Debug levels
  109. */
  110. #define DBG_NONE 0x00000000
  111. #define DBG_INIT 0x00000001
  112. #define DBG_OPEN 0x00000002
  113. #define DBG_CLOSE 0x00000004
  114. #define DBG_IOCTL 0x00000008
  115. #define DBG_READ 0x00000010
  116. #define DBG_WRITE 0x00000020
  117. #define DBG_INTR 0x00000040
  118. #define DBG_PROC 0x00000080
  119. #define DBG_PARAM 0x00000100
  120. #define DBG_CMD 0x00000200
  121. #define DBG_XPRINT 0x00000400
  122. #define DBG_POLL 0x00000800
  123. #define DBG_DAEMON 0x00001000
  124. #define DBG_FAIL 0x00002000
  125. #define DBG_MODEM 0x00004000
  126. #define DBG_LIST 0x00008000
  127. #define DBG_ROUTE 0x00010000
  128. #define DBG_UTIL 0x00020000
  129. #define DBG_BOOT 0x00040000
  130. #define DBG_BUFFER 0x00080000
  131. #define DBG_MON 0x00100000
  132. #define DBG_SPECIAL 0x00200000
  133. #define DBG_VPIX 0x00400000
  134. #define DBG_FLUSH 0x00800000
  135. #define DBG_QENABLE 0x01000000
  136. #define DBG_ALWAYS 0x80000000
  137. #endif /* __rio_riospace_h__ */