Embodiments relate to interfacing between different communication protocols in a computer system.
Modern processors and systems on chip (SoC) are often formed of multiple different logic blocks, often referred to as intellectual property (IP) logics. Sometimes, IP logics of different communication protocols are incorporated into a single integrated circuit (IC). Oftentimes to enable communication between such IP logics within the integrated circuit and external devices, a physical unit (PHY), which is a hardware circuit to enable electrical communication to and from the IC in accordance with a given communication protocol, is provided. Thus when multiple different IP logics that communicate by different communication protocols are provided in an IC, similarly multiple physical unit circuits also are provided, which raise power consumption costs, real estate costs and so forth.
In various embodiments, interface circuitry may he provided within an IC to enable multiple communication protocols, such as multiple different serial-based communication protocols to communicate off-chip by way of a single common physical unit circuit (PHY). In this way, reduced real estate and power consumption can be realized.
Although the scope of the present invention is not limited in this regard, in an embodiment the common PHY may be a generic serializer/deserializer PHY, such as in accordance with a PHY Interface for the Peripheral Component interconnect Express (PCIe), referred to herein as “PIPE controller.” “PIPE” refers to hardware, software and/or firmware compatible with a PHY Interface for the PCI Express specification, such as the PHY Interface for the PCI Express, SATA and USB 3.1 Architectures Specification version 4.2 (published by Intel Corporation, 2013) or another version of such specification (hereafter PIPE specification).
And, while host controllers that act as interfaces between particular IP logics and the PHY may be PIPE-compliant, in certain designs one or more other host controllers may be of a non-PIPE-compliant communication protocol. More specifically in embodiments described herein one or more host controllers of a Mobile Industry Processor Interface (MIPI) M-PHY-based communication protocol may be present. Such MIPI-compliant host controllers may be in accordance with a given MIPI specification such as the MIPI Alliance Draft Specification for M-PHY (version 3.1 rev. 1, Nov. 2013).
While embodiments describe particular interface circuits, understand the scope of the present invention is not limited to these particular interface circuits. Instead, embodiments may be applied to a variety of different manners of interconnecting one or more host controllers of different communication protocols with a common PHY unit. This common PHY unit may be of one of the multiple communication protocols or can be instead of a different communication protocol.
More specifically, embodiments provide a mechanism to connect MIPI M-PHY-based hardware circuitry with an industry standard PIPE interface instead of connection with a physical layer through a MIPI M-PHY standard-defined Reference M-PHY Module Interface (RMMI). In this way, embodiments enable interconnection of a MIPI-compatible controller with a physical unit via a PIPE interface. As such a given set of links (e.g., transmit/receive (Tx/Rx) pairs) coupled to a chip can be configured for either M-PHY based or other serial communication protocols.
Using an embodiment of the present invention, a platform designer is afforded wide flexibility to configure a serial Tx/Rx pair for a MIPI protocol or another serial IO protocol. As examples, a SoC serial I/O hardware intellectual property (HIP) architecture may be configurable and use a single PIPE interface for all serial input/output (IO) controllers, such. as PCIe, Direct Media Interface (DMI), Serial Advanced Technology Attach (SATA), Gigabyte Ethernet (GbE) and Universal Serial Bus (USB) (and Universal Flash Storage (UPS) and Super Speed Inter Chip (SSIC) (which are exemplary M-PHY protocols)).
Embodiments may further reduce SoC cost so that a SoC does not have to dedicate Tx/Rx pins for a MIPI M-PHY-based protocol. Instead, a single set of pins can be configured for a non-MIPI M-PHY serial protocol if so desired for a platform configuration. This sharing allows package sharing of lanes between M-Pitt Y and other serial I/O protocols. Embodiments may Rather enable a M-PHY HIP and M-PHY controller to be designed based on the more popular PIPE interface than on an RMMI-based interface. By using an embodiment of the present invention, an interface circuit provides an interface that is fully compliant with a standard MIPI M-PHY protocol, with no deviation. As such, the conversion operations (and the included interface circuitry) described herein remain transparent to remote MIPI M-PHY device(s) to which a device is coupled.
Referring now to
Interface circuit 100 provides an interface between a MIPI-based host controller 110 and a physical unit circuit (PITY) 160 of another communication protocol. In various embodiments, PHY 160 may be any type of serializer/deserializer PHY, As such, the need for a dedicated MIPI-based PHY is avoided. Thus an interface circuit as in
As illustrated, a host controller 110 couples to fabric 105 via a master interface and a private register access channel. In turn, host controller 110, which as discussed above may be a MIPI-based controller, includes a PHY adapter 115. PHY adapter 115 receives information from fabric 105 and converts it into a RMMI-based communication. In different implementations, this RMMI-based Communication may be sent in parallel widths of 8, 16, 32, 64 or other bit widths. Host controller 110 further includes various storages, including a set of registers 114, which may store configuration information. Host controller 110 may further include a link layer, protocol layer, payload first in first out (FIFO) buffers and a direct memory access (DMA) engine to move data from/to memory. In addition, a set of memory mapped input/output (MMIO) registers 112 also are present. PHY adapter 115 further receives incoming RMMI-based communications and provides them, after conversion, to fabric 105 via the master interface. PHY adapter 115 may receive incoming USB packets and check for errors and strip off link and protocol headers. In turn, a data payload may be transferred to a memory location requested by a software driver.
As further illustrated, host controller 110 couples to a physical coding sub-layer (PCS) 120, more specifically referred to as a MIPI M-PHY PCS (herein “MMP”). MMP 120 provides an interface to convert RMMI-based communications to PIPE-based communications, and vice versa. In an embodiment, MMP 120 may be configured to perform the following operations: datapath translation between RMMI and PIPE (e.g., 8b/10b encoding (in transmit direction) and 8b/10b decoding (in receive direction)); RMMI configuration mode translation to various rate and gear speeds; support for low speed pulse width modification (PWM) transition between RMMI and PIPE using a divided clock; power mode translation of RMMI to PIPE; detection of decode/disparity error; elastic buffer support for handling parts per million (ppm) clock drift; inclusion of standard MIPI M-PHY registers (which cannot be implemented in a standard serial PHY, as its not MIN M-PHY aware); MIPI M-PHY-specific private registers, DFx and testability; and clock and power controls. MMP 120 can integrate with any MITI M-PHY protocol with a RMMI interface on its upstream side and on its downstream side integrate with a PIPE interface to a serial PHY that support MIPI gears and rate. The upstream can integrate with any M-PHY controller like UFS, Camera Serial Interface (CSI), SSIC, or Mobile-Express (Mobile PCIe (MEX)). Embodiments of MMP 120 can support single lane protocols or multi-lane protocols (like UFS, MEX and SSIG).
As further illustrated, MMP 120 includes a transmitter 122 including one or more encoders 125 and a set of registers 124, which provides storage of control/configuration information, useable both within transmitter 122 as well as to provide communication of such information to host controller 110. Thus as seen, RMMI data received in MMP 120 is encoded via one of a set of encoders 125 (which in an embodiment may be implemented as 8b/10b encoders) to thus encode the information into a PIPE-based format such that this data can be communicated via a PIPE-based protocol through a selection circuit 150 to a modular PHY 160.
In general, transmitter 122 takes RMMI byte information from host controller 110 and converts the information into a symbol interface. The transmit burst path (including PHY 160) involves an 8b/10b encoding and a parallel-to-serial conversion to translate the parallel. RMMI interface to a serial PIPE interface.
In general, receiver 130 converts a PIPE symbol interface to a controller RMMI interface. The receive datapath includes an elastic buffer 136 for clock compensation between a recovered clock and a receiver symbol clock at which receiver 130 operates. Receiver 130 may perform decoding of the symbol interface to byte format via decoder 135 and perform datawidth conversion from PIPE to RMMI, e.g., 8-bit PIPE to 32-bit RMMI.
MMP 120 further includes a RMMI configuration interface for updating standard M-PHY lane registers defined by a MITI M-PHY specification. To this end, this circuitry of MMP 120 may perform translation of MIPI M-PHY power saving states like SLEEP/STALL/HIBERN8 to PIPE power down states like P1/2/3, as shown in Table 1 below.
Table 2 provides a description of MIPI M-PHY power states.
Table 3 provides a description of PIPE power states.
As shown in
By providing a common PHY for both MIPI and non-MIPI protocols platform. configurability is enhanced by providing flexibility to choose Tx/Rx pin to MIPI M-PHY lane or non-MIPI lanes; silicon area improvements can be realized in part of, lane sharing as described herein SoC; and easy integration and validation by selection of single modular serial PERT for a SoC.
Selector circuit 150 in the embodiment shown includes multiplexers in the transmit and receive directions, namely multiplexer 152 in the transmit direction can be controlled to output a selected one of PIPE-based data from one or more PIPE controllers 170 or the PIPE-based data from MMP 120. And in the receive direction multiplexer 154 sends data to one of MMP 120 and PIPE controller(s) 170. To this end, a PIPE-based interconnect 140 provides interconnection between one or more PIPE controllers 170 and selector circuit 150.
Using an interface circuit such as MMP 120 enables a MIPI controller (such as host controller 110) to use a serializer/deserializer PHY. After conversion within MMP 110 of transmit MIPI-based data to PIPE-based data, the resulting data lanes may be dynamically multiplexed. While
Note that while 8b/1.0b encoding is performed in MMP 120 for MIPI-based data, for non-MIPI data such encoding can be done at its host controller (e.g., controller 170) or within PHY 160, depending on system configuration.
Understand while a single transmitter 122 and receiver 130 are shown within MMP 120 of
Referring now to
As further illustrated in
As further illustrated, control circuit 220 also includes a core power finite state machine (FSM) 228, which may be configured to control power states of the individual MMP links 210. More specifically, core power FSM 228 may he configured to place one or more of links 210 into a low power and/or clock gate state, e.g., based on traffic activity. Still further, core power FSM 228 may control the power states of links 210, e.g., based on power states of one or more cores of a processor or SoC. As such, core power FSM 228 maybe configured to place some or all of links 210 into a given low power state when some or all cores of the device also are in a low power state. Note that the low power states of these links may correspond to the low power states of the cores. Or in other embodiments, links 210 may be placed into low power link states that are different than corresponding low power states for the corresponding cores. Note that core power FSM 228 may implement per-lane power control such that unused lanes can be disabled. Core power FSM 228 may perform clock gating of various circuitry within an MMP cluster 220 to further reduce power consumption when opportunities exist. Understand while shown at this high level in the embodiment of
In an embodiment, control circuit 220 may be implemented in a separate power domain than the rest of MMP cluster 200. As such, control circuit 220 may always he powered on by virtue of inclusion in an always-on power domain, while instead the remainder of MMP 220 may be implemented within one or more other domains, such as a power domain associated with one or more cores. As used herein, the term “domain” is used to mean a collection of hardware and/or logic that operates at the same voltage and frequency point. With this allocation of circuity to different domains, other portions of MMP 200 may be placed into a low power state, in certain circumstances. As further illustrated in
As further shown, clocks are provided to operate MMP links 210, which in an embodiment may he received from a common PLL of the PHY. In an embodiment, such clocks may include a receiver symbol clock (RxSymbolClk) and a second clock signal, which may be a divided version of this clock signal (RxSymbolClkDiv) (in some cases a host controller may provide the divided version). In addition, a transmit symbol clock (TxSymbolClk) and another clock signal, which may be a divided version of this clock signal (TxSymbolClkDiv) are also received. In other cases, a host controller can provide all symbol clocks. These PLL/controller-supplied clocks may be used depending on mode of MIPI controller operation. More specifically, the RXSymbolClk/TXSymbolClk clock signals may be used during high speed operation (HS) while the divided clock signals may be used during a low speed (LS) mode.
Referring now to
As illustrated in
In an embodiment, platform register settings may be programmed by BIOS or other system software, to host controller 110. Then during MMP initialization, host controller 110 programs configuration registers within MMP 120 via the RMMI configuration interface. Although the scope of the present invention is not limited in this regard, in one example configuration registers (or fields thereof) may be provided for at least some of the following: Mode (PWM or HS); Gear (1/2/3 mainly setting the bandwidth); Rate (PLL reference series of A or B); Amplitude; SYNC/PREPARE parameters; etc.. In an embodiment, there may be two types of speed configuration: Gear 1/2/3 for 1.25 gigabit/per second (Gbps)/2.5G/5G data rates; and Rate A/B, where rate A speed may be at an indicated speed and Rate B speed is a predetermined data rate higher (e.g., 15%) than Rate A.
Still with reference to
Still with reference to
If based on the determination at diamond 360 a power state change has been detected and/or data transmission activity falls below a given threshold, control passes to block 370 where one or more links of the interface circuit (e.g., the MMP itself and/or other portions of the interface circuitry) can be placed into a given low power state. In some cases, rather than the latency and complexity involved in such low power state entry, clock gating may occur to given links or other portions of the MMP, such that reduced power consumption occurs with minimal overhead. If no detection of low power state/inactivity is identified, control instead passes back to block 330 (et seq.), for further data communication operations. Understand while shown at this high level in the embodiment of
In an embodiment, clock gating may be performed during a Hibernate/Disable state, unless it instead is performed during a debug or bring up operation. Clock gating may typically be done at host controller 110, from where the divided symbol clocks are sourced. MMP 120 may be configured to send a clk_request signal and host controller 110 may respond with a clk_ack signal. During a Hibernate state, clk_request is deasserted and clocks are gated. When all lanes are in a LP state, main PLL 165 of PHY 160 is shutdown. In an aggressive power management mode, clock gating can be performed when there is no traffic during a SLEEP/STALL state.
In an embodiment, power gating may be performed only in a Hibernate/Disable state. In this state host controller 110 programs a Hibern8 register in MMP 120, which may maintain the runtime state synchronized between host controller 110 and MMP 120. When lane power gating is not enabled, power is gated only when all lanes are in the Hibern8 state. The power_req comes from MMP 120 and host controller 110 separately, the power_ack is returned by the PM unit in the SoC. In many implementations, the power rail supply for host controller and MMP are same.
Referring now to
Understand that interface circuits as described herein can be implemented into a variety of different ICs, including processors, SoCs and other such devices. In addition, via a common interface for multiple serial-based protocols, such. IC can couple to multiple other ICs via a serial interconnect.
Referring now to
The following Examples pertain to further embodiments.
In one example, an apparatus comprises: a controller to communicate data having a format according to a first communication protocol, the controller comprising a MITI-compatible controller; an interface circuit coupled to the controller to receive the data, convert the data and communicate the converted data to a physical unit of a second communication protocol, the converted data having a format according to the second communication protocol; and the physical unit coupled to the interface circuit to receive and serialize the converted data and output the serialized converted data to a destination.
In an example, the apparatus further comprises a selection circuit coupled between the interface circuit and the physical unit to selectively provide the converted data or second data received from a second controller to the physical unit, the second controller comprising a PIPE-compatible controller.
In an example, the interface circuit is to translate RMMI data to PIPE data.
In an example, the interface circuit comprises a plurality of link circuits, each including a transmitter and a receiver, each of the plurality of link circuits to communicate with the physical unit.
In an example, the interface circuit comprises a control circuit to control plurality of link circuits.
In an example, the control circuit comprises a power controller to independently control power states of the plurality of link circuits.
In an example, the control circuit comprises a translation circuit to translate first speed information of the first communication protocol received from the controller to second speed information of the second communication protocol, the control circuit to control a power state of one or more of the plurality of link circuits according to the second speed information.
In an example, the apparatus comprising a first integrated circuit and the destination comprises a second integrated circuit coupled to the first integrated circuit.
In an example, apparatus comprises an integrated circuit and the physical unit is a sole serial physical unit of the integrated circuit.
In an example, the physical unit comprises a common physical unit for the controller and a second controller, where the second controller comprises a non-MIPI-compatible controller.
In an example, the physical unit comprises a phase lock loop circuit to provide a first transmit clock signal and a first receive clock signal to the interface circuit.
In an example, the interface circuit is to convert the data to the converted data using the first transmit clock signal when the host controller is in operation at a first speed and convert the data to the converted data using a second transmit clock signal when the host controller is in operation at a second speed, the interface circuit to receive the second transmit clock signal from the host controller, the second clock signal comprising a divided version of the first transmit clock signal.
In another example, a method comprises: receiving, in an interface circuit, link configuration information from a host controller coupled to the interface circuit, the host controller comprising a MIPI-compatible controller; configuring one or more transmitters and one or more receivers of the interface circuit in response to the link configuration information; receiving first data from the host controller, the first data in a RMMI format; converting the first data to converted first data, the converted first data in a PIPE format; and sending the converted first data to a PHY unit, the PHY unit comprising a common PHY unit for the host controller and a second host controller, where the second host controller comprises a PIPE-compatible controller.
In an example, the method further comprises receiving first speed information from the host controller and translating the first speed information to second speed information, the second speed information PIPE-compatible.
In an example, the method further comprises receiving a divided clock signal from the host controller, and sending the converted first data to the PHY unit according to the divided clock signal, based on speed information of the link configuration information.
In an example, the method further comprises: placing the one or more transmitters and the one or more receivers into a first low power state, and thereafter receiving updated link configuration information; and updating one or more configuration parameters of the one or more transmitters and the one or more receivers based on the updated link configuration information, and thereafter causing the one or more transmitters and the one or more receivers to exit the low power state.
In an example, the method further comprises dynamically causing the converted first data or second data to be provided to the PHY unit, the second data received from the second host controller.
In another example, a computer readable medium including instructions is to perform the method of any of the above examples.
In another example, a computer readable medium including data is to be used by at least one machine to fabricate at least one integrated circuit to perform the method of any one of the above examples.
In another example, an apparatus comprises means for performing the method of any one of the above examples.
In another example, a system comprises a SoC and an IC coupled to the SoC. The SoC may include: at least one core; a controller to communicate data having a format according to a first communication protocol, the controller comprising a MIPI-compatible controller; an interface circuit coupled to the controller to receive the data, convert the data and communicate the converted data to a physical unit of a second communication protocol, the converted data having a format according to the second communication protocol; and the physical unit coupled to the interface circuit to receive and serialize the converted data and output the serialized converted data. In turn, the IC may include a MIPI WHY to receive and transform the serialized converted data to RMMI data.
In an example, the SoC further includes a second controller comprising a PIPE-compatible controller, and the physical unit is to receive and serialize second data from the second controller and output the serialized second data.
In an example, a second IC is to couple to the SoC, where the second IC includes a physical unit to receive the serialized second data.
Embodiments may be used in many different types of systems. For example, in one embodiment a communication device can be arranged to perform the various methods and techniques described herein. Of course, the scope of the present invention is not limited to a communication device, and instead other embodiments can be directed to other types of apparatus for processing instructions, or one or more machine readable media including instructions that in response to being executed on a computing device, cause the device to carry out one or more of the methods and techniques described herein.
Embodiments may be implemented in code and may be stored on a non-transitory storage medium having stored thereon instructions which can be used to program a system to perform the instructions. Embodiments also may be implemented in data and may be stored on a non-transitory storage medium, which if used by at least one machine, causes the at least one machine to fabricate at least one integrated circuit to perform one or more operations. Still further embodiments may be implemented in a computer readable storage medium including information that, when manufactured into a SoC or other processor, is to configure the SoC or other processor to perform one or more operations. The storage medium may include, but is not limited to, any type of disk including floppy disks, optical disks, solid state drives (SSDs), compact disk read-only memories (CD-ROMs), compact disk rewritables (CD-RWs), and magneto-optical disks, semiconductor devices such as read-only memories (ROMs), random access memories (RAMS) such as dynamic random, access memories (DRAMs), static random access memories (SRAMs), erasable programmable read-only memories (EPROMs), flash memories, electrically erasable programmable read-only memories (EEPROMs), magnetic or optical cards, or any other type of media suitable or storing electronic instructions.
While the present invention has been described with respect to a limited number of embodiments, those skilled in the art will appreciate numerous modifications and variations therefrom. It is intended that the appended claims cover all such modifications and variations as fall within the true spirit and scope of this present invention.