Power delivery and data transmission using PCIe protocol via USB type-C port

Information

  • Patent Grant
  • 9952986
  • Patent Number
    9,952,986
  • Date Filed
    Thursday, December 31, 2015
    8 years ago
  • Date Issued
    Tuesday, April 24, 2018
    6 years ago
Abstract
Techniques for transmitted data through a USB port using a PCIe protocol are described herein. In one example, an apparatus includes a host controller, a root port, a multiplexor coupled to the host controller and the root port and a power delivery module. The power delivery module and the multiplexor can transmit and receive a request via a multimode input/output (I/O) interface and the power delivery module can detect a presence of an external device in response to the external device being coupled to the multimode I/O interface. The power delivery module can also send a first request to the external device to discover a vendor identifier of the external device, send a second request to discover at least one alternate mode supported by the external device, and send a third request to enable data transfer via the protocol.
Description
TECHNICAL FIELD

This disclosure relates generally to data transmission using a Peripheral Component Interconnect express (also referred to herein as PCIe) protocol and specifically, but not exclusively, to data transmission using a PCIe protocol via a USB port.


BACKGROUND

The universal serial bus (also referred to herein as USB) Type-C receptacle, plug and cable provide a smaller, thinner and more robust alternative to transmit data than using the existing USB 3.0 interconnect with standard or micro USB cables and connectors. The USB Type-C connector can be used in very thin platforms or devices, ranging from ultra-thin notebooks to hand held electronic devices, such as smart phones, where existing Standard-A and Micro-AB receptacles are deemed too large, difficult to use, or inadequately robust. In some examples, the USB Type-C receptacle may be used in very thin platforms as the total system height for the mounted USB Type-C receptacle can be less than three millimeters. Also, the USB Type-C plug can enhance ease of use by being plug-able in either upside-up or upside-down configurations. Furthermore, the USB Type-C cable enhances ease of use by being plug-able in either direction between a host device and a slave device.





BRIEF DESCRIPTION OF THE DRAWINGS


FIG. 1 illustrates a block diagram of a computing device that can transmit data using a PCIe protocol via a USB port;



FIG. 2 illustrates a block diagram of an example of a host device with a USB port;



FIG. 3 illustrates a block diagram of an example of a slave device with a USB port; and



FIG. 4 illustrates a process flow diagram for transmitting data using a PCIe protocol via a USB port.





In some cases, the same numbers are used throughout the disclosure and the figures to reference like components and features. Numbers in the 100 series refer to features originally found in FIG. 1; numbers in the 200 series refer to features originally found in FIG. 2; and so on.


DESCRIPTION OF THE EMBODIMENTS

The USB Type-C port or receptacle can enable signaling link technologies, which may have a main signaling link that can be associated with additional signals, such as sideband signals and configuration signals, which are not configured to propagate over the main signaling link. Sideband link input/output (I/O) technologies provide a way for a sideband signal to be provided from one component of a computing device to another component without being propagated on the main signaling link. In some examples, sideband signals can be transmitted along with configuration signals to indicate protocols to be used to transmit data through universal serial bus receptacles or ports.


The techniques described herein include transmitting data using a serial expansion bus protocol, such as PCIe, among others, via a USB receptacle or port. In some embodiments, a host computing device can be coupled to a slave computing device via a multi-mode connector or receptacle, such as the USB Type-C connector or receptacle, among others. The host computing device may include logic to enable data transmission through the USB receptacle using a PCIe protocol. In some embodiments, the host computing device can transmit data to a slave computing device (also referred to herein as a PCIe compatible device) through a USB Type-C port and receptacle. A USB Type-C port, as referred to herein, is a USB port associated to a USB Type-C receptacle, which can include USB signaling, configuration channel logic, multiplexers and other associated logic. A USB Type-C receptacle, as referred to herein, can include a USB receptacle conforming to the mechanical and electrical requirements of the Type-C specification.



FIG. 1 is a block diagram of an example of a host computing device that can transmit data using a PCIe protocol via a USB port. The host computing device 100 may be, for example, a mobile phone, laptop computer, desktop computer, or tablet computer, among others. The host computing device 100 may include a processor 102 that is adapted to execute stored instructions, as well as a memory device 104 that stores instructions that are executable by the processor 102. The processor 102 can be a single core processor, a multi-core processor, a computing cluster, or any number of other configurations. The memory device 104 can include random access memory, read only memory, flash memory, or any other suitable memory systems. The instructions that are executed by the processor 102 may be used to implement a method that can transmit data using a PCIe protocol via a USB port.


The processor 102 may also be linked through the system interconnect 106 (e.g., PCI®, PCI-Express®, NuBus, etc.) to a display interface 108 adapted to connect the host computing device 100 to a display device 110. The display device 110 may include a display screen that is a built-in component of the host computing device 100. The display device 110 may also include a computer monitor, television, or projector, among others, that is externally connected to the host computing device 100. In addition, a network interface controller (also referred to herein as a NIC) 112 may be adapted to connect the host computing device 100 through the system interconnect 106 to a network (not depicted). The network (not depicted) may be a cellular network, a radio network, a wide area network (WAN), a local area network (LAN), or the Internet, among others.


The processor 102 may be connected through a system interconnect 106 to an input/output (I/O) device interface 114 adapted to connect the computing host device 100 to one or more I/O devices 116. The I/O devices 116 may include, for example, a keyboard and a pointing device, wherein the pointing device may include a touchpad or a touchscreen, among others. The I/O devices 116 may be built-in components of the host computing device 100, or may be devices that are externally connected to the host computing device 100.


