Publication | Closed Access
CEDA: Control-Flow Error Detection Using Assertions
63
Citations
21
References
2011
Year
EngineeringVerificationComputer-aided VerificationSoftware EngineeringSoftware AnalysisFormal VerificationHardware SecuritySystems EngineeringStatic CheckingControl-flow Error DetectionCompilersRuntime VerificationOnline DetectionComputer EngineeringComputer ScienceDebuggerStatic Program AnalysisSoftware VerificationFault InjectionAutomated ReasoningProgram AnalysisSoftware TestingFormal MethodsEfficient Software TechniqueSystem Software
This paper presents an efficient software technique, control-flow error detection through assertions (CEDA), for online detection of control-flow errors. Extra instructions are automatically embedded into the program at compile time to continuously update runtime signatures and to compare them against preassigned values. The novel method of computing runtime signatures results in a huge reduction in the performance overhead, as well as the ability to deal with complex programs and the capability to detect subtle control-flow errors. The widely used C compiler, GCC, has been modified to implement CEDA, and the SPEC benchmark programs were used as the target to compare with earlier techniques. Fault injection experiments were used to demonstrate the effect of control-flow errors on software and to evaluate the fault detection capabilities of CEDA. Based on a new comparison metric, method efficiency, which takes into account both error coverage and performance overhead, CEDA is found to be much better than previously proposed methods.
| Year | Citations | |
|---|---|---|
Page 1
Page 1