Synthesizing Software Verifiers from Proof Rules
Corneliu Popeea Technical University Munich
Joint work with Sergey Grebenshchikov, Nuno Lopes and Andrey Rybalchenko
Synthesizing Software Verifiers from Proof Rules Corneliu Popeea - - PowerPoint PPT Presentation
Synthesizing Software Verifiers from Proof Rules Corneliu Popeea Technical University Munich Joint work with Sergey Grebenshchikov, Nuno Lopes and Andrey Rybalchenko Developing verifiers today Program Model transition system, program with
Joint work with Sergey Grebenshchikov, Nuno Lopes and Andrey Rybalchenko
2
3
4
5
6
7
F(V,V')
8
9
10
– safety:
– termination: dwf(q(v,v'))
11
– counterexample: recursion-free Horn clauses
– safety: solving rec.-free Horn clauses
– termination: solving rec.-free Horn clauses with wf
12
Init(V) -> Invi(V) Invi(V) Step ∧
i(V, V') -> Invi(V')
( \/j≠i Invj(V) ∧ Stepj(V,V')) -> Envi(V,V') Invi(V) ∧ Envi(V,V') -> Invi(V') Inv1(V) ∧ .. ∧ InvN(V) Error(V) ∧
________________________
Multi-threaded program is safe
Init(V) V'=V -> ∧ Summ(V,V') Summ(V,V') Step(V', V'') -> ∧ Summ(V,V'') Summ(V,V') Call(V', V'') V'''=V'' -> ∧ ∧ Summ(V'',V''') Summ(V,V') Call(V', V'') ∧ ∧ Summ(V'', V''') ∧ Return(V''', V'''') Local(V', V'''') ∧
Summ(V,V') Error(V') -> false ∧ ____________________________________
Procedural program is safe Init(V) -> Inv(V) Inv(V) Step(V, V') -> ∧ Inv(V') Inv(V) Error(V) -> false ∧ ________________________ Transition system is safe Inv(V) Step(V, V') -> ∧ TransInv(V, V') TransInv(V, V') Step(V', V'') -> ∧ TransInv(V, V'') dwf(TransInv(V, V')) _____________________________ Transition system terminates
true -> Pre(n) Pre(n) n>0 -> ∧ Pre(n-1) Pre(n) n>0 ∧ ∧ Post(n-1,s) -> Post(n,s+n) Pre(n) n<=0 -> ∧ Post(n,0) Post(n,s) -> s>=0
________________________ Functional program is safe
Init(V) Step ∧
i(V,V')
→ Ti(V,V') Ti(V,V') Step ∧
i(V',V'') → Ti(V,V'')
Ti(V,V') Step ∧
i(V', V'')
→ Ti(V',V'') (∨j≠i Init(V) Step ∧
j(V,V')) → Ei(V,V')
(∨j≠i Tj(V,V') Step ∧
j(V',V'')) → Ei(V',V'')
Init(V) ∧ Ei(V,V') → Ti(V,V') Ti(V,V') ∧ Ei(V',V'') → Ti(V,V'') Ti(V,V') E ∧
i(V', V'')
→ Ti(V',V'') dwf(T1(V,V') .. ∧ ∧ TN(V,V'))
____________________________ Multi-threaded program terminates
13
14
(translates C to Horn clauses)
[Reps, Horwitz, Sagiv - POPL 1995]
15
[TACAS 2012]
ControlFlowInteger category:
94 correct results in 80 minutes 2 time/outs
16
17
18
19
20
21
22
[Elmas, Qadeer, Tasiran - POPL 2009]
[Kroening, Sharygina, Tsitovich, Wintersteiger - CAV 2010]
[Cohen, Namjoshi, Sa'ar - CAV 2010]
[Donaldson, Kaiser, Kroening, Wahl - CAV 2011]
[Iosif, Bozga, Konečný - TACAS 2012]
[Henzinger, Jhala, Majumdar - PLDI 2004]
23
24
25
26
27
28
1.HC = { Init(V) move ∧
1(a0,a1) ... ->
∧ T11(V,V'), T11(V,V') move ∧
1(a1,a2) ... ->
∧ T12(V',V''), T12(V,V') move ∧
1(a2,a1) ... ->
∧ T13(V,V''), T13(V,V') -> WF(V,V') } 2.SOLleast(T11(V,V')) = (l=0 l'=1 x'=x move ∧ ∧ ∧
1(a0,a1) pc
∧
2=pc2'=b0)
SOLleast(T12(V,V')) = (l=1 l'=1 x>0 x'=x move ∧ ∧ ∧ ∧
1(a1,a2) pc
∧
2=pc2'=b0)
SOLleast(T13(V,V')) = (l=1 l'=1 x>0 x'=x-1 move ∧ ∧ ∧ ∧
1(a1,a1) pc
∧
2=pc2'=b0)
3.WF(V,V') = (x>0 x'<x) ∧ 4.HC1 = { Init(V) move ∧
1(a0,a1) ... ->
∧ T11(V,V'), T11(V,V') move ∧
1(a1,a2) ... ->
∧ T12(V',V''), T12(V,V') move ∧
1(a2,a1) ... ->
∧ T13(V,V''), T13(V,V') -> x>0 x'<x } ∧ 5.SOL(T11(V,V')) = true SOL(T12(V,V')) = (x>0 x'=x) ∧ SOL(T13(V,V')) = (x>0 x'<x) ∧ SOL(WF(V,V'))= (x>0 x'<x) ∧
Stem Lasso
29
a1) Inv(v) = true via ( (), 1 ) a1) fails 3
pc0 = A → Inv0(pc0,s0,i0) Inv0(pc0,s0,i0) /\ pc0=c /\ s0<0 →⊥
Inv0(pc0,s0,i0) = pc0=A
Find Inv(V) such that: 1) pc = A → Inv(V) 2) Inv(V) ∧ ((pc=A pc'=B s'=0 i'=i) ∧ ∧ ∧ ∨ (pc=B pc'=B i>0 s'=s+i i'=i-1) ∧ ∧ ∧ ∧ ∨ (pc=B pc'=C i ∧ ∧ ≤0 s'=s i'=i ∧ ∧ )) → Inv(V') 3) Inv(V) pc=C s<0 -> ∧ ∧ ⊥
30
a1) Inv(v) = pc=A via ( (), 1 ) a2) Inv(v) = s≥0 via ( a1, 2 )
both a1) and a2) satisfy clause 3
Find Inv(V) such that: 1) pc = A → Inv(V) 2) Inv(V) ∧ ((pc=A pc'=B s'=0 i'=i) ∧ ∧ ∧ ∨ (pc=B pc'=B i>0 s'=s+i i'=i-1) ∧ ∧ ∧ ∧ ∨ (pc=B pc'=C i ∧ ∧ ≤0 s'=s i'=i ∧ ∧ )) → Inv(V') 3) Inv(V) pc=C s<0 -> ∧ ∧ ⊥