123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899 |
- Platform Devices and Drivers
- ~~~~~~~~~~~~~~~~~~~~~~~~~~~~
- Platform devices
- ~~~~~~~~~~~~~~~~
- Platform devices are devices that typically appear as autonomous
- entities in the system. This includes legacy port-based devices and
- host bridges to peripheral buses.
- Platform drivers
- ~~~~~~~~~~~~~~~~
- Drivers for platform devices are typically very simple and
- unstructured. Either the device was present at a particular I/O port
- and the driver was loaded, or it was not. There was no possibility
- of hotplugging or alternative discovery besides probing at a specific
- I/O address and expecting a specific response.
- Other Architectures, Modern Firmware, and new Platforms
- ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
- These devices are not always at the legacy I/O ports. This is true on
- other architectures and on some modern architectures. In most cases,
- the drivers are modified to discover the devices at other well-known
- ports for the given platform. However, the firmware in these systems
- does usually know where exactly these devices reside, and in some
- cases, it's the only way of discovering them.
- The Platform Bus
- ~~~~~~~~~~~~~~~~
- A platform bus has been created to deal with these issues. First and
- foremost, it groups all the legacy devices under a common bus, and
- gives them a common parent if they don't already have one.
- But, besides the organizational benefits, the platform bus can also
- accommodate firmware-based enumeration.
- Device Discovery
- ~~~~~~~~~~~~~~~~
- The platform bus has no concept of probing for devices. Devices
- discovery is left up to either the legacy drivers or the
- firmware. These entities are expected to notify the platform of
- devices that it discovers via the bus's add() callback:
- platform_bus.add(parent,bus_id).
- Bus IDs
- ~~~~~~~
- Bus IDs are the canonical names for the devices. There is no globally
- standard addressing mechanism for legacy devices. In the IA-32 world,
- we have Pnp IDs to use, as well as the legacy I/O ports. However,
- neither tell what the device really is or have any meaning on other
- platforms.
- Since both PnP IDs and the legacy I/O ports (and other standard I/O
- ports for specific devices) have a 1:1 mapping, we map the
- platform-specific name or identifier to a generic name (at least
- within the scope of the kernel).
- For example, a serial driver might find a device at I/O 0x3f8. The
- ACPI firmware might also discover a device with PnP ID (_HID)
- PNP0501. Both correspond to the same device and should be mapped to the
- canonical name 'serial'.
- The bus_id field should be a concatenation of the canonical name and
- the instance of that type of device. For example, the device at I/O
- port 0x3f8 should have a bus_id of "serial0". This places the
- responsibility of enumerating devices of a particular type up to the
- discovery mechanism. But, they are the entity that should know best
- (as opposed to the platform bus driver).
- Drivers
- ~~~~~~~
- Drivers for platform devices should have a name that is the same as
- the canonical name of the devices they support. This allows the
- platform bus driver to do simple matching with the basic data
- structures to determine if a driver supports a certain device.
- For example, a legacy serial driver should have a name of 'serial' and
- register itself with the platform bus.
- Driver Binding
- ~~~~~~~~~~~~~~
- Legacy drivers assume they are bound to the device once they start up
- and probe an I/O port. Divorcing them from this will be a difficult
- process. However, that shouldn't prevent us from implementing
- firmware-based enumeration.
- The firmware should notify the platform bus about devices before the
- legacy drivers have had a chance to load. Once the drivers are loaded,
- they driver model core will attempt to bind the driver to any
- previously-discovered devices. Once that has happened, it will be free
- to discover any other devices it pleases.
|