java -Xmx8000000000 -Xss4m -jar ./plugins/org.eclipse.equinox.launcher_1.3.100.v20150511-1540.jar -data @noDefault -ultimatedata ./data -tc ../../../trunk/examples/toolchains/Sifa.xml -i ../../../trunk/examples/programs/20181010-MemSafetyPathprograms/ArraysOfVariableLength5_true-valid-memsafety.c_10.bpl -------------------------------------------------------------------------------- This is Ultimate 0.1.24-b03553c [2019-08-05 18:14:31,162 INFO L177 SettingsManager]: Resetting all preferences to default values... [2019-08-05 18:14:31,164 INFO L181 SettingsManager]: Resetting UltimateCore preferences to default values [2019-08-05 18:14:31,176 INFO L184 SettingsManager]: Ultimate Commandline Interface provides no preferences, ignoring... [2019-08-05 18:14:31,177 INFO L181 SettingsManager]: Resetting Boogie Preprocessor preferences to default values [2019-08-05 18:14:31,178 INFO L181 SettingsManager]: Resetting Boogie Procedure Inliner preferences to default values [2019-08-05 18:14:31,179 INFO L181 SettingsManager]: Resetting Abstract Interpretation preferences to default values [2019-08-05 18:14:31,181 INFO L181 SettingsManager]: Resetting LassoRanker preferences to default values [2019-08-05 18:14:31,183 INFO L181 SettingsManager]: Resetting Reaching Definitions preferences to default values [2019-08-05 18:14:31,184 INFO L181 SettingsManager]: Resetting SyntaxChecker preferences to default values [2019-08-05 18:14:31,185 INFO L181 SettingsManager]: Resetting Symbolic Interpretation preferences to default values [2019-08-05 18:14:31,186 INFO L184 SettingsManager]: Büchi Program Product provides no preferences, ignoring... [2019-08-05 18:14:31,186 INFO L181 SettingsManager]: Resetting LTL2Aut preferences to default values [2019-08-05 18:14:31,187 INFO L181 SettingsManager]: Resetting PEA to Boogie preferences to default values [2019-08-05 18:14:31,188 INFO L181 SettingsManager]: Resetting BlockEncodingV2 preferences to default values [2019-08-05 18:14:31,190 INFO L181 SettingsManager]: Resetting ChcToBoogie preferences to default values [2019-08-05 18:14:31,191 INFO L181 SettingsManager]: Resetting AutomataScriptInterpreter preferences to default values [2019-08-05 18:14:31,192 INFO L181 SettingsManager]: Resetting BuchiAutomizer preferences to default values [2019-08-05 18:14:31,193 INFO L181 SettingsManager]: Resetting CACSL2BoogieTranslator preferences to default values [2019-08-05 18:14:31,196 INFO L181 SettingsManager]: Resetting CodeCheck preferences to default values [2019-08-05 18:14:31,198 INFO L181 SettingsManager]: Resetting InvariantSynthesis preferences to default values [2019-08-05 18:14:31,199 INFO L181 SettingsManager]: Resetting RCFGBuilder preferences to default values [2019-08-05 18:14:31,200 INFO L181 SettingsManager]: Resetting Referee preferences to default values [2019-08-05 18:14:31,201 INFO L181 SettingsManager]: Resetting TraceAbstraction preferences to default values [2019-08-05 18:14:31,204 INFO L184 SettingsManager]: TraceAbstractionConcurrent provides no preferences, ignoring... [2019-08-05 18:14:31,204 INFO L184 SettingsManager]: TraceAbstractionWithAFAs provides no preferences, ignoring... [2019-08-05 18:14:31,204 INFO L181 SettingsManager]: Resetting TreeAutomizer preferences to default values [2019-08-05 18:14:31,205 INFO L181 SettingsManager]: Resetting IcfgToChc preferences to default values [2019-08-05 18:14:31,206 INFO L181 SettingsManager]: Resetting IcfgTransformer preferences to default values [2019-08-05 18:14:31,207 INFO L184 SettingsManager]: ReqToTest provides no preferences, ignoring... [2019-08-05 18:14:31,207 INFO L181 SettingsManager]: Resetting Boogie Printer preferences to default values [2019-08-05 18:14:31,208 INFO L181 SettingsManager]: Resetting ChcSmtPrinter preferences to default values [2019-08-05 18:14:31,209 INFO L181 SettingsManager]: Resetting ReqPrinter preferences to default values [2019-08-05 18:14:31,210 INFO L181 SettingsManager]: Resetting Witness Printer preferences to default values [2019-08-05 18:14:31,211 INFO L184 SettingsManager]: Boogie PL CUP Parser provides no preferences, ignoring... [2019-08-05 18:14:31,211 INFO L181 SettingsManager]: Resetting CDTParser preferences to default values [2019-08-05 18:14:31,212 INFO L184 SettingsManager]: AutomataScriptParser provides no preferences, ignoring... [2019-08-05 18:14:31,212 INFO L184 SettingsManager]: ReqParser provides no preferences, ignoring... [2019-08-05 18:14:31,213 INFO L181 SettingsManager]: Resetting SmtParser preferences to default values [2019-08-05 18:14:31,214 INFO L181 SettingsManager]: Resetting Witness Parser preferences to default values [2019-08-05 18:14:31,214 INFO L188 SettingsManager]: Finished resetting all preferences to default values... [2019-08-05 18:14:31,241 INFO L81 nceAwareModelManager]: Repository-Root is: /tmp [2019-08-05 18:14:31,254 INFO L258 ainManager$Toolchain]: [Toolchain 1]: Applicable parser(s) successfully (re)initialized [2019-08-05 18:14:31,257 INFO L214 ainManager$Toolchain]: [Toolchain 1]: Toolchain selected. [2019-08-05 18:14:31,259 INFO L271 PluginConnector]: Initializing Boogie PL CUP Parser... [2019-08-05 18:14:31,259 INFO L275 PluginConnector]: Boogie PL CUP Parser initialized [2019-08-05 18:14:31,260 INFO L428 ainManager$Toolchain]: [Toolchain 1]: Parsing single file: /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/../../../trunk/examples/programs/20181010-MemSafetyPathprograms/ArraysOfVariableLength5_true-valid-memsafety.c_10.bpl [2019-08-05 18:14:31,261 INFO L110 BoogieParser]: Parsing: '/storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/../../../trunk/examples/programs/20181010-MemSafetyPathprograms/ArraysOfVariableLength5_true-valid-memsafety.c_10.bpl' [2019-08-05 18:14:31,306 INFO L296 ainManager$Toolchain]: ####################### [Toolchain 1] ####################### [2019-08-05 18:14:31,308 INFO L131 ToolchainWalker]: Walking toolchain with 3 elements. [2019-08-05 18:14:31,309 INFO L113 PluginConnector]: ------------------------Boogie Preprocessor---------------------------- [2019-08-05 18:14:31,309 INFO L271 PluginConnector]: Initializing Boogie Preprocessor... [2019-08-05 18:14:31,309 INFO L275 PluginConnector]: Boogie Preprocessor initialized [2019-08-05 18:14:31,332 INFO L185 PluginConnector]: Executing the observer EnsureBoogieModelObserver from plugin Boogie Preprocessor for "ArraysOfVariableLength5_true-valid-memsafety.c_10.bpl de.uni_freiburg.informatik.ultimate.boogie.parser AST 05.08 06:14:31" (1/1) ... [2019-08-05 18:14:31,334 INFO L185 PluginConnector]: Executing the observer TypeChecker from plugin Boogie Preprocessor for "ArraysOfVariableLength5_true-valid-memsafety.c_10.bpl de.uni_freiburg.informatik.ultimate.boogie.parser AST 05.08 06:14:31" (1/1) ... [2019-08-05 18:14:31,345 INFO L185 PluginConnector]: Executing the observer ConstExpander from plugin Boogie Preprocessor for "ArraysOfVariableLength5_true-valid-memsafety.c_10.bpl de.uni_freiburg.informatik.ultimate.boogie.parser AST 05.08 06:14:31" (1/1) ... [2019-08-05 18:14:31,346 INFO L185 PluginConnector]: Executing the observer StructExpander from plugin Boogie Preprocessor for "ArraysOfVariableLength5_true-valid-memsafety.c_10.bpl de.uni_freiburg.informatik.ultimate.boogie.parser AST 05.08 06:14:31" (1/1) ... [2019-08-05 18:14:31,351 INFO L185 PluginConnector]: Executing the observer UnstructureCode from plugin Boogie Preprocessor for "ArraysOfVariableLength5_true-valid-memsafety.c_10.bpl de.uni_freiburg.informatik.ultimate.boogie.parser AST 05.08 06:14:31" (1/1) ... [2019-08-05 18:14:31,353 INFO L185 PluginConnector]: Executing the observer FunctionInliner from plugin Boogie Preprocessor for "ArraysOfVariableLength5_true-valid-memsafety.c_10.bpl de.uni_freiburg.informatik.ultimate.boogie.parser AST 05.08 06:14:31" (1/1) ... [2019-08-05 18:14:31,354 INFO L185 PluginConnector]: Executing the observer BoogieSymbolTableConstructor from plugin Boogie Preprocessor for "ArraysOfVariableLength5_true-valid-memsafety.c_10.bpl de.uni_freiburg.informatik.ultimate.boogie.parser AST 05.08 06:14:31" (1/1) ... [2019-08-05 18:14:31,356 INFO L132 PluginConnector]: ------------------------ END Boogie Preprocessor---------------------------- [2019-08-05 18:14:31,357 INFO L113 PluginConnector]: ------------------------RCFGBuilder---------------------------- [2019-08-05 18:14:31,358 INFO L271 PluginConnector]: Initializing RCFGBuilder... [2019-08-05 18:14:31,358 INFO L275 PluginConnector]: RCFGBuilder initialized [2019-08-05 18:14:31,359 INFO L185 PluginConnector]: Executing the observer RCFGBuilderObserver from plugin RCFGBuilder for "ArraysOfVariableLength5_true-valid-memsafety.c_10.bpl de.uni_freiburg.informatik.ultimate.boogie.parser AST 05.08 06:14:31" (1/1) ... No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 Starting monitored process 1 with z3 SMTLIB2_COMPLIANT=true -memory:1024 -smt2 -in -t:12000 (exit command is (exit), workingDir is null) Waiting until toolchain timeout for monitored process 1 with z3 SMTLIB2_COMPLIANT=true -memory:1024 -smt2 -in -t:12000 [2019-08-05 18:14:31,433 INFO L124 BoogieDeclarations]: Specification and implementation of procedure ULTIMATE.start given in one single declaration [2019-08-05 18:14:31,433 INFO L130 BoogieDeclarations]: Found specification of procedure ULTIMATE.start [2019-08-05 18:14:31,433 INFO L138 BoogieDeclarations]: Found implementation of procedure ULTIMATE.start [2019-08-05 18:14:31,706 INFO L278 CfgBuilder]: Using the 1 location(s) as analysis (start of procedure ULTIMATE.start) [2019-08-05 18:14:31,706 INFO L283 CfgBuilder]: Removed 0 assume(true) statements. [2019-08-05 18:14:31,707 INFO L202 PluginConnector]: Adding new model ArraysOfVariableLength5_true-valid-memsafety.c_10.bpl de.uni_freiburg.informatik.ultimate.plugins.generator.rcfgbuilder CFG 05.08 06:14:31 BoogieIcfgContainer [2019-08-05 18:14:31,708 INFO L132 PluginConnector]: ------------------------ END RCFGBuilder---------------------------- [2019-08-05 18:14:31,708 INFO L113 PluginConnector]: ------------------------Symbolic Interpretation---------------------------- [2019-08-05 18:14:31,708 INFO L271 PluginConnector]: Initializing Symbolic Interpretation... [2019-08-05 18:14:31,709 INFO L275 PluginConnector]: Symbolic Interpretation initialized [2019-08-05 18:14:31,710 INFO L185 PluginConnector]: Executing the observer SymbolicInterpretationObserver from plugin Symbolic Interpretation for "ArraysOfVariableLength5_true-valid-memsafety.c_10.bpl de.uni_freiburg.informatik.ultimate.plugins.generator.rcfgbuilder CFG 05.08 06:14:31" (1/1) ... [2019-08-05 18:14:31,721 INFO L148 IcfgInterpreter]: Started Sifa with 1 locations of interest [2019-08-05 18:14:31,723 INFO L155 IcfgInterpreter]: Building call graph [2019-08-05 18:14:31,731 INFO L160 IcfgInterpreter]: Initial procedures are [ULTIMATE.start] [2019-08-05 18:14:31,739 INFO L165 IcfgInterpreter]: Starting interpretation [2019-08-05 18:14:31,741 INFO L185 IcfgInterpreter]: Interpreting procedure ULTIMATE.start with input of size 1 [2019-08-05 18:14:31,945 INFO L169 IcfgInterpreter]: Interpretation finished [2019-08-05 18:14:31,945 INFO L177 IcfgInterpreter]: Final predicates for locations of interest are: [2019-08-05 18:14:31,952 INFO L179 IcfgInterpreter]: Location ULTIMATE.startErr0ASSERT_VIOLATIONASSERT has predicate 18#(and (<= |ULTIMATE.start_main_#t~ret3| 2147483647) (= 0 ULTIMATE.start_foo_~i~0) (= |ULTIMATE.start_main_#t~ret3| |ULTIMATE.start_foo_#res|) (= (select |#valid| |ULTIMATE.start_write~int_#ptr.base|) 1) (= ULTIMATE.start_main_~c~0.offset |ULTIMATE.start_main_~#mask~0.offset|) (= 1 (select |#valid| |ULTIMATE.start_main_~#b~0.base|)) (= (+ |ULTIMATE.start_main_~#b~0.offset| (* 4 ULTIMATE.start_main_~i~1)) |ULTIMATE.start_write~int_#ptr.offset|) (= ULTIMATE.start_main_~i~1 |ULTIMATE.start_foo_#in~size|) (= |ULTIMATE.start_write~int_#value| |ULTIMATE.start_main_#t~ret3|) (= |ULTIMATE.start_foo_#in~size| ULTIMATE.start_foo_~size) (<= 4 (+ |ULTIMATE.start_main_~#b~0.offset| (* 4 ULTIMATE.start_main_~i~1))) (= |ULTIMATE.start_write~int_#ptr.base| |ULTIMATE.start_main_~#b~0.base|) (= |ULTIMATE.start_write~int_#sizeOfWrittenType| 4) (= |ULTIMATE.start_foo_#in~b.base| ULTIMATE.start_foo_~b.base) (<= ULTIMATE.start_main_~i~1 1) (exists ((|v_ULTIMATE.start_write~int_old_#memory_int_4| (Array Int (Array Int Int)))) (and (or (and (= 0 |ULTIMATE.start_#Ultimate.alloc_#res.offset|) (= 0 |#NULL.base|) (= 0 (+ ULTIMATE.start_main_~i~1 (- 1))) (= |#valid| (store |ULTIMATE.start_#Ultimate.alloc_old_#valid| |ULTIMATE.start_#Ultimate.alloc_#res.base| 1)) (= |ULTIMATE.start_#Ultimate.alloc_#res.offset| |ULTIMATE.start_main_~#mask~0.offset|) (= |ULTIMATE.start_main_~#mask~0.base| |ULTIMATE.start_#Ultimate.alloc_#res.base|) (not (= |ULTIMATE.start_#Ultimate.alloc_#res.base| 0)) (= 0 (select |ULTIMATE.start_#Ultimate.alloc_old_#valid| |ULTIMATE.start_#Ultimate.alloc_#res.base|)) (not (= 0 |ULTIMATE.start_main_~#b~0.base|)) (exists ((|v_#valid_7| (Array Int Int))) (and (= |ULTIMATE.start_main_old_#valid| (store |v_#valid_7| 0 0)) (= |ULTIMATE.start_#Ultimate.alloc_old_#valid| (store (store |v_#valid_7| 0 0) |ULTIMATE.start_main_~#b~0.base| 1)) (= 0 (select (store |v_#valid_7| 0 0) |ULTIMATE.start_main_~#b~0.base|)))) (= (store |ULTIMATE.start_#Ultimate.alloc_old_#length| |ULTIMATE.start_#Ultimate.alloc_#res.base| |ULTIMATE.start_#Ultimate.alloc_~size|) |#length|) (= |ULTIMATE.start_main_~#b~0.offset| 0) (exists ((|v_#length_6| (Array Int Int))) (= |ULTIMATE.start_#Ultimate.alloc_old_#length| (store |v_#length_6| |ULTIMATE.start_main_~#b~0.base| 128))) (= 32 |ULTIMATE.start_#Ultimate.alloc_~size|) (= |#NULL.offset| 0)) (and (= 0 |ULTIMATE.start_#Ultimate.alloc_#res.offset|) (= 0 |#NULL.base|) (= |#valid| (store |ULTIMATE.start_#Ultimate.alloc_old_#valid| |ULTIMATE.start_#Ultimate.alloc_#res.base| 1)) (<= (+ |ULTIMATE.start_main_~#b~0.offset| 4) (select |#length| |ULTIMATE.start_main_~#b~0.base|)) (exists ((|v_ULTIMATE.start_write~int_old_#memory_int_3| (Array Int (Array Int Int)))) (= (store |v_ULTIMATE.start_write~int_old_#memory_int_3| |ULTIMATE.start_main_~#b~0.base| (store (select |v_ULTIMATE.start_write~int_old_#memory_int_3| |ULTIMATE.start_main_~#b~0.base|) |ULTIMATE.start_main_~#b~0.offset| 0)) |v_ULTIMATE.start_write~int_old_#memory_int_4|)) (<= 0 |ULTIMATE.start_main_~#b~0.offset|) (= |ULTIMATE.start_main_~#mask~0.base| |ULTIMATE.start_#Ultimate.alloc_#res.base|) (= |ULTIMATE.start_#Ultimate.alloc_#res.offset| |ULTIMATE.start_main_~#mask~0.offset|) (= 1 (select |#valid| |ULTIMATE.start_main_~#b~0.base|)) (not (= |ULTIMATE.start_#Ultimate.alloc_#res.base| 0)) (exists ((|v_#valid_7| (Array Int Int))) (and (= |ULTIMATE.start_main_old_#valid| (store |v_#valid_7| 0 0)) (= |ULTIMATE.start_#Ultimate.alloc_old_#valid| (store (store |v_#valid_7| 0 0) |ULTIMATE.start_main_~#b~0.base| 1)) (= 0 (select (store |v_#valid_7| 0 0) |ULTIMATE.start_main_~#b~0.base|)))) (= 0 (select |ULTIMATE.start_#Ultimate.alloc_old_#valid| |ULTIMATE.start_#Ultimate.alloc_#res.base|)) (not (= 0 |ULTIMATE.start_main_~#b~0.base|)) (= (store |ULTIMATE.start_#Ultimate.alloc_old_#length| |ULTIMATE.start_#Ultimate.alloc_#res.base| |ULTIMATE.start_#Ultimate.alloc_~size|) |#length|) (= |ULTIMATE.start_main_~#b~0.offset| 0) (exists ((|v_#length_6| (Array Int Int))) (= |ULTIMATE.start_#Ultimate.alloc_old_#length| (store |v_#length_6| |ULTIMATE.start_main_~#b~0.base| 128))) (= 32 |ULTIMATE.start_#Ultimate.alloc_~size|) (= |#NULL.offset| 0) (= 1 (+ ULTIMATE.start_main_~i~1 (- 1))))) (= (store |v_ULTIMATE.start_write~int_old_#memory_int_4| |ULTIMATE.start_main_~#b~0.base| (store (select |v_ULTIMATE.start_write~int_old_#memory_int_4| |ULTIMATE.start_main_~#b~0.base|) (+ |ULTIMATE.start_main_~#b~0.offset| (* 4 ULTIMATE.start_main_~i~1) (- 4)) 0)) |#memory_int|))) (< ULTIMATE.start_main_~i~1 33) (= |ULTIMATE.start_foo_#in~b.offset| ULTIMATE.start_foo_~b.offset) (< ULTIMATE.start_main_~i~1 32) (= |ULTIMATE.start_write~int_old_#memory_int| |#memory_int|) (or (not (<= 0 |ULTIMATE.start_write~int_#ptr.offset|)) (not (<= (+ |ULTIMATE.start_write~int_#sizeOfWrittenType| |ULTIMATE.start_write~int_#ptr.offset|) (select |#length| |ULTIMATE.start_write~int_#ptr.base|)))) (= |ULTIMATE.start_foo_#res| ULTIMATE.start_foo_~i~0) (= |ULTIMATE.start_main_~#mask~0.base| ULTIMATE.start_main_~c~0.base) (<= (+ |ULTIMATE.start_main_~#b~0.offset| (* 4 ULTIMATE.start_main_~i~1)) (select |#length| |ULTIMATE.start_main_~#b~0.base|)) (<= 0 (+ |ULTIMATE.start_main_#t~ret3| 2147483648)) (not (< ULTIMATE.start_foo_~i~0 ULTIMATE.start_foo_~size)) (= |ULTIMATE.start_foo_#in~b.offset| ULTIMATE.start_main_~c~0.offset) (= |ULTIMATE.start_foo_#in~b.base| ULTIMATE.start_main_~c~0.base)) [2019-08-05 18:14:31,957 WARN L88 terpretationObserver]: Some locations of interest might be reachable, see reported results. [2019-08-05 18:14:31,967 INFO L132 PluginConnector]: ------------------------ END Symbolic Interpretation---------------------------- [2019-08-05 18:14:31,970 INFO L168 Benchmark]: Toolchain (without parser) took 661.02 ms. Allocated memory is still 140.0 MB. Free memory was 107.8 MB in the beginning and 85.2 MB in the end (delta: 22.6 MB). Peak memory consumption was 22.6 MB. Max. memory is 7.1 GB. [2019-08-05 18:14:31,971 INFO L168 Benchmark]: Boogie PL CUP Parser took 0.22 ms. Allocated memory is still 140.0 MB. Free memory is still 109.1 MB. There was no memory consumed. Max. memory is 7.1 GB. [2019-08-05 18:14:31,972 INFO L168 Benchmark]: Boogie Preprocessor took 48.25 ms. Allocated memory is still 140.0 MB. Free memory was 107.8 MB in the beginning and 105.7 MB in the end (delta: 2.2 MB). Peak memory consumption was 2.2 MB. Max. memory is 7.1 GB. [2019-08-05 18:14:31,974 INFO L168 Benchmark]: RCFGBuilder took 350.38 ms. Allocated memory is still 140.0 MB. Free memory was 105.7 MB in the beginning and 93.2 MB in the end (delta: 12.5 MB). Peak memory consumption was 12.5 MB. Max. memory is 7.1 GB. [2019-08-05 18:14:31,975 INFO L168 Benchmark]: Symbolic Interpretation took 258.83 ms. Allocated memory is still 140.0 MB. Free memory was 93.2 MB in the beginning and 85.2 MB in the end (delta: 8.0 MB). Peak memory consumption was 8.0 MB. Max. memory is 7.1 GB. [2019-08-05 18:14:31,979 INFO L335 ainManager$Toolchain]: ####################### End [Toolchain 1] ####################### --- Results --- * Results from de.uni_freiburg.informatik.ultimate.plugins.symbolicinterpretation: - UnprovableResult [Line: 117]: Unable to prove that assertion always holds Unable to prove that assertion always holds Reason: Interpreter reached this location of interest. Location might be reachable.. Possible FailurePath: * Results from de.uni_freiburg.informatik.ultimate.core: - StatisticsResult: Toolchain Benchmarks Benchmark results are: * Boogie PL CUP Parser took 0.22 ms. Allocated memory is still 140.0 MB. Free memory is still 109.1 MB. There was no memory consumed. Max. memory is 7.1 GB. * Boogie Preprocessor took 48.25 ms. Allocated memory is still 140.0 MB. Free memory was 107.8 MB in the beginning and 105.7 MB in the end (delta: 2.2 MB). Peak memory consumption was 2.2 MB. Max. memory is 7.1 GB. * RCFGBuilder took 350.38 ms. Allocated memory is still 140.0 MB. Free memory was 105.7 MB in the beginning and 93.2 MB in the end (delta: 12.5 MB). Peak memory consumption was 12.5 MB. Max. memory is 7.1 GB. * Symbolic Interpretation took 258.83 ms. Allocated memory is still 140.0 MB. Free memory was 93.2 MB in the beginning and 85.2 MB in the end (delta: 8.0 MB). Peak memory consumption was 8.0 MB. Max. memory is 7.1 GB. RESULT: Ultimate could not prove your program: unable to determine feasibility of some traces Received shutdown request...