Updated: April 19, 2023 |
Device drivers enable publishers to communicate with attached devices by supporting POSIX system calls such as open() and read(). Publishers issue these system calls to drivers to obtain information about the devices that the drivers manage; they then publish the information to PPS objects that applications monitor. Using this information, applications can issue PPS commands to perform actions such as setting the power of a USB hub or ejecting a CD.
Activity | usblauncher_otg | mmcsdpub | cdpub |
---|---|---|---|
Driver startup | USB launcher service starts and stops drivers when devices are added or removed | Driver launched at system startup and runs continuously | Driver launched at system startup and runs continuously |
Driver communication |
Drivers create entries in /dev for attached USB devices and manage communication with USB-connected devices: mass storage, DVD, SD Card, etc. The service monitors /dev entries and, when it notices a state change, asks the driver to retrieve device and mount information, which it then publishers through PPS.a The service also gets event notifications (e.g., device insertions and removals) from the USB server; it then writes these to PPS. |
The driver creates entries in /dev for attached devices and manages communication with SD cards. The service monitors /dev entries and, when it notices a state change, asks the driver to retrieve device and mount information, which it then publishes through PPS. |
The driver creates entries in /dev for CD devices and manages communication with DVDs, audio CDs, CD-ROMs, etc. The service monitors /dev entries and, when it notices a state change, asks driver to retrieve device and mount information, which it then publishes through PPS. |