mirror of https://gitee.com/openkylin/linux.git
100 lines
3.8 KiB
Plaintext
100 lines
3.8 KiB
Plaintext
|
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.
|
||
|
|