cachepc-linux

Fork of AMDESE/linux with modifications for CachePC side-channel attack
git clone https://git.sinitax.com/sinitax/cachepc-linux
Log | Files | Refs | README | LICENSE | sfeed.txt

eisa.rst (7828B)


      1================
      2EISA bus support
      3================
      4
      5:Author: Marc Zyngier <maz@wild-wind.fr.eu.org>
      6
      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
     21The EISA infrastructure is made up of three parts:
     22
     23    - The bus code implements most of the generic code. It is shared
     24      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.
     28
     29    - The bus root driver implements the glue between the bus hardware
     30      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.
     36
     37    - The driver offers the bus a list of devices that it manages, and
     38      implements the necessary callbacks to probe and release devices
     39      whenever told to.
     40
     41Every function/structure below lives in <linux/eisa.h>, which depends
     42heavily on <linux/device.h>.
     43
     44Bus root driver
     45===============
     46
     47::
     48
     49	int eisa_root_register (struct eisa_root_device *root);
     50
     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
     53to this device, as well as some parameters for probing purposes::
     54
     55	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	};
     65
     66============= ======================================================
     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============= ======================================================
     76
     77Driver
     78======
     79
     80::
     81
     82	int eisa_driver_register (struct eisa_driver *edrv);
     83	void eisa_driver_unregister (struct eisa_driver *edrv);
     84
     85Clear enough ?
     86
     87::
     88
     89	struct eisa_device_id {
     90		char sig[EISA_SIG_LEN];
     91		unsigned long driver_data;
     92	};
     93
     94	struct eisa_driver {
     95		const struct eisa_device_id *id_table;
     96		struct device_driver         driver;
     97	};
     98
     99=============== ====================================================
    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).
    104
    105driver		a generic driver, such as described in
    106		Documentation/driver-api/driver-model/driver.rst. Only .name,
    107		.probe and .remove members are mandatory.
    108=============== ====================================================
    109
    110An example is the 3c59x driver::
    111
    112	static struct eisa_device_id vortex_eisa_ids[] = {
    113		{ "TCM5920", EISA_3C592_OFFSET },
    114		{ "TCM5970", EISA_3C597_OFFSET },
    115		{ "" }
    116	};
    117
    118	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======
    129
    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
    135encapsulated in a 'struct eisa_device' described as follows::
    136
    137	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	};
    146
    147======== ============================================================
    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.
    155dev	 generic device (see Documentation/driver-api/driver-model/device.rst)
    156======== ============================================================
    157
    158You can get the 'struct eisa_device' from 'struct device' using the
    159'to_eisa_device' macro.
    160
    161Misc stuff
    162==========
    163
    164::
    165
    166	void eisa_set_drvdata (struct eisa_device *edev, void *data);
    167
    168Stores data into the device's driver_data area.
    169
    170::
    171
    172	void *eisa_get_drvdata (struct eisa_device *edev):
    173
    174Gets the pointer previously stored into the device's driver_data area.
    175
    176::
    177
    178	int eisa_get_region_index (void *addr);
    179
    180Returns the region number (0 <= x < EISA_MAX_RESOURCES) of a given
    181address.
    182
    183Kernel parameters
    184=================
    185
    186eisa_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.
    190
    191eisa_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.
    195
    196virtual_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.
    201
    202Random notes
    203============
    204
    205Converting an EISA driver to the new API mostly involves *deleting*
    206code (since probing is now in the core EISA code). Unfortunately, most
    207drivers share their probing routine between ISA, and EISA. Special
    208care 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
    222Thanks
    223======
    224
    225I'd like to thank the following people for their help:
    226
    227- 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.