In some embodiments, the processor 102 may also be linked through the system interconnect 106 to a storage device 118 that can include a hard drive, an optical drive, a USB flash drive, an array of drives, or any combinations thereof. In some embodiments, the storage device 118 can include any suitable application that may attempt to transmit data to an external computing device 120. In some embodiments, the data can be transmitted from the storage device 118 to the external computing device 120 via a universal serial bus (also referred to herein as USB) port 122. The USB port 122 includes a USB power delivery module (also referred to herein as USB PD) 124 that can transmit data from the storage device 118 to the external computing device 120 using any suitable protocol supported by the external computing device 120. In some embodiments, the USB port 122 may transmit data to the external computing device 120 from any suitable component, logic, or application, among others, within the host computing device 100. In some examples, the USB PD 124 may detect that the external computing device 120 can transmit data through the USB port 120 using a PCIe protocol and initiate a data transmission using the PCIe protocol. Techniques for transmitting data through USB port 122 using a PCIe protocol are described in greater detail below in relation to FIGS. 2-4. Additionally, in some embodiments, the USB port 122 can include various components, such as multiplexors, and sideband consolidation logic, among others. The components of the USB port 122 are described in greater detail below in relation to FIGS. 2 and 3.


It is to be understood that the block diagram of FIG. 1 is not intended to indicate that the host computing device 100 is to include all of the components shown in FIG. 1. Rather, the host computing device 100 can include fewer or additional components not illustrated in FIG. 1 (e.g., additional memory components, embedded controllers, additional modules, additional network interfaces, etc.). Furthermore, any of the functionalities of the USB port 122 or USB PD 124 may be partially, or entirely, implemented in hardware and/or in the processor 102. For example, the functionality may be implemented with an application specific integrated circuit, logic implemented in an embedded controller, or in logic implemented in the processor 102, among others. In some embodiments, the functionalities of the USB port 122 or USB PD 122 can be implemented with logic, wherein the logic, as referred to herein, can include any suitable hardware (e.g., a processor, among others), software (e.g., an application, among others), firmware, or any suitable combination of hardware, software, and firmware.



FIG. 2 illustrates a block diagram of an example of a host device with a USB port. In some embodiments, the USB port 122 can include a USB receptacle 200, USB Power Delivery (USB PD) logic 124, a multiplexor 202, an extensible Host Controller Interface (also referred to herein as xHCI Host Controller) 204, and a PCIe Controller Root Port 206.


In some embodiments, the USB PD 124 can detect a set mode signal 210 from the host computing device comprising the USB port 122. For example, the USB PD 124 can detect a set mode signal 210 that indicates the USB PD 124 is to attempt to transmit data with an external computing device using any suitable protocol such as PCIe, among others. In some examples, the USB PD 124 can use configuration channel signals 212, such as CC1 and CC2, to determine if an external computing device is coupled to the USB receptacle 122. A configuration channel (CC), as used herein, can be used in the discovery, configuration and management of connections across a USB Type-C cable.


In some embodiments, the USB PD 124 can detect if an external device coupled to the USB receptacle 200 can transmit data using a vendor or non-USB protocol. For example, the USB PD 124 can detect support within a host computing device for a vendor mode or protocol from the set mode signal 210. The USB PD 124 can then send, as part of a discovery process, a request or vendor defined message to the device coupled to the USB receptacle 122 to determine if the device can transmit data using the requested vendor or non-USB protocol. In some embodiments, the coupled device can respond with an acknowledgment to indicate that the coupled device can proceed with transmitting data to the USB receptacle 122 using the requested protocol or vendor mode.


In some examples, the USB PD 124 can also send a vendor defined message or request to initiate an enter mode process to begin transmitting data using a vendor or non-USB protocol such as the PCIe protocol. In some embodiments, the vendor defined message can include an alternate mode. An alternate mode, as referred to herein, includes an operation defined by a vendor or standards organization that is associated with a standard video identifier (SVID) assigned by any suitable specification such as the USB-IF specification. An alternate mode can be entered or exited by enter mode and exit mode commands included in vendor defined messages as described in greater detail below in Table 2.


The USB PD 124 can send a signal to the multiplexor 202 in response to receiving an acknowledgment from the device coupled to the USB receptacle 122 that indicates data transmission can be initiated using the PCIe protocol. In some embodiments, the signal from the USB PD 124 to the multiplexor 202 can indicate that the multiplexor 202 is to transmit data with the PCIe Controller Root Port 206 rather than the xHCI Host Controller 204. In some examples, the multiplexor 202 can transmit signals to a device coupled to the Type-C receptacle 200 using sideband channels 208 SBU1 and SBU2, which can enable clock management, and a reset, among others.


In some embodiments, the multiplexor 202 can transmit data to the device coupled to the USB receptacle (also referred to as Type-C receptacle) 200 using data lanes 214 and forward data received from data lanes 214 to the PCIe Controller Root Port 206 through data lanes 216. In some embodiments, USB PD 124 can also indicate to the multiplexor 202 that a USB protocol is to be used to transmit data with a device coupled to the USB receptacle 200. The multiplexor 202 can transmit data to the device coupled to the USB receptacle 122 using data lanes 214 or 218 and forward received data to the xHCI Host controller 204 based on the appropriate USB protocol. For example, the multiplexor 202 can forward data using a USB 3.0 protocol to the xHCI Host controller 204 using data lanes 220 or 2202 based on the USB port in the xHCI Host controller 204 that is to receive data from the multiplexor 202. In some examples, data transmitted from the USB receptacle 200 to the xHCI Host controller 204 using the USB 2.0 protocol can bypass the multiplexor 202. In some embodiments, sideband consolidation logic 224 in the multiplexor 202 can receive signals 226 from the PCIe controller root port 206, such as a PERST# signal, a CLKREQ# signal, and a WAKE# signal as a part of the consolidated sideband packet. The PERST# signal can indicate when a power supply is within a voltage tolerance range. The PERST# signal can also initialize logic, such as any suitable state machine, and reset a PCIe link or connection. The Wake# signal is an active low signal that can be transmitted by a PCIe component to reactivate a PCIe component's reference clocks and power. The WAKE# signal can be used to transition a host device to a higher power state, interrupt a host device, or to achieve a buffer flush/fill process. The CLKREQ# or clock request signal can indicate a state (e.g. high state or low state) of the clock for the USB port 122 or host computing device. The CLKREQ# signal can be used when a device exits a low power state. In some embodiments, the multiplexor 202 can continue to forward data to the xHCI Host controller 204 or the PCIe Controller Root Port 206 based on the appropriate protocol until a signal is received from the USB PD 124 indicating that an exit command has been received.


