The present disclosure relates to electronic device operation, and more particularly, to a telemetry data push system that manages telemetry data flow using at least periodicity and skew.
The operation of electronic systems may be managed based on information from which the current condition of the system may be determined. For example, power consumption, data traffic, temperature, up time (e.g., the time that the system is continuously operational) etc. may be monitored and reported for one or more devices in the system. This type of information may be generally termed “telemetry” data. In existing systems, intellectual property (IPs) such as, for example, integrated circuits (ICs), chipsets, multichip modules, etc. may provide telemetry data in a “request-response” mode of operation. In this type of operation, a request is sent to one or more IPs requesting telemetry data. The one or more IPs may provide the requested telemetry data, which may be utilized by control resources to manage operation of the electronic system.
For example, computing systems may utilize microprocessors (e.g., such as processors manufactured by the Intel Corporation) including additional functionality to support processor operation. The functionality may reside within the physical package of the processor to support operation of one or more processing cores (e.g., the “uncore”), or within separate ICs, chipsets, etc. For example, an uncore portion of a processor may include a power controller unit (PCU) to manage processor power consumption, while a platform controller hub (PCH) including at least one IC external to the processor may include a power management controller (PMC) to manage power consumption in the device (e.g., device awake/sleep states). The PCU and/or PMC may accumulate performance, power, thermal, etc. telemetry information from various IPs. Example telemetry data source IPs include various peripheral component interconnect express (PCIe) IPs mapped to a PCIe configuration (PCIe Config) space (e.g., at least one memory register to which data may be written), a memory-mapped input/output (MMIO) space, etc., a memory controller, a power supply unit, digital thermal sensors, integrated/discrete variable reluctance (VR) sensors, etc. Example in-band (IB) recipients for telemetry data may include host-based software (SW) agents that receive telemetry data via model-specific registers (MSRs), command status registers (CSRs), etc. Example out-of-band (OOB) recipients for telemetry data may include management engine (ME), innovation engine (IE) and/or baseboard management controller (BMC)-based firmware (FW) agents. The telemetry data may be conveyed to the various recipients via, for example, a processor environmental control interface (PECI) in-band, wired interface.
The implementation of OOB-meta state machines (MSM) enables multiple agents (e.g., based on host, IE, ME, and BMC) to collect telemetry information from IPs. However, requests may be queued and serviced as round-robin “request-response” only. Although two FW agents may initiate a request at the same-time-instant, responses may be delayed based on time it takes to complete a single request-response. This make correlation of different telemetry data difficult, may negatively impact system efficiency, responsiveness, etc., and thus overall system operation.
Features and advantages of various embodiments of the claimed subject matter will become apparent as the following Detailed Description proceeds, and upon reference to the Drawings, wherein like numerals designate like parts, and in which:
Although the following Detailed Description will proceed with reference being made to illustrative embodiments, many alternatives, modifications and variations thereof will be apparent to those skilled in the art.
The present disclosure is directed to push telemetry data accumulation. A system may comprise at least telemetry circuitry configured to push telemetry data (e.g., provide telemetry data without first receiving a request). In an example implementation, a system may comprise one or more devices that include at least one set of telemetry circuitry. The at least one set of telemetry circuitry may be configured to push data based at least on a frequency configuration and a skew configuration. The frequency configuration may control how often the at least one set of telemetry circuitry generates data. Generating data may include capturing data based on timing provided by a global clock in the system. The skew configuration may control when the telemetry data is transmitted. For example, sets of telemetry circuitry may be configured with different skew configurations to minimize transmission overlap. This may prevent telemetry data accumulation (TDA) circuitry in the system, which receives the transmission of telemetry data from the at least one set of telemetry circuitry, from becoming overwhelmed by multiple simultaneous transmission. The TDA circuitry may reside in, for example, processing circuitry in the system. The processing circuitry may use the telemetry data to control system operation.
In at least one embodiment, a system equipped for push telemetry data accumulation may comprise, for example, at least one set of telemetry circuitry and processing circuitry. The at least one set of telemetry circuitry may be to at least generate and transmit telemetry data. Moreover, the processing circuitry may be to execute code for transforming the processing circuitry into specialized circuitry to configure a frequency and skew in the at least one set of telemetry circuitry, the processing circuitry including at least TDA circuitry to receive the telemetry data from the at least one set of telemetry circuitry, wherein the at least one set of telemetry circuitry is to generate and transmit the telemetry data based on the frequency and skew configuration.
In at least one embodiment, the system may further comprise clock circuitry to maintain universal timing in the system, the clock circuitry including a plurality of timers. The processing circuitry may be to cause the plurality of timers to be synchronized. For example, the processing circuitry may cause the plurality of timers to be synchronized when the system is initialized.
The at least one set of telemetry circuitry may be to monitor the timing based on the frequency configuration. In generating the telemetry data, the at least one set of telemetry circuitry may be to capture the telemetry data when the timing is determined to correspond to the frequency configuration. In transmitting the telemetry data, the at least one set of telemetry circuitry may be to initiate a delay period based on the skew configuration when the timing is determined to correspond to the frequency configuration and then transmit the telemetry data to the telemetry data accumulation circuitry following the delay period. The processing circuitry may be to control the operation of the system based on the telemetry data. An example method for push telemetry data accumulation may comprise determining a timing from clock circuitry in a system and generating and transmitting telemetry data in at least one set of telemetry circuitry in the system based on a frequency configuration and skew configuration in the at least one set of telemetry circuitry.
Consistent with the present disclosure, IPs may “push” telemetry information instead of requiring aggregators to “pull” the information (e.g., by sending a request to an IP from which telemetry data is desired). This type of operation may be, in general, more efficient in that the telemetry data is delivered without the TDA circuitry having to request the data. Moreover, the generation (e.g., capture time) of the telemetry data may be synchronized to global timing in the system. Many IPs may maintain high-precision timer accurate to nanosecond granularity. For example, PCIe IPs may maintain a precision time measurement (PTM) counter while non-PCIe IPs may maintain an always running timer (ART) that may be accessible via, for example, an input/output scale fabric (IOSF, e.g., a high speed interconnect between IPs). The availability of synchronized, high-precision timers may allow IPs to readily align to a timer, and thus the IPs may have the same linear view of time progression. In at least one embodiment, at least one of processor circuitry in the system, an aggregator, etc. may configure frequency and skew values for each IP. Frequency may configure the rate at which IP generates (e.g., captures, measures, snapshots, etc.) telemetry values in its internal buffers. Skew may be a fixed time-delta that may vary between IPs to distribute the instances at which the IPs transmit the captured telemetry data. For example, the actual instances at which an IP may transmit captured telemetry data (e.g., the time at which the telemetry data is “posted”), may be correspond to the most recent point in time corresponding to the frequency plus a delay defined by the skew. The posting of telemetry data (e.g., to the TDA circuitry) is typically done over, for example, an IOSF sideband or PCIe.
Referring to
Example system 100 in
An example disclosing how the timing of telemetry data transmission may vary between telemetry circuitry 102A . . . n′ is illustrated in example 106 of
In the illustrated example configuration, system 100′ may comprise system circuitry 200 to manage general system operations. System circuitry 200 may include processing circuitry 202, memory circuitry 204, power circuitry 206, user interface circuitry 208 and communication interface circuitry 210. System 100′ may further include communication circuitry 212. While communication circuitry 212 is illustrated as separate from system circuitry 200, this example configuration is shown merely for the sake of explanation. Some or all of the functionality associated with communication circuitry 212 may also be incorporated into system circuitry 200.
In system 100′, processing circuitry 202 may comprise one or more processors situated in separate components, or alternatively one or more processing cores in a single component (e.g., in a system-on-chip (SoC) configuration), along with processor-related support circuitry (e.g., bridging interfaces, etc.). Example processors may include, but are not limited to, various x86-based microprocessors from the Intel Corporation including those in the Pentium®, Xeon®, Itanium®, Celeron®, Intel Atom®, Quark®, Core i-series and Core M-series product families, Advanced RISC (e.g., Reduced Instruction Set Computing) Machine or “ARM” processors, etc. Examples of support circuitry may include various chipsets (e.g., Northbridge, Southbridge, PCH, etc. from the Intel Corporation) to provide an interface through which processing circuitry 202 may interact with other system components that may be operating at different speeds, on different buses, etc. in system 100′. Moreover, some or all of the functionality associated with the support circuitry may be included in the same physical package as the processor (e.g., such as in the Sandy Bridge, Broadwell and Skylake families of processors from the Intel Corporation).
Processing circuitry 202 may be configured to execute various instructions in system 100′. Instructions may include program code configured to cause processing circuitry 202 to perform activities related to reading data, writing data, processing data, formulating data, converting data, transforming data, etc. Information (e.g., instructions, data, etc.) may be stored in memory circuitry 204. Memory circuitry 204 may comprise random access memory (RAM) and/or read-only memory (ROM) in a fixed or removable format. RAM may include volatile memory configured to hold information during the operation of system 100′ such as, for example, static RAM (SRAM) or dynamic RAM (DRAM). ROM may include non-volatile (NV) memory circuitry configured based on BIOS, UEFI, etc. to provide instructions when system 100′ is activated, programmable memories such as electronic programmable ROMs (EPROMS), Flash, etc. Other fixed/removable memory may include, but are not limited to, example magnetic memories such as hard disk (HD) drives, etc., example electronic memories such as solid state flash memory (e.g., embedded multimedia card (eMMC), etc.), removable memory cards or sticks (e.g., micro storage device (uSD), USB, etc.), example optical memories such as compact disc-based ROM (CD-ROM), Digital Video Disks (DVD), Blu-Ray Disks, etc.
Power circuitry 206 may include internal power sources (e.g., a battery, fuel cell, etc.) and/or external power sources (e.g., electromechanical or solar generator, power grid, external fuel cell, etc.), and related circuitry configured to supply system 100′ with the power needed to operate. User interface circuitry 208 may include hardware and/or software to allow users to interact with system 100′ such as, for example, various input mechanisms (e.g., microphones, switches, buttons, knobs, keyboards, speakers, touch-sensitive surfaces, one or more sensors configured to capture images and/or sense proximity, distance, motion, gestures, orientation, biometric data, etc.) and various output mechanisms (e.g., speakers, displays, lighted/flashing indicators, electromechanical components for vibration, motion, etc.). The hardware in user interface circuitry 208 may be incorporated within system 100′ and/or may be coupled to system 100′ via a wired or wireless communication medium. User interface circuitry 208 may be optional in certain circumstances such as, for example, a situation wherein system 100′ is a very small form factor device configured remotely (e.g., wirelessly) by another device, a server (e.g., rack server, blade server, etc.) that does not include user interface circuitry 208, and instead relies on another device (e.g., a management terminal) for user interface functionality, etc.
Communication interface circuitry 210 may be configured to manage packet routing and other control functions for communication circuitry 212 that may include resources configured to support wired and/or wireless communications. In some instances, system 100′ may comprise more than one set of communication circuitry 212 (e.g., including separate physical interface circuitry for wired protocols and/or wireless radios) managed by communication interface circuitry 210. Wired communications may include serial and parallel wired mediums such as, for example, Ethernet, USB, Firewire, Thunderbolt, Digital Video Interface (DVI), High-Definition Multimedia Interface (HDMI), etc. Wireless communications may include, for example, close-proximity wireless mediums (e.g., radio frequency (RF) such as based on the RF Identification (RFID) or Near Field Communications (NFC) standards, infrared (IR), etc.), short-range wireless mediums (e.g., Bluetooth®, WLAN, Wi-Fi, etc.), long range wireless mediums (e.g., cellular wide-area radio communication technology, satellite-based communications, etc.), electronic communications via sound waves, long-range optical communications, etc. In one embodiment, communication interface circuitry 210 may be configured to prevent wireless communications that are active in communication circuitry 212 from interfering with each other. In performing this function, communication interface circuitry 210 may schedule activities for communication circuitry 212 based on, for example, the relative priority of messages awaiting transmission. While the embodiment disclosed in
Consistent with the present disclosure, telemetry circuitry 102A . . . n′ and/or TDA circuitry 104′ may include hardware, software or combinations thereof. In an example hardware implementation, telemetry circuitry 102A . . . n′ and/or TDA circuitry 104′ may include dedicated circuitry (e.g., an IC, chipset, multi-chip module (MCM), etc. with or without firmware), or may be part of other circuitry (e.g., processing circuitry 202). In an example software and hardware implementation, at least a portion of telemetry circuitry 102A . . . n′ and/or TDA circuitry 104′ may reside in processing circuitry 202 and/or memory circuitry 204. For example, telemetry circuitry 102A . . . n′ and/or TDA circuitry 104′ may comprise code executed by processing circuitry 202, wherein at least a portion of the code may be stored in memory circuitry 204. Processing circuitry 202 may execute the code to transform processing circuitry 202 from general purpose data processing circuitry into specialized circuitry to perform at least the functions associated with telemetry circuitry 102A . . . n′ and/or TDA circuitry 104′. In an example of operation, telemetry circuitry 102A . . . n′ may transmit telemetry data to TDA circuitry 104′ in processing circuitry 202, which may accumulate the telemetry data. Processing circuitry 202 may then evaluate the telemetry data for use in managing operations in system 100.
In an example of operation, IPA . . . n and aggregators 1, 2 and 3 may align to a global time counter (e.g., system reference clock) when system 100 is initialized. As part of the silicon (e.g., IC) reset sequence, IPA . . . n and aggregators 1, 2 and 3 may initialize their timers utilizing ART management or PCIe precision time measurement (PTM) methods. All internal IPs may now be aligned to an ART via IOSF sideband distribution protocol. External IPs may be synched up via the PCIe PTM protocol. All Aggregators may also implement similar protocols to align to global timing. Aggregator 1, 2 and/or 3 may then program each IPA . . . m with at least a frequency value 110 to control when each of the IPs generate telemetry data and a skew value 112 to control when each IPA . . . m transmits the telemetry data to aggregators 1, 2 or 3 (e.g., to reduce IOSF sideband conflicts and internal buffering requirements for aggregators 1, 2 and 3 since telemetry data delivery is more distributed over time). In addition, by defining an IOSF “multicast” address, IPA . . . m may post/deliver telemetry values to multiple aggregators 1, 2 and/or 3 at the same time. In addition, IPA . . . m may deliver telemetry data to an external aggregator 3 via an IOSF sideband end-point represented by eSPI/I3C I/F. In at least one embodiment, since telemetry data is delivered via unicast, multicast or broadcast communication, aggregators 1, 2 and/or 3 may subscribe or unsubscribe to different IPA . . . m to control communication traffic. Subscribing/unsubscribing may occur, for example, during the initial programming of IPA . . . m.
The above example enables aggregators 1, 2 and/or 3 to receive time-accurate snapshots of telemetry data but have them delivered based on the pre-programmed skew. In at least one embodiment, if multiple aggregators 1, 2 and/or 3 program the same frequency/skew value to at least one IPA . . . m, then the IPA . . . m comprising the conflicting configuration may automatically convert to a multicast/broadcast response to transmit telemetry data to all interested aggregators 1, 2 or 3. There are numerous optimizations that can be driven once time-alignment is achieved. Global time based on ART/PTM/802.1AS-1588 has nanosecond granularity, however many of the SW/FW agents may be expected to only require data at milli/micro second interval accuracy.
Following a “no” determination in operation 406 or operation 408, in operation 410 the current clock timing may be determined. The clock timing may be determined in operation 410 until a determination is made in operation 412 that a transmit instance has occurred. A transmit instance may be determined based on, for example, the current clock timing corresponding to a time that telemetry data should be generated and transmitted based on the frequency value. If it is determined in operation 412 that a transmit instance exists, then in operation 414 telemetry data may be generated (e.g., captured, measured, etc.). The telemetry circuitry may then delay in operation 416 based on the skew value prior to transmitting the telemetry data in operation 418. The transmission of the telemetry data in operation 418 may be followed by a return to operation 410 to continue monitoring the clock timing (e.g., in preparation for the next transmit instance).
While
As used in this application and in the claims, a list of items joined by the term “and/or” can mean any combination of the listed items. For example, the phrase “A, B and/or C” can mean A; B; C; A and B; A and C; B and C; or A, B and C. As used in this application and in the claims, a list of items joined by the term “at least one of” can mean any combination of the listed terms. For example, the phrases “at least one of A, B or C” can mean A; B; C; A and B; A and C; B and C; or A, B and C.
As used in any embodiment herein, the terms “system” or “module” may refer to, for example, software, firmware and/or circuitry configured to perform any of the aforementioned operations. Software may be embodied as a software package, code, instructions, instruction sets and/or data recorded on non-transitory computer readable storage mediums. Firmware may be embodied as code, instructions or instruction sets and/or data that are hard-coded (e.g., nonvolatile) in memory devices. “Circuitry”, as used in any embodiment herein, may comprise, for example, singly or in any combination, hardwired circuitry, programmable circuitry such as computer processors comprising one or more individual instruction processing cores, state machine circuitry, and/or firmware that stores instructions executed by programmable circuitry. The circuitry may, collectively or individually, be embodied as circuitry that forms part of a larger system, for example, an integrated circuit (IC), system on-chip (SoC), desktop computers, laptop computers, tablet computers, servers, smartphones, etc.
Any of the operations described herein may be implemented in a system that includes one or more storage mediums (e.g., non-transitory storage mediums) having stored thereon, individually or in combination, instructions that when executed by one or more processors perform the methods. Here, the processor may include, for example, a server CPU, a mobile device CPU, and/or other programmable circuitry. Also, it is intended that operations described herein may be distributed across a plurality of physical devices, such as processing structures at more than one different physical location. The storage medium may include any type of tangible medium, for example, any type of disk including hard disks, floppy disks, optical disks, compact disk read-only memories (CD-ROMs), compact disk rewritables (CD-RWs), and magneto-optical disks, semiconductor devices such as read-only memories (ROMs), random access memories (RAMs) such as dynamic and static RAMs, erasable programmable read-only memories (EPROMs), electrically erasable programmable read-only memories (EEPROMs), flash memories, Solid State Disks (SSDs), embedded multimedia cards (eMMCs), secure digital input/output (SDIO) cards, magnetic or optical cards, or any type of media suitable for storing electronic instructions. Other embodiments may be implemented as software executed by a programmable control device.
Thus, the present disclosure is directed to push telemetry data accumulation. A system may comprise at least telemetry circuitry configured to push telemetry data (e.g., provide telemetry data without first receiving a request). An example system may comprise one or more devices that include at least one set of telemetry circuitry. The at least one set of telemetry circuitry may be configured to push data based at least on a frequency configuration and a skew configuration. The frequency configuration may control how often the at least one set of telemetry circuitry generates data. The skew configuration may control when the telemetry data is transmitted. For example, sets of telemetry circuitry may be configured with different skew configurations to minimize transmission overlap. This may prevent telemetry data accumulation (TDA) circuitry in the system, which receives the transmission of telemetry data from the at least one set of telemetry circuitry, from becoming overwhelmed.
The following examples pertain to further embodiments. The following examples of the present disclosure may comprise subject material such as a device, a method, at least one machine-readable medium for storing instructions that when executed cause a machine to perform acts based on the method, means for performing acts based on the method and/or a system for push telemetry data accumulation.
According to example 1 there is provided a system equipped for push telemetry data accumulation. The system may comprise at least one set of telemetry circuitry to at least generate and transmit telemetry data and processing circuitry to execute code for transforming the processing circuitry into specialized circuitry to configure a frequency and skew in the at least one set of telemetry circuitry, the processing circuitry including at least telemetry data accumulation circuitry to receive the telemetry data from the at least one set of telemetry circuitry, wherein the at least one set of telemetry circuitry is to generate and transmit the telemetry data based on the frequency and skew configuration.
Example 2 may include the elements of example 1, further comprising clock circuitry to maintain universal timing in the system, the clock circuitry including a plurality of timers.
Example 3 may include the elements of example 2, wherein the processing circuitry is to cause the plurality of timers to be synchronized.
Example 4 may include the elements of example 3, wherein the processing circuitry causes the plurality of timers to be synchronized when the system is initialized.
Example 5 may include the elements of any of examples 3 to 4, wherein the plurality of timers includes at least one always running timer.
Example 6 may include the elements of example 5, wherein the at least one always running timer is synchronized via offset management.
Example 7 may include the elements of any of examples 2 to 6, wherein the at least one set of telemetry circuitry is monitor the timing based on the frequency configuration.
Example 8 may include the elements of example 7, wherein in generating the telemetry data the at least one set of telemetry circuitry is to capture the telemetry data when the timing is determined to correspond to the frequency configuration.
Example 9 may include the elements of example 8, wherein in transmitting the telemetry data the at least one set of telemetry circuitry is to initiate a delay period based on the skew configuration when the timing is determined to correspond to the frequency configuration and then transmit the telemetry data to the telemetry data accumulation circuitry following the delay period.
Example 10 may include the elements of any of examples 1 to 9, wherein the processing circuitry is further to control the operation of the system based on the telemetry data.
According to example 11 there is provided a method for push telemetry data accumulation. The method may comprise determining a timing from clock circuitry in a system; and generating and transmitting telemetry data in at least one set of telemetry circuitry in the system based on a frequency configuration and skew configuration in the at least one set of telemetry circuitry.
Example 12 may include the elements of example 11, and may further comprise initializing the system and synchronizing the clock circuitry.
Example 13 may include the elements of any of examples 11 to 12, and may further comprise setting the frequency configuration and the skew configuration in the at least one set of telemetry circuitry.
Example 14 may include the elements of any of examples 11 to 13, wherein generating the telemetry data comprises capturing the telemetry data when the timing is determined to correspond to the frequency configuration.
Example 15 may include the elements of any of examples 11 to 14, wherein transmitting the telemetry data comprises initiating a delay period based on the skew configuration when the timing is determined to correspond to the frequency configuration and transmitting the telemetry data following the delay period.
Example 16 may include the elements of any of examples 11 to 15, and may further comprise receiving the telemetry data at telemetry data accumulation circuitry in processing circuitry in the system.
According to example 17 there is provided a system for push telemetry data accumulation including at least one device, the system being arranged to perform the method of any of the above examples 11 to 16.
According to example 18 there is provided a chipset arranged to perform the method of any of the above examples 11 to 16.
According to example 19 there is provided at least one machine readable medium comprising a plurality of instructions that, in response to be being executed on a computing device, cause the computing device to carry out the method according to any of the above examples 11 to 16.
According to example 20 there is provided at least one device configured for push telemetry data accumulation, the at least one device being arranged to perform the method of any of the above examples 11 to 16.
According to example 21 there is provided a system for push telemetry data accumulation. The system may comprise means for determining a timing from clock circuitry in a system and means for generating and transmitting telemetry data in at least one set of telemetry circuitry in the system based on a frequency configuration and skew configuration in the at least one set of telemetry circuitry.
Example 22 may include the elements of example 21, and may further comprise means for initializing the system and means for synchronizing the clock circuitry.
Example 23 may include the elements of any of examples 21 to 22, and may further comprise means for setting the frequency configuration and the skew configuration in the at least one set of telemetry circuitry.
Example 24 may include the elements of any of examples 21 to 23, wherein the means for generating the telemetry data comprise means for capturing the telemetry data when the timing is determined to correspond to the frequency configuration.
Example 25 may include the elements of any of examples 21 to 24, wherein the means for transmitting the telemetry data comprise means for initiating a delay period based on the skew configuration when the timing is determined to correspond to the frequency configuration and means for transmitting the telemetry data following the delay period.
Example 26 may include the elements of any of examples 21 to 25, and may further comprise means for receiving the telemetry data at telemetry data accumulation circuitry in processing circuitry in the system.
The terms and expressions which have been employed herein are used as terms of description and not of limitation, and there is no intention, in the use of such terms and expressions, of excluding any equivalents of the features shown and described (or portions thereof), and it is recognized that various modifications are possible within the scope of the claims. Accordingly, the claims are intended to cover all such equivalents.