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 "Test.o"
569#pragma merger(0,"Test.i","")
570#line 8 "Test.c"
571int cleanupTimeShifts = 4;
572#line 11 "Test.c"
573#line 20 "Test.c"
574void timeShift(void) ;
575#line 17 "Test.c"
576void cleanup(void)
577{ int i ;
578 int __cil_tmp2 ;
579
580 {
581 {
582#line 20
583 timeShift();
584#line 22
585 i = 0;
586 }
587 {
588#line 22
589 while (1) {
590 while_3_continue: ;
591 {
592#line 22
593 __cil_tmp2 = cleanupTimeShifts - 1;
594#line 22
595 if (i < __cil_tmp2) {
596
597 } else {
598 goto while_3_break;
599 }
600 }
601 {
602#line 23
603 timeShift();
604#line 22
605 i = i + 1;
606 }
607 }
608 while_3_break: ;
609 }
610#line 1111 "Test.c"
611 return;
612}
613}
614#line 57 "Test.c"
615void printPump(void) ;
616#line 60
617void waterRise(void) ;
618#line 62
619void changeMethaneLevel(void) ;
620#line 56 "Test.c"
621void Specification2(void)
622{
623
624 {
625 {
626#line 57
627 timeShift();
628#line 57
629 printPump();
630#line 58
631 timeShift();
632#line 58
633 printPump();
634#line 59
635 timeShift();
636#line 59
637 printPump();
638#line 60
639 waterRise();
640#line 60
641 printPump();
642#line 61
643 timeShift();
644#line 61
645 printPump();
646#line 62
647 changeMethaneLevel();
648#line 62
649 printPump();
650#line 63
651 timeShift();
652#line 63
653 printPump();
654#line 64
655 cleanup();
656 }
657#line 1159 "Test.c"
658 return;
659}
660}
661#line 67 "Test.c"
662void setup(void)
663{
664
665 {
666#line 1177 "Test.c"
667 return;
668}
669}
670#line 77 "Test.c"
671void test(void) ;
672#line 74 "Test.c"
673void runTest(void)
674{
675
676 {
677 {
678#line 77
679 test();
680 }
681#line 1197 "Test.c"
682 return;
683}
684}
685#line 83 "Test.c"
686void select_helpers(void) ;
687#line 84
688void select_features(void) ;
689#line 85
690int valid_product(void) ;
691#line 82 "Test.c"
692int main(void)
693{ int retValue_acc ;
694 int tmp ;
695
696 {
697 {
698#line 83
699 select_helpers();
700#line 84
701 select_features();
702#line 85
703 tmp = valid_product();
704 }
705#line 85
706 if (tmp) {
707 {
708#line 86
709 setup();
710#line 87
711 runTest();
712 }
713 } else {
714
715 }
716#line 1226 "Test.c"
717 retValue_acc = 0;
718#line 1228
719 return (retValue_acc);
720#line 1235
721 return (retValue_acc);
722}
723}
724#line 1 "scenario.o"
725#pragma merger(0,"scenario.i","")
726#line 7 "featureselect.h"
727int __SELECTED_FEATURE_base ;
728#line 9 "featureselect.h"
729int __SELECTED_FEATURE_highWaterSensor ;
730#line 11 "featureselect.h"
731int __SELECTED_FEATURE_lowWaterSensor ;
732#line 13 "featureselect.h"
733int __SELECTED_FEATURE_methaneQuery ;
734#line 15 "featureselect.h"
735int __SELECTED_FEATURE_methaneAlarm ;
736#line 17 "featureselect.h"
737int __SELECTED_FEATURE_stopCommand ;
738#line 19 "featureselect.h"
739int __SELECTED_FEATURE_startCommand ;
740#line 21 "featureselect.h"
741int __GUIDSL_ROOT_PRODUCTION ;
742#line 16 "scenario.c"
743void startSystem(void) ;
744#line 19
745void stopSystem(void) ;
746#line 3 "scenario.c"
747void test(void)
748{ int splverifierCounter ;
749 int tmp ;
750 int tmp___0 ;
751 int tmp___1 ;
752 int tmp___2 ;
753
754 {
755#line 4
756 splverifierCounter = 0;
757 {
758#line 5
759 while (1) {
760 while_4_continue: ;
761#line 5
762 if (splverifierCounter < 4) {
763
764 } else {
765 goto while_4_break;
766 }
767 {
768#line 9
769 tmp = __VERIFIER_nondet_int();
770 }
771#line 9
772 if (tmp) {
773 {
774#line 7
775 waterRise();
776 }
777 } else {
778
779 }
780 {
781#line 9
782 tmp___0 = __VERIFIER_nondet_int();
783 }
784#line 9
785 if (tmp___0) {
786 {
787#line 10
788 changeMethaneLevel();
789 }
790 } else {
791
792 }
793 {
794#line 12
795 tmp___2 = __VERIFIER_nondet_int();
796 }
797#line 12
798 if (tmp___2) {
799#line 15
800 if (__SELECTED_FEATURE_startCommand) {
801 {
802#line 16
803 startSystem();
804 }
805 } else {
806
807 }
808 } else {
809 {
810#line 17
811 tmp___1 = __VERIFIER_nondet_int();
812 }
813#line 17
814 if (tmp___1) {
815#line 18
816 if (__SELECTED_FEATURE_stopCommand) {
817 {
818#line 19
819 stopSystem();
820 }
821 } else {
822
823 }
824 } else {
825
826 }
827 }
828 {
829#line 19
830 timeShift();
831 }
832 }
833 while_4_break: ;
834 }
835 {
836#line 21
837 cleanup();
838 }
839#line 105 "scenario.c"
840 return;
841}
842}
843#line 1 "MinePump.o"
844#pragma merger(0,"MinePump.i","")
845#line 4 "Environment.h"
846void lowerWaterLevel(void) ;
847#line 10
848int isMethaneLevelCritical(void) ;
849#line 15
850void printEnvironment(void) ;
851#line 16
852int isHighWaterSensorDry(void) ;
853#line 17
854int isLowWaterSensorDry(void) ;
855#line 6 "MinePump.h"
856void activatePump(void) ;
857#line 8
858void deactivatePump(void) ;
859#line 10
860int isPumpRunning(void) ;
861#line 7 "MinePump.c"
862int pumpRunning = 0;
863#line 9 "MinePump.c"
864int systemActive = 1;
865#line 10
866void __utac_acc__Specification3_spec__1(void) ;
867#line 16
868void processEnvironment(void) ;
869#line 12 "MinePump.c"
870void timeShift(void)
871{
872
873 {
874#line 15
875 if (pumpRunning) {
876 {
877#line 16
878 lowerWaterLevel();
879 }
880 } else {
881
882 }
883#line 15
884 if (systemActive) {
885 {
886#line 16
887 processEnvironment();
888 }
889 } else {
890
891 }
892 {
893#line 119 "MinePump.c"
894 __utac_acc__Specification3_spec__1();
895 }
896#line 125
897 return;
898}
899}
900#line 19 "MinePump.c"
901void processEnvironment__before__highWaterSensor(void)
902{
903
904 {
905#line 143 "MinePump.c"
906 return;
907}
908}
909#line 28 "MinePump.c"
910int isHighWaterLevel(void) ;
911#line 23 "MinePump.c"
912void processEnvironment__role__highWaterSensor(void)
913{ int tmp ;
914
915 {
916#line 28
917 if (! pumpRunning) {
918 {
919#line 28
920 tmp = isHighWaterLevel();
921 }
922#line 28
923 if (tmp) {
924 {
925#line 25
926 activatePump();
927 }
928 } else {
929 {
930#line 27
931 processEnvironment__before__highWaterSensor();
932 }
933 }
934 } else {
935 {
936#line 27
937 processEnvironment__before__highWaterSensor();
938 }
939 }
940#line 169 "MinePump.c"
941 return;
942}
943}
944#line 32 "MinePump.c"
945void processEnvironment__before__lowWaterSensor(void)
946{
947
948 {
949#line 37
950 if (__SELECTED_FEATURE_highWaterSensor) {
951 {
952#line 34
953 processEnvironment__role__highWaterSensor();
954 }
955#line 34
956 return;
957 } else {
958 {
959#line 36
960 processEnvironment__before__highWaterSensor();
961 }
962#line 36
963 return;
964 }
965}
966}
967#line 47
968int isLowWaterLevel(void) ;
969#line 42 "MinePump.c"
970void processEnvironment__role__lowWaterSensor(void)
971{ int tmp ;
972
973 {
974#line 47
975 if (pumpRunning) {
976 {
977#line 47
978 tmp = isLowWaterLevel();
979 }
980#line 47
981 if (tmp) {
982 {
983#line 44
984 deactivatePump();
985 }
986 } else {
987 {
988#line 46
989 processEnvironment__before__lowWaterSensor();
990 }
991 }
992 } else {
993 {
994#line 46
995 processEnvironment__before__lowWaterSensor();
996 }
997 }
998#line 223 "MinePump.c"
999 return;
1000}
1001}
1002#line 51 "MinePump.c"
1003void processEnvironment__before__methaneAlarm(void)
1004{
1005
1006 {
1007#line 56
1008 if (__SELECTED_FEATURE_lowWaterSensor) {
1009 {
1010#line 53
1011 processEnvironment__role__lowWaterSensor();
1012 }
1013#line 53
1014 return;
1015 } else {
1016 {
1017#line 55
1018 processEnvironment__before__lowWaterSensor();
1019 }
1020#line 55
1021 return;
1022 }
1023}
1024}
1025#line 66
1026int isMethaneAlarm(void) ;
1027#line 61 "MinePump.c"
1028void processEnvironment__role__methaneAlarm(void)
1029{ int tmp ;
1030
1031 {
1032#line 66
1033 if (pumpRunning) {
1034 {
1035#line 66
1036 tmp = isMethaneAlarm();
1037 }
1038#line 66
1039 if (tmp) {
1040 {
1041#line 63
1042 deactivatePump();
1043 }
1044 } else {
1045 {
1046#line 65
1047 processEnvironment__before__methaneAlarm();
1048 }
1049 }
1050 } else {
1051 {
1052#line 65
1053 processEnvironment__before__methaneAlarm();
1054 }
1055 }
1056#line 277 "MinePump.c"
1057 return;
1058}
1059}
1060#line 69 "MinePump.c"
1061void processEnvironment(void)
1062{
1063
1064 {
1065#line 74
1066 if (__SELECTED_FEATURE_methaneAlarm) {
1067 {
1068#line 71
1069 processEnvironment__role__methaneAlarm();
1070 }
1071#line 71
1072 return;
1073 } else {
1074 {
1075#line 73
1076 processEnvironment__before__methaneAlarm();
1077 }
1078#line 73
1079 return;
1080 }
1081}
1082}
1083#line 80 "MinePump.c"
1084void activatePump__before__methaneQuery(void)
1085{
1086
1087 {
1088#line 81
1089 pumpRunning = 1;
1090#line 325 "MinePump.c"
1091 return;
1092}
1093}
1094#line 85 "MinePump.c"
1095void activatePump__role__methaneQuery(void)
1096{ int tmp ;
1097
1098 {
1099 {
1100#line 90
1101 tmp = isMethaneAlarm();
1102 }
1103#line 90
1104 if (tmp) {
1105
1106 } else {
1107 {
1108#line 87
1109 activatePump__before__methaneQuery();
1110 }
1111 }
1112#line 349 "MinePump.c"
1113 return;
1114}
1115}
1116#line 93 "MinePump.c"
1117void activatePump(void)
1118{
1119
1120 {
1121#line 98
1122 if (__SELECTED_FEATURE_methaneQuery) {
1123 {
1124#line 95
1125 activatePump__role__methaneQuery();
1126 }
1127#line 95
1128 return;
1129 } else {
1130 {
1131#line 97
1132 activatePump__before__methaneQuery();
1133 }
1134#line 97
1135 return;
1136 }
1137}
1138}
1139#line 104 "MinePump.c"
1140void deactivatePump(void)
1141{
1142
1143 {
1144#line 105
1145 pumpRunning = 0;
1146#line 397 "MinePump.c"
1147 return;
1148}
1149}
1150#line 109 "MinePump.c"
1151int isMethaneAlarm(void)
1152{ int retValue_acc ;
1153
1154 {
1155 {
1156#line 415 "MinePump.c"
1157 retValue_acc = isMethaneLevelCritical();
1158 }
1159#line 417
1160 return (retValue_acc);
1161#line 424
1162 return (retValue_acc);
1163}
1164}
1165#line 114 "MinePump.c"
1166int isPumpRunning(void)
1167{ int retValue_acc ;
1168
1169 {
1170#line 446 "MinePump.c"
1171 retValue_acc = pumpRunning;
1172#line 448
1173 return (retValue_acc);
1174#line 455
1175 return (retValue_acc);
1176}
1177}
1178#line 120 "MinePump.c"
1179#line 119 "MinePump.c"
1180void printPump(void)
1181{
1182
1183 {
1184 {
1185#line 120
1186 printf("Pump(System:");
1187 }
1188#line 121
1189 if (systemActive) {
1190 {
1191#line 122
1192 printf("On");
1193 }
1194 } else {
1195 {
1196#line 123
1197 printf("Off");
1198 }
1199 }
1200 {
1201#line 125
1202 printf(",Pump:");
1203 }
1204#line 126
1205 if (pumpRunning) {
1206 {
1207#line 127
1208 printf("On");
1209 }
1210 } else {
1211 {
1212#line 128
1213 printf("Off");
1214 }
1215 }
1216 {
1217#line 130
1218 printf(") ");
1219#line 131
1220 printEnvironment();
1221#line 132
1222 printf("\n");
1223 }
1224#line 495 "MinePump.c"
1225 return;
1226}
1227}
1228#line 134 "MinePump.c"
1229int isHighWaterLevel(void)
1230{ int retValue_acc ;
1231 int tmp ;
1232 int tmp___0 ;
1233
1234 {
1235 {
1236#line 513 "MinePump.c"
1237 tmp = isHighWaterSensorDry();
1238 }
1239#line 513
1240 if (tmp) {
1241#line 513
1242 tmp___0 = 0;
1243 } else {
1244#line 513
1245 tmp___0 = 1;
1246 }
1247#line 513
1248 retValue_acc = tmp___0;
1249#line 515
1250 return (retValue_acc);
1251#line 522
1252 return (retValue_acc);
1253}
1254}
1255#line 137 "MinePump.c"
1256int isLowWaterLevel(void)
1257{ int retValue_acc ;
1258 int tmp ;
1259 int tmp___0 ;
1260
1261 {
1262 {
1263#line 544 "MinePump.c"
1264 tmp = isLowWaterSensorDry();
1265 }
1266#line 544
1267 if (tmp) {
1268#line 544
1269 tmp___0 = 0;
1270 } else {
1271#line 544
1272 tmp___0 = 1;
1273 }
1274#line 544
1275 retValue_acc = tmp___0;
1276#line 546
1277 return (retValue_acc);
1278#line 553
1279 return (retValue_acc);
1280}
1281}
1282#line 140 "MinePump.c"
1283void stopSystem(void)
1284{
1285
1286 {
1287#line 145
1288 if (pumpRunning) {
1289 {
1290#line 142
1291 deactivatePump();
1292 }
1293 } else {
1294
1295 }
1296#line 145
1297 systemActive = 0;
1298#line 582 "MinePump.c"
1299 return;
1300}
1301}
1302#line 147 "MinePump.c"
1303void startSystem(void)
1304{
1305
1306 {
1307#line 149
1308 systemActive = 1;
1309#line 602 "MinePump.c"
1310 return;
1311}
1312}
1313#line 1 "featureselect.o"
1314#pragma merger(0,"featureselect.i","")
1315#line 24 "featureselect.h"
1316int select_one(void) ;
1317#line 7 "featureselect.c"
1318int select_one(void)
1319{ int retValue_acc ;
1320 int choice = __VERIFIER_nondet_int();
1321
1322 {
1323#line 78 "featureselect.c"
1324 retValue_acc = choice;
1325#line 80
1326 return (retValue_acc);
1327#line 87
1328 return (retValue_acc);
1329}
1330}
1331#line 12 "featureselect.c"
1332void select_features(void)
1333{
1334
1335 {
1336 {
1337#line 13
1338 __SELECTED_FEATURE_base = 1;
1339#line 14
1340 __SELECTED_FEATURE_highWaterSensor = select_one();
1341#line 15
1342 __SELECTED_FEATURE_lowWaterSensor = select_one();
1343#line 16
1344 __SELECTED_FEATURE_methaneQuery = select_one();
1345#line 17
1346 __SELECTED_FEATURE_methaneAlarm = select_one();
1347#line 18
1348 __SELECTED_FEATURE_stopCommand = select_one();
1349#line 19
1350 __SELECTED_FEATURE_startCommand = select_one();
1351 }
1352#line 123 "featureselect.c"
1353 return;
1354}
1355}
1356#line 23 "featureselect.c"
1357void select_helpers(void)
1358{
1359
1360 {
1361#line 24
1362 __GUIDSL_ROOT_PRODUCTION = 1;
1363#line 143 "featureselect.c"
1364 return;
1365}
1366}
1367#line 27 "featureselect.c"
1368int valid_product(void)
1369{ int retValue_acc ;
1370
1371 {
1372#line 161 "featureselect.c"
1373 retValue_acc = __SELECTED_FEATURE_base;
1374#line 163
1375 return (retValue_acc);
1376#line 170
1377 return (retValue_acc);
1378}
1379}
1380#line 1 "Specification3_spec.o"
1381#pragma merger(0,"Specification3_spec.i","")
1382#line 4 "wsllib.h"
1383void __automaton_fail(void) ;
1384#line 12 "Environment.h"
1385int getWaterLevel(void) ;
1386#line 11 "Specification3_spec.c"
1387void __utac_acc__Specification3_spec__1(void)
1388{ int tmp ;
1389 int tmp___0 ;
1390 int tmp___1 ;
1391
1392 {
1393 {
1394#line 19
1395 tmp = isMethaneLevelCritical();
1396 }
1397#line 19
1398 if (tmp) {
1399
1400 } else {
1401 {
1402#line 19
1403 tmp___0 = getWaterLevel();
1404 }
1405#line 19
1406 if (tmp___0 == 2) {
1407 {
1408#line 19
1409 tmp___1 = isPumpRunning();
1410 }
1411#line 19
1412 if (tmp___1) {
1413
1414 } else {
1415 {
1416#line 16
1417 __automaton_fail();
1418 }
1419 }
1420 } else {
1421
1422 }
1423 }
1424#line 16
1425 return;
1426}
1427}
1428#line 1 "wsllib_check.o"
1429#pragma merger(0,"wsllib_check.i","")
1430#line 3 "wsllib_check.c"
1431void __automaton_fail(void)
1432{
1433
1434 {
1435 goto ERROR;
1436 ERROR: ;
1437#line 53 "wsllib_check.c"
1438 return;
1439}
1440}
1441#line 1 "Environment.o"
1442#pragma merger(0,"Environment.i","")
1443#line 9 "Environment.c"
1444int waterLevel = 1;
1445#line 12 "Environment.c"
1446int methaneLevelCritical = 0;
1447#line 15 "Environment.c"
1448void lowerWaterLevel(void)
1449{
1450
1451 {
1452#line 19
1453 if (waterLevel > 0) {
1454#line 17
1455 waterLevel = waterLevel - 1;
1456 } else {
1457
1458 }
1459#line 101 "Environment.c"
1460 return;
1461}
1462}
1463#line 22 "Environment.c"
1464void waterRise(void)
1465{
1466
1467 {
1468#line 26
1469 if (waterLevel < 2) {
1470#line 24
1471 waterLevel = waterLevel + 1;
1472 } else {
1473
1474 }
1475#line 124 "Environment.c"
1476 return;
1477}
1478}
1479#line 29 "Environment.c"
1480void changeMethaneLevel(void)
1481{
1482
1483 {
1484#line 34
1485 if (methaneLevelCritical) {
1486#line 31
1487 methaneLevelCritical = 0;
1488 } else {
1489#line 33
1490 methaneLevelCritical = 1;
1491 }
1492#line 150 "Environment.c"
1493 return;
1494}
1495}
1496#line 38 "Environment.c"
1497int isMethaneLevelCritical(void)
1498{ int retValue_acc ;
1499
1500 {
1501#line 168 "Environment.c"
1502 retValue_acc = methaneLevelCritical;
1503#line 170
1504 return (retValue_acc);
1505#line 177
1506 return (retValue_acc);
1507}
1508}
1509#line 44 "Environment.c"
1510void printEnvironment(void)
1511{
1512
1513 {
1514 {
1515#line 45
1516 printf("Env(Water:%i", waterLevel);
1517#line 46
1518 printf(",Meth:");
1519 }
1520#line 47
1521 if (methaneLevelCritical) {
1522 {
1523#line 48
1524 printf("CRIT");
1525 }
1526 } else {
1527 {
1528#line 49
1529 printf("OK");
1530 }
1531 }
1532 {
1533#line 51
1534 printf(")");
1535 }
1536#line 209 "Environment.c"
1537 return;
1538}
1539}
1540#line 55 "Environment.c"
1541int getWaterLevel(void)
1542{ int retValue_acc ;
1543
1544 {
1545#line 227 "Environment.c"
1546 retValue_acc = waterLevel;
1547#line 229
1548 return (retValue_acc);
1549#line 236
1550 return (retValue_acc);
1551}
1552}
1553#line 58 "Environment.c"
1554int isHighWaterSensorDry(void)
1555{ int retValue_acc ;
1556
1557 {
1558#line 65 "Environment.c"
1559 if (waterLevel < 2) {
1560#line 261
1561 retValue_acc = 1;
1562#line 263
1563 return (retValue_acc);
1564 } else {
1565#line 269 "Environment.c"
1566 retValue_acc = 0;
1567#line 271
1568 return (retValue_acc);
1569 }
1570#line 278 "Environment.c"
1571 return (retValue_acc);
1572}
1573}
1574#line 67 "Environment.c"
1575int isLowWaterSensorDry(void)
1576{ int retValue_acc ;
1577
1578 {
1579#line 300 "Environment.c"
1580 retValue_acc = waterLevel == 0;
1581#line 302
1582 return (retValue_acc);
1583#line 309
1584 return (retValue_acc);
1585}
1586}