It is to be understood that the block diagram of FIG. 2 is not intended to indicate that the USB port 122 is to include all of the components shown in FIG. 2. Rather, the USB port 122 can include fewer or additional components not illustrated in FIG. 2 (e.g., additional memory components, embedded controllers, additional modules, etc.). Additionally, the USB port 122 may also execute additional instructions or techniques for transmitting data through a USB receptacle 200 using a PCIe protocol. For example, the USB PD 124 of the USB port 122 may also generate an operation mode 226 (also referred to as op mode) signal that can indicate to a host computing device that the USB port 122 is transmitting data to a slave device using a PCIe protocol.



FIG. 3 illustrates a block diagram of an example of a slave device with a USB port. In some embodiments, the USB port 300 can include a USB plug 302, a USB 2.0 Billboard device 304, sideband consolidation logic 306, a PCIe controller end point 308, and a USB PD End Point (also referred to herein as USB PD EP) 310.


In some examples, the USB port 300 can transmit data to a USB receptacle 122 in a host computing device using a PCIe protocol through USB plug 302. For example, the USB PD EP 310 can receive a vendor defined message from a USB PD in a host computing device. The vendor defined message may attempt to discover or identify alternate modes or interfaces that the USB port 300 supports for data transmission. The USB PD EP 310 may return a response to the vendor defined message including an indication of the alternate modes supported by USB port 300. The USB PD EP 310 may then receive a vendor defined message requesting the USB PD EP 310 to enter an alternate mode such as a mode transmitting data using PCIe protocol. The USB port 300 can then receive data using a USB 2.0 protocol at the USB 2.0 billboard device 304 via data lanes 218. In some examples, the USB port 300 may generate an error indicating that the USB port 300 does not support data transmission using the PCIe protocol. Alternatively, the USB port 300 can receive data transmitted with a PCIe protocol at the PCIe controller end point 308 via data lanes 214. The USB port 300 can also detect signals transmitted to the sideband consolidation logic 306 through data lanes 208. In some embodiments, the sideband consolidation logic 306 can also forward the signals to the PCIe controller root port 308 through data lanes 226. In some examples, the signals can include the PERST#, CLKREQ#, and WAKE# signals from the host computing device. The USB port 300 can also receive power from the VBUS signal 312.


It is to be understood that the block diagram of FIG. 3 is not intended to indicate that the USB port 300 is to include all of the components shown in FIG. 3. Rather, the USB port 300 can include fewer or additional components not illustrated in FIG. 3 (e.g., additional memory components, embedded controllers, additional modules, etc.).



FIG. 4 illustrates a process flow diagram for transmitting data using a PCIe protocol via a USB port. The method 400 illustrated in FIG. 4 can be implemented with any suitable computing component or device, such as computing device 100 of FIG. 1, or USB port 300 of FIG. 3.


At block 402, the USB PD 124 can detect a presence of a slave device in response to the slave device being coupled to the host. In some embodiments, a slave device can be coupled to a host device comprising USB PD 124 using any suitable cable and any suitable port or receptacle such as a Type-C port or receptacle. In some examples, the slave device can be PCIe compatible. The USB PD 124 can detect the presence of the device by detecting an electrical signal transmitted via pins, such as configuration channel pins, in a connector coupled to a receptacle. In some embodiments, the configuration channel pins can establish and manage downstream facing port in a host device (also referred to herein as DFP) to upstream facing port in a slave device (also referred to herein as UFP) connections. In some embodiments, the configuration pins can indicate an orientation of a cable that couples the host device to a slave device. For example, the cable may transmit data from the slave device to the host device either upside-up or upside-down. Accordingly, the configuration pins can detect the orientation of the cable and transmit data between the host device and the slave device in the appropriate orientation.


At block 404, the USB PD 124 can send an electrical signal to pins in the USB port of a slave device from the USB port of a host device. For example, the USB PD 124 can send a five volt signal, or any other suitable signal that complies with a USB specification to pins, such as a VBUS pin and a VCONN pin, that are included in the USB port of the slave device. The VBUS pin and the VCONN pin can provide power to the USB port of the slave device. In some examples, the USB PD 124 monitors the VCONN pin for electrical resistance to detect if a USB port of a slave device is receiving the electrical signal. The electrical resistance can be within any suitable range such as 800 ohms to 1200 ohms. In some embodiments, the VBUS pin can implement any suitable source current from the USB PD 124 to the coupled device.


In some examples, the USB PD 124 can transmit signals and data to a slave device or coupled device using various pin arrangements in a USB cable. For example, a USB cable connecting the USB PD 124 to a coupled device can transmit data with the two pin arrangements illustrated below in Table 1A and 1B, among others.














TABLE 1A






Description
PCIe

Description
PCIe



(for
function

(for
function


Pin
receptacle)
(For device)
Pin
receptacle)
(For device)







A1
Ground return
Ground
B1
Ground Return
Ground


A2
Positive half of
RX+
B2
Positive half of
SS-USB



