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