cprover
cprover.h
Go to the documentation of this file.
1 /*******************************************************************\
2 
3 Module:
4 
5 Author: Daniel Kroening, kroening@kroening.com
6 
7 \*******************************************************************/
8 
9 #ifndef CPROVER_ANSI_C_LIBRARY_CPROVER_H
10 #define CPROVER_ANSI_C_LIBRARY_CPROVER_H
11 
12 typedef __typeof__(sizeof(int)) __CPROVER_size_t;
13 void *__CPROVER_allocate(__CPROVER_size_t size, __CPROVER_bool zero);
14 extern const void *__CPROVER_deallocated;
15 extern const void *__CPROVER_malloc_object;
16 extern __CPROVER_size_t __CPROVER_malloc_size;
18 extern const void *__CPROVER_memory_leak;
19 
20 void __CPROVER_assume(__CPROVER_bool assumption) __attribute__((__noreturn__));
21 void __CPROVER_assert(__CPROVER_bool assertion, const char *description);
22 void __CPROVER_precondition(__CPROVER_bool assertion, const char *description);
23 void __CPROVER_postcondition(__CPROVER_bool assertion, const char *description);
24 
25 __CPROVER_bool __CPROVER_is_zero_string(const void *);
26 __CPROVER_size_t __CPROVER_zero_string_length(const void *);
27 __CPROVER_size_t __CPROVER_buffer_size(const void *);
28 __CPROVER_bool __CPROVER_r_ok(const void *, __CPROVER_size_t);
29 __CPROVER_bool __CPROVER_w_ok(const void *, __CPROVER_size_t);
30 
31 #if 0
32 __CPROVER_bool __CPROVER_equal();
33 __CPROVER_bool __CPROVER_same_object(const void *, const void *);
34 
35 const unsigned __CPROVER_constant_infinity_uint;
36 typedef void __CPROVER_integer;
37 typedef void __CPROVER_rational;
38 void __CPROVER_initialize(void);
39 void __CPROVER_cover(__CPROVER_bool condition);
40 #endif
41 
42 void __CPROVER_printf(const char *format, ...);
43 void __CPROVER_input(const char *id, ...);
44 void __CPROVER_output(const char *id, ...);
45 
46 // concurrency-related
49 void __CPROVER_fence(const char *kind, ...);
50 #if 0
51 __CPROVER_thread_local unsigned long __CPROVER_thread_id=0;
52 __CPROVER_bool __CPROVER_threads_exited[__CPROVER_constant_infinity_uint];
53 unsigned long __CPROVER_next_thread_id=0;
54 
55 // traces
56 void CBMC_trace(int lvl, const char *event, ...);
57 #endif
58 
59 // pointers
60 unsigned __CPROVER_POINTER_OBJECT(const void *p);
61 signed __CPROVER_POINTER_OFFSET(const void *p);
62 __CPROVER_bool __CPROVER_DYNAMIC_OBJECT(const void *p);
63 #if 0
64 extern unsigned char __CPROVER_memory[__CPROVER_constant_infinity_uint];
66  __CPROVER_size_t address, __CPROVER_size_t extent);
67 
68 // this is ANSI-C
69 extern __CPROVER_thread_local const char __func__[__CPROVER_constant_infinity_uint];
70 
71 // this is GCC
72 extern __CPROVER_thread_local const char __FUNCTION__[__CPROVER_constant_infinity_uint];
73 extern __CPROVER_thread_local const char __PRETTY_FUNCTION__[__CPROVER_constant_infinity_uint];
74 #endif
75 
76 // float stuff
77 int __CPROVER_fpclassify(int, int, int, int, int, ...);
78 __CPROVER_bool __CPROVER_isfinite(double f);
79 __CPROVER_bool __CPROVER_isinf(double f);
80 __CPROVER_bool __CPROVER_isnormal(double f);
81 __CPROVER_bool __CPROVER_sign(double f);
82 __CPROVER_bool __CPROVER_isnanf(float f);
83 __CPROVER_bool __CPROVER_isnand(double f);
84 __CPROVER_bool __CPROVER_isnanld(long double f);
85 __CPROVER_bool __CPROVER_isfinitef(float f);
86 __CPROVER_bool __CPROVER_isfinited(double f);
87 __CPROVER_bool __CPROVER_isfiniteld(long double f);
88 __CPROVER_bool __CPROVER_isinff(float f);
89 __CPROVER_bool __CPROVER_isinfd(double f);
90 __CPROVER_bool __CPROVER_isinfld(long double f);
91 __CPROVER_bool __CPROVER_isnormalf(float f);
92 __CPROVER_bool __CPROVER_isnormald(double f);
93 __CPROVER_bool __CPROVER_isnormalld(long double f);
94 __CPROVER_bool __CPROVER_signf(float f);
95 __CPROVER_bool __CPROVER_signd(double f);
96 __CPROVER_bool __CPROVER_signld(long double f);
97 double __CPROVER_inf(void);
98 float __CPROVER_inff(void);
99 long double __CPROVER_infl(void);
100 //extern int __CPROVER_thread_local __CPROVER_rounding_mode;
101 int __CPROVER_isgreaterd(double f, double g);
102 
103 // absolute value
104 int __CPROVER_abs(int);
105 long int __CPROVER_labs(long int);
106 long long int __CPROVER_llabs(long long int);
107 double __CPROVER_fabs(double);
108 long double __CPROVER_fabsl(long double);
109 float __CPROVER_fabsf(float);
110 
111 // arrays
112 //__CPROVER_bool __CPROVER_array_equal(const void *array1, const void *array2);
113 void __CPROVER_array_copy(const void *dest, const void *src);
114 void __CPROVER_array_set(const void *dest, ...);
115 void __CPROVER_array_replace(const void *dest, const void *src);
116 
117 #if 0
118 // k-induction
119 void __CPROVER_k_induction_hint(unsigned min, unsigned max,
120 unsigned step, unsigned loop_free);
121 
122 // manual specification of predicates
123 void __CPROVER_predicate(__CPROVER_bool predicate);
124 void __CPROVER_parameter_predicates();
125 void __CPROVER_return_predicates();
126 #endif
127 
128 // pipes, write, read, close
130  _Bool widowed;
131  char data[4];
132  short next_avail;
133  short next_unread;
134 };
135 #if 0
136 extern struct __CPROVER_pipet __CPROVER_pipes[__CPROVER_constant_infinity_uint];
137 // offset to make sure we don't collide with other fds
138 extern const int __CPROVER_pipe_offset;
139 extern unsigned __CPROVER_pipe_count;
140 #endif
141 
142 void __CPROVER_set_must(const void *, const char *);
143 void __CPROVER_set_may(const void *, const char *);
144 void __CPROVER_clear_must(const void *, const char *);
145 void __CPROVER_clear_may(const void *, const char *);
146 void __CPROVER_cleanup(const void *, void (*)(void *));
147 __CPROVER_bool __CPROVER_get_must(const void *, const char *);
148 __CPROVER_bool __CPROVER_get_may(const void *, const char *);
149 
150 #define __CPROVER_danger_number_of_ops 1
151 #define __CPROVER_danger_max_solution_size 1
152 #define __CPROVER_danger_number_of_vars 1
153 #define __CPROVER_danger_number_of_consts 1
154 
155 // detect overflow
156 __CPROVER_bool __CPROVER_overflow_minus();
157 __CPROVER_bool __CPROVER_overflow_mult();
158 __CPROVER_bool __CPROVER_overflow_plus();
159 __CPROVER_bool __CPROVER_overflow_shl();
161 
162 #endif // CPROVER_ANSI_C_LIBRARY_CPROVER_H
__CPROVER_isnanld
__CPROVER_bool __CPROVER_isnanld(long double f)
__CPROVER_signld
__CPROVER_bool __CPROVER_signld(long double f)
__CPROVER_equal
__CPROVER_bool __CPROVER_equal()
format
static format_containert< T > format(const T &o)
Definition: format.h:35
__CPROVER_isinfd
__CPROVER_bool __CPROVER_isinfd(double f)
__typeof__
typedef __typeof__(sizeof(int)) __CPROVER_size_t
__CPROVER_atomic_end
void __CPROVER_atomic_end()
__CPROVER_isinff
__CPROVER_bool __CPROVER_isinff(float f)
__CPROVER_overflow_mult
__CPROVER_bool __CPROVER_overflow_mult()
__CPROVER_fpclassify
int __CPROVER_fpclassify(int, int, int, int, int,...)
__CPROVER_malloc_object
const void * __CPROVER_malloc_object
__CPROVER_signf
__CPROVER_bool __CPROVER_signf(float f)
__CPROVER_overflow_plus
__CPROVER_bool __CPROVER_overflow_plus()
__CPROVER_get_may
__CPROVER_bool __CPROVER_get_may(const void *, const char *)
__CPROVER_allocated_memory
void __CPROVER_allocated_memory(__CPROVER_size_t address, __CPROVER_size_t extent)
__CPROVER_llabs
long long int __CPROVER_llabs(long long int)
data
Definition: kdev_t.h:24
__CPROVER_isfinitef
__CPROVER_bool __CPROVER_isfinitef(float f)
__CPROVER_overflow_shl
__CPROVER_bool __CPROVER_overflow_shl()
__CPROVER_pipet::next_unread
short next_unread
Definition: cprover.h:133
__CPROVER_deallocated
const void * __CPROVER_deallocated
__CPROVER_assume
void __CPROVER_assume(__CPROVER_bool assumption) __attribute__((__noreturn__))
__CPROVER_infl
long double __CPROVER_infl(void)
__CPROVER_get_must
__CPROVER_bool __CPROVER_get_must(const void *, const char *)
__CPROVER_pipet::widowed
_Bool widowed
Definition: cprover.h:130
__CPROVER_memory_leak
const void * __CPROVER_memory_leak
__CPROVER_output
void __CPROVER_output(const char *id,...)
__CPROVER_array_copy
void __CPROVER_array_copy(const void *dest, const void *src)
__CPROVER_isnand
__CPROVER_bool __CPROVER_isnand(double f)
__CPROVER_malloc_size
__CPROVER_size_t __CPROVER_malloc_size
__CPROVER_atomic_begin
void __CPROVER_atomic_begin()
__CPROVER_buffer_size
__CPROVER_size_t __CPROVER_buffer_size(const void *)
__CPROVER_sign
__CPROVER_bool __CPROVER_sign(double f)
__CPROVER_w_ok
__CPROVER_bool __CPROVER_w_ok(const void *, __CPROVER_size_t)
__CPROVER_isinfld
__CPROVER_bool __CPROVER_isinfld(long double f)
__attribute__
int __gcc_m64 __attribute__((__vector_size__(8), __may_alias__))
Definition: gcc_builtin_headers_types.h:4
__CPROVER_malloc_is_new_array
_Bool __CPROVER_malloc_is_new_array
__CPROVER_cleanup
void __CPROVER_cleanup(const void *, void(*)(void *))
__CPROVER_overflow_unary_minus
__CPROVER_bool __CPROVER_overflow_unary_minus()
__CPROVER_labs
long int __CPROVER_labs(long int)
__CPROVER_inff
float __CPROVER_inff(void)
__CPROVER_isfinite
__CPROVER_bool __CPROVER_isfinite(double f)
__CPROVER_fence
void __CPROVER_fence(const char *kind,...)
__CPROVER_printf
void __CPROVER_printf(const char *format,...)
__CPROVER_set_may
void __CPROVER_set_may(const void *, const char *)
__CPROVER_array_replace
void __CPROVER_array_replace(const void *dest, const void *src)
__CPROVER_set_must
void __CPROVER_set_must(const void *, const char *)
__CPROVER_overflow_minus
__CPROVER_bool __CPROVER_overflow_minus()
__CPROVER_isfinited
__CPROVER_bool __CPROVER_isfinited(double f)
__CPROVER_POINTER_OFFSET
signed __CPROVER_POINTER_OFFSET(const void *p)
__CPROVER_is_zero_string
__CPROVER_bool __CPROVER_is_zero_string(const void *)
__CPROVER_r_ok
__CPROVER_bool __CPROVER_r_ok(const void *, __CPROVER_size_t)
__CPROVER_isgreaterd
int __CPROVER_isgreaterd(double f, double g)
__CPROVER_clear_may
void __CPROVER_clear_may(const void *, const char *)
__CPROVER_assert
void __CPROVER_assert(__CPROVER_bool assertion, const char *description)
__CPROVER_precondition
void __CPROVER_precondition(__CPROVER_bool assertion, const char *description)
__CPROVER_isinf
__CPROVER_bool __CPROVER_isinf(double f)
__CPROVER_fabsl
long double __CPROVER_fabsl(long double)
__CPROVER_POINTER_OBJECT
unsigned __CPROVER_POINTER_OBJECT(const void *p)
__CPROVER_input
void __CPROVER_input(const char *id,...)
__CPROVER_abs
int __CPROVER_abs(int)
__CPROVER_fabsf
float __CPROVER_fabsf(float)
__CPROVER_k_induction_hint
void __CPROVER_k_induction_hint(unsigned min, unsigned max, unsigned step, unsigned loop_free)
__CPROVER_cover
void __CPROVER_cover(__CPROVER_bool condition)
__CPROVER_postcondition
void __CPROVER_postcondition(__CPROVER_bool assertion, const char *description)
__CPROVER_pipet::next_avail
short next_avail
Definition: cprover.h:132
__CPROVER_isnanf
__CPROVER_bool __CPROVER_isnanf(float f)
__CPROVER_isfiniteld
__CPROVER_bool __CPROVER_isfiniteld(long double f)
__CPROVER_same_object
__CPROVER_bool __CPROVER_same_object(const void *, const void *)
__CPROVER_inf
double __CPROVER_inf(void)
__CPROVER_isnormalf
__CPROVER_bool __CPROVER_isnormalf(float f)
__CPROVER_fabs
double __CPROVER_fabs(double)
__CPROVER_isnormald
__CPROVER_bool __CPROVER_isnormald(double f)
__CPROVER_allocate
void * __CPROVER_allocate(__CPROVER_size_t size, __CPROVER_bool zero)
__CPROVER_zero_string_length
__CPROVER_size_t __CPROVER_zero_string_length(const void *)
__CPROVER_isnormalld
__CPROVER_bool __CPROVER_isnormalld(long double f)
__CPROVER_clear_must
void __CPROVER_clear_must(const void *, const char *)
__CPROVER_pipet
Definition: cprover.h:129
__CPROVER_array_set
void __CPROVER_array_set(const void *dest,...)
__CPROVER_isnormal
__CPROVER_bool __CPROVER_isnormal(double f)
__CPROVER_DYNAMIC_OBJECT
__CPROVER_bool __CPROVER_DYNAMIC_OBJECT(const void *p)
__CPROVER_signd
__CPROVER_bool __CPROVER_signd(double f)