first superspeed


second




TX differential


superspeed




pair


RX differential







pair



A3
Negative half of
RX−
B3
Negative half
SS-USB



first superspeed


of second




TX differential


superspeed




pair


RX differential







pair



A4
VBUS

B4
VBUS



A5
CC1

B5
CC2



A6
Dp1
USB2.0
B6
Dp2
USB2.0




Billboard


Billboard




device


device


A7
Dn1
USB2.0
B7
Dn2
USB2.0




Billboard


Billboard




device


device


A8
Sideband Use
Sideband RX
B8
Sideband Use
Sideband


A9
VBUS

B9
VBUS
TX


A10 
Positive half of
SS-USB
B10 
Negative half
TX−



first superspeed


of first




TX differential


superspeed




pair


RX differential







pair



A11 
Negative half of
SS-USB
B11 
Positive half of
TX+



first superspeed


first




TX differential







pair






A12 
Ground Return
Ground
B12 
Ground Return
Ground





















TABLE 1B







PCIe


PCIe


Pin
Description
function
Pin
Description
function







A1
Ground return
Ground
B1
Ground Return
Ground


A2
Positive half of
SS-USB
B2
Positive half of
TX+



first superspeed


second




TX differential


superspeed RX




pair


differential pair



A3
Negative half of
SS-USB
B3
Negative half of
TX−



first superspeed


second




TX differential


superspeed RX




pair


differential pair



A4
VBUS

B4
VBUS



A5
CC1

B5
CC2



A6
Dp1
USB2.0
B6
Dp2
USB2.0




Billboard


Billboard




device


device


A7
Dn1
USB2.0
B7
Dn2
USB2.0




Billboard


Billboard




device


device


A8
Sideband Use
Sideband
B8
Sideband Use
Sideband




RX


TX


A9
VBUS

B9
VBUS



A10 
Positive half of
RX+
B10 
Negative half of
SS-USB



first superspeed


first superspeed




TX differential


RX differential




pair


pair



A11 
Negative half of
RX−
B11 
Positive half of
SS-USB



first superspeed


first superspeed




TX differential







pair






A12 
Ground Return
Ground
B12 
Ground Return
Ground









In Tables 1A and 1B, the pins described as “Dp1,” “Dn1,” “Dp2,” and “Dn2” can be used to transmit data using a USB 2.0 protocol. Also, the term “SS-USB” can indicate data transmissions though USB ports that support USB 3.0. Additionally, the term “TX” refers to data transmission and the term “RX” refers to data reception.


At block 406, the USB PD 124 can initiate a PCIe protocol with the coupled device. In some embodiments, the USB PD 124 can initiate the PCIe protocol by communicating a vendor mode with the coupled device. For example, the USB PD 124 can send a vendor defined message to the coupled device to discover vendor identifiers or VIDs. In some embodiments, the vendor identifiers indicate a vendor or manufacturer of the coupled device using an identifier of any suitable number of bits. In some examples, the coupled device responds to the vendor defined message with the vendor identifier for the coupled device. For example, the coupled device may respond with a vendor identifier of “h8087” in hexadecimal or any other suitable identifier that indicates that the vendor of the coupled device. The USB PD 124 can then send a second vendor defined message to discover alternate modes or interfaces supported by the coupled device. For example, the alternate modes or interfaces can include PCIe, or Display Port, etc. In some examples, the coupled device can respond to the vendor defined message indicating that the coupled device supports data transmission using the PCIe protocol.


A vendor defined message, in some examples, can include requests for data in accordance with Table 2 below. The values in Table 2 are included in a hexadecimal format.









TABLE 2







Structured VDM Header









Bit(s)
Description
Values





4:0
Command
0h = RESERVED, may




not be used.




1h = Discover Identity.




2h = Discover SVIDs.




3h = Discover Modes.




4h = Enter Mode.




5h = Exit Mode.




6h = Attention.




7h-Fh = RESERVED,




may not be used.




10h = PCIe Configure.




11h-1Fh = RESERVED




for PCIE_SID use.


 5
RESERVED
RESERVED (always 0)


7:6
Command Type
00 = Initiator.



Initiator shall clear to 0
01 = Responder ACK.




10 = Responder NAK.




11 = Responder BUSY.


10:8 
Object Position
000 = RESERVED.




001-110 = Index into




the list of Vendor Defined




Objects (VDOs) to




identify the desired Mode




VDO.




111 = Exit all Modes




(equivalent of a power-on




reset). May not be used




with the Enter Mode




command


12:11
RESERVED
RESERVED (always 0)


14:13
Structured VDM Version
00 = Version 1.0




Other values are




RESERVED


15
VDM Type
1 = Structured VDM


31:16
Standard or Vendor ID
Base SID (for Discover




SVIDs command) or




PCIE_SID









As discussed above, a vendor identification (VID), as referred to herein, can include a value assigned by the USB-IF specification to identify a vendor. In some examples, the VID can be a sixteen bit value. A standard identifier (also referred to herein as SID) can include a value, such as a 16 bit value, among others, that is assigned by a universal serial bus in accordance with a USB specification that identifies an industry standard. A standard video identification (also referred to herein as SVID) can be a reference to either a SID or a VID.


In some examples, a vendor defined message can also include data responding to a request, in which the vendor defined message indicates vendor specifications, such as link configuration, pin assignment, and role reversal support, among others, in accordance with Table 3 below.









TABLE 3







Discover Modes Response









Bit(s)
Description
Values





1:0
Link configuration
00 = Reserved




01 = Supports ×2 PCIe link




10 = Supports ×1 PCIe




and no SS-USB




11 = Supports ×1 PCIe




and 1 SS-USB port


3:2
Pin assignments
00 = As per PCIe




