1234567891011121314151617181920212223242526272829303132333435363738394041424344454647 |
- What: /sys/bus/pci/drivers/ehci_hcd/.../companion
- /sys/bus/usb/devices/usbN/../companion
- Date: January 2007
- KernelVersion: 2.6.21
- Contact: Alan Stern <stern@rowland.harvard.edu>
- Description:
- PCI-based EHCI USB controllers (i.e., high-speed USB-2.0
- controllers) are often implemented along with a set of
- "companion" full/low-speed USB-1.1 controllers. When a
- high-speed device is plugged in, the connection is routed
- to the EHCI controller; when a full- or low-speed device
- is plugged in, the connection is routed to the companion
- controller.
- Sometimes you want to force a high-speed device to connect
- at full speed, which can be accomplished by forcing the
- connection to be routed to the companion controller.
- That's what this file does. Writing a port number to the
- file causes connections on that port to be routed to the
- companion controller, and writing the negative of a port
- number returns the port to normal operation.
- For example: To force the high-speed device attached to
- port 4 on bus 2 to run at full speed:
- echo 4 >/sys/bus/usb/devices/usb2/../companion
- To return the port to high-speed operation:
- echo -4 >/sys/bus/usb/devices/usb2/../companion
- Reading the file gives the list of ports currently forced
- to the companion controller.
- Note: Some EHCI controllers do not have companions; they
- may contain an internal "transaction translator" or they
- may be attached directly to a "rate-matching hub". This
- mechanism will not work with such controllers. Also, it
- cannot be used to force a port on a high-speed hub to
- connect at full speed.
- Note: When this file was first added, it appeared in a
- different sysfs directory. The location given above is
- correct for 2.6.35 (and probably several earlier kernel
- versions as well).
|