US11314513B2 - Circuit for verifying the content of registers - Google Patents
Circuit for verifying the content of registers Download PDFInfo
- Publication number
- US11314513B2 US11314513B2 US17/211,546 US202117211546A US11314513B2 US 11314513 B2 US11314513 B2 US 11314513B2 US 202117211546 A US202117211546 A US 202117211546A US 11314513 B2 US11314513 B2 US 11314513B2
- Authority
- US
- United States
- Prior art keywords
- function
- registers
- register
- circuit
- bit
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Active
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING OR CALCULATING; COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/30098—Register arrangements
- G06F9/30101—Special purpose registers
-
- G—PHYSICS
- G06—COMPUTING OR CALCULATING; COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/07—Responding to the occurrence of a fault, e.g. fault tolerance
- G06F11/08—Error detection or correction by redundancy in data representation, e.g. by using checking codes
- G06F11/10—Adding special bits or symbols to the coded information, e.g. parity check, casting out 9's or 11's
- G06F11/1004—Adding special bits or symbols to the coded information, e.g. parity check, casting out 9's or 11's to protect a block of data words, e.g. CRC or checksum
-
- G—PHYSICS
- G06—COMPUTING OR CALCULATING; COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/07—Responding to the occurrence of a fault, e.g. fault tolerance
- G06F11/08—Error detection or correction by redundancy in data representation, e.g. by using checking codes
- G06F11/10—Adding special bits or symbols to the coded information, e.g. parity check, casting out 9's or 11's
-
- G—PHYSICS
- G06—COMPUTING OR CALCULATING; COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/30003—Arrangements for executing specific machine instructions
- G06F9/30007—Arrangements for executing specific machine instructions to perform operations on data operands
- G06F9/30029—Logical and Boolean instructions, e.g. XOR, NOT
-
- G—PHYSICS
- G06—COMPUTING OR CALCULATING; COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/30098—Register arrangements
- G06F9/30105—Register structure
-
- G—PHYSICS
- G06—COMPUTING OR CALCULATING; COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/38—Concurrent instruction execution, e.g. pipeline or look ahead
- G06F9/3836—Instruction issuing, e.g. dynamic instruction scheduling or out of order instruction execution
- G06F9/3838—Dependency mechanisms, e.g. register scoreboarding
- G06F9/384—Register renaming
Definitions
- the present disclosure generally relates to electronic devices and more particularly, to devices comprising a circuit for verifying the content of registers.
- a register is a volatile memory location, generally internal to a digital processor.
- a register is generally used to temporarily store a data word. It may be an instruction (operator), a variable (operand), or a control signal.
- registers may contain information such as a value representative of the closing level of a window, or information relative to the operation of the car (speed, motor temperature, etc.).
- One embodiment provides a device comprising: at least two first registers, each first register containing a data word and a verification bit, and a first circuit configured to determine whether the verification bit of each register corresponds to the data word of said register, the data words of the first registers being selected so that the bits of a same rank of the first registers comprise two complementary bits.
- Another embodiment provides a method comprising, for each register among at least two first registers, each first register containing a data word and a verification bit, a step in which a circuit determines whether the verification bit of each register corresponds to the data word of said register, the data words of the first registers being selected so that the bits of a same rank of the first registers comprise two complementary bits.
- the device comprises at least a second register, each second register containing a data word and a verification bit.
- the device comprises a second circuit configured to cyclically deliver to the first circuit the content of all the registers one after the others.
- each verification bit is obtained on writing into the corresponding register by applying a first function to the data word of said register.
- the first circuit is configured to apply the first function to the data word contained in each register and compare the result with the verification bit contained in said register.
- a common binary word is associated with all the registers, the common word comprising a bit associated with each register, the value of the verification bit of each register depending on the data word of said register and on the value of the bit of the common word associated with said register.
- the first function comprises second and third functions, the second function being applied to the result of the third function.
- each register is coupled to a circuit configured to write into the registers by a third circuit configured to apply the second function, the second function depending on the value of the bit of the common word associated with said register, to the value of the verification bit.
- the second function is an XOR-type function.
- the third bit is a direct electric connection
- the third circuit is an inverter
- the first circuit is configured to: apply the inverse function of the second function to the verification bit; apply the first function to the data word contained in said register; and compare the results.
- the first circuit comprises a fourth circuit configured to apply the third function to the data word contained in the register, a fifth circuit configured to apply an XOR-type function receiving as an input the verification bit of the register and the bit of the common word associated with the register, and a sixth circuit configured to apply an XOR-type function receiving as an input the output of the fourth circuit and the output of the fifth circuit.
- FIG. 1 schematically and partially illustrates an embodiment of an electronic device comprising a circuit for verifying the content of registers
- FIG. 2 shows in further detail a portion of FIG. 1 .
- FIG. 1 schematically and partially illustrates an embodiment of an electronic device wo comprising a circuit for verifying the content of registers.
- Device wo is for example a vehicle control system.
- device wo comprises verification registers 16 .
- Registers 16 are registers dedicated to the verification process and its content has no impact upon the functions controlled by device wo.
- Device wo comprises at least two verification registers 16 , preferably exactly two registers 16 , as shown in FIG. 1 .
- Each register 16 comprises a first portion 16 a having a binary word VIR 1 , VIR 2 stored therein.
- each word VIR 1 , VIR 2 has a size greater than or equal to 8 bits, for example, equal to 32 bits.
- binary words VIR 1 , VIR 2 do not change value during the operation of device 100 , and form, in a way, reference words.
- the binary words of registers 16 are preferably selected so that each location of first portion 16 a has, in at least one of binary words VIR 1 , VIR 2 , all possible values. In other words, the binary words of registers 16 are selected so that the bits of a same rank of registers 16 comprise at least two complementary bits.
- a bit of each location, or of each rank, of the first portions 16 a has value ‘1’ in at least one of verification registers 16 and has value ‘0’ in at least one of verification registers 16 .
- one of registers 16 contains, in first portion 16 a , a word entirely formed of ‘0’s and another register 16 contains, in first portion 16 a , a word entirely formed of ‘1’s.
- one of registers 16 contains, in first portion 16 a , an alternation of ‘1’s and of ‘0’s, starting with a ‘0’, and another one of registers 16 contains, in first portion 16 a , an alternation of ‘1’s and of ‘0’s, starting with a ‘1’.
- Each register 16 comprises a second portion 10 , having a verification bit VPAR 1 , VPAR 2 , for example, a parity bit, stored therein.
- Each verification bit VPAR 1 , VPAR 2 is obtained by applying a function f to the binary word written into the first portion of the corresponding register.
- Function f for example comprises a first function f 1 applied to the data words that we wish to store in the registers and a second function f 2 applied to the result of the function f 1 .
- Function f 1 is for example a usual function enabling to obtain a verification bit from a data word.
- function f 1 is a function enabling to obtain a parity bit.
- function f 1 is an error correction code (for example, a Hamming code), a signature function or, more generally, any function having its result depending on the states of the bits of the data word.
- the information contained in registers 16 that is, data words VIR 1 , VIR 2 and verification bits VPAR 1 , VPAR 2 , is preferably hard coded, meaning fixed, in an immutable way, during the formation of the device.
- Device 100 further comprises a central processing unit (CPU) 12 or processor 12 .
- Unit 12 is for example configured to control functions, not shown, of device 100 .
- Device 100 further comprises at least one register 14 .
- At least one register 14 Three registers 14 are shown in FIG. 1 .
- Each register 14 comprises a first portion 14 a having a data word REG 1 , REG 2 , REG 3 stored therein.
- Each data word REG 1 , REG 2 , REG 3 forms a piece of information stored in the register.
- Each data word forms a piece of information which is desired to be verified.
- Each data word REG 1 , REG 2 , REG 3 is a binary word.
- each data word has a size greater than or equal to 8 bits, for example, equal to 32 bits.
- data words REG 1 , REG 2 , REG 3 all have the same size.
- the binary words VIR 1 , VIR 2 of registers 16 have the same size as the data words of registers 14 .
- Each register 14 comprises a second portion 14 b , having a verification bit PAR 1 , PAR 2 , PAR 3 , for example, a parity bit, stored therein.
- the verification bits are generally obtained by applying the function f to the data words which are desired to be stored into the registers.
- the function f meaning the combination of functions f 1 et f 2 , is for example applied by logic circuits.
- the functions f 1 and f 2 are applied by a same circuit 24 .
- one circuit 24 is coupled between each register 14 and the unit 12 .
- function f is for example applied by unit 12 to the data words which are desired to be stored into the registers.
- unit 12 for example provides the data word to the circuit 24 associated to the register and the circuit 24 applies function f 1 , then function f 2 , to the data word.
- the result of function f 2 is the verification bit and is written into the second portion 14 b of said register.
- the data word is written, preferably without modification, in the first part of the register.
- the information contained in registers 14 is at least partially generated and written into registers 14 by unit 12 .
- the content of the registers is for example written based on the content of a non-volatile memory or is generated by a circuit, not shown.
- a common binary word is associated with the assembly formed by registers 14 and 16 of device 100 .
- the binary word preferably comprises at least as many bits as device 100 comprises registers 14 and 16 .
- Each register 14 and 16 is associated with a bit of the common word.
- the common word comprises 5 bits, the bits being respectively associated with registers REG 1 , REG 2 , REG 3 , VIR 1 , and VIR 2 .
- the common word is for example quasi-random.
- the common word is for example continuously generated or delivered by a circuit 22 .
- Circuit 22 is for example a linear feedback shift register (LSFR).
- the common word comprises at least one value ‘1’ and at least one value ‘0’. The common word is thus not entirely formed of bits having the same value.
- Device 100 comprises an error detection circuit (COMP) 20 .
- the device 100 comprises a unique error detection circuit 20 .
- the contents of the registers 14 and 16 are therefore checked by a same circuit 20 .
- Circuit 18 is for example a multiplexer. Circuit 18 is coupled, preferably connected, at its input to all registers 14 and 16 . Circuit 18 is coupled, preferably connected, at its output to circuit 20 . Circuit 18 for example comprises an output having the data word of the selected register delivered thereto, and another output having the bit contained in the second portion of the selected register delivered thereto. This information, that is, the data word and the verification bit, is delivered to circuit 20 in order to be verified.
- Circuit 18 is also coupled, preferably connected, at its input to a circuit 19 (CNT).
- Circuit 19 is configured to deliver a control signal to circuit 18 determining to which register the content to be delivered to circuit 20 belongs.
- Circuit 19 receives as an input a clock signal CLK.
- Circuit 19 is for example a counter.
- Circuit 19 is configured so that the content of all registers is cyclically delivered to circuit 20 .
- the registers are associated with the bits of the common word in the same order as that in which the contents of the registers are transmitted to circuit 20 by the circuit 18 .
- Circuit 22 is synchronized by the same clock signal CLK as circuit 19 .
- circuit 19 delivers the signal controlling the transfer of the content of one of the registers and circuit 22 delivers the bit of the common word corresponding to this register before the delivery of a signal controlling the transfer of the content of the next register, for example, during a same edge of signal CLK.
- each circuit 24 depends on the value of the bit of the common word associated with the register corresponding to said circuit 24 .
- the value contained in the second portion of each register is thus representative of the data word and of the associated bit of the common word.
- function f 2 corresponds to a first operation if the bit of the common word has a first value and corresponds to a second operation if the bit of the common word has a second value.
- function f 2 is the identity function, that is, the result of function f 2 is equal to the result of function f 1
- function f 2 is the inverse function, that is, the result of function f 2 is the inverse, or the complementary, of the result of function f 1 .
- the inverse of a bit of value ‘1’ is a bit of value ‘0’ and the inverse of a bit of value ‘0’ is a bit of value ‘1’.
- function f 2 for example corresponds to an XOR-type function applied to the associated bit of the common word and to the value resulting from function f 1 .
- Function f 2 has an inverse function f 2 ′.
- the result of function f 2 ′ applied to the result of function f 2 is the value (x) to which the function is applied.
- the common word is known on manufacturing of device 100 .
- Circuits 24 may then be different according to the value associated with each register, and thus the function f 2 .
- the corresponding circuit 24 is a circuit outputting the same binary value as at the input, for example, an electric connection, and if the bit associated with a register has the second value, the corresponding circuit 24 is an inverter.
- the register verification comprises two levels.
- a first level corresponds to the verification of the content of the registers.
- a second level corresponds to the verification of the operation of the verification elements.
- Circuit 20 is coupled, preferably connected, at its input to the outputs of circuit 18 and to circuit 22 .
- Circuit 20 is for example coupled, preferably connected, at its output to a memory 26 (MEM).
- MEM memory 26
- Circuit 20 is configured, when its receives the content of the first and second portions of a register 14 or 16 , via circuit 18 , and the bit of the common word associated with said register, by circuit 22 , to:
- Steps a′) and b′) are for example carried out in parallel.
- step c′ If the result of step c′) indicates that the results are identical, in other words, if the verification bit corresponds to the data word, an output signal of circuit 20 takes a first value. If the result of step c′) indicates that the results are different, in other words, if the verification bit does not correspond to the data word, an output signal of the comparator takes a second value. The first value of the output signal indicates that the data word corresponds to the stored word and thus that the stored information is correct. The second value of the output signal indicates that the data word does not correspond to the desired original value, and that there thus is an error.
- circuit 19 delivers, at a first time, a signal associated with one of registers 14 or 16 to circuit 18 .
- Circuit 18 obtains the content of the first and second portions of this register, for example, data word REG 1 and verification bit PAR 1 .
- This content is delivered at the output of circuit 18 .
- Circuit 20 thus receives as an input the content of the first and second portions of the register.
- Circuit 20 further receives at its input the bit of the common word associated with said register.
- Circuit 20 carries out the previously-described steps a′), b′), and c′).
- the output signal generated by circuit 20 enables to determine whether the data word of said register is correct. If not, the system integrating the device takes measures adapted to the case of invalid data not to be taken into account. For example, the system is reset, put in a downgraded mode, etc.
- circuit 19 delivers to circuit 18 a signal associated with a next register 14 or 16 .
- Circuit 18 obtains the content of the first and second portions of the register, for example, data word REG 2 and verification bit PAR 2 .
- An output signal of circuit 20 is generated in the same way as in the case of the previous register.
- the second time is preferably sufficiently distant from the first time for the output signal of circuit 20 associated with the first register to be generated before the second time.
- the second instant corresponds for example to an edge, for example a rising edge, of the clock signal CLK following the first instant.
- the same verification method is applied to all registers, one after the others.
- the verification method is applied to the following register during each edge, for example rising edge, of the clock signal.
- a register is checked at each clock cycle. Once all registers have been verified, the method is carried out again on the first register. The content of the registers is thus continuously verified.
- the application of the method of verification of each register is preferably fast.
- the duration between the verification of two successive registers is for example shorter than 200 ms, preferably shorter than 50 ms.
- the duration between the verification of two successive registers is such that all registers may be verified within a fault tolerance time interval.
- this time interval is 200 ms, which corresponds to the requirements of the ISO 26262 standard.
- the continuous verification of the registers enables to determine the presence of errors which would have appeared in the data words on writing of the word or during the storage.
- the verification of the content of registers 16 enables to determine whether the circuits located downstream of the registers, that is, on the path between the registers and circuit 20 , operate properly, which corresponds to the second verification level. For example, the verification of registers 16 enables to determine the presence of latent faults in the circuits downstream of the registers.
- latent faults for example means that the circuits, or one of the connections over which the content of the registers is transmitted, do not properly transmit one or a plurality of bits.
- a latent fault in circuit 18 may cause to the output signals to always have one bit, for example, the third bit, at a same value, for example, value ‘0’.
- the third bit of the word received by circuit 20 has value ‘0’.
- each bit of the reference word to be transmitted has value ‘1’ in a register 16 and value ‘0’ in another register 16 , it is possible to determine whether a bit of the reference bit is blocked at a same value.
- the bit of a given rank of a first register 16 has value ‘1’ and the bit of same rank of a second register 16 has value ‘0’ is considered. If an error in the device causes, on transfer of the content of the registers to circuit 20 , the bit of this rank to still have value ‘1’, circuit 20 will detect, on verification of second register 16 , that the value of the bit of the given rank does not have value ‘0’, but has value ‘1’. If an error in the device causes, on transfer of the content of the registers to circuit 20 , the bit of this rank to still have value ‘0’, circuit 20 will detect, on verification of first register 16 , that the value of the bit of the given rank does not have value ‘1’, but has value ‘0’.
- circuit 19 may for example deliver the value of the control signal of circuit 18 , for example, to unit 12 . It is thus possible to know in which register the error has appeared. The reaction of device 100 on detection of an error may for example be different according to the register where the error has been detected.
- circuits 19 and 22 are configured to respectively generate the control signal of circuit 18 corresponding to a register and the bit of the common word corresponding to this register, so that circuit 20 can use the bit of the common word associated with the register to verify the content of the register.
- Circuits 18 , 19 , and 22 might not operate properly.
- circuit 19 might skip a value.
- circuit 18 might not transfer the content of one of the registers in the cycle.
- the register having its content transferred to circuit 20 would thus not correspond to the bit of the common word delivered by circuit 22 . There thus would be an offset between the transferred contents and the bits of the common word delivered to circuit 20 . If the two successive bits of the common word are equal, this would not be detected. However, if the two successive bits of the common word are different, circuit 20 would detect an error.
- the common word associated with registers 14 and 16 of FIG. 2 is 00110.
- the bits of the common word associated with the first, second, third, fourth, and fifth registers, respectively containing words REG 1 , REG 2 , REG 3 , VIR 1 , VIR 2 respectively have values ‘0’, ‘0’, ‘1’, ‘1’, ‘0’.
- circuit 19 does not deliver the signal controlling the transfer of the content of the first register, but delivers the signal controlling the transfer of the content of the second register.
- circuit 20 receives the content of the second register and the bit of the common word of the first register.
- circuit 19 delivers the signal controlling the transfer of the content of the next register, that is, the third register, to circuit 20 .
- Circuit 22 delivers to circuit 20 the next bit of the common word, that is, the bit associated with the second register.
- Circuit 20 thus receives the content of the third register and the bit of the common word associated with the second register. Since the bits of the common word associated with the second and third registers are different, circuit 20 detects an error.
- the bits of the common word associated with the verification registers are equal, preferably equal to the value for which function f 2 is the identity function.
- Each verification bit VPAR 1 , VPAR 2 is then obtained by applying function f 1 to the binary word written into the first portion 16 a of the register. Function f 2 is not applied.
- second portions 16 b are not coupled to unit 12 by circuits 24 .
- the device 100 as described can easily be associated with other elements of data verification.
- the circuit 100 can comprise a circuit 28 (CRC, FIG. 1 ) configured to detect transmission or transfer mistakes.
- Circuit 28 is for example a cyclic redundancy check.
- FIG. 2 shows in further detail a portion of FIG. 1 .
- Circuit 20 comprises a circuit 50 configured to apply function f 1 .
- Circuit 50 receives as an input the content of the first portion 14 a or 16 a of register 14 or 16 .
- circuit 50 performs a bit-to-bit sum of the bits of the data word, for example, with circuits applying XOR-type functions.
- Circuit 20 further comprises a circuit 52 applying function f 2 ′, depending on the bit of the common word.
- Circuit 52 receives as an input the verification bit of said register and the bit of the common word associated to said register.
- the circuit is an XOR gate.
- function f 2 ′ is the identity function
- the output has the value of the verification bit.
- function f 2 ′ is the inverse function or the complementary function.
- Circuit 20 comprises a circuit 54 configured to determine whether the outputs of circuits 50 and 52 are identical or not.
- Circuit 54 is for example a circuit applying an XOR-type function.
- Circuit 54 is for example an XOR-type logic gate.
- An advantage of the described embodiments is that they allow the detection of errors in the content of the registers and in the operation of the verification components.
- Another advantage of the described embodiments is that they enable to ascertain that all registers have been verified.
- Another advantage of the described embodiments is that they comprise a single error detection circuit 20 for all registers 14 and 16 . In some embodiments, all or part of the disadvantages of known circuits for verifying the content of registers are addressed or mitigated.
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Software Systems (AREA)
- General Engineering & Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Quality & Reliability (AREA)
- Computer Security & Cryptography (AREA)
- Detection And Correction Of Errors (AREA)
- Logic Circuits (AREA)
- Hardware Redundancy (AREA)
Abstract
Description
f2′(0)=
f2′(1)=
-
- a′) apply function f1 to the content of the first portion of the register,
- b′) apply function f2′ to the content of the second portion of the register, function f2′ depending on the bit of the common word associated with the register, and
- c′) compare the results of steps a′) and b′).
Claims (19)
Priority Applications (2)
| Application Number | Priority Date | Filing Date | Title |
|---|---|---|---|
| CN202110375666.5A CN113496723B (en) | 2020-04-08 | 2021-04-07 | Circuitry for verifying the contents of a register |
| US17/660,657 US11797306B2 (en) | 2020-04-08 | 2022-04-26 | Circuit for verifying the content of registers |
Applications Claiming Priority (2)
| Application Number | Priority Date | Filing Date | Title |
|---|---|---|---|
| FR2003541 | 2020-04-08 | ||
| FR2003541A FR3109226B1 (en) | 2020-04-08 | 2020-04-08 | Register content verification circuit |
Related Child Applications (1)
| Application Number | Title | Priority Date | Filing Date |
|---|---|---|---|
| US17/660,657 Division US11797306B2 (en) | 2020-04-08 | 2022-04-26 | Circuit for verifying the content of registers |
Publications (2)
| Publication Number | Publication Date |
|---|---|
| US20210318873A1 US20210318873A1 (en) | 2021-10-14 |
| US11314513B2 true US11314513B2 (en) | 2022-04-26 |
Family
ID=72470420
Family Applications (1)
| Application Number | Title | Priority Date | Filing Date |
|---|---|---|---|
| US17/211,546 Active US11314513B2 (en) | 2020-04-08 | 2021-03-24 | Circuit for verifying the content of registers |
Country Status (3)
| Country | Link |
|---|---|
| US (1) | US11314513B2 (en) |
| EP (1) | EP3893117B1 (en) |
| FR (1) | FR3109226B1 (en) |
Citations (4)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| US7418582B1 (en) * | 2004-05-13 | 2008-08-26 | Sun Microsystems, Inc. | Versatile register file design for a multi-threaded processor utilizing different modes and register windows |
| US20090070554A1 (en) * | 2007-09-12 | 2009-03-12 | Qualcomm Incorporated | Register File System and Method for Pipelined Processing |
| US20130073921A1 (en) | 2011-09-20 | 2013-03-21 | Fujitsu Limited | Error correction device, error correction method, and processor |
| US20170060673A1 (en) | 2015-09-01 | 2017-03-02 | International Business Machines Corporation | Parity protection of a register |
-
2020
- 2020-04-08 FR FR2003541A patent/FR3109226B1/en active Active
-
2021
- 2021-03-24 US US17/211,546 patent/US11314513B2/en active Active
- 2021-04-02 EP EP21166806.6A patent/EP3893117B1/en active Active
Patent Citations (4)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| US7418582B1 (en) * | 2004-05-13 | 2008-08-26 | Sun Microsystems, Inc. | Versatile register file design for a multi-threaded processor utilizing different modes and register windows |
| US20090070554A1 (en) * | 2007-09-12 | 2009-03-12 | Qualcomm Incorporated | Register File System and Method for Pipelined Processing |
| US20130073921A1 (en) | 2011-09-20 | 2013-03-21 | Fujitsu Limited | Error correction device, error correction method, and processor |
| US20170060673A1 (en) | 2015-09-01 | 2017-03-02 | International Business Machines Corporation | Parity protection of a register |
Non-Patent Citations (2)
| Title |
|---|
| Arteris IP, "Unit duplication", Chapter One—Unit duplication—Packet validity check, Qualcomm Technologies, Inc., Arteris od17835v1, Nov. 31, 2018, 3 pages. |
| Arteris, "Unit duplication," Arteris IP, FlexNoC 3.9.0 Arteris—FlexNoC Resilience Features, Nov. 31, 2018, 3 pages, © 2018 Qualcomm Technologies, Inc. |
Also Published As
| Publication number | Publication date |
|---|---|
| EP3893117B1 (en) | 2023-12-13 |
| EP3893117A1 (en) | 2021-10-13 |
| US20210318873A1 (en) | 2021-10-14 |
| FR3109226A1 (en) | 2021-10-15 |
| FR3109226B1 (en) | 2022-04-22 |
Similar Documents
| Publication | Publication Date | Title |
|---|---|---|
| US11108499B2 (en) | System and method for transferring data and a data check field | |
| US6799287B1 (en) | Method and apparatus for verifying error correcting codes | |
| US10169126B2 (en) | Memory module, memory controller and systems responsive to memory chip read fail information and related methods of operation | |
| US5384788A (en) | Apparatus and method for optimal error correcting code to parity conversion | |
| US20180189133A1 (en) | Error-correcting code memory | |
| US20040255225A1 (en) | Control circuit for error checking and correction and memory controller | |
| CN106340319B (en) | Method and circuit for protecting and verifying address data | |
| US3568153A (en) | Memory with error correction | |
| US20200371872A1 (en) | Error detection and correction with integrity checking | |
| US10613918B2 (en) | Data register monitoring | |
| US11768731B2 (en) | System and method for transparent register data error detection and correction via a communication bus | |
| US11314513B2 (en) | Circuit for verifying the content of registers | |
| US11797306B2 (en) | Circuit for verifying the content of registers | |
| US11249839B1 (en) | Method and apparatus for memory error detection | |
| US7321996B1 (en) | Digital data error insertion methods and apparatus | |
| US9292378B2 (en) | Single event upset protection circuit and method | |
| CN210984286U (en) | Error correction code memory and electronic circuit | |
| US5835511A (en) | Method and mechanism for checking integrity of byte enable signals | |
| CN115220923A (en) | Signal verification method, medium, electronic device, and program product | |
| US20250117349A1 (en) | System on chip with safe hardware subsystem | |
| US12019510B2 (en) | Random number generator | |
| US20250292862A1 (en) | Methodology to achieve transaction redundancy in memory constrained devices | |
| CN119479756A (en) | Memory system | |
| JPS60258663A (en) | Memory error processing circuit | |
| Widmann | A Data Specification Architecture |
Legal Events
| Date | Code | Title | Description |
|---|---|---|---|
| AS | Assignment |
Owner name: STMICROELECTRONICS (GRENOBLE 2) SAS, FRANCE Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:TRUNDE, GREGORY;DUTEY, DENIS;REEL/FRAME:055706/0205 Effective date: 20210121 |
|
| FEPP | Fee payment procedure |
Free format text: ENTITY STATUS SET TO UNDISCOUNTED (ORIGINAL EVENT CODE: BIG.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY |
|
| STPP | Information on status: patent application and granting procedure in general |
Free format text: NON FINAL ACTION MAILED |
|
| STPP | Information on status: patent application and granting procedure in general |
Free format text: RESPONSE TO NON-FINAL OFFICE ACTION ENTERED AND FORWARDED TO EXAMINER |
|
| STPP | Information on status: patent application and granting procedure in general |
Free format text: NOTICE OF ALLOWANCE MAILED -- APPLICATION RECEIVED IN OFFICE OF PUBLICATIONS |
|
| STPP | Information on status: patent application and granting procedure in general |
Free format text: NOTICE OF ALLOWANCE MAILED -- APPLICATION RECEIVED IN OFFICE OF PUBLICATIONS |
|
| STPP | Information on status: patent application and granting procedure in general |
Free format text: PUBLICATIONS -- ISSUE FEE PAYMENT VERIFIED |
|
| STCF | Information on status: patent grant |
Free format text: PATENTED CASE |
|
| MAFP | Maintenance fee payment |
Free format text: PAYMENT OF MAINTENANCE FEE, 4TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1551); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY Year of fee payment: 4 |