DE112013007770B3 - DEVICES, METHOD AND SYSTEM FOR TRANSMITTING AND RECEIVING VIA AN INTERFACE - Google Patents

DEVICES, METHOD AND SYSTEM FOR TRANSMITTING AND RECEIVING VIA AN INTERFACE Download PDF

Info

Publication number
DE112013007770B3
DE112013007770B3 DE112013007770.1T DE112013007770T DE112013007770B3 DE 112013007770 B3 DE112013007770 B3 DE 112013007770B3 DE 112013007770 T DE112013007770 T DE 112013007770T DE 112013007770 B3 DE112013007770 B3 DE 112013007770B3
Authority
DE
Germany
Prior art keywords
data
link
valid signal
logic
valid
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Active
Application number
DE112013007770.1T
Other languages
German (de)
Inventor
Zuoguo J. Wu
Mahesh Wagh
Debendra Das Sharma
Gerald S. Pasdast
Ananthan Ayyasamy
Xiaobei Li
Robert G. Blankenship
Robert J. Safranek
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Intel Corp
Original Assignee
Intel Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Intel Corp filed Critical Intel Corp
Application granted granted Critical
Publication of DE112013007770B3 publication Critical patent/DE112013007770B3/en
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F13/00Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
    • G06F13/38Information transfer, e.g. on bus
    • G06F13/42Bus transfer protocol, e.g. handshake; Synchronisation
    • G06F13/4265Bus transfer protocol, e.g. handshake; Synchronisation on a point to point bus
    • G06F13/4273Bus transfer protocol, e.g. handshake; Synchronisation on a point to point bus using a clocked protocol

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Information Transfer Systems (AREA)

Abstract

Vorrichtung, die Folgendes umfasst:eine Bitübertragungsschicht-Schnittstelle, die Folgendes umfasst:eine Taktleitung, die dazu eingerichtet ist, eine Taktsignal zu unterstützen;eine Steuerschnittstelle, die dazu eingerichtet ist, ein oder mehrere Steuersignale zu unterstützen, wobei das eine oder die mehreren Steuersignale Steuersignale umfassen, um Übergänge in Verbindungszuständen gemäß einer Zustandsmaschine zu bewirken;mehrere Datenleitungen, die dazu eingerichtet sind, Daten zu übertragen; undeine Gültig-Signal-Leitung, die dazu eingerichtet ist, eine Übertragung eines Gültig-Signals zu unterstützen,wobei die Übertragung von Daten auf den Datenleitungen mit einer Übertragung des Gültig-Signals auf der Gültig-Signal-Leitung abgestimmt werden soll, undwobei die Taktleitung und die Gültig-Signal-Leitung unterschiedliche Leitungen sind.An apparatus comprising:a physical layer interface comprising:a clock line configured to support a clock signal;a control interface configured to support one or more control signals, the one or more control signals control signals to effect transitions in connection states according to a state machine;a plurality of data lines arranged to transmit data; anda valid signal line configured to support transmission of a valid signal,wherein transmission of data on the data lines is to be coordinated with transmission of the valid signal on the valid signal line,andwherein the clock line and the valid signal line are different lines.

Description

GEBIETAREA

Diese Offenbarung betrifft ein Rechensystem und insbesondere (aber nicht ausschließlich) Punkt-zu-Punkt-Zwischenverbindungen. Im Besonderen betrifft die Offenbarung Vorrichtungen, Verfahren und ein System zum Senden und Empfangen von Signalen und Daten über eine Schnittstelle.This disclosure relates to a computing system and particularly (but not exclusively) to point-to-point interconnects. In particular, the disclosure relates to devices, methods and a system for sending and receiving signals and data via an interface.

HINTERGRUNDBACKGROUND

Fortschritte bei der Halbleiterverarbeitung und im Logikdesign haben eine Steigerung der Logikmenge ermöglicht, die auf integrierten Schaltungsvorrichtungen vorhanden sein können. Folglich haben sich Rechensystemkonfigurationen von Systemen mit einer oder mehreren integrierten Schaltungen zu solchen mit mehreren Kernen, mehreren Hardware-Threads und mehreren Logikprozessoren auf einzelnen integrierten Schaltungen sowie mit anderen Schnittstellen, die in solchen Prozessoren integriert sind, entwickelt. Ein Prozessor oder eine integrierte Schaltung umfasst typischerweise einen einzelnen physikalischen Prozessor-Nacktchip, wobei der Prozessor-Nacktchip eine Reihe von Kernen, Hardware-Threads, Logikprozessoren, Schnittstellen, Speichern, Steuerungs-Hub usw. umfassen kann.Advances in semiconductor processing and logic design have enabled an increase in the amount of logic that can reside on integrated circuit devices. As a result, computing system configurations have evolved from systems with one or more integrated circuits to those with multiple cores, multiple hardware threads, and multiple logical processors on individual integrated circuits, as well as other interfaces built into such processors. A processor or integrated circuit typically includes a single physical processor die, where the processor die may include a number of cores, hardware threads, logical processors, interfaces, memories, control hub, and so on.

Als Folge der gesteigerten Möglichkeit, mehr Verarbeitungsleistung in kleineren Gehäusen unterzubringen, haben kleinere Rechenvorrichtungen an Popularität gewonnen. Smartphones, Tablets, ultradünne Notebooks und andere Endgeräte haben exponentiell zugenommen. Diese kleineren Vorrichtungen hängen jedoch sowohl zur Datenspeicherung als auch für komplexe Verarbeitungsvorgänge, die den Formfaktor übersteigen, von Servern ab. Folglich ist auch die Nachfrage nach auf dem Hochleistungsrechenmarkt (d.h. Serverplatz) gestiegen. In modernen Servern gibt es beispielsweise üblicherweise nicht nur einen einzelnen Prozessor mit mehreren Kernen, sondern mehrere physikalische Prozessoren (auch als mehrere Sockets bezeichnet), um die Rechenleistung zu erhöhen. Wenn die Verarbeitungsleistung jedoch gemeinsam mit der Anzahl an Vorrichtungen in deinem Rechensystem steigt, wird die Kommunikation zwischen Sockets und anderen Vorrichtungen entscheidender.As a result of the increased ability to pack more processing power into smaller packages, smaller computing devices have grown in popularity. Smartphones, tablets, ultra-thin notebooks and other end devices have grown exponentially. However, these smaller devices depend on servers for both data storage and complex processing operations that exceed the form factor. Consequently, the demand for in the high-performance computing market (i.e. server space) has also increased. For example, in modern servers, there is typically not just a single processor with multiple cores, but multiple physical processors (also known as multiple sockets) to increase processing power. However, as processing power increases along with the number of devices in your computing system, communication between sockets and other devices becomes more critical.

Tatsächlich haben sich Zwischenverbindungen von traditionelleren Mehrpunktbussen, die vorwiegend elektrische Kommunikation verwalteten, zu ausgereiften Zwischenverbindungsarchitekturen, die rasche Kommunikation ermöglichen, entwickelt. Unglücklicherweise wird mit der steigenden Nachfrage nach zukünftigen Prozessoren, die mit noch höheren Geschwindigkeiten konsumieren, entsprechend die Nachfrage nach Kapazitäten in vorhandenen Zwischenverbindungsarchitekturen zunehmen.In fact, interconnects have evolved from more traditional multipoint buses that primarily managed electrical communications to mature interconnect architectures that enable high-speed communications. Unfortunately, as the demand for future processors consuming at even higher speeds increases, so will the demand for capacity in existing interconnect architectures.

US 2013/0007483 A1 betrifft ein Verfahren und eine Vorrichtung zur Verringerung der Leerlaufleistung einer Plattform. In US 2013/0007483 A1 ist beispielsweise beschrieben, dass ein Host und mit dem Host gekoppelte Endpunkte in der Plattform jeweils über einen Leerlaufzustand mit geringer Leistung verfügen, der die Deaktivierung von Hochgeschwindigkeitsverbindungsschaltungen sowohl im Host als auch in den gekoppelten Endpunkten ermöglicht. US 2013/0007483 A1 relates to a method and apparatus for reducing idle power of a platform. In US 2013/0007483 A1 describes that a host and endpoints coupled to the host in the platform each have a low-power idle state that allows high-speed interconnect circuitry to be disabled in both the host and the coupled endpoints.

ZUSAMMENFASSUNG DER ERFINDUNGSUMMARY OF THE INVENTION

Es kann daher als eine Aufgabe der vorliegenden Erfindung angesehen werden, einer Empfangseinrichtung zu ermöglichen, sich auf den Empfang von Daten vorzubereiten und eine Synchronisation auch bei relativ langen physischen Verbindungswegen aufrechtzuerhalten.It can therefore be seen as an object of the present invention to enable a receiving device to prepare for the reception of data and to maintain synchronization even with relatively long physical connection paths.

Die vorstehende Aufgabe wird erfindungsgemäß mit der Vorrichtung gemäß dem unabhängigen Anspruch 1, der Vorrichtung gemäß dem unabhängigen Anspruch 10, dem Verfahren gemäß dem unabhängigen Anspruch 18 und dem System gemäß dem unabhängigen Anspruch 21 gelöst. Die abhängigen Ansprüche definieren Weiterbildungen der erfindungsgemäßen Vorrichtungen, dem erfindungsgemäßen Verfahren bzw. des erfindungsgemäßen Systems.The above object is achieved according to the invention with the device according to independent claim 1, the device according to independent claim 10, the method according to independent claim 18 and the system according to independent claim 21. The dependent claims define developments of the devices according to the invention, the method according to the invention and the system according to the invention.

Figurenlistecharacter list

  • 1 zeigt eine Ausführungsform eines Rechensystems, das eine Zwischenverbindungsarchitektur umfasst. 1 Figure 1 shows an embodiment of a computing system that includes an interconnect architecture.
  • 2 zeigt eine Ausführungsform einer Zwischenverbindungsarchitektur, die einen Schichtstapel umfasst. 2 Figure 12 shows an embodiment of an interconnect architecture comprising a layer stack.
  • 3 zeigt eine Ausführungsform einer Anfrage oder eines Pakets, die in einer Zwischenverbindungsarchitektur erzeugt oder empfangen werden sollen. 3 Figure 1 shows one embodiment of a request or packet to be generated or received in an interconnect architecture.
  • 4 zeigt eine Ausführungsform eines Sender-und-Empfänger-Paars für eine Zwischenverbindungsarchitektur. 4 Figure 1 shows one embodiment of a transmitter and receiver pair for an interconnect architecture.
  • 5 zeigt eine Ausführungsform eines Mehrchipgehäuses. 5 Figure 1 shows an embodiment of a multi-chip package.
  • 6 ist ein vereinfachtes Blockdiagramm einer Mehrchipgehäuseverbindung (MCPL). 6 Figure 12 is a simplified block diagram of a multi-chip package interconnect (MCPL).
  • 7 ist eine Darstellung einer beispielhaften Signalübertragung auf einer beispielhaften MCPL. 7 Figure 12 is an illustration of an example signaling on an example MCPL.
  • 8 ist ein vereinfachtes Blockdiagramm, das eine Datenbahn in einer beispielhaften MCPL zeigt. 8th Figure 12 is a simplified block diagram showing a data lane in an example MCPL.
  • 9 ist ein vereinfachtes Blockdiagramm, das beispielhafte Übersprechunterdrückungstechniken in einer Ausführungsform einer MCPL. 9 12 is a simplified block diagram showing example crosstalk cancellation techniques in one embodiment of an MCPL.
  • 10 ist ein vereinfachtes Schaltbild, das beispielhafte Übersprechunterdrückungkomponenten in einer Ausführungsform einer MCPL zeigt. 10 12 is a simplified circuit diagram showing example crosstalk cancellation components in one embodiment of an MCPL.
  • 11 ist ein vereinfachtes Blockdiagramm einer MCPL. 11 is a simplified block diagram of an MCPL.
  • 12 ist ein vereinfachtes Blockdiagramm einer MCPL, die eine Schnittstelle mit einer Oberschichtlogik von mehreren Protokollen unter Verwendung einer logischen PHY-Schnittstelle (LPIF) aufweist. 12 Figure 12 is a simplified block diagram of an MCPL interfacing with upper layer logic of multiple protocols using a logical PHY interface (LPIF).
  • 13 ist eine Darstellung einer beispielhaften Signalübertragung auf einer beispielhaften MCPL in Verbindung mit einer Wiederherstellung einer Verbindung. 13 Figure 12 is an illustration of an example signaling on an example MCPL in connection with a connection reestablishment.
  • 14A-14C sind beispielhaft Bit-Kartierungen von Daten auf Bahnen einer beispielhaften MCPL. 14A-14C are exemplary bit maps of data onto lanes of an exemplary MCPL.
  • 15 ist eine Darstellung eines Teils einer beispielhaften Verbindungszustandsmaschine. 15 Figure 12 is an illustration of a portion of an example connection state machine.
  • 16 ist eine Darstellung eines Ablaufs in Verbindung mit einer beispielhaften Zentrierung einer Verbindung. 16 Figure 12 is an illustration of a process associated with an example centering of a connection.
  • 17 ist eine Darstellung einer beispielhaften Verbindungszustandsmaschine. 17 Figure 12 is an illustration of an example connection state machine.
  • 18 ist eine Darstellung einer Signalübertragung zum Eintritt in einen Niedrigenergiezustand. 18 Figure 12 is an illustration of signaling for entering a low power state.
  • 19 zeigt eine Ausführungsform eines Blockdiagramms für ein Rechensystem, das einen Mehrkernprozessor umfasst. 19 Figure 12 shows one embodiment of a block diagram for a computing system that includes a multi-core processor.
  • 20 zeigt eine weitere Ausführungsform eines Blockdiagramms für ein Rechensystem, das einen Mehrkernprozessor umfasst. 20 Figure 12 shows another embodiment of a block diagram for a computing system that includes a multi-core processor.
  • 21 zeigt eine Ausführungsform eines Blockdiagramms für einen Prozessor. 21 Figure 12 shows one embodiment of a block diagram for a processor.
  • 22 zeigt eine weitere Ausführungsform eines Blockdiagramms für ein a Rechensystem, das einen Prozessor umfasst. 22 Figure 12 shows another embodiment of a block diagram for a computing system that includes a processor.
  • 23 zeigt eine Ausführungsform eines Blocks für ein Rechensystem, das mehrere Prozessoren umfasst. 23 Figure 1 shows an embodiment of a block for a computing system comprising multiple processors.
  • 24 zeigt ein beispielhaftes System, das als Ein-Chip-System (SoC) implementiert ist. 24 FIG. 1 shows an example system implemented as a system on chip (SoC).

Ähnliche Bezugszahlen und Bezeichnungen in den verschiedenen Zeichnungen bezeichnen ähnliche Elemente.Similar reference numbers and designations in the different drawings indicate similar elements.

AUSFÜHRLICHE BESCHREIBUNGDETAILED DESCRIPTION

In der folgenden Beschreibung sind zahlreiche spezifische Details dargelegt, wie etwa Beispiele für spezifische Arten von Prozessoren und Systemkonfigurationen, spezifische Hardwarestrukturen, spezifische Architektur- und Mikroarchitekturdetails, spezifische Registerkonfigurationen, spezifische Anweisungsarten, spezifische Systemkomponenten, spezifische Abmessungen/Höhen, spezifische Prozessorpipelinestufen und -operationen usw., um ein umfassendes Verständnis der vorliegenden Erfindung bereitzustellen. Für Fachleute auf dem Gebiet der Erfindung wird jedoch offensichtlich sein, dass diese spezifischen Details nicht eingesetzt werden müssen, um die vorliegende Erfindung umzusetzen. In anderen Fällen wurden allgemein bekannte Komponenten oder Verfahren, wie etwa spezifische und alternative Prozessorarchitekturen, spezifische Logikschaltungen/Codes für beschriebene Algorithmen, spezifische Firmwarecodes, spezifische Verbindungsoperationen, spezifische Logikkonfigurationen, spezifische Herstellungstechniken und -materialien, spezifische Compilerimplementierungen, spezifische Darstellungen von Algorithmen in Codes, spezifische Abschalt- und Gatingtechniken/-logiken und andere spezifische Operationsdetails eines Rechensystems nicht im Detail beschrieben, um eine unnötige Verschleierung der vorliegenden Erfindung zu vermeiden.In the following description, numerous specific details are set forth such as examples of specific types of processors and system configurations, specific hardware structures, specific architectural and microarchitectural details, specific register configurations, specific instruction types, specific system components, specific dimensions/heights, specific processor pipeline stages and operations, etc . to provide a thorough understanding of the present invention. However, it will be apparent to those skilled in the art that these specific details need not be employed in order to practice the present invention. In other instances, well-known components or processes, such as specific and alternative processor architectures, specific logic circuits/codes for described algorithms, specific firmware codes, specific interconnect operations, specific logic configurations, specific manufacturing techniques and materials, specific compiler implementations, specific representations of algorithms in code, specific shutdown and gating techniques/logics, and other specific operational details of a computing system have not been described in detail to avoid unnecessarily obscuring the present invention.

Die folgenden Ausführungsformen können zwar in Bezug auf Energiesparen und Energieeffizienz in spezifischen integrierten Schaltungen, wie etwa Rechenplattformen oder Mikroprozessoren, beschrieben sein, bei anderen Arten von integrierten Schaltungen und Logikvorrichtungen können aber auch andere Ausführungsform eingesetzt werden. Ähnliche Verfahren und Lehren von Ausführungsformen, die hierin beschrieben sind, können auch für andere Arten von Schaltungen oder Halbleitervorrichtungen verwendet werden, die ebenfalls von besserer Energieeffizienz und Energiesparen profitieren können. Beispielsweise sind die vorliegenden Ausführungsformen nicht auf Desktop-Rechnersysteme oder Ultrabooks™ eingeschränkt. Sie können auch in anderen Vorrichtungen verwendet werden, wie etwa in Handgeräten, Tablets, anderen dünnen Notebooks, Systemen auf einem Chip (SOC-Vorrichtungen) und eingebetteten Anwendungen. Einige Beispiele für Handvorrichtungen umfassen Mobiltelefone, Internetprotokollvorrichtungen, Digitalkameras, persönliche digitale Assistenten (PDAs) und Hand-PCs. Eingebettete Anwendungen umfassen üblicherweise eine Mikrosteuerung, einen Digitalsignalprozessor (DSP), ein Ein-Chip-System, Netzwerkrechner (NetPC), Beistellgeräte, NetzwerkHub, Weitverkehrsnetz- (WAN-) Schalter oder ein beliebiges anderes System, das die nachstehende gelehrten Funktionen und Operationen ausführen kann. Darüber hinaus sind die hierin beschriebenen Geräte, Verfahren und Systeme nicht auf physikalische Rechenvorrichtungen eingeschränkt, sondern können sich auch auf Softwareoptimierungen für Energiesparen und -effizienz beziehen. Wie aus der nachfolgenden Beschreibung hervorgeht sind die Ausführungsformen der Verfahren, Geräte und Systeme, die hierin beschrieben sind (egal ob in Bezug auf Hardware, Firmware, Software oder eine Kombination davon) entscheidend für eine Zukunft mit ausgeglichener Berücksichtigung von ,grüner Technologie' und Leistung.While the following embodiments may be described in terms of power conservation and energy efficiency in specific integrated circuits, such as computing platforms or microprocessors, other embodiments may be employed with other types of integrated circuits and logic devices. Similar methods and teachings of embodiments described herein can also be used for other types of circuits or semiconductor devices that can also benefit from better energy efficiency and energy saving. For example, the present embodiments are not limited to desktop computing systems or Ultrabooks™. They can also be used in other devices such as handhelds, tablets, other thin notebooks, systems on a chip (SOC) devices, and embedded applications. Some examples of handheld devices include cell phones, internet protocol devices, digital cameras, personal digital assistants (PDAs), and handheld PCs. Embedded applications typically include a microcontroller, digital signal processor (DSP), system on chip, network computer (NetPC), set-top box, network hub, wide area network (WAN) switch, or any other system that performs the functions and operations taught below can. Additionally, the devices, methods, and systems described herein are not limited to physical computing devices, but may also relate to software optimizations for power conservation and efficiency. As will be apparent from the description below, the embodiments of the methods, devices, and systems described herein (whether in terms of hardware, firmware, software, or a combination thereof) are critical to a future that balances green technology and performance .

Mit der Weiterentwicklung von Rechensystemen werden die darin enthaltenen Komponenten immer komplexer. Als Folge nimmt auch die Komplexität der Zwischenverbindungsarchitektur zum Koppeln der und Kommunikation zwischen den Komponenten zu, um sicherzustellen, dass Bandbreitenaforderungen für einen optimalen Betrieb der Komponenten erfüllt werden. Außerdem fordern verschiedene Marktsegmente unterschiedliche die Bereitstellung unterschiedlicher Aspekte von Zwischenverbindungsarchitekturen zur Erfüllung ihrer Bedürfnisse. Beispielsweise erfordern Server höhere Leistung, während das mobile Ökosystem manchmal bei der Gesamtleistung verzichten kann, um Energie zu sparen. Trotzdem ist das Ziel der meisten Strukturen, die höchstmögliche Leistung bei maximalem Energiesparen bereitzustellen. Nachstehend werden ein paar Verbindungen erläutert, die möglicherweise von Aspekten der hierin beschriebenen Erfindung profitieren würden.With the further development of computing systems, the components they contain are becoming increasingly complex. As a result, the complexity of the interconnect architecture for coupling and communicating between the components to ensure that bandwidth requirements for optimal operation of the components are met is also increased. Also, different market segments have different requirements for providing different aspects of interconnect architectures to meet their needs. For example, servers require higher performance, while the mobile ecosystem can sometimes sacrifice overall performance to save energy. Despite this, the goal of most structures is to provide the highest possible performance with maximum energy savings. Below are a few compounds that would potentially benefit from aspects of the invention described herein.

Eine Zwischenverbindungsstrukturarchitektur umfasst die Peripherkomponentenverbindungs- (PCI-) Express- (PCIe-) Architektur. Ein Hauptziel von PCIe besteht darin, es Komponenten und Vorrichtungen von unterschiedlichen Lieferfirmen zu ermöglichen, in einer offenen Architektur miteinander zu operieren, um mehrere Marktsegmenten zu überspannen; Clients (Desktop- und Mobilgerät), Servers (Standard und Unternehmen) und eingebettete und Kommunikationsvorrichtungen. PCI Express ist eine Mehrzweck-Hochleistungs-I/O-Zwischenverbindung, die für verschiedenste zukünftige Rechen- und Kommunikationsplattformen definiert ist. Manche PCI-Merkmale, wie z.B. sein Nutzungsmodell, seine Lade-Speicher-Architektur und Software-Schnittstellen, wurde bei Überarbeitungen beibehalten, während vorherige parallele Busimplementierungen durch eine stark skalierbare, vollkommen serielle Schnittstelle ersetzt wurden. Die neueren Versionen von PCI Express nutzen die Vorteile der Fortschritte bei Punkt-zu-Punkt-Verbindungen, schalterbasierter Technologie und paketierten Protozollen zur Bereitstellung neuer Leistungsniveaus und Funktionen. Energiemanagement, Dienstgüte (QoS), Hot-Plug/Hot-Swap-Unterstützung, Datenintegrität und Fehlerbehebung sind einige der fortgeschrittenen Funktionen, die von PCI Express unterstützt werden.An interconnect fabric architecture includes the Peripheral Component Interconnect (PCI) Express (PCIe) architecture. A key goal of PCIe is to allow components and devices from different vendors to interoperate in an open architecture to span multiple market segments; Clients (desktop and mobile), servers (standard and enterprise) and embedded and communication devices. PCI Express is a general-purpose, high-performance I/O interconnect defined for a variety of future computing and communications platforms. Some PCI characteristics, such as its usage model, load-memory architecture, and software interfaces, have been retained through revisions, while previous parallel bus implementations have been replaced with a highly scalable, fully serial interface. Newer versions of PCI Express take advantage of advances in point-to-point connections, switch-based technology, and packetized protocols to deliver new levels of performance and functionality. Power management, quality of service (QoS), hot-plug/hot-swap support, data integrity, and error recovery are some of the advanced features supported by PCI Express.

Unter Bezugnahme auf 1 wird eine Ausführungsform einer Struktur dargestellt, die aus Punkt-zu-Punkt-Verbindungen besteht, die eine Gruppe von Komponenten verbinden. System 100 umfasst einen Prozessor 105 und einen Systemspeicher 110, der mit einen Steuerungs-Hub 115 gekoppelt ist. Prozessor 105 umfasst ein beliebiges Verarbeitungselement, wie z.B. einen Mikroprozessor, einen Host-Prozessor, einen eingebetteten Prozessor, einen Coprozessor oder einen anderen Prozessor. Prozessor 105 ist mit Steuerungs-Hub 115 über einen Frontside-Bus (FSB) 106 gekoppelt. In einer Ausführungsform ist FSB 106 eine serielle Punkt-zu-Punkt-Verbindung, wie nachstehend beschrieben ist. In einer weiteren Ausführungsform umfasst Verbindung 106 eine serielle, differentielle Zwischenverbindungsarchitektur, die verschiedenen Verbindungsstandards entspricht.With reference to 1 Illustrated is an embodiment of a structure made up of point-to-point links connecting a group of components. System 100 includes a processor 105 and a system memory 110 coupled to a controller hub 115 . Processor 105 includes any processing element such as a microprocessor, host processor, embedded processor, coprocessor, or other processor. Processor 105 is coupled to controller hub 115 via front side bus (FSB) 106 . In one embodiment, FSB 106 is a point-to-point serial link, as described below. In another embodiment, link 106 includes a serial, differential interconnect architecture that conforms to various link standards.

Systemspeicher 110 umfasst eine beliebige Speichervorrichtung, wie z.B. einen Direktzugriffsspeicher (RAM), einen nichtflüchtigen (NV) Speicher oder einen anderen Speicher, auf den Vorrichtungen im System 100 zugreifen können. Systemspeicher 110 ist mit Steuerungs-Hub 115 durch Speicherschnittstelle 116 gekoppelt. Beispiele für eine Speicherschnittstelle umfassen eine Doppeldatenraten- (DDR-) Speicherschnittstelle, eine Doppelkanal-DDR-Speicherschnittstelle und eine dynamische RAM- (DRAM-) Speicherschnittstelle.System memory 110 includes any storage device, such as random access memory (RAM), non-volatile (NV) memory, or other memory accessible to devices in system 100 . System memory 110 is coupled to controller hub 115 through memory interface 116 . Examples of a memory interface include a double data rate (DDR) memory interface, a dual channel DDR memory interface, and a dynamic RAM (DRAM) memory interface.

In einer Ausführungsform ist Steuerungs-Hub 115 ein Root-Hub, ein Root-Komplex oder eine Root-Steuerung in einer Peripherkomponentenverbindung-Express- (PCIe- oder PCIE-) Verbindungshierarchie. Beispiele für Steuerungs-Hub 115 umfassen einen Chipsatz, einen Speichersteuerungs-Hub (MCH), ein Northbridge, einen Verbindungssteuerungs-Hub (ICH), ein Southbridge und eine(n) Root-Steuerung/Hub. Häufig bezieht sich die Bezeichnung Chipsatz auf zwei physikalische getrennte Steuerungs-Hub, d.h. einen Speichersteuerungs-Hub (MCH), der mit einem Verbindungssteuerungs-Hub (ICH) gekoppelt ist. Es gilt anzumerken, dass aktuelle Systeme den MCH häufig im Prozessor 105 integriert aufweisen, wobei Steuerung 115 zur Kommunikation mit I/O-Vorrichtungen dient, auf ähnliche Weise wie nachstehend beschrieben ist. In manchen Ausführungsformen wird Peer-zu-Peer-Routing gegebenenfalls von einem Root-Komplex 115 unterstützt.In one embodiment, controller hub 115 is a root hub, root complex, or root controller in a Peripheral Interconnect Express (PCIe or PCIE) interconnect hierarchy. Examples of controller hub 115 include a chipset, a memory controller hub (MCH), a northbridge, an interconnect controller hub (ICH), a southbridge, and a root controller/hub. Often the term chipset refers to two physically separate controller hubs, i.e. a memory controller hub (MCH) coupled to an interconnect controller hub (ICH). It should be noted that current systems often have the MCH integrated into processor 105, with controller 115 used to communicate with I/O devices in a manner similar to that described below. In some embodiments, peer-to-peer routing may be supported by a root complex 115.

Hier ist Steuerungs-Hub 115 mit Schalter/Brücke 120 durch serielle Verbindung 119 gekoppelt. Eingabe-/Ausgabemodule 117 und 121, die auch als Schnittstellen/Anschlüsse 117 und 121 bezeichnet werden können, umfassen/implementieren eine geschichteten Protokollstapel zur Bereitstellung von Kommunikation zwischen Steuerungs-Hub 115 und Schalter 120. In einer Ausführungsform können mehrere Vorrichtungen mit Schalter 120 gekoppelt werden.Here controller hub 115 is coupled to switch/bridge 120 through serial link 119 . Input/output modules 117 and 121, which may also be referred to as interfaces/ports 117 and 121, include/implement a layered protocol stack for providing communication between controller hub 115 and switch 120. In one embodiment, multiple devices may be coupled to switch 120 become.

Schalter/Brücke 120 leitet Pakete/Nachrichten von Vorrichtung 125 stromaufwärts, d.h. eine Hierarchie nach oben zu einem Root-Komplex, zu Steuerungs-Hub 115 und stromabwärts, d.h. eine Hierarchie nach unten weg von einer Root-Steuerung, von Prozessor 105 oder Systemspeicher 110 zu Vorrichtung 125. Schalter 120 wird in einer Ausführungsform als logische Gruppe aus mehreren virtuellen PCI-zu-PCI-Brückenvorrichtungen bezeichnet. Vorrichtung 125 umfasst einen beliebige interne oder externe Vorrichtung oder Komponente, die mit einem elektronischen System gekoppelt werden soll, beispielsweise mit einer I/O Vorrichtung, einer Netzwerkschnittstellensteuerung (NIC), einer Steckkarte, einem Audioprozessor, einem Netzwerkprozessor, einer Festplatte, einer Speichervorrichtung, einer CD/DVD ROM, einem Monitor, einem Drucker, einer Maus, einer Tastatur, einem Router, einer tragbaren Speichervorrichtung, einer Firewire-Vorrichtung, einer universellen seriellen Bus- (USB-) Vorrichtung, einem Scanner und anderen Eingabe-/Ausgabevorrichtungen. In der PCIe-Fachsprache wird solch eine Vorrichtung häufig als Endgerät bezeichnet. Es ist zwar nicht spezifisch dargestellt, aber Vorrichtung 125 kann eine PCIe zur PCI/PCI-X-Brücke umfassen, um Legacy- oder andere Versionen von PCI-Vorrichtungen zu unterstützen. Endgerätevorrichtungen bei PCIe werden oft als Endgeräte mit integriertem Legacy, PCIe oder Root-Komplex bezeichnet.Switch/bridge 120 routes packets/messages from device 125 upstream, i.e. up a hierarchy to a root complex, to control hub 115 and downstream, i.e. down a hierarchy away from root control, from processor 105 or system memory 110 to device 125. Switch 120 is referred to in one embodiment as a logical group of multiple virtual PCI-to-PCI bridge devices. Device 125 includes any internal or external device or component to be coupled to an electronic system, such as an I/O device, a network interface controller (NIC), a daughter card, an audio processor, a network processor, a hard drive, a storage device, a CD/DVD ROM, a monitor, a printer, a mouse, a keyboard, a router, a portable storage device, a firewire device, a universal serial bus (USB) device, a scanner, and other input/output devices. In PCIe jargon, such a device is often referred to as an end device. While not specifically shown, device 125 may include a PCIe to PCI/PCI-X bridge to support legacy or other versions of PCI devices. End device devices in PCIe are often referred to as end devices with integrated legacy, PCIe, or root complex.

Grafikbeschleuniger 130 ist ebenfalls mit Steuerungs-Hub 115 durch eine serielle Verbindung 132 gekoppelt. In einer Ausführungsform ist Grafikbeschleuniger 130 mit einem MCH gekoppelt, der mit einem ICH gekoppelt ist. Schalter 120, und demgemäß I/O-Vorrichtung 125, ist dann mit dem ICH gekoppelt. I/O-Module 131 und 118 dienen ebenfalls zur Implementierung eines geschichteten Protokollstapels zur Kommunikation zwischen Grafikbeschleuniger 130 und Steuerungs-Hub 115. Ähnlich wie bei der Erläuterung des MCH oben kann eine Grafiksteuerung oder der Grafikbeschleuniger 130 selbst im Prozessor 105 integriert sein.Graphics accelerator 130 is also coupled to controller hub 115 through serial link 132 . In one embodiment, graphics accelerator 130 is coupled to an MCH that is coupled to an ICH. Switch 120, and accordingly I/O device 125, is then coupled to the ICH. I/O modules 131 and 118 are also used to implement a layered protocol stack for communication between graphics accelerator 130 and controller hub 115. Similar to the discussion of the MCH above, a graphics controller or the graphics accelerator 130 itself may be integrated into the processor 105.

Unter Bezugnahme auf 2 ist eine Ausführungsform eines geschichteten Protokollstapels dargestellt. Geschichteter Protokollstapel 200 umfasst jede beliebige Form eines geschichteten Kommunikationsstapels, wie z.B. einen Quick-Path-Interconnect- (QPI) Stapel, einen PCie-Stapel, einen Hochleistungsrechenverbindungsstapel der nächsten Generation oder einen anderen Schichtstapel. Obwohl sich die direkt nachfolgende Erläuterung unter Bezugnahme auf 1-4 auf einen PCIe-Stapel bezieht, können die gleichen Konzepte auf bei anderen Verbindungsstapeln verwendet werden. In einer Ausführungsform ist Protokollstapel 200 ein PCIe-Protokollstapel, der Transaktionsschicht 205, Verbindungsschicht 210 und physikalische Schicht 220 umfasst. Eine Schnittstelle, wie z.B. Schnittstelle 117, 118, 121, 122, 126 und 131 in 1, kann als Kommunikationsprotokollstapel 200 dargestellt sein. Eine Darstellung als Kommunikationsprotokollstapel kann auch als Modul oder Schnittstelle bezeichnet werden, die einen Protokollstapel implementiert/umfasst.With reference to 2 An embodiment of a layered protocol stack is shown. Layered protocol stack 200 includes any form of layered communications stack, such as a Quick Path Interconnect (QPI) stack, a PCIe stack, a next-generation high-performance computing interconnect stack, or any other layered stack. Although the explanation immediately below with reference to 1-4 refers to a PCIe stack, the same concepts can be applied to other interconnect stacks. In one embodiment, protocol stack 200 is a PCIe protocol stack that includes transaction layer 205, link layer 210, and physical layer 220. FIG. An interface, such as interface 117, 118, 121, 122, 126, and 131 in 1 , may be represented as communication protocol stack 200 . A communications protocol stack representation may also be referred to as a module or interface that implements/comprises a protocol stack.

PCI Express nutzt Pakete zur Übertragung von Informationen zwischen Komponenten. Pakete werden in der Transaktionsschicht 205 Datenverbindungsschicht 210 gebildet, um die Informationen von der Sendekomponente zur Empfangskomponente zu übertragen. Wenn die übertragenen Pakete durch die äußeren Schichten wandern, werden sie mit zusätzlichen Informationen versehen, die notwendig sind, um Pakete in diesen Schichten zu verwalten. Auf der Empfangsseite findet der umgekehrte Prozess statt und Pakete werden von ihrer Darstellung in der physikalischen Schicht 220 zur Darstellung in der Datenverbindungsschicht 210 und schließlich (für Transaktionsschichtpakete) in die Form, die von der Transaktionsschicht 205 der Empfangsvorrichtung verarbeitet werden kann, umgewandelt.PCI Express uses packets to transfer information between components. Packets are formed in the transaction layer 205 data link layer 210 to transfer the information from the sending component to the receiving component. As the transmitted packets travel through the outer layers, they are tagged with additional information necessary to manage packets in those layers. At the receiving end, the reverse process takes place and packets are converted from their representation in the physical layer 220 to their representation in the data link layer 210 and finally (for transaction layer packets) to the form that can be processed by the transaction layer 205 of the receiving device.

Transaktionsschichttransaction layer

In einer Ausführungsform dient die Transaktionsschicht 205 zur Bereitstellung einer Schnittstelle zwischen dem Verarbeitungskern einer Vorrichtung und der Zwischenverbindungsarchitektur, z.B. einer Datenverbindungsschicht 210 und einer physikalischen Schicht 220. In diesem Zusammenhang besteht die Hauptaufgabe der Transaktionsschicht 205 darin, Pakete (d.h. Transaktionsschichtpakete oder TLPs) zusammenzustellen und auseinanderzunehmen. Die Transaktionsschicht 205 verwaltet üblicherweise Credit-basierte Flusskontrolle für TLPs. PCIe implementiert geteilte Transkationen, d.h. Transaktionen, bei denen Anfrage und Antwort zeitlich getrennt sind, was es einer Verbindung erlaubt, anderen Verkehr auszuführen, während die Zielvorrichtung Daten für die Antwort sammelt.In one embodiment, the transaction layer 205 serves to provide an interface between the processing core of a device and the interconnect architecture, e.g. a data link layer 210 and a physical layer 220. In this context, the main task of the transaction layer 205 is to assemble packets (i.e. transaction layer packets or TLPs) and to take apart The transaction layer 205 typically manages credit-based flow control for TLPs. PCIe implements split transactions, i.e. transactions in which request and response are separated in time, allowing one connection to carry other traffic while the target device collects data for the response.

Außerdem nutzt PCIe Credit-basierte Flusskontrolle. Bei diesem Schema gibt eine Vorrichtung eine Anfangsmenge an Credit für jeden der Empfangspuffer in Transaktionsschicht 205 an. Eine externe Vorrichtung am entgegengesetzten Ende der Verbindung, wie z.B. Steuerungs-Hub 115 in 1, zählt die Anzahl an Credits, die von jedem TLP verbraucht werden. Eine Transaktion kann übertragen werden, wenn die Transkation eine Credit-Grenze nicht überscheitet. Beim Empfang einer Antwort wird die Credit-Menge rückgesetzt. Ein Vorteil eines Credit-Schemas ist, dass sich die Latenz der Credit-Wiederherstellung nicht auf die Leistung auswirkt, solange die Credit-Grenze nicht erreicht ist.Also, PCIe uses credit-based flow control. In this scheme, a device specifies an initial amount of credits for each of the receive buffers in transaction layer 205. An external device at the opposite end of the link, such as Control Hub 115 in 1 , counts the number of credits consumed by each TLP. A transaction can be transferred if the transaction does not exceed a credit limit. Upon receipt of a response, the credit amount is reset. An advantage of a credit scheme is that the latency of credit restoration does not affect performance until the credit limit is reached.

