This application relates to debug capability on system-on-chip devices and, more particularly, to performing debugging operations of peer-to-peer transactions within the fabric of the system.
A system-on-chip (SoC) is an integrated circuit that combines different components, such as those traditionally associated with a processor-based system, into a single chip or, in some applications, within a small number of interconnected chips. The SoC may include advanced processors, various homogeneous and/or heterogeneous processing agents, and additional components such as networking devices, e.g., routers, controllers, bridge devices, memories, and so forth.
One implementation of a SoC may include an integrated on-chip system fabric (IOSF) specification issued by a semiconductor manufacturer to provide a standardized on-die interconnect protocol for attaching intellectual property (IP) blocks of varying types within the SoC. The IP blocks may include general-purpose processors, such as in-order or out-of-order cores, fixed function units, graphics processors, and controllers.
By standardizing an interconnect protocol such as IOSF, a framework is thus realized for a broad use of IP agents in different types of chips. The standardized interconnect protocol enables the semiconductor manufacturer to efficiently design different types of chips across a wide variety of customer segments. Further, the standardized protocol specification enables third parties to design logic, such as IP agents, to be incorporated into such chips. By providing multiple options for many facets of the interconnect protocol, reuse of designs is efficiently accommodated.
Primary scalable fabric (PSF) is a highly configurable SoC backbone IP based on the IOSF standard. PSFs are used to create an IOSF-compliant hierarchy that provides interconnection of IP blocks within the SoC or within an I/O subsystem. A single SoC may have one or more PSFs, at least one of which is coupled to the central processing unit (CPU) through a system agent (SA).
Under PSF 1.0, all transactions pass through the SA to the CPU. Debugging operations are thus performed at the SA, and all agents of the SoC are potential targets for the debug.
By contrast, PSF 2.0 supports peer-to-peer transactions between agents, which essentially removes the SA from the transaction path. This complicates the ability of a debugger to reach all entities on the SoC. (The IOSF specification, as well as PSF 1.0 and 2.0, are developed by Intel Corporation of Santa Clara, Calif.)
Thus, there is a need for a debug solution for an integrated on-chip system fabric supporting peer-to-peer transactions.
The foregoing aspects and many of the attendant advantages of this document will become more readily appreciated as the same becomes better understood by reference to the following detailed description, when taken in conjunction with the accompanying drawings, wherein like reference numerals refer to like parts throughout the various views, unless otherwise specified.
In accordance with the embodiments described herein, a fabric trace hook is disclosed to enable debugging operations of agents operating in a peer-to-peer integrated on-chip system fabric (IOSF). The fabric trace hook, embedded within the IOSF, includes programmable triggering and capturing logic, timestamp capability, and a security feature to disallow tracing of proprietary transactions. The fabric trace hook may operate in a lossy or lossless mode.
In the following detailed description, reference is made to the accompanying drawings, which show by way of illustration specific embodiments in which the subject matter described herein may be practiced. However, it is to be understood that other embodiments will become apparent to those of ordinary skill in the art upon reading this disclosure. The following detailed description is, therefore, not to be construed in a limiting sense, as the scope of the subject matter is defined by the claims.
Before describing the fabric trace hook in detail, some background discussion of the environment in which the fabric trace hook operates is appropriate.
The fabric 50 interfaces to a bridge 20. The bridge 20 may act as an interface to other system components, whether the components reside on the same chip or are part of other chips that couple to the interconnect architecture 60.
Each component of the interconnect architecture 60, namely, the fabric 50, the IP agents 30 and 40, and the bridge 20, may include one or more interfaces to handle communication of various signals. The IOSF specification defines signals for communication on these interfaces, protocols used for information exchange between agents, arbitration and flow control mechanisms used to initiate and manage information exchange, supported address decoding and translation capabilities, messaging for in-band or out-of-band communication, power management, test, and validation and debug support. In some embodiments, these interfaces are defined according to the IOSF specification.
The IOSF specification includes three independent interfaces that can be provided for each agent, namely a primary interface, a sideband message interface, and a testability or design for test (DFx) interface. According to the IOSF specification, an agent may support any combination of these interfaces. Specifically, an agent can support zero or more primary interfaces, zero or more sideband message interfaces, and an optional DFx interface. However, according to the IOSF specification, an agent must support at least one of these three interfaces.
The fabric 50 may be a hardware element that moves data between different agents. In some embodiments, the topology of the fabric 50 is product-specific. As examples, a fabric may be implemented as a bus, a hierarchical bus, or a cascaded hub.
In some embodiments, the primary interface 120 implements a split transaction protocol to achieve maximum concurrency. That is, the protocol provides for a request phase, a grant phase, and a command and data phase. Primary interface 120 supports three basic request types: posted, non-posted, and completions, in various embodiments. Generally, a posted transaction is a transaction which, when sent by a source, is considered complete by the source and the source does not receive a completion or other confirmation message regarding the transaction. One such example of a posted transaction may be a write transaction.
In contrast, a non-posted transaction is not considered completed by the source until a return message is received by the source, namely, a completion. One example of a non-posted transaction is a read transaction in which the source agent requests a read of data. The read transaction is not considered complete by the agent until the completion message provides the requested data to the agent.
In addition, the primary interface 120 supports the concept of distinct channels to provide a mechanism for independent data flows throughout the system. The primary interface 120 may include a master interface, to initiate transactions, and a target interface, to receive transactions (not shown). The primary master interface may further be sub-divided into a request interface, a command interface, and a data interface, with the request interface providing control for movement of a transaction's command and data. In some embodiments, the primary interface 120 supports PCI ordering rules and enumeration.
In turn, sideband interface 130 may be a standard mechanism for communicating out-of-band information, such as status, interrupt, power management, configuration shadowing, and test modes. In this way, special-purpose wires designed for a given implementation are avoided, enhancing the ability of IP reuse across a wide variety of chips. In contrast to an IP block that uses dedicated wires to handle out-of-band communications, the sideband interface 130 under the IOSF specification standardizes all out-of-band communication, promoting modularity and reducing validation requirements for IP reuse across different designs. In some embodiments, the sideband interface 130 communicates low-performance information rather than primary data transfers, which typically are communicated via primary interface 120.
As further illustrated in
Using an IOSF specification, various types of chips can be designed having a wide variety of different functionality. Referring now to
The SoC 200 includes a plurality of cores 150A-150N (collectively, “cores 150”). In various embodiments, the cores 150 can be relatively simple in-order cores or more complex out-of-order cores. Or a combination of in-order and out-of-order cores can be present in a single SoC. As seen, cores 150 can be interconnected via a coherent interconnect 170, which further couples to a cache memory 160, such as, for example, a shared last level cache (LLC). Although the scope of the present disclosure is not limited in this regard, in one embodiment, coherent interconnect 170 is designed in accordance with the Quick Path Interconnect (QPI)™ specification. (The QPI™ is a product of Intel Corporation of Santa Clara, Calif.).
As further seen in
As further seen in
The fabric 250 may further couple to an IP agent 260. Although only a single agent is shown for ease of illustration in the embodiment of
Finally, the SoC 200 of
While shown as a single die SoC implementation in
Referring now to
Specifically, the second chip 350 is shown to include an off-die interface 310 to enable communication with SoC 200A, and which, in turn, communicates with a fabric 320, which may be an IOSF fabric, in some embodiments. As seen, the fabric 320 may further be coupled to various controllers in communication with off-chip devices, including a PCIe™ controller 330, a USB controller 340, and a bridge 360.
As discussed above, in various embodiments, all out-of-band communications may be via a sideband message interface.
Whenever a credit put signal is high, this means that a credit is being returned. Whenever a put signal is high, it means that the payload (e.g., data) signal is valid. Whenever a put and EOM are high at the same time, it means that the current payload is the last payload of the message. Note that the interface can both “put” a data payload and “put” a credit in the same clock cycle.
Although the SoCs of
Thus as seen, a direct memory interconnect (DMI) interface 605 may couple to a hub 610, e.g., an input/output hub that in turn provides communication between various peripheral devices. Although not shown for ease of illustration, various engines, such as a manageability engine and a virtualization engine, may be directly coupled to the hub 610.
To provide connection to multiple buses, which may be multi-point or shared buses in accordance with the IOSF specification, an IOSF controller 615 may couple between the hub 610 and a bus 640. In some embodiments, the bus 640 is an IOSF bus that incorporates elements of the fabric as well as routers. The IOSF bus 640 may have coupled to it various controllers to provide for control of off-chip devices. In
As further seen in
Still other implementations are possible. Referring now to
As further seen in
Furthermore, to enable communications, e.g., with storage units of a server-based system, a switch port 740 may couple between bus 720 and another IOSF bus 750, which, in turn, may be coupled to a storage controller unit (SCU) 745, which may be a multi-function device for coupling with various storage devices.
System and software debug requires triggering and observation capabilities of the transactions flowing through the fabric of a system. The above SoC implementations are no exception. Since PSF 2.0 adds peer-to-peer support, the PSFs are the ideal location to provide these hooks. As used herein, a peer-to-peer transaction is a transaction flowing from a first agent to a second agent without being received at the central processing unit of the system under test.
PSF can be used as a single primary IOSF fabric for multiple execution environments or roots. In the system 800, the PSF consists of two instances, PSF 805 and PSF 815, to provide the IOSF fabric for two roots, the host CPU 810 and the IE 840. In this configuration, PSF provides IOSF fabric ports to a set of IOSF agents, 755, 765, 835, and 845 in host address space, and agents 825, 855, the IE 840, and the debug agent 860 in IE address space (with each address space being color-coded accordingly). One IOSF fabric port, PSF 805, provides access to the coherent fabric of the host address space through the system agent (SA) 820, and one port, PSF 815, provides access to the coherent fabric of the innovation engine 840.
In the example of
PSF 805 and PSF 815 operate as ports to receive one or more agents. In the system 800 of
Recall that, under the latest implementation of the IOSF specification (PSF 2.0), peer-to-peer transactions are possible. This means that agent 755 may communicate with agent 765 without going through the SA 820 (or CPU 810), as one example. By inserting the PSF FTH 850 in the PSF 805 port, transactions between agent 755 and 765 are available for debug, despite the peer-to-peer nature of the transactions.
The sideband interface 770 connects to a filter/match on-die logic analyzer trigger (ODLAT) block 780, a packetizer and flow control block 785, and a queue and master agent interface 790. Additionally, configuration registers 795, consisting of both compile-time fields 795A and run-time fields 795B (collectively, configuration registers 795), and mask/match registers 705, are accessible through the sideband interface 770. One possible arrangement of the field configuration of the mask/match register 705 is illustrated in
In some embodiments, the run-time portion 795B of the configuration registers 795 enable the PSF FTH 850 to control the available modes of the FTH. The mask/match registers 705 perform filtering of transactions on the fabric, as well as controlling what is to be captured by the PSF FTH 850.
In the IOSF specification, the CMD and DATA fields are separate buses. In some embodiments, the number of mask/match register pairs is a compile-time parameter (found in the compile-time fields 795A of the configuration register 795), such as the one that instantiates a fabric trace hook in the PSF (also found in the compile-time fields 795A), with a minimum of two register pairs being available by default (one for CMD and one for DATA) to support completion tracking. In some embodiments, the mask/match registers 705 and the configuration registers 795 are programmed via the sideband interface 770 in the PSF.
In some embodiments, the available modes of the PSF FTH 850 are: 1) triggering—signal match only; 2) ODLAT completion tracking triggering—signal match only; 3) capture (CMD+a configurable number of dwords of DATA, up to the maximum allowable DATA payload size; and 4) no data capture—CMD only.
In some embodiments, the filter/match/ODLAT block 780 compares the MCMD and MDATA output port buses as input and compares the input values against the mask/match registers 705. Once an incoming command (CMD) or data (DATA) that matches the mask/match registers 705 is received, the filter/match/ODLAT mechanism 780 sends a trigger to the packetizer and flow control mechanism 785. In some embodiments, there are separate triggers, CMD and DATA, for command and data signals, as they are processed separately under the IOSF specification. Similarly, the compile-time portion 795A of the configuration registers 795 may be programmed such that the PSF FTH 850 has separate mask/match registers 705 for CMD and DATA fields.
In
In some embodiments, the packetizer and flow control block 785 controls capturing of the MCMD 712 and MDATA 714 busses into a queue structure 950 based on enable and mode inputs (from the run-time portion 795B of the configuration registers 795) and match signals (from the match/mask registers 705).
A timestamp counter block 775 ensures that a time stamp is added to the MDATA stored in the queue 950. The timestamp counter block 775 is synchronized to a central timestamp source, such as a global timer of the system under test (e.g., the SoC 800). In some embodiments, the timestamp is a 32-bit timestamp. Thus, the time stamp, the matched command, TCMD, and the matched data, TDATA, are sent to the queue and master agent interface 790 to become the payload that will be sent on the MDATA bus 714 back to the PSF 805, which then sends the payload to the debug agent 860.
In some embodiments, the queue and master agent interface 790 is capable of sending, but not receiving, a transaction. The queue and master agent interface 790 is used to queue the traced transaction, shown as TCMD or TDATA, and send it to the debug agent 860 (
In some embodiments, the queue and master agent interface 790 sends a request to a central arbitration block of the PSF 850 and generates the appropriate MCMD to deliver the write. The transaction is a peer-to-peer write over the fabric directed to the debug agent 860. The time stamp, TCMD, and TDATA will be sent as the data payload. If the PSF FTH 850 supports full data capture, the queue 950 is sized to at least the minimum size to transmit a transaction that contains the maximum data payload, plus the entire original MCMD.
With the exception of the initialization of the configuration registers 795 and the programming of the mask/match registers 705, which take place in the sideband interface 770, all transactions with the PSF fabric trace hook 850 are performed using the fabric itself. Thus, the signals coming into the PSF FTH 850, such as the MCMD, MDATA, trigger_in[N] 704 signals, and grant signals, come in through the fabric. Similarly, the outgoing MCMD, MDATA, and trigger_out[N] 702 signals all pass through the fabric.
In some embodiments, the mask/match registers 705 include, but are not limited to, the following fields: 1) source ID; 2) destination ID; 3) device address; 4) data pattern; 5) security attribute; 6) format; and 7) type. One or more of these fields are used to trigger an action by the debugger 1000.
In some embodiments, the mask/match registers 705 are used by the PSF FTH 850 to trigger on specific individual transactions or classes of transactions. The trigger outputs (shown in
Probe mode is a special processor core debug feature that is controlled via a tap (JTAG). Probe mode is used to halt macro-instruction execution on the processor core in order to be able to set hardware breakpoints and examine processor architectural state and instruction boundaries. Capture mode is the FTH mode of sending the traced transactions to the debug agent. The debug agent can then store the traced transactions to system memory or out to a debug port where a logic analyzer can be used to trace the transactions.
Until the CPU 810 writes the desired data pattern to the device in agent 845, no further action is taken (the “N” prong of block 1108). Once the data pattern is sent, the PSF FTH 850 asserts the trigger output, which flows through the PSF fabric to the debug agent 860 and to the debugger 1000 (block 1110). The debugger 1000 is then able to enter the desired probe mode (block 1112).
In contrast to the above example of a transaction between the CPU and an agent, when an agent generates a read to another agent, the read transaction is marked with a dynamic tag that is assigned by the source agent, known herein as dynamic addressing. When the target agent responds, the completion for the read is sent with this tag value. Because the tag is generated dynamically, static mask/match register values cannot be used. Therefore, in some embodiments, the PSF FTH 850 implements an on-die logic analyzer trigger (ODLAT) mechanism that can be used to track a read completion and generate a subsequent trigger when the read response returns.
Once the read transaction is identified, whether a memory read, an I/O read, or a configuration read (block 1208), the PSF FTH 850 is able to read the unique tag assigned to the transaction (block 1210). The ODLAT mechanism 780 of the PSF FTH 850 is then able to track the read completion from agent 765 (block 1212), whether a successful read completion (CpIID) or a failure (Cpl), by matching the same tag (block 1214), at which time a trigger is generated when the read response returns to agent 755 (block 1216).
The PSF FTH 850 also supports programmable triggering on command fields (CMD) and a configurable amount of data (DATA) of all transactions flowing through PSF 805.
Once a write operation is observed by the PSF FTH 850 (block 1306), succeeding matched write operations by agent 755 are to be sent to the debug agent 860 for analysis by the debugger 1000. First, the traced transaction is packetized by the packetizer and flow control mechanism 785 (block 1308), along with a timestamp generated by the timestamp counter block 775 (block 1310) (
In some embodiments, the PSF FTH 850 can be configured to trace transactions. The PSF FTH 850 implements logic to capture transactions based on the same mask/match registers 750 used for triggering. The mask/match registers 705 can be used to filter transactions to be traced.
In some embodiments, the PSF FTH 850 includes a security mechanism to disallow the tracing of proprietary transactions. In some embodiments, the SoC 800 accepts both proprietary agents and third-party agents to be part of the SoC. The security mechanism is part of the run-time fields 795B of the configuration registers 795, in some embodiments (
The configuration registers 795 include some fields that are accessed at compile time and others that are accessed at run time. Accordingly, the configuration registers 795 are split into compile-time fields 795A and run-time fields 795B. The compile-time fields 795A include an FTH present field, which is accessed during instantiation of the PSF, a mask/match register select field, for determining the number and type (CMD or DATA) of mask/match registers, and a queue size field, for determining the size of the queue 950 (
The run-time fields 795B include a mode select field, to select one of the four operating modes of the PSF FTH 850, a lossy mode select field, for determining whether the capture mechanism of the PSF FTH 850 operates in lossy mode or lossless mode, and a backpressure mechanism select field. The run-time fields are programmable during runtime, in some embodiments. The lossy mode select and backpressure mechanism select fields are described further below.
The PSF FTH 850 also supports either a lossy mode of operation or a lossless mode of operation, in some embodiments. As the name suggests, in the lossy mode, some operations are not processed by the PSF FTH 850, while, in the lossless mode, all operations are processed. This feature gives maximum flexibility to the debugger 1000.
For example, agent 755 requests access to PSF 805. However, the CPU 810 previously sent a request to agent 845, which the PSF FTH 850 is observing. The PSF FTH 850 is also in the process of sending the trace capture transaction to the debug agent 860. In lossless mode, which is selectable by configuring the lossy mode select field of the run-time portion 795B of the configuration registers 795, the PSF FTH 850 must complete its trace capture transaction to the debug agent 860 before agent 755 can access PSF 805.
Returning to
In lossy mode, by contrast, the PSF FTH 850 minimizes any perturbance to the normal flow of traffic, in some embodiments. So, if agent 755 makes a request while the debug agent 860 is tracing transactions for agent 845, the agent 755 transaction will be lost because the PSF FTH 850 is able to send one transaction at a time. Therefore, in some embodiments, while in the lossy mode, the counter 722 (
In some embodiments, the PSF FTH 850 has a mechanism to backpressure transactions generated by agents connected to the PSF. Selectable by programming the backpressure mechanism select field of the run-time portion 795B of the configuration registers 795, this field is used to create a lossless mode of operations when the PSF FTH 850 is configured to trace transactions. A stall signal 724 (
The backpressure mechanism can be turned off to minimize normal functional traffic intrusion. In this “lossy” mode of operation, a dropped packet count is sent with the traced transaction to indicate how many packets were dropped since the last successfully captured transaction. These two modes allow the debugger 1000 to choose between full transactions tracing versus reducing impact to system functionality.
Embodiments can be used in many different types of systems. As examples, implementations described herein may be used in connection with semiconductor devices such as processors or other semiconductor devices that can be fabricated on a single semiconductor die. In particular implementations, the device may be a SoC or other advanced processor that includes various homogeneous and/or heterogeneous processing agents, and additional components such as networking components, e.g., routers, controllers, bridge devices, memories, and so forth.
Although embodiments are described herein in connection with this IOSF specification, the scope of the disclosure is not limited in this regard and embodiments can be used in many different types of systems.
While the application has been described with respect to a limited number of embodiments, those skilled in the art will appreciate numerous modifications and variations therefrom. It is intended that the appended claims cover all such modifications and variations as fall within the true spirit and scope of the invention.