Publication | Open Access
VERISMART: A Highly Precise Safety Verifier for Ethereum Smart Contracts
135
Citations
45
References
2020
Year
Unknown Venue
EngineeringInformation SecurityVerificationEthereum Smart ContractsFormal VerificationSoftware AnalysisHardware SecuritySmart Contract LanguagePresent VerismartArithmetic SafetySystems EngineeringTrusted Execution EnvironmentSecure ComputingTrusted Operating SystemRuntime VerificationComputer EngineeringData PrivacyComputer ScienceSmart ContractData SecurityCryptographySoftware SecurityProgram AnalysisFormal MethodsPrecise VerifierBlockchainSystem Software
We present VERISMART, a highly precise verifier for ensuring arithmetic safety of Ethereum smart contracts. Writing safe smart contracts without unintended behavior is critically important because smart contracts are immutable and even a single flaw can cause huge financial damage. In particular, ensuring that arithmetic operations are safe is one of the most important and common security concerns of Ethereum smart contracts nowadays. In response, several safety analyzers have been proposed over the past few years, but state-of-the-art is still unsatisfactory; no existing tools achieve high precision and recall at the same time, inherently limited to producing annoying false alarms or missing critical bugs. By contrast, VERISMART aims for an uncompromising analyzer that performs exhaustive verification without compromising precision or scalability, thereby greatly reducing the burden of manually checking undiscovered or incorrectly-reported issues. To achieve this goal, we present a new domain-specific algorithm for verifying smart contracts, which is able to automatically discover and leverage transaction invariants that are essential for precisely analyzing smart contracts. Evaluation with real-world smart contracts shows that VERISMART can detect all arithmetic bugs with a negligible number of false alarms, far outperforming existing analyzers.
| Year | Citations | |
|---|---|---|
Page 1
Page 1