In einer Ausführungsform umfassen vier Transaktionsadressräume einen Konfigurationsadressraum, einen Speicheradressraum, einen Eingabe/Ausgabe-Adressraum und einen Nachrichtenadressraum. Speicherplatztransaktionen umfassen eine oder mehrere aus Leseanforderungen und Schreibanforderungen zur Übertragung von Daten von/zu einer im Speicher abgebildeten Position. In einer Ausführungsform sind Speicherplatztransaktionen in der Lage, zwei unterschiedliche Adressformate zu verwenden, z.B. ein kurzes Adressenformat, wie z.B. eine 32-Bit-Adresse, oder ein langes Adressenformat, wie z.B. eine 64-Bit-Adresse. Konfigurationsraumtransaktionen werden verwendet, um auf Konfigurationsraum der PCIe-Vorrichtungen zuzugreifen. Transaktionen am Konfigurationsraum umfassen Leseanforderungen und Schreibanforderungen. Nachrichtenraumtransaktionen (oder einfach Nachrichten) sind so definiert, dass sie bandinterne Kommunikation zwischen PCIe-Agenten unterstützen.In one embodiment, four transaction address spaces include a configuration address space, a memory address space, an input/output address space, and a message address space. Memory space transactions comprise one or more of read requests and write requests to transfer data from/to a location mapped in memory. In one embodiment, memory space transactions are capable of using two different address formats, e.g., a short address format, such as a 32-bit address, or a long address format, such as a 64-bit address. Configuration space transactions are used to access configuration space of PCIe devices. Transactions on configuration space include read requests and write requests. Message space transactions (or simply messages) are defined to support in-band communication between PCIe agents.

Daher assembliert in einer Ausführungsform Transaktionsschicht 205 Paketkopf/Nutzlast 206. Das Format für aktuelle Paketköpfe/Nutzlasten findet sich in den PCIe-Spezifikationen und auf der PCIe-Spezifikationswebseite.Therefore, in one embodiment, transaction layer 205 assembles header/payload 206. The format for current headers/payloads can be found in the PCIe specifications and on the PCIe specification webpage.

Unter Bezugnahme auf 3 ist kurz eine Ausführungsform eines PCIe-Transaktionsdeskriptors dargestellt. In einer Ausführungsform ist der Transaktionsdeskriptor 300 ein Mechanismus zum Tragen von Transaktionsinformationen. In diesem Zusammenhang unterstützt Transaktionsdeskriptor 300 eine Identifikation von Transaktionen in einem System. Andere möglichen Anwendungen umfassen Nachverfolgen von Modifikationen von Standardtransaktionsreihenfolgen und Zuordnung einer Transaktion zu Kanälen.With reference to 3 1 briefly illustrates one embodiment of a PCIe transaction descriptor. In one embodiment, transaction descriptor 300 is a mechanism for carrying transaction information. In this regard, transaction descriptor 300 supports identification of transactions in a system. Other possible applications include tracking modifications to standard transaction orders and associating a transaction with channels.

Transaktionsdeskriptor 300 umfasst ein globales Identifikatorfeld 302, ein Attributfeld 304 und ein Kanalidentifikatorfeld 306. Im veranschaulichten Beispiel ist das globale Identifikatorfeld 302 so dargestellt, dass es ein lokales Transaktionsidentifikatorfeld 308 und ein Quellidentifikatorfeld 310 umfasst. In einer Ausführungsform ist der globale Transaktionsidentifikator 302 einzigartig für alle ausstehenden Anforderungen.Transaction descriptor 300 includes a global identifier 302 field, an attribute 304 field, and a channel identifier 306 field. In one embodiment, the global transaction identifier 302 is unique to all outstanding requests.

Gemäß einer Ausführungsform ist das lokale Transaktionsidentifikatorfeld 308 ein Feld, das von einem Anforderungsagent erzeugt wird, und es ist einzigartig für alle ausstehenden Anforderungen, die eine Komplettierung für diesen Anforderungsagent erfordern. Außerdem identifiziert in diesem Beispiel der Quellidentifikator 310 auf einzigartige Weise den Anforderungsagent innerhalb einer PCIe-Hierarchie. Demgemäß stellt der lokale Transaktionsidentifikator 308 zusammen mit der Quell-ID 310 globale Identifikation einer Transaktion innerhalb einer hierarchischen Domäne bereit.According to one embodiment, the local transaction identifier field 308 is a field generated by a request agent and is unique to all outstanding requests that require completion for that request agent. Also in this example, the source identifier 310 uniquely identifies the request agent within a PCIe hierarchy. Accordingly, the local transaction identifier 308, together with the source ID 310, provides global identification of a transaction within a hierarchical domain.

Attributfeld 304 spezifiziert Eigenschaften und Beziehungen der Transaktion. In diesem Zusammenhang wird Attributfeld 304 möglicherweise verwendet, um zusätzliche Informationen bereitzustellen, die eine Modifikation der Standardverwaltung von Transaktionen ermöglichen. In einer Ausführungsform umfasst Attributfeld 304 Prioritätsfeld 312, reserviertes Feld 314, Reihenfolgenfeld 316 und abhörfreies Feld 318. Hier kann das Prioritätsunterfeld 312 durch einen Initiator modifiziert werden, um der Transaktion eine Priorität zuzuweisen. Das reservierte Attributfeld 314 wird für die Zukunft oder vom Lieferanten definierte Verwendung reserviert. Mögliche Verwendungsmodelle unter Einsatz von Prioritäts- oder Sicherheitsattributen können unter Verwendung des reservierten Attributfelds implementiert werden.Attribute field 304 specifies properties and relationships of the transaction. In this context, attribute field 304 may be used to provide additional information that allows modification of the standard management of transactions. In one embodiment, attribute field 304 includes priority field 312, reserved field 314, order field 316, and eavesdrop field 318. Here, priority subfield 312 may be modified by an initiator to prioritize the transaction. The reserved attribute field 314 is reserved for future or supplier-defined use. Possible usage models using priority or security attributes can be implemented using the reserved attribute field.

In diesem Beispiel wird das Reihenfolgenattributfeld 316 verwendet, um optionale Informationen bereitzustellen, welche die Art von Reihenfolge angeben, welche die Standardreihenfolgenregeln verändern können. Gemäß einer beispielhaften Implementierung bezeichnet ein Reihenfolgenattribut „0“, dass Standardreihenfolgenregeln anzuwenden sind, während ein Reihenfolgenattribut „1“ eine entspannte Reihenfolge bezeichnet, wobei Schreibvorgänge Schreiben in die gleiche Richtung weitergeben können und Lesekomplettierungen Schreiben in die gleiche Richtung weitergeben können. Das Abhörattributfeld 318 wird verwendet, um zu bestimmen, ob Transaktionen abgehört werden. Wie dargestellt identifiziert Kanal-ID-Field 306 einen Kanal, dem eine Transaktion zugeordnet ist.In this example, the ordering attribute field 316 is used to provide optional information specifying the type of ordering that may alter the default ordering rules. According to an example implementation, an ordering attribute of "0" indicates that standard ordering rules apply, while an ordering attribute of "1" indicates relaxed ordering, where writes can propagate writes in the same direction and read completions can propagate writes in the same direction. The listening attribute field 318 is used to determine whether transactions are being listened to. As shown, channel ID field 306 identifies a channel with which a transaction is associated.

Verbindungsschichtconnection layer

Verbindungsschicht 210, auch als Datenverbindungsschicht 210 bezeichnet, dient als Zwischenstufe zwischen Transaktionsschicht 205 und der physikalischen Schicht 220. In einer Ausführungsform ist es eine Aufgabe der Datenverbindungsschicht 210, einen verlässlichen Mechanismus zum Austausch von Transaktionsschichtpaketen (TLPs) zwischen zwei Komponenten einer Verbindung bereitzustellen. Eine Seite der Datenverbindungsschicht 210 akzeptiert TLPs, die von der Transaktionsschicht 205 assembliert werden, wendet Paketsequenzidentifikator 211 an, d.h. eine Identikationsnummer oder Paketnummer, berechnet einen Fehlererkennungscode und wendet ihn an, d.h. CRC 212, und weist die modifizierten TLPs der physikalischen Schicht 220 zu, damit sie über eine physikalische zu einer externen Vorrichtung gesendet werden.Link layer 210, also referred to as data link layer 210, serves as an intermediary between transaction layer 205 and physical layer 220. In one embodiment, a function of data link layer 210 is to provide a reliable mechanism for exchanging transaction layer packets (TLPs) between two components of a connection. One side of the data link layer 210 accepts TLPs assembled by the transaction layer 205, applies packet sequence identifier 211, i.e. an identification number or packet number, calculates and applies an error detection code, i.e. CRC 212, and assigns the modified TLPs to the physical layer 220, to be sent via a physical to an external device.

Physikalische Schichtphysical layer

In einer Ausführungsform umfasst die physikalische Schicht 220 einen logischen Subblock 221 und einen elektrischen Subblock 222, um ein Paket physikalisch zu einer externen Vorrichtung zu senden. Hier ist ein logischer Subblock 221 verantwortlich für die „digitalen“ Funktionen der physikalischen Schicht 221. In diesem Zusammenhang umfasst der logische Subblock einen Sendeabschnitt zur Bereitstellung von ausgehenden Informationen zum Senden durch einen physikalischen Subblock 222 und einen Empfängerabschnitt zur Identifikation und Vorbereitung von empfangenen Informationen, bevor sie in die Verbindungsschicht 210 weitergeleitet werden.In one embodiment, the physical layer 220 includes a logical sub-block 221 and an electrical sub-block 222 to physically transmit a packet to an external device. Here a logical sub-block 221 is responsible for the "digital" functions of the physical layer 221. In this context, the logical sub-block comprises a transmit section for providing outgoing information for transmission by a physical sub-block 222 and a receiver section for identifying and preparing received information, before being forwarded into the link layer 210.

Der physikalische Block 222 umfasst einen Sender und einen Empfänger. Der Sender wird durch einen logischen Subblock 221 mit Symbolen versorgt, die der Sender serialisiert und zu einer externen Vorrichtung überträgt. Der Empfänger wird mit serialisierten Symbolen von einer externen Vorrichtung versorgt und wandelt die empfangenen Signale in einen Bitstrom um. Der Bitstrom wird deserialisiert und zum logischen Subblock 221 geleitet. In einer Ausführungsform wird ein 8b/10b-Sendecode eingesetzt, wobei Zehn-Bit-Symbole gesendet/empfangen werden. Hier werden spezielle Symbole eingesetzt, um ein Paket mit Rahmen 223 einzurahmen. Außerdem stellt der Empfänger in einem Beispiel auch einen Symboltaktgeber bereit, der aus dem ankommenden Serienstrom gewonnen wird.The physical block 222 includes a transmitter and a receiver. The sender is provided with symbols by a logical sub-block 221, which the sender serializes and transmits to an external device. The receiver is supplied with serialized symbols from an external device and converts the received signals into a bit stream. The bit stream is deserialized and passed to logical sub-block 221. In one embodiment, an 8b/10b transmission code is employed, with ten-bit symbols being transmitted/received. Special symbols are used here to enclose a packet with frame 223. In addition, in one example, the receiver also provides a symbol clock extracted from the incoming serial stream.

Wie oben angeführt werden zwar Transaktionsschicht 205, Verbindungsschicht 210 und physikalische Schicht 220 in Bezug auf eine spezifische Ausführungsform eines PCIe-Protokollstapels erläutert, ein geschichteter Protokollstapel ist aber nicht darauf eingeschränkt. In der Tat kann jedes beliebige geschichtete Protokoll enthalten/implementiert sein. Als Beispiel umfasst ein Anschluss/eine Schnittstelle, der/die als geschichtetes Protokoll dargestellt ist: (1) eine erste Schicht zur Assemblierung von Paketen, d.h. eine Transaktionsschicht; eine zweite Schicht zur Sequenzierung von Paketen, d.h. eine Verbindungsschicht; und eine dritte Schicht zum Senden der Pakete, d.h. eine physikalische Schicht. Als spezifisches Beispiel wird ein geschichtetes Protokoll einer herkömmlichen Standardschnittstelle (CSI) verwendet.As noted above, while transaction layer 205, link layer 210, and physical layer 220 are discussed in relation to a specific embodiment of a PCIe protocol stack, a layered protocol stack is not so limited. In fact, any layered protocol can be included/implemented. As an example, a port/interface illustrated as a layered protocol includes: (1) a first layer for assembling packets, i.e., a transaction layer; a second layer for sequencing packets, i.e. a link layer; and a third layer for sending the packets, i.e. a physical layer. As a specific example, a layered protocol of a common standard interface (CSI) is used.

Unter Bezugnahme auf 4 wird als Nächstes eine Ausführungsform einer seriellen PCIe-Punkt-zu-Punkt-Struktur dargestellt. Es ist zwar eine Ausführungsform einer seriellen PCIe-Punkt-zu-Punkt-Verbindung dargestellt, aber eine serielle Punkt-zu-Punkt-Verbindung ist nicht darauf eingeschränkt, das sie jeden beliebigen Sendepfad zum Senden von Seriendaten umfasst. In der dargestellten Ausführungsform umfasst eine grundlegende PCIe-Verbindung zwei differentiell angetriebene Niederspannungssignalpaare: ein Sendepaar 406/411 und ein Empfängerpaar 412/407. Demgemäß umfasst Vorrichtung 405 eine Sendelogik 406 zum Senden von Daten zu Vorrichtung 410 und eine Empfangslogik 407 zum Empfangen von Daten von Vorrichtung 410. Mit anderen Worten sind zwei Sendepfade, d.h. Pfad 416 und 417, und zwei Empfangspfade, d.h. Pfad 418 und 419, in einer PCIe-Verbindung enthalten.With reference to 4 Next, an embodiment of a PCIe serial point-to-point structure is presented. While one embodiment of a PCIe serial point-to-point link is illustrated, a serial point-to-point link is not limited to being everyone includes a large transmission path for sending serial data. In the illustrated embodiment, a basic PCIe link includes two differentially powered low voltage signal pairs: a transmit pair 406/411 and a receive pair 412/407. Accordingly, device 405 includes transmit logic 406 for transmitting data to device 410 and receive logic 407 for receiving data from device 410. In other words, two transmit paths, i.e. path 416 and 417, and two receive paths, i.e. path 418 and 419, are in a PCIe connection included.

Ein Sendepfad bezieht sich auf jeden beliebigen Pfad zum Senden von Daten, wie z.B. eine Sendeleitung, eine Kupferleitung, eine optische Leitung, einen Drahtloskommunikationskanal, eine Infrarotkommunikationsverbindung oder einen anderen Kommunikationspfad. Eine Verbindung zwischen zwei Vorrichtungen, z.B. Vorrichtung 405 und Vorrichtung 410, wird als Verbindung bezeichnet, z.B. Verbindung 415. Eine Verbindung kann eine Bahn unterstützen - jede Bahn stellt einen Satz von Differenzsignalpaaren dar (ein Paar zum Senden, ein Paar zum Empfangen). Um die Bandbreite zu skalieren kann eine Verbindung mehreren Bahnen aggregieren, die durch xN bezeichnet sind, wobei N jede beliebige unterstützte Verbindungsbreite ist, wie z.B. 1, 2, 4, 8, 12, 16, 32, 64 oder mehr.A transmit path refers to any path for sending data, such as a transmit line, a copper line, an optical line, a wireless communication channel, an infrared communication link, or any other communication path. A link between two devices, e.g., device 405 and device 410, is referred to as a link, e.g., link 415. A link may support one lane - each lane represents a set of differential signal pairs (one pair to transmit, one pair to receive). To scale bandwidth, a link may aggregate multiple lanes, denoted by xN, where N is any supported link width, such as 1, 2, 4, 8, 12, 16, 32, 64, or more.

Ein Differenzpaar bezieht sich auf zwei Sendepfade, wie z.B. Bahnen 416 und 417, zum Senden von Differenzsignalen. Wenn beispielsweise Leitung 416 von einem niedrigen Spannungswert zu einem hohen Spannungswert umschaltet, d.h. eine ansteigende Flanke, steuert Leitung 417 von einem hohen Logikpegel zu einem niedrigen Logikpegel, d.h. eine abfallende Flanke. Differenzsignale können eventuell bessere elektrische Eigenschaften aufwiesen, beispielsweise bessere Signalintegrität, d.h. Kreuzkopplung, Spannungsüberschreitung/-unterschreitung, Einschwingen usw. Dies ermöglicht ein besseres Zeitfenster, das raschere Sendefrequenzen ermöglicht.A differential pair refers to two transmit paths, such as lanes 416 and 417, for transmitting differential signals. For example, when line 416 switches from a low voltage value to a high voltage value, i.e., a rising edge, line 417 drives from a high logic level to a low logic level, i.e., a falling edge. Differential signals may have better electrical properties, such as better signal integrity, i.e. cross-coupling, voltage overshoot/undershoot, ringing, etc. This allows for a better timing window that allows for faster transmit frequencies.

5 ist ein vereinfachtes Blockdiagramm 500, das ein Beispiel für ein Mehrchipgehäuse 505 zeigt, das zwei oder mehr Chips oder Nacktchips umfasst (z.B. 510, 515), die unter Verwendung einer beispielhaften Mehrchipgehäuseverbindung (MCPL) 520 zur Kommunikation verbunden sind. In 5 ist zwar ein Beispiel für zwei (oder mehr) Nacktchips dargestellt, die unter Verwendung einer beispielhaften MCPL 520 verbunden sind, es versteht sich jedoch, dass die hierin beschriebenen Prinzipien und Merkmale bezüglich Implementierungen einer MCPL für jede beliebige Zwischenverbindung oder Verbindung zwischen einem Nacktchip (z.B. 510) und anderen Komponenten angewandt werden können, einschließlich der Verbindung von zwei oder zwei oder mehr Nacktchips (z.B. 510, 515), der Verbindung eines Nacktchips (oder Chips) mit einer anderen Komponente, die nicht auf einem Nacktchip ist, der Verbindung eines Nacktchips mit einer anderen Vorrichtung oder einem anderen Nacktchip, die nicht im Gehäuse sind (z.B. 505), der Verbindung eines Nacktchips mit einem BGA-Gehäuse, der Implementierung eines Patch on Interposer (POINT), als eines von möglichen anderen Beispielen. 5 5 is a simplified block diagram 500 showing an example multi-chip package 505 that includes two or more chips or dies (eg, 510, 515) that are connected using an example multi-chip package interconnect (MCPL) 520 for communication. In 5 While an example of two (or more) dies connected using an exemplary MCPL 520 is illustrated, it should be understood that the principles and features described herein apply to implementations of an MCPL for any interconnect or connection between a die (eg 510) and other components may be applied, including connecting two or two or more dies (e.g. 510, 515), connecting a die (or chips) to another component not on a die, connecting a die with another device or die not in the package (eg 505), the connection of a die to a BGA package, the implementation of a Patch on Interposer (POINT), as one of possible other examples.

Im Allgemeinen kann ein Mehrchipgehäuse (z.B. 505) ein Elektronikgehäuse sein, in dem mehrere integrierte Schaltungen (ICs), Halbleiternacktchips oder andere einzelne Komponenten (z.B. 510, 515) auf einem vereinenden Substrat (z.B. Silicium oder ein anderes Halbleitersubstrat) gepackt sind, was die Verwendung der kombinierten Komponenten als einzelne Komponente ermöglicht (z.B. als ob es sich um eine größere IC handeln würde). In manchen Fällen können die größeren Komponenten (z.B. Nacktchips 510, 515) selbst IC-Systeme sein, wie z.B. Systeme auf einem Chip (SoC), Mehrprozessorchips oder anderen Komponenten, die mehrere Komponenten (z.B. 525-530 und 540-545) auf der Vorrichtung umfassen, beispielsweise auf einem einzelnen Nacktchip (z.B. 510, 515). Mehrchipgehäuse 505 können Flexibilität beim Bau von komplexen und unterschiedlichen Systemen aus möglicherweise mehreren separaten Komponenten und Systemen breitstellen. Beispielsweise kann jeder der Nacktchips 510, 515 aus zwei unterschiedlichen Einheiten hergestellt oder auf andere Weise bereitgestellt werden, wobei das Siliciumsubstrat des Gehäuses 505 durch eine dritte Einheit bereitgestellt wird, um eines von vielen Beispielen zu nennen. Außerdem können Nacktchips und andere Komponenten innerhalb eines Mehrchipgehäuses 505 selbst Verbindungs- oder andere Kommunikationsstrukturen enthalten (z.B. 535, 550), welche die Infrastruktur für eine Kommunikation zwischen Komponenten (z.B. 525-530 und 540-545) innerhalb der Vorrichtung bereitstellen (z.B. 510 bzw. 515). Die verschiedenen Komponenten und Zwischenverbindungen (z.B. 535, 550) können möglicherweise mehrere verschiedene Protokolle unterstützen oder nutzen. Ferner kann Kommunikation zwischen Nacktchips (z.B. 510, 515) möglicherweise Transaktionen zwischen den verschiedenen Komponenten auf den Nacktchips über mehrere verschieden Protokolle umfassen. Der Entwurf von Mechanismen zur Bereitstellung von Kommunikation zwischen Chips (oder Nacktchips) auf einem Mehrchipgehäuse kann eine Herausforderung darstellen, da herkömmliche Lösungen hochspezialisierte, teure und gehäusespezifische Lösungen nutzen, die auf spezifischen Kombinationen von Komponenten (und gewünschten Transaktionen) basieren, die verbunden werden sollen.In general, a multi-chip package (e.g., 505) can be an electronics package in which multiple integrated circuits (ICs), semiconductor dies, or other individual components (e.g., 510, 515) are packaged on a unifying substrate (e.g., silicon or other semiconductor substrate), representing the Allows the combined components to be used as a single component (e.g. as if it were a larger IC). In some cases, the larger components (e.g., 510, 515 dies) may be IC systems themselves, such as systems on a chip (SoC), multiprocessor chips, or other components that combine multiple components (e.g., 525-530 and 540-545) on the device, for example on a single die (e.g. 510, 515). Multi-chip packages 505 can provide flexibility in building complex and diverse systems from potentially multiple separate components and systems. For example, each of the dies 510, 515 may be fabricated or otherwise provided from two different units, with the silicon substrate of the package 505 being provided by a third unit, to cite one of many examples. In addition, dies and other components within a multi-chip package 505 may themselves contain interconnect or other communication structures (e.g., 535, 550) that provide the infrastructure for communication between components (e.g., 525-530 and 540-545) within the device (e.g., 510 and .515). The various components and interconnects (e.g. 535, 550) may support or utilize several different protocols. Furthermore, communication between dies (e.g. 510, 515) may potentially involve transactions between the various components on the dies over several different protocols. Designing mechanisms to provide communication between chips (or dies) on a multi-chip package can be challenging, as traditional solutions utilize highly specialized, expensive, and package-specific solutions based on specific combinations of components (and desired transactions) to be connected .

Die Beispiele, Systeme, Algorithmen, Geräte, Logiken und Merkmale, die in dieser Patentschrift beschrieben sind, können zumindest einige der oben identifizierten Probleme ansprechen, einschließlich möglicherweise vieler anderer, die hierin nicht erwähnt sind. Beispielsweise kann in manchen Implementierungen eine Schnittstelle mit hoher Bandbreite, geringer Energie und geringer Latenz bereitgestellt werden, um eine Host-Vorrichtung (z.B. eine CPU) oder andere Vorrichtung mit einem entsprechenden Chip verbinden, der im selben Gehäuse wie der Host enthalten ist. Solch eine Mehrchipgehäuseverbindung (MCPL) kann mehrere Gehäuseoptionen, mehrere I/O-Protokolle sowie Merkmale bezüglich Verlässlichkeit, Verfügbarkeit und Wartbarkeit (RAS) unterstützen. Ferner kann die physikalische Schicht (PHY) eine Elektrikschicht und eine Logikschicht umfassen und kann längere Kanallängen unterstützen, einschließlich Kanallängen von bis zu, und in manchen Fällen mehr als, etwa 45 mm. In manchen Implementierungen kann eine beispielhafte MCPL bei hohen Datenraten laufen, einschließlich Datenraten über 8-10 Gb/s.The examples, systems, algorithms, devices, logic, and features described in this specification may address at least some of the issues identified above, including possibly many others not mentioned herein. For example, in some implementations, a high-bandwidth, low-power, and low-latency interface may be provided to connect a host device (eg, a CPU) or other device to a corresponding chip contained in the same package as the host. Such a multichip package interconnect (MCPL) can support multiple package options, multiple I/O protocols, and reliability, availability and serviceability (RAS) features. Furthermore, the physical layer (PHY) may include an electrical layer and a logic layer, and may support longer channel lengths, including channel lengths of up to, and in some cases greater than, about 45 mm. In some implementations, an example MCPL can run at high data rates, including data rates in excess of 8-10 Gb/s.

In einer beispielhaften Implementierung einer MCPL kann eine PHY-Elektrikschicht eine Verbesserung gegenüber herkömmlichen Mehrkanalverbindungslösungen bereitstellen (z.B. Mehrkanal-DRAM-I/O), wodurch die Datenrate und die Kanalkonfiguration erweitert werden, beispielsweise um eine Reihe von Merkmalen, die beispielsweise regulierte Mittelschienentermination, aktive Niedrigenergie-Übersprechunterdrückung, Schaltungsredundanz, Pro-Bit-Arbeitszykluskorrektur und Entfernung von Laufzeitunterschieden, Zeilenkodierung und Senderausgleich, um einige von vielen Beispielen zu nennen.In an exemplary implementation of an MCPL, a PHY electrical layer may provide an improvement over traditional multi-channel interconnect solutions (e.g., multi-channel DRAM I/O), thereby expanding the data rate and channel configuration, such as by adding a number of features, such as regulated mid-rail termination, active Low-power crosstalk suppression, circuit redundancy, per-bit duty cycle correction and skew removal, line encoding, and transmitter equalization, to name a few of many examples.

In einer beispielhaften Implementierung einer MCPL kann eine PHY-Logikschicht implementiert sein, die zusätzlich die Erweiterung der Datenrate und Kanalkonfiguration unterstützen kann (z.B. Elektrikschichtmerkmale), während sie auch die Verbindung zum Routen von mehreren Protokollen durch die Elektrikschicht ermöglichen kann. Solche Implementierungen können eine modulare gemeinsame physikalische Schicht bereitstellen und definieren, die unabhängig vom Protokoll ist und eine Architektur aufweist, um mit möglicherweise jedem beliebigen existierenden oder zukünftigen Verbindungsprotokoll zu arbeiten.In an exemplary implementation of an MCPL, a PHY logic layer may be implemented, which may additionally support data rate extension and channel configuration (e.g., electrical layer features), while also allowing the connection to route multiple protocols through the electrical layer. Such implementations may provide and define a modular common physical layer that is protocol independent and has an architecture to work with potentially any existing or future link protocol.

Auf 6 Bezug nehmend wird ein vereinfachtes Blockdiagramm 600 dargestellt, das zumindest einen Teil eines Systems zeigt, das eine beispielhafte Implementierung einer Mehrchipgehäuseverbindung (MCPL) darstellt. Eine MCPL kann unter Verwendung physikalischer elektrischer Verbindungen (z.B. als Bahnen implementierte Drähte) implementiert sein, die eine erste Vorrichtung 605 (z.B. einen ersten Nacktchip, der eine oder mehrere Subkomponenten umfasst) mit einer zweiten Vorrichtung 610 (z.B. einem zweiten Nacktchip, der eine oder mehrere Subkomponenten umfasst) verbindet. In dem speziellen in der High-Level-Darstellung 600 dargestellten Beispiel können alle Signale (in Kanal 615, 620) unidirektional sein und es können Bahnen für die Datensignale bereitgestellt werden, um eine Datenübertragung sowohl stromaufwärts als auch stromabwärts zu erhalten. Blockdiagramm 600 aus 6 bezieht sich zwar auf die erste Komponente 605 als stromauf liegende Komponente und auf die zweite Komponente 610 als die stromab liegende Komponente sowie auf die physikalischen Bahnen der MCPL, die beim Senden von Daten verwendet werden, als stromab liegender Kanal 615, und Bahnen, die zum Empfangen von Daten (von Komponente 610) verwendet werden, als stromab liegender Kanal 620, es versteht sich jedoch, dass die MCPL zwischen den Vorrichtungen 605, 610 von jeder Vorrichtung zum sowohl Senden als auch Empfangen von Daten zwischen den Vorrichtungen verwendet werden kann.On 6 Referring now to FIG. 1, a simplified block diagram 600 depicting at least a portion of a system that is an example implementation of a multi-chip package interconnect (MCPL) is presented. An MCPL may be implemented using physical electrical connections (e.g., wires implemented as traces) connecting a first device 605 (e.g., a first die that includes one or more subcomponents) to a second device 610 (e.g., a second die that includes one or more subcomponents). comprises several subcomponents) connects. In the particular example shown in the high-level representation 600, all signals (in channels 615, 620) may be unidirectional, and lanes for the data signals may be provided to receive both upstream and downstream data transmission. Block diagram 600 off 6 while referring to the first component 605 as the upstream component and to the second component 610 as the downstream component, as well as to the physical lanes of the MCPL used in sending data as the downstream channel 615, and lanes leading to the receiving data (from component 610) as downstream channel 620, however, it should be understood that the MCPL between devices 605, 610 may be used by any device to both transmit and receive data between the devices.

In einer beispielhaften Implementierung kann eine MCPL eine physikalische Schicht (PHY) bereitstellen, welche die elektrische MCPL PHY 625a,b (oder gemeinsam 625) und die eine ausführbare Logik implementierbare MCPL-Logik-PHY 630a,b (oder gemeinsam 630) umfasst. Die elektrische oder physikalische PHY 625 kann die physikalische Verbindung bereitstellen, über die Daten zwischen Vorrichtungen 605, 610 übertragen werden. Signalkonditionierungskomponenten und Logik können in Verbindung mit der physikalischen PHY 625 implementiert sein, um eine hohen Datenrate und Kanalkonfigurationsfähigkeiten der Verbindung bereitzustellen, die in manchen Anwendungen dichte gebündelte physikalische Verbindungen mit Längen von etwa 45mm oder mehr umfassen können. Die logische PHY 630 kann eine Logik zur Vereinfachung von Taktgebung, Verbindungszustandsverwaltung (z.B. für Verbindungsschichten 635a, 635b) und Protokollmultiplexen zwischen möglicherweise mehreren, unterschiedlichen Protokollen, die für Kommunikationen über die MCPL verwendet werden, umfassen.In an example implementation, an MCPL may provide a physical layer (PHY) that includes the electrical MCPL PHY 625a,b (or collectively 625) and the executable logic implementable MCPL logic PHY 630a,b (or collectively 630). The electrical or physical PHY 625 may provide the physical connection over which data is transmitted between devices 605,610. Signal conditioning components and logic may be implemented in conjunction with the physical PHY 625 to provide high data rate and link channel configuration capabilities, which in some applications may include densely clustered physical links with lengths of about 45 mm or more. The logical PHY 630 may include logic to facilitate clocking, link state management (e.g. for link layers 635a, 635b), and protocol multiplexing between potentially multiple, different protocols used for communications over the MCPL.

In einer beispielhaften Implementierung kann die physikalische PHY 625 für jeden Kanal (z.B. 615, 620) einen Satz von Datenbahnen umfassen, über die bandinterne Daten gesendet werden können. In diesem speziellen Beispiel sind 50 Datenbahnen in jedem aus dem stromauf und stromab gelegenen Kanal 615, 620 bereitgestellt, obwohl jede beliebige andere Anzahl von Bahnen verwendet werden kann, wenn dies aufgrund der Auslegungs- und Energieeinschränkungen, gewünschten Anwendungen, Vorrichtungseinschränkungen usw. erlaubt ist. Jeder Kanal kann ferner eine oder mehrere dedizierte Bahnen für ein Abtast-, oder Takt-, Signal für den Kanal, eine oder mehrere dedizierte Bahnen für ein gültiges Signal für den Kanal, eine oder mehrere dedizierte Bahnen für ein Stromsignal und eine oder mehrere dedizierte Bahnen für ein Verbindungszustandsmaschinenverwaltungs- oder Seitenbandsignal umfassen. Die physikalische PHY kann ferner eine Seitenbandverbindung 640 umfassen, die in einigen Beispielen eine bidirektionale Niedrigfrequenzsteuersignalverbindung sein kann, die zur Koordination von Zustandsübergängen und anderen Attributen der MCPL verwendet wird, welche die Vorrichtungen 605, 610 verbinden, um eines von mehreren Beispielen zu nennen.In an example implementation, the physical PHY 625 for each channel (eg, 615, 620) may include a set of data lanes over which in-band data may be sent. In this particular example, 50 data lanes are provided in each of the upstream and downstream channels 615, 620, although any other number of lanes may be used if design and power constraints, desired applications, device limitations, etc. allow. Each channel can also have one or more dedicated lanes for a scan, or clock, signal for the channel, one or more dedicated lanes for a valid signal for the channel, one or more dedicated lanes for a power signal, and one or more dedicated lanes for a link state machine management or sideband signal. The physical PHY may further include a sideband link 640, which in some examples may be a bi-directional low frequency control signal link used to coordinate state transitions and other attributes of the MCPL connecting the devices 605, 610, to cite one of several examples.

Wie oben angemerkt können unter Verwendung einer Implementierung der MCPL mehrere Protokolle unterstützt werden. In der Tat können mehrere unabhängige Transaktionsschichten 650a, 650b bei jeder Vorrichtung 605, 610 bereitgestellt werden. Beispielsweise kann jede Vorrichtung 605, 610 zwei oder mehr Protokolle unterstützen und verwenden, wie z.B. unter anderem PCI, PCIe, QPI, Intel In-Die Interconnect (IDI). IDI ist ein kohärentes Protokoll, das auf dem Nacktchip verwendet wird, um zwischen Kernen, Caches der letzten Ebene (LLCs), Speichern, Grafiken und IO-Steuerungen zu kommunizieren. Andere Protokolle können ebenfalls unterstützt werden, einschließlich Ethernet-Protokoll, Infiniband-Protokolle und andere auf PCIe-Strukturen basierende Protokolle. Die Kombination aus der Logik-PHY und der physikalischen PHY kann auch als Verbindung zwischen Nacktchip und Nacktchip verwendet werden, um eine SerDes-PHY (PCIe, Ethernet, Infiniband oder andere Hochgeschwindigkeits-SerDes) auf einem Nacktchip mit den oberen Schichten zu verbinden, die auf dem anderen Nacktchip implementiert sind, um eines von mehreren Beispielen zu nennen.As noted above, multiple protocols can be supported using an implementation of the MCPL. Indeed, multiple independent transaction layers 650a, 650b may be provided at each device 605, 610. For example, each device 605, 610 may support and use two or more protocols such as PCI, PCIe, QPI, Intel In-Die Interconnect (IDI), among others. IDI is a coherent protocol used on the bare chip to communicate between cores, last level caches (LLCs), memory, graphics and IO controllers. Other protocols may also be supported, including Ethernet protocol, Infiniband protocols, and other protocols based on PCIe fabrics. The combination of the logic PHY and physical PHY can also be used as a die-to-die interconnect to connect a SerDes PHY (PCIe, Ethernet, Infiniband, or other high-speed SerDes) on a die to the upper layers that are implemented on the other die, to name one of several examples.

Logik-PHY 630 kann Multiplexen zwischen diesen mehreren Protokollen auf einer MCPL unterstützen. Beispielsweise kann die dedizierte Datenstrombahn verwendet werden, um ein kodiertes Datenstromsignal zuzusichern, das identifiziert, welches Protokoll auf Daten angewandt werden soll, die im Wesentlichen gleichzeitig auf den Datenbahnen des Kanals gesendet werden. Ferner kann Logik-PHY 630 verwendet werden, um die verschiedenen Arten von Verbindungszustandsübergängen automatisch einzustellen, welche die verschiedenen Protokolle unterstützen oder erfordern. In manchen Fällen können LSM_SB-Signale, die über die dedizierte LSM_SB-Bahn des Kanals gesendet werden, zusammen mit der Seitenbandverbindung 640 verwendet werden, um Verbindungszustandsübergänge zwischen den Vorrichtungen 605, 610 zu kommunizieren und automatisch einzustellen. Ferner können Verbindungstraining, Fehlererkennung, Laufzeitunterschiedsfeststellung, Entfernung von Laufzeitunterschieden und andere Funktionalitäten von herkömmlichen Verbindungen unter Verwendung von Logik-PHY 630 teilweise ersetzt oder gesteuert werden. Beispielsweise können gültige Signale, die über eine oder mehrere dedizierte gültige Signalbahnen in jedem Kanal gesendet werden, zur Signalisierung von Verbindungsaktivität, Feststellung von Laufzeitverschiebungen, Verbindungsfehler, und Umsetzung anderer Merkmale, um einige Beispiele zu nennen, verwendet werden. Im speziellen Beispiel aus 6 werden mehrere gültige bahnen pro Kanal bereitgestellt. Beispielsweise können Datenbahnen innerhalb eines Kanals gebündelt oder zusammengeballt sein (physikalisch und/oder logisch), und eine gültige bahn für jedes Bündel kann bereitgestellt sein. Ferner können mehrere Abtastbahnen bereitgestellt sein, in manchen Fällen auch um ein dediziertes Abtastsignal für jedes Bündel in einer Vielzahl von Datenbahnbündeln in einem Kanal bereitzustellen, um ein Beispiel zu nennen.Logic PHY 630 can support multiplexing between these multiple protocols on an MCPL. For example, the dedicated data stream path can be used to assert an encoded data stream signal that identifies which protocol is to be applied to data sent substantially simultaneously on the data paths of the channel. Furthermore, logic PHY 630 can be used to automatically adjust the different types of link state transitions that the different protocols support or require. In some cases, LSM_SB signals sent over the channel's dedicated LSM_SB lane may be used in conjunction with the sideband link 640 to communicate and automatically adjust link state transitions between the devices 605, 610. Furthermore, link training, error detection, skew detection, skew removal, and other functionalities of conventional links may be partially replaced or controlled using logic PHY 630 . For example, valid signals sent over one or more dedicated valid signaling lanes in each channel can be used to signal link activity, detect skew, link errors, and implement other features, to name a few examples. In the specific example 6 multiple valid lanes are provided per channel. For example, data lanes may be bundled or clustered (physically and/or logically) within a channel, and a valid lane for each cluster may be provided. Furthermore, multiple scan lanes may be provided, in some cases also to provide a dedicated scan signal for each burst in a plurality of data lane bursts in a channel, for example.

