Detection of hardware errors using periodically synchronized redundant transactions and comparing results from cores of a multi-core processor

US9619356B2 · US · B2

Patent metadata
FieldValue
Publication numberUS-9619356-B2
Application numberUS-201514963296-A
CountryUS
Kind codeB2
Filing dateDec 9, 2015
Priority dateAug 8, 2013
Publication dateApr 11, 2017
Grant dateApr 11, 2017

How to read this patent

A practical reading order for non-experts. Skip the full description unless you need deep technical detail.

  1. Title

    What the patent document calls the invention.

  2. Abstract

    A short plain-language summary of the technical disclosure.

  3. Assignees and inventors

    Who owns or filed the patent and who is credited as inventor.

  4. Key dates

    Filing, priority, publication, and grant dates set the timeline.

  5. First independent claim

    The legal scope of protection — read this for what is actually claimed.

  6. CPC / IPC classifications

    Technology tags used to group this patent with similar filings.

  7. Citations and related patents

    Prior art links and similar publications in this corpus.

Abstract

Official abstract text for this publication.

A method for detecting errors in hardware including running a transaction on a plurality of cores, wherein each of the cores runs a respective copy of the transaction, periodically synchronizing the transaction on the cores throughout execution of the transaction, comparing results of the transaction on the cores, and determining an error in one or more of the cores.

First claim

Opening claim text (preview).

What is claimed is: 1. A method for detecting errors in hardware, the method comprising: running a transaction on a plurality of cores, wherein each of the cores runs a respective copy of the transaction; periodically synchronizing the transaction on the cores throughout execution of the transaction; comparing results of the transaction on the cores; determining an error in one or more of the cores; and copying a thread of the transaction from a first core of the plurality of cores to one or more second cores of the plurality of cores before running the transaction on the plurality of cores, wherein the first core and the one or more second cores are components of a multi-core processor. 2. The method of claim 1 , wherein comparing results of the transaction on the cores further comprises recording data about the thread upon determining a difference between the results of the transaction on the cores. 3. The method of claim 2 , wherein the data includes at least one of a start and end program counter (PC) of the transaction, a timestamp of when the transaction ran, and which cores the transaction was run on. 4. A computer program product for detecting errors in hardware, the computer program product comprising: a non-transitory computer readable storage medium having computer readable program code embodied therewith, the non-transitory computer readable program code comprising: computer readable program code configured to run a transaction on a plurality of cores, wherein each of the cores runs a respective copy of the transaction; computer readable program code configured to periodically synchronize the transaction on the cores throughout execution of the transaction; computer readable program code configured to compare results of the transaction on the cores; computer readable program code configured to determine an error in one or more of the cores; and computer readable program code configured to copy a thread of the transaction from a first core of the plurality of cores to one or more second cores of the plurality of cores before running the transaction on the plurality of cores, wherein the first core and the one or more second cores are components of a multi-core processor. 5. The computer program product of claim 4 , wherein the computer readable program code configured to compare results of the transaction on the cores further comprises computer readable program code configured to record data about the thread upon determining a difference between the results of the transaction on the cores. 6. The computer program product of claim 5 , wherein the data includes at least one of a start and end program counter (PC) of the transaction, a timestamp of when the transaction ran, and which cores the transaction was run on. 7. A system for testing hardware using multithreaded software, the system comprising: a redundant transaction hardware configured to run a transaction of the multithreaded software redundantly and to periodically synchronize redundant instances of the transaction executed by the redundant transaction hardware throughout execution of the transaction; a module configured to detect errors in the redundant transaction hardware based on differences detected between said redundant instances of the transaction executed by the redundant transaction hardware; and a multi-core processor, wherein the redundant transaction hardware is configured to copy a thread of the transaction from a first core of a plurality of cores to one or more second cores of the plurality of cores before running the transaction on the plurality of cores, wherein the first core and the one or more second cores are components of the multi-core processor.

Assignees

Inventors

Classifications

  • Functional testing · CPC title

  • G06F11/273Primary

    Tester hardware, i.e. output processing circuits {(G06F11/263 takes precedence)} · CPC title

  • in multi-processor systems, e.g. one processor becoming the primary tester (G06F11/2736 takes precedence) · CPC title

  • Generation of test inputs, e.g. test vectors, patterns or sequences {; with adaptation of the tested hardware for testability with external testers} · CPC title

  • Error detection by comparing the output signals of redundant hardware (G06F11/1629, G06F11/1666 take precedence; error detection or correction in information storage based on relative movement between record carrier and transducer G11B20/18; checking static stores for correct operation G11C29/00; for logic circuits H03K19/003, H03K19/007; for pulse counters or frequency dividers H03K21/40) · CPC title

Patent family

Related publications grouped by family.

External sources

Frequently asked questions

Answers are generated from the same data shown on this page.

What does patent US9619356B2 cover?
A method for detecting errors in hardware including running a transaction on a plurality of cores, wherein each of the cores runs a respective copy of the transaction, periodically synchronizing the transaction on the cores throughout execution of the transaction, comparing results of the transaction on the cores, and determining an error in one or more of the cores.
Who is the assignee on this patent?
IBM
What technology area does this patent fall under?
Primary CPC classification G06F11/273. Mapped technology areas include Physics.
When was this patent published?
Publication date Tue Apr 11 2017 00:00:00 GMT+0000 (Coordinated Universal Time) (B2). Legal status and post-grant events are not shown on this page.
What related patents are in patentsdb?
We list 8 related publications on this page (citations in our corpus or others sharing the same primary CPC).