training. Valid if “Link




Configuration” is 01b, i.e.




supports lane reversal.




01 = Pin Assignment A




10 = Pin Assignment B




11 = Reserved




In case where 1 SS-USB




is supported, the high




speed pins left unused




after using the pins used




by PCIe, can be used for




the SS-USB connection


4
Role Reversal
0 = Role Reversal not




supported




1 = Role Reversal




supported, i.e. the




device can act as either




an upstream port or a




downstream port.


31:5 
Reserved
0









At block 408, the USB PD 124 can send a vendor defined message to the coupled device to initiate an enter mode process. The enter mode process can include sending a vendor defined message, such as a PCIe configure command, to the coupled device to enter an alternate mode or interface. For example, the vendor defined message can request that the coupled device enter an alternate mode in which data is transmitted using a data protocol, such as PCIe. In response to the vendor defined message, the USB PD 124 may monitor and detect an acknowledgment from the coupled device that indicates that the coupled device is transmitting data using the alternate mode or interface. In some examples, the vendor defined message for a PCIe command requesting initiation of an enter mode process can include data based on Table 4 below.









TABLE 4







Configure PCIe Command









Bit(s)
Description
Values





1:0
Link Configuration
00 = Reserved




01 = ×2 PCIe link




10 = ×1 PCIe and no SS-




USB




11 = ×1 PCIe and 1 SS-




USB port


3:2
Pin Assignment
00 = As per PCIe training.




Valid if “Link




configuration” is 01b.




01 = Use Pin assignment A




10 = Use Pin assignment B




11 = Reserved




In case where 1 SS-USB




is supported, the high




speed pins left unused




after using the pins for




PCIe, can be used for the




SS-USB connection


4
Role Reversal
0: No Role Reversal




1: Enter Role Reversal,




(e.g. The plugged in




device acts as a




downstream port, and the




system acts as an




upstream port from PCIe




perspective.)


31:5 
Reserved
0









In some embodiments, the USB PD 124 can send a PCIe configure command to the multiplexor in response to receiving a programmable instruction, in response to embedded logic, or in response to a runtime process. For example, the USB PD 124 can detect that the multiplexor is to detect data from a coupled device, wherein the data is transmitted using the PCIe protocol.


At block 410, the USB PD 124 can send a signal to a multiplexor in the USB port 122 to transmit data using a PCIe protocol. As discussed above in relation to FIG. 2, the USB PD 124 can send a signal to the multiplexor to transmit data to a PCIe controller rather than an xHCI host controller when data is transmitted using a PCIe protocol. At block 412, the USB PD 124 can notify the host computing device, in which the USB PD 124 resides, that data transmitted between the host computing device and the coupled device is to be transmitted using the PCIe protocol. For example, the USB PD 124 may receive data from any suitable hardware component, application, or logic in the host computing device and transmit the received data to a slave computing device coupled to the USB port 122 using a PCIe protocol.


At block 414, the USB PD 124 can send a request to a PCIe controller to begin a link training process. In some embodiments, the link training process can include implementing the PCIe Link Training and Status State Machine rules. At block 416, the USB PD 124 can send a request to the multiplexor indicating that the sideband signals are to be consolidated on sideband channels or SBU pins using a serial sideband link protocol. In some embodiments, the sideband channels can transmit consolidated signals such as the PERST# signal, the WAKE# signal, the CLKREQ# signal, and the buffer flush/fill signal, among others.


At block 418, the USB PD 124 can transmit data through the USB port using a PCIe protocol. In some embodiments, the USB PD 124 can continue transmitting data using a PCIe protocol until the USB PD 124 receives a vendor defined message requesting an exit mode, a cable connecting the host computing device to the coupled device is removed, or the USB PD 124 receives a hard reset signal. If the USB PD 124 stops transmitting data using a PCIe protocol, the USB PD can initiate an exit mode that results in data transmission using any suitable USB protocol rather than a PCIe protocol. In some embodiments, the USB PD 124 can indicate that data is to be transmitted with a coupled device using a USB 2.0 protocol in response to receiving a negative acknowledgment or NAK from the coupled device.


The process flow diagram of FIG. 4 is not intended to indicate that the operations of the method 400 are to be executed in any particular order, or that all of the operations of the method 400 are to be included in every case. Additionally, the method 400 can include any suitable number of additional operations. For example, the USB PD 124 can detect support for a role reversal mode, which can be used in cases where a host system can be controlled by the device coupled to the USB port. In some embodiments, role reversal can be used for debugging purposes and troubleshooting applications, and the like. In some embodiments, if Role Reversal is supported by the USB PD 124 and the device coupled to the USB receptacle 122, the USB PD 124 can send an alert to software in a host device indicating that a role reversal option is available.


Furthermore, the USB PD 124 can generate an error in response to detecting the data from the slave device or PCIe compliant device is transmitted using a protocol not supported by the USB PD 124. In some examples, isolation circuitry can be included in the USB port 122 and the isolation circuitry can generate the error.


Moreover, the USB PD 124 may also search a response to a vendor defined message from a slave device for an SVID. As discussed above, an SVID can indicate a vendor identifier or standard identifier for a slave device. In some examples, a slave device connected to a USB port might support more than one SVID. In that case, the slave device may present the SVID in any arbitrary order, and the USB PD 124 can search the response to discover the PCIE_SID or the identifier associated with PCIe protocol support. An example of a response from a slave device that includes multiple SVIDs is provided below in Table 5.












TABLE 5







Header
Vendor
Vendor Defined
Vendor Defined


Message
Defined
Object 1
Object 2












Length = 1-7
Message
SVID-0
SVID-1
SVID-2
0x0000



Header
(B31-16)
(B15-0)
(B31-16)
(B15-0)









