292 lines
11 KiB
Plaintext
292 lines
11 KiB
Plaintext
USB Type-C port devices (eg. /sys/class/typec/port0/)
|
|
|
|
What: /sys/class/typec/<port>/data_role
|
|
Date: April 2017
|
|
Contact: Heikki Krogerus <heikki.krogerus@linux.intel.com>
|
|
Description:
|
|
The supported USB data roles. This attribute can be used for
|
|
requesting data role swapping on the port. Swapping is supported
|
|
as synchronous operation, so write(2) to the attribute will not
|
|
return until the operation has finished. The attribute is
|
|
notified about role changes so that poll(2) on the attribute
|
|
wakes up. Change on the role will also generate uevent
|
|
KOBJ_CHANGE on the port. The current role is show in brackets,
|
|
for example "[host] device" when DRP port is in host mode.
|
|
|
|
Valid values: host, device
|
|
|
|
What: /sys/class/typec/<port>/power_role
|
|
Date: April 2017
|
|
Contact: Heikki Krogerus <heikki.krogerus@linux.intel.com>
|
|
Description:
|
|
The supported power roles. This attribute can be used to request
|
|
power role swap on the port when the port supports USB Power
|
|
Delivery. Swapping is supported as synchronous operation, so
|
|
write(2) to the attribute will not return until the operation
|
|
has finished. The attribute is notified about role changes so
|
|
that poll(2) on the attribute wakes up. Change on the role will
|
|
also generate uevent KOBJ_CHANGE. The current role is show in
|
|
brackets, for example "[source] sink" when in source mode.
|
|
|
|
Valid values: source, sink
|
|
|
|
What: /sys/class/typec/<port>/port_type
|
|
Date: May 2017
|
|
Contact: Badhri Jagan Sridharan <Badhri@google.com>
|
|
Description:
|
|
Indicates the type of the port. This attribute can be used for
|
|
requesting a change in the port type. Port type change is
|
|
supported as a synchronous operation, so write(2) to the
|
|
attribute will not return until the operation has finished.
|
|
|
|
Valid values:
|
|
- source (The port will behave as source only DFP port)
|
|
- sink (The port will behave as sink only UFP port)
|
|
- dual (The port will behave as dual-role-data and
|
|
dual-role-power port)
|
|
|
|
What: /sys/class/typec/<port>/vconn_source
|
|
Date: April 2017
|
|
Contact: Heikki Krogerus <heikki.krogerus@linux.intel.com>
|
|
Description:
|
|
Shows is the port VCONN Source. This attribute can be used to
|
|
request VCONN swap to change the VCONN Source during connection
|
|
when both the port and the partner support USB Power Delivery.
|
|
Swapping is supported as synchronous operation, so write(2) to
|
|
the attribute will not return until the operation has finished.
|
|
The attribute is notified about VCONN source changes so that
|
|
poll(2) on the attribute wakes up. Change on VCONN source also
|
|
generates uevent KOBJ_CHANGE.
|
|
|
|
Valid values:
|
|
- "no" when the port is not the VCONN Source
|
|
- "yes" when the port is the VCONN Source
|
|
|
|
What: /sys/class/typec/<port>/power_operation_mode
|
|
Date: April 2017
|
|
Contact: Heikki Krogerus <heikki.krogerus@linux.intel.com>
|
|
Description:
|
|
Shows the current power operational mode the port is in. The
|
|
power operation mode means current level for VBUS. In case USB
|
|
Power Delivery communication is used for negotiating the levels,
|
|
power operation mode should show "usb_power_delivery".
|
|
|
|
Valid values:
|
|
- default
|
|
- 1.5A
|
|
- 3.0A
|
|
- usb_power_delivery
|
|
|
|
What: /sys/class/typec/<port>/preferred_role
|
|
Date: April 2017
|
|
Contact: Heikki Krogerus <heikki.krogerus@linux.intel.com>
|
|
Description:
|
|
The user space can notify the driver about the preferred role.
|
|
It should be handled as enabling of Try.SRC or Try.SNK, as
|
|
defined in USB Type-C specification, in the port drivers. By
|
|
default the preferred role should come from the platform.
|
|
|
|
Valid values: source, sink, none (to remove preference)
|
|
|
|
What: /sys/class/typec/<port>/supported_accessory_modes
|
|
Date: April 2017
|
|
Contact: Heikki Krogerus <heikki.krogerus@linux.intel.com>
|
|
Description:
|
|
Space separated list of accessory modes, defined in the USB
|
|
Type-C specification, the port supports.
|
|
|
|
What: /sys/class/typec/<port>/usb_power_delivery_revision
|
|
Date: April 2017
|
|
Contact: Heikki Krogerus <heikki.krogerus@linux.intel.com>
|
|
Description:
|
|
Revision number of the supported USB Power Delivery
|
|
specification, or 0 when USB Power Delivery is not supported.
|
|
|
|
What: /sys/class/typec/<port>/usb_typec_revision
|
|
Date: April 2017
|
|
Contact: Heikki Krogerus <heikki.krogerus@linux.intel.com>
|
|
Description:
|
|
Revision number of the supported USB Type-C specification.
|
|
|
|
|
|
USB Type-C partner devices (eg. /sys/class/typec/port0-partner/)
|
|
|
|
What: /sys/class/typec/<port>-partner/accessory_mode
|
|
Date: April 2017
|
|
Contact: Heikki Krogerus <heikki.krogerus@linux.intel.com>
|
|
Description:
|
|
Shows the Accessory Mode name when the partner is an Accessory.
|
|
The Accessory Modes are defined in USB Type-C Specification.
|
|
|
|
What: /sys/class/typec/<port>-partner/supports_usb_power_delivery
|
|
Date: April 2017
|
|
Contact: Heikki Krogerus <heikki.krogerus@linux.intel.com>
|
|
Description:
|
|
Shows if the partner supports USB Power Delivery communication:
|
|
Valid values: yes, no
|
|
|
|
What: /sys/class/typec/<port>-partner>/identity/
|
|
Date: April 2017
|
|
Contact: Heikki Krogerus <heikki.krogerus@linux.intel.com>
|
|
Description:
|
|
This directory appears only if the port device driver is capable
|
|
of showing the result of Discover Identity USB power delivery
|
|
command. That will not always be possible even when USB power
|
|
delivery is supported, for example when USB power delivery
|
|
communication for the port is mostly handled in firmware. If the
|
|
directory exists, it will have an attribute file for every VDO
|
|
in Discover Identity command result.
|
|
|
|
What: /sys/class/typec/<port>-partner/identity/id_header
|
|
Date: April 2017
|
|
Contact: Heikki Krogerus <heikki.krogerus@linux.intel.com>
|
|
Description:
|
|
ID Header VDO part of Discover Identity command result. The
|
|
value will show 0 until Discover Identity command result becomes
|
|
available. The value can be polled.
|
|
|
|
What: /sys/class/typec/<port>-partner/identity/cert_stat
|
|
Date: April 2017
|
|
Contact: Heikki Krogerus <heikki.krogerus@linux.intel.com>
|
|
Description:
|
|
Cert Stat VDO part of Discover Identity command result. The
|
|
value will show 0 until Discover Identity command result becomes
|
|
available. The value can be polled.
|
|
|
|
What: /sys/class/typec/<port>-partner/identity/product
|
|
Date: April 2017
|
|
Contact: Heikki Krogerus <heikki.krogerus@linux.intel.com>
|
|
Description:
|
|
Product VDO part of Discover Identity command result. The value
|
|
will show 0 until Discover Identity command result becomes
|
|
available. The value can be polled.
|
|
|
|
|
|
USB Type-C cable devices (eg. /sys/class/typec/port0-cable/)
|
|
|
|
Note: Electronically Marked Cables will have a device also for one cable plug
|
|
(eg. /sys/class/typec/port0-plug0). If the cable is active and has also SOP
|
|
Double Prime controller (USB Power Deliver specification ch. 2.4) it will have
|
|
second device also for the other plug. Both plugs may have alternate modes as
|
|
described in USB Type-C and USB Power Delivery specifications.
|
|
|
|
What: /sys/class/typec/<port>-cable/type
|
|
Date: April 2017
|
|
Contact: Heikki Krogerus <heikki.krogerus@linux.intel.com>
|
|
Description:
|
|
Shows if the cable is active.
|
|
Valid values: active, passive
|
|
|
|
What: /sys/class/typec/<port>-cable/plug_type
|
|
Date: April 2017
|
|
Contact: Heikki Krogerus <heikki.krogerus@linux.intel.com>
|
|
Description:
|
|
Shows type of the plug on the cable:
|
|
- type-a - Standard A
|
|
- type-b - Standard B
|
|
- type-c
|
|
- captive
|
|
|
|
What: /sys/class/typec/<port>-cable/identity/
|
|
Date: April 2017
|
|
Contact: Heikki Krogerus <heikki.krogerus@linux.intel.com>
|
|
Description:
|
|
This directory appears only if the port device driver is capable
|
|
of showing the result of Discover Identity USB power delivery
|
|
command. That will not always be possible even when USB power
|
|
delivery is supported. If the directory exists, it will have an
|
|
attribute for every VDO returned by Discover Identity command.
|
|
|
|
What: /sys/class/typec/<port>-cable/identity/id_header
|
|
Date: April 2017
|
|
Contact: Heikki Krogerus <heikki.krogerus@linux.intel.com>
|
|
Description:
|
|
ID Header VDO part of Discover Identity command result. The
|
|
value will show 0 until Discover Identity command result becomes
|
|
available. The value can be polled.
|
|
|
|
What: /sys/class/typec/<port>-cable/identity/cert_stat
|
|
Date: April 2017
|
|
Contact: Heikki Krogerus <heikki.krogerus@linux.intel.com>
|
|
Description:
|
|
Cert Stat VDO part of Discover Identity command result. The
|
|
value will show 0 until Discover Identity command result becomes
|
|
available. The value can be polled.
|
|
|
|
What: /sys/class/typec/<port>-cable/identity/product
|
|
Date: April 2017
|
|
Contact: Heikki Krogerus <heikki.krogerus@linux.intel.com>
|
|
Description:
|
|
Product VDO part of Discover Identity command result. The value
|
|
will show 0 until Discover Identity command result becomes
|
|
available. The value can be polled.
|
|
|
|
|
|
Alternate Mode devices.
|
|
|
|
The alternate modes will have Standard or Vendor ID (SVID) assigned by USB-IF.
|
|
The ports, partners and cable plugs can have alternate modes. A supported SVID
|
|
will consist of a set of modes. Every SVID a port/partner/plug supports will
|
|
have a device created for it, and every supported mode for a supported SVID will
|
|
have its own directory under that device. Below <dev> refers to the device for
|
|
the alternate mode.
|
|
|
|
What: /sys/class/typec/<port|partner|cable>/<dev>/svid
|
|
Date: April 2017
|
|
Contact: Heikki Krogerus <heikki.krogerus@linux.intel.com>
|
|
Description:
|
|
The SVID (Standard or Vendor ID) assigned by USB-IF for this
|
|
alternate mode.
|
|
|
|
What: /sys/class/typec/<port|partner|cable>/<dev>/mode<index>/
|
|
Date: April 2017
|
|
Contact: Heikki Krogerus <heikki.krogerus@linux.intel.com>
|
|
Description:
|
|
Every supported mode will have its own directory. The name of
|
|
a mode will be "mode<index>" (for example mode1), where <index>
|
|
is the actual index to the mode VDO returned by Discover Modes
|
|
USB power delivery command.
|
|
|
|
What: /sys/class/typec/<port|partner|cable>/<dev>/mode<index>/description
|
|
Date: April 2017
|
|
Contact: Heikki Krogerus <heikki.krogerus@linux.intel.com>
|
|
Description:
|
|
Shows description of the mode. The description is optional for
|
|
the drivers, just like with the Billboard Devices.
|
|
|
|
What: /sys/class/typec/<port|partner|cable>/<dev>/mode<index>/vdo
|
|
Date: April 2017
|
|
Contact: Heikki Krogerus <heikki.krogerus@linux.intel.com>
|
|
Description:
|
|
Shows the VDO in hexadecimal returned by Discover Modes command
|
|
for this mode.
|
|
|
|
What: /sys/class/typec/<port|partner|cable>/<dev>/mode<index>/active
|
|
Date: April 2017
|
|
Contact: Heikki Krogerus <heikki.krogerus@linux.intel.com>
|
|
Description:
|
|
Shows if the mode is active or not. The attribute can be used
|
|
for entering/exiting the mode with partners and cable plugs, and
|
|
with the port alternate modes it can be used for disabling
|
|
support for specific alternate modes. Entering/exiting modes is
|
|
supported as synchronous operation so write(2) to the attribute
|
|
does not return until the enter/exit mode operation has
|
|
finished. The attribute is notified when the mode is
|
|
entered/exited so poll(2) on the attribute wakes up.
|
|
Entering/exiting a mode will also generate uevent KOBJ_CHANGE.
|
|
|
|
Valid values: yes, no
|
|
|
|
What: /sys/class/typec/<port>/<dev>/mode<index>/supported_roles
|
|
Date: April 2017
|
|
Contact: Heikki Krogerus <heikki.krogerus@linux.intel.com>
|
|
Description:
|
|
Space separated list of the supported roles.
|
|
|
|
This attribute is available for the devices describing the
|
|
alternate modes a port supports, and it will not be exposed with
|
|
the devices presenting the alternate modes the partners or cable
|
|
plugs support.
|
|
|
|
Valid values: source, sink
|