// S : tags c sym $TAGS // S : expect --result valid // S : cc -o test.bc $CC_OPT $file // S : verify --symbolic --solver $solver --sequential -o nofail:malloc $V_OPT test.bc // N : V : CC_OPT : V_OPT : TAGS : RESULT // V : big.100 : -DNUM=100 : : big : valid // V : big.1000 : -DNUM=1000 : : big : valid // V : big.10000 : -DNUM=10000 : : big : valid // V : big.10 : -DNUM=10 : : big : valid // V : big.100000 : -DNUM=100000 : : big : valid // V : small.5 : -DNUM=5 : : big : valid extern void __VERIFIER_error(void); extern void __VERIFIER_assume(int); void __VERIFIER_assert(int cond) { if (!(cond)) { ERROR: __VERIFIER_error(); } return; } extern int __VERIFIER_nondet_int(void); int main( int argc, char *argv[]){ int n,l,r,i,j; n = __VERIFIER_nondet_int(); if (!(1 <= n && n <= NUM)) return 0; l = n/2 + 1; r = n; if(l>1) { l--; } else { r--; } while(r > 1) { i = l; j = 2*l; while(j <= r) { if( j < r) { __VERIFIER_assert(1 <= j); __VERIFIER_assert(j <= n); __VERIFIER_assert(1 <= j+1); __VERIFIER_assert(j+1 <= n); if( __VERIFIER_nondet_int() ) j = j + 1; } __VERIFIER_assert(1 <= j); __VERIFIER_assert(j <= n); if( __VERIFIER_nondet_int() ) { break; } __VERIFIER_assert(1 <= i); __VERIFIER_assert(i <= n); __VERIFIER_assert(1 <= j); __VERIFIER_assert(j <= n); i = j; j = 2*j; } if(l > 1) { __VERIFIER_assert(1 <= l); __VERIFIER_assert(l <= n); l--; } else { __VERIFIER_assert(1 <= r); __VERIFIER_assert(r <= n); r--; } } return 0; }