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