Example 1

An apparatus that can transmit data through a USB port using PCIe protocol is described herein. The apparatus can include a multiplexor, and logic to detect a coupling of the apparatus and a PCIe compatible device via a Type-C connector and send at least one vendor defined message to the PCIe compatible device. The logic can also receive a vendor identification and an alternate mode indicator corresponding to a data transfer via a PCIe protocol and send an enter mode command to the PCIe compatible device to enable the data transfer between the apparatus and the PCIe compatible device via the PCIe protocol. Furthermore, the logic can transfer data between the apparatus and the PCIe compatible device via the Type-C connector with the PCIe protocol.


In some embodiments, the logic can detect support for role reversal. Alternatively, or in addition, the logic can send the alternate mode indicator to an application or hardware component of the apparatus to indicate that the apparatus is to transmit data to the PCIe compatible device using a PCIe protocol. Alternatively, or in addition, the apparatus can include an xHCI Host controller, and the logic can control the multiplexor to transmit data via the PCIe protocol or a USB protocol. Alternatively, or in addition, the multiplexor can include sideband logic. Alternatively, or in addition, the logic can send a PCIe configure command to the multiplexor. Alternatively, or in addition, the alternate mode indicator can indicate whether the PCIe compliant device is configured to transmit data using the PCIe protocol. Alternatively, or in addition, the logic can send the PCIe configure command to the multiplexor in response to receiving a programmable instruction, in response to embedded logic, or in response to a runtime process. Alternatively, or in addition, the logic can include isolation circuitry to generate an error in response to detecting the data from the PCIe compliant device is transmitted using a protocol not supported by the logic.


Example 2

A method for transmitting data via a USB port is also described herein. The method can include detecting a coupling of an apparatus and a PCIe compatible device via a Type-C connector and sending at least one vendor defined message to the PCIe compatible device. The method can also include receiving an alternate mode indicator corresponding to a data transfer via a PCIe protocol and sending an enter mode command to the PCIe compatible device to enable the data transfer between the apparatus and the PCIe compatible device via the PCIe protocol. Furthermore, the method can include transferring data between the apparatus and the PCIe compatible device via the Type-C connector with the PCIe protocol.


In some embodiments, the method includes detecting support for role reversal. Alternatively, or in addition, the method can include sending the alternate mode indicator to an application or hardware component of the apparatus to indicate that the apparatus is to transmit data to the PCIe compatible device using a PCIe protocol. Alternatively, or in addition, the method can include controlling a multiplexor to transmit data via a PCIe protocol or a USB protocol. Alternatively, or in addition, the method can include sending a PCIe configure command to the multiplexor. Alternatively, or in addition, the alternate mode indicator can indicate whether the PCIe compliant device is configured to transmit data using the PCIe protocol. Alternatively, or in addition, the method can include sending the PCIe configure command to a multiplexor in response to receiving a programmable instruction, in response to embedded logic, or in response to a runtime process. Alternatively, or in addition, the method can include generating an error in response to detecting the data from the PCIe compliant device is transmitted using a protocol not supported by the logic


Example 3

A system for transmitting data is described herein. The system includes logic to detect a coupling of the apparatus and a serial expansion bus compatible device via a multi-mode connector and send at least one vendor defined message to the serial expansion bus compatible device. The logic can also receive an alternate mode indicator corresponding to a data transfer via a serial expansion bus protocol and send an enter mode command to the serial expansion bus compatible device to enable the data transfer between the apparatus and the serial expansion bus compatible device via the serial expansion bus protocol. Additionally, the logic can transfer data between the apparatus and the serial expansion bus compatible device via the multi-mode connector with the serial expansion bus protocol.


In some embodiments, the logic can detect support for role reversal. Alternatively, or in addition, the logic can send the alternate mode indicator to an application or hardware component of the apparatus to indicate that the apparatus is to transmit data to the serial expansion bus compatible device using a serial expansion bus protocol. Alternatively, or in addition, the apparatus can include an xHCI Host controller, and the logic can control the multiplexor to transmit data via the serial expansion bus protocol or a USB protocol. Alternatively, or in addition, the multiplexor can include sideband logic. Alternatively, or in addition, the logic can send a serial expansion bus configure command to the multiplexor. Alternatively, or in addition, the alternate mode indicator can indicate whether the serial expansion bus compliant device is configured to transmit data using the serial expansion bus protocol. Alternatively, or in addition, the logic can send the serial expansion bus configure command to the multiplexor in response to receiving a programmable instruction, in response to embedded logic, or in response to a runtime process. Alternatively, or in addition, the logic can include isolation circuitry to generate an error in response to detecting the data from the serial expansion bus compliant device is transmitted using a protocol not supported by the logic.


Example 4

An apparatus that can transmit data through a USB port using PCIe protocol is described herein. The apparatus can include a multiplexor, and logic comprising means for detecting a coupling of the apparatus and a PCIe compatible device via a Type-C connector and means for sending at least one vendor defined message to the PCIe compatible device. The logic also comprises means for receiving a vendor identification and an alternate mode indicator corresponding to a data transfer via a PCIe protocol and means for sending an enter mode command to the PCIe compatible device to enable the data transfer between the apparatus and the PCIe compatible device via the PCIe protocol. Furthermore, the logic comprises means for transferring data between the apparatus and the PCIe compatible device via the Type-C connector with the PCIe protocol.


