USB doc patch 2

A little more detail on how and when to poll() /proc/bus/usb/devices.

Signed-off-by: Sam Bishop <sam@bishop.dhs.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
This commit is contained in:
Sam Bishop 2006-08-28 16:52:15 -06:00 committed by Greg Kroah-Hartman
parent 3413232692
commit 06afff00bc
1 changed files with 18 additions and 7 deletions

View File

@ -453,14 +453,25 @@
file in your Linux kernel sources. file in your Linux kernel sources.
</para> </para>
<para>Otherwise the main use for this file from programs <para>This file, in combination with the poll() system call, can
is to poll() it to get notifications of usb devices also be used to detect when devices are added or removed:
as they're plugged or unplugged. <programlisting>int fd;
To see what changed, you'd need to read the file and struct pollfd pfd;
compare "before" and "after" contents, scan the filesystem,
or see its hotplug event.
</para>
fd = open("/proc/bus/usb/devices", O_RDONLY);
pfd = { fd, POLLIN, 0 };
for (;;) {
/* The first time through, this call will return immediately. */
poll(&amp;pfd, 1, -1);
/* To see what's changed, compare the file's previous and current
contents or scan the filesystem. (Scanning is more precise.) */
}</programlisting>
Note that this behavior is intended to be used for informational
and debug purposes. It would be more appropriate to use programs
such as udev or HAL to initialize a device or start a user-mode
helper program, for instance.
</para>
</sect1> </sect1>
<sect1> <sect1>