Wie oben angemerkt kann Logik-PHY 630 verwendet werden, um Verbindungssteuerungssignale, die zwischen durch die MCPL verbundenen Vorrichtungen gesendet werden, automatisch einzustellen und zu verwalten. In einigen Implementierungen kann Logik-PHY 630 eine Verbindungsschichtpaket- (LLP) Erzeugungslogik 660 umfassen, die verwendet werden kann, um Verbindungsschichtsteuernachrichten über die MCPL (d.h. bandintern) zu senden. Solche Nachrichten können über Datenbahnen des Kanals gesendet werden, wobei die Datenstrombahn identifiziert, dass die Daten Verbindungsschicht-zu-Verbindungsschicht-Nachrichtenübertragung darstellen, wie z.B. Verbindungsschichtsteuerdaten, um ein Beispiel zu nennen. Verbindungsschichtnachrichten, die unter Verwendung eines LLP-Moduls 660 aktiviert sind, können die automatische Einstellung und Leistung von Verbindungsschichtzustandsübergängen, Energieverwaltung, Schleifenbetrieb, Deaktivierung, Neuzentrierung, Verwürflung, unter anderen Verbindungsschichtmerkmalen, zwischen den Verbindungsschichten 635a, 635b von Vorrichtung 605 bzw. 610 unterstützen.As noted above, logic PHY 630 may be used to automatically adjust and manage link control signals sent between devices connected through the MCPL. In some implementations, logic PHY 630 may include link layer packet (LLP) generation logic 660 that may be used to send link layer control messages over the MCPL (i.e., in-band). Such messages may be sent over data lanes of the channel, the data stream identifying the data as representing link layer-to-link layer messaging, such as link layer control data, for example. Link layer messages enabled using an LLP module 660 can support the automatic adjustment and performance of link layer state transitions, power management, looping, deactivation, re-centering, scrambling, among other link layer features, between the link layers 635a, 635b of devices 605 and 610, respectively.

Auf 7 Bezug nehmend wird ein Diagramm 700 dargestellt, das eine beispielhafte Signalübertragung unter Verwendung eines Satzes von Bahnen (z.B. 615, 620) in einem bestimmten Kanal einer beispielhaften MCPL zeigt. Im Beispiel aus 7 sind zwei Bündel aus fünfundzwanzig (25) Datenbahnen für insgesamt fünfzig (50) Datenbahnen im Kanal bereitgestellt. Ein Teil der Bahnen ist dargestellt, während andere (z.B. DATA[4-46] und eine zweite Abtastsignalbahn (STRB)) der einfacheren Darstellung des speziellen Beispiels halber weggelassen sind (z.B. als redundante Signale). Wenn die physikalische Schicht sich in einem aktiven Zustand befindet (z.B. nicht abgeschaltet oder in einem Niedrigenergiemodus (z.B. einem L1-Zustand)), können Abtastbahnen (STRB) mit einem synchronen Taktsignal versehen werden. In einigen Implementierungen können Daten auf sowohl der ansteigenden als auch der abfallenden Flanke der Abtastung gesendet werden. Jede Flanke (oder Halbtaktzyklus) kann ein Einheitsintervall (UI) begrenzen. Demgemäß kann in diesem Beispiel ein Bit (z.B. 705) auf jeder Bahn gesendet werden, sodass ein Byte alle 8 UI gesendet werden kann. Eine Byte-Zeitdauer 710 kann als 8 UI definiert werden, oder die Zeit, die zum Senden eines Bytes auf einer einzelnen der Datenbahnen notwendig ist (z.B. DATA[0-49]).On 7 Referring now to FIG. 7, a diagram 700 is presented showing an example signal transmission using a set of lanes (eg, 615, 620) in a particular channel of an example MCPL. In the example off 7 two bundles of twenty-five (25) data lanes are provided for a total of fifty (50) data lanes in the channel. A portion of the traces are shown while others (eg, DATA[4-46] and a second strobe signal trace (STRB)) are omitted (eg, as redundant signals) for ease of illustration of the specific example. When the physical layer is in an active state (e.g. not powered down or in a low power mode (e.g. an L1 state)), scanning paths (STRB) can be provided with a synchronous clock signal. In some implementations, data can be sent on both the rising and falling edges of the sample. Each edge (or half-clock cycle) can delimit a unit interval (UI). Accordingly, in this example, one bit (eg, 705) can be sent on each lane, so one byte can be sent every 8 UI. A byte period 710 can be defined as 8 UI, or the time it takes to send a byte on a single one of the data lanes (eg, DATA[0-49]).

In einigen Implementierungen kann ein gültiges Signal, das auf einem oder mehreren dedizierten gültigen Signalkanälen (z.B. VALID0, VALID1) gesendet wird, als führender Indikator für die Empfangsvorrichtung dienen, um, wenn zugesichert (hoch), für die Empfangsvorrichtung oder Senke, zu identifizieren, dass Daten von der Sendevorrichtung, oder Quelle, auf Datenbahnen (z.B. DATA[0-49]) während der folgenden Zeitperiode, z.B. eine Byte-Zeitdauer 710, gesendet werden. Alternativ dazu gibt, wenn das gültige Signal niedrig ist, die Quelle der Senke an, dass die Senke während der folgenden Zeitdauer keine Daten auf den Datenbahnen senden wird. Demgemäß kann, wenn die Senken-Logik-PHY feststellt, dass das gültige Signal nicht zugesichert ist (z.B. auf Bahne VALID0 und VALID1), die Senke jegliche Daten, die auf den Datenbahnen (z.B. DATA[0-49]) während der folgenden Zeitdauer festgestellt werden, ignorieren. Beispielsweise können Übersprechgeräusche oder andere Bits auf einer oder mehreren der Datenbahnen auftreten, wenn die Quelle in Wahrheit keine Daten sendet. Aufgrund eines niedrigen, oder nicht zugesicherten, gültigen Signals während der vorherigen Zeitdauer (z.B. der vorherigen Byte-Zeitdauer), kann die Senke bestimmen, dass die Datenbahnen während der folgenden Zeitdauer zu ignorieren sind.In some implementations, a valid signal transmitted on one or more dedicated valid signal channels (e.g., VALID0, VALID1) may serve as a leading indicator for the receiving device to identify, if committed (high), for the receiving device or sink that data is sent from the sending device, or source, on data lanes (e.g., DATA[0-49]) during the following time period, e.g., one byte period 710. Alternatively, if the valid signal is low, the source indicates to the sink that the sink will not send data on the data lanes for the following period of time. Accordingly, if the sink logic PHY determines that the valid signal is not asserted (e.g., on lanes VALID0 and VALID1), the sink can retrieve any data that is on the data lanes (e.g., DATA[0-49]) during the following period be detected, ignore. For example, crosstalk or other bits may appear on one or more of the data lanes when the source is not actually sending data. Based on a low, or unasserted, valid signal during the previous period (e.g., the previous byte period), the sink may determine to ignore the data lanes during the following period.

Auf einer der Bahnen der MCPL gesendete Daten können streng mit dem Abtastsignal abgeglichen sein. Eine Zeitdauer kann basierend auf der Abtastung definiert sein, wie z.B. eine Byte-Zeitdauer, und jede dieser Dauern kann einem definierten Fenster entsprechen, in dem Signale auf den Datenbahnen (z.B. DATA[0-49]), den gültigen Bahnen (z.B. VALID1, VALID2) und der Datenstrombahn (z.B. STREAM) zu senden sind. Demgemäß kann Abgleichen dieser Signale eine Identifikation ermöglichen, dass ein gültiges Signal in einem vorherigen Zeitraumfester für Daten im nachfolgenden Zeitraumfenster gilt, und dass ein Datenstromsignal für Daten im gleichen Zeitdauerfenster gilt. Das Datenstromsignal kann ein kodiertes Signal sein (z.B. 1 Byte von Daten für ein Byte-Zeitdauerfenster), das kodier ist, um das Protokoll zu identifizieren, das für Daten gilt, die während desselben Zeitdauerfensters gesendet werden.Data sent on either lane of the MCPL may be strictly aligned with the strobe signal. A time period may be defined based on the sample, such as a byte time period, and each of these durations may correspond to a defined window in which signals on the data lanes (e.g., DATA[0-49]), the valid lanes (e.g., VALID1, VALID2) and the data flow path (e.g. STREAM) are to be sent. Accordingly, matching these signals may allow identification that a valid signal in a previous time period window applies to data in the subsequent time period window and that a data stream signal applies to data in the same time period window. The data stream signal may be an encoded signal (e.g. 1 byte of data for one byte time window) encoded to identify the protocol applicable to data sent during the same time window.

Zur Veranschaulichung ist im speziellen Beispiel aus 7 ein Byte-Zeitdauerfenster definiert. Ein gültig wird bei einer Zeitdauerfenster n (715) zugesichert, bevor irgendwelche Daten auf die Datenbahnen DATA[0-49] geschickt werden. Im folgenden Zeitdauerfenster n+1 (720) werden Daten auf zumindest einer dieser Datenbahnen gesendet. In diesem Fall werden während n+1 (720) Daten auf allen fünfzig Datenbahnen gesendet. Da ein gültig für die Dauer des vorherigen Zeitdauerfensters n (715) zugesichert wurde, kann die Senkenvorrichtung die Daten validieren, die auf den Datenbahnen DATA[0-49] während des Zeitdauerfensters n+1 (720) empfangen werden. Außerdem erlaubt es die führende Art des gültigen Signals während des Zeitdauerfensters n (715) der Empfangsvorrichtung, sich auf die ankommenden Daten vorzubereiten. Mit dem Beispiel aus 7 fortsetzend wird bleibt das gültige Signal während der Dauer von Zeitdauerfenster n+1 (720) zugesichert (auf VALID1 und VALID2), was dazu führt, dass die Senkenvorrichtung die Daten erwartet, die über Datenbahnen DATA[0-49] während des Zeitdauerfensters n+2 (725) gesendet werden. Bliebe das gültige Signals während Zeitdauerfenster n+2 (725) zugesichert, könnte die Senkenvorrichtung weiterhin erwarten, weitere Daten zu empfangen (und zu verarbeiten), die während eines direkt nachfolgenden Zeitdauerfensters n+3 (730) gesendet werden. Im Beispiel aus 7 wird jedoch die Zusicherung des gültigen Signals während der Dauer von Zeitdauerfenster n+2 (725) aufgehoben, was der Senkenvorrichtung anzeigt, dass während Zeitdauerfenster n+3 (730) keine Daten gesendet werden und dass jegliche Bits, die auf Datenbahnen DATA[0-49] erfasst werden, während Zeitdauerfenster n+3 (730) ignoriert werden sollten.For illustration, the specific example is off 7 defines a byte time window. A valid is asserted at a time period window n (715) before any data is sent onto data lanes DATA[0-49]. In the following time window n+1 (720), data is sent on at least one of these data paths. In this case, data is sent on all fifty data lanes during n+1 (720). Since a valid for the duration of the previous duration window n (715) has been asserted, the sink device can validate the data received on data lanes DATA[0-49] during the duration window n+1 (720). Also, the leading nature of the valid signal during duration window n (715) allows the receiving device to prepare for the incoming data. With the example out 7 continuing, the valid signal remains asserted (on VALID1 and VALID2) for the duration of duration window n+1 (720), resulting in the sink device awaiting the data to be sent over lanes DATA[0-49] during duration window n+ 2 (725) to be sent. If the valid signal remained asserted during duration window n+2 (725), the sink device could still expect to receive (and process) more data sent during an immediately following duration window n+3 (730). In the example off 7 however, the valid signal is deasserted during duration window n+2 (725), indicating to the sink device that no data will be sent during duration window n+3 (730) and that any bits written on data lanes DATA[0- 49] should be detected while duration windows n+3 (730) should be ignored.

Wie oben angemerkt können mehrere gültige Bahnen und Abtastbahnen pro Kanal aufrechterhalten werden. Dies kann, unter anderen Vorteilen, dazu beitragen, die Einfachheit der Schaltung und Synchronisation zwischen den Bündeln von relativ langen physikalischen Bahnen, welche die zwei Vorrichtungen verbinden, zu erhalten. In einigen Implementierungen kann ein Satz von Datenbahnen in Bündeln von Datenbahnen unterteilt werden. Im Beispiel aus 7 können beispielsweise Datenbahnen DATA[0-49] in zwei fünfundzwanzig Bahnen umfassende Bündel unterteilt werden, und jedes Bündel kann eine dedizierte gültige und Abtastbahne umfassen. Beispielsweise kann gültige Bahne VALID1 Datenbahnen DATA[0-24] zugeordnet sein, und gültige Bahn VALID2 kann Datenbahnen DATA[25-49] zugeordnet sein. Die Signale auf jeder „Kopie“ der gültigen und Abtastbahnen für jedes Bündel können identisch sein.As noted above, multiple valid trajectories and scan trajectories can be maintained per channel. This can, among other benefits, help preserve the simplicity of the circuitry and synchronization between the bursts of relatively long physical traces connecting the two devices. In some implementations, a set of data lanes can be divided into bundles of data lanes. In the example off 7 For example, data lanes DATA[0-49] may be divided into two twenty-five lane bundles, and each bundle may include a dedicated valid and scan lane. For example, valid lane VALID1 may be associated with data lanes DATA[0-24] and valid lane VALID2 may be associated with data lanes DATA[25-49]. The signals on each "copy" of the valid and scan trajectories for each bundle may be identical.

Wie oben eingeführt können Daten auf Datenstrombahn STREAM verwendet werden, um der Empfangslogik-PHY anzuzeigen, welches Protokoll für entsprechende Daten anzuwenden ist, die auf Datenbahnen DATA[0-49] gesendet werden. Im Beispiel aus 7 wird ein Datenstromsignal auf STREAM während desselben Zeitdauerfensters gesendet wie Daten auf Datenbahnen DATA[0-49], um das Protokoll der Daten auf den Datenbahnen anzuzeigen. In alternativen Implementierungen kann das Datenstromsignal während eines vorherigen Zeitdauerfensters gesendet werden, beispielsweise mit entsprechenden gültigen Signalen, um eine von möglichen anderen Modifikationen zu nennen. Mit dem Beispiel aus 7 fortsetzend wird jedoch ein Datenstromsignal 735 während Zeitdauerfenster n+1 (720) gesendet, das kodiert ist, um das Protokoll (z.B. PCIe, PCI, IDI, QPI usw.) anzuzeigen, das auf die Bits anzuwenden ist, die über Datenbahnen DATA[0-49] während Zeitdauerfenster n+1 (720) gesendet werden. Auf ähnliche Weise kann ein weiteres Datenstromsignal 740 während des nachfolgenden Zeitdauerfensters n+2 (725) gesendet werden, um das Protokoll anzuzeigen, das auf die Bits anzuwenden ist, die über Datenbahnen DATA[0-49] während Zeitdauerfenster n+2 (725) gesendet werden, usw. In manchen Fällen, wie beim Beispiel aus 7 (wobei beide Datenstromsignale 735, 740 die gleiche Kodierung aufwiesen, binäres FF), können Daten in nachfolgenden Zeitdauerfenstern (z.B. n+1 (720) und n+2 (725)) zum selben Protokoll gehören. In anderen Fällen können jedoch Daten in nachfolgenden Zeitdauerfenstern (z.B. n+1 (720) und n+2 (725)) von verschiedenen Transaktionen stammen, bei denen unterschiedliche Protokolle anzuwenden sind, und Datenstromsignale (z.B. 735, 740) können demgemäß kodiert sein, um die unterschiedlichen Protokolle zu identifizieren, die für die nachfolgenden Bytes von Daten auf den Datenbahnen (z.B. DATA[0-49]) gelten, um ein Beispiel zu nennen.As introduced above, data on data stream lane STREAM can be used to indicate to the receive logic PHY which protocol to apply for corresponding data sent on data lanes DATA[0-49]. In the example off 7 a data stream signal is sent on STREAM during the same time duration window as data on data lanes DATA[0-49] to indicate the history of the data on the data lanes. In alternative implementations, the data stream signal may be sent during a previous time duration window, for example with corresponding valid signals, to name one of possible other modifications. With the example out 7 however, a data stream signal 735 encoded to indicate the protocol (e.g., PCIe, PCI, IDI, QPI, etc.) to be applied to the bits carried over data lanes DATA[0 -49] are sent during duration windows n+1 (720). Similarly, another data stream signal 740 may be sent during the subsequent duration window n+2 (725) to indicate the protocol to be applied to the bits transmitted over data lanes DATA[0-49] during duration window n+2 (725). be sent, etc. In some cases, as in the example below 7 (both data stream signals 735, 740 having the same encoding, binary FF), data in subsequent time duration windows (e.g., n+1 (720) and n+2 (725)) may belong to the same protocol. In other cases, however, data in subsequent time duration windows (e.g., n+1 (720) and n+2 (725)) may originate from different transactions employing different protocols, and data stream signals (e.g., 735, 740) may be encoded accordingly to identify the different protocols that apply to the subsequent bytes of data on the data lanes (e.g., DATA[0-49]), to give an example.

In einigen Implementierungen kann ein Niedrigenergie- oder Ruhezustand für die MCPL definiert sen. Wenn beispielsweise keine Vorrichtung auf der MCPL Daten sendet, kann die physikalische Schicht (elektrisch und logisch) von MCPL in einen Ruhe- oder Niedrigenergiezustand übergehen. Im Beispiel aus 7 ist beispielsweise bei Zeitdauerfenster n-2 (745) die MCPL in einem inaktiven oder Ruhezustand und die Abtastung ist ausgeschaltet, um Energie zu sparen. Die MCPL kann aus einem Niedrigenergie- oder Ruhezustand austreten und die Abtastung bei Zeitdauerfenster n-1 (z.B. 705) aktivieren. Die Abtastung kann eine Sendepräambel komplettieren (z.B. um das Aufwaschen und Synchronisieren der einzelnen Bahnen des Kanals sowie der Senkenvorrichtung zu unterstützen), das Abtastsignal vor jeder anderen Signalübertragung auf den anderen Nicht-Abtastbahnen übertragen. Nach diesem Zeitdauerfenster n-1 (705) kann das gültige Signal bei Zeitdauerfenster n (715) zugesichert werden, um die Senke zu benachrichtigen, dass Daten im folgenden Zeitdauerfenster n+1 (720) kommen werden, wie oben erläutert ist.In some implementations, a low power or sleep state may be defined for the MCPL. For example, when no device on the MCPL is transmitting data, the physical layer (electrical and logical) of the MCPL may enter an idle or low power state. In the example off 7 for example, at duration window n-2 (745), the MCPL is in an inactive or idle state and sampling is off to save power. The MCPL may emerge from a low power or sleep state and enable sampling at duration window n-1 (eg, 705). The scan may complete a transmit preamble (eg, to help wash up and synchronize the individual lanes of the channel as well as the sink device) carrying the scan signal before any other signal transmission on the other non-scan lanes. After this duration window n-1 (705), the valid signal can be asserted at duration window n (715) to notify the sink that data will be coming in the following duration window n+1 (720), as explained above.

Die MCPL kann wieder in einen Niedrigenergie- oder Ruhezustand (z.B. einen L1-Zustand) übergehen, nachdem Ruhezustände auf den gültigen Bahnen, Datenbahnen und/oder anderen Bahnen des MCPL-Kanals erfasst wurden. Beispielsweise kann eine Signalübertragung erfasst werden, die bei Zeitdauerfenster n+3 (730) beginnt und weiterläuft. Logik auf entweder der Quelle oder der Senkenvorrichtung kann initiierten, dass zurück in einen Niedrigenergiezustand gegangen wird, was wiederum (z.B. Zeitdauerfenster n+5 (755)) dazu führt, dass die Abtastung in einen Energiesparmodus übergeht, um ein Beispiel und Prinzipien zu nennen (einschließlich der später hierin erläuterten).The MCPL may transition back to a low power or idle state (e.g., an L1 state) after idle states are detected on the valid lanes, data lanes, and/or other lanes of the MCPL channel. For example, a signaling transmission beginning and continuing at duration window n+3 (730) can be detected. Logic on either the source or sink device can initiate going back to a low power state, which in turn (e.g. duration window n+5 (755)) causes the sampling to go into a power saving mode, for example and principles ( including those discussed later herein).

Elektrische Eigenschaften der physikalischen PHY können eine oder mehrere aus einseitiger Signalübertragung, weitergeleiteter Halbratentaktgebung, Abstimmung von Verbindungskanal sowie On-Chip-Transportverzögerung von Sender (Quelle) und Empfänger (Senke), optimiertem elektrostatischem Endladungs- (ESD-) Schutz, Kontaktstellenkapazität, und anderen Merkmalen, umfassen. Außerdem kann eine MCPL implementiert werden, um höhere Datenraten (z.B. nahe 16 Gb/s) und bessere Energieeffizienzeigenschaften als bei herkömmlichen Gehäuse-I/O-Lösungen zu erreichen.Electrical properties of the physical PHY can include one or more of unidirectional signaling, forwarded half-rate clocking, link channel tuning, as well as on-chip transport delay of transmitter (source) and receiver (sink), optimized electrostatic discharge (ESD) protection, pad capacitance, and others characteristics include. Additionally, an MCPL can be implemented to achieve higher data rates (e.g., close to 16 Gb/s) and better power efficiency characteristics than traditional packaged I/O solutions.

8 zeigt einen Teil eines vereinfachten Blockdiagramms 800, der einen Teil einer beispielhaften MCPL zeigt. Das Diagramm 800 aus 8 umfasst eine Darstellung einer beispielhaften Bahn 805 (z.B. einer Datenbahn, gültigen Bahn oder Datenstrombahn) und Takterzeugungslogik 810. Wie im Beispiel aus 8 gezeigt kann in einigen Implementierungen Takterzeugungslogik 810 als Taktbaum implementiert sein, um ein erzeugtes Taktsignal zu jedem Block zu senden, welche die einzelnen Bahnen in der beispielhaften MCPL implementieren, wie z.B. Datenbahn 805. Ferner kann eine Taktrücksetzschaltung 815 bereitgestellt sein. In einigen Implementierungen wird keine separate Taktrücksetzschaltung für jede Bahn bereitgestellt, in der das Taktsignal bereitgestellt wird, da herkömmlicherweise in zumindest einigen traditionellen Verbindungs-I/O-Architekturen eine einzelne Taktrücksetzschaltung für ein Bündel aus einer Vielzahl von Bahnen bereitgestellt werden kann. In der Tat können, wie in den beispielhaften Konfigurationen in 6 und 7, eine separate Abtastbahn und eine begleitende Taktrücksetzschaltung für jedes Bündel aus fünfundzwanzig Datenbahnen bereitgestellt werden. 8th 8 shows a portion of a simplified block diagram 800 showing a portion of an example MCPL. The chart 800 off 8th includes an illustration of an example trajectory 805 (eg, a data trajectory, valid trajectory, or data stream trajectory) and clock generation logic 810. As in the example of FIG 8th As shown, in some implementations, clock generation logic 810 may be implemented as a clock tree to send a generated clock signal to each block that implements each lane in the example MCPL, such as data lane 805. Clock reset circuitry 815 may also be provided. In some implementations, a separate clock reset circuit is not provided for each lane in which the clock signal is provided, as conventionally in at least some traditional interconnect I/O architectures a single clock reset circuit may be provided for a bundle of multiple lanes. In fact, as in the exemplary configurations in 6 and 7 , a separate scan lane and accompanying clock reset circuitry are provided for each burst of twenty-five data lanes.

Mit dem Beispiel aus 8 fortsetzend können in einigen Implementierungen zumindest die Datenbahnen, Datenstrombahnen und gültigen Bahnen in der Mitte der Bahn auf eine regulierte Spannung über null (Masse) terminiert werden. In einigen Implementierungen kann eine Mittelschienenspannung auf Vcc/2 geregelt werden. In einigen Implementierungen kann ein einzelner Spannungsregler 825 pro Bündel von Bahnen bereitgestellt sein. Bei Anwendung auf die Beispiele aus 6 und 7 kann beispielsweise ein erster Spannungsregler für ein erstes Bündel aus fünfundzwanzig Datenbahnen und ein zweiter Spannungsregler für das restliche Bündel aus fünfundzwanzig Datenbahnen bereitgestellt sein, um eines von möglichen Beispielen zu nennen. In einigen Beispielen kann ein beispielhafter Spannungsregler 825 als linearer Regler, geschaltete Kondensatorschaltung, um einige Beispiele zu nennen, implementiert sein. In einigen Implementierungen kann der lineare Regler mit einer analogen Rückkopplungsschleife oder einer digitalen Rückkopplungsschleife versehen sein, um einige Beispiele zu nennen.With the example out 8th furthermore, in some implementations, at least the data lanes, data stream lanes, and mid-lane valid lanes may be terminated to a regulated voltage above zero (ground). In some implementations, a mid-rail voltage can be regulated to Vcc/2. In some implementations, a single voltage regulator 825 may be provided per bundle of traces. When applied to the examples below 6 and 7 For example, a first voltage regulator may be provided for a first bundle of twenty-five data lanes and a second voltage regulator for the remaining bundle of twenty-five data lanes, to cite one of possible examples. In some examples, an example voltage regulator 825 may be implemented as a linear regulator, switched capacitor circuit, to name a few examples. In some implementations, the linear regulator can be provided with an analog feedback loop or a digital feedback loop, to name a few examples.

In einigen Implementierungen kann auch eine Übersprechunterdrückungsschaltung für eine beispielhafte MCPL bereitgestellt sein. In einigen Fällen kann die kompakte Art der langen MCPL-Drähte Übersprechstörungen zwischen Bahnen einbringen. Übersprechunterdrückungslogik kann implementiert sein, um diese und andere Probleme anzusprechen. Beispielsweise kann in einem Beispiel, das in 9-10 dargestellt ist, Übersprechen mit einer beispielhaften aktiven Niedrigenergieschaltung, wie z.B. in den Diagrammen 900 und 1000 dargestellt, signifikant reduziert werden. Im Beispiel aus 9 kann beispielsweise ein gewichtetes hochpassgefiltertes „Aggressor“-Signal zum „Opfer“-Signal (d.h. das Signal, das von Übersprechstörungen vom Aggressor leidet) hinzugefügt werden. Jedes Signal kann als Opfer von Übersprechen durch ein beliebiges anderes Signal in der Verbindung betrachtet werden und kann selbst der Aggressor für das andere Signal sein, solange es die Quelle der Übersprechstörung ist. Solch ein Signal kann erzeugt werden und Übersprechen auf der Opferbahn um mehr als 50 % reduzieren, und zwar dank der derivativen Art des Übersprechens auf der Verbindung. Das tiefpassgefilterte Aggressorsignal im Beispiel aus 9 kann durch einen Hochpass-RC-Filter erzeugt werden (z.B. durch C und R1 implementiert), der das gefilterte Signal erzeugt, das unter Verwendung einer Summierschaltung 905 (z.B. RX-Sense-amp) hinzugefügt wird.In some implementations, crosstalk suppression circuitry may also be provided for an example MCPL. In some cases, the compact nature of long MCPL wires can introduce crosstalk interference between traces. Crosstalk cancellation logic can be implemented to address these and other issues. For example, in an example given in 9-10 1, crosstalk can be significantly reduced with an exemplary low-power active circuit, such as illustrated in plots 900 and 1000. FIG. In the example off 9 For example, a weighted high-pass filtered "aggressor" signal can be added to the "victim" signal (ie the signal suffering from crosstalk interference from the aggressor). Any signal can be considered a victim of crosstalk by any other signal in the link and can itself be the aggressor of the other signal as long as it is the source of the crosstalk interference. Such a signal can be generated and reduce crosstalk on the victim lane by more than 50% thanks to the derivative nature of crosstalk on the link. The low-pass filtered aggressor signal in the example 9 can be generated by a high pass RC filter (e.g. implemented by C and R1) which produces the filtered signal which is added using a summing circuit 905 (e.g. RX sense amp).

Ähnliche Implementierungen wie im Beispiel aus 9 beschrieben können besonders praktische Lösungen für eine Anwendung wie MCLP darstellen, da eine Implementierung der Schaltung mit relativ geringem zusätzlichem Platzbedarf erzeugt werden kann, wie im Diagramm aus 10 dargestellt ist, das ein beispielhaftes Schema auf Transistorebene der im Beispiel aus 9 dargestellten und beschriebenen Schaltung zeigt. Es gilt anzumerken, dass die Darstellungen in 9 und 10 vereinfachte Darstellungen sind, und dass eine tatsächliche Implementierung mehrere Kopien der in 9 und 10 dargestellten Schaltungen umfassen würde, um das Netzwerk von Übersprechstörungen unter und zwischen den Bahnen einer Verbindung unterzubringen. Als Beispiel könnte in einer Dreibahnverbindung (z.B. Bahnen 0-2) eine ähnliche Schaltung wie die in den Beispielen aus 9 und 10 bereitgestellt sein, von Bahn 0 bis Bahn 1, von Bahn 0 bis Bahn 2, von Bahn 1 bis Bahn 0, von Bahn 1 bis Bahn 2, von Bahn 2 bis Bahn 0, von Bahn 2 bis Bahn 1 usw., bezogen auf die Geometrie und die Auslegung der Bahnen, um ein Beispiel zu nennen.Similar implementations as in the example below 9 can represent particularly practical solutions for an application such as MCLP, since an implementation of the circuit can be produced with relatively little additional space, as shown in the diagram 10 is shown, which is an example schematic at the transistor level of the example 9 shown and described circuit shows. It should be noted that the illustrations in 9 and 10 are simplified representations, and that an actual implementation is multiple copies of the in 9 and 10 circuits shown would include to accommodate the network of cross-talk interference under and between lanes of a link. As an example, in a three-lane connection (e.g. lanes 0-2) a circuit similar to that in the examples could be made out 9 and 10 be provided, from lane 0 to lane 1, from lane 0 to lane 2, from lane 1 to lane 0, from lane 1 to lane 2, from lane 2 to lane 0, from lane 2 to lane 1, etc., based on the Geometry and layout of the tracks, to name an example.

Weitere Merkmale können auf der physikalischen PHY-Ebene einer beispielhaften MCPL implementiert sein. Beispielsweise kann eine Empfängerabweichung einen signifikanten Fehler einführen und I/O-Spannungsgrenzen in manchen Fällen begrenzen. Schaltungsredundanz kann verwendet werden, um Empfängerempfindlichkeit zu verbessern. In einigen Implementierungen kann Schaltungsredundanz optimiert werden, um die Standardabweichung von Datensamplern anzusprechen, die in der MCPL verwendet werden. Beispielsweise kann ein beispielhafter Datensampler bereitgestellt sein, der mit einer drei (3) Snandardabweichungsspezifikation ausgelegt ist. In den Beispielen aus 6 und 7 wurden beispielsweise zwei (2) Datensampler für jeden Empfänger verwendet (z.B. für jede Bahn), einhundert (100) Sampler würden für eine MCPL mit fünfzig (50) Bahnen verwendet. In diesem Beispiel ist die Wahrscheinlichkeit, dass eine der Empfänger- (RX-) bahnen nicht der Dreistandardabweichungsspezifikation entspricht, 24 %. Ein Chipbezugsspannungsgenerator kann bereitgestellt werden, um die Abweichungsobergrenze festzusetzen und zum nächsten Datensampler am Empfänger weiterzugehen, wenn bestimmt wird, dass ein weiterer Datensampler die Grenze überschreitet. Wenn jedoch vier (4) Datensampler pro Empfänger verwendet werden (d.h. anstelle von zwei in diesem Beispiel), versagt der Empfänger nicht nur, wenn drei von vier Samplern versagen. Bei einer Fünfzigbahn-MCPL, wie in den Beispiele aus 6 und 7, kann das Hinzufügen dieser zusätzlichen Schaltungsredundanz die Versagerate deutlich 24 % auf weniger als 0,01 % verringern.Other features may be implemented at the physical PHY level of an example MCPL. For example, receiver drift can introduce significant error and limit I/O voltage limits in some cases. Circuit redundancy can be used to improve receiver sensitivity. In some implementations, circuit redundancy can be optimized to address the standard deviation of data samplers used in the MCPL. For example, an example data sampler designed with a three (3) standard deviation specification may be provided. In the examples from 6 and 7 for example, if two (2) data samplers were used for each receiver (eg, for each lane), one hundred (100) samplers would be used for a fifty (50) lane MCPL. In this example, the probability that one of the receiver (RX) traces does not meet the three standard deviation specification is 24%. A chip reference voltage generator may be provided to set the deviation upper limit and proceed to the next data sampler at the receiver when another data sampler is determined to exceed the limit. However, if four (4) data samplers are used per receiver (ie, instead of two in this example), the receiver will fail only if three out of four samplers fail. For a fifty-lane MCPL, as in the examples below 6 and 7 , adding this additional circuit redundancy can significantly reduce the failure rate by 24% to less than 0.01%.

In weiteren Beispielen kann bei sehr hohen Datenraten pro Bit-Arbeitszykluskorrektur (DCC) und Entfernung der Laufzeitverschiebung verwendet werden, um die Basislinie pro Bündel-DCC zu erhöhen und Entfernung der Laufzeitverschiebung, um den Verbindungsabstand zu verbessern. Anstatt in allen Fällen zu korrigieren, wie bei herkömmlichen Lösungen, kann in einigen Implementierungen eine Niedrigenergie-Digitalimplementierung eingesetzt werden, welche die Ausreißer abfühlt und korrigiert, wo die I/O-Bahn versagen würde. Beispielsweise kann ein globales Abstimmen der Bahnen durchgeführt werden, um Problembahnen innerhalb der Bündel zu identifizieren. Auf diese Problembahnen kann dann für Pro-Bahn-Abstimmung abgezielt werden, um die hohen Datenraten zu erreichen, die von der MCPL unterstützt werden.In other examples, at very high data rates, per bit duty cycle correction (DCC) and skew removal can be used to increase baseline per burst DCC and skew removal to improve link spacing. Instead of correcting in all cases, as in conventional solutions, in some implementations a low-power Digital implementation can be used that senses and corrects the outliers where the I/O trace would fail. For example, global lane matching can be performed to identify problem lanes within clusters. These problem lanes can then be targeted for per-lane tuning to achieve the high data rates supported by the MCPL.

Weitere Merkmale können ebenfalls gegebenenfalls in einigen Beispielen einer MCPL implementiert werden, um die Leistungsmerkmale der physikalischen Verbindung zu verbessern. Beispielsweise kann Zeilenkodierung bereitgestellt werden. Während Mittelbahnterminationen, wie oben beschrieben, das Auslassen einer DC-Datenbusinversion (DBI) ermöglichen können, kann AC-DBI immer noch verwendet werden, um die dynamische Leistung zu reduzieren. Kompliziertere Kodierung kann auch verwendet werden, um den ungünstigsten Fall einer Abweichung von 1's und 0's zu eliminieren, um beispielsweise die Ansteuerungsanforderung eines Mittelbahnreglers zu reduzieren sowie I/O-Schaltgeräusche zu begrenzen, um einige vorteilhafte Beispiele zu nennen. Ferner kann Senderausgleich auch gegebenenfalls implementiert werden. Beispielsweise kann bei sehr hohen Datenraten ein Einfügungsverlust bei einem Kanal innerhalb des Gehäuses signifikant sein. Unter anderem kann ein Zweiabgriffsgewichtungssenderausgleich (z.B. während einer anfänglichen Einschaltsequenz) kann in manchen Fällen ausreichen, um einige dieser Problem zu lindern.Other features may also be optionally implemented in some instances of an MCPL to enhance physical link performance. For example, row encoding can be provided. While center lane terminations, as described above, may allow DC data bus inversion (DBI) to be skipped, AC-DBI can still be used to reduce dynamic power. More complicated coding can also be used to eliminate the worst-case mismatch of 1's and 0's, for example to reduce the drive requirement of a center lane regulator, as well as to limit I/O switching noise, to name a few beneficial examples. Furthermore, sender equalization can also be implemented if necessary. For example, at very high data rates, insertion loss in a channel within the package can be significant. Among other things, two-tap weight transmitter equalization (e.g., during an initial power-up sequence) may be sufficient in some cases to alleviate some of these problems.

Auf 11 Bezug nehmend wird ein vereinfachtes Blockdiagramm 1100 dargestellt, das eine beispielhafte Logik-PHY einer beispielhaften MCPL zeigt. Eine physikalische PHY 1105 kann mit einem Nacktchip verbunden werden, der Logik-PHY 1110 und weitere Logik umfasst, die eine Verbindungsschicht der MCPL unterstützt. Der Nacktchip kann in diesem Beispiel ferner Logik zur Unterstützung mehrerer unterschiedlicher Protokolle auf der MCPL umfassen. Im Beispiel aus 11 kann beispielsweise PCIe-Logik 1115 bereitgestellt sein, sowie IDI-Logik 1120, sodass die Nacktchips entweder unter Verwendung von PCIe oder IDI über die gleiche MCPL kommunizieren können, welche die beiden Nacktchips verbindet, um eines von vielen möglichen Beispielen zu nennen, einschließlich Beispielen, bei denen mehr als zwei Protokolle oder andere Protokolle als PCIe und IDI auf der MCPL unterstützt werden. Verschiedene Protokolle, die zwischen den Nacktchips unterstützt werden, können unterschiedliche Grade an Diensten und Funktionen bieten.On 11 Referring now to FIG. 1, a simplified block diagram 1100 showing an example logic PHY of an example MCPL is presented. A physical PHY 1105 can be connected to a die that includes logic PHY 1110 and other logic that supports a link layer of the MCPL. The die in this example may also include logic to support multiple different protocols on the MCPL. In the example off 11 For example, PCIe logic 1115 may be provided, as well as IDI logic 1120, so that the dies can communicate using either PCIe or IDI over the same MCPL connecting the two dies, to cite one of many possible examples, including examples where more than two protocols or protocols other than PCIe and IDI are supported on the MCPL. Different protocols supported between dies can provide different levels of service and functionality.