In some embodiments, the logic comprises means for detecting support for role reversal. Alternatively, or in addition, the logic comprises means for sending the alternate mode indicator to an application or hardware component of the apparatus to indicate that the apparatus is to transmit data to the PCIe compatible device using a PCIe protocol. Alternatively, or in addition, the apparatus can include an xHCI Host controller, and the logic can comprise means for controlling the multiplexor to transmit data via the PCIe protocol or a USB protocol. Alternatively, or in addition, the multiplexor can include sideband logic. Alternatively, or in addition, the logic comprises means for sending a PCIe configure command to the multiplexor. Alternatively, or in addition, the alternate mode indicator can indicate whether the PCIe compliant device is configured to transmit data using the PCIe protocol. Alternatively, or in addition, the logic comprises means for sending the PCIe configure command to the multiplexor in response to receiving a programmable instruction, in response to embedded logic, or in response to a runtime process. Alternatively, or in addition, the logic can include isolation circuitry to generate an error in response to detecting the data from the PCIe compliant device is transmitted using a protocol not supported by the logic.


An embodiment is an implementation or example. Reference in the specification to “an embodiment,” “one embodiment,” “some embodiments,” “various embodiments,” or “other embodiments” means that a particular feature, structure, or characteristic described in connection with the embodiments is included in at least some embodiments, but not necessarily all embodiments, of the present techniques. The various appearances of “an embodiment,” “one embodiment,” or “some embodiments” are not necessarily all referring to the same embodiments.


Not all components, features, structures, characteristics, etc. described and illustrated herein need be included in a particular embodiment or embodiments. If the specification states a component, feature, structure, or characteristic “may”, “might”, “can” or “could” be included, for example, that particular component, feature, structure, or characteristic is not required to be included. If the specification or claim refers to “a” or “an” element, that does not mean there is only one of the element. If the specification or claims refer to “an additional” element, that does not preclude there being more than one of the additional element.


It is to be noted that, although some embodiments have been described in reference to particular implementations, other implementations are possible according to some embodiments. Additionally, the arrangement and/or order of circuit elements or other features illustrated in the drawings and/or described herein need not be arranged in the particular way illustrated and described. Many other arrangements are possible according to some embodiments.


In each system shown in a figure, the elements in some cases may each have a same reference number or a different reference number to suggest that the elements represented could be different and/or similar. However, an element may be flexible enough to have different implementations and work with some or all of the systems shown or described herein. The various elements shown in the figures may be the same or different. Which one is referred to as a first element and which is called a second element is arbitrary.


It is to be understood that specifics in the aforementioned examples may be used anywhere in one or more embodiments. For instance, all optional features of the computing device described above may also be implemented with respect to either of the methods or the computer-readable medium described herein. Furthermore, although flow diagrams and/or state diagrams may have been used herein to describe embodiments, the techniques are not limited to those diagrams or to corresponding descriptions herein. For example, flow need not move through each illustrated box or state or in exactly the same order as illustrated and described herein.


The present techniques are not restricted to the particular details listed herein. Indeed, those skilled in the art having the benefit of this disclosure will appreciate that many other variations from the foregoing description and drawings may be made within the scope of the present techniques. Accordingly, it is the following claims including any amendments thereto that define the scope of the present techniques.

Claims
  • 1. An apparatus comprising: a host controller;a root port;a multiplexor coupled to the host controller and the root port; anda power delivery module, the power delivery module and the multiplexor to transmit and receive a request via a multimode input/output (I/O) interface, the power delivery module: to detect a presence of an external device in response to the external device being coupled to the multimode I/O interface, wherein the multimode I/O interface is a USB Type-C compatible interface,to send a first request to the external device to discover a vendor identifier of the external device,to send a second request to discover at least one alternate mode supported by the external device, the at least one alternate mode including a mode to support data transfer via a protocol implemented by the root port, andto send a third request to enable data transfer via the protocol;wherein the power delivery module is to control the multiplexor to enable communication based on the protocol between the root port and the external device.
  • 2. The apparatus of claim 1, wherein the host controller is a universal serial bus (USB) host controller and the power delivery module is a USB power delivery module.
  • 3. The apparatus of claim 1, wherein the root port is a peripheral component interconnect express (PCIe) root port.
  • 4. The apparatus of claim 3, wherein the protocol is a PCIe protocol.
  • 5. The apparatus of claim 4, wherein the request is a vendor defined message.
CROSS-REFERENCE TO RELATED APPLICATIONS

The present application is a continuation of U.S. patent application Ser. No. 14/570,304, titled “Data Transmission Using PCIe Protocol Via USB Port” filed on Dec. 15, 2014, which is incorporated by reference as though fully set forth herein.

