mca.txt 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314
  1. i386 Micro Channel Architecture Support
  2. =======================================
  3. MCA support is enabled using the CONFIG_MCA define. A machine with a MCA
  4. bus will have the kernel variable MCA_bus set, assuming the BIOS feature
  5. bits are set properly (see arch/i386/boot/setup.S for information on
  6. how this detection is done).
  7. Adapter Detection
  8. =================
  9. The ideal MCA adapter detection is done through the use of the
  10. Programmable Option Select registers. Generic functions for doing
  11. this have been added in include/linux/mca.h and arch/x86/kernel/mca_32.c.
  12. Everything needed to detect adapters and read (and write) configuration
  13. information is there. A number of MCA-specific drivers already use
  14. this. The typical probe code looks like the following:
  15. #include <linux/mca.h>
  16. unsigned char pos2, pos3, pos4, pos5;
  17. struct net_device* dev;
  18. int slot;
  19. if( MCA_bus ) {
  20. slot = mca_find_adapter( ADAPTER_ID, 0 );
  21. if( slot == MCA_NOTFOUND ) {
  22. return -ENODEV;
  23. }
  24. /* optional - see below */
  25. mca_set_adapter_name( slot, "adapter name & description" );
  26. mca_set_adapter_procfn( slot, dev_getinfo, dev );
  27. /* read the POS registers. Most devices only use 2 and 3 */
  28. pos2 = mca_read_stored_pos( slot, 2 );
  29. pos3 = mca_read_stored_pos( slot, 3 );
  30. pos4 = mca_read_stored_pos( slot, 4 );
  31. pos5 = mca_read_stored_pos( slot, 5 );
  32. } else {
  33. return -ENODEV;
  34. }
  35. /* extract configuration from pos[2345] and set everything up */
  36. Loadable modules should modify this to test that the specified IRQ and
  37. IO ports (plus whatever other stuff) match. See 3c523.c for example
  38. code (actually, smc-mca.c has a slightly more complex example that can
  39. handle a list of adapter ids).
  40. Keep in mind that devices should never directly access the POS registers
  41. (via inb(), outb(), etc). While it's generally safe, there is a small
  42. potential for blowing up hardware when it's done at the wrong time.
  43. Furthermore, accessing a POS register disables a device temporarily.
  44. This is usually okay during startup, but do _you_ want to rely on it?
  45. During initial configuration, mca_init() reads all the POS registers
  46. into memory. mca_read_stored_pos() accesses that data. mca_read_pos()
  47. and mca_write_pos() are also available for (safer) direct POS access,
  48. but their use is _highly_ discouraged. mca_write_pos() is particularly
  49. dangerous, as it is possible for adapters to be put in inconsistent
  50. states (i.e. sharing IO address, etc) and may result in crashes, toasted
  51. hardware, and blindness.
  52. User level drivers (such as the AGX X server) can use /proc/mca/pos to
  53. find adapters (see below).
  54. Some MCA adapters can also be detected via the usual ISA-style device
  55. probing (many SCSI adapters, for example). This sort of thing is highly
  56. discouraged. Perfectly good information is available telling you what's
  57. there, so there's no excuse for messing with random IO ports. However,
  58. we MCA people still appreciate any ISA-style driver that will work with
  59. our hardware. You take what you can get...
  60. Level-Triggered Interrupts
  61. ==========================
  62. Because MCA uses level-triggered interrupts, a few problems arise with
  63. what might best be described as the ISA mindset and its effects on
  64. drivers. These sorts of problems are expected to become less common as
  65. more people use shared IRQs on PCI machines.
  66. In general, an interrupt must be acknowledged not only at the ICU (which
  67. is done automagically by the kernel), but at the device level. In
  68. particular, IRQ 0 must be reset after a timer interrupt (now done in
  69. arch/x86/kernel/time.c) or the first timer interrupt hangs the system.
  70. There were also problems with the 1.3.x floppy drivers, but that seems
  71. to have been fixed.
  72. IRQs are also shareable, and most MCA-specific devices should be coded
  73. with shared IRQs in mind.
  74. /proc/mca
  75. =========
  76. /proc/mca is a directory containing various files for adapters and
  77. other stuff.
  78. /proc/mca/pos Straight listing of POS registers
  79. /proc/mca/slot[1-8] Information on adapter in specific slot
  80. /proc/mca/video Same for integrated video
  81. /proc/mca/scsi Same for integrated SCSI
  82. /proc/mca/machine Machine information
  83. See Appendix A for a sample.
  84. Device drivers can easily add their own information function for
  85. specific slots (including integrated ones) via the
  86. mca_set_adapter_procfn() call. Drivers that support this are ESDI, IBM
  87. SCSI, and 3c523. If a device is also a module, make sure that the proc
  88. function is removed in the module cleanup. This will require storing
  89. the slot information in a private structure somewhere. See the 3c523
  90. driver for details.
  91. Your typical proc function will look something like this:
  92. static int
  93. dev_getinfo( char* buf, int slot, void* d ) {
  94. struct net_device* dev = (struct net_device*) d;
  95. int len = 0;
  96. len += sprintf( buf+len, "Device: %s\n", dev->name );
  97. len += sprintf( buf+len, "IRQ: %d\n", dev->irq );
  98. len += sprintf( buf+len, "IO Port: %#lx-%#lx\n", ... );
  99. ...
  100. return len;
  101. }
  102. Some of the standard MCA information will already be printed, so don't
  103. bother repeating it. Don't try putting in more than 3K of information.
  104. Enable this function with:
  105. mca_set_adapter_procfn( slot, dev_getinfo, dev );
  106. Disable it with:
  107. mca_set_adapter_procfn( slot, NULL, NULL );
  108. It is also recommended that, even if you don't write a proc function, to
  109. set the name of the adapter (i.e. "PS/2 ESDI Controller") via
  110. mca_set_adapter_name( int slot, char* name ).
  111. MCA Device Drivers
  112. ==================
  113. Currently, there are a number of MCA-specific device drivers.
  114. 1) PS/2 SCSI
  115. drivers/scsi/ibmmca.c
  116. drivers/scsi/ibmmca.h
  117. The driver for the IBM SCSI subsystem. Includes both integrated
  118. controllers and adapter cards. May require command-line arg
  119. "ibmmcascsi=io_port" to force detection of an adapter. If you have a
  120. machine with a front-panel display (i.e. model 95), you can use
  121. "ibmmcascsi=display" to enable a drive activity indicator.
  122. 2) 3c523
  123. drivers/net/3c523.c
  124. drivers/net/3c523.h
  125. 3Com 3c523 Etherlink/MC ethernet driver.
  126. 3) SMC Ultra/MCA and IBM Adapter/A
  127. drivers/net/smc-mca.c
  128. drivers/net/smc-mca.h
  129. Driver for the MCA version of the SMC Ultra and various other
  130. OEM'ed and work-alike cards (Elite, Adapter/A, etc).
  131. 4) NE/2
  132. driver/net/ne2.c
  133. driver/net/ne2.h
  134. The NE/2 is the MCA version of the NE2000. This may not work
  135. with clones that have a different adapter id than the original
  136. NE/2.
  137. 5) Future Domain MCS-600/700, OEM'd IBM Fast SCSI Adapter/A and
  138. Reply Sound Blaster/SCSI (SCSI part)
  139. Better support for these cards than the driver for ISA.
  140. Supports multiple cards with IRQ sharing.
  141. Also added boot time option of scsi-probe, which can do reordering of
  142. SCSI host adapters. This will direct the kernel on the order which
  143. SCSI adapter should be detected. Example:
  144. scsi-probe=ibmmca,fd_mcs,adaptec1542,buslogic
  145. The serial drivers were modified to support the extended IO port range
  146. of the typical MCA system (also #ifdef CONFIG_MCA).
  147. The following devices work with existing drivers:
  148. 1) Token-ring
  149. 2) Future Domain SCSI (MCS-600, MCS-700, not MCS-350, OEM'ed IBM SCSI)
  150. 3) Adaptec 1640 SCSI (using the aha1542 driver)
  151. 4) Bustek/Buslogic SCSI (various)
  152. 5) Probably all Arcnet cards.
  153. 6) Some, possibly all, MCA IDE controllers.
  154. 7) 3Com 3c529 (MCA version of 3c509) (patched)
  155. 8) Intel EtherExpressMC (patched version)
  156. You need to have CONFIG_MCA defined to have EtherExpressMC support.
  157. 9) Reply Sound Blaster/SCSI (SB part) (patched version)
  158. Bugs & Other Weirdness
  159. ======================
  160. NMIs tend to occur with MCA machines because of various hardware
  161. weirdness, bus timeouts, and many other non-critical things. Some basic
  162. code to handle them (inspired by the NetBSD MCA code) has been added to
  163. detect the guilty device, but it's pretty incomplete. If NMIs are a
  164. persistent problem (on some model 70 or 80s, they occur every couple
  165. shell commands), the CONFIG_IGNORE_NMI flag will take care of that.
  166. Various Pentium machines have had serious problems with the FPU test in
  167. bugs.h. Basically, the machine hangs after the HLT test. This occurs,
  168. as far as we know, on the Pentium-equipped 85s, 95s, and some PC Servers.
  169. The PCI/MCA PC 750s are fine as far as I can tell. The ``mca-pentium''
  170. boot-prompt flag will disable the FPU bug check if this is a problem
  171. with your machine.
  172. The model 80 has a raft of problems that are just too weird and unique
  173. to get into here. Some people have no trouble while others have nothing
  174. but problems. I'd suspect some problems are related to the age of the
  175. average 80 and accompanying hardware deterioration, although others
  176. are definitely design problems with the hardware. Among the problems
  177. include SCSI controller problems, ESDI controller problems, and serious
  178. screw-ups in the floppy controller. Oh, and the parallel port is also
  179. pretty flaky. There were about 5 or 6 different model 80 motherboards
  180. produced to fix various obscure problems. As far as I know, it's pretty
  181. much impossible to tell which bugs a particular model 80 has (other than
  182. triggering them, that is).
  183. Drivers are required for some MCA memory adapters. If you're suddenly
  184. short a few megs of RAM, this might be the reason. The (I think) Enhanced
  185. Memory Adapter commonly found on the model 70 is one. There's a very
  186. alpha driver floating around, but it's pretty ugly (disassembled from
  187. the DOS driver, actually). See the MCA Linux web page (URL below)
  188. for more current memory info.
  189. The Thinkpad 700 and 720 will work, but various components are either
  190. non-functional, flaky, or we don't know anything about them. The
  191. graphics controller is supposed to be some WD, but we can't get things
  192. working properly. The PCMCIA slots don't seem to work. Ditto for APM.
  193. The serial ports work, but detection seems to be flaky.
  194. Credits
  195. =======
  196. A whole pile of people have contributed to the MCA code. I'd include
  197. their names here, but I don't have a list handy. Check the MCA Linux
  198. home page (URL below) for a perpetually out-of-date list.
  199. =====================================================================
  200. MCA Linux Home Page: http://www.dgmicro.com/mca/
  201. Christophe Beauregard
  202. chrisb@truespectra.com
  203. cpbeaure@calum.csclub.uwaterloo.ca
  204. =====================================================================
  205. Appendix A: Sample /proc/mca
  206. This is from my model 8595. Slot 1 contains the standard IBM SCSI
  207. adapter, slot 3 is an Adaptec AHA-1640, slot 5 is a XGA-1 video adapter,
  208. and slot 7 is the 3c523 Etherlink/MC.
  209. /proc/mca/machine:
  210. Model Id: 0xf8
  211. Submodel Id: 0x14
  212. BIOS Revision: 0x5
  213. /proc/mca/pos:
  214. Slot 1: ff 8e f1 fc a0 ff ff ff IBM SCSI Adapter w/Cache
  215. Slot 2: ff ff ff ff ff ff ff ff
  216. Slot 3: 1f 0f 81 3b bf b6 ff ff
  217. Slot 4: ff ff ff ff ff ff ff ff
  218. Slot 5: db 8f 1d 5e fd c0 00 00
  219. Slot 6: ff ff ff ff ff ff ff ff
  220. Slot 7: 42 60 ff 08 ff ff ff ff 3Com 3c523 Etherlink/MC
  221. Slot 8: ff ff ff ff ff ff ff ff
  222. Video : ff ff ff ff ff ff ff ff
  223. SCSI : ff ff ff ff ff ff ff ff
  224. /proc/mca/slot1:
  225. Slot: 1
  226. Adapter Name: IBM SCSI Adapter w/Cache
  227. Id: 8eff
  228. Enabled: Yes
  229. POS: ff 8e f1 fc a0 ff ff ff
  230. Subsystem PUN: 7
  231. Detected at boot: Yes
  232. /proc/mca/slot3:
  233. Slot: 3
  234. Adapter Name: Unknown
  235. Id: 0f1f
  236. Enabled: Yes
  237. POS: 1f 0f 81 3b bf b6 ff ff
  238. /proc/mca/slot5:
  239. Slot: 5
  240. Adapter Name: Unknown
  241. Id: 8fdb
  242. Enabled: Yes
  243. POS: db 8f 1d 5e fd c0 00 00
  244. /proc/mca/slot7:
  245. Slot: 7
  246. Adapter Name: 3Com 3c523 Etherlink/MC
  247. Id: 6042
  248. Enabled: Yes
  249. POS: 42 60 ff 08 ff ff ff ff
  250. Revision: 0xe
  251. IRQ: 9
  252. IO Address: 0x3300-0x3308
  253. Memory: 0xd8000-0xdbfff
  254. Transceiver: External
  255. Device: eth0
  256. Hardware Address: 02 60 8c 45 c4 2a