Showing error 2145

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