1extern int __VERIFIER_nondet_int(void);
2extern int printf (__const char *__restrict __format, ...);
3
4
5
6#line 2 "libacc.c"
7struct JoinPoint {
8 void **(*fp)(struct JoinPoint * ) ;
9 void **args ;
10 int argsCount ;
11 char const **argsType ;
12 void *(*arg)(int , struct JoinPoint * ) ;
13 char const *(*argType)(int , struct JoinPoint * ) ;
14 void **retValue ;
15 char const *retType ;
16 char const *funcName ;
17 char const *targetName ;
18 char const *fileName ;
19 char const *kind ;
20 void *excep_return ;
21};
22#line 18 "libacc.c"
23struct __UTAC__CFLOW_FUNC {
24 int (*func)(int , int ) ;
25 int val ;
26 struct __UTAC__CFLOW_FUNC *next ;
27};
28#line 18 "libacc.c"
29struct __UTAC__EXCEPTION {
30 void *jumpbuf ;
31 unsigned long long prtValue ;
32 int pops ;
33 struct __UTAC__CFLOW_FUNC *cflowfuncs ;
34};
35#line 211 "/usr/lib/gcc/x86_64-linux-gnu/4.4.5/include/stddef.h"
36typedef unsigned long size_t;
37#line 76 "libacc.c"
38struct __ACC__ERR {
39 void *v ;
40 struct __ACC__ERR *next ;
41};
42#line 1 "libacc.o"
43#pragma merger(0,"libacc.i","")
44#line 73 "/usr/include/assert.h"
45extern __attribute__((__nothrow__, __noreturn__)) void __assert_fail(char const *__assertion ,
46 char const *__file ,
47 unsigned int __line ,
48 char const *__function ) ;
49#line 471 "/usr/include/stdlib.h"
50extern __attribute__((__nothrow__)) void *malloc(size_t __size ) __attribute__((__malloc__)) ;
51#line 488
52extern __attribute__((__nothrow__)) void free(void *__ptr ) ;
53#line 32 "libacc.c"
54void __utac__exception__cf_handler_set(void *exception , int (*cflow_func)(int ,
55 int ) ,
56 int val )
57{ struct __UTAC__EXCEPTION *excep ;
58 struct __UTAC__CFLOW_FUNC *cf ;
59 void *tmp ;
60 unsigned long __cil_tmp7 ;
61 unsigned long __cil_tmp8 ;
62 unsigned long __cil_tmp9 ;
63 unsigned long __cil_tmp10 ;
64 unsigned long __cil_tmp11 ;
65 unsigned long __cil_tmp12 ;
66 unsigned long __cil_tmp13 ;
67 unsigned long __cil_tmp14 ;
68 int (**mem_15)(int , int ) ;
69 int *mem_16 ;
70 struct __UTAC__CFLOW_FUNC **mem_17 ;
71 struct __UTAC__CFLOW_FUNC **mem_18 ;
72 struct __UTAC__CFLOW_FUNC **mem_19 ;
73
74 {
75 {
76#line 33
77 excep = (struct __UTAC__EXCEPTION *)exception;
78#line 34
79 tmp = malloc(24UL);
80#line 34
81 cf = (struct __UTAC__CFLOW_FUNC *)tmp;
82#line 36
83 mem_15 = (int (**)(int , int ))cf;
84#line 36
85 *mem_15 = cflow_func;
86#line 37
87 __cil_tmp7 = (unsigned long )cf;
88#line 37
89 __cil_tmp8 = __cil_tmp7 + 8;
90#line 37
91 mem_16 = (int *)__cil_tmp8;
92#line 37
93 *mem_16 = val;
94#line 38
95 __cil_tmp9 = (unsigned long )cf;
96#line 38
97 __cil_tmp10 = __cil_tmp9 + 16;
98#line 38
99 __cil_tmp11 = (unsigned long )excep;
100#line 38
101 __cil_tmp12 = __cil_tmp11 + 24;
102#line 38
103 mem_17 = (struct __UTAC__CFLOW_FUNC **)__cil_tmp10;
104#line 38
105 mem_18 = (struct __UTAC__CFLOW_FUNC **)__cil_tmp12;
106#line 38
107 *mem_17 = *mem_18;
108#line 39
109 __cil_tmp13 = (unsigned long )excep;
110#line 39
111 __cil_tmp14 = __cil_tmp13 + 24;
112#line 39
113 mem_19 = (struct __UTAC__CFLOW_FUNC **)__cil_tmp14;
114#line 39
115 *mem_19 = cf;
116 }
117#line 654 "libacc.c"
118 return;
119}
120}
121#line 44 "libacc.c"
122void __utac__exception__cf_handler_free(void *exception )
123{ struct __UTAC__EXCEPTION *excep ;
124 struct __UTAC__CFLOW_FUNC *cf ;
125 struct __UTAC__CFLOW_FUNC *tmp ;
126 unsigned long __cil_tmp5 ;
127 unsigned long __cil_tmp6 ;
128 struct __UTAC__CFLOW_FUNC *__cil_tmp7 ;
129 unsigned long __cil_tmp8 ;
130 unsigned long __cil_tmp9 ;
131 unsigned long __cil_tmp10 ;
132 unsigned long __cil_tmp11 ;
133 void *__cil_tmp12 ;
134 unsigned long __cil_tmp13 ;
135 unsigned long __cil_tmp14 ;
136 struct __UTAC__CFLOW_FUNC **mem_15 ;
137 struct __UTAC__CFLOW_FUNC **mem_16 ;
138 struct __UTAC__CFLOW_FUNC **mem_17 ;
139
140 {
141#line 45
142 excep = (struct __UTAC__EXCEPTION *)exception;
143#line 46
144 __cil_tmp5 = (unsigned long )excep;
145#line 46
146 __cil_tmp6 = __cil_tmp5 + 24;
147#line 46
148 mem_15 = (struct __UTAC__CFLOW_FUNC **)__cil_tmp6;
149#line 46
150 cf = *mem_15;
151 {
152#line 49
153 while (1) {
154 while_0_continue: ;
155 {
156#line 49
157 __cil_tmp7 = (struct __UTAC__CFLOW_FUNC *)0;
158#line 49
159 __cil_tmp8 = (unsigned long )__cil_tmp7;
160#line 49
161 __cil_tmp9 = (unsigned long )cf;
162#line 49
163 if (__cil_tmp9 != __cil_tmp8) {
164
165 } else {
166 goto while_0_break;
167 }
168 }
169 {
170#line 50
171 tmp = cf;
172#line 51
173 __cil_tmp10 = (unsigned long )cf;
174#line 51
175 __cil_tmp11 = __cil_tmp10 + 16;
176#line 51
177 mem_16 = (struct __UTAC__CFLOW_FUNC **)__cil_tmp11;
178#line 51
179 cf = *mem_16;
180#line 52
181 __cil_tmp12 = (void *)tmp;
182#line 52
183 free(__cil_tmp12);
184 }
185 }
186 while_0_break: ;
187 }
188#line 55
189 __cil_tmp13 = (unsigned long )excep;
190#line 55
191 __cil_tmp14 = __cil_tmp13 + 24;
192#line 55
193 mem_17 = (struct __UTAC__CFLOW_FUNC **)__cil_tmp14;
194#line 55
195 *mem_17 = (struct __UTAC__CFLOW_FUNC *)0;
196#line 694 "libacc.c"
197 return;
198}
199}
200#line 59 "libacc.c"
201void __utac__exception__cf_handler_reset(void *exception )
202{ struct __UTAC__EXCEPTION *excep ;
203 struct __UTAC__CFLOW_FUNC *cf ;
204 unsigned long __cil_tmp5 ;
205 unsigned long __cil_tmp6 ;
206 struct __UTAC__CFLOW_FUNC *__cil_tmp7 ;
207 unsigned long __cil_tmp8 ;
208 unsigned long __cil_tmp9 ;
209 int (*__cil_tmp10)(int , int ) ;
210 unsigned long __cil_tmp11 ;
211 unsigned long __cil_tmp12 ;
212 int __cil_tmp13 ;
213 unsigned long __cil_tmp14 ;
214 unsigned long __cil_tmp15 ;
215 struct __UTAC__CFLOW_FUNC **mem_16 ;
216 int (**mem_17)(int , int ) ;
217 int *mem_18 ;
218 struct __UTAC__CFLOW_FUNC **mem_19 ;
219
220 {
221#line 60
222 excep = (struct __UTAC__EXCEPTION *)exception;
223#line 61
224 __cil_tmp5 = (unsigned long )excep;
225#line 61
226 __cil_tmp6 = __cil_tmp5 + 24;
227#line 61
228 mem_16 = (struct __UTAC__CFLOW_FUNC **)__cil_tmp6;
229#line 61
230 cf = *mem_16;
231 {
232#line 64
233 while (1) {
234 while_1_continue: ;
235 {
236#line 64
237 __cil_tmp7 = (struct __UTAC__CFLOW_FUNC *)0;
238#line 64
239 __cil_tmp8 = (unsigned long )__cil_tmp7;
240#line 64
241 __cil_tmp9 = (unsigned long )cf;
242#line 64
243 if (__cil_tmp9 != __cil_tmp8) {
244
245 } else {
246 goto while_1_break;
247 }
248 }
249 {
250#line 65
251 mem_17 = (int (**)(int , int ))cf;
252#line 65
253 __cil_tmp10 = *mem_17;
254#line 65
255 __cil_tmp11 = (unsigned long )cf;
256#line 65
257 __cil_tmp12 = __cil_tmp11 + 8;
258#line 65
259 mem_18 = (int *)__cil_tmp12;
260#line 65
261 __cil_tmp13 = *mem_18;
262#line 65
263 (*__cil_tmp10)(4, __cil_tmp13);
264#line 66
265 __cil_tmp14 = (unsigned long )cf;
266#line 66
267 __cil_tmp15 = __cil_tmp14 + 16;
268#line 66
269 mem_19 = (struct __UTAC__CFLOW_FUNC **)__cil_tmp15;
270#line 66
271 cf = *mem_19;
272 }
273 }
274 while_1_break: ;
275 }
276 {
277#line 69
278 __utac__exception__cf_handler_free(exception);
279 }
280#line 732 "libacc.c"
281 return;
282}
283}
284#line 80 "libacc.c"
285void *__utac__error_stack_mgt(void *env , int mode , int count ) ;
286#line 80 "libacc.c"
287static struct __ACC__ERR *head = (struct __ACC__ERR *)0;
288#line 79 "libacc.c"
289void *__utac__error_stack_mgt(void *env , int mode , int count )
290{ void *retValue_acc ;
291 struct __ACC__ERR *new ;
292 void *tmp ;
293 struct __ACC__ERR *temp ;
294 struct __ACC__ERR *next ;
295 void *excep ;
296 unsigned long __cil_tmp10 ;
297 unsigned long __cil_tmp11 ;
298 unsigned long __cil_tmp12 ;
299 unsigned long __cil_tmp13 ;
300 void *__cil_tmp14 ;
301 unsigned long __cil_tmp15 ;
302 unsigned long __cil_tmp16 ;
303 void *__cil_tmp17 ;
304 void **mem_18 ;
305 struct __ACC__ERR **mem_19 ;
306 struct __ACC__ERR **mem_20 ;
307 void **mem_21 ;
308 struct __ACC__ERR **mem_22 ;
309 void **mem_23 ;
310 void **mem_24 ;
311
312 {
313#line 82 "libacc.c"
314 if (count == 0) {
315#line 758 "libacc.c"
316 return (retValue_acc);
317 } else {
318
319 }
320#line 86 "libacc.c"
321 if (mode == 0) {
322 {
323#line 87
324 tmp = malloc(16UL);
325#line 87
326 new = (struct __ACC__ERR *)tmp;
327#line 88
328 mem_18 = (void **)new;
329#line 88
330 *mem_18 = env;
331#line 89
332 __cil_tmp10 = (unsigned long )new;
333#line 89
334 __cil_tmp11 = __cil_tmp10 + 8;
335#line 89
336 mem_19 = (struct __ACC__ERR **)__cil_tmp11;
337#line 89
338 *mem_19 = head;
339#line 90
340 head = new;
341#line 776 "libacc.c"
342 retValue_acc = (void *)new;
343 }
344#line 778
345 return (retValue_acc);
346 } else {
347
348 }
349#line 94 "libacc.c"
350 if (mode == 1) {
351#line 95
352 temp = head;
353 {
354#line 98
355 while (1) {
356 while_2_continue: ;
357#line 98
358 if (count > 1) {
359
360 } else {
361 goto while_2_break;
362 }
363 {
364#line 99
365 __cil_tmp12 = (unsigned long )temp;
366#line 99
367 __cil_tmp13 = __cil_tmp12 + 8;
368#line 99
369 mem_20 = (struct __ACC__ERR **)__cil_tmp13;
370#line 99
371 next = *mem_20;
372#line 100
373 mem_21 = (void **)temp;
374#line 100
375 excep = *mem_21;
376#line 101
377 __cil_tmp14 = (void *)temp;
378#line 101
379 free(__cil_tmp14);
380#line 102
381 __utac__exception__cf_handler_reset(excep);
382#line 103
383 temp = next;
384#line 104
385 count = count - 1;
386 }
387 }
388 while_2_break: ;
389 }
390 {
391#line 107
392 __cil_tmp15 = (unsigned long )temp;
393#line 107
394 __cil_tmp16 = __cil_tmp15 + 8;
395#line 107
396 mem_22 = (struct __ACC__ERR **)__cil_tmp16;
397#line 107
398 head = *mem_22;
399#line 108
400 mem_23 = (void **)temp;
401#line 108
402 excep = *mem_23;
403#line 109
404 __cil_tmp17 = (void *)temp;
405#line 109
406 free(__cil_tmp17);
407#line 110
408 __utac__exception__cf_handler_reset(excep);
409#line 820 "libacc.c"
410 retValue_acc = excep;
411 }
412#line 822
413 return (retValue_acc);
414 } else {
415
416 }
417#line 114
418 if (mode == 2) {
419#line 118 "libacc.c"
420 if (head) {
421#line 831
422 mem_24 = (void **)head;
423#line 831
424 retValue_acc = *mem_24;
425#line 833
426 return (retValue_acc);
427 } else {
428#line 837 "libacc.c"
429 retValue_acc = (void *)0;
430#line 839
431 return (retValue_acc);
432 }
433 } else {
434
435 }
436#line 846 "libacc.c"
437 return (retValue_acc);
438}
439}
440#line 122 "libacc.c"
441void *__utac__get_this_arg(int i , struct JoinPoint *this )
442{ void *retValue_acc ;
443 unsigned long __cil_tmp4 ;
444 unsigned long __cil_tmp5 ;
445 int __cil_tmp6 ;
446 int __cil_tmp7 ;
447 unsigned long __cil_tmp8 ;
448 unsigned long __cil_tmp9 ;
449 void **__cil_tmp10 ;
450 void **__cil_tmp11 ;
451 int *mem_12 ;
452 void ***mem_13 ;
453
454 {
455#line 123
456 if (i > 0) {
457 {
458#line 123
459 __cil_tmp4 = (unsigned long )this;
460#line 123
461 __cil_tmp5 = __cil_tmp4 + 16;
462#line 123
463 mem_12 = (int *)__cil_tmp5;
464#line 123
465 __cil_tmp6 = *mem_12;
466#line 123
467 if (i <= __cil_tmp6) {
468
469 } else {
470 {
471#line 123
472 __assert_fail("i > 0 && i <= this->argsCount", "libacc.c",
473 123U, "__utac__get_this_arg");
474 }
475 }
476 }
477 } else {
478 {
479#line 123
480 __assert_fail("i > 0 && i <= this->argsCount", "libacc.c",
481 123U, "__utac__get_this_arg");
482 }
483 }
484#line 870 "libacc.c"
485 __cil_tmp7 = i - 1;
486#line 870
487 __cil_tmp8 = (unsigned long )this;
488#line 870
489 __cil_tmp9 = __cil_tmp8 + 8;
490#line 870
491 mem_13 = (void ***)__cil_tmp9;
492#line 870
493 __cil_tmp10 = *mem_13;
494#line 870
495 __cil_tmp11 = __cil_tmp10 + __cil_tmp7;
496#line 870
497 retValue_acc = *__cil_tmp11;
498#line 872
499 return (retValue_acc);
500#line 879
501 return (retValue_acc);
502}
503}
504#line 129 "libacc.c"
505char const *__utac__get_this_argtype(int i , struct JoinPoint *this )
506{ char const *retValue_acc ;
507 unsigned long __cil_tmp4 ;
508 unsigned long __cil_tmp5 ;
509 int __cil_tmp6 ;
510 int __cil_tmp7 ;
511 unsigned long __cil_tmp8 ;
512 unsigned long __cil_tmp9 ;
513 char const **__cil_tmp10 ;
514 char const **__cil_tmp11 ;
515 int *mem_12 ;
516 char const ***mem_13 ;
517
518 {
519#line 131
520 if (i > 0) {
521 {
522#line 131
523 __cil_tmp4 = (unsigned long )this;
524#line 131
525 __cil_tmp5 = __cil_tmp4 + 16;
526#line 131
527 mem_12 = (int *)__cil_tmp5;
528#line 131
529 __cil_tmp6 = *mem_12;
530#line 131
531 if (i <= __cil_tmp6) {
532
533 } else {
534 {
535#line 131
536 __assert_fail("i > 0 && i <= this->argsCount", "libacc.c",
537 131U, "__utac__get_this_argtype");
538 }
539 }
540 }
541 } else {
542 {
543#line 131
544 __assert_fail("i > 0 && i <= this->argsCount", "libacc.c",
545 131U, "__utac__get_this_argtype");
546 }
547 }
548#line 903 "libacc.c"
549 __cil_tmp7 = i - 1;
550#line 903
551 __cil_tmp8 = (unsigned long )this;
552#line 903
553 __cil_tmp9 = __cil_tmp8 + 24;
554#line 903
555 mem_13 = (char const ***)__cil_tmp9;
556#line 903
557 __cil_tmp10 = *mem_13;
558#line 903
559 __cil_tmp11 = __cil_tmp10 + __cil_tmp7;
560#line 903
561 retValue_acc = *__cil_tmp11;
562#line 905
563 return (retValue_acc);
564#line 912
565 return (retValue_acc);
566}
567}
568#line 1 "Specification4_spec.o"
569#pragma merger(0,"Specification4_spec.i","")
570#line 4 "wsllib.h"
571void __automaton_fail(void) ;
572#line 10 "MinePump.h"
573int isPumpRunning(void) ;
574#line 12 "Environment.h"
575int getWaterLevel(void) ;
576#line 11 "Specification4_spec.c"
577__inline void __utac_acc__Specification4_spec__1(void)
578{ int tmp ;
579 int tmp___0 ;
580
581 {
582 {
583#line 17
584 tmp = getWaterLevel();
585 }
586#line 17
587 if (tmp == 0) {
588 {
589#line 17
590 tmp___0 = isPumpRunning();
591 }
592#line 17
593 if (tmp___0) {
594 {
595#line 14
596 __automaton_fail();
597 }
598 } else {
599
600 }
601 } else {
602
603 }
604#line 14
605 return;
606}
607}
608#line 1 "wsllib_check.o"
609#pragma merger(0,"wsllib_check.i","")
610#line 3 "wsllib_check.c"
611void __automaton_fail(void)
612{
613
614 {
615 goto ERROR;
616 ERROR: ;
617#line 53 "wsllib_check.c"
618 return;
619}
620}
621#line 1 "Environment.o"
622#pragma merger(0,"Environment.i","")
623#line 4 "Environment.h"
624void lowerWaterLevel(void) ;
625#line 6
626void waterRise(void) ;
627#line 8
628void changeMethaneLevel(void) ;
629#line 10
630int isMethaneLevelCritical(void) ;
631#line 15
632void printEnvironment(void) ;
633#line 16
634int isHighWaterSensorDry(void) ;
635#line 17
636int isLowWaterSensorDry(void) ;
637#line 9 "Environment.c"
638int waterLevel = 1;
639#line 12 "Environment.c"
640int methaneLevelCritical = 0;
641#line 15 "Environment.c"
642void lowerWaterLevel(void)
643{
644
645 {
646#line 19
647 if (waterLevel > 0) {
648#line 17
649 waterLevel = waterLevel - 1;
650 } else {
651
652 }
653#line 85 "Environment.c"
654 return;
655}
656}
657#line 22 "Environment.c"
658void waterRise(void)
659{
660
661 {
662#line 26
663 if (waterLevel < 2) {
664#line 24
665 waterLevel = waterLevel + 1;
666 } else {
667
668 }
669#line 108 "Environment.c"
670 return;
671}
672}
673#line 29 "Environment.c"
674void changeMethaneLevel(void)
675{
676
677 {
678#line 34
679 if (methaneLevelCritical) {
680#line 31
681 methaneLevelCritical = 0;
682 } else {
683#line 33
684 methaneLevelCritical = 1;
685 }
686#line 134 "Environment.c"
687 return;
688}
689}
690#line 38 "Environment.c"
691int isMethaneLevelCritical(void)
692{ int retValue_acc ;
693
694 {
695#line 152 "Environment.c"
696 retValue_acc = methaneLevelCritical;
697#line 154
698 return (retValue_acc);
699#line 161
700 return (retValue_acc);
701}
702}
703#line 45 "Environment.c"
704#line 44 "Environment.c"
705void printEnvironment(void)
706{
707
708 {
709 {
710#line 45
711 printf("Env(Water:%i", waterLevel);
712#line 46
713 printf(",Meth:");
714 }
715#line 47
716 if (methaneLevelCritical) {
717 {
718#line 48
719 printf("CRIT");
720 }
721 } else {
722 {
723#line 49
724 printf("OK");
725 }
726 }
727 {
728#line 51
729 printf(")");
730 }
731#line 193 "Environment.c"
732 return;
733}
734}
735#line 55 "Environment.c"
736int getWaterLevel(void)
737{ int retValue_acc ;
738
739 {
740#line 211 "Environment.c"
741 retValue_acc = waterLevel;
742#line 213
743 return (retValue_acc);
744#line 220
745 return (retValue_acc);
746}
747}
748#line 58 "Environment.c"
749int isHighWaterSensorDry(void)
750{ int retValue_acc ;
751
752 {
753#line 65 "Environment.c"
754 if (waterLevel < 2) {
755#line 245
756 retValue_acc = 1;
757#line 247
758 return (retValue_acc);
759 } else {
760#line 253 "Environment.c"
761 retValue_acc = 0;
762#line 255
763 return (retValue_acc);
764 }
765#line 262 "Environment.c"
766 return (retValue_acc);
767}
768}
769#line 67 "Environment.c"
770int isLowWaterSensorDry(void)
771{ int retValue_acc ;
772
773 {
774#line 284 "Environment.c"
775 retValue_acc = waterLevel == 0;
776#line 286
777 return (retValue_acc);
778#line 293
779 return (retValue_acc);
780}
781}
782#line 1 "Test.o"
783#pragma merger(0,"Test.i","")
784#line 8 "Test.c"
785int cleanupTimeShifts = 4;
786#line 11 "Test.c"
787#line 20 "Test.c"
788void timeShift(void) ;
789#line 17 "Test.c"
790void cleanup(void)
791{ int i ;
792 int __cil_tmp2 ;
793
794 {
795 {
796#line 20
797 timeShift();
798#line 22
799 i = 0;
800 }
801 {
802#line 22
803 while (1) {
804 while_3_continue: ;
805 {
806#line 22
807 __cil_tmp2 = cleanupTimeShifts - 1;
808#line 22
809 if (i < __cil_tmp2) {
810
811 } else {
812 goto while_3_break;
813 }
814 }
815 {
816#line 23
817 timeShift();
818#line 22
819 i = i + 1;
820 }
821 }
822 while_3_break: ;
823 }
824#line 1111 "Test.c"
825 return;
826}
827}
828#line 57 "Test.c"
829void printPump(void) ;
830#line 56 "Test.c"
831void Specification2(void)
832{
833
834 {
835 {
836#line 57
837 timeShift();
838#line 57
839 printPump();
840#line 58
841 timeShift();
842#line 58
843 printPump();
844#line 59
845 timeShift();
846#line 59
847 printPump();
848#line 60
849 waterRise();
850#line 60
851 printPump();
852#line 61
853 timeShift();
854#line 61
855 printPump();
856#line 62
857 changeMethaneLevel();
858#line 62
859 printPump();
860#line 63
861 timeShift();
862#line 63
863 printPump();
864#line 64
865 cleanup();
866 }
867#line 1159 "Test.c"
868 return;
869}
870}
871#line 67 "Test.c"
872void setup(void)
873{
874
875 {
876#line 1177 "Test.c"
877 return;
878}
879}
880#line 77 "Test.c"
881void test(void) ;
882#line 74 "Test.c"
883void runTest(void)
884{
885
886 {
887 {
888#line 77
889 test();
890 }
891#line 1197 "Test.c"
892 return;
893}
894}
895#line 83 "Test.c"
896void select_helpers(void) ;
897#line 84
898void select_features(void) ;
899#line 85
900int valid_product(void) ;
901#line 82 "Test.c"
902int main(void)
903{ int retValue_acc ;
904 int tmp ;
905
906 {
907 {
908#line 83
909 select_helpers();
910#line 84
911 select_features();
912#line 85
913 tmp = valid_product();
914 }
915#line 85
916 if (tmp) {
917 {
918#line 86
919 setup();
920#line 87
921 runTest();
922 }
923 } else {
924
925 }
926#line 1226 "Test.c"
927 retValue_acc = 0;
928#line 1228
929 return (retValue_acc);
930#line 1235
931 return (retValue_acc);
932}
933}
934#line 1 "featureselect.o"
935#pragma merger(0,"featureselect.i","")
936#line 8 "featureselect.h"
937int select_one(void) ;
938#line 8 "featureselect.c"
939int select_one(void)
940{ int retValue_acc ;
941 int choice = __VERIFIER_nondet_int();
942
943 {
944#line 62 "featureselect.c"
945 retValue_acc = choice;
946#line 64
947 return (retValue_acc);
948#line 71
949 return (retValue_acc);
950}
951}
952#line 14 "featureselect.c"
953void select_features(void)
954{
955
956 {
957#line 93 "featureselect.c"
958 return;
959}
960}
961#line 20 "featureselect.c"
962void select_helpers(void)
963{
964
965 {
966#line 111 "featureselect.c"
967 return;
968}
969}
970#line 25 "featureselect.c"
971int valid_product(void)
972{ int retValue_acc ;
973
974 {
975#line 129 "featureselect.c"
976 retValue_acc = 1;
977#line 131
978 return (retValue_acc);
979#line 138
980 return (retValue_acc);
981}
982}
983#line 1 "MinePump.o"
984#pragma merger(0,"MinePump.i","")
985#line 6 "MinePump.h"
986void activatePump(void) ;
987#line 8
988void deactivatePump(void) ;
989#line 14
990void startSystem(void) ;
991#line 7 "MinePump.c"
992int pumpRunning = 0;
993#line 9 "MinePump.c"
994int systemActive = 1;
995#line 16
996void processEnvironment(void) ;
997#line 12 "MinePump.c"
998void timeShift(void)
999{
1000
1001 {
1002#line 15
1003 if (pumpRunning) {
1004 {
1005#line 16
1006 lowerWaterLevel();
1007 }
1008 } else {
1009
1010 }
1011#line 15
1012 if (systemActive) {
1013 {
1014#line 16
1015 processEnvironment();
1016 }
1017 } else {
1018
1019 }
1020 {
1021#line 101 "MinePump.c"
1022 __utac_acc__Specification4_spec__1();
1023 }
1024#line 107
1025 return;
1026}
1027}
1028#line 19 "MinePump.c"
1029void processEnvironment__wrappee__base(void)
1030{
1031
1032 {
1033#line 125 "MinePump.c"
1034 return;
1035}
1036}
1037#line 28 "MinePump.c"
1038int isHighWaterLevel(void) ;
1039#line 23 "MinePump.c"
1040void processEnvironment__wrappee__highWaterSensor(void)
1041{ int tmp ;
1042
1043 {
1044#line 28
1045 if (! pumpRunning) {
1046 {
1047#line 28
1048 tmp = isHighWaterLevel();
1049 }
1050#line 28
1051 if (tmp) {
1052 {
1053#line 25
1054 activatePump();
1055 }
1056 } else {
1057 {
1058#line 27
1059 processEnvironment__wrappee__base();
1060 }
1061 }
1062 } else {
1063 {
1064#line 27
1065 processEnvironment__wrappee__base();
1066 }
1067 }
1068#line 151 "MinePump.c"
1069 return;
1070}
1071}
1072#line 36 "MinePump.c"
1073int isLowWaterLevel(void) ;
1074#line 31 "MinePump.c"
1075void processEnvironment(void)
1076{ int tmp ;
1077
1078 {
1079#line 36
1080 if (pumpRunning) {
1081 {
1082#line 36
1083 tmp = isLowWaterLevel();
1084 }
1085#line 36
1086 if (tmp) {
1087 {
1088#line 33
1089 deactivatePump();
1090 }
1091 } else {
1092 {
1093#line 35
1094 processEnvironment__wrappee__highWaterSensor();
1095 }
1096 }
1097 } else {
1098 {
1099#line 35
1100 processEnvironment__wrappee__highWaterSensor();
1101 }
1102 }
1103#line 177 "MinePump.c"
1104 return;
1105}
1106}
1107#line 40 "MinePump.c"
1108void activatePump__wrappee__lowWaterSensor(void)
1109{
1110
1111 {
1112#line 41
1113 pumpRunning = 1;
1114#line 197 "MinePump.c"
1115 return;
1116}
1117}
1118#line 48 "MinePump.c"
1119int isMethaneAlarm(void) ;
1120#line 43 "MinePump.c"
1121void activatePump(void)
1122{ int tmp ;
1123
1124 {
1125 {
1126#line 48
1127 tmp = isMethaneAlarm();
1128 }
1129#line 48
1130 if (tmp) {
1131
1132 } else {
1133 {
1134#line 45
1135 activatePump__wrappee__lowWaterSensor();
1136 }
1137 }
1138#line 221 "MinePump.c"
1139 return;
1140}
1141}
1142#line 52 "MinePump.c"
1143void deactivatePump(void)
1144{
1145
1146 {
1147#line 53
1148 pumpRunning = 0;
1149#line 241 "MinePump.c"
1150 return;
1151}
1152}
1153#line 57 "MinePump.c"
1154int isMethaneAlarm(void)
1155{ int retValue_acc ;
1156
1157 {
1158 {
1159#line 259 "MinePump.c"
1160 retValue_acc = isMethaneLevelCritical();
1161 }
1162#line 261
1163 return (retValue_acc);
1164#line 268
1165 return (retValue_acc);
1166}
1167}
1168#line 62 "MinePump.c"
1169int isPumpRunning(void)
1170{ int retValue_acc ;
1171
1172 {
1173#line 290 "MinePump.c"
1174 retValue_acc = pumpRunning;
1175#line 292
1176 return (retValue_acc);
1177#line 299
1178 return (retValue_acc);
1179}
1180}
1181#line 67 "MinePump.c"
1182void printPump(void)
1183{
1184
1185 {
1186 {
1187#line 68
1188 printf("Pump(System:");
1189 }
1190#line 69
1191 if (systemActive) {
1192 {
1193#line 70
1194 printf("On");
1195 }
1196 } else {
1197 {
1198#line 71
1199 printf("Off");
1200 }
1201 }
1202 {
1203#line 73
1204 printf(",Pump:");
1205 }
1206#line 74
1207 if (pumpRunning) {
1208 {
1209#line 75
1210 printf("On");
1211 }
1212 } else {
1213 {
1214#line 76
1215 printf("Off");
1216 }
1217 }
1218 {
1219#line 78
1220 printf(") ");
1221#line 79
1222 printEnvironment();
1223#line 80
1224 printf("\n");
1225 }
1226#line 339 "MinePump.c"
1227 return;
1228}
1229}
1230#line 82 "MinePump.c"
1231int isHighWaterLevel(void)
1232{ int retValue_acc ;
1233 int tmp ;
1234 int tmp___0 ;
1235
1236 {
1237 {
1238#line 357 "MinePump.c"
1239 tmp = isHighWaterSensorDry();
1240 }
1241#line 357
1242 if (tmp) {
1243#line 357
1244 tmp___0 = 0;
1245 } else {
1246#line 357
1247 tmp___0 = 1;
1248 }
1249#line 357
1250 retValue_acc = tmp___0;
1251#line 359
1252 return (retValue_acc);
1253#line 366
1254 return (retValue_acc);
1255}
1256}
1257#line 85 "MinePump.c"
1258int isLowWaterLevel(void)
1259{ int retValue_acc ;
1260 int tmp ;
1261 int tmp___0 ;
1262
1263 {
1264 {
1265#line 388 "MinePump.c"
1266 tmp = isLowWaterSensorDry();
1267 }
1268#line 388
1269 if (tmp) {
1270#line 388
1271 tmp___0 = 0;
1272 } else {
1273#line 388
1274 tmp___0 = 1;
1275 }
1276#line 388
1277 retValue_acc = tmp___0;
1278#line 390
1279 return (retValue_acc);
1280#line 397
1281 return (retValue_acc);
1282}
1283}
1284#line 88 "MinePump.c"
1285void startSystem(void)
1286{
1287
1288 {
1289#line 90
1290 systemActive = 1;
1291#line 421 "MinePump.c"
1292 return;
1293}
1294}
1295#line 1 "scenario.o"
1296#pragma merger(0,"scenario.i","")
1297#line 1 "scenario.c"
1298void test(void)
1299{ int splverifierCounter ;
1300 int tmp ;
1301 int tmp___0 ;
1302 int tmp___1 ;
1303 int tmp___2 ;
1304
1305 {
1306#line 2
1307 splverifierCounter = 0;
1308 {
1309#line 3
1310 while (1) {
1311 while_4_continue: ;
1312#line 3
1313 if (splverifierCounter < 4) {
1314
1315 } else {
1316 goto while_4_break;
1317 }
1318 {
1319#line 7
1320 tmp = __VERIFIER_nondet_int();
1321 }
1322#line 7
1323 if (tmp) {
1324 {
1325#line 5
1326 waterRise();
1327 }
1328 } else {
1329
1330 }
1331 {
1332#line 7
1333 tmp___0 = __VERIFIER_nondet_int();
1334 }
1335#line 7
1336 if (tmp___0) {
1337 {
1338#line 8
1339 changeMethaneLevel();
1340 }
1341 } else {
1342
1343 }
1344 {
1345#line 10
1346 tmp___2 = __VERIFIER_nondet_int();
1347 }
1348#line 10
1349 if (tmp___2) {
1350 {
1351#line 11
1352 startSystem();
1353 }
1354 } else {
1355 {
1356#line 12
1357 tmp___1 = __VERIFIER_nondet_int();
1358 }
1359#line 12
1360 if (tmp___1) {
1361
1362 } else {
1363
1364 }
1365 }
1366 {
1367#line 14
1368 timeShift();
1369 }
1370 }
1371 while_4_break: ;
1372 }
1373 {
1374#line 16
1375 cleanup();
1376 }
1377#line 76 "scenario.c"
1378 return;
1379}
1380}