Publication | Closed Access
Certifying low-level programs with hardware interrupts and preemptive threads
79
Citations
25
References
2008
Year
Unknown Venue
Program CheckingEngineeringHardware Verification LanguageVerificationComputer ArchitecturePreemptive ThreadsComputer-aided VerificationSoftware AnalysisFormal VerificationHardware SecuritySystems EngineeringProgram Control FlowHoare LogicRuntime VerificationConcurrent ProgrammingComputer EngineeringHardware InterruptsComputer ScienceSoftware VerificationOperating SystemsProgram AnalysisFormal MethodsSystem Software
Hardware interrupts are widely used in the world's critical software systems to support preemptive threads, device drivers, operating system kernels, and hypervisors. Handling interrupts properly is an essential component of low-level system programming. Unfortunately, interrupts are also extremely hard to reason about: they dramatically alter the program control flow and complicate the invariants in low-level concurrent code (e.g., implementation of synchronization primitives). Existing formal verification techniques---including Hoare logic, typed assembly language, concurrent separation logic, and the assume-guarantee method---have consistently ignored the issues of interrupts; this severely limits the applicability and power of today's program verification systems.
| Year | Citations | |
|---|---|---|
Page 1
Page 1