Showing error 2026

User: Jiri Slaby
Error type: Reachable Error Location
Error type description: A specified error location is reachable in some program path
File location: product-lines/minepump_spec3_product56_unsafe.cil.c
Line in file: 1422
Project: SV-COMP 2013
Project version: 2.6.28
Tools: Manual Work
Entered: 2013-01-17 16:57:54 UTC


Source:

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