US Referenced Citations (70)
Number Name Date Kind
5396376 Chambors et al. Mar 1995 A
6009488 Kavipurapu Dec 1999 A
7185135 Briggs et al. Feb 2007 B1
7673092 Zhao et al. Mar 2010 B2
7769883 Harriman Aug 2010 B2
7782805 Belhadj et al. Aug 2010 B1
7934032 Sardella et al. Apr 2011 B1
7949794 Ajanovic et al. May 2011 B2
8218580 Harriman Jul 2012 B2
8437343 Wagh et al. May 2013 B1
8446903 Ranganathan et al. May 2013 B1
8549205 Harriman et al. Oct 2013 B1
8638783 Wagh et al. Jan 2014 B2
8737390 Ranganathan et al. May 2014 B2
8924620 Harriman et al. Dec 2014 B2
8972640 Wagh Mar 2015 B2
9710406 Pethe Jul 2017 B2
20030229748 Brewer et al. Dec 2003 A1
20040221315 Kobayashi Nov 2004 A1
20050078614 Haartsen Apr 2005 A1
20060023633 Caruk et al. Feb 2006 A1
20060184809 Kojou Aug 2006 A1
20060268936 Hong et al. Nov 2006 A1
20060294272 Chou et al. Dec 2006 A1
20070162645 Han et al. Jul 2007 A1
20070239900 Beasley et al. Oct 2007 A1
20080065796 Lee et al. Mar 2008 A1
20080065805 Wu et al. Mar 2008 A1
20080084836 Baird et al. Apr 2008 A1
20080109565 Ajanovic et al. May 2008 A1
20080233912 Hunsaker et al. Sep 2008 A1
20080235528 Kim et al. Sep 2008 A1
20080294831 Mao Nov 2008 A1
20090106476 Jenkins et al. Apr 2009 A1
20090141654 Voutilainen et al. Jun 2009 A1
20090193164 Ajanovic et al. Jul 2009 A1
20090310699 Kodama et al. Dec 2009 A1
20100014541 Harriman Jan 2010 A1
20100081406 Tan et al. Apr 2010 A1
20100278195 Wagh et al. Nov 2010 A1
20100312942 Blinick et al. Dec 2010 A1
20100325463 Lindsay Dec 2010 A1
20100332868 Tan et al. Dec 2010 A1
20110016252 Sultenfuss et al. Jan 2011 A1
20110016373 Teruyama et al. Jan 2011 A1
20110060931 Radhakrishnan et al. Mar 2011 A1
20110078483 Islam Mar 2011 A1
20110087952 Marin et al. Apr 2011 A1
20110099405 Voutilainen Apr 2011 A1
20110138096 Radulescu et al. Jun 2011 A1
20110208925 Ajanovic et al. Aug 2011 A1
20110296216 Looi et al. Dec 2011 A1
20120017016 Ma et al. Jan 2012 A1
20120079156 Safranek et al. Mar 2012 A1
20120120959 Krause May 2012 A1
20120191887 Yamauchi et al. Jul 2012 A1
20120246373 Chang Sep 2012 A1
20120265918 Nakajima et al. Oct 2012 A1
20130007489 Unnikrishnan et al. Jan 2013 A1
20130013842 Numamoto et al. Jan 2013 A1
20130252543 Badi et al. Sep 2013 A1
20130262892 Radulescu Oct 2013 A1
20130346635 Morriss et al. Dec 2013 A1
20130346656 Harriman et al. Dec 2013 A1
20140032873 Ozdemir et al. Jan 2014 A1
20140108686 Wagh et al. Apr 2014 A1
20140108697 Wagh Apr 2014 A1
20140108698 Wagh et al. Apr 2014 A1
20140156875 Saunders et al. Jun 2014 A1
20140244869 Adrian et al. Aug 2014 A1
Foreign Referenced Citations (10)
Number Date Country
104350720 Feb 2015 CN
112013001661 Jan 2015 DE
112013002639 Feb 2015 DE
10-2013-0091690 Aug 2013 KR
2001072067 Sep 2001 WO
2008032150 Mar 2008 WO
2008154144 Dec 2008 WO
2013176953 Nov 2013 WO
2013176954 Nov 2013 WO
2014004188 Jan 2014 WO
Non-Patent Literature Citations (15)
Entry
International Search Report, PCT Application No. PCT/US2014/072389, dated May 26, 2015, 3 pages.
International Search Report, PCT Application No. PCT/US2015/053760, dated Apr. 22, 2016.
Harriman et al., “Providing a Serial Protocol for a Bidirectional Serial Interconnect”, U.S. Appl. No. 14/558,942, filed Dec. 3, 2014, pp. 1-27.
Harriman, et al., “Providing a Consolidated Sideband Communication Channel Between Devices”, U.S. Appl. No. 14/557,699, filed Dec. 2, 2014, pp. 1-51.
Intel Corporation, “An Introduction to the Intel QuickPath Interconnect,” Jan. 30, 2009, pp. 1-22.
Kolbehdar, et al., “The Emergence of PCI Express in the Next Generation of Mobile Platforms”, Intel Technology Journal, Published Feb. 17, 2005, pp. 21-36, vol. 9 Issue 1, 16 pages.
Merrit, Rick, “Smartphone is next stop for PCI Express” from www.eetimes.com; published Sep. 13, 2012; 2 pages.
Merrit, Rick, “Spec turns USB3 into chip link”, from www.eetimes.com; published May 3, 2011; 2 pages.
MIPI Alliance, “MIPI Alliance Launches New M-PHY and UniPro Specifications for Mobile Device Applications”, published on Jun. 10, 2011, 1-2 pages.
MPI Alliance,“Physical Layer Specifications: MIPI Alliance Launches M-PHY v1 .0 +Uni Pro v1 .40 Specifications”, 2012 (the year of publication is sufficiently earlier than the effective U.S. filing date and any foreign priority date so that the particular month of publication is not in issue in accordance with MPEP § 609.04(a)), retrieved from http://www.http://mipi.org/specifications/physical-layer. [Accessed on May 11, 2012]; 3 pages.
Murray, Matthew, “PCIe Over M-PHY May Bring High-Speed I/O to Tablets, Smartphones”, from www.pcmag.com; published Sep. 13, 2012, 1 page.
Pethe et al., “Serial Sideband Signaling Link”, PCT Patent Application No. PCT/US14/72389, filed on Dec. 24, 2014, pp. 1-43.
Pethe, et al., “Serial Sideband Signaling Link”, MY [Type] Patent Application No. PI 2014702585 , filed on Sep. 11, 2014, pp. 1-44.
Takla, et al., “M-PHY benefits and challenges”, from www.eetimes.com; published Apr. 11, 2011; 8 pages.
Wagh, et al., “Optimized Link Training and Management Mechanism”, U.S. Appl. No. 14/109,061, filed Dec. 17, 2013,—Claims as filed on Dec. 17, 2013, pp. 1-5.
Related Publications (1)
Number Date Country
20160170914 A1 Jun 2016 US
Continuations (1)
Number Date Country
Parent 14570304 Dec 2014 US
Child 14986268 US