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 "wsllib_check.o"
569#pragma merger(0,"wsllib_check.i","")
570#line 3 "wsllib_check.c"
571void __automaton_fail(void)
572{
573
574 {
575 goto ERROR;
576 ERROR: ;
577#line 53 "wsllib_check.c"
578 return;
579}
580}
581#line 1 "Environment.o"
582#pragma merger(0,"Environment.i","")
583#line 4 "Environment.h"
584void lowerWaterLevel(void) ;
585#line 6
586void waterRise(void) ;
587#line 8
588void changeMethaneLevel(void) ;
589#line 10
590int isMethaneLevelCritical(void) ;
591#line 12
592int getWaterLevel(void) ;
593#line 15
594void printEnvironment(void) ;
595#line 16
596int isHighWaterSensorDry(void) ;
597#line 17
598int isLowWaterSensorDry(void) ;
599#line 9 "Environment.c"
600int waterLevel = 1;
601#line 12 "Environment.c"
602int methaneLevelCritical = 0;
603#line 15 "Environment.c"
604void lowerWaterLevel(void)
605{
606
607 {
608#line 19
609 if (waterLevel > 0) {
610#line 17
611 waterLevel = waterLevel - 1;
612 } else {
613
614 }
615#line 85 "Environment.c"
616 return;
617}
618}
619#line 22 "Environment.c"
620void waterRise(void)
621{
622
623 {
624#line 26
625 if (waterLevel < 2) {
626#line 24
627 waterLevel = waterLevel + 1;
628 } else {
629
630 }
631#line 108 "Environment.c"
632 return;
633}
634}
635#line 29 "Environment.c"
636void changeMethaneLevel(void)
637{
638
639 {
640#line 34
641 if (methaneLevelCritical) {
642#line 31
643 methaneLevelCritical = 0;
644 } else {
645#line 33
646 methaneLevelCritical = 1;
647 }
648#line 134 "Environment.c"
649 return;
650}
651}
652#line 38 "Environment.c"
653int isMethaneLevelCritical(void)
654{ int retValue_acc ;
655
656 {
657#line 152 "Environment.c"
658 retValue_acc = methaneLevelCritical;
659#line 154
660 return (retValue_acc);
661#line 161
662 return (retValue_acc);
663}
664}
665#line 45 "Environment.c"
666#line 44 "Environment.c"
667void printEnvironment(void)
668{
669
670 {
671 {
672#line 45
673 printf("Env(Water:%i", waterLevel);
674#line 46
675 printf(",Meth:");
676 }
677#line 47
678 if (methaneLevelCritical) {
679 {
680#line 48
681 printf("CRIT");
682 }
683 } else {
684 {
685#line 49
686 printf("OK");
687 }
688 }
689 {
690#line 51
691 printf(")");
692 }
693#line 193 "Environment.c"
694 return;
695}
696}
697#line 55 "Environment.c"
698int getWaterLevel(void)
699{ int retValue_acc ;
700
701 {
702#line 211 "Environment.c"
703 retValue_acc = waterLevel;
704#line 213
705 return (retValue_acc);
706#line 220
707 return (retValue_acc);
708}
709}
710#line 58 "Environment.c"
711int isHighWaterSensorDry(void)
712{ int retValue_acc ;
713
714 {
715#line 65 "Environment.c"
716 if (waterLevel < 2) {
717#line 245
718 retValue_acc = 1;
719#line 247
720 return (retValue_acc);
721 } else {
722#line 253 "Environment.c"
723 retValue_acc = 0;
724#line 255
725 return (retValue_acc);
726 }
727#line 262 "Environment.c"
728 return (retValue_acc);
729}
730}
731#line 67 "Environment.c"
732int isLowWaterSensorDry(void)
733{ int retValue_acc ;
734
735 {
736#line 284 "Environment.c"
737 retValue_acc = waterLevel == 0;
738#line 286
739 return (retValue_acc);
740#line 293
741 return (retValue_acc);
742}
743}
744#line 1 "Specification2_spec.o"
745#pragma merger(0,"Specification2_spec.i","")
746#line 10 "MinePump.h"
747int isPumpRunning(void) ;
748#line 7 "Specification2_spec.c"
749int methAndRunningLastTime ;
750#line 11 "Specification2_spec.c"
751__inline void __utac_acc__Specification2_spec__1(void)
752{
753
754 {
755#line 13
756 methAndRunningLastTime = 0;
757#line 13
758 return;
759}
760}
761#line 17 "Specification2_spec.c"
762__inline void __utac_acc__Specification2_spec__2(void)
763{ int tmp ;
764 int tmp___0 ;
765
766 {
767 {
768#line 27
769 tmp = isMethaneLevelCritical();
770 }
771#line 27
772 if (tmp) {
773 {
774#line 27
775 tmp___0 = isPumpRunning();
776 }
777#line 27
778 if (tmp___0) {
779#line 24
780 if (methAndRunningLastTime) {
781 {
782#line 21
783 __automaton_fail();
784 }
785 } else {
786#line 23
787 methAndRunningLastTime = 1;
788 }
789 } else {
790#line 26
791 methAndRunningLastTime = 0;
792 }
793 } else {
794#line 26
795 methAndRunningLastTime = 0;
796 }
797#line 26
798 return;
799}
800}
801#line 1 "MinePump.o"
802#pragma merger(0,"MinePump.i","")
803#line 4 "MinePump.h"
804void timeShift(void) ;
805#line 6
806void activatePump(void) ;
807#line 8
808void deactivatePump(void) ;
809#line 13
810void printPump(void) ;
811#line 14
812void stopSystem(void) ;
813#line 15
814void startSystem(void) ;
815#line 7 "MinePump.c"
816int pumpRunning = 0;
817#line 9 "MinePump.c"
818int systemActive = 1;
819#line 16
820void processEnvironment(void) ;
821#line 12 "MinePump.c"
822void timeShift(void)
823{
824
825 {
826#line 15
827 if (pumpRunning) {
828 {
829#line 16
830 lowerWaterLevel();
831 }
832 } else {
833
834 }
835#line 15
836 if (systemActive) {
837 {
838#line 16
839 processEnvironment();
840 }
841 } else {
842
843 }
844 {
845#line 103 "MinePump.c"
846 __utac_acc__Specification2_spec__2();
847 }
848#line 109
849 return;
850}
851}
852#line 19 "MinePump.c"
853void processEnvironment__wrappee__base(void)
854{
855
856 {
857#line 127 "MinePump.c"
858 return;
859}
860}
861#line 28 "MinePump.c"
862int isHighWaterLevel(void) ;
863#line 23 "MinePump.c"
864void processEnvironment__wrappee__highWaterSensor(void)
865{ int tmp ;
866
867 {
868#line 28
869 if (! pumpRunning) {
870 {
871#line 28
872 tmp = isHighWaterLevel();
873 }
874#line 28
875 if (tmp) {
876 {
877#line 25
878 activatePump();
879 }
880 } else {
881 {
882#line 27
883 processEnvironment__wrappee__base();
884 }
885 }
886 } else {
887 {
888#line 27
889 processEnvironment__wrappee__base();
890 }
891 }
892#line 153 "MinePump.c"
893 return;
894}
895}
896#line 36 "MinePump.c"
897int isLowWaterLevel(void) ;
898#line 31 "MinePump.c"
899void processEnvironment__wrappee__lowWaterSensor(void)
900{ int tmp ;
901
902 {
903#line 36
904 if (pumpRunning) {
905 {
906#line 36
907 tmp = isLowWaterLevel();
908 }
909#line 36
910 if (tmp) {
911 {
912#line 33
913 deactivatePump();
914 }
915 } else {
916 {
917#line 35
918 processEnvironment__wrappee__highWaterSensor();
919 }
920 }
921 } else {
922 {
923#line 35
924 processEnvironment__wrappee__highWaterSensor();
925 }
926 }
927#line 179 "MinePump.c"
928 return;
929}
930}
931#line 43 "MinePump.c"
932int isMethaneAlarm(void) ;
933#line 38 "MinePump.c"
934void processEnvironment(void)
935{ int tmp ;
936
937 {
938#line 43
939 if (pumpRunning) {
940 {
941#line 43
942 tmp = isMethaneAlarm();
943 }
944#line 43
945 if (tmp) {
946 {
947#line 40
948 deactivatePump();
949 }
950 } else {
951 {
952#line 42
953 processEnvironment__wrappee__lowWaterSensor();
954 }
955 }
956 } else {
957 {
958#line 42
959 processEnvironment__wrappee__lowWaterSensor();
960 }
961 }
962#line 205 "MinePump.c"
963 return;
964}
965}
966#line 47 "MinePump.c"
967void activatePump(void)
968{
969
970 {
971#line 48
972 pumpRunning = 1;
973#line 225 "MinePump.c"
974 return;
975}
976}
977#line 52 "MinePump.c"
978void deactivatePump(void)
979{
980
981 {
982#line 53
983 pumpRunning = 0;
984#line 245 "MinePump.c"
985 return;
986}
987}
988#line 57 "MinePump.c"
989int isMethaneAlarm(void)
990{ int retValue_acc ;
991
992 {
993 {
994#line 263 "MinePump.c"
995 retValue_acc = isMethaneLevelCritical();
996 }
997#line 265
998 return (retValue_acc);
999#line 272
1000 return (retValue_acc);
1001}
1002}
1003#line 62 "MinePump.c"
1004int isPumpRunning(void)
1005{ int retValue_acc ;
1006
1007 {
1008#line 294 "MinePump.c"
1009 retValue_acc = pumpRunning;
1010#line 296
1011 return (retValue_acc);
1012#line 303
1013 return (retValue_acc);
1014}
1015}
1016#line 67 "MinePump.c"
1017void printPump(void)
1018{
1019
1020 {
1021 {
1022#line 68
1023 printf("Pump(System:");
1024 }
1025#line 69
1026 if (systemActive) {
1027 {
1028#line 70
1029 printf("On");
1030 }
1031 } else {
1032 {
1033#line 71
1034 printf("Off");
1035 }
1036 }
1037 {
1038#line 73
1039 printf(",Pump:");
1040 }
1041#line 74
1042 if (pumpRunning) {
1043 {
1044#line 75
1045 printf("On");
1046 }
1047 } else {
1048 {
1049#line 76
1050 printf("Off");
1051 }
1052 }
1053 {
1054#line 78
1055 printf(") ");
1056#line 79
1057 printEnvironment();
1058#line 80
1059 printf("\n");
1060 }
1061#line 343 "MinePump.c"
1062 return;
1063}
1064}
1065#line 82 "MinePump.c"
1066int isHighWaterLevel(void)
1067{ int retValue_acc ;
1068 int tmp ;
1069 int tmp___0 ;
1070
1071 {
1072 {
1073#line 361 "MinePump.c"
1074 tmp = isHighWaterSensorDry();
1075 }
1076#line 361
1077 if (tmp) {
1078#line 361
1079 tmp___0 = 0;
1080 } else {
1081#line 361
1082 tmp___0 = 1;
1083 }
1084#line 361
1085 retValue_acc = tmp___0;
1086#line 363
1087 return (retValue_acc);
1088#line 370
1089 return (retValue_acc);
1090}
1091}
1092#line 85 "MinePump.c"
1093int isLowWaterLevel(void)
1094{ int retValue_acc ;
1095 int tmp ;
1096 int tmp___0 ;
1097
1098 {
1099 {
1100#line 392 "MinePump.c"
1101 tmp = isLowWaterSensorDry();
1102 }
1103#line 392
1104 if (tmp) {
1105#line 392
1106 tmp___0 = 0;
1107 } else {
1108#line 392
1109 tmp___0 = 1;
1110 }
1111#line 392
1112 retValue_acc = tmp___0;
1113#line 394
1114 return (retValue_acc);
1115#line 401
1116 return (retValue_acc);
1117}
1118}
1119#line 88 "MinePump.c"
1120void stopSystem(void)
1121{
1122
1123 {
1124#line 93
1125 if (pumpRunning) {
1126 {
1127#line 90
1128 deactivatePump();
1129 }
1130 } else {
1131
1132 }
1133#line 93
1134 systemActive = 0;
1135#line 430 "MinePump.c"
1136 return;
1137}
1138}
1139#line 95 "MinePump.c"
1140void startSystem(void)
1141{
1142
1143 {
1144#line 97
1145 systemActive = 1;
1146#line 450 "MinePump.c"
1147 return;
1148}
1149}
1150#line 1 "scenario.o"
1151#pragma merger(0,"scenario.i","")
1152#line 7 "scenario.c"
1153#line 17
1154void cleanup(void) ;
1155#line 1 "scenario.c"
1156void test(void)
1157{ int splverifierCounter ;
1158 int tmp ;
1159 int tmp___0 ;
1160 int tmp___1 ;
1161 int tmp___2 ;
1162
1163 {
1164#line 2
1165 splverifierCounter = 0;
1166 {
1167#line 3
1168 while (1) {
1169 while_3_continue: ;
1170#line 3
1171 if (splverifierCounter < 4) {
1172
1173 } else {
1174 goto while_3_break;
1175 }
1176 {
1177#line 7
1178 tmp = __VERIFIER_nondet_int();
1179 }
1180#line 7
1181 if (tmp) {
1182 {
1183#line 5
1184 waterRise();
1185 }
1186 } else {
1187
1188 }
1189 {
1190#line 7
1191 tmp___0 = __VERIFIER_nondet_int();
1192 }
1193#line 7
1194 if (tmp___0) {
1195 {
1196#line 8
1197 changeMethaneLevel();
1198 }
1199 } else {
1200
1201 }
1202 {
1203#line 10
1204 tmp___2 = __VERIFIER_nondet_int();
1205 }
1206#line 10
1207 if (tmp___2) {
1208 {
1209#line 11
1210 startSystem();
1211 }
1212 } else {
1213 {
1214#line 12
1215 tmp___1 = __VERIFIER_nondet_int();
1216 }
1217#line 12
1218 if (tmp___1) {
1219 {
1220#line 13
1221 stopSystem();
1222 }
1223 } else {
1224
1225 }
1226 }
1227 {
1228#line 15
1229 timeShift();
1230 }
1231 }
1232 while_3_break: ;
1233 }
1234 {
1235#line 17
1236 cleanup();
1237 }
1238#line 78 "scenario.c"
1239 return;
1240}
1241}
1242#line 1 "featureselect.o"
1243#pragma merger(0,"featureselect.i","")
1244#line 8 "featureselect.h"
1245int select_one(void) ;
1246#line 10
1247void select_features(void) ;
1248#line 12
1249void select_helpers(void) ;
1250#line 14
1251int valid_product(void) ;
1252#line 8 "featureselect.c"
1253int select_one(void)
1254{ int retValue_acc ;
1255 int choice = __VERIFIER_nondet_int();
1256
1257 {
1258#line 62 "featureselect.c"
1259 retValue_acc = choice;
1260#line 64
1261 return (retValue_acc);
1262#line 71
1263 return (retValue_acc);
1264}
1265}
1266#line 14 "featureselect.c"
1267void select_features(void)
1268{
1269
1270 {
1271#line 93 "featureselect.c"
1272 return;
1273}
1274}
1275#line 20 "featureselect.c"
1276void select_helpers(void)
1277{
1278
1279 {
1280#line 111 "featureselect.c"
1281 return;
1282}
1283}
1284#line 25 "featureselect.c"
1285int valid_product(void)
1286{ int retValue_acc ;
1287
1288 {
1289#line 129 "featureselect.c"
1290 retValue_acc = 1;
1291#line 131
1292 return (retValue_acc);
1293#line 138
1294 return (retValue_acc);
1295}
1296}
1297#line 1 "Test.o"
1298#pragma merger(0,"Test.i","")
1299#line 8 "Test.c"
1300int cleanupTimeShifts = 4;
1301#line 11 "Test.c"
1302#line 17 "Test.c"
1303void cleanup(void)
1304{ int i ;
1305 int __cil_tmp2 ;
1306
1307 {
1308 {
1309#line 20
1310 timeShift();
1311#line 22
1312 i = 0;
1313 }
1314 {
1315#line 22
1316 while (1) {
1317 while_4_continue: ;
1318 {
1319#line 22
1320 __cil_tmp2 = cleanupTimeShifts - 1;
1321#line 22
1322 if (i < __cil_tmp2) {
1323
1324 } else {
1325 goto while_4_break;
1326 }
1327 }
1328 {
1329#line 23
1330 timeShift();
1331#line 22
1332 i = i + 1;
1333 }
1334 }
1335 while_4_break: ;
1336 }
1337#line 1111 "Test.c"
1338 return;
1339}
1340}
1341#line 56 "Test.c"
1342void Specification2(void)
1343{
1344
1345 {
1346 {
1347#line 57
1348 timeShift();
1349#line 57
1350 printPump();
1351#line 58
1352 timeShift();
1353#line 58
1354 printPump();
1355#line 59
1356 timeShift();
1357#line 59
1358 printPump();
1359#line 60
1360 waterRise();
1361#line 60
1362 printPump();
1363#line 61
1364 timeShift();
1365#line 61
1366 printPump();
1367#line 62
1368 changeMethaneLevel();
1369#line 62
1370 printPump();
1371#line 63
1372 timeShift();
1373#line 63
1374 printPump();
1375#line 64
1376 cleanup();
1377 }
1378#line 1159 "Test.c"
1379 return;
1380}
1381}
1382#line 67 "Test.c"
1383void setup(void)
1384{
1385
1386 {
1387#line 1177 "Test.c"
1388 return;
1389}
1390}
1391#line 74 "Test.c"
1392void runTest(void)
1393{
1394
1395 {
1396 {
1397#line 1190 "Test.c"
1398 __utac_acc__Specification2_spec__1();
1399#line 77 "Test.c"
1400 test();
1401 }
1402#line 1205 "Test.c"
1403 return;
1404}
1405}
1406#line 82 "Test.c"
1407int main(void)
1408{ int retValue_acc ;
1409 int tmp ;
1410
1411 {
1412 {
1413#line 83
1414 select_helpers();
1415#line 84
1416 select_features();
1417#line 85
1418 tmp = valid_product();
1419 }
1420#line 85
1421 if (tmp) {
1422 {
1423#line 86
1424 setup();
1425#line 87
1426 runTest();
1427 }
1428 } else {
1429
1430 }
1431#line 1234 "Test.c"
1432 retValue_acc = 0;
1433#line 1236
1434 return (retValue_acc);
1435#line 1243
1436 return (retValue_acc);
1437}
1438}