Publication | Closed Access
Precise Detection of Side-Channel Vulnerabilities using Quantitative Cartesian Hoare Logic
80
Citations
48
References
2017
Year
Hardware TrojanEngineeringInformation SecurityVerificationPrecise DetectionSide-channel AttackFormal VerificationSoftware AnalysisHardware SecurityVulnerability Assessment (Computing)Static CheckingProgram LogicEpsilon-bounded Non-interferenceRuntime VerificationStatic AnalysisComputer EngineeringComputer ScienceStatic Program AnalysisLanguage-based SecurityData SecurityCryptographySoftware SecurityProgram AnalysisAttack ModelSoftware TestingFormal MethodsJava ApplicationsSide-channel AnalysisSecurity MeasurementSystem Software
This paper presents Themis, an end-to-end static analysis tool for finding resource-usage side-channel vulnerabilities in Java applications. We introduce the notion of epsilon-bounded non-interference, a variant and relaxation of Goguen and Meseguer's well-known non-interference principle. We then present Quantitative Cartesian Hoare Logic (QCHL), a program logic for verifying epsilon-bounded non-interference. Our tool, Themis, combines automated reasoning in CHL with lightweight static taint analysis to improve scalability. We evaluate Themis on well known Java applications and demonstrate that Themis can find unknown side-channel vulnerabilities in widely-used programs. We also show that Themis can verify the absence of vulnerabilities in repaired versions of vulnerable programs and that Themis compares favorably against Blazer, a state-of-the-art static analysis tool for finding timing side channels in Java applications.
| Year | Citations | |
|---|---|---|
Page 1
Page 1