Logik-PHY 1110 kann eine Verbindungszustandsmaschinenverwaltungslogik 1125 zur automatischen Einstellung von Verbindungszustandsübergängen in Verbindung mit Anfrage einer übergenordneten Logik des Nacktchips (z.B. über PCIe oder IDI empfangen) zu umfassen. Logik-PHY 1110 kann ferner eine Verbindungstest- und Fehlerbehebungslogik (z.B. 1130) in einigen Implementierungen umfassen. Wie oben angemerkt kann eine beispielhafte MCPL Steuersignale unterstützen, die zwischen Nacktchips über die MCPL gesendet werden, um protokollunabhängige Hochleistungs- und Energieeffizienzfunktionen (unter andere beispielhaften Funktionen) der MCPL bereitzustellen. Beispielsweise kann Logik-PHY 1110 Erzeugen und Senden sowie Empfangen und Verarbeitung von gültigen Signalen, Datenstromsignalen und LSM-Seitenbandsignalen in Verbindung mit dem Senden und Empfangen von Daten über dedizierte Datenbahnen unterstützen, wie in den obigen Beispielen beschrieben ist.Logic PHY 1110 may include link state machine management logic 1125 for automatically adjusting link state transitions in conjunction with requests from higher-level logic of the die (e.g., received via PCIe or IDI). Logic PHY 1110 may further include connection test and debug logic (e.g., 1130) in some implementations. As noted above, an example MCPL may support control signals sent between dies over the MCPL to provide protocol independent high performance and power efficiency features (among other example features) of the MCPL. For example, logic PHY 1110 may support generation and transmission, and reception and processing of valid signals, data stream signals, and LSM sideband signals in conjunction with the transmission and reception of data over dedicated data lanes, as described in the examples above.

In einigen Implementierungen kann eine Multiplexier- (z.B. 1135) und Demultiplexier- (z.B. 1140) logik in Logik-PHY 1110 enthalten sein oder auf andere Weise für diese zugänglich sein. Beispielsweise kann eine Multiplexierlogik (z.B. 1135) verwendet werden, um Daten (z.B. als Pakete, Nachrichten usw. ausgeführt) zu identifizieren, auf die MCPL hinaus gesendet werden sollen. Die Multiplexierlogik 1135 kann das Protokoll identifizieren, das die Daten verwaltet, und ein Datenstromsignal erzeugen, das kodiert ist, um das Protokoll zu identifizieren. Beispielsweise kann in einer beispielhaften Implementierung das Datenstromsignal als Byte aus zwei Hexadezimalsymbolen kodiert sein (z.B. IDI: FFh; PCIe: F0h; LLP: AAh; Seitenband: 55h; usw.) und kann während desselben Fensters (z.B. ein Byte-Zeitdauerfenster) der Daten gesendet werden, die vom identifizierte Protokoll verwaltet werden. Auf ähnliche Weise kann Demultiplexierlogik 1140 eingesetzt werden, um ankommende Datenstromsignale zu interpretieren, um das Datenstromsignal zu dekodieren und das Protokoll zu identifizieren, das auf die Daten anzuwenden ist, die gleichzeitig mit dem Datenstromsignal auf den Datenbahnen empfangen werden. Die Demultiplexierlogik 1140 kann dann protokollspezifische Verbindungsschichtabwicklung anwenden (oder sicherstellen) und dazu führen, dass die Daten von der entsprechenden Protokolllogik abgewickelt werden (z.B. PCIe-Logik 1115 oder IDI-Logik 1120).In some implementations, multiplexing (e.g., 1135) and demultiplexing (e.g., 1140) logic may be included in or otherwise accessible to logic PHY 1110. For example, multiplexing logic (e.g., 1135) may be used to identify data (e.g., embodied as packets, messages, etc.) on which to send MCPLs. The multiplexing logic 1135 can identify the protocol that manages the data and generate a data stream signal that is encoded to identify the protocol. For example, in an example implementation, the data stream signal may be encoded as a byte of two hexadecimal symbols (e.g., IDI: FFh; PCIe: F0h; LLP: AAh; Sideband: 55h; etc.) and may occur during the same window (e.g., a byte-time window) of the data are sent managed by the identified protocol. Similarly, demultiplexing logic 1140 may be employed to interpret incoming data stream signals to decode the data stream signal and identify the protocol to be applied to data received on the data lanes concurrently with the data stream signal. The demultiplexing logic 1140 can then apply (or ensure) protocol-specific link layer handling and cause the data to be handled by the appropriate protocol logic (e.g., PCIe logic 1115 or IDI logic 1120).

Logik-PHY 1110 kann ferner Verbindungsschichtpaketlogik 1150 umfassen, die verwendet werden kann, um verschiedene Verbindungssteuerfunktionen handzuhaben, einschließlich Leistungsverwaltungsaufgaben, Schleifenbetrieb, Deaktivierung, Neuzentrierung, Verwürflung usw. LLP-Logik 1150 kann, neben anderen Funktionen, Verbindungsschicht-zu-Verbindungsschicht-Nachrichten über MCLP ermöglichen. Daten, die der LLP-Signalübertragung entsprechen, können auch durch ein Datenstromsignal identifiziert werden, das auf einer dedizierten Datenstromsignalbahn gesendet wird und das kodiert ist, um die Datenbahn-LLP-Daten zu identifizieren. Multiplexier- und Demultiplexierlogik (z.B. 1135, 1140) kann auch verwendet werden, um die Datenstromsignale zu erzeugen und zu interpretieren, die LLP-Verkehr entsprechen, sowie um dazu zu führen, dass solcher Verkehr von der entsprechenden Nacktchiplogik (z.B. LLP-Logik 1150) abgewickelt wird. Auf ähnliche Weise kann bei einigen Implementierungen eine MCLP ein dediziertes Seitenband (z.B. Seitenband 1155 und unterstützende Logik) umfassen, z.B. einen asynchronen und/oder Niederfrequenz-Seitenbandkanal, um ein Beispiel zu nennen.Logic PHY 1110 may further include link-layer packet logic 1150, which may be used to handle various link control functions, including power management tasks, looping, deactivation, re-centering, scrambling, etc. LLP logic 1150 may, among other functions, transmit link-layer-to-link-layer messages over Enable MCLP. Data corresponding to LLP signaling can also be identified by a data stream signal sent on a dedicated data stream signal path and encoded to identify the data path LLP data. Multiplexing and demultiplexing logic (e.g. 1135, 1140) may also be used to generate and interpret the data stream signals corresponding to LLP traffic and to cause such traffic to be routed by the corresponding bare chip logic (e.g. LLP logic 1150) is processed. Similarly, in some implementations, an MCLP may include a dedicated sideband (eg, sideband 1155 and supporting logic), eg, an asynchronous and/or low-frequency sideband channel, to cite an example.

Logische PHY-Logik 1110 kann ferner Verbindungszustandsmaschinenverwaltungslogik umfassen, die Verbindungszustandsverwaltungsnachrichtenübertragung über eine dedizierte LSM-Seitenbandbahn erzeugen (und verwenden) kann. Beispielsweise kann eine LSM-Seitenbandbahn verwendet werden, um eine Abstimmung durchzuführen und den Verbindungsübungszustand zu beschleunigen, aus den Leistungsverwaltungszuständen (z.B. einem L1-Zustand) auszutreten, um einige von möglichen Beispielen zu nennen. Das LSM-Seitenbandsignal kann ein asynchrones Signal sein, in dem Sinne, dass es nicht mit den Daten, gültigen und Datenstromsignalen der Verbindung abgeglichen ist, sondern stattdessen Signalübertragungszustandsübergängen entspricht und die Verbindungszustandsmaschine zwischen zwei Nacktchips oder Chips, die durch die Verbindung verbunden sind, abgleicht, um ein Beispiel zu nennen. Bereitstellen einer dedizierten LSM-Seitenbandbahn kann in manchen Fällen ermöglichen, dass eine vorübergehende Rauschsperre und empfangene Feststellungsschaltungen eines analogen Front-Ends (AFE) eliminiert werden, um einige vorteilhafte Beispiele zu nennen.Logical PHY logic 1110 may further include link state machine management logic that may generate (and use) link state management messaging over a dedicated LSM sideband lane. For example, an LSM sideband trace can be used to perform tuning and speed up the link training state, exiting power management states (e.g., an L1 state), to name a few possible examples. The LSM sideband signal may be an asynchronous signal in the sense that it is not aligned with the link's data, valid, and stream signals, but instead corresponds to signaling state transitions and aligns the link state machine between two dies or chips connected by the link , to give an example. Providing a dedicated LSM sideband trace can in some cases allow transient squelch and received detection circuits of an analog front end (AFE) to be eliminated, to cite a few beneficial examples.

Auf 12 Bezug nehmen ist ein vereinfachtes Blockdiagramm 1200 dargestellt, das eine weitere Darstellung von Logik zeigt, die zur Implementierung einer MCPL verwendet wird. Beispielsweise wird Logik-PHY 1110 mit einer definierten Logik-PHY-Schnittstelle (LPIF) 1205 bereitgestellt, durch die jedes beliebige einer Vielzahl von unterschiedlichen Protokollen (z.B. PCIe, IDI, QPI, etc.) 1210, 1215, 1220, 1225 und Signalübertragungsmodi (z.B. Seitenband) eine Schnittstelle mit der physikalischen Schicht einer beispielhaften MCPL darstellen kann. In einigen Implementierungen kann Multiplexier- und Arbitrierlogik 1230 auch als von Logik-PHY 1110 separate Schicht bereitgestellt werden. In einem Beispiel kann LPIF 1205 als Schnittstelle auf einer beliebigen Seite dieser MuxArb-Schicht 1230 bereitgestellt werden. Die Logik-PHY 1110 kann eine Schnittstelle mit der physikalischen PHY (z.B. dem analogen Front-End (AFE) 1105 der MCPL PHY) durch eine weitere Schnittstelle darstellen.On 12 Referring now to FIG. 1, a simplified block diagram 1200 is shown showing another representation of logic used to implement an MCPL. For example, logical PHY 1110 is provided with a defined logical PHY interface (LPIF) 1205 through which any of a variety of different protocols (e.g., PCIe, IDI, QPI, etc.) 1210, 1215, 1220, 1225 and signaling modes ( eg sideband) can interface with the physical layer of an exemplary MCPL. Multiplexing and arbitration logic 1230 may also be provided as a separate layer from logic PHY 1110 in some implementations. In one example, LPIF 1205 may be provided as an interface on either side of this MuxArb 1230 layer. The logic PHY 1110 may interface with the physical PHY (eg, the analog front end (AFE) 1105 of the MCPL PHY) through another interface.

Die LPIF kann die PHY (logisch und elektrisch/analog) von den oberen Schichten (z.B. 1210, 1215, 1220, 1225) abstrahieren, sodass eine komplett andere PHY unter LPIF implementiert werden kann, für die oberen Schichten transparent ist. Dies kann die Förderung von Modularität und Wiederverwendung in Design unterstützen, da die oberen Schichten intakt bleiben können, wenn darunterliegende Signalübertragungstechnologie-PHY aktualisiert wird, um ein Beispiel zu nennen. Ferner kann die LPIF eine Reihe von Signalen definieren, die Multiplexieren/Demultiplexieren, LSM-Verwaltung, Fehlererkennung und -behebung und andere Funktionalitäten der Logik-PHY ermöglichen. Beispielsweise ist in Table 1 zumindest ein Teil von Signalen zusammengefasst, die für eine beispielhafte LPIF definiert werden können: TABELLE 1: Signalname Beschreibung Rst Rückstellung Lclk Verbindungstaktgeber - 8UI von PHY-Verbindungstaktgeber Pl_trdy Die physikalische Schicht ist bereit, Daten anzunehmen, Daten werden von der physikalischen Schicht angenommen, wenn Pl_trdy und Lp_valid beide zugesichert sind. Pl_data[N-1:0][7:0] Physikalische Schicht-zu-Verbindungsschicht-Daten, wobei N gleich der Anzahl an Bahnen ist. Pl_valid Physikalische Schicht-zu-Verbindungsschicht-Signal, das Datengültigkeit anzeigt Pl_Stream[7:0] Physikalische Schicht-zu-Verbindungsschicht-Signal, das die Datenstrom-ID anzeigt, die mit den Daten empfangen wurde Pl_error Physikalische Schicht stellte einen Fehler fest (z.B. Rahmensynchronisation oder Training) Pl_AlignReq Physikalische Schicht fordert die Verbindungsschicht auf, Pakete mit der LPIF-Breitengrenze abzugleichen Pl_in_L0 Zeigt an, dass die Verbindungszustandsmaschine (LSM) in L0 ist Pl_in_retrain Zeigt an, dass LSM in Retrain/Rückstellung ist Pl_rejectL1 Zeigt an, dass die PHY-Schicht Eintritt in L1 abgewiesen hat Pl_in_L12 Zeigt an, dass LSM in L1 oder L2 ist Pl_LSM (3:0) Aktuelle LSM-Zustandsinformationen Lp_data[N-1:0][7:0] Verbindungsschicht-zu-physikalische-Schicht-Daten, wobei N gleich der Anzahl an Bahnen ist Lp_Stream[7:0] Verbindungsschicht-zu-physikalische-Schicht-Signal, das die Datenstrom-ID anzeigt, die mit Daten zu verwenden ist Lp_AlignAck Verbindungsschicht-zu-physikalische-Schicht zeigt an, dass die Pakete mit der LPIF-Breitengrenze abgeglichen sind Lp_valid Verbindungsschicht-zu-physikalische-Schicht-Signal, das Datengültigkeit anzeigt Lp_ enterL 1 Verbindungsschichtanfrage an physikalische Schicht, in L1 einzutreten Lp_enterL2 Verbindungsschichtanfrage an physikalische Schicht, in L2 einzutreten Lp_Retrain Verbindungsschichtanfrage an physikalische Schicht, die PHY einem Retrain zu unterziehen Lp_ exitL 12 Verbindungsschichtanfrage an physikalische Schicht, aus L1, L2 auszutreten Lp_Disable Verbindungsschichtanfrage an physikalische Schicht, PHY zu deaktivieren The LPIF can abstract the PHY (logical and electrical/analog) from the upper layers (eg 1210, 1215, 1220, 1225) so that a completely different PHY can be implemented under LPIF, transparent to the upper layers. This can help encourage modularity and reuse in design, as the upper layers can remain intact when underlying signaling technology PHY is updated, for example. Further, the LPIF may define a set of signals that enable multiplexing/demultiplexing, LSM management, error detection and recovery, and other logic PHY functionalities. For example, Table 1 summarizes at least some of the signals that can be defined for an example LPIF: TABLE 1: signal name Description Rst provision lclk Link Clock - 8UI of PHY link clock Pl_trdy The physical layer is ready to accept data, data is accepted from the physical layer when Pl_trdy and Lp_valid are both asserted. Pl_data[N-1:0][7:0] Physical layer-to-link layer data, where N equals the number of lanes. Pl_valid Physical layer-to-link layer signal indicating data validity Pl_Stream[7:0] Physical layer-to-link layer signal indicating the data stream ID received with the data Pl_error Physical layer encountered an error (e.g. frame synchronization or training) Pl_AlignReq Physical layer asks link layer to match packets with LPIF width limit Pl_in_L0 Indicates that the link state machine (LSM) is in L0 Pl_in_retrain Indicates that LSM is in retrain Pl_rejectL1 Indicates that the PHY layer rejected entry into L1 Pl_in_L12 Indicates that LSM is in L1 or L2 Pl_LSM (3:0) Current LSM status information lp_data[N-1:0][7:0] Link layer to physical layer data, where N equals the number of lanes lp_Stream[7:0] Link layer to physical layer signal indicating data stream ID to be used with data Lp_AlignAck Link layer-to-physical layer indicates that the packets are matched to the LPIF width limit lp_valid Link layer to physical layer signal indicating data validity Lp_enterL 1 Link layer request to physical layer to enter L1 lp_enterL2 Link layer request to physical layer to enter L2 Lp_Retrain Link layer request to physical layer to retrain the PHY Lp_exitL 12 Link layer request to physical layer to exit L1, L2 lp_disable Link layer request to physical layer to disable PHY

Wie in Tabelle 1 zu sehen kann in einigen Implementierungen ein Abgleichungsmechanismus durch einen AlignReq/AlignAck-Handshake bereitgestellt werden. Wenn beispielsweise die physikalische Schicht in Rücksetzung eintritt, können einige Protokolle die Paketrahmensynchronisation verlieren. Abgleichen der Pakete kann korrigiert werden, beispielsweise um korrekte Rahmensynchronisationsidentifikation durch die Verbindungsschicht sicherzustellen. Außerdem kann, wie in 13 dargestellt, die physikalische Schicht ein StallReq-Signal zusichern, wenn es in Rücksetzung eintritt, sodass die Verbindungsschicht ein Stall-Signal zusichert, wenn ein neues abgeglichenes Paket bereit zur Übertragung ist. Die Logik der physikalischen Schicht kann sowohl Stall als auch Valid abtasten, um zu bestimmen, ob das Paket abgeglichen ist. Beispielsweise kann die physikalische Schicht fortsetzen, trdy anzusteuern, um die Verbindungsschichtpakete abzuleiten, bis Stall und Valid als zugesichert abgetastet werden, um eine von möglichen Implementierungen zu nennen, einschließlich anderer alternativer Implementierungen unter Verwendung von Valid, um die Paketabgleichung zu unterstützen.As seen in Table 1, in some implementations an alignment mechanism can be provided by an AlignReq/AlignAck handshake. For example, when the physical layer goes into reset, some protocols may lose packet frame synchronization. Matching of the packets can be corrected, for example to ensure correct frame synchronization identification by the link layer. In addition, as in 13 As shown, the physical layer asserts a StallReq signal when it enters reset, so the link layer asserts a stall signal when a new matched packet is ready for transmission. The physical layer logic can sample both Stall and Valid to determine if the packet is matched. For example, the physical layer may continue to drive trdy to derive the link layer packets until Stall and Valid are sampled as committed, to name one of possible implementations, including other alternative implementations using Valid to aid in packet matching.

Verschiedene Fehlertoleranzen können für Signale auf der MCPL definiert werden. Beispielsweise können Fehlertoleranzen für gültige, Datenstrom-, LSM-Seitenband-, Niedrigfrequenzweitenband-, Verbindungsschichtpakete- und andere Arten von Signale definiert werden. Fehlertoleranzen für Pakete, Nachrichten und andere Daten, die über die dedizierten Datenbahnen der MCPL gesendet werden, können auf dem jeweiligen Protokoll basieren, das die Daten verwaltet. In einigen Implementierungen können Fehlererkennungs- und -beseitigungsmechanismen bereitgestellt werden, wie z.B. zyklische Redundanzprüfung (CRC), Wiederholungspuffer, um einige mögliche Beispiele zu nennen. Als Beispiele kann für PCIe-Pakete, die über die MCPL gesendet werden, 32-Bit-CRC für PCIe-Transaktionsschichtpakete (TLPs) verwendet werden (mit garantierter Zustellung (z.B. durch einen Rückspielmechanismus)) und 16-Bit-CRC kann für PCIe-Verbindungsschichtpakete verwendet werden (deren Architektur verlustbehaftet ist (z.B. wo kein Rückspielen eingesetzt wird)). Ferner kann für PCIe Rahmensynchronisationtoken ein bestimmter Hamming-Abstand (z.B. Hamming-Abstand vier (4)) für den Tokenidentifikator definiert werden; Parität und 4-Bit-CRC können ebenfalls verwendet werden, um ein Beispiel zu nennen. Bei IDI-Paketen andererseits kann 16-Bit-CRC verwendet werden.Various error tolerances can be defined for signals on the MCPL. For example, error tolerances can be defined for valid, stream, LSM sideband, low frequency wideband, link layer packet, and other types of signals. Fault tolerance for packets, messages, and other data sent over the MCPL's dedicated data lanes may be based on the particular protocol managing the data. In some implementations, error detection and recovery mechanisms may be provided, such as cyclic redundancy check (CRC), retry buffers, to name a few possible examples. As examples, 32-bit CRC can be used for PCIe transaction layer packets (TLPs) for PCIe packets sent over the MCPL (with guaranteed delivery (e.g. through a replay mechanism)) and 16-bit CRC can be used for PCIe Link layer packets are used (whose architecture is lossy (e.g. where no playback is employed)). Furthermore, for PCIe frame synchronization tokens, a specific hamming distance (e.g., hamming distance four (4)) can be defined for the token identifier; Parity and 4-bit CRC can also be used, to give an example. On the other hand, IDI packets can use 16-bit CRC.

In einigen Implementierungen können Fehlertoleranzen für Verbindungsschichtpakete (LLPs) definiert werden, die Anfordern eines gültigen Signals zum Übergang von niedrig zu hoch (d.h. 0 zu 1) umfassen (z.B. um Bit- und Symbolsperrung zu unterstützen) umfassen. Ferner kann in einem Beispiel eine bestimmte Anzahl an aufeinanderfolgenden, identischen LLPs definiert werden, die gesendet werden sollen, und Antworten auf jede Anfrage können erwartet werden, mit Neuversuchen durch den Anfrager nachdem die Antwortzeit abgelaufen ist, einschließlich anderer definierter Eigenschaften, die als Basis zur Bestimmung von Fehlern in LLP-Daten auf der MCPL verwendet werden können. In weiteren Beispielen kann eine Fehlertoleranz für ein gültiges Signal bereitgestellt werden, beispielsweise durch Erweitern des gültigen Signals über ein ganzes Zeitdauerfenster oder Symbol (z.B. durch Hochhalten des gültigen Signals länger als für acht UIs). Darüber hinaus können Fehler oder Störungen in Datenstromsignalen verhindert werden, indem ein Hamming-Abstand für Kodierwerte des Datenstromsignals eingehalten wird, um ein Beispiel zu nennen.In some implementations, fault tolerances may be defined for link layer packets (LLPs) that include requesting a valid signal to transition from low to high (ie, 0 to 1). (eg to support bit and symbol locking). Further, in one example, a specified number of consecutive, identical LLPs can be defined to be sent, and responses to each request can be expected, with retries by the requestor after the response time has expired, including other defined properties that serve as a basis for Determination of errors in LLP data on the MCPL can be used. In other examples, error tolerance may be provided for a valid signal, for example, by extending the valid signal across an entire time duration window or symbol (eg, by holding the valid signal high for more than eight UIs). Furthermore, errors or glitches in data stream signals can be prevented by maintaining a Hamming distance for encoding values of the data stream signal, for example.

Implementierungen einer Logik-PHY können Fehlerbestimmungs-, Fehlerberichterstattungs- und Fehlerbeseitigungslogik umfassen. In einigen Implementierungen kann eine Logik-PHY einer beispielhaften MCPL Logik zur Bestimmung von PHY-Schicht-Rahmensynchronisationsbeseitigungsfehlern (z.B. auf der gültigen und Datenstrombahn), Seitenbandfehler (z.B. in Bezug auf LSM-Zustandsübergänge), Fehler in LLPs (die z.B. entscheidend für LSM-Zustandsübergänge sind) umfassen, um einige Beispiele zu nennen. Manche Fehlerbestimmungen/-lösungen können zu einer Logik einer höheren Schicht delegiert werden, wie z.B. PCIe-Logik, die angepasst ist, um PCIe-spezifische Fehler zu bestimmen, um ein Beispiel zu nennen.Logic PHY implementations may include error determination, error reporting, and error recovery logic. In some implementations, logic PHY of an example MCPL may include logic to determine PHY layer frame synchronization failures (e.g., on the valid and data flow path), sideband failures (e.g., related to LSM state transitions), failures in LLPs (e.g., those critical to LSM state transitions are) to name a few examples. Some error determination/resolution may be delegated to higher layer logic, such as PCIe logic that is adapted to determine PCIe specific errors, for example.

Im Falle von Rahmensynchronisationsbeseitigungsfehlern können in einigen Implementierungen ein oder mehrere Mechanismen bereitgestellt werden, die durch Fehlerbeseitigungslogik bereitgestellt werden können. Rahmensynchronisationsbeseitigungsfehler können basierend auf den beteiligten Protokollen beseitigt werden. Beispielsweise können in einigen Implementierungen Verbindungsschichten über den Fehler informiert werden, um einen Neuversuch auszulösen. Rahmensynchronisationsbeseitigung kann auch eine Neuabgleichung der Logik-PHY-Rahmensynchronisationsbeseitigung auslösen. Ferner kann eine Neuzentrierung der Logik-PHY durchgeführt werden, und Symbol/Fenster-Sperrung kann erneut erworben werden, neben anderen Techniken. Zentrieren kann in einigen Beispielen umfassen, dass die PHY die Empfängertaktphase zum optimalen Punkt bewegt, um die ankommenden Daten festzustellen. „Optimal“ kann in diesem Zusammenhang bedeuten, wo sie den größten Raum für Rauschen und Taktjitter hat. Neuzentrierung kann vereinfachte Zentrierfunktionen umfassen, die beispielsweise durchgeführt werden, wenn die PHY von einem Niedrigenergiezustand aufwacht, um ein Beispiel zu nennen.In the case of frame synchronization debugging errors, one or more mechanisms that can be provided by debugging logic may be provided in some implementations. Frame synchronization elimination errors can be eliminated based on the protocols involved. For example, in some implementations, link layers may be informed of the failure to trigger a retry. Frame sync elimination may also trigger a logic PHY frame sync elimination realignment. Furthermore, logic PHY re-centering can be performed and symbol/window locking can be re-acquired, among other techniques. Centering may, in some examples, involve the PHY moving the receiver clock phase to the sweet spot to determine the incoming data. "Optimal" in this context can mean where it has the greatest room for noise and clock jitter. Re-centering may include simplified centering functions performed when the PHY wakes up from a low power state, for example.

Andere Arten von Fehlern können andere Fehlerbeseitigungstechniken umfassen. Beispielsweise können Fehler, die in einem Seitenband festgestellt werden, durch einen Zeitbegrenzungsemechanismus eines entsprechenden Zustands (z.B. einer LSM) abgefangen werden. Der Fehler kann geloggt werden, und die Verbindungszustandsmaschine kann dann in Rückstellung übergehen. Die LSM kann in Rückstellung bleiben, bis ein Neustartbefehl von einer Software empfangen wird. In einem weiteren Beispiel können LLP-Fehler, wie z.B. ein Verbindungssteuerungspaketfehler, mit einem Zeitbegrenzungsmechanismus abgewickelt werden, die die LLP-Sequenz neu starten kann, wenn keine Bestätigung der LLP-Sequenz erhalten wird.Other types of errors may involve other error recovery techniques. For example, errors detected in a sideband can be trapped by a timeout mechanism of an appropriate state (e.g. an LSM). The error can be logged and the connection state machine can then transition to reset. The LSM can remain in default until a restart command is received from software. In another example, LLP errors, such as a link control packet error, can be handled with a timeout mechanism that can restart the LLP sequence if no acknowledgment of the LLP sequence is received.

14A-14C zeigen Darstellungen von beispielhaften Bit-Kartierungen auf Datenbahnen einer beispielhaften MCPL für verschiedene Arten von Daten. Eine beispielhafte MCPL kann fünfzig Datenbahnen umfassen. 14A zeigt eine erste Bit-Kartierung aus beispielhaften 16-Byte-Slots in einem ersten Protokoll, wie z.B. IDI, di über die Datenbahnen innerhalb eines 8UI-Symbols oder eines Fensters gesendet werden kann. Innerhalb des definierten 8UI-Fensters können beispielsweise drei 16-Byte-Slots, einschließlich eines Kopf-Slots, gesendet werden. Zwei Byte von Daten verbleiben in diesem Beispiel, und die restlichen zwei Byte können als CRC-Bits verwendet werden (z.B. in Bahnen DATA[48] und DATA[49]). 14A-14C Figure 12 shows representations of example bit maps on data lanes of an example MCPL for various types of data. An example MCPL may include fifty data lanes. 14A FIG. 12 shows a first bit-mapping of example 16-byte slots in a first protocol, such as IDI, that can be sent over data lanes within an 8UI symbol or window. For example, three 16-byte slots, including a header slot, can be sent within the defined 8UI window. Two bytes of data remain in this example, and the remaining two bytes can be used as CRC bits (eg, in lanes DATA[48] and DATA[49]).

In einem weiteren Beispiel zeigt 14B eine zweite beispielhafte Bit-Kartierung für PCIe-Paketdaten, die über die fünfzig Datenbahnen einer beispielhaften MCPL gesendet werden. Im Beispiel aus 14B können 16-Byte-Pkakete (z.B. Transaktionsschicht- (TLP-) oder Datenverbindungsschicht- (DLLP-) PCIe-Pakete) über die MCPL gesendet werden. In einem 8UI-Fenster können drei Pakete gesendet werden, wobei die restlichen zwei Byte der Bandbreite in dem Fenster ungenutzt bleiben. Rahmensynchronisationstoken können in diesen Symbolen enthalten sein und verwendet werden, um den Beginn und das Ende jedes Pakets zu bestimmen. In einem Beispiel von PCIe kann die Rahmensynchronisation, die im Beispiel aus 14B verwendet wird, die gleiche sein wie die für PCIe bei 8 GT/s implementierten Token.In another example shows 14B Figure 12 shows a second example bit-mapping for PCIe packet data sent over the fifty data lanes of an example MCPL. In the example off 14B 16-byte packets (e.g. transaction layer (TLP) or data link layer (DLLP) PCIe packets) can be sent over the MCPL. Three packets can be sent in an 8UI window, leaving the remaining two bytes of bandwidth in the window unused. Frame synchronization tokens can be included in these symbols and used to determine the start and end of each packet. In an example of PCIe, the frame synchronization shown in the example 14B be the same as the tokens implemented for PCIe at 8 GT/s.

In einem weiteren Beispiel, das in 14C dargestellt ist, ist eine beispielhafte Bit-Kartierung von Verbindung-zu-Verbindung-Paketen (z.B. LLP-Paketen) dargestellt, die über eine beispielhafte MCPL gesendet werden. LLPs können jeweils 4 Byte große sein, und jede LLP (z.B. LLP0, LLP1, LLP2 usw.) kann vier aufeinanderfolgende Male gesendet werden, in Übereinstimmung mit Fehlertoleranz und Fehlerbestimmung innerhalb einer beispielhaften Implementierung. Beispielsweise kann ein Versagen, vier aufeinanderfolgende identische LLPs zu empfangen, einen Fehler anzeigen. Außerdem kann, bei anderen Datenarten, ein Versagen, ein VALID in einem Verarbeitungszeitfenster oder Symbol zu empfangen, auch einen Fehler anzeigen. In manchen Fällen können LLPs fixe Slots aufweisen. Außerdem können in diesem Beispiel ungenutzte, oder „Ersatz-“, Bits in der Byte-Zeitperiode dazu führen, dass logische 0en über zwei der fünfzig Bahnen übertragen werden (z.B. DATA[48-49]), um ein Beispiel zu nennen.In another example found in 14C 1, an example bit-map of connection-to-connection packets (eg, LLP packets) sent over an example MCPL is shown. LLPs can be 4 bytes each, and each LLP (eg, LLP0, LLP1, LLP2, etc.) can be four sent consecutive times consistent with fault tolerance and fault determination within an example implementation. For example, a failure to receive four consecutive identical LLPs may indicate an error. Additionally, with other data types, a failure to receive a VALID in a processing time slot or symbol may also indicate an error. In some cases, LLPs may have fixed slots. Also in this example, unused, or "spare," bits in the byte time period may result in logical 0s being transmitted across two of the fifty lanes (eg, DATA[48-49]), for example.

Auf 15 Bezug nehmend ist ein vereinfachtes Verbindungszustandsmaschinenübergangsdiagramm 1400 zusammen mit Seitenband-Handshake dargestellt, die zwischen den Zustandsübergängen verwendet wird. Beispielsweise kann ein Reset.Idle-Zustand (z.B. wenn eine Phasensperrschleifen- (PLL-) Sperrkalibrierung durchgeführt wird) durch einen Seitenband-Handshake zu einem Reset.Cal-Zustand (wo z.B. die Verbindung weiter kalibriert wird) übergehen. Reset.Cal kann durch einen Seitenband-Handshake, zu einem Reset.ClockDCC-Zustand übergehen (wo z.B. eine Arbeitszykluskorrektur (DCC) und verzögerungsgesperrte Schleifen- (DLL-) Sperre durchgeführt wird). Ein zusätzlicher Handshake kann durchgeführt werden, um von einem Reset.ClockDCC- zu einem Reset.Quiet-Zustand überzugehen (z.B. um die Zusicherung des Valid-Signals aufzuheben). Um die Abgleichung der Signalübertragung auf den Bahnen der MCPL zu unterstützen, können die Bahnen durch einen Center.Pattern-Zustand zentriert werden.On 15 Referring to this, a simplified connection state machine transition diagram 1400 is shown along with sideband handshaking used between the state transitions. For example, a Reset.Idle state (eg, when performing a phase lock loop (PLL) lock calibration) may transition to a Reset.Cal state (eg, where the link is further calibrated) through a sideband handshake. Reset.Cal can transition to a Reset.ClockDCC state (where eg duty cycle correction (DCC) and delay locked loop (DLL) locking is performed) through a sideband handshake. An additional handshake can be performed to transition from a Reset.ClockDCC to a Reset.Quiet state (eg, to deassert the Valid signal). To help align signal transmission on the lanes of the MCPL, the lanes can be centered by a Center.Pattern state.

