| ============== | 
 | Device Drivers | 
 | ============== | 
 |  | 
 | See the kerneldoc for the struct device_driver. | 
 |  | 
 | Allocation | 
 | ~~~~~~~~~~ | 
 |  | 
 | Device drivers are statically allocated structures. Though there may | 
 | be multiple devices in a system that a driver supports, struct | 
 | device_driver represents the driver as a whole (not a particular | 
 | device instance). | 
 |  | 
 | Initialization | 
 | ~~~~~~~~~~~~~~ | 
 |  | 
 | The driver must initialize at least the name and bus fields. It should | 
 | also initialize the devclass field (when it arrives), so it may obtain | 
 | the proper linkage internally. It should also initialize as many of | 
 | the callbacks as possible, though each is optional. | 
 |  | 
 | Declaration | 
 | ~~~~~~~~~~~ | 
 |  | 
 | As stated above, struct device_driver objects are statically | 
 | allocated. Below is an example declaration of the eepro100 | 
 | driver. This declaration is hypothetical only; it relies on the driver | 
 | being converted completely to the new model:: | 
 |  | 
 |   static struct device_driver eepro100_driver = { | 
 |          .name		= "eepro100", | 
 |          .bus		= &pci_bus_type, | 
 |  | 
 |          .probe		= eepro100_probe, | 
 |          .remove		= eepro100_remove, | 
 |          .suspend		= eepro100_suspend, | 
 |          .resume		= eepro100_resume, | 
 |   }; | 
 |  | 
 | Most drivers will not be able to be converted completely to the new | 
 | model because the bus they belong to has a bus-specific structure with | 
 | bus-specific fields that cannot be generalized. | 
 |  | 
 | The most common example of this are device ID structures. A driver | 
 | typically defines an array of device IDs that it supports. The format | 
 | of these structures and the semantics for comparing device IDs are | 
 | completely bus-specific. Defining them as bus-specific entities would | 
 | sacrifice type-safety, so we keep bus-specific structures around. | 
 |  | 
 | Bus-specific drivers should include a generic struct device_driver in | 
 | the definition of the bus-specific driver. Like this:: | 
 |  | 
 |   struct pci_driver { | 
 |          const struct pci_device_id *id_table; | 
 |          struct device_driver	  driver; | 
 |   }; | 
 |  | 
 | A definition that included bus-specific fields would look like | 
 | (using the eepro100 driver again):: | 
 |  | 
 |   static struct pci_driver eepro100_driver = { | 
 |          .id_table       = eepro100_pci_tbl, | 
 |          .driver	       = { | 
 | 		.name		= "eepro100", | 
 | 		.bus		= &pci_bus_type, | 
 | 		.probe		= eepro100_probe, | 
 | 		.remove		= eepro100_remove, | 
 | 		.suspend	= eepro100_suspend, | 
 | 		.resume		= eepro100_resume, | 
 |          }, | 
 |   }; | 
 |  | 
 | Some may find the syntax of embedded struct initialization awkward or | 
 | even a bit ugly. So far, it's the best way we've found to do what we want... | 
 |  | 
 | Registration | 
 | ~~~~~~~~~~~~ | 
 |  | 
 | :: | 
 |  | 
 |   int driver_register(struct device_driver *drv); | 
 |  | 
 | The driver registers the structure on startup. For drivers that have | 
 | no bus-specific fields (i.e. don't have a bus-specific driver | 
 | structure), they would use driver_register and pass a pointer to their | 
 | struct device_driver object. | 
 |  | 
 | Most drivers, however, will have a bus-specific structure and will | 
 | need to register with the bus using something like pci_driver_register. | 
 |  | 
 | It is important that drivers register their driver structure as early as | 
 | possible. Registration with the core initializes several fields in the | 
 | struct device_driver object, including the reference count and the | 
 | lock. These fields are assumed to be valid at all times and may be | 
 | used by the device model core or the bus driver. | 
 |  | 
 |  | 
 | Transition Bus Drivers | 
 | ~~~~~~~~~~~~~~~~~~~~~~ | 
 |  | 
 | By defining wrapper functions, the transition to the new model can be | 
 | made easier. Drivers can ignore the generic structure altogether and | 
 | let the bus wrapper fill in the fields. For the callbacks, the bus can | 
 | define generic callbacks that forward the call to the bus-specific | 
 | callbacks of the drivers. | 
 |  | 
 | This solution is intended to be only temporary. In order to get class | 
 | information in the driver, the drivers must be modified anyway. Since | 
 | converting drivers to the new model should reduce some infrastructural | 
 | complexity and code size, it is recommended that they are converted as | 
 | class information is added. | 
 |  | 
 | Access | 
 | ~~~~~~ | 
 |  | 
 | Once the object has been registered, it may access the common fields of | 
 | the object, like the lock and the list of devices:: | 
 |  | 
 |   int driver_for_each_dev(struct device_driver *drv, void *data, | 
 | 			  int (*callback)(struct device *dev, void *data)); | 
 |  | 
 | The devices field is a list of all the devices that have been bound to | 
 | the driver. The LDM core provides a helper function to operate on all | 
 | the devices a driver controls. This helper locks the driver on each | 
 | node access, and does proper reference counting on each device as it | 
 | accesses it. | 
 |  | 
 |  | 
 | sysfs | 
 | ~~~~~ | 
 |  | 
 | When a driver is registered, a sysfs directory is created in its | 
 | bus's directory. In this directory, the driver can export an interface | 
 | to userspace to control operation of the driver on a global basis; | 
 | e.g. toggling debugging output in the driver. | 
 |  | 
 | A future feature of this directory will be a 'devices' directory. This | 
 | directory will contain symlinks to the directories of devices it | 
 | supports. | 
 |  | 
 |  | 
 |  | 
 | Callbacks | 
 | ~~~~~~~~~ | 
 |  | 
 | :: | 
 |  | 
 | 	int	(*probe)	(struct device *dev); | 
 |  | 
 | The probe() entry is called in task context, with the bus's rwsem locked | 
 | and the driver partially bound to the device.  Drivers commonly use | 
 | container_of() to convert "dev" to a bus-specific type, both in probe() | 
 | and other routines.  That type often provides device resource data, such | 
 | as pci_dev.resource[] or platform_device.resources, which is used in | 
 | addition to dev->platform_data to initialize the driver. | 
 |  | 
 | This callback holds the driver-specific logic to bind the driver to a | 
 | given device.  That includes verifying that the device is present, that | 
 | it's a version the driver can handle, that driver data structures can | 
 | be allocated and initialized, and that any hardware can be initialized. | 
 | Drivers often store a pointer to their state with dev_set_drvdata(). | 
 | When the driver has successfully bound itself to that device, then probe() | 
 | returns zero and the driver model code will finish its part of binding | 
 | the driver to that device. | 
 |  | 
 | A driver's probe() may return a negative errno value to indicate that | 
 | the driver did not bind to this device, in which case it should have | 
 | released all resources it allocated. | 
 |  | 
 | Optionally, probe() may return -EPROBE_DEFER if the driver depends on | 
 | resources that are not yet available (e.g., supplied by a driver that | 
 | hasn't initialized yet).  The driver core will put the device onto the | 
 | deferred probe list and will try to call it again later. If a driver | 
 | must defer, it should return -EPROBE_DEFER as early as possible to | 
 | reduce the amount of time spent on setup work that will need to be | 
 | unwound and reexecuted at a later time. | 
 |  | 
 | .. warning:: | 
 |       -EPROBE_DEFER must not be returned if probe() has already created | 
 |       child devices, even if those child devices are removed again | 
 |       in a cleanup path. If -EPROBE_DEFER is returned after a child | 
 |       device has been registered, it may result in an infinite loop of | 
 |       .probe() calls to the same driver. | 
 |  | 
 | :: | 
 |  | 
 | 	void	(*sync_state)	(struct device *dev); | 
 |  | 
 | sync_state is called only once for a device. It's called when all the consumer | 
 | devices of the device have successfully probed. The list of consumers of the | 
 | device is obtained by looking at the device links connecting that device to its | 
 | consumer devices. | 
 |  | 
 | The first attempt to call sync_state() is made during late_initcall_sync() to | 
 | give firmware and drivers time to link devices to each other. During the first | 
 | attempt at calling sync_state(), if all the consumers of the device at that | 
 | point in time have already probed successfully, sync_state() is called right | 
 | away. If there are no consumers of the device during the first attempt, that | 
 | too is considered as "all consumers of the device have probed" and sync_state() | 
 | is called right away. | 
 |  | 
 | If during the first attempt at calling sync_state() for a device, there are | 
 | still consumers that haven't probed successfully, the sync_state() call is | 
 | postponed and reattempted in the future only when one or more consumers of the | 
 | device probe successfully. If during the reattempt, the driver core finds that | 
 | there are one or more consumers of the device that haven't probed yet, then | 
 | sync_state() call is postponed again. | 
 |  | 
 | A typical use case for sync_state() is to have the kernel cleanly take over | 
 | management of devices from the bootloader. For example, if a device is left on | 
 | and at a particular hardware configuration by the bootloader, the device's | 
 | driver might need to keep the device in the boot configuration until all the | 
 | consumers of the device have probed. Once all the consumers of the device have | 
 | probed, the device's driver can synchronize the hardware state of the device to | 
 | match the aggregated software state requested by all the consumers. Hence the | 
 | name sync_state(). | 
 |  | 
 | While obvious examples of resources that can benefit from sync_state() include | 
 | resources such as regulator, sync_state() can also be useful for complex | 
 | resources like IOMMUs. For example, IOMMUs with multiple consumers (devices | 
 | whose addresses are remapped by the IOMMU) might need to keep their mappings | 
 | fixed at (or additive to) the boot configuration until all its consumers have | 
 | probed. | 
 |  | 
 | While the typical use case for sync_state() is to have the kernel cleanly take | 
 | over management of devices from the bootloader, the usage of sync_state() is | 
 | not restricted to that. Use it whenever it makes sense to take an action after | 
 | all the consumers of a device have probed:: | 
 |  | 
 | 	int 	(*remove)	(struct device *dev); | 
 |  | 
 | remove is called to unbind a driver from a device. This may be | 
 | called if a device is physically removed from the system, if the | 
 | driver module is being unloaded, during a reboot sequence, or | 
 | in other cases. | 
 |  | 
 | It is up to the driver to determine if the device is present or | 
 | not. It should free any resources allocated specifically for the | 
 | device; i.e. anything in the device's driver_data field. | 
 |  | 
 | If the device is still present, it should quiesce the device and place | 
 | it into a supported low-power state. | 
 |  | 
 | :: | 
 |  | 
 | 	int	(*suspend)	(struct device *dev, pm_message_t state); | 
 |  | 
 | suspend is called to put the device in a low power state. | 
 |  | 
 | :: | 
 |  | 
 | 	int	(*resume)	(struct device *dev); | 
 |  | 
 | Resume is used to bring a device back from a low power state. | 
 |  | 
 |  | 
 | Attributes | 
 | ~~~~~~~~~~ | 
 |  | 
 | :: | 
 |  | 
 |   struct driver_attribute { | 
 |           struct attribute        attr; | 
 |           ssize_t (*show)(struct device_driver *driver, char *buf); | 
 |           ssize_t (*store)(struct device_driver *, const char *buf, size_t count); | 
 |   }; | 
 |  | 
 | Device drivers can export attributes via their sysfs directories. | 
 | Drivers can declare attributes using a DRIVER_ATTR_RW and DRIVER_ATTR_RO | 
 | macro that works identically to the DEVICE_ATTR_RW and DEVICE_ATTR_RO | 
 | macros. | 
 |  | 
 | Example:: | 
 |  | 
 | 	DRIVER_ATTR_RW(debug); | 
 |  | 
 | This is equivalent to declaring:: | 
 |  | 
 | 	struct driver_attribute driver_attr_debug; | 
 |  | 
 | This can then be used to add and remove the attribute from the | 
 | driver's directory using:: | 
 |  | 
 |   int driver_create_file(struct device_driver *, const struct driver_attribute *); | 
 |   void driver_remove_file(struct device_driver *, const struct driver_attribute *); |