The present invention relates to a nuclear reaction detection device, a nuclear reaction detection method, and a nuclear reaction detection program that determine the energy of a particle beam and measure a cross-section occurring in a CRAM due to the energy of the particle beam.
A technology has been proposed that measures a single-event upset (SEU) cross-section by emitting particle radiation with specific energy (e.g., see Non-Patent Literature 1). The “SEU,” also called “soft error,” refers to a phenomenon in which a single particle (a neutron, a proton, a baryon, or the like) enters an LSI, such as a memory, and an electric charge produced by means of a nuclear reaction causes data (bits) stored in the LSI to be inverted.
Using a field-programmable gate array (FPGA) formed by a configuration random-access memory (CRAM), in the event that an SEU occurs in the FPGA, the technology detects a change in a logic circuit that has been designed in the FPGA in advance and the resulting malfunction, and can thereby detect the SEU with accuracy in the order of a few nanoseconds (ns) (the order of the operation clock of the FPGA). Further, it is possible to measure the energy of a particle that has caused the SEU by means of a time-of-flight method, and to measure the SEU cross-section of that energy from the fluence of the radiated particle. The CRAM can be formed by a static random-access memory (SRAM).
An SEU cross-section is a measure to represent a rate at which a particle causes an SEU. When the number of SEUs that have occurred as a result of irradiating a semiconductor with a particle fluence ϕ [n/cm2] (the total number of particles entering a unit area) is N, the SEU cross-section can be expressed by the following Formula (1):
(SEU cross-section)=N/ϕ (1)
However, the conventional technology uses only a logical abnormality of an FPGA caused by a bit error of a configuration RAM (CRAM) as a detection trigger. Therefore, it is not possible to identify whether an SEU having occurred due to particle radiation is a single-bit upset (SBU) in which only one bit is inverted or a multi-bit upset (MBU) in which multiple bits are inverted.
That is, conventionally, only a logical abnormality of an FPGA caused by a bit error of a CRAM is used as a detection trigger. Since a logical abnormality occurs regardless of an SBU or an MBU, these two may not be identified. Therefore, there has been a problem that an SBU cross-section and an MBU cross-section may not be calculated separately.
The present invention has been devised in view of the above problems, and an object of the present invention is to provide a nuclear reaction detection device, a nuclear reaction detection method, and a nuclear reaction detection program that can detect an SEU occurring in a CRAM, further distinguish whether the SEU is an SBU or an MBU, and calculate an SBU cross-section and an MBU cross-section separately.
A nuclear reaction detection device of one aspect of the present invention is a nuclear reaction detection device having an FPGA, and includes: a detection circuit unit that detects a soft error failure (SEF) that is an error causing a logical abnormality in the FPGA; an error monitoring unit that detects a bit error occurring in the FPGA, and determines whether the bit error is an SBU that is an error of one bit or an MBU that is an error of multiple bits; an SBU cross-section calculation section that detects the energy of a particle that has caused the SEF, and calculates an SBU cross-section based on the energy and a total number of SBUs that have occurred in the FPGA; and an MBU cross-section calculation section that calculates an MBU cross-section based on the energy and a total number of MBUs that have occurred in the FPGA.
A nuclear reaction detection method of one aspect of the present invention is a nuclear reaction detection method performed by a nuclear reaction detection device having an FPGA, and includes the steps of: detecting an SEF that is an error causing a logical abnormality in the FPGA; detecting a bit error occurring in the FPGA, and determining whether the bit error is an SBU that is an error of one bit or an MBU that is an error of multiple bits; detecting the energy of a particle that has caused the SEF, and calculating an SBU cross-section based on the energy and a total number of SBUs that have occurred in the FPGA; and calculating an MBU cross-section based on the energy and a total number of MBUs that have occurred in the FPGA.
One aspect of the present invention is a nuclear reaction detection program that causes a computer to function as the nuclear reaction detection device.
The present invention makes it possible to distinguish whether an SEU that is a soft error occurring in a CRAM is an SBU or an MBU and calculate an SBU cross-section and an MBU cross-section separately.
An embodiment of the present invention will be described below with reference to the drawings.
In this embodiment, a soft error (an “SEF” which will be described later) that occurs in a semiconductor device, such as an LSI, due to an SEU is detected in the order of nanoseconds. Based on the detection result, the energy of a particle (a neutron, a proton, a baryon, or the like) that has caused the SEU is measured by means of a technique such as a time-of-flight method. Then, based on the fluence of radiated particles (the total number of particles entering a unit area), an SEU cross-section of the particle energy is measured, and moreover an SBU cross-section and an MBU cross-section are measured. Specifically, an SEU is detected by means of the FPGA 100 shown in
As shown in
In the following, the specific circuit configuration of the FPGA 100 will be described with reference to the circuit diagram shown in
The CLBs 11 are circuits forming various types of logic circuits.
The IOBs 12 are circuits serving as interfaces with external devices, such as LEDs and various sensors. Data can be input from and output to external devices through the IOBs.
The PSBs 13 are circuits for coupling an output wire of one CLB 11 to another CLB 11.
The SMs 14 are circuits for outputting a signal output from the CLB 11 via the PSB 13 to another CLB.
As shown in
On and off of each pass-transistor Tr are controlled by means of a control signal given from outside. Alternatively on and off are controlled as the CLB 11 controls a switching control unit (not shown) that is provided separately from the aforementioned LUT circuit 21 and FF circuit 22. The pass-transistor Tr is turned off when “0” is received as a control signal, for example. The pass-transistor Tr is turned on when “1” is received as a control signal. When a bit error occurs in the CRAM forming the SM 14, the connection becomes different from a design intended by a user, which results in a logical abnormality.
Referring back to
As described above, the memory circuit unit 110 is built by the CLB 11 that is formed of a CRAM. As shown in
The LUT circuit 21 has a resistor 51 to which a plurality of (in
Each multiplexer circuit p1 operates in accordance with a preset truth table Q1 based on data of select signals “A,” “B,” and “C.” An output of the resistor 51 is selected as “0” or “1” according to the select signals “A,” “B,” and “C.” Therefore, if the same select signal is input to the LUT circuits 21 set for two CLBs 11, outputs of the two resistors (which will be referred to as resistors 51A, 51B) become the same, for example. However, if an error due to an SEU occurs in the CRAM forming the LUT circuit 21, the circuit becomes different from a circuit designed by the user, thereby causing malfunction. Therefore, if the same select signal is input to the LUT circuits 21 set for two CLBs 11, an output of the resistor 51A and an output of the resistor 51B become different numerical values. Hereinafter, an error that causes a logical abnormality due to an SEU will be referred to as a soft error failure (SEF).
Referring back to
The data update circuit section 121 is built as a circuit that changes the select signals “A,” “B,” and “C” of each LUT circuit 21 included in the memory circuit unit 110 so as to repeat “0” and “1” at a predetermined frequency. The predetermined frequency is, for example, a maximum frequency at which operation is possible (timing can be converged), for example, the frequency of a clock signal given from an external clock. The frequency of the clock signal is 250 [MHz], for example. The predetermined frequency may be the same or may not be the same as the operation clock of the FPGA 100.
As the data update circuit section 121 is activated, the numerical values of the select signals “A,” “B,” and “C” of the LUT circuit 21 shown in
The data comparison circuit section 122 monitors output data of each resistor 51 included in the memory circuit unit 110. The data comparison circuit section 122 can be built using an exclusive OR circuit (XOR circuit), for example. The data comparison circuit section 122 inputs output data of the two resistors 51A and 51B set for the memory circuit unit 110 to the XOR circuit and determines whether output data of the XOR circuit is “0” or “1.”
Specifically, as shown in
The data comparison circuit section 122 inputs the same select signal to the two resistors 51A and 51B having the same configuration, and determines whether the output data of the respective resistors 51A and 51B are the same.
Based on the output result of the data comparison circuit section 122, the detection circuit section 123 detects an SEF occurring in the CRAM that forms the memory circuit unit 110. That is, if an SEU occurs in the CRAM forming the CLB 11 or the SM 14 shown in
More specifically, the detection circuit section 123 determines that an SEF has occurred if the output data in the above-described data comparison circuit section 122 is “1.” That is, when an XOR circuit is used in the data comparison circuit section 122, as shown in
The outputs of the respective resistors 51A and 51B are alternately switched between “0” and “1” at the frequency of the clock. If the resistors 51A and 51B are operating normally, the output data of the data comparison circuit section 122 is “0”, and therefore no SEF is detected. Meanwhile, if an SEU occurs in the CRAM and an SEF occurs due to the SEU, the output of the resistor 51B is fixed at, for example, “1.” As a result, the output data of the data comparison circuit section 122 becomes “1” and therefore an SEF is detected. In this case, if the frequency of the clock is 250 [MHz], as one clock is four nanoseconds, occurrence of an SEF can be detected in eight nanoseconds that correspond to two clocks.
In the example shown in
If occurrence of an SEF is detected, the detection circuit section 123 outputs a signal indicating occurrence of an SEF to the number-of-errors determination unit 130 and an SEF detection unit 210 which will be described later.
Referring back to
An error detected by means of an error check method, such as CRC, in the CRAM monitoring circuit 102 will be hereinafter referred to as a “CRAM error” to distinguish it from the above-described “SEF.” When a bit error due to an SEU occurs in the CRAM, this bit error does not always cause a logical abnormality (SEF) in the FPGA 100. That is, an error among CRAM errors that causes a logical abnormality in the FPGA 100 is an SEF.
The number-of-errors determination unit 130 determines whether the bit number of the error detected in the CRAM monitoring circuit 102 is one bit or multiple bits. Further, the number-of-errors determination unit 130 distinguishes and detects whether the bit error having occurred in the CRAM is a single-bit upset (SBU) that is an error of one bit or a multi-bit upset (MBU) that is an error of multiple bits.
The number-of-errors determination unit 130 outputs information on the determination result of the bit error (information on an SBU or an MBU) to a number-of-errors identification unit 240 of the nuclear reaction detection device main body 200. Further, the number-of-errors determination unit 130 outputs information on the address of the bit error detected by means of the CRAM monitoring circuit 102 to the number-of-errors identification unit 240.
A process of detecting a CRAM error by means of the CRAM monitoring circuit 102 will be specifically described below. The processing procedure of the method of detecting a CRAM error is different between a case where the FPGA 100 does not have an error correction function of correcting CRAM errors and a case where the FPGA 100 has the error correction function. In the following, each of the case where the FPGA 100 does not have the error correction function for CRAM errors and the case where the FPGA 100 has the error correction function will be described.
[Process when FPGA does not have Error Correction Function for CRAM Errors]
In the case where the FPGA 100 does not have the error correction function for CRAM errors, once an error occurs when checking CRAM errors on a fixed cycle by means of an error check method, such as CRC, this error is not corrected. Therefore, this error keeps being detected during the next and subsequent detections. This will be specifically described below with reference to the tables shown in
In the example shown in
Suppose that, as shown in
Therefore, the CRAM monitoring circuit 102 determines that errors obtained by omitting the CRAM errors detected in the n+1-th CRAM check, which is the previous check, from the CRAM errors detected in the n+2-th CRAM check are CRAM errors detected in the current check. Specifically, the CRAM monitoring circuit 102 determines that the error indicated by reference sign Z1 in
In other words, suppose that the FPGA 100 does not have the error correction function of correcting bit errors having occurred in the FPGA 100. In the above case, the CRAM monitoring circuit 102 (an error monitoring unit), when detecting bit errors on a fixed cycle, determines that the difference between bit errors in the current detection and bit errors in the previous detection is bit errors detected in the current detection.
[Process when FPGA has Error Correction Function for CRAM Errors]
Meanwhile, in the case where the FPGA 100 has the error correction function for CRAM errors, once an error occurs when checking CRAM errors on a fixed cycle by means of an error check method, such as CRC, this error is corrected. The error that has been once detected is not detected in the next and subsequent CRAM checks. Accordingly, as shown in
That is, in the case where the FPGA 100 has the error correction function of correcting bit errors having occurred in the FPGA 100, the CRAM monitoring circuit 102 (an error monitoring unit), when detecting bit errors on a fixed cycle, determines that bit errors that are detected in each cycle are bit errors that have occurred as of that point in time.
However, when an SEF occurs in the user circuit 101 and immediately thereafter two or more CRAM errors occur, for example, when two or more CRAM errors occur in the n+2-th CRAM check shown in
Next, the configuration of the nuclear reaction detection device main body 200 shown in
The nuclear reaction detection device main body 200 has a timing unit 290 having a function as a timer that measures time, the SEF detection unit 210, the number-of-errors identification unit 240, a particle energy calculation unit 220, and an SEU cross-section calculation unit 230. The SEU cross-section calculation unit 230 includes an SBU cross-section calculation section 231 and an MBU cross-section calculation section 232.
The SEF detection unit 210 acquires information on an SEF output from the detection circuit section 123 of the FPGA 100. When occurrence of an SEF is detected, the SEF detection unit 210 calculates the time of occurrence of the SEF by acquiring the current time measured by the timing unit 290. The SEF detection unit 210 stores information indicating occurrence of an SEF and the time of occurrence of the SEF in predetermined storage means (not shown). Alternatively, the SEF detection unit 210 outputs the information and the time to an external device (not shown).
The particle energy calculation unit 220 acquires, from outside, the time at which a particle, such as a neutron, a proton, or a baryon, has been given to the FPGA 100 (a particle generation timing signal). The particle energy calculation unit 220 calculates the differential time between the time of occurrence of the SEF and the time at which the particle has been given to the FPGA 100. Based on this differential time, the particle energy calculation unit 220 calculates the energy of the particle that has caused the SEU in the FPGA 100 that led to the SEF.
The particle energy calculation unit 220 stores the calculated particle energy in a storage unit (not shown), or outputs the energy to an external device.
The number-of-errors identification unit 240 acquires information on the SEF acquired by the SEF detection unit 210, and information on the number of errors of CRAM errors detected by the number-of-errors determination unit 130, that are the address at which the CRAM error has occurred and information on an SBU or an MBU.
As described above, when an SEU (an SBU or an MBU) occurs in the CRAM, this SEU does not always cause an SEF. Even if an SEU occurs in a CRAM that does not affect circuit operation, malfunction does not occur and no SEF is detected, for example. Specifically, it is known that 5 to 20% of SEUs occurring in a CRAM actually affect the operation of the user circuit 101 shown in
Based on the SEF acquired by the SEF detection unit 210 and the information on the number of errors detected by the number-of-errors determination unit 130, the number-of-errors identification unit 240 links the SEF to the information on the number of errors that cause the SEF (an SBU or an MBU).
The SBU cross-section calculation section 231 acquires the number of SBUs calculated by the number-of-errors identification unit 240 (which will be denoted by “NS”). The SBU cross-section calculation section 231 acquires, from the particle energy calculation unit 220, the particle fluence (which is assumed to be ϕ1 [n/cm2]) of particles that constitute a source of occurrence of the SEF linked to each acquired SBU. Then, based on the number of SBUs “NS” and the particle fluence “ϕ1,” the SBU cross-section is calculated by using the following Formula (2):
(SBU cross-section)=NS/ϕ1 (2)
The MBU cross-section calculation section 232 acquires the number of MBUs calculated by the number-of-errors identification unit 240 (which will be denoted by “NM”). The MBU cross-section calculation section 232 acquires, from the particle energy calculation unit 220, the particle fluence (which is assumed to be ϕ2 [n/cm2]) of particles that constitute a source of occurrence of the SEF linked to each acquired MBU. Then, based on the number of MBUs “NM” and the particle fluence “ϕ2,” the SBU cross-section is calculated by using the following Formula (3):
(SBU cross-section)=NM/ϕ2 (3)
In this way, each of the SBU cross-section and the MBU cross-section can be separately detected.
In this way, the nuclear reaction detection device 1 according to the present embodiment monitors occurrence of CRAM errors using an error check method, such as CRC, by means of the CRAM monitoring circuit 102 provided in the FPGA 100. When a CRAM error is detected, the address of a region where the CRAM error has occurred is detected. Further, whether the error is an SBU that is an error of one bit or an MBU that is an error of multiple bits is detected. Then, by using the detected SBU and MBU, an SBU cross-section and an MBU cross-section can be separately calculated.
That is, in the conventional technology, only a logical abnormality of the FPGA 100 caused by a bit error of the CRAM is used as an SEU detection trigger. Therefore, it is not possible to identify whether an SEU caused by particle radiation is an SBU in which only one bit is inverted or an MBU in which multiple bits are inverted.
In the present embodiment, an SBU and an MBU can be detected, while being distinguished from each other, by means of the CRAM monitoring circuit 102 that constantly checks data in the CRAM by using an error check method, such as CRC. Therefore, the energy of a particle that has caused the SBU and the energy of a particle that has caused the MBU can be measured while being distinguished from each other. As a result, an SBU cross-session and an MBU cross-session for each continuous particle energy can be measured.
In both the case where the FPGA 100 has the function of correcting CRAM errors and the case where the FPGA 100 does not have the function, the error can be detected by identifying whether the error is the SBU or the MBU.
Further, if a plurality of CRAM errors is detected in one cycle of detection by the CRAM monitoring circuit 102, these CRAM errors are not used for calculation of an SBU cross-section and an MBU cross-section. This can avoid decrease in the calculation accuracy of the cross-sections due to use of uncertain data.
The present invention is not limited to the above embodiment but various modifications can be made within the scope of the gist of the invention.
For the nuclear reaction detection device 1 of the present embodiment described above, for example, as shown in
The nuclear reaction detection device 1 may be implemented using one computer or may be implemented using a plurality of computers. The nuclear reaction detection device 1 may be a virtual machine implemented in a computer.
Programs for the nuclear reaction detection device 1 can be stored in a computer-readable storage medium, such as an HDD, an SSD, a universal serial bus (USB) memory, a compact disc (CD), or a digital versatile disc (DVD), or can be distributed through a network.
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/JP2020/018950 | 5/12/2020 | WO |