In einigen Implementierungen kann, wie im Beispiel aus 16 dargestellt, während des Center.Pattern-Zustands der Sender Training-Muster oder andere Daten erzeugen. Der Empfänger kann seine Empfängerschaltung konditionieren, um solche Training-Muster zu empfangen, beispielsweise indem die Phaseninterpolatorposition und vref-Position eingestellt wird und der Komparator eingestellt wird. Der Empfänger kann kontinuierlich die empfangen Muster mit erwarteten Mustern vergleichen und das Ergebnis in einem Register speichern. Nachdem ein Satz von Mustern abgeschlossen ist, kann der Empfänger die Phaseninterpolatoreinstellung erhöhen und vref gleich lassen. Die Testmustererzeugung und der Vergleichsprozess können fortsetzen und neue Vergleichsergebnisse können im Register gespeichert werden, wobei das Verfahren wiederholt alle Phaseninterpolatorwerte und alle Werte für vref durchläuft. In den Center.Quiet-Zustand kann eingetreten werden, wenn der Mustererzeugungs- und Vergleichsvorgang abgeschlossen sind. Nach dem Zentrieren der Bahnen durch die Center.Pattern- und Center.Quiet-Verbindungszustände kann ein Seitenband-Handshake (z.B. unter Verwendung eines LSM-Seitenbandsignals auf der dedizierten LSM-Seitenbandbahn der Verbindung) ermöglicht werden, um in einen Link.Init-Zustand überzugehen, um die MCPL zu initialisieren und Senden von Daten auf der MCPL zu ermöglichen.In some implementations, as shown in the example 16 shown, during the Center.Pattern state the transmitters generate training patterns or other data. The receiver can condition its receiver circuitry to receive such training patterns, for example by adjusting the phase interpolator position and vref position and adjusting the comparator. The receiver can continuously compare the patterns received with expected patterns and store the result in a register. After a set of patterns is complete, the receiver can increase the phase interpolator setting and leave vref the same. The test pattern generation and comparison process can continue and new comparison results can be stored in the register, the process repeatedly cycling through all phase interpolator values and all vref values. The Center.Quiet state can be entered when the pattern generation and comparison process are complete. After centering the lanes through the Center.Pattern and Center.Quiet link states, a sideband handshake (e.g., using an LSM sideband signal on the link's dedicated LSM sideband lane) can be enabled to enter a Link.Init state to initialize the MCPL and allow data to be sent on the MCPL.

Kurz auf die Erläuterung von 15 zurückkommend kann, wie oben angemerkt, ein Seitenband-Handshake verwendet werden, um Verbindungszustandsmaschinenübergänge zwischen Nacktchips oder Chips in einem Mehrchipgehäuse zu vereinfachen. Beispielsweise können Signale auf den LSM-Seitenbandbahnen einer MCPL verwendet werden, um die Zustandsmaschinenübergänge am Nacktchip zu synchronisieren. Beispielsweise kann, wenn die Bedingungen zum Austritt aus seinem Zustand erfüllt sind (z.B. Reset.Idle), die Seite, die diese Bedingungen erfüllt hat, auf seiner ausgehenden LSM_SB-Bahn ein LSM-Seitenbandsignal zusichern und auf den anderen, separaten Nacktchip warten, bis dieser die gleiche Bedingung erreicht und ein LSM-Seitenbandsignal auf seiner LSM_SB-Bahn zusichern. Wenn beide LSM_SB-Signale zugesichert sind, kann die Verbindungszustandsmaschine jedes der Nacktchips in den nächsten Zustand übergehen (z.B. ein Reset.Cal-Zustand). Eine Mindestüberlappungszeit kann definiert werden, während der beide LSM_SB-Signale zugesichert bleiben sollten, bevor der Übergangszustand eintritt. Ferner kann eine Mindestruhezeit definiert werden, nachdem die Zusicherung von LSM_SB aufgehoben wurde, um eine genaue Umkehrfeststellung zu ermöglichen. In einigen Implementierungen kann jeder Verbindungszustandsmaschinenübergang auf/durch solche(n) LSM_SB-Handshakes konditioniert sein und vereinfacht werden.Briefly on the explanation of 15 Coming back, as noted above, a sideband handshake can be used to facilitate interconnect state machine transitions between dies or chips in a multichip package. For example, signals on the LSM sideband lanes of an MCPL can be used to synchronize the state machine transitions on the die. For example, if the conditions for exiting its state are met (e.g. Reset.Idle), the side that met those conditions can assert an LSM sideband signal on its outbound LSM_SB lane and wait for the other, separate die until this achieves the same condition and assures an LSM sideband signal on its LSM_SB path. If both LSM_SB signals are asserted, each die's connection state machine may transition to the next state (eg, a Reset.Cal state). A minimum overlap time can be defined during which both LSM_SB signals should remain asserted before the transition state occurs. Furthermore, a minimum sleep time can be defined after LSM_SB is de-asserted to allow accurate reversal detection. In some implementations, each connection state machine transition may be conditioned on/by such LSM_SB handshakes and simplified.

17 ist ein detailliertes Verbindungszustandsmaschinendiagramm 1700, das zumindest einige der zusätzlichen Verbindungszustände und Verbindungszustandsübergänge zeigt, die in einer beispielhaften MCPL enthalten sein können. In einigen Implementierungen kann bei einer beispielhaften Verbindungszustandsmaschine unter den anderen, in 17 dargestellten Zuständen und Zustandsübergängen auch ein „gelenkter Schleifenbetrieb-“ Übergang bereitgestellt sein, um die Bahnen einer MCPL in einen digitalen Schleifenbetrieb zu setzen. Beispielsweise können die Empfängerbahnen einer MCPL nach den Taktrücksetzschaltungen zurück zu den Senderbahnen geführt werden. Ein „LB_Neuzentrierung“-Zustand kann in manchen Fällen ebenfalls bereitgestellt werden, der verendet werden kann, um die Datensymbole abzugleichen. Außerdem kann, wie in 15 dargestellt, die MCPL mehrere Verbindungszustände unterstützen, einschließlich eines aktiven L0-Zustands und eines Niedrigenergiezustands, wie z.B. eines L1-Ruhezustands und L2-Schlafzustands, um einige von möglichen Beispielen zu nennen. 17 17 is a detailed link state machine diagram 1700 showing at least some of the additional link states and link state transitions that may be included in an example MCPL. In some implementations, in an example connection state machine, among the others, in 17 In addition to the illustrated states and state transitions, a "guided looping" transition may also be provided to place the lanes of an MCPL in digital looping. For example, the receiver lanes of an MCPL can be routed back to the transmitter lanes after the clock reset circuits. A "LB_Recenter" state can also be provided in some cases, which can be used to match the data symbols. In addition, as in 15 shown that support MCPL multiple link states finally, an active L0 state and a low-power state, such as an L1 idle state and L2 sleep state, to name a few possible examples.

18 ist ein vereinfachtes Blockdiagramm 1800, das einen beispielhaften Fluss in einem Übergang zwischen einem aktiven Zustand (z.B. L0) und einem Niedrigenergie-, oder Ruhe-, Zustand (z.B. L1) zeigt. In diesem speziellen Beispiel sind eine erste Vorrichtung 1805 und eine zweite Vorrichtung 1810 unter Verwendung einer MCPL kommunikativ gekoppelt. Im aktiven Zustand werden Daten über die Bahnen der MCPL (z.B. DATA, VALID, STREAM usw.) übertragen. Verbindungsschichtpakete (LLPs) können über die Bahnen kommuniziert werden (z.B. Datenbahnen, wobei das Datenstromsignal anzeigt, dass die Daten LLP-Daten sind), um die Vereinfachung von Verbindungszustandsübergängen zu unterstützen. Beispielsweise können LLPs zwischen der ersten und zweiten Vorrichtung 1805, 1810 gesendet werden, um von L0 in L1 automatisch überzugehen. Beispielsweise ist erwünscht, dass Oberschichtprotokolle, die von der MCPL unterstützt werden, diesen Eintritt in L1 (oder einen anderen Zustand) kommunizieren, und die Oberschichtprotokolle können dazu führen, dass LLPs über die MCPL gesendet werden, um einen Verbindungsschicht-Handshake zu vereinfachen, damit die physikalische Schicht in L1 eintritt. 18 zeigt beispielsweise zumindest einen Teil von LLPs, die unter Einschluss eines „Eintritt-in-L1“-Anfrage-LLP von der zweiten (stromauf liegenden) Vorrichtung 1810 zur ersten (stromab liegenden) Vorrichtung 1805 gesendet werden. In einigen Implementierungen und Protokollen der oberen Ebene initiiert der stromab liegende Anschluss nicht den Eintritt in L1. Die empfangende erste Vorrichtung 1805 kann als Antwort eine ein „Ändern-zu-L1“-Anfrage-LLP schicken, welche die zweite Vorrichtung 1810 durch ein „Ändern-zu-L1“-Bestätigungs-(ACK-) LLP bestätigen kann, um ein Beispiel zu nennen. Wird die Beendigung des Handshakes festgestellt, kann die Logik-PHY dazu führen, dass ein Seitenbandsignal auf einer dedizierten Seitenbandverbindung zugesichert wird, um zu bestätigen, dass die ACK empfangen wurde und dass die Vorrichtung (z.B. 1805) bereit für den Eintritt in L1 ist und diesen erwartet. Beispielsweise kann die erste Vorrichtung 1805 ein Seitenbandsignal 1815 zusichern, das zur zweiten Vorrichtung 1810 gesendet wird, um den Empfang der endgültigen ACK im Verbindungsschicht-Handshake zu bestätigen. Außerdem kann die zweite Vorrichtung 1810 auch ein Seitenbandsignal als Antwort auf Seitenbandsignal 1815 zusichern, um die erste Vorrichtung 1805 über die Seitenband-ACK 1805 der ersten Vorrichtung zu benachrichtigen. Wenn die Verbindungsschichtkontrolle und der Seitenband-Handshake abgeschlossen sind, kann die MCPL-PHY in den L1-Zustand übergeführt werden, was dazu führt, dass alle Bahnen der MCPL in einen Ruhe-Energiesparmodus gesetzt werden, einschließlich entsprechender MCPL-Abtasten von 1820, 1825 der Vorrichtungen 1805, 1810. Aus L1 kann ausgestiegen werden, wenn Oberschichtlogik von einer der ersten und zweiten Vorrichtung 1805, 1810 einen Wiedereintritt in L0 anfordert, beispielsweise als Antwort darauf, dass Daten festgestellt werden, die über die MCPL zu der anderen Vorrichtung gesendet werden sollen. 18 18 is a simplified block diagram 1800 showing an example flow in a transition between an active state (eg, L0) and a low power, or idle, state (eg, L1). In this particular example, a first device 1805 and a second device 1810 are communicatively coupled using an MCPL. In the active state, data is transmitted via the lanes of the MCPL (e.g. DATA, VALID, STREAM, etc.). Link layer packets (LLPs) may be communicated over the lanes (eg, data lanes, with the data stream signal indicating the data is LLP data) to help facilitate link state transitions. For example, LLPs can be sent between the first and second devices 1805, 1810 to transition from L0 to L1 automatically. For example, upper-layer protocols supported by the MCPL are desired to communicate this entry into L1 (or some other state), and the upper-layer protocols may result in LLPs being sent over the MCPL to facilitate a link-layer handshake in order to do so the physical layer enters L1. 18 FIG. 14, for example, shows at least a portion of LLPs sent from the second (upstream) device 1810 to the first (downstream) device 1805, including an “enter L1” request LLP. In some upper level implementations and protocols, the downstream port does not initiate entry into L1. The receiving first device 1805 may send in response a change-to-L1 request LLP, which the second device 1810 may acknowledge by a change-to-L1 acknowledgment (ACK) LLP to enter a to name an example. Upon detecting completion of the handshake, the logic PHY may cause a sideband signal to be asserted on a dedicated sideband link to confirm that the ACK has been received and that the device (e.g., 1805) is ready to enter L1 and expected this. For example, the first device 1805 may assert a sideband signal 1815 that is sent to the second device 1810 to acknowledge receipt of the final ACK in the link-layer handshake. In addition, the second device 1810 may also assert a sideband signal in response to the sideband signal 1815 to notify the first device 1805 of the sideband ACK 1805 of the first device. When the link layer control and sideband handshake are complete, the MCPL PHY can be transitioned to the L1 state, resulting in all lanes of the MCPL being placed in a sleep power saving mode, including corresponding MCPL scans of 1820, 1825 of devices 1805, 1810. L1 may be exited when upper-layer logic requests one of the first and second devices 1805, 1810 to re-enter L0, for example in response to detecting data being sent over the MCPL to the other device should.

Wie oben angemerkt kann in einigen Implementierungen eine MCPL Kommunikation zwischen zwei Vorrichtungen vereinfachen, die möglicherweise mehrere unterschiedliche Protokolle unterstützen, und die MCPL kann Kommunikationen gemäß möglicherweise einem der mehreren Protokolle über die Bahnen der MCPL ermöglichen. Ermöglichen mehrerer Protokolle kann jedoch den Eintritt und Wiedereintritt in zumindest einige Verbindungszustände erschweren. Während manche herkömmliche Verbindungen beispielsweise ein einziges Oberschichtprotokoll aufweisen, das den Master der Zustandsübergänge darstellt, umfasst eine Implementierung von MCPL mit mehreren unterschiedlichen Protokollen effektiv mehrere Master. Wie in 18 beispielhaft dargestellt kann jedes von PCIe und IDI zwischen zwei Vorrichtungen 1805, 1810 durch eine Implementierung von MCPL unterstützt werden, beispielsweise kann Setzen der physikalischen Schicht in einen Ruhe- oder Niedrigenergiezustand von der Bedingung abhängen, dass zuerst einer Erlaubnis von jedem der unterstützten Protokolle eingeholt wird (z.B. sowohl PCIe als auch IDI).As noted above, in some implementations, an MCPL may facilitate communication between two devices that may support multiple different protocols, and the MCPL may facilitate communications according to possibly one of multiple protocols over the lanes of the MCPL. However, allowing multiple protocols may make entering and re-entering at least some connection states more difficult. For example, while some traditional connections have a single upper layer protocol that is the master of the state transitions, an implementation of MCPL with multiple different protocols effectively includes multiple masters. As in 18 by way of example, each of PCIe and IDI between two devices 1805, 1810 can be supported by an implementation of MCPL, e.g. setting the physical layer to an idle or low power state can depend on the condition that permission is first obtained from each of the supported protocols (e.g. both PCIe and IDI).

In manchen Fällen kann Eintritt in L1 (oder einen anderen Zustand) nur von einer der mehreren unterstützten Protokolle angefordert werden, die für die Implementierung einer MCPL unterstützt werden. Es mag zwar Wahrscheinlich sein, dass die anderen Protokolle ebenfalls einen Eintritt in den gleichen Zustand anfordern werden (z.B. basierend auf einer Identifikation ähnlicher Bedingungen (z.B. wenig oder kein Verkehr) auf der MCPL), die Logik-PHY kann aber warten, bis eine Erlaubnis oder Anweisungen von jedem Oberschichtprotokoll empfangen wurde, bevor der Zustandsübergang tatsächlich ermöglicht. Die Logik-PHY kann verfolgen, welche Oberschichtprotokolle die Zustandsänderung angefordert haben (z.B. einen entsprechenden Handshake durchgeführt hat) und den Zustandsübergang auslösen, wenn identifiziert wird, dass jedes der Protokolle die jeweiligen Zustandsänderung angefordert hat, wie z.B. einen Übergang von L0 zu L1 oder einen anderen Übergang, der sich auf die Kommunikationen der anderen Protokolle auswirken oder diese stören würde. In einigen Implementierungen können Protokolle blind in Bezug auf ihre zumindest teilweise Abhängigkeit von anderen Protokollen im System sein. Ferner kann in manchen Fällen ein Protokoll eine Antwort (z.B. von der PHY) auf eine Anfrage, in einen bestimmten Zustand überzugehen, erwarten, beispielsweise eine Bestätigung oder Ablehnung des angeforderten Zustandsübergangs. Demgemäß kann in solchen Fällen, während auf eine Erlaubnis von einem anderen unterstützten Protokolle für einen Eintritt in einen Ruheverbindungszustand gewartet wird, die Logik-PHY synthetische Antworten auf eine Anfrage, erzeugen, um in den Ruhezustand einzutreten und das anfragende Oberschichtprotokoll „auszutricksen“, sodass dieses annimmt, das in einen bestimmten Zustand übergegangen wurde (währen in Wahrheit die Bahnen immer noch aktive sind, zumindest bis die anderen Protokolle ebenfalls einen Eintritt in den Ruhezustand anfordern). Unter anderen möglichen Vorteilen kann dies den Eintritt in den Niedrigenergiezustand zwischen mehreren Protokollen durch Koordination vereinfachen, um ein Beispiel zu nennen.In some cases, entry into L1 (or other state) can only be requested by one of the several supported protocols supported for implementation of an MCPL. While it may be likely that the other protocols will also request entry into the same state (eg, based on an identification of similar conditions (eg, little or no traffic) on the MCPL), the logic PHY can wait for permission or instructions have been received from any upper layer protocol before the state transition is actually enabled. The logic PHY can track which upper-layer protocols requested the state change (e.g., performed a corresponding handshake) and trigger the state transition when identifying that each of the protocols requested the respective state change, such as an L0 to L1 transition or a other transition that would affect or disrupt the communications of the other protocols. In some implementations, protocols may be blind to their at least partial dependency on other protocols in the system. Further, in some cases, a protocol may expect a response (eg, from the PHY) to a request to transition to a particular state, e.g wise an acknowledgment or rejection of the requested state transition. Accordingly, in such cases, while waiting for permission from another supported protocol to enter an idle connection state, the logic PHY can generate synthetic responses to a request to enter the idle state and "trick" the requesting upper-layer protocol to do so assumes that it has entered a certain state (while in fact the lanes are still active, at least until the other protocols also request entry into the idle state). Among other potential benefits, this may simplify entry into the low power state between multiple protocols through coordination, for example.

Es gilt anzumerken, dass die oben beschriebenen Geräte, Verfahren und Systeme in jeder/m beliebigen elektrischen Vorrichtung oder System implementiert werden können, wie oben erwähnt ist. Als spezifische Veranschaulichungen stellen die nachfolgenden Figuren beispielhafte Systeme zur Verwendung der Erfindung wie hierin beschrieben bereit. Wenn die Systeme nachstehend genauer beschrieben werden, wird eine Reihe von unterschiedlichen Verbindungen offenbart, beschrieben und aus der obigen Erläuterung wiederaufgenommen. Und wie leicht erkennbar sein wird, können die oben beschriebenen Vorteile bei beliebigen dieser Verbindungen, Strukturen oder Architekturen angewandt werden.It should be noted that the devices, methods, and systems described above may be implemented in any electrical device or system as mentioned above. As specific illustrations, the following figures provide example systems for using the invention as described herein. When the systems are described in more detail below, a number of different connections are disclosed, described, and resumed from the discussion above. And as will be readily apparent, the advantages described above can be applied to any of these connections, structures or architectures.

Unter Bezugnahme auf 19 ist eine Ausführungsform eines Blockdiagramms für ein Rechensystem dargestellt, das einen Mehrkernprozessor umfasst. Prozessor 1900 umfasst eine Prozessor- oder Verarbeitungsvorrichtung, wie z.B. einen Mikroprozessor, einen eingebetteten Prozessor, einen Digitalsignalprozessor (DSP), einen Netzwerkprozessor, einen Handprozessor, einen Anwendungsprozessor, einen Coprozessor, ein Ein-Chip-System (SOC) oder eine andere Vorrichtung zur Ausführung eines Codes. Prozessor 1900 umfasst in einer Ausführungsform zumindest zwei Kerne - Kern 1901 und 1902, die asymmetrische Kerne oder symmetrische Kerne (die dargestellte Ausführungsform) umfassen können. Prozessor 1900 kann jedoch auch eine Reihe von Verarbeitungselementen umfassen, die symmetrisch oder asymmetrisch sein können.With reference to 19 Illustrated is one embodiment of a block diagram for a computing system that includes a multi-core processor. Processor 1900 includes a processor or processing device, such as a microprocessor, an embedded processor, a digital signal processor (DSP), a network processor, a handheld processor, an application processor, a coprocessor, a system on chip (SOC), or other device for execution of a code. Processor 1900, in one embodiment, includes at least two cores - cores 1901 and 1902, which may include asymmetric cores or symmetric cores (the illustrated embodiment). However, processor 1900 may also include a number of processing elements, which may be symmetric or asymmetric.

In einer Ausführungsform bezieht sich ein Verarbeitungselement auf Hardware oder Logik zur Unterstützung eines Software-Threads. Beispiele für Hardware-Verarbeitungselemente umfassen: eine Threadeinheit, einen Thread-Slot, einen Thread, eine Prozesseinheit, einen Kontext, eine Kontexteinheit, einen Logikprozessor, einen Hardware-Thread, einen Kern, und/oder ein beliebiges anderes Element, das in der Lage ist, einen Zustand eines Prozessors zu halten, z.B. einen Ausführungszustand oder einen Architekturzustand. Mit anderen Worten kann sich ein Verarbeitungselement in einer Ausführungsform auf eine beliebige Hardware beziehen, die unabhängig einem Code zugeordnet sein kann, z.B. einem Software-Thread, einem Betriebssystem, einer Anwendung oder einem anderen Code. Ein physikalischer Prozessor (oder Prozessorsocket) bezieht sich üblicherweise auf eine integrierte Schaltung, die möglicherweise eine beliebige Anzahl von anderen Verarbeitungselementen umfasst, wie z.B. Kerne oder Hardware-Threads.In one embodiment, a processing element refers to hardware or logic supporting a software thread. Examples of hardware processing elements include: a thread unit, a thread slot, a thread, a process unit, a context, a context unit, a logical processor, a hardware thread, a core, and/or any other element capable of is to hold a state of a processor, e.g., an execution state or an architectural state. In other words, a processing element in one embodiment can refer to any hardware that can be independently associated with code, such as a software thread, an operating system, an application, or other code. A physical processor (or processor socket) commonly refers to an integrated circuit that may include any number of other processing elements, such as cores or hardware threads.

Ein Kern bezieht sich häufig auf eine Logik, die sich auf einer integrierten Schaltung befindet, die in der Lage ist, einen unabhängigen Architekturzustand aufrechtzuerhalten, wobei jeder unabhängig aufrechterhaltene Architekturzustand zumindest einigen dedizierten Ausführungsressourcen zugeordnet ist. Im Gegensatz zu Kernen bezieht sich ein Hardware-Thread üblicherweise auf eine beliebige Logik, die sich auf einer integrierten Schaltung befindet und in der Lage ist, einen unabhängigen Architekturzustand aufrechtzuerhalten, wobei die unabhängig aufrechterhaltenen Architekturzustände einen gemeinsamen Zugang zu Ausführungsressourcen haben. Wie zu sehen ist überlappt, wenn bestimmte Ressourcen geteilt werden und andere für einen Architekturzustand reserviert sind, die Grenze zwischen der Terminologie für einen Hardware-Thread und für einen Kern. Häufig werden ein Kern und ein Hardware-Thread jedoch von einem Betriebssystem als einzelne Logikprozessoren betrachtet, wobei das Betriebssystem in der Lage ist, Operationen auf jedem Logikprozessor separat zu planen.A core often refers to logic residing on an integrated circuit capable of maintaining an independent architectural state, with each independently maintained architectural state being associated with at least some dedicated execution resources. In contrast to cores, a hardware thread commonly refers to any logic residing on an integrated circuit capable of maintaining an independent architectural state, where the independently maintained architectural states have common access to execution resources. As can be seen, when certain resources are shared and others are reserved for an architectural state, the boundary between the terminology for a hardware thread and for a core overlaps. Often, however, a core and a hardware thread are viewed by an operating system as individual logical processors, with the operating system being able to schedule operations on each logical processor separately.

Physikalischer Prozessor 1900, wie in 19 dargestellt, umfasst zwei Kerne - Kern 1901 und 1902. Hier werden Kern 1901 und 1902 als symmetrische Kerne gesehen, d.h. Kerne mit den gleichen Konfigurationen, Funktionseinheiten und/oder Logiken. In einer weiteren Ausführungsform umfasst Kern 1901 einen die Reihenfolge nicht einhaltenden Prozessorkern, während Kern 1902 einen die Reihenfolge einhaltenden Prozessorkern umfasst. Kerne 1901 und 1902 können jedoch unabhängig aus jeder beliebigen Art von Kern ausgewählt sein, wie z.B. einem nativen Kern, einem Software-verwalteten Kern, einem Kern, der zur Ausführung einer nativen Befehlssatzarchitektur (ISA) angepasst ist, einen Kern, der zur Ausführung einer übersetzten Befehlssatzarchitektur (ISA) angepasst ist, einem gemeinsam entworfenen Kern oder einem anderen bekannten Kern. In einer heterogenen Kernumgebung (d.h. asymmetrische Kerne) kann eine Form von Übersetzung, wie z.B. Binärübersetzung, verwendet werden, um einen Code auf einem oder beiden Kernen zu planen oder auszuführen. Um die Erläuterung zu verkürzen, sind nachstehend die in Kern 1901 dargestellten Funktionseinheiten genauer beschrieben, da die Einheiten in Kern 1902 in der dargestellten Ausführungsform auf ähnliche Weise arbeiten.Physical processor 1900, as in 19 shown comprises two cores - core 1901 and 1902. Here core 1901 and 1902 are seen as symmetric cores, ie cores with the same configurations, functional units and/or logic. In another embodiment, core 1901 includes an out-of-order processor core, while core 1902 includes an in-order processor core. However, cores 1901 and 1902 may be independently selected from any type of core, such as a native core, a software managed core, a core adapted to execute a native instruction set architecture (ISA), a core adapted to execute a Translated Instruction Set Architecture (ISA), a commonly designed kernel, or another known kernel. In a heterogeneous core environment (ie, asymmetric cores), some form of translation, such as binary translation, can be used to translate code on one or both cores to plan or carry out. For the sake of brevity, the functional units represented in core 1901 are described in more detail below, since the units in core 1902 operate in a similar manner in the illustrated embodiment.

Wie dargestellt umfasst Kern 1901 zwei Hardware-Threads 1901a und 1901b, die auch als Hardware-Thread-Slots 1901a und 1901b bezeichnet werden können. Daher sehen Software-Einheiten, wie z.B. ein Betriebssystem, in einer Ausführungsform Prozessor 1900 möglicherweise als vier separate Prozessoren, d.h. vier Logikprozessoren oder Verarbeitungselemente, die in der Lage sind, vier Software-Threads gleichzeitig auszuführen. Wie oben angemerkt ist ein erster Thread Architekturzustandsregistern 1901a zugeordnet, ein zweiter Thread ist Architekturzustandsregistern 1901b zugeordnet, ein dritter Thread kann Architekturzustandsregistern 1902a zugeordnet sein und ein vierter Thread kann Architekturzustandsregistern 1902b zugeordnet sein. Hier kann jedes der Architekturzustandsregister (1901a, 1901b, 1902a, und 1902b) als Verarbeitungselement, Thread-Slot oder Thread-Einheit bezeichnet werden, wie oben beschrieben ist. Wie dargestellt werden Architekturzustandsregister 1901a in Architekturzustandsregistern 1901b repliziert, sodass einzelne Architekturzustände/-kontexte in für Logikprozessor 1901a und Logikprozessor 1901b gespeichert werden können. In Kern 1901 können auch andere kleine Ressourcen, wie z.B. Anweisungszeiger und Umbenennungslogik im Zuordner- und Umbenennerblock 1930 für Threads 1901a und 1901b repliziert werden. Manche Ressourcen, wie z.B. Neuordnunsgpuffer in Neuordnungs-/Rückordnungseinheit 1935, ILTB 1920, Lade-/Speicherpuffer und Warteschlangen können durch Partitionierung geteilt werden. Andere Ressourcen, wie z.B. interne Allzweckregister, (ein) auf Seiten-Tabellen basierende(s) Register, Datencaches der unteren Ebene und Daten-TLB 1915, (eine) Ausführungseinheit(en) 1940 sowie Teile von die Reihenfolge nicht einhaltender Einheit 1935, werden möglicherweise vollständig geteilt.As shown, core 1901 includes two hardware threads 1901a and 1901b, which may also be referred to as hardware thread slots 1901a and 1901b. Therefore, in one embodiment, software entities such as an operating system may view processor 1900 as four separate processors, i.e., four logical processors or processing elements capable of executing four software threads concurrently. As noted above, a first thread is associated with architecture state registers 1901a, a second thread is associated with architecture state registers 1901b, a third thread may be associated with architecture state registers 1902a, and a fourth thread may be associated with architecture state registers 1902b. Here, each of the architecture state registers (1901a, 1901b, 1902a, and 1902b) may be referred to as a processing element, thread slot, or thread unit, as described above. As shown, architecture state registers 1901a are replicated in architecture state registers 1901b so that individual architecture states/contexts can be stored in for logical processor 1901a and logical processor 1901b. Other small resources such as instruction pointers and renaming logic in allocator and renamer block 1930 for threads 1901a and 1901b may also be replicated in core 1901. Some resources, such as reorder buffers in reorder/retire unit 1935, ILTB 1920, load/store buffers, and queues may be shared through partitioning. Other resources such as internal general purpose registers, (a) page table based register(s), low level data caches and data TLB 1915, (a) execution unit(s) 1940 and parts of out of order unit 1935 possibly fully shared.

Prozessor 1900 umfasst häufig andere Ressourcen, die vollständig geteilt werden können, durch Partitionierung gemeinsam genutzt werden können oder von/für Verarbeitungselemente dediziert werden können. In 19 ist eine Ausführungsform eines rein exemplarischen Prozessors mit veranschaulichenden logischen Einheiten/Ressourcen eines Prozessors dargestellt. Es gilt anzumerken, dass ein Prozessor beliebige dieser Funktionseinheiten enthalten oder nicht enthalten kann sowie beliebige andere bekannte Funktionseinheiten, Logik oder Firmware enthalten kann, die nicht dargestellt sind. Wie dargestellt umfasst Kern 1901 einen vereinfachten, die Reihenfolge nicht einhaltenden (OOO) Prozessorkern. Aber in anderen Ausführungsformen kann ein die Reihenfolge einhaltender Prozessor verwendet werden. Der OOO-Kern umfasst einen Verzweigungszielpuffer 1920, um Verzweigungen vorherzusagen, die ausgeführt/genommen werden, und einen Anweisungsübersetzungspuffer (I-TLB) 1920 zum Speichern von Adressübersetzungseintragungen für Anweisungen.Processor 1900 often includes other resources that can be fully shared, shared through partitioning, or dedicated by/to processing elements. In 19 1 is an embodiment of a purely exemplary processor with illustrative logical units/resources of a processor. It is noted that a processor may or may not include any of these functional units, as well as any other known functional units, logic, or firmware that are not shown. As illustrated, core 1901 comprises a simplified out of order (OOO) processor core. But in other embodiments, an in-order processor may be used. The OOO core includes a branch target buffer 1920 to predict branches that will be taken/taken and an instruction translation buffer (I-TLB) 1920 to store address translation entries for instructions.

Kern 1901 umfasst ferner ein Dekodiermodul 1925, das mit Abrufeinheit 1920 gekoppelt ist, um abgerufene Elemente zu dekodieren. Eine Abruflogik umfasst in einer Ausführungsform einzelne Sequenzierer, die Thread-Slots 1901a bzw. 1901b zugeordnet sind. Üblicherweise ist Kern 1901 einer ersten ISA zugeordnet, die Anweisungen definiert/spezifiziert, die auf Prozessor 1900 ausführbar sind. Häufig umfassen Maschinencodeanweisungen, die Teil der ersten ISA sind, einen Teil der Anweisung (als Opcode bezeichnet), die (auf) eine Anweisung oder eine Operation verweist/spezifiziert, die ausgeführt werden soll. Dekodierlogik 1925 umfasst eine Schaltung, die diese Anweisungen aus ihren Opcodes erkennt und die dekodierten Anweisungen in die Pipeline zur Verarbeitung weiterleitet, wie sie durch die erste ISA definiert ist. Wie nachstehend genauer erläutert können Dekodierer 1925 beispielsweise in einer Ausführungsform eine Logik umfassen, die ausgelegt oder angepasst ist, um spezifische Anweisungen zu erkennen, wie z.B. eine Transaktionsanweisung. Als Ergebnis der Erkennung durch Dekodierer 1925 setzt die Architektur oder der Kern 1901 bestimmte vordefinierte Aktionen zur Ausführung von Aufgaben, die der geeigneten Anweisung zugeordnet sind. Es ist wichtig, anzumerken, dass beliebige der Aufgaben, Blöcke, Operationen und Verfahren, die hierin beschrieben sind, als Antwort auf eine einzelne oder auf mehrere Anweisungen ausgeführt werden können; manche davon können neue oder alte Anweisungen sein. Es gilt anzumerken, dass Dekodierer 1926 in einer Ausführungsform die gleiche ISA (oder einen Subsatz davon) erkennen. Alternativ dazu erkennen Dekodierer 1926 in einer heterogenen Kernumgebung eine zweite ISA (entweder einen Subsatz einer ersten ISA oder einer anderen ISA).Core 1901 further includes a decode module 1925 coupled to fetch unit 1920 to decode fetched items. In one embodiment, fetch logic includes individual sequencers associated with thread slots 1901a and 1901b, respectively. Typically, core 1901 is associated with a first ISA that defines/specifies instructions executable on processor 1900. Often, machine code instructions that are part of the first ISA include a portion of the instruction (referred to as opcode) that references/specifies an instruction or operation to be performed. Decode logic 1925 includes circuitry that recognizes these instructions from their opcodes and passes the decoded instructions down the pipeline for processing as defined by the first ISA. For example, as discussed in more detail below, in one embodiment, decoders 1925 may include logic designed or adapted to recognize specific instructions, such as a transaction instruction. As a result of detection by decoders 1925, the architecture or core 1901 takes certain predefined actions to perform tasks associated with the appropriate instruction. It is important to note that any of the tasks, blocks, operations, and methods described herein may be performed in response to a single or multiple instructions; some of these may be new or old instructions. Note that in one embodiment, decoders 1926 recognize the same ISA (or a subset thereof). Alternatively, in a heterogeneous core environment, decoders 1926 recognize a second ISA (either a subset of a first ISA or a different ISA).

In einem Beispiel umfasst der Zuordner- und Umbenennerblock 1930 einen Zuordner zur Reservierung von Ressourcen, wie z.B. Registerdateien zur Speicherung von Anweisungsverarbeitungsergebnissen. Threads 1901a und 1901b sind jedoch möglicherweise zur nicht die Reihenfolge nicht einhaltenden Ausführung in der Lage, wobei Zuordner- und Umbenennerblock 1930 auch andere Ressourcen reserviert, wie z.B. Neuordnungspuffers zum Nachverfolgen von Anweisungsergebnissen. Einheit 1930 kann auch einen Registerumbenenner zum Umbenennen von Programm-/Anweisungsreferenzregistern zu anderen internen Registern von Prozessor 1900 umfassen. Neuordnungs-/Rückordnungseinheit 1935 umfasst Komponenten, wie z.B. die oben genannten Neuordnungspuffer, Ladepuffers und Speicherpuffers, um die die Reihenfolge nicht einhaltende Ausführung und später und die die Reihenfolge einhaltenden Rückordnung von Anweisungen zu unterstützen, die nicht der Reihenfolge nach ausgeführt wurden.In one example, the allocator and renamer block 1930 includes an allocator for reserving resources, such as register files for storing instruction processing results. However, threads 1901a and 1901b may be capable of out-of-order execution, with allocator and renamer block 1930 also reserving other resources, such as reorder buffers for tracking instruction results. Unit 1930 may also include a register renamer for renaming program/instruction reference registers to other internal registers star of 1900 processor. Reorder/retirement unit 1935 includes components such as the reorder buffers, load buffers, and store buffers noted above to support out-of-order execution and later and in-order retirement of out-of-order instructions.

Planer- und Ausführungseinheit(en)-Block 1940 umfasst in einer Ausführungsform eine Planereinheit zum Planen von Anweisungen/Operationen auf Ausführungseinheiten. Beispielsweise wird ein Gleitkommabefehl an einem Anschluss einer Ausführungseinheit geplant, der eine verfügbare Gleitkommaausführungseinheit aufweist. Registerdateien, die den Ausführungseinheiten zugeordnet sind, sind ebenfalls enthalten, um Informationen über Anweisungsverarbeitungsergebnisse zu speichern. Beispielhafte Ausführungseinheiten umfassen eine Gleitkommaausführungseinheit, eine Ganzzahlausführungseinheit, eine Sprungausführungseinheit, eine Lastausführungseinheit, eine Speicherausführungseinheit und andere bekannte Ausführungseinheiten.Scheduler and Execution Unit(s) Block 1940, in one embodiment, includes a scheduler unit for scheduling instructions/operations onto execution units. For example, a floating point instruction is scheduled on an execution unit port that has an available floating point execution unit. Register files associated with execution units are also included to store information about instruction processing results. Example execution units include a floating point execution unit, an integer execution unit, a branch execution unit, a load execution unit, a memory execution unit, and other known execution units.

Ein Datencache der unteren Ebene und ein Datenübersetzungspuffer (D-TLB) 1950 werden mit Ausführungseinheit(en) 1940 gekoppelt. Der Datencache dient zur Speicherung von kürzlich verwendeter/bearbeiteter Elemente, wie z.B. Datenoperanden, di möglicherweise in Speicherkohärenzzuständen gehalten werden. Der D-TLB dient zur Speicherung kürzlicher virtuell/linear-zu-physikalischer Adressübersetzungen. Als spezifisches Beispiel kann ein Prozessor eine Seiten-Tabellen-Struktur umfassen, um einen physikalischen Speicher in eine Vielzahl von virtuellen Seiten aufzubrechen.A low level data cache and a data translation buffer (D-TLB) 1950 are coupled to execution unit(s) 1940 . The data cache is used to store recently used/edited items, such as data operands, that may be held in memory coherency states. The D-TLB is used to store recent virtual/linear-to-physical address translations. As a specific example, a processor may include a page table structure to break up physical memory into a plurality of virtual pages.

Hier teilen Kerne 1901 und 1902 Zugang zu einem Cache auf höherer Ebene oder weiter außerhalb, wie z.B. einem Cache auf zweiter Ebene, der einer On-Chip-Schnittstelle 1910 zugeordnet ist. Es gilt anzumerken, dass sich höhere Ebene oder weiter außerhalb auf Cacheebenen bezieht, die von der/den Ausführungseinheit(en) weg aufsteigen oder weiter weg liegen. In einer Ausführungsform ist ein Cache höherer Ebene ein Datencache der letzten Ebene - der letzte Cache in der Speicherhierarchie auf Prozessor 1900 - wie z.B. ein Cache der zweiten oder dritten Ebene. Ein Cache einer höheren Ebene ist jedoch nicht darauf eingeschränkt, da er einem Anweisungscache zugeordnet sein kann oder einen solchen umfassen kann. Ein Verfolgungscache - eine Art von Anweisungscache - kann stattdessen nach dem Dekodierer 1925 gekoppelt werden, um kürzlich dekodierte Abläufe zu speichern. Hier bezieht sich eine Anweisung möglicherweise auf eine Makroanweisung (d.h. eine allgemeine Anweisung, die von den Dekodierern erkannt wird), die in eine Reihe von Mikroanweisungen (Mikrooperationen) dekodiert werden kann.Here, cores 1901 and 1902 share access to a higher-level or more external cache, such as a second-level cache associated with an on-chip interface 1910. Note that higher level or further out refers to cache levels that are ascending or further away from the execution unit(s). In one embodiment, a higher level cache is a last level data cache - the last cache in the memory hierarchy on processor 1900 - such as a second or third level cache. However, a higher level cache is not so limited, as it may be associated with or include an instruction cache. A trace cache - a type of instruction cache - may instead be coupled after the decoder 1925 to store recently decoded runs. Here, an instruction may refer to a macro-instruction (i.e., a general instruction recognized by the decoders) that can be decoded into a series of micro-instructions (micro-operations).

In der dargestellten Konfiguration umfasst Prozessor 1900 auch ein On-Chip-Schnittstellenmodul 1910. Früher war eine Speichersteuerung, die nachstehend genauer beschrieben ist, in einem Rechensystem enthalten, das außerhalb des Prozessors 1900 liegt. In diesem Szenario dient die On-Chip-Schnittstelle 1910 zur Kommunikation mit Vorrichtungen, die außerhalb des Prozessors 1900 liegen, z.B. einem Systemspeicher 1975, einem Chipsatz (häufig einen Speichersteuerungs-Hub umfassend, um Speicher 1975 und einen I/O-Steuerungs-Hub zu verbinden, um periphere Vorrichtungen zu verbinden), einem Speichersteuerungs-Hub, einer Northbridge oder anderen integrierten Schaltungen. Und in diesem Szenario kann Bus 1905 eine beliebige bekannte Verbindung umfassen, wie z.B. einen Mehrpunktbus, eine Punkt-zu-Punkt-Verbindung, eine Serielle Verbindung, einen parallelen Bus, einen kohärenten (z.B. cachekohärenten) Bus, eine Protokollschichtarchitektur, einen differentiellen Bus und einen GTL-Bus.In the configuration shown, processor 1900 also includes an on-chip interface module 1910. Historically, a memory controller, described in more detail below, was included in a computing system external to processor 1900. In this scenario, the on-chip interface 1910 is used to communicate with devices external to the processor 1900, e.g., a system memory 1975, a chipset (often including a memory controller hub, around memory 1975, and an I/O controller hub to connect to peripheral devices), a memory controller hub, a northbridge, or other integrated circuits. And in this scenario, bus 1905 can include any known connection, such as a multipoint bus, a point-to-point connection, a serial connection, a parallel bus, a coherent (e.g., cache-coherent) bus, a protocol layer architecture, a differential bus, and a GTL bus.

Speicher 1975 kann für Prozessor 1900 dediziert sein oder mit anderen Vorrichtungen in einem System geteilt werden. Herkömmliche Beispiele für Arten von Speicher 1975 umfassen DRAM, SRAM, nichtflüchtige Speicher (NV-Speicher) und andere bekannte Speichervorrichtungen. Es gilt anzumerken, dass Vorrichtung 1980 einen Grafikbeschleuniger, einen Prozessor oder eine Karte mit einem Speichersteuerungs-Hub gekoppelt, einen Datenspeicher mit einem I/O Steuerungs-Hub gekoppelt, einen Drahtlossendeempfänger, eine Flashvorrichtung, eine Audiosteuerung, eine Netzwerksteuerung oder eine andere bekannte Vorrichtung umfassen kann.Memory 1975 may be dedicated to processor 1900 or shared with other devices in a system. Common examples of types of memory 1975 include DRAM, SRAM, non-volatile memory (NV memory), and other known memory devices. Note that device 1980 is a graphics accelerator, a processor or card coupled to a memory controller hub, a memory coupled to an I/O controller hub, a wireless transceiver, a flash device, an audio controller, a network controller, or other known device may include.

Seit Kurzem kann jedoch, da mehr Logik und Vorrichtungen auf einem einzelnen Nacktchip, wie z.B. SOC, untergebracht werden, jede dieser Vorrichtungen auf Prozessor 1900 inkorporiert sein. In einer Ausführungsform befindet sich beispielsweise ein Speichersteuerungs-Hub auf demselben Paket und/oder Nacktchip wie Prozessor 1900. Hier umfasst ein Teil des Kerns (ein On-Core-Teil) 1910 eine oder mehrere Steuerung(en) zur Bereitstellung einer Schnittstelle mit anderen Vorrichtungen, wie z.B. Speicher 1975 oder einer Grafikvorrichtung 1980. Die Konfiguration, die eine Verbindung und Steuerungen zur Bereitstellung einer Schnittstelle mit solchen Vorrichtungen umfasst, wird oft als On-Core bezeichnet (oder Un-Core-Konfiguration). Beispielsweise umfasst eine On-Chip-Schnittstelle 1910 eine Ringverbindung für On-Chip-Kommunikation und eine serielle Punkt-zu-Punkt-Hochgeschwindigkeitsverbindung 1905 für Off-Chip-Kommunikation. Nichtsdestotrotz könne in der SOC-Umgebung noch weitere Vorrichtungen, wie z.B. die Netzwerk-Schnittstelle, Coprozessoren, Speicher 1975, Grafikprozessor 1980 und beliebige andre bekannte Rechenvorrichtungen/Schnittstellen auf einem einzelnen Nacktchip oder einer integrierten Schaltung vorhanden sein, um einen kleinen Formfaktor mit hoher Funktionalität und geringem Energieverbrauch bereitzustellen.More recently, however, as more logic and devices are packaged on a single die, such as an SOC, each of these devices may be incorporated on processor 1900. For example, in one embodiment, a memory controller hub resides on the same package and/or die as processor 1900. Here, a portion of core (an on-core portion) 1910 includes one or more controllers for providing an interface with other devices , such as memory 1975 or a graphics device 1980. The configuration that includes connection and controls for interfacing with such devices is often referred to as on-core (or un-core configuration). For example, an on-chip interface 1910 includes a ring connection for on-chip communications tion and a point-to-point high-speed serial link 1905 for off-chip communications. Nonetheless, in the SOC environment, other devices such as the network interface, coprocessors, memory 1975, graphics processor 1980 and any other known computing devices/interfaces can reside on a single die or integrated circuit to provide a small form factor with high functionality and provide low energy consumption.

In einer Ausführungsform ist Prozessor 1900 in der Lage, einen Kompilierungs-, Optimierungs- und/oder Übersetzercode 1977 zum Kompilieren, Übersetzen und/oder Optimieren von Anwendungscode 1976 auszuführen, um das Gerät und die Verfahren, die hierin beschrieben sind, zu unterstützen oder eine Schnittstelle damit bereitzustellen. Ein Compiler umfasst oft ein Programm oder einen Satz von Programmen zur Übersetzung von Quelltest/-code in Zieltext/-code. Üblicherweise erfolgt eine Kompilierung von Programm-/Anwendungscode mit einem Compiler in mehreren Phasen und Durchläufen, um einen Programmiersprachencode höherer Ebene in einen Maschinen- oder Assemblersprachencode einer niedrigeren Ebene umzuwandeln. Nichtsdestotrotz können für einfache Kompilation auch Compiler mit einem Durchlauf eingesetzt werden. Ein Compiler kann beliebige bekannte Kompilationstechniken nutzen und beliebige bekannte Compileroperationen ausführen, wie z.B. eine lexikalische Analyse, Vorverarbeitung, Syntaxanalyse, semantische Analyse, Codeerzeugung, Codetransformation und Codeoptimierung.In one embodiment, processor 1900 is capable of executing compilation, optimization, and/or translator code 1977 to compile, translate, and/or optimize application code 1976 to support the apparatus and methods described herein or a to provide an interface with it. A compiler often includes a program or set of programs for translating source test/code into target text/code. Typically, program/application code is compiled with a compiler in multiple stages and passes to convert higher level programming language code to lower level machine or assembly language code. However, single-pass compilers can also be used for simple compilation. A compiler can use any known compilation techniques and perform any known compiler operations, such as lexical analysis, preprocessing, parsing, semantic analysis, code generation, code transformation, and code optimization.

Größere Compiler umfassen oft mehrere Phasen, aber meistens sind diese Phasen in zwei allgemeinen Phasen enthalten: (1) Front-End, d.h. wo im Allgemeinen syntaktische Verarbeitung, semantische Verarbeitung und etwas Transformation/Optimierung stattfinden können, und (2) ein Back-End, d.h. wo im Allgemeinen Analysen, Transformationen, Optimierungen und Codeerzeugung stattfinden. Manche Compiler beziehen sich auf eine Mitte, was das Verschwimmen von Grenzen wischen einem Front-End und einem Back-End eines Compilers widerspiegelt. Als Folge kann ein Verweis auf eine Insertion, Zuordnung, Erzeugung oder andere Operation eines Compilers in jeder/m beliebigen der vorgenannten Phasen oder Durchgänge erfolgen sowie auch in beliebigen anderen bekannten Phasen oder Durchgängen eines Compilers. Als veranschaulichendes Beispiel insertiert ein Compiler möglicherweise Operationen, Aufrufe, Funktionen usw. in einer oder mehreren Kompilationsphasen, wie z.B. Insertion von Aufrufen/Operationen in einer Front-Ende-Phase der Kompilation und dann Transformation der Aufrufe/Operationen in einen Code einer niedrigeren Ebene während einer Transformationsphase. Es gilt anzumerken, dass während einer dynamischen Kompilation ein Compilercode oder dynamischer Optimierungscode solche Operationen/Aufrufe insertieren kann, sowie auch den Code zur Ausführung während der Laufzeit optimieren kann. Als spezifisches veranschaulichendes Beispiel kann ein Binärcode (schon kompilierter Code) dynamisch während der Laufzeit optimiert werden. Hier kann der Programmcode den dynamischen Optimierungscode, den Binärcode oder eine Kombination davon umfassen.Larger compilers often include multiple phases, but most often these phases are contained within two general phases: (1) a front-end, i.e. where generally syntactic processing, semantic processing, and some transformation/optimization can take place, and (2) a back-end , i.e. where analysis, transformation, optimization and code generation generally take place. Some compilers refer to a middle, reflecting the blurring of boundaries between a compiler's front end and back end. As a result, a reference to an insertion, allocation, generation, or other operation of a compiler may occur in any of the foregoing phases or passes, as well as any other known phases or passes of a compiler. As an illustrative example, a compiler may insert operations, calls, functions, etc. at one or more compilation phases, such as inserting calls/operations at a front-end phase of compilation and then transforming the calls/operations to lower-level code during a transformation phase. It should be noted that during dynamic compilation, compiler code or dynamic optimization code may insert such operations/calls, as well as optimize the code for execution at runtime. As a specific illustrative example, binary code (already compiled code) may be dynamically optimized at runtime. Here, the program code may include dynamic optimization code, binary code, or a combination thereof.

Ähnlich wie ein Compiler übersetzt ein Übersetzer, wie z.B. ein Binärübersetzer, eine Code entweder statisch oder dynamisch, um den Code zu optimieren und/oder zu übersetzen. Daher kann ein Verweis auf eine Ausführung eines Codes, eines Anwendungscodes, eines Programmcodes oder einer anderen Software-Umgebung auf folgendes verweisen: (1) auf eine Ausführung eines oder mehrerer Compilerprogramme, eines Optimierungscodeoptimierers oder eines Übersetzers entweder dynamisch oder statisch, um einen Programmcode zu kompilieren, Software-Strukturen zu erhalten, um andere Operationen durchzuführen, einen Code zu optimieren oder einen Code zu übersetzen; (2) auf eine Ausführung eines Hauptprogrammcodes, einschließlich Operationen/Aufrufen, wie z.B. eines Anwendungscodes, der optimiert/kompiliert wurde; (3) auf eine Ausführungsform eines anderen Programmcodes, wie z.B. Bibliotheken, die dem Hauptprogrammcode zugeordnet sind, um Software-Strukturen zu erhalten, um andere Software-bezogene Operationen auszuführen, oder um einen Code zu optimieren; oder (4) auf eine Kombination davon.Similar to a compiler, a translator, such as a binary translator, translates code either statically or dynamically to optimize and/or translate the code. Therefore, a reference to execution of code, application code, program code, or other software environment may refer to: (1) execution of one or more compiler programs, optimizing code optimizer, or translator, either dynamically or statically, to create program code compile, obtain software structures to perform other operations, optimize code, or translate code; (2) to execution of main program code, including operations/calls, such as application code that has been optimized/compiled; (3) to an embodiment of other program code, such as libraries associated with the main program code, to maintain software structures, to perform other software-related operations, or to optimize code; or (4) a combination thereof.

Auf 20 Bezug nehmend wird nun ein Blockdiagramm eine Ausführungsform eines Mehrkernprozessors gezeigt. Wie in der Ausführungsform von 20 zu sehen ist, umfasst Prozessor 2000 mehrere Domänen. Genauer gesagt umfasst eine Kerndomäne 2030 eine Vielzahl von Kernen 2030A-2030N, eine Grafikdomänen 2060 umfasst einen oder mehrere Grafikmaschinen mit einer Medienmaschine 2065 und einer Systemagentdomäne 2010.On 20 Referring now, a block diagram of one embodiment of a multi-core processor is shown. As in the embodiment of 20 As can be seen, processor 2000 includes multiple domains. More specifically, a core domain 2030 includes a plurality of cores 2030A-2030N, a graphics domain 2060 includes one or more graphics engines with a media engine 2065 and a system agent domain 2010.

In verschiedenen Ausführungsformen wickelt Systemagentdomäne 2010 Leistungssteuerungsvorgänge und Leistungsverwaltung ab, sodass einzelne Einheiten von Domänen 2030 und 2060 (z.B. Kerne und/oder Grafikmaschinen) unabhängig steuerbar sind, um ein(en) geeigneten/s Leistungsmodus/ebene dynamisch zu betreiben (z.B. Aktiv-, Turbo-, Schlaf-, Ruhe-, Tiefschlaf- oder andere ähnliche Zustände wie bei fortgeschnittenen Leistungsschnittstellenkonfigurationen), im Hinblick auf die Aktivität (oder Inaktivität) in der jeweiligen Einheit. Jede der Domänen 2030 und 2060 kann mit unterschiedlicher Spannung und/oder Leistung laufen, und außerdem können die einzelnen Einheiten innerhalb der Domänen jeweils möglicherweise mit unabhängiger Frequenz und Spannung laufen. Es gilt anzumerken, dass zwar nur drei Domänen dargestellt sind, der Schutzumfang der vorliegenden Erfindung aber nicht auf den Zusammenhang von Nacktchips eingeschränkt ist und in anderen Ausführungsformen weitere Domänen vorhanden sein können.In various embodiments, system agent domain 2010 handles power control operations and power management such that individual units of domains 2030 and 2060 (e.g., cores and/or graphics engines) are independently controllable to dynamically operate an appropriate power mode/level (e.g., active, turbo, sleep, hibernation, hibernation, or other similar states as in advanced power interface configurations) with respect to the activity (or inactivity) in the respective unit. Each of the domains 2030 and 2060 can have a different voltage and/or power, and also the individual units within the domains may each be able to run at independent frequency and voltage. It should be noted that while only three domains are shown, the scope of the present invention is not limited to the context of die and other domains may be present in other embodiments.

Wie dargestellt umfasst jeder Kern 2030 ferner Caches einer niedrigen Ebene zusätzlich zu verschiedenen Ausführungseinheiten und weiteren Verarbeitungselements. Hier sind die verschiedenen Kerne miteinander und mit einem geteilten Cachespeicher gekoppelt, der aus einer Vielzahl von Einheiten oder Scheiben aus zumindest einem Cache der letzten Ebene (LLC) 2040A-2040N gebildet ist; diese LLCs umfassen oft Speicher- und Cachesteuerungsfunktionalität und werden von den Kernen geteilt, sowie auch möglicherweise von den Grafikmaschinen.As shown, each core 2030 also includes low-level caches in addition to various execution units and other processing elements. Here, the various cores are coupled to each other and to a shared cache made up of a plurality of units or slices of at least one last level cache (LLC) 2040A-2040N; these LLCs often include memory and cache control functionality and are shared between the cores and possibly the graphics engines as well.

Wie zu sehen ist, koppelt eine Ringverbindung 2050 die Kerne aneinander und stelle eine Verbindung zwischen der Kerndomäne 2030, der Grafikdomäne 2060 und der Systemagentschaltung 2010 über eine Vielzahl von Ringstopps 2052A-2052N bereit, jeder bei einer Kopplung zwischen einem Kern und einer LLC-Scheibe. Wie in 20 zu sehen ist, wird Verbindung 2050 verwendet, um verschiedene Informationen zu tragen, Einschließlich Adresseninformationen, Dateninformationen, Bestätigungsinformationen und Abhör-/ungültige Informationen. Obwohl eine Ringverbindung dargestellt ist, kann jede bekannte nacktchipgetragene Verbindung oder Struktur eingesetzt werden. Als veranschaulichendes Beispiel können einige der oben erläuterten Strukturen (z.B. eine weitere nacktchipgetragene Verbindung, On-Chip-System-Struktur (OSF) eine fortgeschrittene Mikrosteuerungsbusarchitektur- (AMBA-) Verbindung, ein mehrdimensionales Netzstruktur oder eine andere bekannte Zwischenverbindungsarchitektur) auf ähnliche Weise eingesetzt werden.As can be seen, a ring interconnect 2050 couples the cores together and provides a connection between the core domain 2030, the graphics domain 2060 and the system agent circuitry 2010 via a plurality of ring stops 2052A-2052N, each at a coupling between a core and an LLC slice . As in 20 As seen, link 2050 is used to carry various information, including address information, date information, acknowledgment information, and intercept/invalid information. Although a ring connection is shown, any known die-borne connection or structure may be employed. As an illustrative example, some of the structures discussed above (e.g., another die-borne interconnect, system on-chip fabric (OSF), an advanced microcontroller bus architecture (AMBA) interconnect, a multi-dimensional mesh fabric, or other known interconnect architecture) may be employed in a similar manner .

Wie ferner dargestellt umfasst Systemagentdomäne 2010 eine Anzeigemaschine 2012, die zur Bereitstellung einer Steuerung von und einer Schnittstelle mit einer zugeordnete Anzeige dient. Systemagentdomäne 2010 kann weitere Einheiten umfassen, wie etwa: eine integrierte Speichersteuerung 2020, die eine Schnittstelle mit einem Systemspeicher (z.B. einem DRAM, implementiert mit mehreren DIMMs) bereitstellt; eine Kohärenzlogik 2022 zur Ausführung von Speicherkohärenzoperationen. Mehrere Schnittstellen können vorhanden sein, um eine Verbindung zwischen dem Prozessor einer anderen Schaltung bereitzustellen. In einer Ausführungsform wird beispielsweise zumindest eine direkte Medienschnittstelle (DMI) 2016 breitgestellt, sowie eine oder mehreren PCIe™-Schnittstellen 2014. Die Anzeigemaschine und diese Schnittstellen sind typischerweise über eine PCIe™-Brücke 2018 mit einem Speicher gekoppelt. Ferner können zur Bereitstellung von Kommunikation zwischen anderen Agenten, wie z.B. zusätzlichen Prozessoren oder anderer Schaltung, eine oder mehrere andere Schnittstellen bereitgestellt werden.As further illustrated, system agent domain 2010 includes a display engine 2012 operable to provide control of and interface with an associated display. System agent domain 2010 may include other entities such as: an integrated memory controller 2020 that interfaces with system memory (e.g., DRAM implemented with multiple DIMMs); a coherency logic 2022 for performing memory coherency operations. Multiple interfaces may be present to provide a connection between the processor of another circuit. For example, in one embodiment, at least one direct media interface (DMI) 2016 is provided, as well as one or more PCIe™ interfaces 2014. The display engine and these interfaces are typically coupled to memory via a PCIe™ bridge 2018. Furthermore, one or more other interfaces may be provided to provide communication between other agents, such as additional processors or other circuitry.

Auf 21 Bezug nehmend wird nun ein Blockdiagramm eines repräsentativen Kerns dargestellt; genauer gesagt Logikblöcke eines Back-Ends eines Kerns, wie z.B. Kern 2030 aus 20. Im Allgemeinen umfasst die in 21 dargestellte Struktur einen die Reihenfolge nicht einhaltenden Prozessor, der eine Fron-End-Einheit 2170 umfasst, die zum Abrufen von ankommenden Anweisungen, Ausführung verschiedener Verarbeitungen (z.B. Cachen, Dekodieren, Verzweigungsvorhersage usw.) und Weiterleiten von Anweisungen/Operationen an die die Reihenfolge nicht einhaltenden (OOO) Maschine 2180 verwendet wird. OOO-Maschine 2180 führt weitere Verarbeitung an dekodierten Anweisungen aus.On 21 Referring now, a block diagram of a representative core is presented; more specifically, logical blocks of a back-end of a core, such as core 2030 20 . In general, the in 21 The structure shown depicts an out-of-order processor that includes a front-end unit 2170 configured to fetch incoming instructions, perform various processing (eg, caching, decoding, branch prediction, etc.), and forward instructions/operations to out-of-order processors compliant (OOO) machine 2180 is used. OOO engine 2180 performs further processing on decoded instructions.

Genauer gesagt umfasst in der Ausführungsform aus 21 die die Reihenfolge nicht einhaltende Maschine 2180 eine Zuordnungseinheit 2182 zum Empfangen von dekodierten Anweisungen, die in Form von einer oder mehreren Mikroanweisungen oder uops von der Front-End-Einheit 2170 vorliegen können, und ihr Zuordnen zu geeigneten Ressourcen, wie Register usw. Als Nächstes werden die Anweisungen zu einer Reservierungsstation 2184 geleitet, die Ressourcen dediziert und diese zur Ausführung auf einer von einer Vielzahl von Ausführungseinheiten 2186A-2186N plant. Verschiedene Arten von Ausführungseinheiten können vorhanden sein, beispielsweise arithmetisch- logische Einheiten (ALUs), Lade- und Speichereinheiten, Vektorverarbeitungseinheiten (VPUs), Gleitkommaausführungseinheiten und andere. Ergebnisse von diesen verschiedenen Ausführungseinheiten werden zu einem Neuordnungspuffer (ROB) 2188 bereitgestellt, der ungeordnete Ergebnisse nimmt und die korrekte Programmordnung wiederherstellt.More specifically, in the embodiment includes 21 the out-of-order engine 2180 has a mapping unit 2182 for receiving decoded instructions, which may be in the form of one or more micro-instructions or uops, from the front-end unit 2170 and mapping them to appropriate resources, such as registers, etc. Next the instructions are routed to a reservation station 2184, which dedicates resources and schedules them for execution on one of a plurality of execution units 2186A-2186N. Various types of execution units may exist, such as arithmetic logic units (ALUs), load and store units, vector processing units (VPUs), floating point execution units, and others. Results from these various execution units are provided to a reorder buffer (ROB) 2188, which takes unordered results and restores the correct program ordering.

Noch unter Bezugnahme auf 21 gilt es anzumerken, dass sowohl die Front-End-Einheit 2170 als auch die Reihenfolge nicht einhaltenden Maschine 2180 mit unterschiedlichen Ebenen einer Speicherhierarchie gekoppelt sind. Spezifisch dargestellt ist ein Anweisungsebenencache 2172, der wiederum mit einem Cache der mittleren Ebene 2176 gekoppelt ist, der wiederum mit einem Cache der letzten Ebene 2195 gekoppelt ist. In einer Ausführungsform ist der Cache der letzten Ebene 2195 in einer On-Chip- (manchmal als Uncore bezeichnet) Einheit 2190 implementiert ist. Beispielsweise ist Einheit 2190 ähnlich wie Systemagent 2010 aus 20. Wie oben erläutert kommuniziert Uncore 2190 mit Systemspeicher 2199, der in der veranschaulichten Ausführungsform mittels ED-RAM implementiert ist. Es gilt auch anzumerken, dass die verschiedenen Ausführungseinheiten 2186 innerhalb der die Reihenfolge nicht einhaltenden Maschine 2180 in Kommunikation mit einem Cache der ersten Ebene 2174 stehen, der auch in Kommunikation mit einem Cache der mittleren Ebene 2176 steht. Es gilt auch anzumerken, dass weitere Kerne 2130N-2 - 2130N mit LLC 2195 gekoppelt sein können. Obwohl in der Ausführungsform aus 21 in dieser hohen Ebene dargestellt, versteht sich, dass verschiedene Änderungen und weitere Komponenten vorhanden sein können.Still referring to 21 it should be noted that both the front-end unit 2170 and the out-of-order engine 2180 are coupled to different levels of a memory hierarchy. Specifically shown is an instruction level cache 2172 which in turn is coupled to a middle level cache 2176 which in turn is coupled to a top level cache 2195 . In one embodiment, the last level cache 2195 is implemented in an on-chip (sometimes referred to as an uncore) device 2190 . For example, Unit 2190 is similar to System agent 2010 off 20 . As explained above, uncore 2190 communicates with system memory 2199, which in the illustrated embodiment is implemented using ED-RAM. It should also be noted that the various execution units 2186 within the out-of-order engine 2180 are in communication with a first-level cache 2174 that is also in communication with a mid-level cache 2176 . It should also be noted that other cores 2130N-2 - 2130N may be coupled to LLC 2195 . Although in the embodiment off 21 Illustrated at this high level, it is understood that various modifications and additional components may be present.

Auf 22 Bezug nehmen ist ein Blockdiagramm eines beispielhaften Rechnersystems dargestellt, das mit einem Prozessor gebildet ist, der Ausführungseinheiten zur Ausführung einer Anweisung umfasst, wobei eine oder mehrere der Verbindungen ein oder mehrere Merkmale gemäß einer Ausführungsform der vorliegenden Erfindung aufweisen. System 2200 umfasst eine Komponente, wie z.B. einen Prozessor 2202, zur Anwendung von Ausführungseinheiten, einschließlich Logik zur Ausführung von Algorithmen für Prozessdaten gemäß der vorliegenden Erfindung, wie z.B. in der hierin beschriebenen Ausführungsform. System 2200 ist veranschaulichend für Verarbeitungssysteme basierend auf Mikroprozessoren PENTIUM III™, PENTIUM 4™, Xeon™, Itanium, XScale™ und/oder StrongARM™, obwohl auch andere Systeme verwendet werden können (einschließlich PCs mit anderen Mikroprozessoren, Entwicklungsworkstations, Beistellgeräte und dergleichen). In einer Ausführungsform führt ein Probengerät 2200 eine Version des Betriebssystems WINDOWS™ aus, das von Microsoft Corporation in Redmond, Washington, USA, erhältlich ist, obwohl auch andere Betriebssysteme (UNIX und Linux etwa), eingebettete Software und/oder graphische Benutzerschnittstellen verwendet werden können. Somit sind Ausführungsformen der vorliegenden Erfindung nicht auf eine bestimmte Kombination von Hardware-Schaltung und Software eingeschränkt.On 22 Referring to FIG. 1, a block diagram of an exemplary computing system formed with a processor including execution units for executing an instruction, one or more of the interconnects having one or more features in accordance with an embodiment of the present invention is shown. System 2200 includes a component, such as a processor 2202, for applying execution units including logic to perform algorithms on process data in accordance with the present invention, such as in the embodiment described herein. System 2200 is illustrative of processing systems based on PENTIUM III™, PENTIUM 4™, Xeon™, Itanium, XScale™ and/or StrongARM™ microprocessors, although other systems may be used (including personal computers with other microprocessors, development workstations, consoles and the like) . In one embodiment, a sample device 2200 runs a version of the WINDOWS™ operating system available from Microsoft Corporation of Redmond, Washington, USA, although other operating systems (such as UNIX and Linux), embedded software, and/or graphical user interfaces may be used . Thus, embodiments of the present invention are not limited to any particular combination of hardware circuitry and software.

Ausführungsformen sind nicht auf Rechensysteme eingeschränkt. Alternative Ausführungsformen der vorliegenden Erfindung können in anderen Vorrichtungen, wie etwa Handvorrichtungen und eingebetteten Anwendungen, verwendet werden. Einige Beispiele für Handvorrichtungen umfassen Mobiltelefone, Internetprotokollvorrichtungen, Digitalkameras, persönliche digitale Assistenten (PDAs) und Hand-PCs. Eingebettete Anwendungen können eine Mikrosteuerung, einen Digitalsignalprozessor (DSP), ein Ein-chip-System, NetzwerkRechner (NetPC), Beistellgeräte, NetzwerkHub, Weitverkehrsnetz- (WAN-) Schalter oder ein beliebiges anderes System, das eine oder mehrere Anweisungen gemäß zumindest einer Ausführungsform ausführen kann, umfassen.Embodiments are not limited to computing systems. Alternative embodiments of the present invention may be used in other devices, such as handheld devices and embedded applications. Some examples of handheld devices include cell phones, internet protocol devices, digital cameras, personal digital assistants (PDAs), and handheld PCs. Embedded applications may be a microcontroller, digital signal processor (DSP), system on chip, network computer (NetPC), set-top box, network hub, wide area network (WAN) switch, or any other system that implements one or more instructions according to at least one embodiment can perform include.

In dieser veranschaulichten Ausführungsform umfasst der Prozessor 2202 eine oder mehrere Ausführungseinheiten 2208 zur Implementierung eines Algorithmus, der zur Ausführung zumindest einer Anweisung dient. Eine Ausführungsform kann im Zusammenhang mit einem einzelnem Prozessortischgerät oder Serversystem beschrieben sein, aber alternative Ausführungsformen können in einem Mehrprozessorsystem enthalten sein. System 2200 ist ein Beispiel für eine „Hub“-Systemarchitektur. Das Rechensystem 2200 umfasst einen Prozessor 2202 zur Verarbeitung von Datensignalen. Der Prozessor 2202 kann in einem veranschaulichenden Beispiel etwa einen Mikroprozessor eines Rechners mit komplexem Anweisungssatz (CISC), einen Mikroprozessor eines Rechners mit reduziertem Anweisungssatz (RISC), einen Mikroprozessor für sehr lange Anweisungswörter (VLIW), einen Prozessor, der eine Kombination von Anweisungssätzen implementiert, oder eine beliebige andere Prozessorvorrichtung, wie z.B. einen Digitalsignalprozessor umfassen. Der Prozessor 2202 ist mit einem Prozessorbus 2210 gekoppelt, der Datensignale zwischen dem Prozessor 2202 und anderen Komponenten im System 2200 überträgt. Die Elemente von System 2200 (z.B. Grafikbeschleuniger 2212, Speichersteuerungs-Hub 2216, Speicher 2220, I/O-Steuerungs-Hub 2224, Drahtlossendeempfänger 2226, Flash-BIOS 2228, Netzwerk-Steuerung 2234, Audio-Steuerung 2236, serieller Erweiterungsanschluss 2238, I/O-Steuerung 2240 usw.) führen ihre herkömmlichen Funktionen aus, die Fachleuten auf dem Gebiet der Erfindung wohlbekannt sind.In this illustrated embodiment, the processor 2202 includes one or more execution units 2208 for implementing an algorithm to execute at least one instruction. An embodiment may be described in the context of a single processor desktop or server system, but alternative embodiments may be included in a multi-processor system. System 2200 is an example of a "hub" system architecture. The computing system 2200 includes a processor 2202 for processing data signals. Processor 2202 may, in one illustrative example, include a complex instruction set computer (CISC) microprocessor, a reduced instruction set computer (RISC) microprocessor, a very long instruction word (VLIW) microprocessor, a processor that implements a combination of instruction sets , or any other processor device such as a digital signal processor. The processor 2202 is coupled to a processor bus 2210 that transfers data signals between the processor 2202 and other components in the system 2200. The elements of system 2200 (e.g., graphics accelerator 2212, memory controller hub 2216, memory 2220, I/O controller hub 2224, wireless transceiver 2226, flash BIOS 2228, network controller 2234, audio controller 2236, serial expansion port 2238, I /O controller 2240, etc.) perform their conventional functions well known to those skilled in the art.

In einer Ausführungsform umfasst der Prozessor 2202 einen internen Level-1-(L1-) Cache-Speicher 2204. Je nach Architektur kann der Prozessor 2202 einen einzelnen internen Cache oder mehrere Ebenen von internen Caches aufweisen. Andere Ausführungsformen umfassen eine Kombination aus sowohl internen als auch externen Caches, je nach jeweiliger Implementierung und Anforderungen. Registerdatei 2206 dient zum Speichern von unterschiedlichen Arten von Daten in verschiedenen Registern, einschließlich Ganzzahlregistern, Gleitkommaregistern, Vektorregistern, Bank-Register, Schattenregister, Checkpoint-Register, Statusregister und Anweisungszeigerregister.In one embodiment, the processor 2202 includes an internal level 1 (L1) cache 2204. Depending on the architecture, the processor 2202 may have a single internal cache or multiple levels of internal caches. Other embodiments include a combination of both internal and external caches, depending on the particular implementation and requirements. Register file 2206 is used to store different types of data in various registers, including integer registers, floating point registers, vector registers, bank registers, shadow registers, checkpoint registers, status registers, and instruction pointer registers.

Ausführungseinheit 2208, einschließlich Logik zur Ausführung von Ganzzahl- und Gleitkommaoperationen, liegt ebenfalls im Prozessor 2202. Der Prozessor 2202 umfasst in einer Ausführungsform einen Mikrocode- (ucode-) ROM zum Speichern eines Mikrocodes, der bei Ausführung dazu dient, Algorithmen für bestimmte Makroanweisungen auszuführen oder komplexe Szenarien handzuhaben. Hier ist ein Mikrocode möglicherweise aktualisierbar, um Logikfehler/korrekturen für Prozessor 2202 handzuhaben. Bei einer Ausführungsform umfasst Ausführungseinheit 2208 Logik zur Abwicklung eines gepackten Anweisungssatzes 2209. Durch Aufnahme des gepackten Anweisungssatzes 2209 in den Anweisungssatz eines Allzweckprozessors 2202, gemeinsam mit einer zugeordneten Schaltung zur Ausführung der Anweisungen, können die von vielen Multimediaanwendungen verwendeten Operationen unter Verwendung von gepackten Daten in einem Allzweckprozessor 2202 ausgeführt werden. Somit werden viele Multimediaanwendungen beschleunigt und effizienter ausgeführt, indem die gesamte Breite eines Prozessordatenbusses zur Ausführung von Operationen an gepackten Daten verwendet wird. Dies hebt möglicherweise die Notwendigkeit auf, kleinere Dateneinheiten über den Prozessordatenbus zu übertragen, um eine oder mehrere Operationen, ein Element nach dem anderen auszuführen.Execution unit 2208, including logic for performing integer and floating point operations, also resides within processor 2202. Processor 2202, in one embodiment, includes microcode (ucode) ROM for storing microcode that, when executed, is used to execute algorithms for execute specific macro instructions or handle complex scenarios. Microcode here may be updatable to handle processor 2202 logic bugs/fixes. In one embodiment, execution unit 2208 includes logic for handling a packed instruction set 2209. By including the packed instruction set 2209 in the instruction set of a general purpose processor 2202, along with associated circuitry for executing the instructions, the operations used by many multimedia applications can be performed using packed data in executed on a 2202 general purpose processor. Thus, many multimedia applications are accelerated and run more efficiently by using the full width of a processor data bus to perform operations on packed data. This potentially eliminates the need to transfer smaller units of data across the processor data bus to perform one or more operations, one element at a time.

Alternative Ausführungsformen einer Ausführungseinheit 2208 können auch in Mikrosteuerungen, eingebetteten Prozessoren, Grafikvorrichtungen, DSPs und anderen Arten von Logikschaltungen eingesetzt werden. System 2200 umfasst einen Speicher 2220. Speicher 2220 umfasst eine dynamische Direktzugriffsspeicher- (DRAM-) Vorrichtung, eine statische Direktzugriffsspeicher- (SRAM-) Vorrichtung, Eine Flashspeichervorrichtung oder eine andere Speichervorrichtung. Speicher 2220 speichert Anweisungen und/oder Daten, die von Datensignalen dargestellt werden, die vom Prozessor 2202 auszuführen sind.Alternative embodiments of an execution unit 2208 may also be used in microcontrollers, embedded processors, graphics devices, DSPs, and other types of logic circuits. System 2200 includes memory 2220. Memory 2220 includes a dynamic random access memory (DRAM) device, a static random access memory (SRAM) device, a flash memory device, or other storage device. Memory 2220 stores instructions and/or data represented by data signals to be executed by processor 2202.

Es gilt anzumerken, dass beliebige der oben genannten Merkmale oder Aspekte der Erfindung an einer oder mehreren der in 22 dargestellten Verbindungen verwendet werden können. Beispielsweise können an einer nacktchipgetragenen Verbindung (ODI), die nicht dargestellt ist, zum Koppeln von internen Einheiten von Prozessor 2202 einer oder mehrere Aspekte der oben beschriebenen Erfindung implementiert werden. Oder die Erfindung ist einem Prozessorbus 2210 (z.B. einer andere bekannten Hochleistungsrechenverbindung), einem Speicherpfad mit hoher Bandbreite 2218 zu Speicher 2220, einer Punkt-zu-Punkt-Verbindung zu Grafikbeschleuniger 2212 (z.B. mit Peripherkomponentenverbindung-Express- (PCIe-) konformer Struktur), einer Steuerungs-Hubverbindung 2222, einer I/O- oder anderen Verbindung (z.B. USB, PCI, PCIe) zum Koppeln der anderen veranschaulichten Komponenten zugeordnet. Einige Beispiele für solche Komponenten umfassen die Audiosteuerung 2236, Firmware-Hub (Flash-BIOS) 2228, Drahtlossendeempfänger 2226, Datenspeicher 2224, Legacy-I/O-Steuerung 2210 enthaltende Benutzereingabe- und Tastaturschnittstellen 2242, einen seriellen Erweiterungsanschluss 2238, wie z.B. universellen seriellen Bus (USB), und eine Netzwerk-Steuerung 2234. Die Datenspeichervorrichtung 2224 kann eine Festplatte, eine Diskette, eine CD-ROM-Vorrichtung, eine Flashspeichervorrichtung oder eine andere Massenspeichervorrichtung umfassen.It should be noted that any of the above features or aspects of the invention can be derived from one or more of the 22 connections shown can be used. For example, one or more aspects of the invention described above may be implemented on a bare die carried (ODI) interconnect, not shown, for coupling internal units of processor 2202. Or the invention is a processor bus 2210 (e.g. other known high performance computing interconnect), a high bandwidth memory path 2218 to memory 2220, a point-to-point connection to graphics accelerator 2212 (e.g. with Peripheral Component Interconnect Express (PCIe) compliant structure) , a controller hub connection 2222, an I/O or other connection (eg, USB, PCI, PCIe) for coupling the other illustrated components. Some examples of such components include audio controller 2236, firmware hub (flash BIOS) 2228, wireless transceiver 2226, data storage 2224, legacy I/O controller 2210 containing user input and keyboard interfaces 2242, an expansion serial port 2238, such as universal serial bus (USB), and a network controller 2234. The data storage device 2224 may include a hard drive, floppy disk, CD-ROM device, flash memory device, or other mass storage device.

Auf 23 Bezug nehmen wird ein Blockdiagramm eines zweiten Systems 2300 gemäß einer Ausführungsform der vorliegenden Erfindung gezeigt. Wie in 23 dargestellt ist Multiprozessorsystem 2300 ein Punkt-zu-Punkt-Verbindungssystem und umfasst einen ersten Prozessor 2370 und einen zweiten Prozessor 2380, der über eine Punkt-zu-Punkt-Verbindung 2350 gekoppelt ist. Jeder der Prozessoren 2370 und 2380 kann eine Version eines Prozessors sein. In einer Ausführungsform sind 2352 und 2354 Teil einer seriellen, kohärenten Punkt-zu-Punkt-Struktur, wie z.B. einer Hochleistungsarchitektur. Als Ergebnis kann die Erfindung innerhalb der QPI-Architektur implementiert werden.On 23 Referring to FIG. 1, a block diagram of a second system 2300 is shown in accordance with an embodiment of the present invention. As in 23 Multiprocessor system 2300 is shown as a point-to-point connection system and includes a first processor 2370 and a second processor 2380 coupled via a point-to-point connection 2350 . Each of processors 2370 and 2380 may be a version of a processor. In one embodiment, 2352 and 2354 are part of a serial, point-to-point, coherent fabric, such as a high performance architecture. As a result, the invention can be implemented within the QPI architecture.

Währen nur zwei Prozessoren 2370, 2380 dargestellt sind, versteht sich, dass der Schutzumfang der vorliegenden Erfindung nicht darauf eingeschränkt ist. In anderen Ausführungsformen können ein oder mehrere weitere Prozessoren in einem gegebenen Prozessor enthalten sein.While only two processors 2370, 2380 are shown, it should be understood that the scope of the present invention is not so limited. In other embodiments, one or more other processors may be included in a given processor.

Prozessoren 2370 und 2380 sind mit integrierten Speichersteuerungseinheiten 2372 bzw. 2382 dargestellt. Prozessor 2370 umfass tauch als Teil seiner Bussteuerungseinheiten Punkt-zu-Punkt- (P-P-) Schnittstellen 2376 und 2378; auf ähnliche Weise umfasst der zweite Prozessor 2380 P-P-Schnittstellen 2386 und 2388. Prozessoren 2370, 2380 können Informationen über eine Punkt-zu-Punkt- (P-P-) Schnittstelle 2350 unter Verwendung von P-P-Schnittstellenschaltungen 2378, 2388 austauschen. Wie in 23 dargestellt koppeln IMCs 2372 und 2382 die Prozessoren mit entsprechenden Speichern, nämlich einem Speicher 2332 und einem Speicher 2334, die Teile eines Hauptspeichers sein können, der lokal an die entsprechenden Prozessoren angeschlossen ist.Processors 2370 and 2380 are shown with integrated memory controllers 2372 and 2382, respectively. Processor 2370 also includes as part of its bus control units point-to-point (PP) interfaces 2376 and 2378; similarly, the second processor 2380 includes PP interfaces 2386 and 2388. Processors 2370, 2380 may exchange information over a point-to-point (PP) interface 2350 using PP interface circuits 2378,2388. As in 23 IMCs 2372 and 2382 are shown coupling the processors to respective memories, namely memory 2332 and memory 2334, which may be portions of a main memory attached locally to the respective processors.

Prozessoren 2370, 2380 tauschen jeweils Informationen mit einem Chipsatz 2390 über einzelne P-P-Schnittstellen 2352, 2354 aus, unter Verwendung von Punkt-zu-Punkt-Schnittstellenschaltungen 2376, 2394, 2386, 2398. Chipsatz 2390 tauscht ebenfalls Informationen mit einer Hochleistungsgrafikschaltung 2338 über eine Schnittstellenschaltung 2392 über eine Hochleistungsgrafikverbindung 2339 aus.Processors 2370, 2380 each exchange information with a chipset 2390 via individual P-P interfaces 2352, 2354 using point-to-point interface circuits 2376, 2394, 2386, 2398. Chipset 2390 also exchanges information with a high performance graphics circuit 2338 via a interface circuit 2392 over a high performance graphics link 2339.

Ein geteilter Cache (nicht dargestellt) kann in einem Prozessor oder außerhalb beider Prozessoren enthalten sein; ebenfalls mit den Prozessoren über eine P-P-Verbindung verbunden, sodass lokale Cacheinformationen von einem der oder von beiden Prozessoren im geteilten Cache gespeichert werden können, wenn ein Prozessor in einen Niedrigenergiemodus gesetzt wird.A shared cache (not shown) may reside on one processor or external to both processors; also connected to the processors via a PP link so that local cache information from either or both processors can be stored in the shared cache when a processor is placed in a low power mode.

Chipsatz 2390 kann mit einem ersten Bus 2316 über eine Schnittstelle 2396 gekoppelt sein. In einer Ausführungsform kann der erste Bus 2316 ein Peripherkomponentenverbindungs- (PCI) Bus oder ein Bus wie ein PCI-Express-Bus oder ein anderer I/O-Verbindungsbus der dritten Generation sein, obwohl der Schutzumfang der vorliegenden Erfindung nicht darauf eingeschränkt ist.Chipset 2390 can be coupled to a first bus 2316 via an interface 2396 . In one embodiment, the first bus 2316 may be a peripheral component interconnect (PCI) bus or a bus such as a PCI Express bus or other third generation I/O interconnect bus, although the scope of the present invention is not so limited.

Wie in 23 dargestellt werden verschiedene I/O-Vorrichtungen 2314 mit dem ersten Bus 2316 gekoppelt, gemeinsam mit einer Busbrücke 2318, die einen ersten Bus 2316 mit einem zweiten Bus 2320 koppelt. In einer Ausführungsform umfasst der zweite Bus 2320 einen Bus mit geringer Pinzahl (LPC). Verschiedene Vorrichtungen werden mit dem zweiten Bus 2320 gekoppelt, einschließlich beispielsweise eine Tastatur und/oder Maus 2322, Kommunikationsvorrichtungen 2327 und eine Speichereinheit 2328, wie z.B. ein Diskettenlaufwerk oder eine andere Massenspeichervorrichtung, die häufig Anweisungen/Code und Daten 2330 enthält, in einer Ausführungsform. Ferner ist eine Audio-I/O 2324 dargestellt, die mit dem zweiten Bus 2320 gekoppelt ist. Es gilt anzumerken, dass andre Architekturen möglich sind, wenn die eingeschlossenen Komponenten und Zwischenverbindungsarchitekturen variieren. Beispielsweise kann anstelle der Punkt-zu-Punkt-Architektur aus 23 ein System einen Mehrpunktbus oder eine andere solche Architektur implementieren.As in 23 various I/O devices 2314 are shown coupled to the first bus 2316 along with a bus bridge 2318 coupling a first bus 2316 to a second bus 2320 . In one embodiment, the second bus 2320 comprises a low pin count (LPC) bus. Various devices are coupled to the second bus 2320, including, for example, a keyboard and/or mouse 2322, communication devices 2327, and a storage unit 2328 such as a floppy disk drive or other mass storage device, often containing instructions/code and data 2330, in one embodiment. An audio I/O 2324 coupled to the second bus 2320 is also shown. It should be noted that other architectures are possible if the components involved and interconnect architectures vary. For example, instead of the point-to-point architecture, 23 a system implementing a multidrop bus or other such architecture.

Als nächstes wird auf 24 Bezug nehmend eine Ausführungsform eines Ein-Chip-System- (SOC-) Designs gemäß den Erfindungen dargestellt. Als spezifisches veranschaulichendes Beispiel ist SOC 2400 in einem Benutzergerät (UE) enthalten. In einer Ausführungsform bezieht sich UE auf eine beliebige Vorrichtung, die von einem Endbenutzer zur Kommunikation zu verwenden ist, wie z.B. ein Handtelefon, Smartphone, Tablet, ultradünnes Notebook, Notebook mit Breitbandadapter oder eine beliebige andere ähnliche Kommunikationsvorrichtung. Häufig verbindet sich ein UE mit einer Basisstation oder einem Hub, die möglicherweise in ihrer Natur einer Mobilstation (MS) in einem GSM-Netzwerk entsprechen.Next is on 24 Referring to FIG. 1, an embodiment of a System on Chip (SOC) design according to the inventions is shown. As a specific illustrative example, SOC 2400 is included in a user equipment (UE). In one embodiment, UE refers to any device to be used by an end user to communicate, such as a handheld phone, smartphone, tablet, ultra-thin notebook, notebook with broadband adapter, or any other similar communication device. Often a UE connects to a base station or hub, which may correspond in nature to a mobile station (MS) in a GSM network.

Hier umfasst SOC 2400 2 Kerne - 2406 und 2407. Ähnlich wie oben erläutert können Kerne 2406 und 2407 mit einer Anweisungssatzarchitektur konform sein, wie z.B. einem Prozessor auf Basis eines Intel® Architektur Core™, einem Prozessor von Advanced Micro Devices, Inc. (AMD), einem Prozessor auf MIPS-Basis, einem Prozessor auf ARM-Basis oder einem Kunden sowie von Lizenznehmern oder Adoptern davon. Kerne 2406 und 2407 sind mit Cachesteuerung 2408 gekoppelt, die Bus-Schnittstelleneinheit 2409 und L2-Cache 2411 zugeordnet ist, um mit anderen teilen von System 2400 zu kommunizieren. Verbindung 2410 umfasst eine On-Chip-Verbindung, wie z.B. IOSF, AMBA, oder eine andere oben erläuterte Verbindung, die möglicherweise einen oder mehrere der hierin beschriebenen Aspekte implementiert.Here, SOC 2400 includes 2 cores - 2406 and 2407. Similar to the above, cores 2406 and 2407 may be compliant with an instruction set architecture, such as an Intel® Architecture Core™ based processor, an Advanced Micro Devices, Inc. (AMD ), a MIPS-based processor, an ARM-based processor or a customer, licensees or adopters thereof. Cores 2406 and 2407 are coupled to cache controller 2408 associated with bus interface unit 2409 and L2 cache 2411 to communicate with other parts of system 2400. Connection 2410 includes an on-chip connection, such as IOSF, AMBA, or other connection discussed above that may implement one or more aspects described herein.

Schnittstelle 2410 stellt Kommunikationskanäle für die anderen Komponenten bereit, wie z.B. ein Teilnehmeridentitätsmodul (SIM) 2430, um eine Schnittstelle mit einer SIM-Karte bereitzustellen, ein Boot-Rom 2435 zum Halten eines Boot-Codes zur Ausführung durch Kerne 2406 und 2407 zur Initialisierung und zum Booten von SOC 2400, eine SDRAM-Steuerung 2440 um eine Schnittstelle mit einem externen Speicher (e.g. DRAM 2460) bereitzustellen, eine Flashsteuerung 2445, um eine Schnittstelle mit einem nichtflüchtigen Speicher (z.B. Flash 2465) bereitzustellen, eine periphere Steuerung 2450 (z.B. serielle periphere Schnittstelle), um eine Schnittstelle mit Periphergeräten bereitzustellen. Videocodecs 2420 und Videoschnittstelle 2425, um Eingaben anzuzeigen und zu empfangen (e.g. Berührungseingabe), GPU 2415, um grafikbezogene Berechnungen auszuführen usw. Jede dieser Schnittstellen kann hierin beschriebene Aspekte der Erfindung inkorporieren.Interface 2410 provides communication channels for the other components, such as a Subscriber Identity Module (SIM) 2430 to interface with a SIM card, a boot ROM 2435 to hold boot code for execution by cores 2406 and 2407 for initialization and for booting SOC 2400, SDRAM controller 2440 to interface with external memory (e.g. DRAM 2460), Flash controller 2445 to interface with non-volatile memory (e.g. Flash 2465), peripheral controller 2450 (e.g. serial peripheral interface) to provide an interface with peripheral devices. video codecs 2420 and video interface 2425 to display and receive input (e.g. touch input), GPU 2415 to perform graphics-related computations, etc. Any of these interfaces may incorporate aspects of the invention described herein.

Darüber hinaus zeigt das System Periphergeräte zur Kommunikation, wie z.B. ein Bluetooth-Modul 2470, 3G-Modem 2475, GPS 2485 und WiFi 2485. Wie oben angemerkt gilt, dass ein UE Funk zur Kommunikation umfasst. Daher sind nicht alle dies peripheren Kommunikationsmodule erforderlich. In einem UE muss jedoch irgendeine Form von Funk zur externen Kommunikation enthalten sein.In addition, the system shows peripherals for communication, such as a Bluetooth module 2470, 3G modem 2475, GPS 2485, and WiFi 2485. As noted above, a UE includes radio for communication. Therefore, not all of these peripheral communication modules are required. However, some form of radio for external communication must be included in a UE.

Die vorliegende Erfindung wurde zwar in Bezug auf eine begrenzte Zahl von Ausführungsformen beschrieben, Fachleute auf dem Gebiet der Erfindung werden jedoch zahlreiche Modifikationen und Variationen davon kennen. Es ist vorgesehen, dass die beiliegenden Ansprüche alle solche Modifikationen und Variationen einschließen, die innerhalb des wahren Geists und Schutzumfangs der vorliegenden Erfindung liegen.While the present invention has been described in terms of a limited number of embodiments, those skilled in the art will recognize 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 the present invention.

Ein Design kann verschiedene Stufen durchlaufen, von der Schaffung über die Simulation bis hin zur Produktion. Daten, die ein Design darstellen, können das Design auf unterschiedliche Arten darstellen. Erstens kann, wie es bei Simulationen nützlich ist, die Hardware unter Verwendung einer Hardwarebeschreibungssprache oder einer anderen funktionellen Beschreibungssprache dargelegt werden. Außerdem kann ein Schaltungsebenenmodell mit Logik- und/oder Transistor-Gates in manchen Stufen des Designvorgangs erzeugt werden. Darüber hinaus erreichen die meisten Designs in einer Stufe eine Datenebene, welche die physische Platzierung von verschiedenen Vorrichtungen im Hardware-Modell darstellen. Wenn herkömmliche Halbleiterherstellungsverfahren eingesetzt werden, können die Daten, die das Hardware-Modell darstellen, die Daten sein, welche die Gegenwart oder Abwesenheit verschiedener Merkmale auf unterschiedlichen Masken schichten für Masken spezifizieren, die zur Herstellung der integrierten Schaltung eingesetzt werden. In jeder Darstellung des Designs könne die Daten in jeder beliebigen Form eines maschinenlesbaren Mediums gespeichert werden. Ein Internspeicher oder ein magnetischer oder optischer Speicher, wie z.B. eine Diskette, können das maschinenlesbare Medium zur Speicherung von Informationen sein, die ober optische oder elektrischen Wellen überragen werden, die moduliert oder auf anderen Weise zur Übertragung solcher Informationen erzeugt werden. Wenn eine elektrische Trägerwelle, die den Code oder das Design angibt oder trägt, übertragen wird, sodass Kopieren, Puffern oder eine Neuübertragung des elektrischen Signals durchgeführt wird, wird eine neue Kopie erstellt. Somit kann ein Kommunikationsprovider oder ein Netzwerkprovider auf einem flüchtigen, maschinenlesbaren Medium zumindest temporär einen Artikel, wie z.B. Informationen, die in einer Trägerwelle kodiert sind und die Techniken von Ausführungsformen der vorliegenden Erfindung darstellen, speichern.A design can go through different stages, from creation to simulation to production. Data representing a theme can represent the theme in different ways. First, as is useful in simulations, the hardware can be represented using a hardware description language or another functional description language. Additionally, a circuit level model with logic and/or transistor gates may be generated at some stages of the design process. In addition, most designs at some stage reach a data plane that represents the physical placement of various devices in the hardware model. When conventional semiconductor fabrication techniques are employed, the data representing the hardware model may be the data specifying the presence or absence of various features on different mask layers for masks used to fabricate the integrated circuit. In each representation of the design, the data can be stored in any form of machine-readable medium. Internal storage, or magnetic or optical storage such as a floppy disk, may be the machine-readable medium for storing information transmitted via optical or electrical waves that are modulated or otherwise generated to transmit such information. When an electrical carrier wave that indicates or carries the code or design is transmitted, so that copying, buffering, or retransmission of the electrical signal is performed, a new copy is made. Thus, a communications provider or a network provider may store on a transient, machine-readable medium, at least temporarily, an item, such as information, encoded in a carrier wave embodying techniques of embodiments of the present invention.

Ein Modul, wie hierin verwendet, steht für jede beliebige Kombination aus Hardware, Software und/oder Firmware. Beispielsweise umfasst ein Modul Hardware, wie z.B. eine Mikrosteuerung, die einem nichtflüchtigen Medium zugeordnet ist, um einen Code zu speichern, der angepasst ist, um von der Mikrosteuerung ausgeführt zu werden. Daher bezieht sich ein Verweis auf ein Modul in einer Ausführungsform auf die Hardware, die spezifisch konfiguriert ist, um den Code, der in einem nichtflüchtigen Medium gehalten wird, zu erkennen und/oder auszuführen. Ferner bezieht sich in einer weiteren Ausführungsform die Verwendung eines Moduls darauf, dass das nichtflüchtige Medium den Code enthält, der spezifisch angepasst ist, um von der Mikrosteuerung ausgeführt zu werden, um vorbestimmte Operationen auszuführen. Und wie abgeleitet werden kann sich in einer weiteren Ausführungsform die Bezeichnung Modul (in diesem Beispiel) auf die Kombination der Mikrosteuerung und des nichtflüchtigen Mediums beziehen. Herkömmlicherweise variieren Modulgrenzen, die als separat dargestellt sind, und überlappen sich möglicherweise. Beispielsweise können sich ein erstes und zweites Modul Hardware, Software, Firmware oder eine Kombination davon teilen, während möglicherweise manche Hardware, Software oder Firmware einbehalten wird. In einer Ausführungsform umfasst die Verwendung der Bezeichnung Logik Hardware, wie z.B. Transistoren, Register oder andere Hardware, wie z.B. programmierbare Logikvorrichtungen.A module, as used herein, means any combination of hardware, software, and/or firmware. For example, a module includes hardware, such as a microcontroller, associated with a non-transitory medium for storing code adapted to be executed by the microcontroller. Therefore, in one embodiment, a reference to a module refers to hardware that is specifically configured to recognize and/or execute code held in a non-transitory medium. Furthermore, in another embodiment, the use of a module refers to the non-transitory medium containing the code that is specifically adapted to be executed by the microcontroller to perform predetermined operations. And as can be deduced, in another embodiment, the term module (in this example) may refer to the combination of the microcontroller and the non-transitory medium. Conventionally, module boundaries presented as separate vary and may overlap. For example, a first and second module may share hardware, software, firmware, or a combination thereof, while possibly retaining some hardware, software, or firmware. In one embodiment, use of the term logic includes hardware such as transistors, registers, or other hardware such as programmable logic devices.

Die Verwendung der Phrase „konfiguriert, um“ bezieht sich in einer Ausführungsform auf die Anordnung, den Zusammenbau, die Herstellung, das Anbieten zum Verkauf, das Importieren und/oder das Entwerfen eines Geräts, einer Hardware, einer Logik oder eines Elements zur Ausführung einer bezeichneten oder bestimmten Aufgabe. In diesem Beispiel ist ein Gerät oder Element davon, das nicht läuft, trotzdem „konfiguriert, um“ eine bezeichnete Aufgabe auszuführen, wenn es entworfen, gekoppelt und/oder verbunden ist, um die bezeichnete Aufgabe auszuführen. Als rein veranschaulichendes Beispiel kann ein Logik-Gate eine 0 oder eine 1 während eines Betriebs bereitstellen. Aber ein Logikgatter, das „konfiguriert“ ist, um ein Einschaltsignal an einen Taktgeber bereitzustellen, umfasst nicht jedes mögliche Logikgatter, das eine 1 oder 0 bereitstellen kann. Stattdessen ist das Logikgatter eines, das so Weise gekoppelt ist, dass während des Betriebs die 1 oder 0 ausgegeben wird, um den Taktgeber einzuschalten. Es sei erneut darauf hingewiesen, dass die Verwendung der Bezeichnung „konfiguriert, um“ keinen Betrieb erfordert, sondern sich stattdessen auf den latenten Zustand eines Geräts, einer Hardware und/oder eines Elements konzentriert, wobei das Gerät, die Hardware und/oder das Element so entworfen ist, dass es im eine bestimmte Aufgabe ausführt, wenn das Gerät, die Hardware und/oder das Element in Betrieb ist.The use of the phrase "configured to," in one embodiment, refers to arranging, assembling, manufacturing, offering for sale, importing, and/or designing a device, hardware, logic, or element to perform a designated or specific task. In this example, a device or element thereof that is not running is nevertheless "configured to" perform a designated task if it is designed, paired, and/or connected to perform the designated task. As a purely illustrative example, a logic gate may provide a 0 or a 1 during operation. But a logic gate that is “configured” to provide an enable signal to a clock does not include every possible logic gate that can provide a 1 or 0. Instead, the logic gate is one that is coupled in such a way that, during operation, the 1 or 0 is output to turn on the clock. Again, the use of the term "configured to" does not imply an operation, but instead focuses on the latent state of a device, hardware, and/or item, where the device, hardware, and/or item is designed to perform a specific task when the device, hardware and/or item is in operation.

Ferner bezieht sich die Verwendung der Phrasen „um zu“, „in der Lage zu“ oder „betreibbar, um“ in einer Ausführungsform auf ein Gerät, eine Logik, eine Hardware und/oder ein Element, das entworfen ist, um die Verwendung des Geräts, der Logik, der Hardware und/oder des Elements auf eine bestimmte Weise zu ermöglichen. Wie oben sei darauf hingewiesen, dass die Verwendung von um zu, in der Lage zu, betreibbar, um, sich in einer Ausführungsform auf den latenten Zustand eines Geräts, einer Logik, einer Hardware und/oder eines Elements bezieht, wobei das Gerät, die Logik, die Hardware und/oder das Element nicht in Betrieb ist, aber so entworfen ist, dass es die Verwendung eines Geräts auf eine bestimmte Weise ermöglicht.Further, in one embodiment, use of the phrases "to," "capable of," or "operable to" refers to a device, logic, hardware, and/or element designed to enable use of the enable the device, logic, hardware and/or element in a specific way. As above, it should be noted that the use of to, able to, operable to, in one embodiment refers to the latent state of a device, logic, hardware, and/or element, where the device, the Logic, the hardware and/or element is not operational but is designed to allow a device to be used in a specific way.

Ein Wert wie hierin beschrieben umfasst jede beliebige bekannte Darstellung einer Zahl, eines Zustands, einer Logik oder eines binären logischen Zustands. Häufig wird die Verwendung von Logikebenen, Logikwerten oder logischen Werten auch als 1en und 0en bezeichnet, was einfach binäre logische Zustände darstellt. Beispielsweise steht eine 1 für einen hohen logischen Zustand und 0 für einen niedrigen logischen Zustand. In einer Ausführungsform kann eine Speicherzelle, wie z.B. eine Transistor- oder Flashzelle, in der Lage sein, einen einzigen logischen Wert oder mehrere logische Werte zu halten. Andere Darstellungen von Werten in Rechnersystemen wurden jedoch ebenfalls verwendet. Beispielsweise kann auch die Dezimalzahl zehn als binärer Wert von 1010 und als hexadezimaler Buchstabe A dargestellt sein. Daher umfasst ein Wert jede Darstellung von Informationen, die in einem Rechnersystem aufgenommen werden können.A value, as described herein, includes any known representation of a number, state, logic, or binary logic state. Often the use of logic levels, logic values, or logical values is also referred to as 1's and 0's, which simply represent binary logic states. For example, a 1 represents a high logic state and a 0 represents a low logic state. In one embodiment, a memory cell, such as a transistor or flash cell, may be capable of holding a single logical value or multiple logical values. However, other representations of values in computer systems have also been used. For example, the decimal number ten can also be represented as a binary value of 1010 and the letter A in hexadecimal. Thus, a value includes any representation of information that can be held in a computer system.

Darüber hinaus können Zustände durch Werte oder Teile von Werten repräsentiert werden. Als ein Beispiel kann ein erster Wert wie zum Beispiel ein logischer Wert einen Standard- oder Anfangszustand repräsentieren, während ein zweiter Wert, wie zum Beispiel logisch null, einen Nicht-Standardzustand repräsentieren kann. Zusätzlich dazu betreffen die Begriffe Rückstellung und Festsetzen in einer Ausführungsform einen Standardbeziehungsweise einen aktualisierten Wert oder Zustand. Zum Beispiel umfasst ein Standardwert potentiell einen hohen logischen Wert, d. h. eine Rückstellung, während ein aktualisierter Wert potentiell einen niedrigen logischen Wert umfasst, d.h. eine Festsetzung. Es ist zu beachten, dass eine beliebige Kombination von Werten genutzt werden kann, um eine beliebige Anzahl von Zuständen zu repräsentieren.In addition, states can be represented by values or parts of values. As an example, a first value, such as a logical value, may represent a default or initial state, while a second value, such as logical zero, may represent a non-default state. Additionally, in one embodiment, the terms reset and set refer to a default and updated value or state, respectively. For example, a default value potentially includes a high logical value, i. H. a reset, while an updated value potentially includes a low logic value, i.e., a fix. Note that any combination of values can be used to represent any number of states.

Die oben erläuterten Ausführungsformen von Verfahren, Hardware, Software, Firmware oder Code können über Anweisungen oder Code implementiert werden, die/der auf einem maschinenzugänglichen, maschinenlesbaren, computerzugänglichen oder computerlesbaren Medium gespeichert sind/ist, die/der von einem Verarbeitungselement ausgeführt werden können/kann. Ein nichtflüchtiges, maschinenzugängliches/-lesbares Medium umfasst jeglichen Mechanismus, der Informationen in einer Form bereitstellt (d. h. speichert und/oder überträgt), die von einer Maschine wie z. B. einem Computer oder elektronischen System lesbar ist. Zum Beispiel umfasst ein nichtflüchtiges, maschinenzugängliches Medium Direktzugriffspeicher (RAM) wie zum Beispiel statische RAM (SRAM) oder dynamische RAM (DRAM); ROM; ein magnetisches oder optisches Speichermedium; Flash-Speichervorrichtungen; elektrische Speichervorrichtungen; optische Speichervorrichtungen; akustische Speichervorrichtungen; andere Formen von Speichervorrichtungen, um Informationen festzuhalten, die von vorübergehenden (sich ausbreitenden) Signalen (z. B. Trägerwellen, Infrarotsignalen, digitalen Signalen) empfangen wurden; etc., die von den nichtflüchtigen Medien zu unterscheiden sind, die Informationen von diesen empfangen können.The method, hardware, software, firmware, or code embodiments discussed above may be implemented via instructions or code stored on a machine-accessible, machine-readable, computer-accessible, or computer-readable medium, executable by a processing element can. A non-transitory machine-accessible/readable medium includes any mechanism that provides (i.e., stores and/or transmits) information in a form readable by a machine, such as a computer. B. a computer or electronic system is readable. For example, a non-volatile, machine-accessible medium includes random access memory (RAM), such as static RAM (SRAM) or dynamic RAM (DRAM); ROME; a magnetic or optical storage medium; flash memory devices; electrical storage devices; optical storage devices; acoustic storage devices; other forms of storage devices to retain information received from transient (propagating) signals (e.g., carrier waves, infrared signals, digital signals); etc., to be distinguished from the non-volatile media capable of receiving information from them.

Anweisungen, die verwendet werden, um Logik zu programmieren, um Ausführungsformen der Erfindung durchzuführen, können innerhalb eines Speichers in dem System wie z. B. einem DRAM, Cache, Flash-Speicher oder anderen Speicher gespeichert sein. Darüber hinaus können die Anweisungen über ein Netzwerk oder mittels anderer computerlesbarer Medien gesendet werden. Daher kann ein maschinenlesbares Medium einen beliebigen Mechanismus umfassen, um Informationen in einer Form zu speichern oder zu übertragen, die von einer Maschine (z. B. einem Computer) lesbar ist, ist aber nicht beschränkt auf Disketten, optische Datenträger, Compact-Disc-Festwertspeicher (CD-ROMs), und magneto-optische Datenträger, Festwertspeicher (ROMs), Direktzugriffspeicher (RAM), löschbare programmierbare Festwertspeicher (EPROM), elektrisch löschbare programmierbare Festwertspeicher (EEPROM), magnetische oder optische Karten, Flash-Speicher oder einen physischen, maschinenlesbaren Speicher, der bei der Übertragung von Informationen über das Internet mittels elektrischen, optischen, akustischen oder anderen Formen von sich ausbreitenden Signalen (z. B. Trägerwellen, Infrarotsignalen, digitalen Signalen usw.) verwendet wird. Dementsprechend umfasst ein computerlesbares Medium jegliche Art maschinenlesbares Medium, das dazu geeignet ist, elektronische Anweisungen oder Informationen in einer von einer Maschine (z. B. einem Computer) lesbaren Form zu speichern oder zu übertragen.Instructions used to program logic to perform embodiments of the invention may reside within memory in the system, such as a memory. B. a DRAM, cache, flash memory or other memory can be stored. Additionally, the instructions may be sent over a network or other computer-readable media. Therefore, a machine-readable medium may include any mechanism to store or transmit information in a form that is readable by a machine (e.g., a computer), but is not limited to floppy disks, optical disks, compact disc Read-only memories (CD-ROMs), and magneto-optical data carriers, read-only memories (ROMs), random access memories (RAM), erasable programmable read-only memories (EPROM), electrically erasable programmable read-only memories (EEPROM), magnetic or optical cards, flash memory or a physical, machine-readable storage used in the transmission of information over the Internet using electrical, optical, acoustic or other forms of propagated signals (e.g., carrier waves, infrared signals, digital signals, etc.). Accordingly, a computer-readable medium includes any type of machine-readable medium capable of storing or transmitting electronic instructions or information in a machine (e.g., computer) readable form.

Die folgenden Beispiele betreffen Ausführungsformen, die mit dieser Beschreibung in Einklang sind. Eine oder mehrere Ausführungsformen können eine Vorrichtung, ein System, einen maschinenlesbaren Speicher, ein maschinenlesbares Medium, hardware- und/oder softwarebasierte Logik sowie ein Verfahren umfassen, um Daten auf einer oder mehreren Datenbahnen einer physikalischen Verbindung zu empfangen, ein gültiges Signal auf einer weiteren der Bahnen der physikalischen Verbindung zu empfangen, welches identifiziert, dass gültige Daten der Zusicherung des gültigen Signals auf der einen oder mehreren Datenbahnen nachfolgen sollen, und um ein Datenstromsignal auf einer weiteren der Bahnen der physikalischen Verbindung zu empfangen, welches eine Art der Daten auf der einen oder mehreren Datenbahnen identifiziert.The following examples relate to embodiments consistent with this description. One or more embodiments may include an apparatus, system, machine-readable memory, machine-readable medium, hardware and/or software-based logic, and method for receiving data on one or more data lanes of one physical connection, a valid signal on another of the lanes of the physical link identifying that valid data is to follow the assertion of the valid signal on the one or more data lanes, and to receive a data stream signal on another of the lanes of the physical link identifying a type of the data on the identified one or more lanes.

In zumindest einem Beispiel soll die Logik der physikalischen Schicht ferner ein Verbindungszustandsmaschinen-Verwaltungssignal über eine weitere der Bahnen der physikalischen Verbindung senden.In at least one example, the physical layer logic is also to send a link state machine management signal over another of the lanes of the physical link.

In zumindest einem Beispiel soll die Logik der physikalischen Schicht ferner ein Seitenbandsignal über eine Seitenbandverbindung senden.In at least one example, the physical layer logic is further to transmit a sideband signal over a sideband link.

In zumindest einem Beispiel umfasst die Art ein Protokoll, das den Daten zugeordnet ist, wobei das Protokoll eines aus einer Vielzahl von Protokollen ist, welche die physikalische Verbindung nutzen.In at least one example, the type includes a protocol associated with the data, where the protocol is one of a variety of protocols that utilize the physical connection.

In zumindest einem Beispiel umfasst die Art Verbindungsschichtpaketdaten.In at least one example, the type includes link layer packet data.

In zumindest einem Beispiel sollen die Daten Verbindungszustandsübergänge für die physikalische Verbindung ermöglichen.In at least one example, the data is intended to enable link state transitions for the physical link.

In zumindest einem Beispiel soll die Logik der physikalischen Schicht ferner das Datenstromsignal dekodieren, um zu identifizieren, welches einer Vielzahl unterschiedlicher Protokolle auf die Daten zutrifft.In at least one example, the physical layer logic is further to decode the data stream signal to identify which of a plurality of different protocols the data applies to.

In zumindest einem Beispiel soll die physikalische Schicht die Daten ferner an Oberschichtprotokolllogik weiterleiten, die einem bestimmten einen der in dem Datenstromsignal identifizierten Vielzahl von Protokollen entspricht.In at least one example, the physical layer is to further forward the data to upper layer protocol logic conforming to a particular one of the plurality of protocols identified in the data stream signal.

In zumindest einem Beispiel umfasst die Vorrichtung zusätzlich zu der physikalischen Schichtlogik Verbindungsschichtlogik und andere Oberschichtlogik jedes der Vielzahl von Protokollen.In at least one example, the device includes, in addition to the physical layer logic, link layer logic and other upper layer logic of each of the plurality of protocols.

In zumindest einem Beispiel umfasst die Vielzahl von Protokollen zumindest zwei aus einer Peripherkomponentenverbindung (PCI), PCI-Expressverbindung (PCIe), Intel-In-Die-Verbindung (IDI), und Quick-Path-Verbindung (QPI).In at least one example, the plurality of protocols includes at least two of Peripheral Component Interconnect (PCI), PCI Express Interconnect (PCIe), Intel In-Die Interconnect (IDI), and Quick Path Interconnect (QPI).

In zumindest einem Beispiel soll die Logik der physikalischen Schicht ferner Fehler in jedem der Vielzahl von Protokollen bestimmen.In at least one example, the physical layer logic is to further determine errors in each of the plurality of protocols.

In zumindest einem Beispiel soll die Logik der physikalischen Schicht ferner Fehler in einem oder mehreren aus dem gültigen Signal und dem Datenstromsignal bestimmen.In at least one example, the physical layer logic is to further determine errors in one or more of the valid signal and the data stream signal.

In zumindest einem Beispiel soll die Logik der physikalischen Schicht ferner ein Datenfenster für auf den Datenbahnen zu sendende Daten definieren, und das Datenfenster entspricht dem gültigen Signal.In at least one example, the physical layer logic shall further define a data window for data to be sent on the data lanes, and the data window corresponds to the valid signal.

In zumindest einem Beispiel entspricht das Datenfenster einem Datensymbol, und das gültige Datensignal soll in einem Fenster zugesichert werden, das dem Fenster, in dem die Daten gesendet werden sollen, direkt vorausgeht.In at least one example, the data window corresponds to a data symbol, and the valid data signal is to be asserted in a window immediately preceding the window in which the data is to be sent.

In zumindest einem Beispiel sollen Daten auf Datenbahnen in einem Fenster, das einem vorausgehenden Fenster direkt nachfolgt, in dem das gültige Signal nicht zugesichert ist, ignoriert werden.In at least one example, data on data lanes in a window immediately following a preceding window in which the valid signal is not asserted should be ignored.

In zumindest einem Beispiel entspricht das Fenster einer Byte-Zeitdauer.In at least one example, the window corresponds to a byte period.

In zumindest einem Beispiel wird jedes aus dem gültigen Datensignal, Daten und dem Datenstromsignal gemäß für die physikalische Verbindung definierten Datenfenstern abgeglichen.In at least one example, each of the valid data signal, data, and the data stream signal is matched according to data windows defined for the physical link.

In zumindest einem Beispiel soll das Datenstromsignal während desselben Fensters wie die Daten gesendet werden.In at least one example, the data stream signal is intended to be sent during the same window as the data.

In zumindest einem Beispiel verbindet die physikalische Verbindung zwei Vorrichtungen in einem Mehrchipgehäuse.In at least one example, the physical connection connects two devices in a multi-chip package.

In zumindest einem Beispiel soll die physikalische Schicht ferner Signale auf den Bahnen der physikalischen Verbindung neu zentrieren.In at least one example, the physical layer is also intended to re-center signals on the lanes of the physical link.

In zumindest einem Beispiel sollen die Bahnen basierend auf dem gültigen Signal neu zentriert werden.In at least one example, the lanes are to be re-centered based on the valid signal.

In zumindest einem Beispiel wird ein Datenstromsignal auf einer dedizierten Datenstromsignalbahn der Datenverbindung während eines zweiten Fensters empfangen, das Datenstromsignal wird dekodiert und ein Protokoll, das den Daten zugeordnet ist, wird aus dem Dekodieren des Datenstromsignals bestimmt.In at least one example, a data stream signal is received on a dedicated data stream signal path of the data connection during a second window, the data stream signal is decoded, and a protocol associated with the data is determined from the decoding of the data stream signal.

In zumindest einem Beispiel ist die Datenverbindung geeignet, um Daten einer Vielzahl unterschiedlicher Protokolle zu übertragen.In at least one example, the data link is capable of transmitting data of a variety of different protocols.

In zumindest einem Beispiel werden Daten identifiziert, die auf der Datenverbindung gesendet werden sollen, ein gültiges Signal wird während eines bestimmten Zeitfensters, welches den zu sendenden Daten entspricht, auf einer ausgehenden gültigen Signalbahn der Datenverbindung gesendet, und die Daten werden während eines weiteren Fensters, das dem bestimmten Fenster direkt nachfolgt, auf dedizierten ausgehenden Datenbahnen gesendet.In at least one example, data is identified to be sent on the data link, a valid signal is sent on an outgoing valid signal lane of the data link during a particular time window corresponding to the data to be sent, and the data is sent during another window, immediately succeeding the particular window is sent on dedicated outbound lanes.

In zumindest einem Beispiel umfasst die Vielzahl von Datenbahnen ferner eine dedizierte Verbindungszustandsmaschinen-Seitenbandbahn.In at least one example, the plurality of data lanes further includes a dedicated connection state machine sideband lane.

In zumindest einem Beispiel umfasst die erste Vorrichtung einen ersten Nacktchip in einem Gehäuse, und die zweite Vorrichtung umfasst einen zweiten Nacktchip in dem Gehäuse.In at least one example, the first device includes a first die in a package and the second device includes a second die in the package.

In zumindest einem Beispiel umfasst die erste Vorrichtung eine Vorrichtung auf dem Gehäuse, und die zweite Vorrichtung umfasst eine Vorrichtung, die nicht auf dem Gehäuse ist.In at least one example, the first device comprises a device on the housing and the second device comprises a device that is not on the housing.

Eine oder mehrere Ausführungsformen können eine Vorrichtung, ein System, einen maschinenlesbaren Speicher, ein maschinenlesbares Medium, hardware- und/oder softwarebasierte Logik sowie ein Verfahren bereitstellen, um Daten zu identifizieren, die auf dedizierten Datenbahnen einer Datenverbindung gesendet werden sollen, um während eines bestimmten Fensters, welches auf der Datenverbindung zu sendenden Daten entspricht, ein gültiges Signal auf einer dedizierten gültigen Signalbahn der Datenverbindung zu senden, um die Daten während eines weiteren Fensters, das dem bestimmten Fenster direkt nachfolgt, auf dedizierten Datenbahnen der Datenverbindung zu senden, und um ein Datenstromsignal auf einer Datenstromsignalverbindung zu senden, die kodiert ist, um eine Art der Daten zu identifizieren.One or more embodiments may provide an apparatus, system, machine-readable memory, machine-readable medium, hardware and/or software-based logic, and method for identifying data to be sent on dedicated data lanes of a data connection in order to during a particular window corresponding to data to be sent on the data link, to send a valid signal on a dedicated valid signal lane of the data link, to send the data on dedicated lanes of the data link during a further window immediately following the particular window, and to send a To send a data stream signal on a data stream signal link that is encoded to identify a type of data.

In zumindest einem Beispiel soll das gültige Signal angeben, dass Daten auf den Datenbahnen während des anderen Fensters gültige Daten sind.In at least one example, the valid signal is intended to indicate that data on the data lanes is valid data during the other window.

In zumindest einem Beispiel umfasst die Datenstromsignalverbindung eine dedizierte Datenstromsignalverbindung.In at least one example, the data streaming signal connection comprises a dedicated data streaming signal connection.

In zumindest einem Beispiel ist das Datenstromsignal geeignet, um zu identifizieren, ob den Daten ein bestimmtes Protokoll zugeordnet ist.In at least one example, the data stream signal is operable to identify whether a particular protocol is associated with the data.

In zumindest einem Beispiel ist die Logik der physikalischen Schicht in einer gemeinsamen physikalischen Schicht umfasst, und eine Vielzahl von Protokollen nutzt die gemeinsame physikalische Schicht, und das bestimmte Protokoll ist in der Vielzahl von Protokollen umfasst.In at least one example, the physical layer logic is included in a common physical layer, and a plurality of protocols share the common physical layer, and the particular protocol is included in the plurality of protocols.

In zumindest einem Beispiel umfasst die Vielzahl von Protokollen zwei oder mehr aus PCI, PCIe, IDI und QPI.In at least one example, the plurality of protocols includes two or more of PCI, PCIe, IDI, and QPI.

In zumindest einem Beispiel ist das Datenstromsignal ferner geeignet, um zu identifizieren, ob die Daten Verbindungsschichtpakete umfassen.In at least one example, the data stream signal is further adapted to identify whether the data comprises link layer packets.

In zumindest einem Beispiel ist das Datenstromsignal ferner geeignet, um zu identifizieren, ob die Seitenbanddaten.In at least one example, the data stream signal is further adapted to identify whether the sideband data.

In zumindest einem Beispiel soll die Logik der physikalischen Schicht ferner den Datenart bestimmen und das Datenstromsignal kodieren, um die bestimmte Art zu identifizieren.In at least one example, the physical layer logic is to further determine the data type and encode the data stream signal to identify the particular type.

In zumindest einem Beispiel soll die physikalische Schicht ferner Verbindungszustandsmaschine-Seitenband- (LSM_SB-) Signale auf einer dedizierten LSM_SB-Bahn der Datenverbindung senden.In at least one example, the physical layer shall also send link state machine sideband (LSM_SB) signals on a dedicated LSM_SB lane of the data link.

In zumindest einem Beispiel soll die Logik der physikalischen Schicht ferner Seitenbandsignale auf einer von der Datenverbindung getrennten Seitenbandverbindung senden.In at least one example, the physical layer logic is also to transmit sideband signals on a separate sideband link from the data link.

In zumindest einem Beispiel soll die physikalische Schicht ferner Verbindungsschichtdaten auf den Datenbahnen senden, wobei die Verbindungsschichtdaten verwendet werden, um die Datenverbindung von einem ersten Verbindungszustand in einen zweiten Verbindungszustand überzuführen.In at least one example, the physical layer is also to transmit link layer data on the data lanes, the link layer data being used to transition the data link from a first connection state to a second connection state.

In zumindest einem Beispiel umfasst der erste Verbindungszustand einen aktiven Verbindungszustand, und der zweite Verbindungszustand umfasst einen Niedrigenergieverbindungszustand.In at least one example, the first connection state comprises an active connection state and the second connection state comprises a low power connection state.

In zumindest einem Beispiel soll die Logik der physikalischen Schicht ferner ein erstes Datenfenster identifizieren, das dem gültigen Signal entspricht, und die Daten auf den Datenbahnen innerhalb eines zweiten Datenfensters senden, das dem ersten Datenfenster direkt nachfolgt.In at least one example, the physical layer logic is further to identify a first data window that corresponds to the valid signal and transmit the data on the data lanes within a second data window that immediately follows the first data window.

In zumindest einem Beispiel gibt das Nichtzusichern des gültigen Signals an, dass Daten auf den Datenbahnen in einem direkt nachfolgenden Fenster als ungültig ignoriert werden sollen.In at least one example, failing to assert the valid signal indicates that data on the data lanes should be ignored as invalid in an immediately subsequent window.

In zumindest einem Beispiel ist jedes aus dem ersten und dem zweiten Datenfenster definiert, um einer Byte-Zeitdauer zu entsprechen.In at least one example, each of the first and second data windows is defined to correspond to a byte period.

In zumindest einem Beispiel werden jedes aus dem gültigen Signal, Daten und dem Datenstromsignal gemäß den für die physikalische Verbindung definierten Datenfenstern abgeglichen.In at least one example, each of the valid signal, data, and data stream signal are matched according to the data windows defined for the physical connection.

In zumindest einem Beispiel soll das Datenstromsignal während desselben Fensters wie die Daten gesendet werden.In at least one example, the data stream signal is intended to be sent during the same window as the data.

In zumindest einem Beispiel soll die physikalische Schicht ferner jedes des gültigen und des Datenstromsignals erzeugen.In at least one example, the physical layer is further to generate each of the valid and stream signals.

In zumindest einem Beispiel verbindet die Datenverbindung zwei Vorrichtungen in einem Mehrchipgehäuse.In at least one example, the data link connects two devices in a multi-chip package.

In zumindest einem Beispiel soll die Datenverbindung Datengeschwindigkeiten über 8 Gb/s unterstützen.In at least one example, the data link is intended to support data speeds in excess of 8 Gb/s.

Eine oder mehrere Ausführungsformen können eine Vorrichtung, ein System, einen maschinenlesbaren Speicher, ein maschinenlesbares Medium, hardware- und/oder softwarebasierte Logik sowie ein Verfahren bereitstellen, um eine einseitige Signalübertragung auf einer Datenverbindung bereitzustellen, die eine Vielzahl von Bahnen umfasst, welche eine Vielzahl von Datenbahnen, eine oder mehrere gültige Signalbahnen, eine oder mehrere Datenstrombahnen umfassen, und um ein Taktsignal zur Verwendung durch die Vielzahl von Bahnen zu senden, wobei Signale, die auf jeder der Vielzahl von Bahnen gesendet werden, mit dem Taktsignal abgeglichen sein sollen.One or more embodiments may provide an apparatus, system, machine-readable memory, machine-readable medium, hardware and/or software-based logic, and method for providing unidirectional signaling on a data link that includes a plurality of lanes that include a plurality of data lanes, one or more valid signal lanes, one or more data stream lanes, and to transmit a clock signal for use by the plurality of lanes, wherein signals transmitted on each of the plurality of lanes are to be aligned with the clock signal.

In zumindest einem Beispiel wird jede der Datenbahnen in der Mitte der Bahn auf eine regulierte Spannung terminiert.In at least one example, each of the data lanes is terminated to a regulated voltage at the center of the lane.

In zumindest einem Beispiel wird die regulierte Spannung für jede der Vielzahl von Datenbahnen von einem einzigen Spannungsregler bereitgestellt.In at least one example, the regulated voltage for each of the plurality of data lanes is provided by a single voltage regulator.

In zumindest einem Beispiel ist die regulierte Spannung im Wesentlichen gleich Vcc/2, wobei Vcc eine Versorgungsspannung umfasst.In at least one example, the regulated voltage is substantially equal to Vcc/2, where Vcc includes a supply voltage.

In zumindest einem Beispiel soll die Logik der physikalischen Schicht versuchen, eine Übersprechunterdrückung zwischen zwei oder mehr der Vielzahl von Datenbahnen bereitzustellen.In at least one example, the physical layer logic shall attempt to provide crosstalk rejection between two or more of the plurality of data lanes.

In zumindest einem Beispiel wird eine Übersprechunterdrückung bereitgestellt, indem ein gewichtetes hochpassgefiltertes Aggressorsignal auf einer ersten der zwei oder mehr Datenbahnen zu dem Signal einer zweiten der zwei oder mehr Datenbahnen hinzugefügt wird.In at least one example, crosstalk cancellation is provided by adding a weighted high-pass filtered aggressor signal on a first of the two or more data lanes to the signal on a second of the two or more data lanes.

In zumindest einem Beispiel soll die Logik der physikalischen Schicht das gewichtete hochpassgefilterte Aggressorsignal zumindest teilweise unter Verwendung eines Widerstand-Kondensator- (RC-) Tiefpassfilters erzeugen.In at least one example, the physical layer logic is to generate the weighted high-pass filtered aggressor signal using at least part of a resistor-capacitor (RC) low-pass filter.

In zumindest einem Beispiel soll die Logik der physikalischen Schicht eine Pro-Bit-Arbeitszykluskorrektur bereitstellen.In at least one example, the physical layer logic is to provide per-bit duty cycle correction.

In zumindest einem Beispiel soll die Logik der physikalischen Schicht Laufzeitverschiebungen auf zumindest einer bestimmten der Datenbahnen detektieren und die Laufzeitverschiebungen auf der bestimmten Datenbahn entfernen.In at least one example, the physical layer logic is to detect skews on at least a particular one of the data lanes and remove the skews on the particular data lane.

In zumindest einem Beispiel soll die Logik der physikalischen Schicht ferner eine AC-Datenbusinversion (DBI) auf zumindest eine der Datenbahnen anwenden.In at least one example, the physical layer logic shall further apply AC data bus inversion (DBI) to at least one of the data lanes.

In zumindest einem Beispiel umfasst das Taktsignal ein Halbraten-Vorwärtstaktsignal.In at least one example, the clock signal comprises a half-rate forward clock signal.

In zumindest einem Beispiel soll die Logik der physikalischen Schicht ferner elektrostatischen Entladungsschutz bereitstellen.In at least one example, the physical layer logic is to further provide ESD protection.

In zumindest einem Beispiel ist die Logik der physikalischen Schicht zumindest teilweise durch Hardwareschaltungen implementiert.In at least one example, the physical layer logic is implemented at least in part by hardware circuitry.

In zumindest einem Beispiel sollen gültige Signale auf den gültigen Signalbahnen übertragen werden, und jedes gültige Signal identifiziert, dass gültige Daten der Zusicherung des gültigen Signals auf der Vielzahl von Datenbahnen nachfolgen sollen, und Datenstromsignale sollen auf den Datenstromsignalbahnen übertragen werden, und jedes Datenstromsignal identifiziert eine Art der Daten auf den einen oder mehreren Datenbahnen.In at least one example, valid signals are to be carried on the valid signal lanes, and each valid signal identifies that valid data is to follow the assertion of the valid signal on the plurality of data lanes, and data stream signals are to be carried on the data stream signal lanes, and each data stream signal identifies one Type of data on the one or more data lanes.

In zumindest einem Beispiel, soll die Datenverbindung Datengeschwindigkeiten über 8 Gb/s unterstützen.In at least one example, the data connection shall support data speeds in excess of 8 Gb/s.

Eine oder mehrere Ausführungsformen können eine Vorrichtung, ein System, einen maschinenlesbaren Speicher, ein maschinenlesbares Medium, hardware- und/oder softwarebasierte Logik sowie ein Verfahren bereitstellen, um eine einseitige Signalübertragung auf einer Datenverbindung bereitzustellen, die eine Vielzahl von Bahnen umfasst, welche eine Vielzahl von Datenbahnen, eine oder mehrere gültige Signalbahnen, eine oder mehrere Datenstrombahnen und ein oder mehrere Verbindungszustandsmaschinen-Seitenbandbahnen umfassen, um ein Taktsignal zur Verwendung durch die Vielzahl von Bahnen zu senden, wobei Signale, die auf jeder der Vielzahl von Bahnen gesendet werden, mit dem Taktsignal abgeglichen sein sollen, um eine Übersprechunterdrückung zwischen zwei oder mehr aus der Vielzahl von Datenbahnen bereitzustellen, und um eine Pro-Bit-Arbeitszykluskorrektur für die Datenverbindung bereitzustellen, wobei jede der Datenbahnen in der Mitte der Bahn auf eine regulierte Spannung terminiert wird.One or more embodiments may provide an apparatus, system, machine-readable memory, machine-readable medium, hardware and/or software-based logic, and method for providing unidirectional signaling on a data link that includes a plurality of lanes that include a plurality of data lanes, one or more valid signal lanes, one or more data stream lanes, and one or more connection state machine sideband lanes to transmit a clock signal for use by the plurality of lanes, wherein signals transmitted on each of the plurality of lanes are associated with the clock signals are to be balanced to provide crosstalk rejection between two or more of the plurality of data lanes and to provide per-bit duty cycle correction for the data link, with each of the data lanes being terminated to a regulated voltage midway through the lane.

In zumindest einem Beispiel soll die Logik der physikalischen Schicht ferner Laufzeitverschiebungen auf zumindest einer bestimmten der Datenbahnen detektieren und die Laufzeitverschiebung der bestimmten Datenbahn entfernen.In at least one example, the physical layer logic is further to detect skews on at least a particular one of the data lanes and remove the skew of the particular data lane.

Eine oder mehrere Ausführungsformen können eine Vorrichtung, ein System, einen maschinenlesbaren Speicher, ein maschinenlesbares Medium, hardware- und/oder softwarebasierte Logik sowie ein Verfahren bereitstellen, um zu identifizieren, dass jeweilige obere Schichten jedes einer Vielzahl von geschichteten Protokollen einen Übergang einer Datenverbindung von einem aktiven Verbindungszustand in einen Niedrigenergieverbindungszustand anfordern, wobei jedes der Vielzahl von geschichteten Protokollen die Datenverbindung als physikalische Schicht nutzen soll, und um die Datenverbindung von dem aktiven Verbindungszustand in den Niedrigenergieverbindungszustand basierend auf einer Identifikation überzuführen, dass die oberen Schichten jedes der Vielzahl von geschichteten Protokollen einen Übergang zu dem Niedrigenergieverbindungszustand anfordert.One or more embodiments may provide an apparatus, system, machine-readable memory, machine-readable medium, hardware and/or software-based logic, and method to identify that respective upper layers of each of a plurality of layered protocols transition a data connection from request an active link state to a low power link state, wherein each of the plurality of layered protocols is to use the data link as a physical layer, and to transition the data link from the active link state to the low power link state based on an identification that the upper layers of each of the plurality of layered protocols requests a transition to the low power connection state.

In zumindest einem Beispiel soll die Logik der physikalischen Schicht ferner an einem Handshake mit anderen Vorrichtungen teilnehmen, um zu bewirken, dass die Datenverbindung in den Niedrigenergieverbindungszustand übergeht.In at least one example, the physical layer logic shall further participate in a handshake with other devices to cause the data link to transition to the low power link state.

In zumindest einem Beispiel umfasst der Handshake einen Verbindungsschicht-Handshake.In at least one example, the handshake comprises a link layer handshake.

In zumindest einem Beispiel soll die Logik der physikalischen Schicht Verbindungsschichtdaten in dem Verbindungsschicht-Handshake senden, während die Datenverbindung in dem aktiven Verbindungszustand ist.In at least one example, the physical layer logic is to send link layer data in the link layer handshake while the data link is in the link active state.

In zumindest einem Beispiel soll die Logik der physikalischen Schicht ein Datenstromsignal im Wesentlichen gleichzeitig mit den Verbindungsschichtdaten senden, um zu identifizieren, dass Daten, die auf Datenschichten der Datenverbindung gesendet wurden, Verbindungsschichtpakete umfassen.In at least one example, the physical layer logic shall send a data stream signal substantially concurrently with the link layer data to identify that data sent on data layers of the data link comprises link layer packets.

In zumindest einem Beispiel wird das Datenstromsignal auf einer dedizierten Datenstromsignalbahn der Datenverbindung während eines bestimmten Fensters gesendet, wobei die Verbindungsschichtdaten ebenfalls während des bestimmten Fensters gesendet werden.In at least one example, the data stream signal is sent on a dedicated data stream signal path of the data link during a particular window, and the link layer data is also sent during the particular window.

In zumindest einem Beispiel soll die Logik der physikalischen Schicht ein gültiges Signal auf einer dedizierten gültigen Signalbahn der Datenverbindung senden, wobei das gültige Signal in einem anderen Fenster gesendet wird, das dem bestimmten Fenster direkt vorausgeht, um anzugeben, dass die in dem bestimmten Fenster gesendeten Daten gültig sind.In at least one example, the physical layer logic shall send a valid signal on a dedicated valid signal lane of the data link, with the valid signal being sent in another window immediately preceding the particular window to indicate that those being sent in the particular window data are valid.

In zumindest einem Beispiel umfasst der Handshake eine Handshake-Kommunikation über eine Seitenbandverbindung.In at least one example, the handshake includes handshake communication over a sideband connection.

In zumindest einem Beispiel umfasst der Handshake einen Verbindungsschicht-Handshake und die Handshake-Kommunikation über die Seitenbandverbindung.In at least one example, the handshake includes a link layer handshake and the handshake communication over the sideband link.

In zumindest einem Beispiel bestätigt die Handshake-Kommunikation über die Seitenbandverbindung den Verbindungsschicht-Handshake.In at least one example, the handshake communication over the sideband link acknowledges the link layer handshake.

In zumindest einem Beispiel soll die Logik der physikalischen Schicht ferner eine Anfrage von einer oberen Schicht eines ersten der Vielzahl von geschichteten Protokollen identifizieren, die Datenverbindung von dem aktiven Verbindungszustand in einen Niedrigenergieverbindungszustand überzuführen.In at least one example, the physical layer logic is further to identify a request from an upper layer of a first of the plurality of layered protocols to transition the data connection from the active connection state to a low power connection state.

In zumindest einem Beispiel soll die Logik der physikalischen Schicht ferner warten, um die Datenverbindung von dem aktiven Verbindungszustand in den Niedrigenergieverbindungszustand überzuführen, bis Anfragen von jedem der anderen Protokolle der Vielzahl geschichteter Protokolle empfangen werden.In at least one example, the physical layer logic shall further wait to transition the data link from the active link state to the low power link state until requests from each of the other protocols of the plurality of layered protocols are received.

In zumindest einem Beispiel soll die Logik der physikalischen Schicht für jedes der Vielzahl geschichteter Protokolle verfolgen, ob das Protokoll angefragt hat, die Datenverbindung von dem aktiven Verbindungszustand in den Niedrigenergieverbindungszustand überzuführen.In at least one example, for each of the plurality of layered protocols, the physical layer logic is to track whether the protocol has requested to transition the data link from the active link state to the low power link state.

In zumindest einem Beispiel soll die Logik der physikalischen Schicht ferner vor dem tatsächlichen Übergang der Datenverbindung von dem aktiven Verbindungszustand in den Niedrigenergieverbindungszustand eine Antwort auf die Anfrage erzeugen, den Übergang der Datenverbindung von dem aktiven Verbindungszustand in den Niedrigenergieverbindungszustand zu bestätigen.In at least one example, the physical layer logic shall further generate a response to the request to acknowledge the transition of the data link from the active link state to the low power link state prior to the actual transition of the data link from the active link state to the low power link state.

In zumindest einem Beispiel wird die Antwort gesendet, während die Genehmigung des Überganges der Datenverbindung von dem aktiven Verbindungszustand in den Niedrigenergieverbindungszustand von einem oder mehreren der anderen Protokolle in der Vielzahl geschichteter Protokolle ausstehend ist.In at least one example, the response is sent while the data link's transition from the active link state to the low power link state is pending approval of one or more of the other protocols in the plurality of layered protocols.

In zumindest einem Beispiel umfasst der Niedrigenergieverbindungszustand einen Ruheverbindungszustand.In at least one example, the low power connection state includes an idle connection state.

In zumindest einem Beispiel umfasst die Vielzahl der geschichteten Protokolle eines oder mehrere aus PCI, PCIe, IDI und QPI.In at least one example, the plurality of layered protocols includes one or more of PCI, PCIe, IDI, and QPI.

Es kann ein System bereitgestellt werden, um eine Datenverbindung zu umfassen, welche eine Vielzahl von Bahnen, eine erste Vorrichtung und eine zweite Vorrichtung umfasst, die unter Verwendung der Datenverbindung mit der ersten Vorrichtung kommunikativ verbunden ist, wobei die zweite Vorrichtung Oberschichtlogik eines ersten Protokolls, Oberschichtlogik eines zweiten Protokolls, wobei jeder der Vielzahl von Protokollstapeln eine gemeinsame physikalische Schicht nutzt, und Logik der physikalischen Schicht für die gemeinsame physikalische Schicht umfasst, worin die Logik der physikalischen Schicht feststellen soll, dass jedes der Protokolle einschließlich des ersten und des zweiten Protokolls, welche die Datenverbindung nutzen, das Überführen der Datenverbindung von einem aktiven Verbindungszustand in einen Niedrigenergieverbindungszustand genehmigt, bevor die Datenverbindung in den Niedrigenergieverbindungszustand übergeführt wird.A system may be provided to include a data link comprising a plurality of lanes, a first device, and a second device communicatively coupled to the first device using the data link, the second device having upper layer logic of a first protocol, Upper layer logic of a second protocol, each of the plurality of protocol stacks sharing a common physical layer, and physical layer logic for the common physical layer, wherein the physical layer logic is to determine that each of the protocols, including the first and second protocols, using the data link allow the data link to transition from an active link state to a low power link state before the data link is in the low power link state is transferred.

In zumindest einem Beispiel umfasst die Vielzahl von Bahnen eine Vielzahl von Datenbahnen, eine oder mehrere gültige Signalbahnen, eine oder mehrere Datenstrombahnen.In at least one example, the plurality of lanes includes a plurality of data lanes, one or more valid signal lanes, one or more data stream lanes.

In zumindest einem Beispiel sollen gültige Signale auf den gültigen Signalbahnen übertragen werden, und jedes gültige Signal identifiziert, dass gültige Daten der Zusicherung des gültigen Signals auf der Vielzahl von Datenbahnen nachfolgen sollen, und Datenstromsignale sollen auf den Datenstromsignalbahnen übertragen werden, und jedes Datenstromsignal identifiziert eine Art der Daten auf den einen oder mehreren Datenbahnen.In at least one example, valid signals are to be carried on the valid signal lanes, and each valid signal identifies that valid data is to follow the assertion of the valid signal on the plurality of data lanes, and data stream signals are to be carried on the data stream signal lanes, and each data stream signal identifies one Type of data on the one or more data lanes.

In zumindest einem Beispiel umfasst das Überführen der Datenverbindung in den Niedrigenergieverbindungszustand einen Handshake zwischen der ersten und der zweiten Vorrichtung.In at least one example, transitioning the data connection to the low power connection state includes a handshake between the first and second devices.

In zumindest einem Beispiel umfasst der Handshake einen Verbindungsschicht-Handshake und einen Seitenband-Handshake.In at least one example, the handshake includes a link layer handshake and a sideband handshake.

In zumindest einem Beispiel umfasst die erste Vorrichtung einen ersten Nacktchip in einem Gehäuse, und die zweite Vorrichtung umfasst einen zweiten Nacktchip in dem Gehäuse.In at least one example, the first device includes a first die in a package and the second device includes a second die in the package.

In zumindest einem Beispiel umfasst die erste Vorrichtung eine Vorrichtung auf dem Gehäuse, und die zweite Vorrichtung umfasste eine Vorrichtung, die nicht auf dem Gehäuse ist.In at least one example, the first device comprises a device on the housing and the second device comprises a device that is not on the housing.

Claims (26)

Vorrichtung, die Folgendes umfasst: eine Bitübertragungsschicht-Schnittstelle, die Folgendes umfasst: eine Taktleitung, die dazu eingerichtet ist, eine Taktsignal zu unterstützen; eine Steuerschnittstelle, die dazu eingerichtet ist, ein oder mehrere Steuersignale zu unterstützen, wobei das eine oder die mehreren Steuersignale Steuersignale umfassen, um Übergänge in Verbindungszuständen gemäß einer Zustandsmaschine zu bewirken; mehrere Datenleitungen, die dazu eingerichtet sind, Daten zu übertragen; und eine Gültig-Signal-Leitung, die dazu eingerichtet ist, eine Übertragung eines Gültig-Signals zu unterstützen, wobei die Übertragung von Daten auf den Datenleitungen mit einer Übertragung des Gültig-Signals auf der Gültig-Signal-Leitung abgestimmt werden soll, und wobei die Taktleitung und die Gültig-Signal-Leitung unterschiedliche Leitungen sind.Device comprising: a physical layer interface comprising: a clock line configured to support a clock signal; a control interface configured to support one or more control signals, the one or more control signals comprising control signals to effect transitions in connection states according to a state machine; multiple data lines configured to transmit data; and a valid signal line configured to support transmission of a valid signal, wherein transmission of data on the data lines is to be coordinated with transmission of the valid signal on the valid signal line, and wherein the clock line and the valid signal line are different lines. Vorrichtung nach Anspruch 1, die ferner eine Bitübertragungsschicht-Logik umfasst, die dazu eingerichtet ist, das Gültig-Signal zu erzeugen.device after claim 1 , further comprising physical layer logic configured to generate the valid signal. Vorrichtung nach Anspruch 2, wobei die Bitübertragungsschicht-Logik dazu eingerichtet ist, ein Training einer Verbindung, die die mehreren Datenleitungen umfasst, zu verwalten.device after claim 2 , wherein the physical layer logic is configured to manage training of a connection including the plurality of data lines. Vorrichtung nach Anspruch 3, wobei die Verbindungszustände mehrere Verbindungstrainingszustände umfassen und die Verbindungstrainingszustände bei dem Training der Verbindung verwendet werden.device after claim 3 , wherein the link states include multiple link training states, and the link training states are used in training the link. Vorrichtung nach Anspruch 4, wobei ein spezieller der mehreren Verbindungstrainingszustände einen Zustand mit niedriger Leistung umfasst, bei dem keine Daten auf der Verbindung gesendet werden sollen.device after claim 4 , wherein a specific one of the plurality of link training states includes a low power state where no data is to be sent on the link. Vorrichtung nach Anspruch 3, wobei das Training der Verbindung ein Senden und Empfangen von Trainingssequenzen auf der Verbindung umfasst.device after claim 3 , wherein training the link includes sending and receiving training sequences on the link. Vorrichtung nach einem der Ansprüche 1-6, wobei die Steuersignale Seitenbandsteuersignale umfassen.Device according to one of Claims 1 - 6 , wherein the control signals comprise sideband control signals. Vorrichtung nach einem der Ansprüche 1-7, wobei die Bitübertragungsschicht-Schnittstelle eine Bitübertragungsschicht-Abstraktion umfasst.Device according to one of Claims 1 - 7 , wherein the physical layer interface comprises a physical layer abstraction. Vorrichtung nach einem der Ansprüche 1-8, die ferner einen Sender umfasst, der dazu eingerichtet ist, das Gültig-Signal zu übertragen und die speziellen Daten auf den mehreren Datenleitungen, die mit dem Gültig-Signal abgestimmt sind, zu übertragen.Device according to one of Claims 1 - 8th , further comprising a transmitter configured to transmit the valid signal and to transmit the specific data on the plurality of data lines coordinated with the valid signal. Vorrichtung, die Folgendes umfasst: eine Schnittstelle, die Folgendes umfasst: eine Taktsignalleitung, die dazu eingerichtet ist, eine Taktsignals zu empfangen; eine Steuerschnittstelle, die dazu eingerichtet ist, ein oder mehrere Steuersignale zu empfangen, wobei das eine oder die mehreren Steuersignale Steuersignale umfassen, um Übergänge in Verbindungszuständen gemäß einer Zustandsmaschine zu bewirken; mehrere Datenleitungen, die dazu eingerichtet sind, Daten zu empfangen, die durch eine andere Einrichtung auf einer Verbindung übertragen werden; und eine Gültig-Signal-Leitung, die dazu eingerichtet ist, ein den Daten entsprechendes Gültig-Signal zu empfangen, wobei die Übertragung von Daten auf den Datenleitungen mit einer Übertragung des Gültig-Signals auf der Gültig-Signal-Leitung abgestimmt werden soll, und wobei die Taktleitung und die Gültig-Signal-Leitung unterschiedliche Leitungen sind.Device comprising: an interface that includes: a clock signal line configured to receive a clock signal; a control interface configured to receive one or more control signals, the one or more control signals comprising control signals to effect transitions in connection states according to a state machine; a plurality of data lines configured to receive data transmitted by another device on a link; and a valid signal line configured to receive a valid signal corresponding to the data, wherein transmission of data on the data lines is to be coordinated with transmission of the valid signal on the valid signal line, and wherein the clock line and the valid signal line are different lines. Vorrichtung nach Anspruch 10, die ferner eine Bitübertragungsschicht-Logik umfasst, die dazu eingerichtet ist, einen Empfang des Gültig-Signals auf der Gültig-Signal-Leitung zu identifizieren und die auf den mehreren Datenleitungen empfangenen Daten basierend auf dem Empfang des Gültig-Signals zu verarbeiten.device after claim 10 , further comprising physical layer logic configured to identify receipt of the valid signal on the valid signal line and to process the data received on the plurality of data lines based on the receipt of the valid signal. Vorrichtung nach einem der Ansprüche 10-11, wobei das Steuersignal ein Seitenbandsignal umfasst.Device according to one of Claims 10 - 11 , wherein the control signal comprises a sideband signal. Vorrichtung nach einem der Ansprüche 10-12, wobei das Gültig-Signal mit einer Flanke des Taktsignals abgestimmt ist.Device according to one of Claims 10 - 12 , wherein the valid signal is timed to an edge of the clock signal. Vorrichtung nach einem der Ansprüche 10-13, wobei die Verbindungszustände Verbindungstrainingszustände umfassen.Device according to one of Claims 10 - 13 , wherein the link states include link training states. Vorrichtung nach Anspruch 14, wobei Trainingssequenzen während eines oder mehrerer der Verbindungstrainingszustände durch die Vorrichtung gesendet und empfangen werden sollen.device after Claim 14 wherein training sequences are to be transmitted and received by the device during one or more of the link training states. Vorrichtung nach Anspruch 15, wobei die Trainingssequenzen gemäß einem definierten Verbindungsprotokoll sind.device after claim 15 , where the training sequences are according to a defined connection protocol. Vorrichtung nach Anspruch 16, wobei das definierte Verbindungsprotokoll eines mehrerer unterschiedlicher Verbindungsprotokolle, die unter Verwendung der Schnittstelle unterstützt werden, umfasst.device after Claim 16 , wherein the defined connection protocol comprises one of a plurality of different connection protocols supported using the interface. Verfahren, das Folgendes umfasst: Senden eines Taktsignals auf einer dedizierten Taktleitung einer Schnittstelle; Senden eines Steuersignals auf einer Steuerleitung, wobei das Steuersignal Übergänge in Verbindungszuständen gemäß einer Zustandsmaschine bewirken soll; Identifizieren von Daten, die auf mehreren Datenleitungen der Schnittstelle gesendet werden sollen; Senden eines Gültig-Signals auf einer dedizierten Gültig-Leitung der Schnittstelle, wobei das Gültig-Signal den speziellen Daten entspricht; und Senden der speziellen Daten auf den mehreren Datenleitungen, sodass sie mit dem Gültig-Signal abgestimmt werden, wobei die dedizierte Taktleitung und die dedizierte Gültig-Leitung unterschiedliche Leitungen der Schnittstelle sind.Procedure, which includes: sending a clock signal on a dedicated clock line of an interface; sending a control signal on a control line, the control signal to effect transitions in connection states according to a state machine; identifying data to be sent on multiple data lines of the interface; sending a valid signal on a dedicated valid line of the interface, the valid signal corresponding to the specific data; and sending the specific data on the multiple data lines to be aligned with the valid signal, wherein the dedicated clock line and the dedicated valid line are different lines of the interface. System, das Mittel umfasst, die dazu eingerichtet sind, das Verfahren nach Anspruch 18 durchzuführen.System comprising means set up to follow the method Claim 18 to perform. System nach Anspruch 19, wobei die Mittel ein computerlesbares Speichermedium mit darauf gespeicherten Anweisungen umfassen, wobei die Anweisungen durch eine Datenprozessoreinrichtung ausgeführt werden können, um zumindest einen Teil des Verfahrens nach Anspruch 18 durchzuführen.system after claim 19 , the means comprising a computer-readable storage medium having instructions stored thereon, the instructions being executable by data processing means to carry out at least part of the method according to Claim 18 to perform. System, das Folgendes umfasst: eine erste Datenverarbeitungseinrichtung; eine zweite Datenverarbeitungseinrichtung, die mit der ersten Datenverarbeitungseinrichtung über eine Verbindung verbunden ist, wobei die zweite Datenverarbeitungseinrichtung eine Bitübertragungsschicht-Schnittstelle umfasst, die dazu eingerichtet ist, die Verbindung zu unterstützen und die Bitübertragungsschicht-Schnittstelle Folgendes umfasst: eine Taktsignalleitung, die dazu eingerichtet ist, ein Taktsignal zu empfangen; eine Steuerschnittstelle, die dazu eingerichtet ist, ein oder mehrere Steuersignale zu empfangen, wobei das eine oder die mehreren Steuersignale Steuersignale umfassen, um Übergänge in Verbindungszuständen gemäß einer Zustandsmaschine zu bewirken; mehrere Datenleitungen, die dazu eingerichtet sind, Daten zu empfangen, die durch eine andere Einrichtung auf einer Verbindung übertragen werden; und eine Gültig-Signal-Leitung, die dazu eingerichtet ist, ein den Daten entsprechenden Gültig-Signal zu empfangen, wobei die Übertragung von Daten auf den Datenleitungen mit einer Übertragung des Gültig-Signals auf der Gültig-Signal-Leitung abgestimmt werden soll, und wobei die Taktsignalleitung und die Gültig-Signal-Leitung unterschiedliche Leitungen sind.System that includes: a first data processing device; a second data processing device connected to the first data processing device via a connection, the second data processing device comprising a physical layer interface arranged to support the connection and the physical layer interface comprising: a clock signal line configured to receive a clock signal; a control interface configured to receive one or more control signals, the one or more control signals comprising control signals to effect transitions in connection states according to a state machine; a plurality of data lines configured to receive data transmitted by another device on a link; and a valid signal line configured to receive a valid signal corresponding to the data, wherein transmission of data on the data lines is to be coordinated with transmission of the valid signal on the valid signal line, and wherein the clock signal line and the valid signal line are different lines. System nach Anspruch 21, wobei die zweite Datenverarbeitungseinrichtung einen Prozessor umfasst.system after Claim 21 , wherein the second data processing device comprises a processor. System nach Anspruch 22, wobei die erste Datenverarbeitungseinrichtung einen zweiten Prozessor umfasst.system after Claim 22 , wherein the first data processing device comprises a second processor. System nach Anspruch 21, wobei die zweite Datenverarbeitungseinrichtung eine Speichersteuerung umfasst.system after Claim 21 , wherein the second data processing device comprises a memory controller. System nach Anspruch 21, wobei die zweite Datenverarbeitungseinrichtung einen Grafikprozessor umfasst.system after Claim 21 , wherein the second data processing device comprises a graphics processor. System nach Anspruch 21, wobei die zweite Datenverarbeitungseinrichtung eine Netzwerksteuerung umfasst.system after Claim 21 , wherein the second data processing device comprises a network controller.
DE112013007770.1T 2013-12-26 2013-12-26 DEVICES, METHOD AND SYSTEM FOR TRANSMITTING AND RECEIVING VIA AN INTERFACE Active DE112013007770B3 (en)

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
DE112013007770 2013-12-26

Publications (1)

Publication Number Publication Date
DE112013007770B3 true DE112013007770B3 (en) 2023-04-06

Family

ID=85573761

Family Applications (1)

Application Number Title Priority Date Filing Date
DE112013007770.1T Active DE112013007770B3 (en) 2013-12-26 2013-12-26 DEVICES, METHOD AND SYSTEM FOR TRANSMITTING AND RECEIVING VIA AN INTERFACE

Country Status (1)

Country Link
DE (1) DE112013007770B3 (en)

Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20130007483A1 (en) 2011-07-01 2013-01-03 Diefenbaugh Paul S Method and apparatus to reduce idle link power in a platform

Patent Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20130007483A1 (en) 2011-07-01 2013-01-03 Diefenbaugh Paul S Method and apparatus to reduce idle link power in a platform

Similar Documents

Publication Publication Date Title
DE112013007734B4 (en) DEVICES, METHODS AND SYSTEMS FOR IDENTIFYING A PROTOCOL THAT USES A PHYSICAL CONNECTION
DE112013007751B3 (en) High Performance Interconnect Physical Layer
DE112013007724B4 (en) SYSTEM, APPARATUS AND METHOD FOR SHARING MEMORY AND I/O SERVICES BETWEEN NODES
DE112013007732B4 (en) System and device for determining and reporting a fault on a web
CN107430569B (en) Multi-chip package link
DE102020120102A1 (en) Global permanent memory flush
DE112016003233T5 (en) Redriver CONNECTION TESTING
DE112017005002T5 (en) CONNECTING PHYSICAL LAYER INTERFACE ADAPTER
DE112017001430T5 (en) IN-BAND RETIMER REGISTER IN TOUCH
DE112013007726T5 (en) Improvements to an interconnect retimer
DE102018005753A1 (en) SERDES LINK TRAINING
DE112018001088T5 (en) APPLYING FRAMING RULES FOR A HIGH-SPEED DATA CONNECTION
DE112016003222T5 (en) HIGH PERFORMANCE REPEATER
DE112017004963T5 (en) TENSION-MODULATED CONTROL LANE
DE102020101958A1 (en) DYNAMIC LANE ACCESS SWITCHING BETWEEN PCIE ROOTS
DE102021121490A1 (en) APPROXIMATE DATA BUS INVERSION TECHNOLOGY FOR LATENT-SENSITIVE APPLICATIONS
JP2018085129A (en) Multichip package link
DE112013007770B3 (en) DEVICES, METHOD AND SYSTEM FOR TRANSMITTING AND RECEIVING VIA AN INTERFACE
DE112013007842B3 (en) SYSTEM, DEVICE AND METHOD FOR GENERATION AND TRANSMISSION FLITS OF DIFFERENT PROTOCOLS IN DIFFERENT MODES
DE112013007841B3 (en) SYSTEM, APPARATUS AND METHOD FOR RECEIVING A SYNC HEADER AND LOG IDENTIFICATION DATA
DE112013007769B3 (en) System, apparatus and method for generating and sending SKP ordered sets
DE102020134763A1 (en) CLOSED CHASSIS DEBUGGING THROUGH TUNNELING

Legal Events

Date Code Title Description
R012 Request for examination validly filed
R129 Divisional application from

Ref document number: 112013007734

Country of ref document: DE

R016 Response to examination communication
R016 Response to examination communication
R018 Grant decision by examination section/examining division
R020 Patent grant now final