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