Showing error 2080

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