Accelerating Transient Fault Injection Campaigns by using Dynamic HDL
  Slicing by Bagbaba, Ahmet Cagri et al.
2019 IEEE. Personal use of this material is permitted. Permission from IEEE must be obtained for all other uses, in any
current or future media, including reprinting/republishing this material for advertising or promotional purposes, creating new
collective works, for resale or redistribution to servers or lists, or reuse of any copyrighted component of this work in other
works.
.
ar
X
iv
:2
00
1.
09
98
2v
1 
 [c
s.A
R]
  2
4 J
an
 20
20
Accelerating Transient Fault Injection Campaigns
by using Dynamic HDL Slicing
Ahmet Cagri Bagbaba∗†, Maksim Jenihhin†, Jaan Raik†, Christian Sauer∗
∗Cadence Design Systems, Munich, Germany; † Tallinn University of Technology, Tallinn, Estonia
Email: ∗{abagbaba, sauerc}@cadence.com, †{maksim.jenihhin, jaan.raik}@taltech.ee
Abstract—Along with the complexity of electronic systems
for safety-critical applications, the cost of safety mechanisms
evaluation by fault injection simulation is rapidly going up. To
reduce these efforts, we propose a fault injection methodology
where Hardware Description Language (HDL) code slicing is
exploited to accelerate transient fault injection campaigns by
pruning fault lists and reducing the number of the injections.
In particular, the dynamic HDL slicing technique provides for
a critical fault list and allows avoiding injections at non-critical
time-steps. Experimental results on an industrial core show that
the proposed methodology can successfully reduce the number
of injections by up to 10 percent and speed-up the fault injection
campaigns.
Index Terms—fault injection, fault simulation, functional
safety, transient faults, ISO26262, RTL, CPU
I. INTRODUCTION
With new and increased capabilities in applications such
as autonomous driving, the complexity of electronics systems
for safety critical applications is growing exponentially. This
is causing a shift in the traditional design flow and is push-
ing ISO26262 compliance down in the semiconductor chain
to the individual IP provider and even into the traditional
Electronic Design Automation tools. As a result, functional
safety compliance becomes a part of the requirements for the
development of complex electronics systems. During the de-
sign of ISO26262 compliant chips, designers need to evaluate
effectiveness of the design to deal with random hardware fail-
ures. This is usually done by Fault Injection Simulations. Also,
ISO26262 standard highly recommends using of fault injection
during the development process of integrated circuits [1].
Fault injection is a powerful technique that shows the be-
haviour of a circuit under the effect of a fault [2]. The objective
of fault injection is to mimic the effects of faults originating
inside a chip as well as those affecting external buses. Different
approaches to fault injection and dependability evaluation have
been proposed. These include emulation-based fault injection
using FPGA architectures as hardware accelerators to speed
up estimation of systems’ fault tolerance [3], [4] and formal
method based approaches [5], [6]. This paper focuses on the
simulation-based fault injection approach, which can be ap-
plied to larger designs compared to the formal and emulation-
based solutions.
Having enormous number of possible faults in modern
designs is a major drawback of simulation-based fault injection
technique as designers need to execute a fault-free simulation
as well as thousands of faulty simulations [7]. Therefore, it is
too hard to inject all possible faults in an acceptable time in all
possible locations and at each clock cycle [8]. One solution
is to use Statistical Fault Injection (SFI) [8] in which only
a randomly selected subset of possible faults is injected. SFI
can provide a better execution time by reducing the number
of the injections with an error margin. Moreover, [9] have
demonstrated that with randomly selected fault lists the ratio
of faults which do not produce errors may range as low as
2 to 8 percent, depending on the design under simulation.
In consequence, minimization of fault injection locations or
pruning fault lists are advantageous ways to reduce the fault
injection simulation time significantly while allowing injection
of a considerably larger number of relevant faults.
This work proposes a simulation-based fault injection
methodology based on Dynamic HDL Slicing to minimize
the number of fault injections. The proposed methodology
identifies critical faults which cause the system to fail in
the absence of a safety mechanism, and injects only critical
faults during the transient fault injection simulation campaigns.
Using critical faults to estimate fault coverage eliminates the
possibility of fault injection experiments to produce no error.
The main contribution of this work is three-fold as follows:
• Dynamic slicing on HDL to generate critical fault list
• Implicit fault collapsing within the slicing model: The
fault list obtained by the proposed slicing method has an
additional feature of avoiding injections at time-steps as
data inside registers is not being consumed.
• Language-agnostic RTL fault injection supported by in-
dustrial grade EDA tool flow
As a result, this method can successfully reduce the number
of fault injections on an industrial core. The fault model
implemented in this paper is based on single-clock-cycle
bit-flip faults within the RTL registers. This fault model is
targeting single Single-Event-Upsets (SEUs) in all the registers
of the design. The proposed methodology is demonstrated on
Cadence tools but it remains applicable to other tool flows as
well. This work is an extension of our previous work [10].
The major difference is that we extend dynamic slices’ scope
by including both sequential and combinational parts as it is
explained in Section III-C1. This brings 100% accuracy in
the results. In the previous work, less accuracy is adopted as
only sequential parts are considered in dynamic slices. The978-1-7281-2769-9/19/$31.00 ©2019 IEEE
Fig. 1. Proposed HDL slicing based fault injection methodology [10].
second difference is that we evaluate our methodology in the
industrial size CPU with different workloads to demonstrate
the potential of the proposed methodology.
This paper is structured as following. Section II gives an
overview of related works. We describe our dynamic HDL
slicing methodology in Section III. Experimental results are
shown in Section IV. Section V concludes this paper.
II. RELATED WORKS
There exist many advanced tools and methods for
simulation-based fault injection. In [11], a tool called VERIFY
(VHDL-based Evaluation of Reliability by Injection Faults
Efficiently) is presented that utilizes an extension of VHDL for
describing faults correlated to a component, enabling hardware
manufacturers, which provide the design libraries, to express
their knowledge of the fault behaviour of their components.
Although it provides multi-threaded fault injection as well as
checkpoints and comparison with a golden run to speed up
the simulation of faulty runs, the drawback is that it requires
modification of the VHDL language itself. [12] proposes
MEFISTO-C: A VHDL-based fault injection tool that conducts
fault injection experiments using VHDL simulation models. A
variety of predefined fault models are supported by the tool;
however, it does not provide specific optimizations to speed
up the simulation.
Several approaches to generate the critical fault list to
be considered as the basis of fault list injection have been
proposed. In [13], a method for generating a critical fault
list is presented. The system under test is described by a
data flow graph, the fault tree is constructed by applying
the instruction set architecture fault model to the data flow
description with a reverse implication technique, the fault
injection is performed, and fault collapsing on the fault tree
is employed. The proposed method is very costly in terms of
CPU time and it therefore not applicable to systems with high
complexity.
[7] presents a new technique and a platform for accelerating
and speeding-up simulation-based fault injection in VHDL
descriptions. Use check-pointing to reload the fault-free state
if the design allowing to start the fault simulation from the
clock-cycle of fault injection. In addition, a golden-run fault
collapsing technique is utilized that discards all fault injections
between read-write and write-write operations of the memory
elements. However, the approach does not take advantage of
the dynamic slicing benefits. [9] proposes fault collapsing
based on extracting high-level decision diagrams from the
VHDL model. Although significant speed-up can be achieved,
the step of efficient decision diagram synthesis from the full
synthesizable subset of VHDL remains an issue.
There are several papers dealing with transient fault in-
jection. [14] shows the results collected in a series of fault
injection experiments conducted on a commercial processor.
Here, the authors inject a fault in a given sequential element at
a given instant of time. However, as it is hard to inject a fault
in each of the tens of thousands sequential elements in the
processor, the execution is divided into the parts and, for each
of these parts, a random fault injection instant is selected. [15]
analyses fault injection campaign in the CPU registers by
choosing a random instant when the fault is injected. [16]
identifies the optimal set of flip-flops but injection time is
randomized uniformly over the active region of the simulation.
Similarly, [17] injects a fault randomly in time and location in
RT-level. Lastly, [18] deals with single and multiple errors in
processors by randomly selecting injecting time and choosing
registers. As opposed to these works, our approach shows the
fault injection time explicitly instead of random instants.
Dynamic slicing technique is used in [19], [20]. The former
uses dynamic slicing for statistical bug localization in RTL.
The latter proposes dynamic slicing and location-ranking-
based method for accurately pinpointing the error locations
combined with a dedicated set of mutation operators.
Different from the works listed above, this paper proposes
a dynamic HDL slicing based technique that implicitly covers
the golden run fault collapsing, thereby significantly speeding
up the fault injection process.
III. FAULT INJECTION BASED ON DYNAMIC HDL SLICING
TECHNIQUE
In this work, fault injection simulation campaigns are opti-
mized by pruning the fault list to the critical faults identified
using HDL slicing on the RTL design model. The proposed
flow is shown in Fig. 1 and starts with the (1) extraction
of static slices for the target observation point. In parallel,
code coverage data is generated by (2) simulation-based code
coverage analysis for the design with pre-defined stimuli in the
testbench. Next, (3) the dynamic slicing procedure identifies
the intersection of the identified static slice and covered
code items and results in a set of clock-cycle-long dynamic
Fig. 2. HDL slicing on a motivational example chopper [10].
slices for the given observation point. Finally, (4) the fault
injection simulation selects critical faults from the dynamic
slices, injects them at the specified time and evaluates the fault
propagation. We explain the details of the methodology in the
following subsections using a motivational example depicted
in Fig. 2, i.e. a VHDL implementation of a signal chopper
design [21]. Following subsections explain each step of the
proposed methodology in detail.
A. Static Slicing
Static slice, as it is implemented in the current paper,
includes all statements that affect the value of a variable
v for all possible inputs at the point of interest, e.g., at
the statement x, in the program. In the RTL code, static
slice shows the dependency between HDL statements [22]. A
simple design chopper in Fig. 2 has four outputs representing
different chops for the input signal SOURCE based on the
design configuration by inputs INV and DUP. It is possible to
perform a search backward to find dependencies in the HDL.
The resulting static slice is computed for the chopper design’s
output TAR F as shown in Fig. 3 by the help of formal analysis
tool’s structural analysis capability. The column Static Slice in
Fig. 2 marks HDL statements of a static slice on the TAR F
output. For instance, as the static slice of TAR F does not
include Line 40, H0 is counted as outside of the static slice
and for a TAR F output there is no need to inject fault on H0.
Fig. 2 also implies that, static slice does not depend on clock
cycles (shown as C1, C2, C3, C4 and C5) while executed
statements and dynamic slice may change for each clock
cycle. In summary, static slice includes statically available
information only as it does not make any assumptions on
inputs. Static slice is the first step of the proposed methodology
to prune fault list.
B. Coverage Analysis
In parallel to static slicing step, the RTL design is simulated
in the logic simulation tool to dump and analyse the coverage
data. In this step, we dump coverage data for each clock cycle
so that we can find what statements in the RTL are executed
for each clock cycle. In the proposed methodology, one clock
cycle defines the size of our dynamic slice. We use coverage
tool and coverage metrics in order to find executed statements.
After loading a simulation run into the coverage tool, we
can analyze coverage metrics data scored in that run. In this
work, we use code coverage which measures how thoroughly
a testbench exercises the lines of HDL code. Code coverage
includes block coverage, branch coverage, statement coverage,
expression coverage, and toggle coverage. All these coverage
types except toggle coverage can be used in this work. Block
coverage identifies the lines of code that get executed during a
simulation run. It helps us determine if the testbench executes
the statements in a block. Branch coverage complements
block coverage by providing more precise coverage results for
reporting coverage numbers for various branches individually.
Statement coverage is just a subset of block coverage and
it shows execution of all the executable statements in the
RTL. Expression coverage provides information on why a
conditional piece of code was executed. At the end of this
step, we generate executed statements data to find dynamic
slices in the next step. Fig. 2 shows executed statements for
five clock cycles (C1, C2, C3, C4, C5).
C. Dynamic Slicing
Dynamic slice, as it is implemented in the current paper,
includes those statements that actually affect the value of a
variable v for a particular set of inputs of the RTL so it is
computed on a given input [23]. It provides more narrow slices
than static slice and consists of only the statements that affect
the value of a variable for a given input.
In a nutshell, dynamic slice is the intersection of static slice
and executed statements. We illustrate the concept of dynamic
slice in Fig. 2. This figure also shows how dynamic slices
narrow down the fault space when compared to state-of-the-art
static slice approach. For instance, during the time window C5,
register FF (Line 27) is not in dynamic slice meaning that we
do not need to inject fault in FF at C5 time window. Dynamic
slice gives us critical faults and eliminates those faults that
are not critical. In this way, we manage to reduce fault list by
injecting only critical faults. This provides a speed-up in the
fault injection simulation time as each injected fault increases
total run time of fault injection campaign.
1) Implicit Fault Collapsing in Dynamic Slices: In our
proposed methodology, dynamic slices cover both sequential
and combinational parts. In this way, all faults outside of
dynamic slices are 100% undetected and can be collapsed to
exclude them from the fault list. When considering the average
CPU time per a fault, an undetected fault spends more CPU
time than a detected fault as the fault injection simulation for
an undetected fault lasts until the end of the simulation. Hence,
it is very effective to identify undetected faults without running
fault injection campaigns.
Fig. 3. Backward static slice on the signal TAR F in the chopper design.
In the previous work [10], only sequential parts are con-
sidered in dynamic slices; however, both registers (sequential)
and combinational parts that are connected to the registers are
counted in dynamic slices in this work. In Fig. 4, dynamic
slice is built by considering the register inst dest bin and
inst dest (combinational) so that we can have 100% accurate
results. This is called as implicit fault collapsing since we
avoid injections at time-steps as data inside registers is not
being consumed.
D. Fault Injection Simulation
Fault injection enables to verify the capability of a safety
mechanism to recognize failures in a design’s functionality, by
injecting faults into the design. In a fault injection simulation,
target system and the possible hardware faults are modeled
and simulated by the simulator. In this process, the system
behaves as if there is a hardware fault.
To inject faults into a design, fault injection simulator needs
to know fault target at which to inject fault. In this work,
we enable fault instrumentation on the dynamic slices, more
specifically on registers that are in dynamic slices. In other
words, the proposed method identifies critical faults from
dynamic slices and inject them at the specified times. As a
fault model, we use Single Event Upset (SEU) fault type which
inverts the value of output of a sequential element and hold
the modified value until it is assigned a new value. Another
thing that fault injection simulations need is an observation
point, since the purpose of a fault campaign is to verify that
an error will be observed at some specific point in the design.
By defining explicit observation points when running a good
simulation, we can generate data that will help us to determine
if an injected fault is detected or undetected at one or more
specified nets.
In brief, fault injection simulation is used to show the
effectiveness of the proposed method. We inject one fault in
one simulation run. Also, in the case of having more than
one observation point in the analysis, the proposed method
prevents multiple injection of faults within the overlap of static
slices.
IV. EXPERIMENTAL RESULTS
In order to verify the accuracy of the proposed fault injection
method, we evaluate our application on industrial CPU with
different workloads [24]. In the following subsections, firstly,
Fig. 4. Implicit fault collapsing.
we explain our experimental setup. Then, we show the results
in detail.
A. Experimental Setup
Aiming to automate the execution of fault injection cam-
paigns using the different tools, an application is developed as
in the Fig. 5. This is the more detailed illustration of Fig. 1.
We create generic scripts to activate the tools and automate
the flow. In this work, the proposed methodology is integrated
into Cadence flow but it can be applied using tools by any
major EDA vendor.
In the first step, backward static slice is built for a selected
observation point by using Cadence® JasperGold Formal Ver-
ification Platform. Then, we generate coverage results through
Cadence® Xcelium™ for each clock cycle that defines the size
of the dynamic slices. In the next step, static slice and executed
statements data are sent to fault injection simulation to define
fault target for the campaign. Annotation results provide
information regarding to number of injected faults, number
of detected and undetected faults. Moreover, we also use the
profiling feature of the tool that measures where CPU time
is spent during simulation. The profiler generates a run-time
profile file that contains simulation run-time information that
is useful for comparing execution time of different campaigns.
Cadence® Xcelium Fault Simulator is used for fault injection
simulations.
B. Evaluation and Results
We evaluate our methodology on a 16-bit microcontroller
core [24] with a single address space for instructions and
data. To show the effectiveness of the proposed method,
we use three different workloads on openMSP430. We show
our results in two categories as fault list reduction and time
savings. Then, we evaluate the accuracy of this methodology
by comparing our results to a state-of-the-art static slicing
optimization method.
In the first step, backward static slice is built from dmem din
observation point which is the main output of the core and then
Fig. 5. Overall flow of experimental setup.
Fig. 6. Fault list reduction based on three different workloads.
coverage data is calculated. Next, considering the registers
in static slice, instruction source and destination registers are
selected as fault targets to apply the proposed method since
these registers are widely used in fault injection applications
as they hold all instructions.
Table I shows the comparison of two techniques: a) state-of-
the-art static slicing and b) dynamic HDL slicing. We perform
a fault injection campaign for each workload and a fault target
(and) for each approach. For the execution of Dhrystone and
Coremark workloads with static slicing, we select 100k faults
after the warm-up phase of the CPU.
1) Fault List Reduction: Fig. 6 shows the reduction in the
number of faults injected. All detected faults seen in Fig. 6
are critical faults. As seen in this charts, dynamic HDL slicing
is effective in pruning the fault list as compared to the static
slicing. Table II shows the percent reduction in the number of
faults injection. The best reduction is achieved in Sandbox
workload as a reduction of 9.94%. The magnitude of the
fault list reduction depends on the workload characteristics.
In this experimental results, the fault list reduction varies
between 1.36% and 9.94%. These analysis reveal that dynamic
HDL slicing prune the fault list and identify the critical faults
successfully while analysis and optimization effort costs are
very minor. Additionally, to identify undetected faults and
exclude them from the fault list provides a increased fault
coverage as it can easily be seen in Table I.
2) Time Savings: Table I shows the total CPU time of
overall regression for each fault injection campaign. Dynamic
slicing provides various time savings from 1.58% to 16.91%
as shown in Table III. As in fault list reduction, time savings
TABLE I
EXPERIMENTAL RESULTS ON OPENMSP430
Sandbox Dhrystone Coremark
Static Slicing Dynamic Slicing Static Slicing Dynamic Slicing Static Slicing Dynamic Slicing
inst dest bin
Detected 8036 8036 56236 56236 48891 48891
Undetected 3996 2852 43764 42404 51109 47809
Total 12032 10888 100000 98640 100000 96700
Total CPU time of overall regression 1197.1s 994.7s 658919.7s 622459.0s 3437663.0s 3323109.9s
Fault Coverage 66.788% 73.806% 56.236% 62.735% 48.891% 50.559%
inst src bin
Detected 2423 2423 34766 34766 45161 45161
Undetected 9609 8413 65234 63498 54839 48051
Total 12032 10836 100000 98264 100000 93212
Total CPU time of overall regression 1488.2s 1284.2s 803009.1s 790300.0s 3575198.1s 3178378.2s
Fault Coverage 20.137% 22.361% 34.766% 35.380% 45.161% 48.450%
TABLE II
PERCENTAGE OF REDUCTION OF THE TOTAL NUMBER OF INJECTIONS
WITH DYNAMIC HDL SLICING
Sandbox Dhrystone Coremark
Percentage of reduction Percentage of reduction Percentage of reduction
inst dest bin 9.51% 1.36% 3.3%
inst src bin 9.94% 1.74% 6.79%
TABLE III
TIME SAVINGS USING DYNAMIC HDL SLICING
Sandbox Dhrystone Coremark
Dynamic slicing time saving Dynamic slicing time saving Dynamic slicing time saving
inst dest bin 16.91% 5.53% 3.33%
inst src bin 13.71% 1.58% 11.10%
depend on the workload characteristic. When considering
the need of multiple fault injection campaigns in real life
applications, this time savings can expeditiously increase.
3) Accuracy: In this work, we show the results of a fault
injection campaign performed using dynamic slicing, along
with a state-of-the-art static slicing approach. These results
reveal that dynamic slicing achieves the same number of
detected faults as static slicing campaign. This means that
dynamic slicing can be used for different purposes as it is
an accurate fault injection methodology. For instance, SFI [8]
prunes the fault list in terms of margin of error with a given
confidence level. However, dynamic slicing exclude only non-
critical faults and find all critical faults with a 100% accuracy.
V. CONCLUSIONS
Fault injection on RTL requires excessively long simulation
time which prevents detailed reliability evaluation of hardware
components with significant number of injections. This paper
presents a method to speed-up fault injection campaigns by
minimizing of fault injection locations. The method applies
dynamic slicing on HDL to accurately pinpoint fault injection
locations and allows injection of critical faults in these time
windows. In this way, this paper narrows down the fault space
and provides reduced simulation time. Moreover, average 5-
10% extra gain in simulation time for fault injection is a
significant improvement of the total chip validation costs, as
this phase is the most time consuming. The proposed method is
language-agnostic and suitable for industrial grade EDA tool
flows. Experimental results on industrial-size example show
that we achieve significant speed-up of the fault injection
simulation when comparing to the state-of-the-art flows.
ACKNOWLEDGEMENT
This research was supported by project RESCUE funded
from the European Union’s Horizon 2020 research and inno-
vation programme under the Marie Sklodowaska-Curie grant
agreement No 722325.
REFERENCES
[1] ISO, “ISO 26262 - road vehicles - functional safety,” Dec 2018.
[2] G. A. Kanawati, N. A. Kanawati, and J. A. Abraham, “Ferrari: a flexible
software-based fault and error injection system,” IEEE Transactions on
Computers, vol. 44, no. 2, pp. 248–260, Feb 1995.
[3] P. Civera, L. Macchiarulo, M. Rebaudengo, M. S. Reorda, and
M. Violante, “An fpga-based approach for speeding-up fault injection
campaigns on safety-critical circuits,” Journal of Electronic Testing,
vol. 18, no. 3, pp. 261–271, Jun 2002. [Online]. Available:
https://doi.org/10.1023/A:1015079004512
[4] A. Pellegrini, K. Constantinides, D. Zhang, S. Sudhakar, V. Bertacco,
and T. Austin, “Crashtest: A fast high-fidelity fpga-based resiliency anal-
ysis framework,” in 2008 IEEE International Conference on Computer
Design, Oct 2008, pp. 363–370.
[5] R. Leveugle, “A new approach for early dependability evaluation based
on formal property checking and controlled mutations,” in 11th IEEE
International On-Line Testing Symposium, July 2005, pp. 260–265.
[6] G. Fey and R. Drechsler, “A basis for formal robustness checking,” in
9th International Symposium on Quality Electronic Design (isqed 2008),
March 2008, pp. 784–789.
[7] L. Berrojo, I. Gonzalez, F. Corno, M. S. Reorda, G. Squillero, L. En-
trena, and C. Lopez, “New techniques for speeding-up fault-injection
campaigns,” in Proceedings 2002 Design, Automation and Test in Europe
Conference and Exhibition, March 2002, pp. 847–852.
[8] R. Leveugle, A. Calvez, P. Maistri, and P. Vanhauwaert, “Statistical fault
injection: Quantified error and confidence,” in 2009 Design, Automation
Test in Europe Conference Exhibition, April 2009, pp. 502–506.
[9] J. Raik, U. Repinski, M. Jenihhin, and A. Chepurov, “High-level decision
diagram simulation for diagnosis and soft-error analysis,” Design and
Test Technology for Dependable Systems-on-Chip, pp. 294–309, 2011.
[10] A. C. Bagbaba, M. Jenihhin, J. Raik, and C. Sauer, “Efficient fault
injection based on dynamic hdl slicing technique,” in 2019 IEEE 25th
International Symposium on On-Line Testing and Robust System Design
(IOLTS), July 2019, pp. 52–53.
[11] V. Sieh, O. Tschache, and F. Balbach, “Verify: evaluation of reliability
using vhdl-models with embedded fault descriptions,” in Proceedings of
IEEE 27th International Symposium on Fault Tolerant Computing, June
1997, pp. 32–36.
[12] P. Folkesson, S. Svensson, and J. Karlsson, “A comparison of simulation
based and scan chain implemented fault injection,” in Digest of Papers.
Twenty-Eighth Annual International Symposium on Fault-Tolerant Com-
puting (Cat. No.98CB36224), June 1998, pp. 284–293.
[13] D. T. Smith, B. W. Johnson, J. A. Profeta, and D. G. Bozzolo, “A
fault-list generation algorithm for the evaluation of system coverage,” in
Annual Reliability and Maintainability Symposium 1995 Proceedings,
Jan 1995, pp. 425–432.
[14] X. Iturbe, B. Venu, and E. Ozer, “Soft error vulnerability assessment
of the real-time safety-related arm cortex-r5 cpu,” in 2016 IEEE In-
ternational Symposium on Defect and Fault Tolerance in VLSI and
Nanotechnology Systems (DFT), Sept 2016, pp. 91–96.
[15] R. Travessini, P. R. C. Villa, F. L. Vargas, and E. A. Bezerra, “Processor
core profiling for seu effect analysis,” in 2018 IEEE 19th Latin-American
Test Symposium (LATS), March 2018, pp. 1–6.
[16] A. Evans, M. Nicolaidis, S. Wen, and T. Asis, “Clustering techniques and
statistical fault injection for selective mitigation of seus in flip-flops,” in
International Symposium on Quality Electronic Design (ISQED), March
2013, pp. 727–732.
[17] W. Mansour, R. Velazco, R. Ayoubi, H. Ziade, and W. E. Falou, “A
method and an automated tool to perform set fault-injection on hdl-based
designs,” in 2013 25th International Conference on Microelectronics
(ICM), Dec 2013, pp. 1–4.
[18] T. Bonnoit, A. Coelho, N. Zergainoh, and R. Velazco, “Seu impact
in processor’s control-unit: Preliminary results obtained for leon3 soft-
core,” in 2017 18th IEEE Latin American Test Symposium (LATS), March
2017, pp. 1–4.
[19] M. Jenihhin, A. Tepurov, V. Tihhomirov, J. Raik, H. Hantson, R. Ubar,
G. Bartsch, J. H. M. Escobar, and H. Wuttke, “Automated design error
localization in rtl designs,” IEEE Design Test, vol. 31, no. 1, pp. 83–92,
Feb 2014.
[20] U. Repinski, H. Hantson, M. Jenihhin, J. Raik, R. Ubar, G. D.
Guglielmo, G. Pravadelli, and F. Fummi, “Combining dynamic slicing
and mutation operators for esl correction,” in 2012 17th IEEE European
Test Symposium (ETS), May 2012, pp. 1–6.
[21] E. M. Clarke, M. Fujita, S. P. Rajan, T. W. Reps, S. Shankar, and
T. Teitelbaum, “Program slicing for vhdl,” International Journal on
Software Tools for Technology Transfer, vol. 4, pp. 125–137, 2002.
[22] M. Iwaihara, M. Nomura, S. Ichinose, and H. Yasuura, “Program slicing
on vhdl descriptions and its applications,” 1996.
[23] B. Korel and J. Laski, “Dynamic program slicing,” Inf. Process.
Lett., vol. 29, no. 3, pp. 155–163, Oct. 1988. [Online]. Available:
http://dx.doi.org/10.1016/0020-0190(88)90054-3
[24] (2019) Opencores. [Online]. Available: http://www.opencores.org, last
accessed July 24, 2019
[25] M. Kaliorakis, D. Gizopoulos, R. Canal, and A. Gonzalez, “Merlin:
Exploiting dynamic instruction behavior for fast and accurate microar-
chitecture level reliability assessment,” in 2017 ACM/IEEE 44th Annual
International Symposium on Computer Architecture (ISCA), June 2017,
pp. 241–254.
[26] H. Cho, “Impact of microarchitectural differences of risc-v processor
cores on soft error effects,” IEEE Access, vol. 6, pp. 41 302–41 313,
2018.
[27] M. Ebrahimi and M. B. Tahoori, “Invited: Cross-layer approaches for
soft error modeling and mitigation,” in 2016 53nd ACM/EDAC/IEEE
Design Automation Conference (DAC), June 2016, pp. 1–6.
[28]
