blob: c07565ba57da5830a9fed4f5e7c45015783478a9 [file] [log] [blame]
Mauro Carvalho Chehab72fd15c2017-05-14 13:27:55 -03001================
2EISA bus support
3================
4
5:Author: Marc Zyngier <maz@wild-wind.fr.eu.org>
Linus Torvalds1da177e2005-04-16 15:20:36 -07006
7This document groups random notes about porting EISA drivers to the
8new EISA/sysfs API.
9
10Starting from version 2.5.59, the EISA bus is almost given the same
11status as other much more mainstream busses such as PCI or USB. This
12has been possible through sysfs, which defines a nice enough set of
13abstractions to manage busses, devices and drivers.
14
15Although the new API is quite simple to use, converting existing
16drivers to the new infrastructure is not an easy task (mostly because
17detection code is generally also used to probe ISA cards). Moreover,
18most EISA drivers are among the oldest Linux drivers so, as you can
19imagine, some dust has settled here over the years.
20
Mauro Carvalho Chehab72fd15c2017-05-14 13:27:55 -030021The EISA infrastructure is made up of three parts:
Linus Torvalds1da177e2005-04-16 15:20:36 -070022
23 - The bus code implements most of the generic code. It is shared
Mauro Carvalho Chehab72fd15c2017-05-14 13:27:55 -030024 among all the architectures that the EISA code runs on. It
25 implements bus probing (detecting EISA cards available on the bus),
26 allocates I/O resources, allows fancy naming through sysfs, and
27 offers interfaces for driver to register.
Linus Torvalds1da177e2005-04-16 15:20:36 -070028
29 - The bus root driver implements the glue between the bus hardware
Mauro Carvalho Chehab72fd15c2017-05-14 13:27:55 -030030 and the generic bus code. It is responsible for discovering the
31 device implementing the bus, and setting it up to be latter probed
32 by the bus code. This can go from something as simple as reserving
33 an I/O region on x86, to the rather more complex, like the hppa
34 EISA code. This is the part to implement in order to have EISA
35 running on an "new" platform.
Linus Torvalds1da177e2005-04-16 15:20:36 -070036
37 - The driver offers the bus a list of devices that it manages, and
Mauro Carvalho Chehab72fd15c2017-05-14 13:27:55 -030038 implements the necessary callbacks to probe and release devices
39 whenever told to.
Linus Torvalds1da177e2005-04-16 15:20:36 -070040
41Every function/structure below lives in <linux/eisa.h>, which depends
42heavily on <linux/device.h>.
43
Mauro Carvalho Chehab72fd15c2017-05-14 13:27:55 -030044Bus root driver
45===============
Linus Torvalds1da177e2005-04-16 15:20:36 -070046
Mauro Carvalho Chehab72fd15c2017-05-14 13:27:55 -030047::
48
49 int eisa_root_register (struct eisa_root_device *root);
Linus Torvalds1da177e2005-04-16 15:20:36 -070050
51The eisa_root_register function is used to declare a device as the
52root of an EISA bus. The eisa_root_device structure holds a reference
Mauro Carvalho Chehab72fd15c2017-05-14 13:27:55 -030053to this device, as well as some parameters for probing purposes::
Linus Torvalds1da177e2005-04-16 15:20:36 -070054
Mauro Carvalho Chehab72fd15c2017-05-14 13:27:55 -030055 struct eisa_root_device {
56 struct device *dev; /* Pointer to bridge device */
57 struct resource *res;
58 unsigned long bus_base_addr;
59 int slots; /* Max slot number */
60 int force_probe; /* Probe even when no slot 0 */
61 u64 dma_mask; /* from bridge device */
62 int bus_nr; /* Set by eisa_root_register */
63 struct resource eisa_root_res; /* ditto */
64 };
Linus Torvalds1da177e2005-04-16 15:20:36 -070065
Mauro Carvalho Chehab72fd15c2017-05-14 13:27:55 -030066============= ======================================================
67node used for eisa_root_register internal purpose
68dev pointer to the root device
69res root device I/O resource
70bus_base_addr slot 0 address on this bus
71slots max slot number to probe
72force_probe Probe even when slot 0 is empty (no EISA mainboard)
73dma_mask Default DMA mask. Usually the bridge device dma_mask.
74bus_nr unique bus id, set by eisa_root_register
75============= ======================================================
Linus Torvalds1da177e2005-04-16 15:20:36 -070076
Mauro Carvalho Chehab72fd15c2017-05-14 13:27:55 -030077Driver
78======
Linus Torvalds1da177e2005-04-16 15:20:36 -070079
Mauro Carvalho Chehab72fd15c2017-05-14 13:27:55 -030080::
81
82 int eisa_driver_register (struct eisa_driver *edrv);
83 void eisa_driver_unregister (struct eisa_driver *edrv);
Linus Torvalds1da177e2005-04-16 15:20:36 -070084
85Clear enough ?
86
Mauro Carvalho Chehab72fd15c2017-05-14 13:27:55 -030087::
Linus Torvalds1da177e2005-04-16 15:20:36 -070088
Mauro Carvalho Chehab72fd15c2017-05-14 13:27:55 -030089 struct eisa_device_id {
90 char sig[EISA_SIG_LEN];
91 unsigned long driver_data;
92 };
Linus Torvalds1da177e2005-04-16 15:20:36 -070093
Mauro Carvalho Chehab72fd15c2017-05-14 13:27:55 -030094 struct eisa_driver {
95 const struct eisa_device_id *id_table;
96 struct device_driver driver;
97 };
Linus Torvalds1da177e2005-04-16 15:20:36 -070098
Mauro Carvalho Chehab72fd15c2017-05-14 13:27:55 -030099=============== ====================================================
100id_table an array of NULL terminated EISA id strings,
101 followed by an empty string. Each string can
102 optionally be paired with a driver-dependent value
103 (driver_data).
Linus Torvalds1da177e2005-04-16 15:20:36 -0700104
Mauro Carvalho Chehab72fd15c2017-05-14 13:27:55 -0300105driver a generic driver, such as described in
Mauro Carvalho Chehabfe34c892019-06-18 12:34:59 -0300106 Documentation/driver-api/driver-model/driver.rst. Only .name,
Mauro Carvalho Chehab72fd15c2017-05-14 13:27:55 -0300107 .probe and .remove members are mandatory.
108=============== ====================================================
Linus Torvalds1da177e2005-04-16 15:20:36 -0700109
Mauro Carvalho Chehab72fd15c2017-05-14 13:27:55 -0300110An example is the 3c59x driver::
Linus Torvalds1da177e2005-04-16 15:20:36 -0700111
Mauro Carvalho Chehab72fd15c2017-05-14 13:27:55 -0300112 static struct eisa_device_id vortex_eisa_ids[] = {
113 { "TCM5920", EISA_3C592_OFFSET },
114 { "TCM5970", EISA_3C597_OFFSET },
115 { "" }
116 };
Linus Torvalds1da177e2005-04-16 15:20:36 -0700117
Mauro Carvalho Chehab72fd15c2017-05-14 13:27:55 -0300118 static struct eisa_driver vortex_eisa_driver = {
119 .id_table = vortex_eisa_ids,
120 .driver = {
121 .name = "3c59x",
122 .probe = vortex_eisa_probe,
123 .remove = vortex_eisa_remove
124 }
125 };
126
127Device
128======
Linus Torvalds1da177e2005-04-16 15:20:36 -0700129
130The sysfs framework calls .probe and .remove functions upon device
131discovery and removal (note that the .remove function is only called
132when driver is built as a module).
133
134Both functions are passed a pointer to a 'struct device', which is
Mauro Carvalho Chehab72fd15c2017-05-14 13:27:55 -0300135encapsulated in a 'struct eisa_device' described as follows::
Linus Torvalds1da177e2005-04-16 15:20:36 -0700136
Mauro Carvalho Chehab72fd15c2017-05-14 13:27:55 -0300137 struct eisa_device {
138 struct eisa_device_id id;
139 int slot;
140 int state;
141 unsigned long base_addr;
142 struct resource res[EISA_MAX_RESOURCES];
143 u64 dma_mask;
144 struct device dev; /* generic device */
145 };
Linus Torvalds1da177e2005-04-16 15:20:36 -0700146
Mauro Carvalho Chehab72fd15c2017-05-14 13:27:55 -0300147======== ============================================================
148id EISA id, as read from device. id.driver_data is set from the
149 matching driver EISA id.
150slot slot number which the device was detected on
151state set of flags indicating the state of the device. Current
152 flags are EISA_CONFIG_ENABLED and EISA_CONFIG_FORCED.
153res set of four 256 bytes I/O regions allocated to this device
154dma_mask DMA mask set from the parent device.
Mauro Carvalho Chehabfe34c892019-06-18 12:34:59 -0300155dev generic device (see Documentation/driver-api/driver-model/device.rst)
Mauro Carvalho Chehab72fd15c2017-05-14 13:27:55 -0300156======== ============================================================
Linus Torvalds1da177e2005-04-16 15:20:36 -0700157
158You can get the 'struct eisa_device' from 'struct device' using the
159'to_eisa_device' macro.
160
Mauro Carvalho Chehab72fd15c2017-05-14 13:27:55 -0300161Misc stuff
162==========
Linus Torvalds1da177e2005-04-16 15:20:36 -0700163
Mauro Carvalho Chehab72fd15c2017-05-14 13:27:55 -0300164::
165
166 void eisa_set_drvdata (struct eisa_device *edev, void *data);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700167
168Stores data into the device's driver_data area.
169
Mauro Carvalho Chehab72fd15c2017-05-14 13:27:55 -0300170::
171
172 void *eisa_get_drvdata (struct eisa_device *edev):
Linus Torvalds1da177e2005-04-16 15:20:36 -0700173
174Gets the pointer previously stored into the device's driver_data area.
175
Mauro Carvalho Chehab72fd15c2017-05-14 13:27:55 -0300176::
177
178 int eisa_get_region_index (void *addr);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700179
180Returns the region number (0 <= x < EISA_MAX_RESOURCES) of a given
181address.
182
Mauro Carvalho Chehab72fd15c2017-05-14 13:27:55 -0300183Kernel parameters
184=================
Linus Torvalds1da177e2005-04-16 15:20:36 -0700185
Mauro Carvalho Chehab72fd15c2017-05-14 13:27:55 -0300186eisa_bus.enable_dev
187 A comma-separated list of slots to be enabled, even if the firmware
188 set the card as disabled. The driver must be able to properly
189 initialize the device in such conditions.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700190
Mauro Carvalho Chehab72fd15c2017-05-14 13:27:55 -0300191eisa_bus.disable_dev
192 A comma-separated list of slots to be enabled, even if the firmware
193 set the card as enabled. The driver won't be called to handle this
194 device.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700195
Mauro Carvalho Chehab72fd15c2017-05-14 13:27:55 -0300196virtual_root.force_probe
197 Force the probing code to probe EISA slots even when it cannot find an
198 EISA compliant mainboard (nothing appears on slot 0). Defaults to 0
199 (don't force), and set to 1 (force probing) when either
200 CONFIG_ALPHA_JENSEN or CONFIG_EISA_VLB_PRIMING are set.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700201
Mauro Carvalho Chehab72fd15c2017-05-14 13:27:55 -0300202Random notes
203============
Linus Torvalds1da177e2005-04-16 15:20:36 -0700204
205Converting an EISA driver to the new API mostly involves *deleting*
206code (since probing is now in the core EISA code). Unfortunately, most
Paul Gortmakerbb8187d2012-05-17 19:06:13 -0400207drivers share their probing routine between ISA, and EISA. Special
Linus Torvalds1da177e2005-04-16 15:20:36 -0700208care must be taken when ripping out the EISA code, so other busses
209won't suffer from these surgical strikes...
210
211You *must not* expect any EISA device to be detected when returning
212from eisa_driver_register, since the chances are that the bus has not
213yet been probed. In fact, that's what happens most of the time (the
214bus root driver usually kicks in rather late in the boot process).
215Unfortunately, most drivers are doing the probing by themselves, and
216expect to have explored the whole machine when they exit their probe
217routine.
218
219For example, switching your favorite EISA SCSI card to the "hotplug"
220model is "the right thing"(tm).
221
Mauro Carvalho Chehab72fd15c2017-05-14 13:27:55 -0300222Thanks
223======
Linus Torvalds1da177e2005-04-16 15:20:36 -0700224
Mauro Carvalho Chehab72fd15c2017-05-14 13:27:55 -0300225I'd like to thank the following people for their help:
226
Linus Torvalds1da177e2005-04-16 15:20:36 -0700227- Xavier Benigni for lending me a wonderful Alpha Jensen,
228- James Bottomley, Jeff Garzik for getting this stuff into the kernel,
229- Andries Brouwer for contributing numerous EISA ids,
230- Catrin Jones for coping with far too many machines at home.