// verifast_options{disable_overflow_check target:ILP32} // This file is part of the SV-Benchmarks collection of verification tasks: // https://gitlab.com/sosy-lab/benchmarking/sv-benchmarks // // SPDX-FileCopyrightText: 2019 Dirk Beyer and Matthias Dangl // // SPDX-License-Identifier: Apache-2.0 // It was automatically generated from 'eq2.c' with https://github.com/FlorianDyck/semtransforms // To reproduce it you can use the following command: // python run_transformations.py [insert path here]eq2.c -o . --pretty_names --trace to_recursive:0 // in case the newest version cannot recreate this file, the commit hash of the used version is 869b5a9 extern void abort(void); //@ requires true; //@ ensures true; void reach_error() //@ requires false; //@ ensures true; {} extern unsigned int __VERIFIER_nondet_uint(void); void __VERIFIER_assert(int cond) //@ requires (cond != 0); //@ ensures (cond != 0); { if (!cond) { ERROR: { reach_error(); abort(); } } else { } return; } void func_to_recursive_line_16_to_18_0(unsigned int *y, unsigned int *z) //@ requires true; //@ ensures true; { if (__VERIFIER_nondet_uint()) //@ requires true; //@ ensures true; { { (*y)++; (*z)++; } func_to_recursive_line_16_to_18_0(y, z); } else { } } int main(void) //@ requires module(recursified_eq2__verifast_instrumented, true); //@ ensures junk(); { //@ open_module(); unsigned int w = __VERIFIER_nondet_uint(); unsigned int x = w; unsigned int y = w + 1; unsigned int z = x + 1; func_to_recursive_line_16_to_18_0(&y, &z); __VERIFIER_assert(y == z); return 0; }