Lock in $30 Savings on PRO—Offer Ends Soon! ⏳

Jean Yang on An Axiomatic Basis for Computer Pr...

Jean Yang on An Axiomatic Basis for Computer Programming

Our lives now run on software. Bugs are becoming not just annoyances for software developers, but sources of potentially catastrophic failures. A careless programmer mistake could leak our social security numbers or crash our cars. While testing provides some assurance, it is difficult to test all possibilities in complex systems--and practically impossible in concurrent systems. For the critical systems in our lives, we should demand mathematical guarantees that the software behaves the way the programmer expected.

A single paper influenced much of the work towards providing these mathematical guarantees. C.A.R. Hoare’s seminal 1969 paper “An Axiomatic Basis for Computer Programming” introduces a method of reasoning about program correctness now known as Hoare logic. In this paper, Hoare provides a technique that 1) allows programmers to express program properties and 2) allows these properties to be automatically checked. These ideas have influenced decades of research in automated reasoning about software correctness.

In this talk, I will describe the main ideas in Hoare logic, as well as the impact of these ideas. I will talk about my personal experience using Hoare logic to verify memory guarantees in an operating system. I will also discuss takeaway lessons for working programmers.

Papers_We_Love

November 18, 2014
Tweet

More Decks by Papers_We_Love

Other Decks in Programming

Transcript

  1. Testing I looked in the mirror five times. I confirmed

    that I look good. I am Ryan Gosling. I am wearing a suit. Ryan Gosling looks good in a suit. Q.E.D. Logical reasoning vs.
  2. Axioms. The set of facts we have to work with.

    Ingredients Theorems. Built from our axioms based on deduction rules.
  3. → → Am Ryan Gosling → Great hair Great hair

    → Look good Am Ryan Gosling Look good Deductive Logic: Syllogism
  4. Deductive Logic: Contrapositive → ¬ ¬ Am Ryan Gosling →

    Look good Do not look good Am not Ryan Gosling
  5. Previous Work: Characterizing Program State = 3 > ( ≠

    0) ⇒ ( + = ) = ∈1… [] ∀ ∈ 1 … . > [ − 1] Slide borrowed from Jonathan Aldrich, who borrowed slides from Rustan Leino.
  6. Example Hoare Triples ∶= 5 = 5 = { ∶=

    + 3} = + 3 > 0 { ∶= ∗ 2} > −2 = < 0 ℎ ∶= − = || { ∶= 3} = 8 {ℎ ≔ + 1} … Looks good Any program Looks good
  7. Example: Assignment ? ≔ + 1 ≤ Assignment axiom schema

    0 ≔ where is a variable identifier; is an expression; 0 is obtained from by substituting for all occurrences of .
  8. Example: Assignment + 1 ≤ ≔ + 1 ≤ 0

    ≔ where is a variable identifier; is an expression; 0 is obtained from by substituting for all occurrences of . Assignment axiom schema
  9. 1 1 1 2 1 ; 2 Composition > 1

    ≔ + 1 > 2 > 2 ≔ + 1 > 3 > 1 ≔ + 1; ≔ + 1 > 3 > 1 ≔ + 1 > 2 > 0 ≔ − < 0 > 1 ≔ + 1; ≔ − ?
  10. → → Consequence > 1 ≔ + 1 > 2

    > 2 → > 0 > 0 ≔ − < 0 > 1 ≔ + 1; ≔ − < 0
  11. Iteration ∧ conjunction ¬ negation ∧ < 10 ≔ +

    1 < 10 ≔ + 1 ≥ 10 ∧ > 0 ∧ < 10 ≔ + 1 > 0 > 0 < 10 ≔ + 1 ≥ 10 ∧ > 0 ∧ ¬ ∧
  12. Verified Type-checked Verve, a Type-Safe OS Safe to the Last

    Instruction / Jean Yang • Verify partial correctness of low- level Nucleus using Hoare logic based on a hardware spec. • Verify an interface to typed assembly for end-to-end safety. Nucleus File System Drivers Applications Microkernel Hardware specification Interface specification 27 [Yang and Hawblitzel, PLDI 2010]
  13. “Load” Specification procedure Load(ptr:int) returns (val:int); requires memAddr(ptr); requires Aligned(ptr);

    modifies Eip; ensures word(val); ensures val == Mem[ptr]; Safe to the Last Instruction / Jean Yang 29
  14. Boogie to x86 implementation ReadKeyboard(){ call KeyboardStatusIn8(); call eax :=

    And(eax, 1); if (eax != 0) { goto proc; } call eax := mov(256); return; proc: call KeyboardDataIn8(); call eax := And(eax, 255); return; } Safe to the Last Instruction / Jean Yang ReadKeyboard proc in al, 064h and eax, 1 cmp eax, 0 jne ReadKeyboard$proc mov eax, 256 ret ReadKeyboard$skip: in al, 060h and eax, 255 ret 30
  15. The Verve Nucleus Safe to the Last Instruction / Jean

    Yang 31 Verified Type-checked Nucleus File System Driver s Applications Microkernel Hardware specification Interface specification Verified Interface specification x86 instructions Memory bounds Devices GC Heap Allocator and GC [POPL 2009] Stacks Interrupt table Interrupt/error handling Interface specification
  16. Pop Quiz! • What main issues did this paper address?

    • Why do we want to prove programs correct? • What were Hoare’s contributions to software verification? • What should we be doing when we leave here?
  17. Hoare Logic, Since 1969 1. Define a way to characterize

    programs and properties. 2. Build tools to automatically check program properties. 3. Profit.