The present application claims priority to United Kingdom Patent Application No. GB2202823.7 filed Mar. 1, 2022, the disclosure of which is hereby incorporated herein by reference in its entirety.
The present disclosure relates to a processing device comprising a plurality of components including a processing unit configured to execute a set of application instructions.
In the context of processing data for complex or high-volume applications, a processing unit for performing the processing of that data may be provided. The processing unit may function as a work accelerator to which the processing of certain data is offloaded from a host system. Such a processing unit may have specialised hardware for performing specific types of processing. For example, a processing unit adapted for machine learning may include a large number of processors tiles implemented together on the same chip, so as to provide for a large degree of parallelism supported by the same processors. To support the operation of such a processing unit, additional circuitry may be provided together with the processing unit as part of the same device. Such circuitry may include, for example, on-chip memory that is independent of the memory of the processor tiles, port controllers for external communication, boot hardware for booting the processing units. The processing device in which the processing unit is provided, therefore, includes a plurality of further components, in addition to the processing unit itself.
During processing of an application supported on a device, various error events may be associated with one or more of the components of the device. Common events include, for example, an over temperature condition, occurrence of an uncorrectable memory error, failure of an external link of a device.
When performing processing using a device having multiple components, one challenge is to ensure that notification of error events that may require event handling actions to be performed are effectively propagated across the device to enable any of the components of the device to take appropriate responsive action.
According to a first aspect, there is a processing device comprising: a plurality of components, wherein each of the components is associated with storage for storing a copy of an error event vector for the processing device, wherein the error event vector comprises a plurality of elements, each of which is associated with a different type of error condition event; and a control node for updating the elements of the error event vector, wherein each of a subset of the components comprises event detection circuitry operable to detect an event associated with the respective component and cause that event to be reported to a control node in a respective event report, wherein the control node comprises processing circuitry configured to receive a first of the event reports from a first of the components, reporting a first type of event, and responsive to that first of the event reports: broadcast one or more writes to each of the plurality of the components, so as to cause each of the copies of the error event vector to be updated by setting a first one of the elements that is associated with the first type of event so as to indicate that the first type of event has occurred on the processing device, wherein a second one of the components comprises circuitry configured to, perform an action associated with the first type of event in response to the setting of the first one of the elements in its own copy of the error event vector.
An error event vector is defined for the device, where each element of that error event vector is used to indicate whether or not an event of the associated event class has occurred for any of the components of the device. If so, a control node causes the respective element of each of the copies of the error event vector to be set to indicate that an error of the event class has occurred. A component, i.e. the second one of the components, performs a responsive action for the event class in response to the update to its own copy of the error event vector.
In some embodiments, the action performed in response to the detection of the first type of event comprises at least one of: an event handling action; and notifying event handling software.
In some embodiments, a third one of the components comprises circuitry configured to, perform a further action associated with the first type of event in response to the setting of the first one of the elements in its own copy of the error event vector, wherein the further action is different to the action performed by the second one of the components in response to the detection of the first type of event.
In some embodiments, the processing circuitry of the control node is configured to receive a second of the event reports reporting a second type of event, and responsive to that second of the event reports: broadcast one or more writes to each of the plurality of the components, so as to cause each of the copies of the error event vector to be updated by setting a second one of the elements that is associated with the second type of event in each of the copies, wherein the second one of the components comprises circuitry configured to, perform a further action associated with the second type of event in response to the setting of the second one of the elements in its own copy of the error event vector, wherein the further action is different to the action performed by the second one of the components in response to the detection of the first type of event.
In some embodiments, the second one of the components is a circuit for exchanging data packets between the processing unit and a further processing unit belonging to a further device, wherein the action comprises preventing the exchange of further data packets between the processing unit and the further processing unit.
In some embodiments, the action performed by the second one of the components comprises providing a notification to event handling software configured to determine a further action to be performed for the processing device.
In some embodiments, one of the plurality of components includes a processing unit for executing a set of instructions of an application, wherein the further action comprises a reset of the processing device, wherein the processing device comprises reset circuitry configured to: receive from the event handling software a signal to cause the processing device to undergo the reset; and in response to the signal, cause the processing device to undergo the reset at least by wiping state of the application contained in memory of the processing unit.
In some embodiments, the first of the event reports reporting comprises additional event details not recorded in the error event vector, wherein the control node comprises an event data register for storing the additional event details.
In some embodiments, the control node is configured to: following the broadcasting of the one or more writes, receive a read request from an event handler, and return in response the additional event details.
In some embodiments, further comprising a bus via which the one or more writes are broadcast, wherein each of the components has an associated node on the bus which provides a target for the one or more writes.
In some embodiments, each of the targets comprises a storage for storing the copy of the error event vector for its associated one of the components.
In some embodiments, the plurality of event reports are sent via the bus.
In some embodiments, the processing device comprises one or more interfaces for interfacing with one or more further processing devices of a data processing system, wherein the error event vector is a global event vector for which each of the elements indicates whether or not an event of the associated event class has occurred in the data processing system.
In some embodiments, the one or more interfaces are configured to receive an update to a second of the elements of the global event vector from the one or more further processing devices, wherein the control node is configured to: broadcast one or more writes to each of the plurality of the components, so as to cause each of the copies of the error event vector to be updated by setting the second one of the elements in each of the copies.
In some embodiments, the data processing device is an integrated circuit.
In some embodiments, the data processing device is an integrated circuit configured to interface with one or more further integrated circuits, wherein a first of the further integrated circuits comprises further event detection circuitry operable to detect a further event associated with the respective component and cause that event to be reported to the control node in a further event report, wherein the processing circuitry of the control node is configured to responsive to the first of the event reports, broadcast one or more writes to each of the plurality of the components, so as to cause each of the copies of the error event vector to be updated by setting a second one of the elements that is associated with the further type of event in each of the copies.
In some embodiments, the plurality of components includes a processing unit for executing a set of instructions of an application, wherein the action associated with the first type of event affects a state of the application.
In some embodiments, the action associated with the first type of event causes application processing on the processing device to pause or cease.
According to a second aspect, there is provided a data processing system comprising the processing device as claimed in any preceding claim, wherein the data processing system comprises one or more further processing devices, wherein the error event vector is a local event vector for recording events for the processing device, wherein each of the one or more further processing devices comprises at least one storage storing a local event vector associated with the respective further processing device, wherein the local event vector for the processing device differs from at least one of the local event vectors for the further processing devices.
According to a third aspect, there is provided a method comprising: storing in association with each of a plurality of components of a processing device, a copy of an error event vector for the processing device, wherein the error event vector comprises a plurality of elements, each of which is associated with a different type of event indicative of an error condition; at each of a subset of the components, detecting an event associated with the respective component and causing that event to be reported to a control node in a respective event report; receiving at a control node for updating the elements of the error event vector, a first of the event reports from a first of the components, the first of the event reports reporting a first type of event; and responsive to the first of the event reports: broadcasting one or more writes to each of the plurality of the components, so as to cause each of the copies of the error event vector to be updated by setting a first one of the elements that is associated with the first type of event in each of the copies; and at a second one of the components performing an action associated with the first type of event in response to the setting of the first one of the elements in its own copy of the error event vector.
To aid understanding of the present disclosure and to show how embodiments may be put into effect, reference is made by way of example to the accompanying drawings in which:
Reference is made to
The processing unit 2 comprises an array 6 of multiple processor tiles 4 and an interconnect 34 connecting between the tiles 4. The processing unit 2 may be implemented alone as one of multiple dies packaged in the same IC package. The interconnect 34 may also be referred to herein as the “exchange fabric” 34 as it enables the tiles 4 to exchange data with one another. Each tile 4 comprises a respective instance of an execution unit and memory. For instance, by way of illustration, the processing unit 2 may comprise of the order of hundreds of tiles 4, or even over a thousand. For completeness, note also that an “array” as referred to herein does not necessarily imply any particular number of dimensions or physical layout of the tiles 4.
In embodiments, each processing unit 2 is part of a chip that also comprises one or more external links, enabling the processing unit 2 to be connected to one or more other processing units (e.g. one or more other instances of the same processing unit 2). These external links may comprise any one or more of: one or more processing unit-to-host links for connecting the processing unit 2 to a host system, and/or one or more processing unit-to-processing unit links for connecting together with one or more other instances of the processing unit 2 on the same IC package or card, or on different cards. The processing unit 2 receives work from the host, in the form of application data which it processes.
Each of the tiles 4 comprises processing circuitry and memory. In some example embodiments, the processing circuitry is a multi-threaded processor 10.
The memory 12 stores a variety of different threads of a program, each thread comprising a respective sequence of instructions for performing a certain task or tasks. Note that an instruction as referred to herein means a machine code instruction, i.e. an instance of one of the fundamental instructions of the processor's instruction set, consisting of a single opcode and zero or more operands.
Within the processor 10, multiple different ones of the threads from the instruction memory 12 can be interleaved through a single execution pipeline 13 (though typically only a subset of the total threads stored in the instruction memory can be interleaved at any given point in the overall program). The multi-threaded processor 10 comprises: a plurality of context register files 26 each arranged to represent the state (context) of a different respective one of the threads to be executed concurrently; a shared execution pipeline 13 that is common to the concurrently executed threads; and a scheduler 24 for scheduling the concurrent threads for execution through the shared pipeline in an interleaved manner, preferably in a round robin manner. The processor 10 is connected to a shared instruction memory 12 common to the plurality of threads, and a shared data memory 22 that is again common to the plurality of threads.
The execution pipeline 13 comprises a fetch stage 14, a decode stage 16, and an execution stage 18 comprising an execution unit which may perform arithmetic and logical operations, address calculations, load and store operations, and other operations, as defined by the instruction set architecture. Each of the context register files 26 comprises a respective set of registers for representing the program state of a respective thread.
Reference is made to
In a particular processing node (either node 300 or node 400), a number of different events may occur that may be indicative of error conditions that have occurred in the processing node. Such events may, for example, be an overtemperature event detected by the temperature sensor 330, an exception event recorded by a tile 4 whilst executing its application code, or occurrence of an uncorrectable error in a DRAM module 350, 430. Some of the error events may be fatal to the application, e.g. a link between chips has gone down, whereas other may not be fatal whilst still requiring reporting, e.g. a number of correctable errors above a threshold amount has occurred on a link. The events for which reporting and aggregation is performed are each assigned to an event classes, which refers to the type of event. For example, an uncorrectable memory error in a DRAM module 350, 430 may be one event class, whereas a security exception may be another event class. In the case of the processing node 400, which comprise multiple chips 410, 420, some of the events may take place on the main processing chip 410, whist others may occur on one of the fabric chips 420.
A system of processing nodes is provided in which each of the processing nodes is configured to execute part of the application code for the entire system. Such a system may be referred to as a partition, since a single isolated application executes across the devices of the system. Each processing node in the system stores at least one copy of an event vector, where each element of that event vector corresponds to a different event class. Each element indicates whether an event of the class to which it corresponds has occurred anywhere in the system of processing nodes. This event vector, which is aggregated across the system, is referred to herein as a global event vector (GEV). In addition to the GEV, each node also stores its own associated local event vector (referred to herein as the ‘CEV’). The CEV also comprises a plurality of elements, where each of those elements indicate whether an event of a corresponding event class has occurred on the processing node storing that local event vector.
Reference is made to
Reference is made herein to ‘event state’. This refers to the state of the CEV and GEV. Reference is also made to ‘global event state’, which refers to the state of the GEV.
Reference is made to
The connections between the nodes 510 that are used for the exchange of the global event state form a spanning tree. The spanning tree enables communication between any of the nodes 510 in the system 500, but does so without any cycles (or rings) being provided in the graph that is formed by the interconnected nodes 510. The use of the spanning tree enables messages to be transmitted between any two of the nodes 510 is a small number of hops, whilst maintaining a simple topology with a smaller number of connections than might otherwise be the case.
Reference is made to
Although, in the examples of
Reference is made to
As shown, each of the nodes 510a-d of the system maintains a copy of the GEV and a copy of its own CEV. In practice, each node comprises a plurality of registers, some of which are referred to as global event vector registers (GEVVRs) and hold one of the copies of the GEV, and some of which are referred to as the Colossus event vector registers (CEVVRs) and hold one of the copies of the CEV. However, logically it may be considered that there is a single copy of the node's CEV and a single copy of the GEV on each of the nodes 510a-510d.
Whenever an event of an event class that is recorded in the CEV occurs on one of the nodes 510a-d, processing circuitry of that node 510a-d updates the CEV held on that node 510. Specifically, the processing circuitry of that node 510a-d updates the element of the CEV that corresponds to the event class of the event that was detected. If the event class is a class that is propagated across the nodes 510, in addition to updating the CEV on one of the nodes 510a-d, circuitry of that node 510 also updates the corresponding element of the GEV held on that node 510. Interface circuitry of the processing node 510 then causes an update message (which may be referred to as GCM message) comprising an indication of the update to the GEV to be sent to one or more other processing nodes 510. Each such update message may comprise the entire updated GEV or an indication of the element of the GEV that is to be updated. The update message is sent from one of the nodes 510a-d to a node 510 that is a neighbouring node (i.e. is connected to) of the one of the nodes 510a-d sending the update. The node 510 that receives the update message, updates its copy of the GEV in accordance with the update message, and then sends one or more further update messages to its own neighbouring nodes 510 (other than the neighbouring node 510 that provided it with the update).
In the example in
In response to the update to the copy of the GEV on node 510a, circuitry of the node 510a causes a data packet to be issued to node 510b, where that data packet comprises an indication of the update to the GEV. The node 510b receives the data packet, and circuitry of the node 510b causes the copy of the GEV 510b held on the node 510b to be updated in accordance with the indication.
In response to the update to the copy of the GEV on node 510b, circuitry of the node 510b causes data packets to be issued to nodes 510c, 510d, where those data packet each comprise an indication of the update to the GEV. Circuitry of each of these nodes 510c, 510d causes each of the copies of the GEV held on the respective node 510 to be updated in accordance with indicated update provided in the data packets.
It will now be described how the event state is reported by a component in a processing node 510 and propagated to other components in that node 510
When an event is detected by a particular component of a processing node 510, that component forwards an event report to a regulator component of the node 510, which updates its copy of the CEV (known as the master copy) before broadcasting the update to other components that maintain other copies of the CEV. The exchange of these messages between nodes may take place via a control bus architecture.
Reference is made to
The control bus 700 is described in more detail in our earlier application Ser. No. 17/328,143, which is incorporated by reference. The control bus 700 is a data path for carrying single word control traffic in ring. The control bus 700 is a pipelined data bus via which data packets move from stage to stage in the pipeline at a rate determined by a clock pulse that is applied to the control bus 700. The ring comprises a plurality of a nodes 710, with traffic passing from one node 710 to the next node 710 in a direction of flow around the ring. Each node's output port 750 is connected to the input port 760 of the next node 710 in the ring.
Some of the nodes (referred to herein as target nodes) have circuitry for receiving requests to read or write to configuration settings associated with that node. An example of a target node 720 is shown attached to the bus 700. Such a target node 720 stores configuration settings for its associated component 770, where those configuration settings may be read from or written to by read/write requests received from the control bus 700. The configuration settings (or configuration state) includes a copy of the CEV and the GEV.
Some of the nodes (referred to herein as initiator nodes) have requesting circuitry for issuing read or write requests onto the bus 700. An example of an initiator node 730 is shown attached to the bus 700. Under the control of an attached module, such an initiator node 730 issues read or write requests to configuration settings associated with target nodes 720 attached to the control bus 700. Initiators 730 may be controlled by software in some cases, and by fixed function hardware engines in others.
As shown, each of the initiator nodes 730 and each of the target nodes 720 has an associated component (shown as attached block) 770. The initiator nodes 730 and target nodes 720 may be implemented within their associated component 770. Each of the initiators 730 operates under the control of its associated component 770 to dispatch read or write requests on to the control bus 700. Each of the target nodes 730 receives and stores configuration state for controlling its associated component 770. This configuration state is output from the target node 720 to the associated component.
Each of the initiator nodes 730 is capable of issuing requests to target nodes 720 and receiving completions from the target nodes 720. Each request is either a command to read from a storage (e.g. an attached addressable entity or auto-generated register) associated with the target node 720 or a request to write to such a storage associated with the target node 720. In response to receipt of such a request, a target node 720 responds by issuing a completion. A completion provides a status update indicating whether or not the read or write request was successful or not. In the case of read completions, each of the completions contains the data that was read from the target node 720 and is returned to the initiator node 730 that issued the read request. In the case of write completions, the write completion comprises an indication of whether or not the write request was successful or not.
A further type of transaction supported by the control bus 700 is an event report. Event reports are packets posted to the control bus 700 that are dispatched on to the control bus 700 either by an initiator node 730 or by a target node 720 and contain information relating to a detected event. When a hardware unit 770 detects an event, it controls its associated initiator node 730 or associated target node 720 to cause an event report to be dispatched on to the control bus 700.
Reference is made to
The event class field 820 identifies the event class that the detected event falls into. In embodiments, the event class identifies one of the 15 event classes discussed above that may be captured in the CEV. The event identifier field 830 identifies a unique event occurring at the component 770 that is identified by the origin field 810 and occurring within the event class 820. The event identifier field 830 also comprises additional details of the event.
When an event report is dispatched onto the bus 700, that event report is delivered to the Cbus regulator 740. The Cbus regulator 740 may also be referred to as control node 740 or control component 740. The event report circulates on the bus 700 until it reaches the Regulator 740, where it is consumed and the Event logged.
Reference is made to
The regulator node 740 comprises a plurality of registers 1020 for storing the information received in the event reports. These registers 1020 are referred to as event data register (EDR) 1020. The regulator node 740 comprises an EDR 1020 for each of the plurality of event classes.
When an event report is received at the regulator 740, the regulator 740 causes information from that event report to be stored in the EDR 1020 for the event class identified in the event report. The information stored in the EDR 1020 comprises the event identifier 830 from that event report and the event origin identifier 810 from the event report. Each EDR 1020 also comprises an event flag, which is set to indicate that an event of the class corresponding to the class of the EDR 1020 has occurred. In response to the event report, if the event flag for the EDR 1020 corresponding to the class of the event report is not already set, the node 740 causes that event flag to be updated to indicate that an event has occurred for that event class.
The regulator 740 also comprises a register 1030 for storing a copy of the CEV for the processing node 510. This register 1030 is referred to as the master CEVVR 1030, since it is first of the CEVVRs in the node 510 to be updated in response to the detection of an event. When the event report is received at the regulator 740, if the bit of the CEV corresponding to the event class identified in the event report is not already set, the regulator 740 causes that bit of the CEV to be set to indicate that an event of that class has occurred. The CEV exhibits idempotency, such that, if a bit of the CEV for a particular event class is already set, then when a subsequent event report of the same event class is received, that bit of the CEV remains unchanged. The regulator node 740 controls access permissions for the CEV such that the bits of the CEV, may not be unset except in response to a reset event.
The regulator node 740 comprises a register 1010 for storing a copy of the GEV. The register 1010 is referred to as the master GEVVR 1010, since it updated prior to the updated of the GEVVRs of the target nodes 720 in the same processing node 510. The master GEVVR 1010 can be updated in response to either i) the detection of an event in its own node 510 or ii) a packet received at the node 510 indicating an update to the GEV, where that update results from an event that has occurred on another node 510.
The regulator node 740 comprises a mask register 1050, referred to herein as the GEVVRMASK register 1050. The GEVVRMASK register 1050 provides a set of bits, which indicate for each event class having a corresponding element in the GEV, whether or not global aggregation is enabled for that event class. To ensure consistency in which event classes are aggregated across the system 500, the values held in the GEVVRMASK register 1050 are set to be the same for each of the nodes 510 in the system 500.
When the event report is received at the regulator 740, if the bit in the GEVVRMASK register 1050 corresponding to the event class identified in the event report is set to indicate that global aggregation is enabled, and the bit set in the GEVVR 1010 is not already set to indicate an event has occurred in that class, the regulator 740 then causes the bit of the GEV for that class to be set to indicate that an event of that class has occurred. The GEV exhibits idempotency, such that, if a bit of the GEV for a particular event class is already set, then when a subsequent event report of the same event class is received at the regulator 740, that bit of the GEV remains unchanged. The regulator node 740 controls access permissions for the GEV, such that bits of the GEV that indicate the occurrence of an event, may not be unset except in response to a reset event.
When one or more of the event flags in the EDRs 1020 changes state to indicate an event has occurred, the regulator 740 broadcasts an update message to all of the target nodes 720 in the processing node 510. The update message is a message sent via the control bus 700 to update the CEVVRs of each of the target nodes 720 in the processing node 510. The update message causes each of the copies of the CEV in the node 510 to be updated such that the element of the CEV associated with the class for which the event flag was set, is updated to reflect that an event has occurred in that class.
Additionally, when one or more bits in the master GEVVR 1010 changes state, the regulator 740 broadcasts an update message (which may be the same update message used to update the copies of the CEV) to all of the target nodes 720 in the processing node 510. The update message is a message sent via the control bus 700 to update the GEVVRs of each of the target nodes 720 in the processing node 510. The update message causes each of the copies of the GEV in the target nodes 720 to be updated such that the element of the GEV that is associated with the event class for which the event flag was set, is updated to reflect that an event has occurred in that class.
Reference is made to
In addition to the at least one target node management register 910, the target node 720 is associated with additional storage 920 that is part of the component 770 with which the target node 720 is associated. The additional storage 920 may comprise an auto-generated register and/or storage accessible via an addressable window. This additional storage 920 may include control registers on tiles 4 of the processing unit 2 that are addressable over a further bus. This additional storage 920 may allow access to off-chip storage, such as host storage that is accessible over PCI links. In this, case the additional storage 920 is memory of a host dispatcher that provides data written to the memory to the host storage.
The target node has an input port and an output port. The input port receives read and write requests from the control bus 700, with these requests being buffered in request buffer 960 and then passed to the processing logic 930. The outport port sends completions from the completion buffer 970 onto the control bus 700. The processing logic 930 may perform functions implemented in hardware or software. The processing logic 930 may comprises one or more of an ASIC, FPGA, or at least one processor configured to execute computer readable instructions stored in at least one memory of the target node 720.
As shown in
When the regulator 740 send an update message to update the CEV, this update message is received at the target node 720. The processing logic 930 cause the CEVVR 980 of that target node 720 to be updated in accordance with the update. The CEV in CEVVR 980 is updated to match the CEV held in the master CEVVR 1030. The processing logic 980 causes this updated CEV state to be propagated to the attached component 770 to enable that component to act on the updated error state. The same updates are performed in each of the target nodes 720 in the processing node 510.
Likewise, when the regulator 740 send an update message (which may be the same as or different to that used to update the GEV) to update the GEV, this update message is received at the target node 720. The processing logic 930 cause the GEVVR 990 of that target node 720 to be updated in accordance with the update. The GEV in GEVVR 990 is updated to match the GEV held in the master GEVVR 1010. The processing logic 980 causes this updated GEV state to be propagated to the attached component 770 to enable that component to act on the updated error state. The same updates are performed in each of the target nodes 720 in the processing node 510.
Amongst the components 770 that receive updates to their associated GEVs (i.e. those held in the target GEVVR 990) are the EPCs (e.g. EPCs 360, 460, 470) of the processing node 510. When certain EPCs receive updates to their GEV from the regulator node 740 of the processing node 510 to which they belong, these EPCs are configured to provide in an update message, an indication of the updated GEV state. The indication of the GEV state is propagated between the processing nodes 510 and used to update the GEVs held in those nodes 510. The certain EPCs configured to propagate the event state are those used for communicating over the connections shown in
Reference is made to
Reference is made to
As described, in response to a GEV update message broadcast from the regulator 740, the GEVVR register 990 is updated. This updated state of the GEV is output from the target 720 to the GCP 1200. The GCP 1200 comprises a register 1210, referred to herein as the GEVEN register 1210. The register 1210 comprises an indication as to whether or not the GCP 1200 is enabled for global event aggregation. If the GCP 1200 is enabled, by the indication in register 1210, to perform global event aggregation, the GCP 1200 will respond to updates to its target GEVVR 990 by dispatching update packets to another processing node 510.
Each GCP 1200 comprises a further register 1240, referred to herein as the Global Event GCP External Global Event Vector Register (GEVEXTGEVVR) 1240. The GEVEXTGEVVR 1240 stores a copy of the GEV. The circuitry 1220 compares the copy of the GEV held in the GEVEXTGEVVR register 1240 to the copy of the GEV held in the GEVVR register 990 to determine whether or not updates should be dispatched to another node 510 or to the regulator 740 of the same node. If circuitry 1220 of the GCP 1200 determines that a bit is set in the target GEVVR 990, that is not set in the GEVEXTGEVVR 1240, the circuitry 1220 of the GCP 1200 updates the GEVEXTGEVVR register 1240 to match the copy of the GEV held in the GEVVR 990. The GCP 1200 also causes an update message to be dispatched to a GCP on another node 510 that the GPC 1200 is configured to communicate with. The update message provides an indication of the updated GEV and causes that recipient GCP to update its own GEVEXTGEVVR to match the GEVEXTGEVVR 1240 of the GCP 1200 that dispatched the update message.
To provide for reliable propagation, the GCP 1200 sends the update message three times. Having dispatched the GEV update message in a frame, the GCP 1200 then waits for 1000 system clock cycles of its chip 510 to elapse, before re-sending the same frame containing the update message. The GCP 1200 then waits another 5000 system clock cycles and then sends the frame a third time. If the GCP's 1200 associated target GEVVR 990 changes again before these copies have been sent, then the resend sequence above is aborted and a new update message is sent containing the new state held in the GEVVR 990.
The GCP 1200 may receive update messages from a GCP on another node 510 that cause the copy of the GEV in its GEVEXTGEVVR 1240 to be updated. As a result of such updates, the copy of the GEV held in the GEVEXTGEVVR 1240 may not match the copy of the GEV held in the target GEVVR 990 associated with the GCP 1200. In response to determining that a bit is set in the GEVEXTGEVVR 1240 that is not set in the associated GEVVR 990, the GCP 1200 issues a write request to the Cbus regulator 740 on its own node 510, where that write request is a request to update the GEVUPDATER register 1060 to match the copy of the GEV now held in the GEVEXTGEVVR 1240.
In response to receipt of the write to the GEVUPDATER 1060, the regulator node 740 updates the GEVUPDATER 1060 accordingly. In response to the update to GEVUPDATER 1060, the regulator 740 updates its copy of the GEV held in the master GEV register 1010 for the processing node 510. The update to master GEVVR 1010 is performed such that any bit set in GEVUPDATER 1060 to indicate that an event has taken place in a particular class is also set in GEVVR 1010. However, for any bits in GEVUPDATER 1060 that are set to indicate that no event has occurred in that class, then the regulator 740 will not update GEVVR 1010 to indicate that no event has occurred in that class. In this way, the update policies of the regulator 740 ensure that the GEV held in GEVVR 1010 is idempotent.
In addition to updating its copy of the GEV held in register 1010, the regulator 740 broadcasts an update message on the control bus 700 to all of the target nodes 720 of the processing node 510.
The update message comprises the updated GEV held in the register 1010 of the regulator 740. Referring to
Some of these components 770, which via their associated GEVVR 990 receive updates to their copy of the GEV, are themselves GCPs that are enabled to perform global event aggregation. Each such GCP, in response to an update to its GEVVR 990, issues an update message to another node 510. The updated GEV is then propagated to the different components of that another node 510 in the same manner as described above.
Reference is made to
The result of the propagation of the local event state (i.e. the CEV) and the global event state (i.e. the GEV) to the components 770 provides each component 770 in the system 500 with access to two different event vectors. Each component 770 has access to, via its own local copy of the CEV for its processing node 510, device wide event and error state for its own processing node 510. Each component 770 also has access to, via its own local copy of the GEV for the system, system wide event and error state. On the basis of this state, components 770 may be configured to perform action. Such actions taken on the basis of a copy of the CEV or GEV accessible to a component are referred to herein as autonomous event handling (AEH). Different components 770 in the same processing node 510 may be configured to perform different actions in response to events belonging to the same class. One or more components 770 may be configured with different policies and be configured to perform different actions in response to events belonging to different event classes. Furthermore, one or more components 770 may perform different actions in response to events associated with its own processing node 510 (and reflected in its CEV) as compared to events associated with the system 500 (and reflected in the GEV).
An example of a component that may participate in AEH is circuitry (referred to herein as an exchange block (XB)) for enabling tiles 4 of the processing unit 2 to exchange data with devices external to the chip 510 on which the processing unit 2 is implemented.
Reference is made to
The XB 1310 is configured to engage in certain autonomous error handling (AEH) in response to indication of an error in the GEV. Reference is made to
In performing AEH, the XB 1310 stops the sending of packets to the interface 1320 from the tiles 4 and stops the sending of packets to the tiles 4 from the interface 1320. If the XB 1310 receives packets from the tiles 4, the XB 1310 causes these packets to be dropped. Likewise, if the XB 1310 receives packets from the interface 1320, the XB 1310 causes these packets to be dropped. The XB 1310, in this way, blocks communication between the tiles 4 and external devices. The result is that the data plane traffic is rapidly quiesced.
The type of event indicated in the GEV that may cause the XBs 1310 to be block the traffic is an error event that is fatal to the execution of the application, e.g. an unrepairable memory error, or one of the external links of the chip 1300 being brought down. In this case, the 10 traffic is quiesced in advance of reset of the chip 1300.
Different components in the system may comprise different mask registers, such as register 1410, that indicate for each component, which of events the respective component is configured to perform actions in response to. The mask register in a particular component may comprise a first set of indications, indicating for which of the event classes identified in the CEV, the component is configured to take action in response to. The mask register may also comprise a second set of indications, indicating for which of the event classes identified in the GEV, the component is configured to take action in response to. These registers are defined on a per component basis, such that each component may perform take action (i.e. perform AEH) in response to different types of events.
Each of the event classes defined in the CEV (and by extension the GEV also) has an associated event handler that is configured to implement a given response to the occurrence of that event. The event handler is a software module running on an event handler device. The action taken by the handling device is in addition to any AEH performed by individual components 770 of the processing node 510. For example, in response to an event occurring that represents a fatal application error, the handling entity may cause the application to be reset from checkpoint.
The handling entity is different for different event classes. For some event classes, the handling entity may be software running on the MCPU 310. For other event classes, the handling entity may be a host process running on the host 320/440. Each of the event handlers in the overall system is associated with one or more of the processing nodes 510 and is configured to take action with respect to its associated one or more of the processing nodes 510 in response to event notification received from the associated one or more of the processing nodes 510.
Reference is made to
The event notification hardware 1500 comprises a CEV notification mask register 1520. The CEV notification mask register 1520 indicates, for each of the event classes for which events are logged in the CEV, event notifications are to be provided to the handler software 1510. In response to receipt from the target node 720 that an event has occurred in a particular event class, processing circuitry of the event notification hardware 1500 checks the corresponding indicating in the register 1520 for that event class. If the register 1520 indicates that the events in that class are to be reported to handler software 1510, processing circuitry of the event notification hardware 1500 issues an event notification to the handler software 1510. The event notification may take the form of an interrupt to the handler software 1510.
The event notification hardware 1500 also comprises a GEV notification mask register 1530. The GEV notification mask register 1530 indicates, for each of the event classes for which events are logged in the GEV, event notifications are to be provided to the handler software 1510. In response to receipt from the target node 720 that an event has occurred in a particular event class, processing circuitry of the event notification hardware 1500 checks the corresponding indicating in the register 1530 for that event class. If the register 1530 indicates that the events in that class are to be reported to handler software 1510, processing circuitry of the event notification hardware 1500 issues an event notification to the handler software 1510. The event notification may take the form of an interrupt to the handler software 1510.
For each of the event classes reported in the CEV, one event hander is defined for handling events of that class. Similarly, for each of the event classes reported in the GEV, one event hander is defined for handling events of that class. In embodiments, each processing node 510 is associated with four event handlers: two host processes running on the host device 320/440, a process running on the MCPU 310, and a process running on an additional hardware unit for enabling cryptographic functions (referred to as the ICU). The event handlers may therefore be implemented on separate devices (e.g. the MCPU and host) or may take the form of separate processes running on the same device (e.g. separate host processes running on a single host).
In response to receipt of an event notification, the handler software 1510 is configured to take appropriate action. These actions include issuing a read request to read the event data registers 1020 in the associated regulator node 740. The event handler 1510 reads the EDR register 1020 for the relevant event class. The event handler reads the event flag and the event identifier from that EDR register 1020. The read may be issued by the event hander using an associated initiator 730 for that event handler, with the event details (e.g. the event flat and event identifier) being returned to the event handler 1510.
In the case of a global event notified to the handler software on the basis of the GEV, the event flag indicates to the event handler 1510 whether or not the event is associated with the processing node 510 with which that event handler 1510 is associated.
Reference is made to
As a first step, each event handler 1510, in response to receipt of an event notification, issues a read request to read the event data register 1020 associated with the event class identified by the event notification. The event data register 1020 that is read by each event handler 1510 belongs to the processing node 510 with which the event handler 1510 is associated.
As a second step, each event handler 1510, receives in response, the state held in the EDR 1020 that was identified by the read request it sent. This state includes the event flag and event identifier held in that EDR 1020. If the event reflected in the GEV occurred in the processing node 510 with which an event handler 1510 is associated, the event flag will be set in the state to indicate that the event occurred on that node 510. In the example, shown in
As a third step, the event handler 2 propagates messages in relation to the event to the other event handlers 1 and 3. The messages may be the event details received by event handler 2 in the EDR state or may be messages to cause the event handlers 1 and 3 to reset their associated processing nodes 510. In the example shown, each of the event handlers 1510 determines to reset its associated processing node 510. This determination is made based on the EDR state obtained from processing node 2. The determination may be made by the event handler 2, which then propagates a command to the other event handlers 1 and 3, or may be made by each event handler 1510 individually on the basis of the EDR state obtained and distributed by event handler 2.
In this example, and as a fourth step, it is shown that each of the event handlers 1510 issues a command to reset its associated processing node 510. This reset is achieved by asserting a signal to a reset pin 1600 on the processing node 510. Circuitry on each processing node 510 causes the reset to be performed.
The reset, which may be referred to as a software reset, resets the state of a plurality of components that are part of each processing node 510. The reset has the effect of wiping the memory of the tiles 4 to remove the application data. The reset also has the effect of wiping the state of cryptographic hardware used to encrypt communications in and out of the device 510. The reset causes the state for the logical links and the connections using those links to be reset. However, the reset does not take the link down, and all state to configure the physical link is unmodified. Therefore there is no need to reprogram the EPCs 470 after the reset. The reset does not wipe the application state of the MCPU 310.
The reset has the effect of causing the CEVs and GEVs held in the components of the system to be cleared, such that they do not indicate that any events have occurred. The clearing of the CEVs and GEVs is performed by the regulator 720, which has write permissions to the CEVVRs and GEVVRs in its processing node 510.
Once a particular processing node 510 has reset its state and tile memory has been wiped, that processing node 510 may restart its application from an application checkpoint. Each processing device 300/410 has access to an external memory in which checkpoint data is periodically stored. The tiles 4 of the processing unit, following the read request, load from the external memory the checkpoint data, enabling the application to be restarted from an earlier point.
Each of the event handlers 1510 is configured to cause its associated processing node 510 to be reset immediately without requiring synchronisation of the reset across the system. One problem that may be encountered when performing a reset without synchronisation is that one of the processing nodes 510 may perform its reset and restart from an earlier checkpoint, whilst a further processing node 510 has not yet undergone reset continues to execute an earlier version of the application. In this case, if the processing node 510 that has not yet undergone reset, sends data packets containing application data corresponding to an earlier version, these data packets may be received by a processing unit 2 that has reset from the checkpoint. In this case, erroneous results may occur in the processing by the processing unit 2 that has restarted from the checkpoint, since the processing unit 2 is receiving data corresponding to an earlier application version.
According to embodiments, a number (referred to as the generation number) is included in the frames sent between different processing nodes 510, where that number is updated in response to each reset event. The number, therefore, indicates how many times the application has been reset. When data frames are sent by one processing node 510 to another, the sending node 510 includes in each of those frames its own copy of the generation number. The number is checked at the recipient node 510 against the recipient's own copy of the generation number. The recipient node 510 discards the frames if the generation number in the frames does not match the generation number held by the recipient node 510. In this way, when the recipient node 510 has already reset and restored from checkpoint, the recipient node is protected against frames relating to pre-reset generation of the application, which may dispatched by other nodes in the system that have not yet undergone reset.
Reference is made to
Typically, the system would comprise more than two processing nodes, but for simplification only two such nodes are shown in
Reference is made to
At S1810, in response to a detected error event, reset circuitry 1600 of the first processing node 1700a causes the first processing node 1700a to be reset. As part of this reset, the state is erased from various components of the node 1700a. The memory of tiles 4 is wiped by circuitry of a hardware module of the node 1700a, which causes zeros to be written to that memory. As part of the reset, a copy of the generation number held in storage in the node 1700a is updated. As will be described, the generation number may be held in storage in the interface 1710. The generation number is updated by being incremented to a new value.
At 51820, following the reset of the processing node 1700a, the part of the application that the processing node 1700a is responsible for is restored from checkpoint. In order to achieve this, a bootloader program is provided from a hardware module of the node 1700a to different ones of the tiles 4. The tiles 4 execute the bootloader program to issue read requests to a checkpoint memory 1720. The checkpoint memory 1720 is shown as a single memory unit, but may comprise multiple memory units for different nodes 1700a,b. In response to the read requests issued by the tiles 4 of node 1700a, application instructions and application data for the checkpoint is returned to those tiles 4 from memory 1720. The application data returned to node 1700a represents the state of the part of the application executing on the processing unit 2 of that node 1700a that was written out of that processing unit 2 at the last checkpoint.
At S1830, the tiles 4 of the processing unit 2 of the node 1700a continue executing application instructions from the checkpoint. At the same time, the second processing node 1700b has not yet undergone reset and the processing unit 2 of that node 1700b is performing processing of its part of the application corresponding to an earlier generation. The second processing node 1700b, therefore, stores the earlier generation number, which was also held in storage of the first processing node 1700a, prior to the reset at S1810.
At S1840, the tiles 4 of the processing unit 2 of the node 1700b are configured to cause the issuance one or more data frames to the first processing node 1700a. The one or more data frames each comprise a copy of the earlier generation number held in storage of the node 1700b. The tiles 4 cause the data frames to be issued by issuing data packets to an EPC of the respective processing node 1700b, which causes the data packets to be encapsulated into data frames and sent to the node 1700a.
At S1850, the first processing node 1700a receives the data frames sent at S1840. Circuity of the first processing node 1700a checks the generation number in each of the data frames and compares this to the copy of the generation number held in the storage of the processing node 1700a. Since these two generation numbers do not match, the circuitry of the processing node 1700a discards the frames. As will be described, the checking and discarding of the frames may be performed by the interface 1710 of the first processing node 1700a.
At S1860, the second processing node 1700b resets. This step performed at S1860 is the same as S1810 described above, but performed by the second processing node 1700b, rather than the first processing node 1700a.
At S1870, following the reset of the processing node 1700b, the part of the application that the processing node 1700b is responsible for is restored from checkpoint. In order to achieve this, a bootloader program is provided from a hardware module of the node 1700b to different ones of the tiles 4. The tiles 4 execute the bootloader program to issue read requests to a checkpoint memory 1720. In response to the read requests issued by the tiles 4 of node 1700b, application instructions and application data for the checkpoint is returned to those tiles 4 from memory 1720. The application data returned to node 1700b represents the state of the part of the application executing on the processing unit 2 of that node 1700b that was written out of that processing unit 2 at the last checkpoint.
At S1880, the processing unit 2 of the second processing node 1700b continues execution of its part of the application from the checkpoint.
At S1890, the tiles 4 of the processing unit 2 of the node 1700b are configured to cause issuance of a further one or more data frames to the first processing node 1700a. The tiles 4 cause these further data frames to be issued by issuing data packets to an EPC of the respective processing node 1700b, which causes the data packets to be encapsulated into data frames and sent to the node 1700a. Unlike the frames sent at S1840, these further one or more data frames each comprise a copy of the updated version of the generation number, which is now held in the storage of both nodes 1700a,b.
At S1895, first processing node 1700a receives the data frames sent at S1890. Circuity of the first processing node 1700a checks the generation number in each of the data frames and compares this to the copy of the generation number held in the storage of the processing node 1700a. Since these two generation numbers match, the circuitry of the processing node 1700a accepts the frames. The data from these frames is written to tile 4 memory.
The generation number may be inserted at different points in the data frames sent between the nodes 1700a, 1700b. The generation number may be inserted in a packet header (e.g. an Elink packet header) that is dispatched by a tile 4. Alternatively, the generation number may be inserted in a payload of the packet.
Reference is made to
When a tile 4 has data to send, the tile 4 dispatches this data to the interface 1710 in the form of one or more data packets (e.g. Elink packets). The frame builder 1120 encapsulates the data packets into data frames by adding the frame headers and frame tail. In this way, the data packets issued by the processing unit 2 may be tunneled over Ethernet. The frame builder 1120 inserts the MAC held in the connection state register 1915 as the destination MAC for each frame. The frame builder 1120 inserts the MAC held in the connection state register 1915 as the source MAC for each frame.
On the receive side, a frame check buffer 1908 is provided that receives data frames from the other interface 1710 belonging to the other node. Circuitry of the interface 1710 shown in
The MCPU 310 comprises at least one processor executing instructions to provide the update function 1920 and the address resolution function 1940 shown. The address resolution function is configured to provide the MAC addresses for the connection, which are provided to the interface 1710. The MAC addresses are local scope MAC addresses and so may be updated by software, rather than fixed at all times for a particular interface 1710. The address resolution function 1940 inserts into each MAC address, the current generation number held in generation number register 1910. The remaining parts of the MAC address may be obtained from storage 1930 or be determined by the function 1940 in another suitable way.
The MCPU 404 updates MACs for a connection in a response to a reset event. The MCPU 404 comprises the generation number register 1210, which stores the current generation number, which is provided as part of each MAC address output by the address resolution function 1240. The processing circuitry of the MCPU 404 supports an update function 1220 that updates the generation number held in the generation number register 1210.
When a reset (e.g. the resets occurring in S1810 and S1860) of the processing node which the MCPU 310 belongs to is performed, the indication of this reset is delivered to the MCPU 310. The update function 1920 responds to this reset event by updating the value of the generation number held in the generation number register 1910. The update of the generation number held in the generation number register 1910 may comprise incrementing the current value of the generation number by one. For example, suppose that the generation number consists of five bits, with the current value of the generation number held in the register 1910 being given by the bit sequence: 00001. In response to a reset event, the update function 1920 updates the generation number by increasing the value by one to: 00010.
Since the generation number comprises a finite number of bits, in the case that the current value of the generation is equal to the maximum possible value, the updating of the generation number comprises resetting the generation number to the lowest possible value. For example, suppose that the generation number consists of five bits, with the current value of the generation number held in the register 1210 being given by the bit sequence: 11111. In response to a reset event, the update function 1220 resets the generation number to the lowest possible value given by: 00000. Therefore, the generation number is updated by the update function 1920 in a wraparound manner.
In response to the indication of the reset event, the address resolution function 1940 determines updated MAC addresses for the connections participated in by the device 400. As noted, one or more bits are reserved in each MAC address for representing the generation number. The address resolution function 1240 sets these bits to the value of the new generation number stored in the register 1910 by the update function. The remaining bits in each MAC address are set to the same values as before the reset event.
For each MAC address, the remaining bits of that MAC address may be determined in different ways. In some embodiments, these bits may be held in a storage 1930 accessible to the address resolution function 1240 and concatenated with the bits of the new generation number to form a full MAC address. These bits held in the storage 1930 are not wiped in response to the reset event, but persist and do not change following the reset event. In this embodiment, the storage 1930 stores the remaining bits (i.e. those bits other than the bits of the generation number) for each of the MAC addresses for which the address resolution function 1940 is responsible for determining. The address resolution function 1940 provides each of these MACs by combining the same generation number with the remaining bits for the respective MAC.
As noted, the application state for a first processing node 1700a may be restored from a checkpoint prior to the application state of other ones of the processing nodes (e.g. node 1700b) also being restored from. In this case, the first processing node 1700a may continue its application processing, even whilst processing node 1700b has not yet reset and comprises application state corresponding to a previous generation of the application. This may be enabled via the use of barrier synchronisations, which separate a compute phase for participating processing units 2 from an exchange phase for those processing units 2. Barrier synchronisations are inserted into the compiled code running on each of the processing units 2. For each of the barrier synchronisations one or more processing units 2 is configured to participate.
The use of barrier synchronisations prevents the first processing unit 2 of the node 1700a from running ahead of a point in its code, beyond which it would need to exchange data with a processing unit 2 that has not yet undergone restore and restart from a checkpoint. For example, suppose the processing unit 2 of the node 1700a, following the checkpoint, enters a compute phase in which it performs computations on data to generate results. The processing unit 2 of node 1700a does not exchange data with the processing unit 2 of node 1700b until it reaches a barrier synchronisation in which both processing units 2 of nodes 1700a, 1700b participate. Upon reaching this barrier synchronisation, the processing unit 2 of node 1700a stalls until the processing unit 2 of node 1700b also reaches the barrier synchronisation. In this way, even if the processing unit 2 of node 1700a reaches the barrier synchronisation, whilst node 1700b has not yet been reset, the processing unit 2 of node 1700a will wait until the node 1700b resets and its processing unit 2 reaches the barrier, before moving on to the exchange phase following the barrier synchronisation. During the exchange phase, the processing unit 2 of node 1700a sends any application data scheduled for sending during that exchange phase to the processing unit 2 of node 1700b.
The use of barrier synchronisations prevents processing units 2 of the system 500 from running ahead and sending data to any processing units 2 of the system 500 that have not yet reset. The use of barrier synchronisations in the context of the processing units 2 is described in more detail in our earlier U.S. application Ser. No. 17/446,681, which is incorporated by reference.
It has been described how, in response to a reset event, the copies of the CEV and GEV are cleared from the processing nodes (i.e. reset to indicate no events). Bits of the CEV may also be reset by the event handler for an event class. Resetting bits of the CEV enables another event within the event class enables to be detected and handled.
Referring again to
When an event handler 1510 has received an event notification, the event handler 1510 may, amongst other things, determine to clear the event state for that event, such that any further occurrences of events in the same event class may be detected. To clear the event state for an event class, the event handler 1510 issues a request via the control bus 700 to the regulator node 740, where that request is a request to clear the EDR for that event class. The request includes an identifier of the relevant event handler 1510 and an identifier of the event class. The regulator node 740 examines the permission indication for that event class in the event handler registration register 1040 for that event handler 1510. If the event handler 1510 has permission to clear the event state for that event class, the regulator node 740 updates the EDR for that event class to reset the EDR to its default state. In this state, the EDR indicates that no event has been detected. Additionally, the regulator node 740 updates the master CEVVR 1030 to reset the event indication for this event class. The regulator node 740 broadcasts a write request to also update the copies of the CEV held in the target nodes 720 of the processing node 510 so to also reset the event indication in the same way.
Reference is made to
S2010 is performed by each node 510 in the system 500. At S2010, each processing node 510 in the system 510 stores a copy of the global event vector for the processing system 500. Initially, this vector is set to indicate no events have occurred in the system 500. The global event vector is held in the master GEVVR 1010 and in the GEVVRs 990 of the target nodes.
S2020 is performed by each node 510 in the system 500. At S2020, each processing unit 2 in the system 500 executes a set of instructions of the distributed application.
S2030 is performed by each node 510 in the system 500. At S2030, each of the processing nodes 510, updates each of one or more the elements of the at least one copy of the global event vector in response to an event of a type that is associated with the respective element and that has taken place on one of the processing nodes in the processing system. This step is performed by the regulator 740.
At S2040, on a first of the processing nodes 510, a first event of a first of the types of event is detected. This event may, for example, be the event detected by component 770a of node 510a. In response to detection of the first event, the first of the processing nodes 510 provides to one or more other ones of the processing nodes 510, an indication of the update to a first of the elements of the global event vector. The first of the elements is associated with the first of the types of event.
S2050 is performed by other nodes 510 (i.e. other than the first of the nodes 510) in the system 500 that receive the update provided by the first of the processing nodes 510 at S2040. At S2050, each of these other nodes 510, responsive to the indication of the update to the first of the elements, updates a corresponding first of the elements in its at least one copy of the global event vector.
Reference is made to
At 52110, a copy of the event vector is stored for each of the components 770 in the device 300. Initially, each copy of the event vector may be set to indicate that no events in any of the event classes captured in the event vector have occurred.
At 52120, at each of a subset of the components 770, an event associated that component 770 is detected. The event is reported to the control node 740 in a respective event report. The subset of the components 770 comprises one or more components 770.
At 52130, the control node 740 receives a first of the event reports from a first of the components 770, the first of the event reports reporting a first type of event, where an event of that first type has been detected by the first of the components 770.
At 52140, the control node 740 broadcasts one or more writes to each of the plurality of the components 770, so as to cause each of the copies of the error event vector to be updated by setting a first one of the elements that is associated with the first type of event so as to indicate that the first type of event has occurred on the processing device. These copies are held in the CEVVRs 980 of the target nodes 720.
At 52150, at a second one of the components 770, an action associated with the first type of event is performed in response to the setting of the first one of the elements in its own copy of the error event vector.
Various functions are described above as being performed by circuitry, e.g. processing logic 930, processing circuitry 1010, processing circuitry 1220, processing circuitry 1400, circuitry 1600. This circuitry may comprise dedicated hardware, e.g. FPGAs or ASICs, and/or processors configured to execute instructions. Each processing node 510 in the system 500 is allocated a set of instructions for performing any of the operations performed by processors configured to executed instructions.
The above embodiments have been described by way of example only.
Number | Date | Country | Kind |
---|---|---|---|
2202823.7 | Mar 2022 | GB | national |