./Ultimate.py --spec ../sv-benchmarks/c/properties/unreach-call.prp --file ../sv-benchmarks/c/aws-c-common/aws_hash_callback_string_eq_harness.i --full-output -ea --architecture 64bit -------------------------------------------------------------------------------- Checking for ERROR reachability Using default analysis Version 03d7b7b3 Calling Ultimate with: /usr/bin/java -Dosgi.configuration.area=/storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/data/config -Xmx15G -Xms4m -ea -jar /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/plugins/org.eclipse.equinox.launcher_1.5.800.v20200727-1323.jar -data @noDefault -ultimatedata /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/data -tc /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/config/AutomizerReach.xml -i ../sv-benchmarks/c/aws-c-common/aws_hash_callback_string_eq_harness.i -s /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/config/svcomp-Reach-64bit-Automizer_Default.epf --cacsl2boogietranslator.entry.function main --witnessprinter.witness.directory /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux --witnessprinter.witness.filename witness.graphml --witnessprinter.write.witness.besides.input.file false --witnessprinter.graph.data.specification CHECK( init(main()), LTL(G ! call(reach_error())) ) --witnessprinter.graph.data.producer Automizer --witnessprinter.graph.data.architecture 64bit --witnessprinter.graph.data.programhash 617e08addfe2d13b261907959d3757079a581721356bb3e7b4090decaff2b168 --- Real Ultimate output --- This is Ultimate 0.2.2-dev-03d7b7b [2022-02-20 21:08:03,425 INFO L177 SettingsManager]: Resetting all preferences to default values... [2022-02-20 21:08:03,427 INFO L181 SettingsManager]: Resetting UltimateCore preferences to default values [2022-02-20 21:08:03,479 INFO L184 SettingsManager]: Ultimate Commandline Interface provides no preferences, ignoring... [2022-02-20 21:08:03,480 INFO L181 SettingsManager]: Resetting Boogie Preprocessor preferences to default values [2022-02-20 21:08:03,482 INFO L181 SettingsManager]: Resetting Boogie Procedure Inliner preferences to default values [2022-02-20 21:08:03,484 INFO L181 SettingsManager]: Resetting Abstract Interpretation preferences to default values [2022-02-20 21:08:03,487 INFO L181 SettingsManager]: Resetting LassoRanker preferences to default values [2022-02-20 21:08:03,489 INFO L181 SettingsManager]: Resetting Reaching Definitions preferences to default values [2022-02-20 21:08:03,494 INFO L181 SettingsManager]: Resetting SyntaxChecker preferences to default values [2022-02-20 21:08:03,495 INFO L181 SettingsManager]: Resetting Sifa preferences to default values [2022-02-20 21:08:03,496 INFO L184 SettingsManager]: Büchi Program Product provides no preferences, ignoring... [2022-02-20 21:08:03,497 INFO L181 SettingsManager]: Resetting LTL2Aut preferences to default values [2022-02-20 21:08:03,499 INFO L181 SettingsManager]: Resetting PEA to Boogie preferences to default values [2022-02-20 21:08:03,501 INFO L181 SettingsManager]: Resetting BlockEncodingV2 preferences to default values [2022-02-20 21:08:03,504 INFO L181 SettingsManager]: Resetting ChcToBoogie preferences to default values [2022-02-20 21:08:03,505 INFO L181 SettingsManager]: Resetting AutomataScriptInterpreter preferences to default values [2022-02-20 21:08:03,506 INFO L181 SettingsManager]: Resetting BuchiAutomizer preferences to default values [2022-02-20 21:08:03,508 INFO L181 SettingsManager]: Resetting CACSL2BoogieTranslator preferences to default values [2022-02-20 21:08:03,514 INFO L181 SettingsManager]: Resetting CodeCheck preferences to default values [2022-02-20 21:08:03,515 INFO L181 SettingsManager]: Resetting InvariantSynthesis preferences to default values [2022-02-20 21:08:03,517 INFO L181 SettingsManager]: Resetting RCFGBuilder preferences to default values [2022-02-20 21:08:03,518 INFO L181 SettingsManager]: Resetting Referee preferences to default values [2022-02-20 21:08:03,520 INFO L181 SettingsManager]: Resetting TraceAbstraction preferences to default values [2022-02-20 21:08:03,526 INFO L184 SettingsManager]: TraceAbstractionConcurrent provides no preferences, ignoring... [2022-02-20 21:08:03,526 INFO L184 SettingsManager]: TraceAbstractionWithAFAs provides no preferences, ignoring... [2022-02-20 21:08:03,527 INFO L181 SettingsManager]: Resetting TreeAutomizer preferences to default values [2022-02-20 21:08:03,529 INFO L181 SettingsManager]: Resetting IcfgToChc preferences to default values [2022-02-20 21:08:03,529 INFO L181 SettingsManager]: Resetting IcfgTransformer preferences to default values [2022-02-20 21:08:03,530 INFO L184 SettingsManager]: ReqToTest provides no preferences, ignoring... [2022-02-20 21:08:03,530 INFO L181 SettingsManager]: Resetting Boogie Printer preferences to default values [2022-02-20 21:08:03,531 INFO L181 SettingsManager]: Resetting ChcSmtPrinter preferences to default values [2022-02-20 21:08:03,533 INFO L181 SettingsManager]: Resetting ReqPrinter preferences to default values [2022-02-20 21:08:03,534 INFO L181 SettingsManager]: Resetting Witness Printer preferences to default values [2022-02-20 21:08:03,535 INFO L184 SettingsManager]: Boogie PL CUP Parser provides no preferences, ignoring... [2022-02-20 21:08:03,535 INFO L181 SettingsManager]: Resetting CDTParser preferences to default values [2022-02-20 21:08:03,536 INFO L184 SettingsManager]: AutomataScriptParser provides no preferences, ignoring... [2022-02-20 21:08:03,536 INFO L184 SettingsManager]: ReqParser provides no preferences, ignoring... [2022-02-20 21:08:03,536 INFO L181 SettingsManager]: Resetting SmtParser preferences to default values [2022-02-20 21:08:03,537 INFO L181 SettingsManager]: Resetting Witness Parser preferences to default values [2022-02-20 21:08:03,539 INFO L188 SettingsManager]: Finished resetting all preferences to default values... [2022-02-20 21:08:03,540 INFO L101 SettingsManager]: Beginning loading settings from /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/config/svcomp-Reach-64bit-Automizer_Default.epf [2022-02-20 21:08:03,567 INFO L113 SettingsManager]: Loading preferences was successful [2022-02-20 21:08:03,568 INFO L115 SettingsManager]: Preferences different from defaults after loading the file: [2022-02-20 21:08:03,568 INFO L136 SettingsManager]: Preferences of UltimateCore differ from their defaults: [2022-02-20 21:08:03,569 INFO L138 SettingsManager]: * Log level for class=de.uni_freiburg.informatik.ultimate.lib.smtlibutils.quantifier.QuantifierPusher=ERROR; [2022-02-20 21:08:03,569 INFO L136 SettingsManager]: Preferences of Boogie Procedure Inliner differ from their defaults: [2022-02-20 21:08:03,570 INFO L138 SettingsManager]: * Ignore calls to procedures called more than once=ONLY_FOR_SEQUENTIAL_PROGRAMS [2022-02-20 21:08:03,570 INFO L136 SettingsManager]: Preferences of BlockEncodingV2 differ from their defaults: [2022-02-20 21:08:03,571 INFO L138 SettingsManager]: * Create parallel compositions if possible=false [2022-02-20 21:08:03,571 INFO L138 SettingsManager]: * Use SBE=true [2022-02-20 21:08:03,571 INFO L136 SettingsManager]: Preferences of CACSL2BoogieTranslator differ from their defaults: [2022-02-20 21:08:03,572 INFO L138 SettingsManager]: * Overapproximate operations on floating types=true [2022-02-20 21:08:03,572 INFO L138 SettingsManager]: * Check division by zero=IGNORE [2022-02-20 21:08:03,572 INFO L138 SettingsManager]: * Pointer to allocated memory at dereference=IGNORE [2022-02-20 21:08:03,572 INFO L138 SettingsManager]: * If two pointers are subtracted or compared they have the same base address=IGNORE [2022-02-20 21:08:03,573 INFO L138 SettingsManager]: * Check array bounds for arrays that are off heap=IGNORE [2022-02-20 21:08:03,573 INFO L138 SettingsManager]: * Check if freed pointer was valid=false [2022-02-20 21:08:03,573 INFO L138 SettingsManager]: * Use constant arrays=true [2022-02-20 21:08:03,573 INFO L138 SettingsManager]: * Pointer base address is valid at dereference=IGNORE [2022-02-20 21:08:03,573 INFO L136 SettingsManager]: Preferences of RCFGBuilder differ from their defaults: [2022-02-20 21:08:03,574 INFO L138 SettingsManager]: * Size of a code block=SequenceOfStatements [2022-02-20 21:08:03,574 INFO L138 SettingsManager]: * SMT solver=External_DefaultMode [2022-02-20 21:08:03,574 INFO L138 SettingsManager]: * Command for external solver=z3 SMTLIB2_COMPLIANT=true -memory:2024 -smt2 -in -t:2000 [2022-02-20 21:08:03,574 INFO L136 SettingsManager]: Preferences of TraceAbstraction differ from their defaults: [2022-02-20 21:08:03,574 INFO L138 SettingsManager]: * Compute Interpolants along a Counterexample=FPandBP [2022-02-20 21:08:03,575 INFO L138 SettingsManager]: * Positions where we compute the Hoare Annotation=LoopsAndPotentialCycles [2022-02-20 21:08:03,575 INFO L138 SettingsManager]: * Trace refinement strategy=CAMEL [2022-02-20 21:08:03,575 INFO L138 SettingsManager]: * Command for external solver=z3 SMTLIB2_COMPLIANT=true -memory:2024 -smt2 -in [2022-02-20 21:08:03,577 INFO L138 SettingsManager]: * Large block encoding in concurrent analysis=OFF [2022-02-20 21:08:03,577 INFO L138 SettingsManager]: * Automaton type used in concurrency analysis=PETRI_NET [2022-02-20 21:08:03,577 INFO L138 SettingsManager]: * Compute Hoare Annotation of negated interpolant automaton, abstraction and CFG=true [2022-02-20 21:08:03,577 INFO L138 SettingsManager]: * SMT solver=External_ModelsAndUnsatCoreMode WARNING: An illegal reflective access operation has occurred WARNING: Illegal reflective access by com.sun.xml.bind.v2.runtime.reflect.opt.Injector$1 (file:/storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/plugins/com.sun.xml.bind_2.2.0.v201505121915.jar) to method java.lang.ClassLoader.defineClass(java.lang.String,byte[],int,int) WARNING: Please consider reporting this to the maintainers of com.sun.xml.bind.v2.runtime.reflect.opt.Injector$1 WARNING: Use --illegal-access=warn to enable warnings of further illegal reflective access operations WARNING: All illegal access operations will be denied in a future release Applying setting for plugin de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator: Entry function -> main Applying setting for plugin de.uni_freiburg.informatik.ultimate.witnessprinter: Witness directory -> /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux Applying setting for plugin de.uni_freiburg.informatik.ultimate.witnessprinter: Witness filename -> witness.graphml Applying setting for plugin de.uni_freiburg.informatik.ultimate.witnessprinter: Write witness besides input file -> false Applying setting for plugin de.uni_freiburg.informatik.ultimate.witnessprinter: Graph data specification -> CHECK( init(main()), LTL(G ! call(reach_error())) ) Applying setting for plugin de.uni_freiburg.informatik.ultimate.witnessprinter: Graph data producer -> Automizer Applying setting for plugin de.uni_freiburg.informatik.ultimate.witnessprinter: Graph data architecture -> 64bit Applying setting for plugin de.uni_freiburg.informatik.ultimate.witnessprinter: Graph data programhash -> 617e08addfe2d13b261907959d3757079a581721356bb3e7b4090decaff2b168 [2022-02-20 21:08:03,803 INFO L75 nceAwareModelManager]: Repository-Root is: /tmp [2022-02-20 21:08:03,826 INFO L261 ainManager$Toolchain]: [Toolchain 1]: Applicable parser(s) successfully (re)initialized [2022-02-20 21:08:03,829 INFO L217 ainManager$Toolchain]: [Toolchain 1]: Toolchain selected. [2022-02-20 21:08:03,831 INFO L271 PluginConnector]: Initializing CDTParser... [2022-02-20 21:08:03,831 INFO L275 PluginConnector]: CDTParser initialized [2022-02-20 21:08:03,833 INFO L432 ainManager$Toolchain]: [Toolchain 1]: Parsing single file: /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/../sv-benchmarks/c/aws-c-common/aws_hash_callback_string_eq_harness.i [2022-02-20 21:08:03,899 INFO L220 CDTParser]: Created temporary CDT project at /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/data/e5ed9349c/6e79b8603d4d49158d7e0c1d8c7e59a9/FLAGc24070209 [2022-02-20 21:08:04,661 INFO L306 CDTParser]: Found 1 translation units. [2022-02-20 21:08:04,662 INFO L160 CDTParser]: Scanning /storage/repos/ultimate/releaseScripts/default/sv-benchmarks/c/aws-c-common/aws_hash_callback_string_eq_harness.i [2022-02-20 21:08:04,708 INFO L349 CDTParser]: About to delete temporary CDT project at /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/data/e5ed9349c/6e79b8603d4d49158d7e0c1d8c7e59a9/FLAGc24070209 [2022-02-20 21:08:04,737 INFO L357 CDTParser]: Successfully deleted /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/data/e5ed9349c/6e79b8603d4d49158d7e0c1d8c7e59a9 [2022-02-20 21:08:04,739 INFO L299 ainManager$Toolchain]: ####################### [Toolchain 1] ####################### [2022-02-20 21:08:04,741 INFO L131 ToolchainWalker]: Walking toolchain with 6 elements. [2022-02-20 21:08:04,744 INFO L113 PluginConnector]: ------------------------CACSL2BoogieTranslator---------------------------- [2022-02-20 21:08:04,744 INFO L271 PluginConnector]: Initializing CACSL2BoogieTranslator... [2022-02-20 21:08:04,747 INFO L275 PluginConnector]: CACSL2BoogieTranslator initialized [2022-02-20 21:08:04,748 INFO L185 PluginConnector]: Executing the observer ACSLObjectContainerObserver from plugin CACSL2BoogieTranslator for "CDTParser AST 20.02 09:08:04" (1/1) ... [2022-02-20 21:08:04,749 INFO L205 PluginConnector]: Invalid model from CACSL2BoogieTranslator for observer de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator.ACSLObjectContainerObserver@165b689 and model type de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 09:08:04, skipping insertion in model container [2022-02-20 21:08:04,750 INFO L185 PluginConnector]: Executing the observer CACSL2BoogieTranslatorObserver from plugin CACSL2BoogieTranslator for "CDTParser AST 20.02 09:08:04" (1/1) ... [2022-02-20 21:08:04,755 INFO L145 MainTranslator]: Starting translation in SV-COMP mode [2022-02-20 21:08:04,874 INFO L178 MainTranslator]: Built tables and reachable declarations [2022-02-20 21:08:05,204 WARN L230 ndardFunctionHandler]: Function reach_error is already implemented but we override the implementation for the call at /storage/repos/ultimate/releaseScripts/default/sv-benchmarks/c/aws-c-common/aws_hash_callback_string_eq_harness.i[4501,4514] [2022-02-20 21:08:05,212 WARN L230 ndardFunctionHandler]: Function reach_error is already implemented but we override the implementation for the call at /storage/repos/ultimate/releaseScripts/default/sv-benchmarks/c/aws-c-common/aws_hash_callback_string_eq_harness.i[4561,4574] [2022-02-20 21:08:06,159 WARN L1545 CHandler]: Possible shadowing of function index [2022-02-20 21:08:06,159 WARN L1545 CHandler]: Possible shadowing of function index [2022-02-20 21:08:06,160 WARN L1545 CHandler]: Possible shadowing of function index [2022-02-20 21:08:06,169 WARN L1545 CHandler]: Possible shadowing of function index [2022-02-20 21:08:06,172 WARN L1545 CHandler]: Possible shadowing of function index [2022-02-20 21:08:06,185 WARN L1545 CHandler]: Possible shadowing of function index [2022-02-20 21:08:06,186 WARN L1545 CHandler]: Possible shadowing of function index [2022-02-20 21:08:06,187 WARN L1545 CHandler]: Possible shadowing of function index [2022-02-20 21:08:06,188 WARN L1545 CHandler]: Possible shadowing of function index [2022-02-20 21:08:06,572 WARN L611 FunctionHandler]: implicit declaration of function __atomic_load_n [2022-02-20 21:08:06,573 WARN L611 FunctionHandler]: implicit declaration of function __atomic_store_n [2022-02-20 21:08:06,574 WARN L611 FunctionHandler]: implicit declaration of function __atomic_exchange_n [2022-02-20 21:08:06,575 WARN L611 FunctionHandler]: implicit declaration of function __atomic_compare_exchange_n [2022-02-20 21:08:06,579 WARN L611 FunctionHandler]: implicit declaration of function __atomic_fetch_add [2022-02-20 21:08:06,583 WARN L611 FunctionHandler]: implicit declaration of function __atomic_fetch_sub [2022-02-20 21:08:06,584 WARN L611 FunctionHandler]: implicit declaration of function __atomic_fetch_or [2022-02-20 21:08:06,586 WARN L611 FunctionHandler]: implicit declaration of function __atomic_fetch_and [2022-02-20 21:08:06,587 WARN L611 FunctionHandler]: implicit declaration of function __atomic_fetch_xor [2022-02-20 21:08:06,591 WARN L611 FunctionHandler]: implicit declaration of function __atomic_thread_fence [2022-02-20 21:08:06,749 WARN L611 FunctionHandler]: implicit declaration of function __builtin_va_copy [2022-02-20 21:08:06,838 WARN L1545 CHandler]: Possible shadowing of function index [2022-02-20 21:08:06,838 WARN L1545 CHandler]: Possible shadowing of function index [2022-02-20 21:08:07,116 WARN L1545 CHandler]: Possible shadowing of function index [2022-02-20 21:08:07,117 WARN L1545 CHandler]: Possible shadowing of function index [2022-02-20 21:08:07,146 WARN L1545 CHandler]: Possible shadowing of function index [2022-02-20 21:08:07,148 WARN L1545 CHandler]: Possible shadowing of function index [2022-02-20 21:08:07,154 WARN L1545 CHandler]: Possible shadowing of function index [2022-02-20 21:08:07,155 WARN L1545 CHandler]: Possible shadowing of function index [2022-02-20 21:08:07,177 WARN L1545 CHandler]: Possible shadowing of function index [2022-02-20 21:08:07,179 WARN L1545 CHandler]: Possible shadowing of function index [2022-02-20 21:08:07,180 WARN L1545 CHandler]: Possible shadowing of function index [2022-02-20 21:08:07,180 WARN L1545 CHandler]: Possible shadowing of function index [2022-02-20 21:08:07,180 WARN L1545 CHandler]: Possible shadowing of function index [2022-02-20 21:08:07,181 WARN L1545 CHandler]: Possible shadowing of function index [2022-02-20 21:08:07,182 WARN L1545 CHandler]: Possible shadowing of function index [2022-02-20 21:08:07,245 INFO L210 PostProcessor]: Analyzing one entry point: main [2022-02-20 21:08:07,292 INFO L203 MainTranslator]: Completed pre-run [2022-02-20 21:08:07,309 WARN L230 ndardFunctionHandler]: Function reach_error is already implemented but we override the implementation for the call at /storage/repos/ultimate/releaseScripts/default/sv-benchmarks/c/aws-c-common/aws_hash_callback_string_eq_harness.i[4501,4514] [2022-02-20 21:08:07,310 WARN L230 ndardFunctionHandler]: Function reach_error is already implemented but we override the implementation for the call at /storage/repos/ultimate/releaseScripts/default/sv-benchmarks/c/aws-c-common/aws_hash_callback_string_eq_harness.i[4561,4574] [2022-02-20 21:08:07,347 WARN L1545 CHandler]: Possible shadowing of function index [2022-02-20 21:08:07,347 WARN L1545 CHandler]: Possible shadowing of function index [2022-02-20 21:08:07,348 WARN L1545 CHandler]: Possible shadowing of function index [2022-02-20 21:08:07,348 WARN L1545 CHandler]: Possible shadowing of function index [2022-02-20 21:08:07,348 WARN L1545 CHandler]: Possible shadowing of function index [2022-02-20 21:08:07,355 WARN L1545 CHandler]: Possible shadowing of function index [2022-02-20 21:08:07,355 WARN L1545 CHandler]: Possible shadowing of function index [2022-02-20 21:08:07,356 WARN L1545 CHandler]: Possible shadowing of function index [2022-02-20 21:08:07,356 WARN L1545 CHandler]: Possible shadowing of function index [2022-02-20 21:08:07,392 WARN L611 FunctionHandler]: implicit declaration of function __atomic_load_n [2022-02-20 21:08:07,393 WARN L611 FunctionHandler]: implicit declaration of function __atomic_store_n [2022-02-20 21:08:07,394 WARN L611 FunctionHandler]: implicit declaration of function __atomic_exchange_n [2022-02-20 21:08:07,395 WARN L611 FunctionHandler]: implicit declaration of function __atomic_compare_exchange_n [2022-02-20 21:08:07,395 WARN L611 FunctionHandler]: implicit declaration of function __atomic_fetch_add [2022-02-20 21:08:07,396 WARN L611 FunctionHandler]: implicit declaration of function __atomic_fetch_sub [2022-02-20 21:08:07,396 WARN L611 FunctionHandler]: implicit declaration of function __atomic_fetch_or [2022-02-20 21:08:07,397 WARN L611 FunctionHandler]: implicit declaration of function __atomic_fetch_and [2022-02-20 21:08:07,397 WARN L611 FunctionHandler]: implicit declaration of function __atomic_fetch_xor [2022-02-20 21:08:07,398 WARN L611 FunctionHandler]: implicit declaration of function __atomic_thread_fence [2022-02-20 21:08:07,415 WARN L611 FunctionHandler]: implicit declaration of function __builtin_va_copy [2022-02-20 21:08:07,485 WARN L1545 CHandler]: Possible shadowing of function index [2022-02-20 21:08:07,487 WARN L1545 CHandler]: Possible shadowing of function index [2022-02-20 21:08:07,566 WARN L1545 CHandler]: Possible shadowing of function index [2022-02-20 21:08:07,567 WARN L1545 CHandler]: Possible shadowing of function index [2022-02-20 21:08:07,579 WARN L1545 CHandler]: Possible shadowing of function index [2022-02-20 21:08:07,580 WARN L1545 CHandler]: Possible shadowing of function index [2022-02-20 21:08:07,585 WARN L1545 CHandler]: Possible shadowing of function index [2022-02-20 21:08:07,585 WARN L1545 CHandler]: Possible shadowing of function index [2022-02-20 21:08:07,594 WARN L1545 CHandler]: Possible shadowing of function index [2022-02-20 21:08:07,594 WARN L1545 CHandler]: Possible shadowing of function index [2022-02-20 21:08:07,595 WARN L1545 CHandler]: Possible shadowing of function index [2022-02-20 21:08:07,595 WARN L1545 CHandler]: Possible shadowing of function index [2022-02-20 21:08:07,596 WARN L1545 CHandler]: Possible shadowing of function index [2022-02-20 21:08:07,596 WARN L1545 CHandler]: Possible shadowing of function index [2022-02-20 21:08:07,596 WARN L1545 CHandler]: Possible shadowing of function index [2022-02-20 21:08:07,650 INFO L210 PostProcessor]: Analyzing one entry point: main [2022-02-20 21:08:07,922 INFO L208 MainTranslator]: Completed translation [2022-02-20 21:08:07,928 INFO L202 PluginConnector]: Adding new model de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 09:08:07 WrapperNode [2022-02-20 21:08:07,928 INFO L132 PluginConnector]: ------------------------ END CACSL2BoogieTranslator---------------------------- [2022-02-20 21:08:07,929 INFO L113 PluginConnector]: ------------------------Boogie Procedure Inliner---------------------------- [2022-02-20 21:08:07,929 INFO L271 PluginConnector]: Initializing Boogie Procedure Inliner... [2022-02-20 21:08:07,929 INFO L275 PluginConnector]: Boogie Procedure Inliner initialized [2022-02-20 21:08:07,935 INFO L185 PluginConnector]: Executing the observer TypeChecker from plugin Boogie Procedure Inliner for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 09:08:07" (1/1) ... [2022-02-20 21:08:08,037 INFO L185 PluginConnector]: Executing the observer Inliner from plugin Boogie Procedure Inliner for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 09:08:07" (1/1) ... [2022-02-20 21:08:08,126 INFO L137 Inliner]: procedures = 768, calls = 3257, calls flagged for inlining = 77, calls inlined = 7, statements flattened = 399 [2022-02-20 21:08:08,130 INFO L132 PluginConnector]: ------------------------ END Boogie Procedure Inliner---------------------------- [2022-02-20 21:08:08,131 INFO L113 PluginConnector]: ------------------------Boogie Preprocessor---------------------------- [2022-02-20 21:08:08,131 INFO L271 PluginConnector]: Initializing Boogie Preprocessor... [2022-02-20 21:08:08,131 INFO L275 PluginConnector]: Boogie Preprocessor initialized [2022-02-20 21:08:08,138 INFO L185 PluginConnector]: Executing the observer EnsureBoogieModelObserver from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 09:08:07" (1/1) ... [2022-02-20 21:08:08,139 INFO L185 PluginConnector]: Executing the observer TypeChecker from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 09:08:07" (1/1) ... [2022-02-20 21:08:08,150 INFO L185 PluginConnector]: Executing the observer ConstExpander from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 09:08:07" (1/1) ... [2022-02-20 21:08:08,151 INFO L185 PluginConnector]: Executing the observer StructExpander from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 09:08:07" (1/1) ... [2022-02-20 21:08:08,195 INFO L185 PluginConnector]: Executing the observer UnstructureCode from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 09:08:07" (1/1) ... [2022-02-20 21:08:08,208 INFO L185 PluginConnector]: Executing the observer FunctionInliner from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 09:08:07" (1/1) ... [2022-02-20 21:08:08,213 INFO L185 PluginConnector]: Executing the observer BoogieSymbolTableConstructor from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 09:08:07" (1/1) ... [2022-02-20 21:08:08,227 INFO L132 PluginConnector]: ------------------------ END Boogie Preprocessor---------------------------- [2022-02-20 21:08:08,228 INFO L113 PluginConnector]: ------------------------RCFGBuilder---------------------------- [2022-02-20 21:08:08,228 INFO L271 PluginConnector]: Initializing RCFGBuilder... [2022-02-20 21:08:08,228 INFO L275 PluginConnector]: RCFGBuilder initialized [2022-02-20 21:08:08,229 INFO L185 PluginConnector]: Executing the observer RCFGBuilderObserver from plugin RCFGBuilder for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 09:08:07" (1/1) ... [2022-02-20 21:08:08,234 INFO L173 SolverBuilder]: Constructing external solver with command: z3 SMTLIB2_COMPLIANT=true -memory:2024 -smt2 -in -t:2000 [2022-02-20 21:08:08,265 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-02-20 21:08:08,281 INFO L229 MonitoredProcess]: Starting monitored process 1 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 SMTLIB2_COMPLIANT=true -memory:2024 -smt2 -in -t:2000 (exit command is (exit), workingDir is null) [2022-02-20 21:08:08,306 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 SMTLIB2_COMPLIANT=true -memory:2024 -smt2 -in -t:2000 (1)] Waiting until timeout for monitored process [2022-02-20 21:08:08,320 INFO L130 BoogieDeclarations]: Found specification of procedure aws_string_is_valid [2022-02-20 21:08:08,321 INFO L138 BoogieDeclarations]: Found implementation of procedure aws_string_is_valid [2022-02-20 21:08:08,322 INFO L130 BoogieDeclarations]: Found specification of procedure ensure_string_is_allocated_bounded_length [2022-02-20 21:08:08,322 INFO L138 BoogieDeclarations]: Found implementation of procedure ensure_string_is_allocated_bounded_length [2022-02-20 21:08:08,322 INFO L130 BoogieDeclarations]: Found specification of procedure memcmp [2022-02-20 21:08:08,322 INFO L130 BoogieDeclarations]: Found specification of procedure nondet_bool [2022-02-20 21:08:08,322 INFO L138 BoogieDeclarations]: Found implementation of procedure nondet_bool [2022-02-20 21:08:08,322 INFO L130 BoogieDeclarations]: Found specification of procedure read~int [2022-02-20 21:08:08,323 INFO L130 BoogieDeclarations]: Found specification of procedure __VERIFIER_assert [2022-02-20 21:08:08,323 INFO L138 BoogieDeclarations]: Found implementation of procedure __VERIFIER_assert [2022-02-20 21:08:08,323 INFO L130 BoogieDeclarations]: Found specification of procedure #Ultimate.allocOnHeap [2022-02-20 21:08:08,323 INFO L130 BoogieDeclarations]: Found specification of procedure #Ultimate.allocInit [2022-02-20 21:08:08,323 INFO L130 BoogieDeclarations]: Found specification of procedure write~$Pointer$ [2022-02-20 21:08:08,323 INFO L130 BoogieDeclarations]: Found specification of procedure ULTIMATE.start [2022-02-20 21:08:08,323 INFO L138 BoogieDeclarations]: Found implementation of procedure ULTIMATE.start [2022-02-20 21:08:08,323 INFO L130 BoogieDeclarations]: Found specification of procedure bounded_malloc [2022-02-20 21:08:08,324 INFO L138 BoogieDeclarations]: Found implementation of procedure bounded_malloc [2022-02-20 21:08:08,324 INFO L130 BoogieDeclarations]: Found specification of procedure assume_abort_if_not [2022-02-20 21:08:08,324 INFO L138 BoogieDeclarations]: Found implementation of procedure assume_abort_if_not [2022-02-20 21:08:08,324 INFO L130 BoogieDeclarations]: Found specification of procedure aws_array_eq [2022-02-20 21:08:08,324 INFO L138 BoogieDeclarations]: Found implementation of procedure aws_array_eq [2022-02-20 21:08:08,324 INFO L130 BoogieDeclarations]: Found specification of procedure write~init~$Pointer$ [2022-02-20 21:08:08,325 INFO L130 BoogieDeclarations]: Found specification of procedure can_fail_allocator [2022-02-20 21:08:08,325 INFO L138 BoogieDeclarations]: Found implementation of procedure can_fail_allocator [2022-02-20 21:08:08,325 INFO L130 BoogieDeclarations]: Found specification of procedure nondet_uint64_t [2022-02-20 21:08:08,325 INFO L138 BoogieDeclarations]: Found implementation of procedure nondet_uint64_t [2022-02-20 21:08:08,325 INFO L130 BoogieDeclarations]: Found specification of procedure write~int [2022-02-20 21:08:08,325 INFO L130 BoogieDeclarations]: Found specification of procedure aws_c_string_is_valid [2022-02-20 21:08:08,325 INFO L138 BoogieDeclarations]: Found implementation of procedure aws_c_string_is_valid [2022-02-20 21:08:08,326 INFO L130 BoogieDeclarations]: Found specification of procedure write~init~int [2022-02-20 21:08:08,575 INFO L234 CfgBuilder]: Building ICFG [2022-02-20 21:08:08,577 INFO L260 CfgBuilder]: Building CFG for each procedure with an implementation [2022-02-20 21:08:08,961 INFO L766 $ProcedureCfgBuilder]: dead code at ProgramPoint $Ultimate##21: assume !true; [2022-02-20 21:08:08,977 INFO L275 CfgBuilder]: Performing block encoding [2022-02-20 21:08:08,985 INFO L294 CfgBuilder]: Using the 1 location(s) as analysis (start of procedure ULTIMATE.start) [2022-02-20 21:08:08,988 INFO L299 CfgBuilder]: Removed 2 assume(true) statements. [2022-02-20 21:08:08,990 INFO L202 PluginConnector]: Adding new model de.uni_freiburg.informatik.ultimate.plugins.generator.rcfgbuilder CFG 20.02 09:08:08 BoogieIcfgContainer [2022-02-20 21:08:08,991 INFO L132 PluginConnector]: ------------------------ END RCFGBuilder---------------------------- [2022-02-20 21:08:08,994 INFO L113 PluginConnector]: ------------------------TraceAbstraction---------------------------- [2022-02-20 21:08:08,994 INFO L271 PluginConnector]: Initializing TraceAbstraction... [2022-02-20 21:08:08,997 INFO L275 PluginConnector]: TraceAbstraction initialized [2022-02-20 21:08:08,998 INFO L185 PluginConnector]: Executing the observer TraceAbstractionObserver from plugin TraceAbstraction for "CDTParser AST 20.02 09:08:04" (1/3) ... [2022-02-20 21:08:08,998 INFO L205 PluginConnector]: Invalid model from TraceAbstraction for observer de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction.TraceAbstractionObserver@65d3581 and model type de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction AST 20.02 09:08:08, skipping insertion in model container [2022-02-20 21:08:08,998 INFO L185 PluginConnector]: Executing the observer TraceAbstractionObserver from plugin TraceAbstraction for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 09:08:07" (2/3) ... [2022-02-20 21:08:08,999 INFO L205 PluginConnector]: Invalid model from TraceAbstraction for observer de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction.TraceAbstractionObserver@65d3581 and model type de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction AST 20.02 09:08:08, skipping insertion in model container [2022-02-20 21:08:08,999 INFO L185 PluginConnector]: Executing the observer TraceAbstractionObserver from plugin TraceAbstraction for "de.uni_freiburg.informatik.ultimate.plugins.generator.rcfgbuilder CFG 20.02 09:08:08" (3/3) ... [2022-02-20 21:08:09,001 INFO L111 eAbstractionObserver]: Analyzing ICFG aws_hash_callback_string_eq_harness.i [2022-02-20 21:08:09,009 INFO L205 ceAbstractionStarter]: Automizer settings: Hoare:true NWA Interpolation:FPandBP Determinization: PREDICATE_ABSTRACTION [2022-02-20 21:08:09,011 INFO L164 ceAbstractionStarter]: Applying trace abstraction to program that has 1 error locations. [2022-02-20 21:08:09,063 INFO L338 AbstractCegarLoop]: ======== Iteration 0 == of CEGAR loop == AllErrorsAtOnce ======== [2022-02-20 21:08:09,070 INFO L339 AbstractCegarLoop]: Settings: SEPARATE_VIOLATION_CHECK=true, mInterprocedural=true, mMaxIterations=1000000, mWatchIteration=1000000, mArtifact=RCFG, mInterpolation=FPandBP, mInterpolantAutomaton=STRAIGHT_LINE, mDumpAutomata=false, mAutomataFormat=ATS_NUMERATE, mDumpPath=., mDeterminiation=PREDICATE_ABSTRACTION, mMinimize=MINIMIZE_SEVPA, mHoare=true, mAutomataTypeConcurrency=PETRI_NET, mHoareTripleChecks=INCREMENTAL, mHoareAnnotationPositions=LoopsAndPotentialCycles, mDumpOnlyReuseAutomata=false, mLimitTraceHistogram=0, mErrorLocTimeLimit=0, mLimitPathProgramCount=0, mCollectInterpolantStatistics=true, mHeuristicEmptinessCheck=false, mHeuristicEmptinessCheckAStarHeuristic=ZERO, mHeuristicEmptinessCheckAStarHeuristicRandomSeed=1337, mHeuristicEmptinessCheckSmtFeatureScoringMethod=DAGSIZE, mSMTFeatureExtraction=false, mSMTFeatureExtractionDumpPath=., mOverrideInterpolantAutomaton=false, mMcrInterpolantMethod=WP, mLoopAccelerationTechnique=FAST_UPR [2022-02-20 21:08:09,071 INFO L340 AbstractCegarLoop]: Starting to check reachability of 1 error locations. [2022-02-20 21:08:09,088 INFO L276 IsEmpty]: Start isEmpty. Operand has 110 states, 71 states have (on average 1.2253521126760563) internal successors, (87), 71 states have internal predecessors, (87), 28 states have call successors, (28), 10 states have call predecessors, (28), 10 states have return successors, (28), 28 states have call predecessors, (28), 28 states have call successors, (28) [2022-02-20 21:08:09,096 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 94 [2022-02-20 21:08:09,096 INFO L506 BasicCegarLoop]: Found error trace [2022-02-20 21:08:09,097 INFO L514 BasicCegarLoop]: trace histogram [6, 6, 6, 2, 2, 2, 2, 2, 2, 2, 2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2022-02-20 21:08:09,097 INFO L402 AbstractCegarLoop]: === Iteration 1 === Targeting __VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION === [__VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-02-20 21:08:09,101 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-02-20 21:08:09,102 INFO L85 PathProgramCache]: Analyzing trace with hash -1707101443, now seen corresponding path program 1 times [2022-02-20 21:08:09,108 INFO L126 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-02-20 21:08:09,108 INFO L338 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [269402821] [2022-02-20 21:08:09,108 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 21:08:09,109 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-02-20 21:08:09,370 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:09,562 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 2 [2022-02-20 21:08:09,595 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:09,623 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:08:09,624 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:09,639 INFO L290 TraceCheckUtils]: 0: Hoare triple {113#true} #res := #t~nondet13;havoc #t~nondet13; {113#true} is VALID [2022-02-20 21:08:09,639 INFO L290 TraceCheckUtils]: 1: Hoare triple {113#true} assume true; {113#true} is VALID [2022-02-20 21:08:09,639 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {113#true} {113#true} #182#return; {113#true} is VALID [2022-02-20 21:08:09,640 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 6 [2022-02-20 21:08:09,642 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:09,652 INFO L290 TraceCheckUtils]: 0: Hoare triple {113#true} ~cond := #in~cond; {113#true} is VALID [2022-02-20 21:08:09,653 INFO L290 TraceCheckUtils]: 1: Hoare triple {113#true} assume 0 == ~cond % 256;assume false; {114#false} is VALID [2022-02-20 21:08:09,654 INFO L290 TraceCheckUtils]: 2: Hoare triple {114#false} assume true; {114#false} is VALID [2022-02-20 21:08:09,654 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {114#false} {113#true} #184#return; {114#false} is VALID [2022-02-20 21:08:09,660 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 12 [2022-02-20 21:08:09,664 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:09,676 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:08:09,677 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:09,712 INFO L290 TraceCheckUtils]: 0: Hoare triple {113#true} ~cond := #in~cond; {113#true} is VALID [2022-02-20 21:08:09,713 INFO L290 TraceCheckUtils]: 1: Hoare triple {113#true} assume 0 == ~cond % 256;assume false; {114#false} is VALID [2022-02-20 21:08:09,713 INFO L290 TraceCheckUtils]: 2: Hoare triple {114#false} assume true; {114#false} is VALID [2022-02-20 21:08:09,713 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {114#false} {113#true} #192#return; {114#false} is VALID [2022-02-20 21:08:09,714 INFO L290 TraceCheckUtils]: 0: Hoare triple {200#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size; {113#true} is VALID [2022-02-20 21:08:09,714 INFO L272 TraceCheckUtils]: 1: Hoare triple {113#true} call assume_abort_if_not((if 0 == (if ~size % 18446744073709551616 <= 36028797018963967 then 1 else 0) then 0 else 1)); {113#true} is VALID [2022-02-20 21:08:09,714 INFO L290 TraceCheckUtils]: 2: Hoare triple {113#true} ~cond := #in~cond; {113#true} is VALID [2022-02-20 21:08:09,715 INFO L290 TraceCheckUtils]: 3: Hoare triple {113#true} assume 0 == ~cond % 256;assume false; {114#false} is VALID [2022-02-20 21:08:09,715 INFO L290 TraceCheckUtils]: 4: Hoare triple {114#false} assume true; {114#false} is VALID [2022-02-20 21:08:09,716 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {114#false} {113#true} #192#return; {114#false} is VALID [2022-02-20 21:08:09,716 INFO L290 TraceCheckUtils]: 6: Hoare triple {114#false} call #t~malloc555.base, #t~malloc555.offset := #Ultimate.allocOnHeap(~size);#res.base, #res.offset := #t~malloc555.base, #t~malloc555.offset;havoc #t~malloc555.base, #t~malloc555.offset; {114#false} is VALID [2022-02-20 21:08:09,716 INFO L290 TraceCheckUtils]: 7: Hoare triple {114#false} assume true; {114#false} is VALID [2022-02-20 21:08:09,716 INFO L284 TraceCheckUtils]: 8: Hoare quadruple {114#false} {114#false} #186#return; {114#false} is VALID [2022-02-20 21:08:09,717 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 23 [2022-02-20 21:08:09,718 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:09,729 INFO L290 TraceCheckUtils]: 0: Hoare triple {113#true} #res := #t~nondet8;havoc #t~nondet8; {113#true} is VALID [2022-02-20 21:08:09,729 INFO L290 TraceCheckUtils]: 1: Hoare triple {113#true} assume true; {113#true} is VALID [2022-02-20 21:08:09,730 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {113#true} {114#false} #188#return; {114#false} is VALID [2022-02-20 21:08:09,730 INFO L290 TraceCheckUtils]: 0: Hoare triple {180#(and (= |old(#length)| |#length|) (= |old(#memory_real)| |#memory_real|) (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|) (= |old(#valid)| |#valid|))} ~max_size#1 := #in~max_size#1; {113#true} is VALID [2022-02-20 21:08:09,730 INFO L272 TraceCheckUtils]: 1: Hoare triple {113#true} call #t~ret540#1 := nondet_uint64_t(); {113#true} is VALID [2022-02-20 21:08:09,731 INFO L290 TraceCheckUtils]: 2: Hoare triple {113#true} #res := #t~nondet13;havoc #t~nondet13; {113#true} is VALID [2022-02-20 21:08:09,731 INFO L290 TraceCheckUtils]: 3: Hoare triple {113#true} assume true; {113#true} is VALID [2022-02-20 21:08:09,731 INFO L284 TraceCheckUtils]: 4: Hoare quadruple {113#true} {113#true} #182#return; {113#true} is VALID [2022-02-20 21:08:09,731 INFO L290 TraceCheckUtils]: 5: Hoare triple {113#true} ~len~1#1 := #t~ret540#1;havoc #t~ret540#1; {113#true} is VALID [2022-02-20 21:08:09,732 INFO L272 TraceCheckUtils]: 6: Hoare triple {113#true} call assume_abort_if_not((if 0 == (if ~len~1#1 % 18446744073709551616 < ~max_size#1 % 18446744073709551616 then 1 else 0) then 0 else 1)); {113#true} is VALID [2022-02-20 21:08:09,732 INFO L290 TraceCheckUtils]: 7: Hoare triple {113#true} ~cond := #in~cond; {113#true} is VALID [2022-02-20 21:08:09,733 INFO L290 TraceCheckUtils]: 8: Hoare triple {113#true} assume 0 == ~cond % 256;assume false; {114#false} is VALID [2022-02-20 21:08:09,733 INFO L290 TraceCheckUtils]: 9: Hoare triple {114#false} assume true; {114#false} is VALID [2022-02-20 21:08:09,733 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {114#false} {113#true} #184#return; {114#false} is VALID [2022-02-20 21:08:09,734 INFO L290 TraceCheckUtils]: 11: Hoare triple {114#false} assume { :begin_inline_ensure_string_is_allocated } true;ensure_string_is_allocated_#in~len#1 := ~len~1#1;havoc ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset;havoc ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset, ensure_string_is_allocated_#t~ret543#1, ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset, ensure_string_is_allocated_#t~ret544#1.base, ensure_string_is_allocated_#t~ret544#1.offset, ensure_string_is_allocated_~len#1, ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset;ensure_string_is_allocated_~len#1 := ensure_string_is_allocated_#in~len#1; {114#false} is VALID [2022-02-20 21:08:09,734 INFO L272 TraceCheckUtils]: 12: Hoare triple {114#false} call ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset := bounded_malloc(-1234550 + ensure_string_is_allocated_~len#1); {200#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:08:09,734 INFO L290 TraceCheckUtils]: 13: Hoare triple {200#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size; {113#true} is VALID [2022-02-20 21:08:09,734 INFO L272 TraceCheckUtils]: 14: Hoare triple {113#true} call assume_abort_if_not((if 0 == (if ~size % 18446744073709551616 <= 36028797018963967 then 1 else 0) then 0 else 1)); {113#true} is VALID [2022-02-20 21:08:09,735 INFO L290 TraceCheckUtils]: 15: Hoare triple {113#true} ~cond := #in~cond; {113#true} is VALID [2022-02-20 21:08:09,735 INFO L290 TraceCheckUtils]: 16: Hoare triple {113#true} assume 0 == ~cond % 256;assume false; {114#false} is VALID [2022-02-20 21:08:09,736 INFO L290 TraceCheckUtils]: 17: Hoare triple {114#false} assume true; {114#false} is VALID [2022-02-20 21:08:09,736 INFO L284 TraceCheckUtils]: 18: Hoare quadruple {114#false} {113#true} #192#return; {114#false} is VALID [2022-02-20 21:08:09,736 INFO L290 TraceCheckUtils]: 19: Hoare triple {114#false} call #t~malloc555.base, #t~malloc555.offset := #Ultimate.allocOnHeap(~size);#res.base, #res.offset := #t~malloc555.base, #t~malloc555.offset;havoc #t~malloc555.base, #t~malloc555.offset; {114#false} is VALID [2022-02-20 21:08:09,736 INFO L290 TraceCheckUtils]: 20: Hoare triple {114#false} assume true; {114#false} is VALID [2022-02-20 21:08:09,737 INFO L284 TraceCheckUtils]: 21: Hoare quadruple {114#false} {114#false} #186#return; {114#false} is VALID [2022-02-20 21:08:09,737 INFO L290 TraceCheckUtils]: 22: Hoare triple {114#false} ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset := ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset;havoc ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset; {114#false} is VALID [2022-02-20 21:08:09,737 INFO L272 TraceCheckUtils]: 23: Hoare triple {114#false} call ensure_string_is_allocated_#t~ret543#1 := nondet_bool(); {113#true} is VALID [2022-02-20 21:08:09,737 INFO L290 TraceCheckUtils]: 24: Hoare triple {113#true} #res := #t~nondet8;havoc #t~nondet8; {113#true} is VALID [2022-02-20 21:08:09,738 INFO L290 TraceCheckUtils]: 25: Hoare triple {113#true} assume true; {113#true} is VALID [2022-02-20 21:08:09,738 INFO L284 TraceCheckUtils]: 26: Hoare quadruple {113#true} {114#false} #188#return; {114#false} is VALID [2022-02-20 21:08:09,738 INFO L290 TraceCheckUtils]: 27: Hoare triple {114#false} assume !(0 != ensure_string_is_allocated_#t~ret543#1 % 256);ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset := 0, 0; {114#false} is VALID [2022-02-20 21:08:09,739 INFO L290 TraceCheckUtils]: 28: Hoare triple {114#false} call write~$Pointer$(ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset, ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset, 8);havoc ensure_string_is_allocated_#t~ret543#1;havoc ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset;havoc ensure_string_is_allocated_#t~ret544#1.base, ensure_string_is_allocated_#t~ret544#1.offset;call write~int(ensure_string_is_allocated_~len#1, ensure_string_is_allocated_~str~0#1.base, 8 + ensure_string_is_allocated_~str~0#1.offset, 8);call write~int(0, ensure_string_is_allocated_~str~0#1.base, 16 + ensure_string_is_allocated_~str~0#1.offset + (if ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 else ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset := ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset; {114#false} is VALID [2022-02-20 21:08:09,739 INFO L290 TraceCheckUtils]: 29: Hoare triple {114#false} #t~ret541#1.base, #t~ret541#1.offset := ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset;assume { :end_inline_ensure_string_is_allocated } true;#res#1.base, #res#1.offset := #t~ret541#1.base, #t~ret541#1.offset;havoc #t~ret541#1.base, #t~ret541#1.offset; {114#false} is VALID [2022-02-20 21:08:09,739 INFO L290 TraceCheckUtils]: 30: Hoare triple {114#false} assume true; {114#false} is VALID [2022-02-20 21:08:09,739 INFO L284 TraceCheckUtils]: 31: Hoare quadruple {114#false} {113#true} #198#return; {114#false} is VALID [2022-02-20 21:08:09,740 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 36 [2022-02-20 21:08:09,742 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:09,753 INFO L290 TraceCheckUtils]: 0: Hoare triple {113#true} #res := #t~nondet8;havoc #t~nondet8; {113#true} is VALID [2022-02-20 21:08:09,753 INFO L290 TraceCheckUtils]: 1: Hoare triple {113#true} assume true; {113#true} is VALID [2022-02-20 21:08:09,754 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {113#true} {114#false} #200#return; {114#false} is VALID [2022-02-20 21:08:09,754 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 42 [2022-02-20 21:08:09,760 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:09,774 INFO L290 TraceCheckUtils]: 0: Hoare triple {113#true} ~str.base, ~str.offset := #in~str.base, #in~str.offset;#t~short464 := ~str.base != 0 || ~str.offset != 0; {113#true} is VALID [2022-02-20 21:08:09,775 INFO L290 TraceCheckUtils]: 1: Hoare triple {113#true} assume #t~short464;call #t~mem463 := read~int(~str.base, 8 + ~str.offset, 8);#t~short464 := 0 == (1 + #t~mem463) % 18446744073709551616 || ~str.base != 0 || 16 + ~str.offset != 0; {113#true} is VALID [2022-02-20 21:08:09,775 INFO L290 TraceCheckUtils]: 2: Hoare triple {113#true} #t~short467 := #t~short464; {113#true} is VALID [2022-02-20 21:08:09,775 INFO L290 TraceCheckUtils]: 3: Hoare triple {113#true} assume #t~short467;call #t~mem465 := read~int(~str.base, 8 + ~str.offset, 8);call #t~mem466 := read~int(~str.base, 16 + ~str.offset + (if #t~mem465 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then #t~mem465 % 18446744073709551616 % 18446744073709551616 else #t~mem465 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);#t~short467 := 0 == #t~mem466 % 256; {113#true} is VALID [2022-02-20 21:08:09,776 INFO L290 TraceCheckUtils]: 4: Hoare triple {113#true} #res := (if 0 == (if #t~short467 then 1 else 0) then 0 else 1);havoc #t~mem463;havoc #t~short464;havoc #t~mem465;havoc #t~mem466;havoc #t~short467; {113#true} is VALID [2022-02-20 21:08:09,776 INFO L290 TraceCheckUtils]: 5: Hoare triple {113#true} assume true; {113#true} is VALID [2022-02-20 21:08:09,776 INFO L284 TraceCheckUtils]: 6: Hoare quadruple {113#true} {114#false} #204#return; {114#false} is VALID [2022-02-20 21:08:09,777 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 50 [2022-02-20 21:08:09,778 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:09,789 INFO L290 TraceCheckUtils]: 0: Hoare triple {113#true} ~cond := #in~cond; {113#true} is VALID [2022-02-20 21:08:09,790 INFO L290 TraceCheckUtils]: 1: Hoare triple {113#true} assume 0 == ~cond % 256;assume false; {114#false} is VALID [2022-02-20 21:08:09,790 INFO L290 TraceCheckUtils]: 2: Hoare triple {114#false} assume true; {114#false} is VALID [2022-02-20 21:08:09,790 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {114#false} {114#false} #206#return; {114#false} is VALID [2022-02-20 21:08:09,791 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 56 [2022-02-20 21:08:09,796 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:09,811 INFO L290 TraceCheckUtils]: 0: Hoare triple {113#true} ~str.base, ~str.offset := #in~str.base, #in~str.offset;#t~short464 := ~str.base != 0 || ~str.offset != 0; {113#true} is VALID [2022-02-20 21:08:09,812 INFO L290 TraceCheckUtils]: 1: Hoare triple {113#true} assume #t~short464;call #t~mem463 := read~int(~str.base, 8 + ~str.offset, 8);#t~short464 := 0 == (1 + #t~mem463) % 18446744073709551616 || ~str.base != 0 || 16 + ~str.offset != 0; {113#true} is VALID [2022-02-20 21:08:09,812 INFO L290 TraceCheckUtils]: 2: Hoare triple {113#true} #t~short467 := #t~short464; {113#true} is VALID [2022-02-20 21:08:09,812 INFO L290 TraceCheckUtils]: 3: Hoare triple {113#true} assume #t~short467;call #t~mem465 := read~int(~str.base, 8 + ~str.offset, 8);call #t~mem466 := read~int(~str.base, 16 + ~str.offset + (if #t~mem465 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then #t~mem465 % 18446744073709551616 % 18446744073709551616 else #t~mem465 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);#t~short467 := 0 == #t~mem466 % 256; {113#true} is VALID [2022-02-20 21:08:09,812 INFO L290 TraceCheckUtils]: 4: Hoare triple {113#true} #res := (if 0 == (if #t~short467 then 1 else 0) then 0 else 1);havoc #t~mem463;havoc #t~short464;havoc #t~mem465;havoc #t~mem466;havoc #t~short467; {113#true} is VALID [2022-02-20 21:08:09,813 INFO L290 TraceCheckUtils]: 5: Hoare triple {113#true} assume true; {113#true} is VALID [2022-02-20 21:08:09,813 INFO L284 TraceCheckUtils]: 6: Hoare quadruple {113#true} {114#false} #208#return; {114#false} is VALID [2022-02-20 21:08:09,813 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 64 [2022-02-20 21:08:09,815 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:09,826 INFO L290 TraceCheckUtils]: 0: Hoare triple {113#true} ~cond := #in~cond; {113#true} is VALID [2022-02-20 21:08:09,827 INFO L290 TraceCheckUtils]: 1: Hoare triple {113#true} assume 0 == ~cond % 256;assume false; {114#false} is VALID [2022-02-20 21:08:09,827 INFO L290 TraceCheckUtils]: 2: Hoare triple {114#false} assume true; {114#false} is VALID [2022-02-20 21:08:09,827 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {114#false} {114#false} #210#return; {114#false} is VALID [2022-02-20 21:08:09,828 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 71 [2022-02-20 21:08:09,829 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:09,840 INFO L290 TraceCheckUtils]: 0: Hoare triple {113#true} ~cond := #in~cond; {113#true} is VALID [2022-02-20 21:08:09,841 INFO L290 TraceCheckUtils]: 1: Hoare triple {113#true} assume 0 == ~cond % 256;assume false; {114#false} is VALID [2022-02-20 21:08:09,841 INFO L290 TraceCheckUtils]: 2: Hoare triple {114#false} assume true; {114#false} is VALID [2022-02-20 21:08:09,841 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {114#false} {114#false} #214#return; {114#false} is VALID [2022-02-20 21:08:09,842 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 78 [2022-02-20 21:08:09,843 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:09,854 INFO L290 TraceCheckUtils]: 0: Hoare triple {113#true} ~cond := #in~cond; {113#true} is VALID [2022-02-20 21:08:09,855 INFO L290 TraceCheckUtils]: 1: Hoare triple {113#true} assume 0 == ~cond % 256;assume false; {114#false} is VALID [2022-02-20 21:08:09,855 INFO L290 TraceCheckUtils]: 2: Hoare triple {114#false} assume true; {114#false} is VALID [2022-02-20 21:08:09,856 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {114#false} {114#false} #218#return; {114#false} is VALID [2022-02-20 21:08:09,858 INFO L290 TraceCheckUtils]: 0: Hoare triple {113#true} assume { :begin_inline_ULTIMATE.init } true;#NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(38, 2);call #Ultimate.allocInit(12, 3);call #Ultimate.allocInit(78, 4);~#s_can_fail_allocator_static~0.base, ~#s_can_fail_allocator_static~0.offset := 5, 0;call #Ultimate.allocInit(40, 5);call write~init~$Pointer$(#funAddr~s_can_fail_malloc_allocator.base, #funAddr~s_can_fail_malloc_allocator.offset, ~#s_can_fail_allocator_static~0.base, ~#s_can_fail_allocator_static~0.offset, 8);call write~init~$Pointer$(#funAddr~s_can_fail_free_allocator.base, #funAddr~s_can_fail_free_allocator.offset, ~#s_can_fail_allocator_static~0.base, 8 + ~#s_can_fail_allocator_static~0.offset, 8);call write~init~$Pointer$(#funAddr~s_can_fail_realloc_allocator.base, #funAddr~s_can_fail_realloc_allocator.offset, ~#s_can_fail_allocator_static~0.base, 16 + ~#s_can_fail_allocator_static~0.offset, 8);call write~init~$Pointer$(#funAddr~s_can_fail_calloc_allocator.base, #funAddr~s_can_fail_calloc_allocator.offset, ~#s_can_fail_allocator_static~0.base, 24 + ~#s_can_fail_allocator_static~0.offset, 8);call write~init~$Pointer$(0, 0, ~#s_can_fail_allocator_static~0.base, 32 + ~#s_can_fail_allocator_static~0.offset, 8);~#s_tolower_table~0.base, ~#s_tolower_table~0.offset := 6, 0;call #Ultimate.allocInit(256, 6);call write~init~int(0, ~#s_tolower_table~0.base, ~#s_tolower_table~0.offset, 1);call write~init~int(1, ~#s_tolower_table~0.base, 1 + ~#s_tolower_table~0.offset, 1);call write~init~int(2, ~#s_tolower_table~0.base, 2 + ~#s_tolower_table~0.offset, 1);call write~init~int(3, ~#s_tolower_table~0.base, 3 + ~#s_tolower_table~0.offset, 1);call write~init~int(4, ~#s_tolower_table~0.base, 4 + ~#s_tolower_table~0.offset, 1);call write~init~int(5, ~#s_tolower_table~0.base, 5 + ~#s_tolower_table~0.offset, 1);call write~init~int(6, ~#s_tolower_table~0.base, 6 + ~#s_tolower_table~0.offset, 1);call write~init~int(7, ~#s_tolower_table~0.base, 7 + ~#s_tolower_table~0.offset, 1);call write~init~int(8, ~#s_tolower_table~0.base, 8 + ~#s_tolower_table~0.offset, 1);call write~init~int(9, ~#s_tolower_table~0.base, 9 + ~#s_tolower_table~0.offset, 1);call write~init~int(10, ~#s_tolower_table~0.base, 10 + ~#s_tolower_table~0.offset, 1);call write~init~int(11, ~#s_tolower_table~0.base, 11 + ~#s_tolower_table~0.offset, 1);call write~init~int(12, ~#s_tolower_table~0.base, 12 + ~#s_tolower_table~0.offset, 1);call write~init~int(13, ~#s_tolower_table~0.base, 13 + ~#s_tolower_table~0.offset, 1);call write~init~int(14, ~#s_tolower_table~0.base, 14 + ~#s_tolower_table~0.offset, 1);call write~init~int(15, ~#s_tolower_table~0.base, 15 + ~#s_tolower_table~0.offset, 1);call write~init~int(16, ~#s_tolower_table~0.base, 16 + ~#s_tolower_table~0.offset, 1);call write~init~int(17, ~#s_tolower_table~0.base, 17 + ~#s_tolower_table~0.offset, 1);call write~init~int(18, ~#s_tolower_table~0.base, 18 + ~#s_tolower_table~0.offset, 1);call write~init~int(19, ~#s_tolower_table~0.base, 19 + ~#s_tolower_table~0.offset, 1);call write~init~int(20, ~#s_tolower_table~0.base, 20 + ~#s_tolower_table~0.offset, 1);call write~init~int(21, ~#s_tolower_table~0.base, 21 + ~#s_tolower_table~0.offset, 1);call write~init~int(22, ~#s_tolower_table~0.base, 22 + ~#s_tolower_table~0.offset, 1);call write~init~int(23, ~#s_tolower_table~0.base, 23 + ~#s_tolower_table~0.offset, 1);call write~init~int(24, ~#s_tolower_table~0.base, 24 + ~#s_tolower_table~0.offset, 1);call write~init~int(25, ~#s_tolower_table~0.base, 25 + ~#s_tolower_table~0.offset, 1);call write~init~int(26, ~#s_tolower_table~0.base, 26 + ~#s_tolower_table~0.offset, 1);call write~init~int(27, ~#s_tolower_table~0.base, 27 + ~#s_tolower_table~0.offset, 1);call write~init~int(28, ~#s_tolower_table~0.base, 28 + ~#s_tolower_table~0.offset, 1);call write~init~int(29, ~#s_tolower_table~0.base, 29 + ~#s_tolower_table~0.offset, 1);call write~init~int(30, ~#s_tolower_table~0.base, 30 + ~#s_tolower_table~0.offset, 1);call write~init~int(31, ~#s_tolower_table~0.base, 31 + ~#s_tolower_table~0.offset, 1);call write~init~int(32, ~#s_tolower_table~0.base, 32 + ~#s_tolower_table~0.offset, 1);call write~init~int(33, ~#s_tolower_table~0.base, 33 + ~#s_tolower_table~0.offset, 1);call write~init~int(34, ~#s_tolower_table~0.base, 34 + ~#s_tolower_table~0.offset, 1);call write~init~int(35, ~#s_tolower_table~0.base, 35 + ~#s_tolower_table~0.offset, 1);call write~init~int(36, ~#s_tolower_table~0.base, 36 + ~#s_tolower_table~0.offset, 1);call write~init~int(37, ~#s_tolower_table~0.base, 37 + ~#s_tolower_table~0.offset, 1);call write~init~int(38, ~#s_tolower_table~0.base, 38 + ~#s_tolower_table~0.offset, 1);call write~init~int(39, ~#s_tolower_table~0.base, 39 + ~#s_tolower_table~0.offset, 1);call write~init~int(40, ~#s_tolower_table~0.base, 40 + ~#s_tolower_table~0.offset, 1);call write~init~int(41, ~#s_tolower_table~0.base, 41 + ~#s_tolower_table~0.offset, 1);call write~init~int(42, ~#s_tolower_table~0.base, 42 + ~#s_tolower_table~0.offset, 1);call write~init~int(43, ~#s_tolower_table~0.base, 43 + ~#s_tolower_table~0.offset, 1);call write~init~int(44, ~#s_tolower_table~0.base, 44 + ~#s_tolower_table~0.offset, 1);call write~init~int(45, ~#s_tolower_table~0.base, 45 + ~#s_tolower_table~0.offset, 1);call write~init~int(46, ~#s_tolower_table~0.base, 46 + ~#s_tolower_table~0.offset, 1);call write~init~int(47, ~#s_tolower_table~0.base, 47 + ~#s_tolower_table~0.offset, 1);call write~init~int(48, ~#s_tolower_table~0.base, 48 + ~#s_tolower_table~0.offset, 1);call write~init~int(49, ~#s_tolower_table~0.base, 49 + ~#s_tolower_table~0.offset, 1);call write~init~int(50, ~#s_tolower_table~0.base, 50 + ~#s_tolower_table~0.offset, 1);call write~init~int(51, ~#s_tolower_table~0.base, 51 + ~#s_tolower_table~0.offset, 1);call write~init~int(52, ~#s_tolower_table~0.base, 52 + ~#s_tolower_table~0.offset, 1);call write~init~int(53, ~#s_tolower_table~0.base, 53 + ~#s_tolower_table~0.offset, 1);call write~init~int(54, ~#s_tolower_table~0.base, 54 + ~#s_tolower_table~0.offset, 1);call write~init~int(55, ~#s_tolower_table~0.base, 55 + ~#s_tolower_table~0.offset, 1);call write~init~int(56, ~#s_tolower_table~0.base, 56 + ~#s_tolower_table~0.offset, 1);call write~init~int(57, ~#s_tolower_table~0.base, 57 + ~#s_tolower_table~0.offset, 1);call write~init~int(58, ~#s_tolower_table~0.base, 58 + ~#s_tolower_table~0.offset, 1);call write~init~int(59, ~#s_tolower_table~0.base, 59 + ~#s_tolower_table~0.offset, 1);call write~init~int(60, ~#s_tolower_table~0.base, 60 + ~#s_tolower_table~0.offset, 1);call write~init~int(61, ~#s_tolower_table~0.base, 61 + ~#s_tolower_table~0.offset, 1);call write~init~int(62, ~#s_tolower_table~0.base, 62 + ~#s_tolower_table~0.offset, 1);call write~init~int(63, ~#s_tolower_table~0.base, 63 + ~#s_tolower_table~0.offset, 1);call write~init~int(64, ~#s_tolower_table~0.base, 64 + ~#s_tolower_table~0.offset, 1);call write~init~int(97, ~#s_tolower_table~0.base, 65 + ~#s_tolower_table~0.offset, 1);call write~init~int(98, ~#s_tolower_table~0.base, 66 + ~#s_tolower_table~0.offset, 1);call write~init~int(99, ~#s_tolower_table~0.base, 67 + ~#s_tolower_table~0.offset, 1);call write~init~int(100, ~#s_tolower_table~0.base, 68 + ~#s_tolower_table~0.offset, 1);call write~init~int(101, ~#s_tolower_table~0.base, 69 + ~#s_tolower_table~0.offset, 1);call write~init~int(102, ~#s_tolower_table~0.base, 70 + ~#s_tolower_table~0.offset, 1);call write~init~int(103, ~#s_tolower_table~0.base, 71 + ~#s_tolower_table~0.offset, 1);call write~init~int(104, ~#s_tolower_table~0.base, 72 + ~#s_tolower_table~0.offset, 1);call write~init~int(105, ~#s_tolower_table~0.base, 73 + ~#s_tolower_table~0.offset, 1);call write~init~int(106, ~#s_tolower_table~0.base, 74 + ~#s_tolower_table~0.offset, 1);call write~init~int(107, ~#s_tolower_table~0.base, 75 + ~#s_tolower_table~0.offset, 1);call write~init~int(108, ~#s_tolower_table~0.base, 76 + ~#s_tolower_table~0.offset, 1);call write~init~int(109, ~#s_tolower_table~0.base, 77 + ~#s_tolower_table~0.offset, 1);call write~init~int(110, ~#s_tolower_table~0.base, 78 + ~#s_tolower_table~0.offset, 1);call write~init~int(111, ~#s_tolower_table~0.base, 79 + ~#s_tolower_table~0.offset, 1);call write~init~int(112, ~#s_tolower_table~0.base, 80 + ~#s_tolower_table~0.offset, 1);call write~init~int(113, ~#s_tolower_table~0.base, 81 + ~#s_tolower_table~0.offset, 1);call write~init~int(114, ~#s_tolower_table~0.base, 82 + ~#s_tolower_table~0.offset, 1);call write~init~int(115, ~#s_tolower_table~0.base, 83 + ~#s_tolower_table~0.offset, 1);call write~init~int(116, ~#s_tolower_table~0.base, 84 + ~#s_tolower_table~0.offset, 1);call write~init~int(117, ~#s_tolower_table~0.base, 85 + ~#s_tolower_table~0.offset, 1);call write~init~int(118, ~#s_tolower_table~0.base, 86 + ~#s_tolower_table~0.offset, 1);call write~init~int(119, ~#s_tolower_table~0.base, 87 + ~#s_tolower_table~0.offset, 1);call write~init~int(120, ~#s_tolower_table~0.base, 88 + ~#s_tolower_table~0.offset, 1);call write~init~int(121, ~#s_tolower_table~0.base, 89 + ~#s_tolower_table~0.offset, 1);call write~init~int(122, ~#s_tolower_table~0.base, 90 + ~#s_tolower_table~0.offset, 1);call write~init~int(91, ~#s_tolower_table~0.base, 91 + ~#s_tolower_table~0.offset, 1);call write~init~int(92, ~#s_tolower_table~0.base, 92 + ~#s_tolower_table~0.offset, 1);call write~init~int(93, ~#s_tolower_table~0.base, 93 + ~#s_tolower_table~0.offset, 1);call write~init~int(94, ~#s_tolower_table~0.base, 94 + ~#s_tolower_table~0.offset, 1);call write~init~int(95, ~#s_tolower_table~0.base, 95 + ~#s_tolower_table~0.offset, 1);call write~init~int(96, ~#s_tolower_table~0.base, 96 + ~#s_tolower_table~0.offset, 1);call write~init~int(97, ~#s_tolower_table~0.base, 97 + ~#s_tolower_table~0.offset, 1);call write~init~int(98, ~#s_tolower_table~0.base, 98 + ~#s_tolower_table~0.offset, 1);call write~init~int(99, ~#s_tolower_table~0.base, 99 + ~#s_tolower_table~0.offset, 1);call write~init~int(100, ~#s_tolower_table~0.base, 100 + ~#s_tolower_table~0.offset, 1);call write~init~int(101, ~#s_tolower_table~0.base, 101 + ~#s_tolower_table~0.offset, 1);call write~init~int(102, ~#s_tolower_table~0.base, 102 + ~#s_tolower_table~0.offset, 1);call write~init~int(103, ~#s_tolower_table~0.base, 103 + ~#s_tolower_table~0.offset, 1);call write~init~int(104, ~#s_tolower_table~0.base, 104 + ~#s_tolower_table~0.offset, 1);call write~init~int(105, ~#s_tolower_table~0.base, 105 + ~#s_tolower_table~0.offset, 1);call write~init~int(106, ~#s_tolower_table~0.base, 106 + ~#s_tolower_table~0.offset, 1);call write~init~int(107, ~#s_tolower_table~0.base, 107 + ~#s_tolower_table~0.offset, 1);call write~init~int(108, ~#s_tolower_table~0.base, 108 + ~#s_tolower_table~0.offset, 1);call write~init~int(109, ~#s_tolower_table~0.base, 109 + ~#s_tolower_table~0.offset, 1);call write~init~int(110, ~#s_tolower_table~0.base, 110 + ~#s_tolower_table~0.offset, 1);call write~init~int(111, ~#s_tolower_table~0.base, 111 + ~#s_tolower_table~0.offset, 1);call write~init~int(112, ~#s_tolower_table~0.base, 112 + ~#s_tolower_table~0.offset, 1);call write~init~int(113, ~#s_tolower_table~0.base, 113 + ~#s_tolower_table~0.offset, 1);call write~init~int(114, ~#s_tolower_table~0.base, 114 + ~#s_tolower_table~0.offset, 1);call write~init~int(115, ~#s_tolower_table~0.base, 115 + ~#s_tolower_table~0.offset, 1);call write~init~int(116, ~#s_tolower_table~0.base, 116 + ~#s_tolower_table~0.offset, 1);call write~init~int(117, ~#s_tolower_table~0.base, 117 + ~#s_tolower_table~0.offset, 1);call write~init~int(118, ~#s_tolower_table~0.base, 118 + ~#s_tolower_table~0.offset, 1);call write~init~int(119, ~#s_tolower_table~0.base, 119 + ~#s_tolower_table~0.offset, 1);call write~init~int(120, ~#s_tolower_table~0.base, 120 + ~#s_tolower_table~0.offset, 1);call write~init~int(121, ~#s_tolower_table~0.base, 121 + ~#s_tolower_table~0.offset, 1);call write~init~int(122, ~#s_tolower_table~0.base, 122 + ~#s_tolower_table~0.offset, 1);call write~init~int(123, ~#s_tolower_table~0.base, 123 + ~#s_tolower_table~0.offset, 1);call write~init~int(124, ~#s_tolower_table~0.base, 124 + ~#s_tolower_table~0.offset, 1);call write~init~int(125, ~#s_tolower_table~0.base, 125 + ~#s_tolower_table~0.offset, 1);call write~init~int(126, ~#s_tolower_table~0.base, 126 + ~#s_tolower_table~0.offset, 1);call write~init~int(127, ~#s_tolower_table~0.base, 127 + ~#s_tolower_table~0.offset, 1);call write~init~int(128, ~#s_tolower_table~0.base, 128 + ~#s_tolower_table~0.offset, 1);call write~init~int(129, ~#s_tolower_table~0.base, 129 + ~#s_tolower_table~0.offset, 1);call write~init~int(130, ~#s_tolower_table~0.base, 130 + ~#s_tolower_table~0.offset, 1);call write~init~int(131, ~#s_tolower_table~0.base, 131 + ~#s_tolower_table~0.offset, 1);call write~init~int(132, ~#s_tolower_table~0.base, 132 + ~#s_tolower_table~0.offset, 1);call write~init~int(133, ~#s_tolower_table~0.base, 133 + ~#s_tolower_table~0.offset, 1);call write~init~int(134, ~#s_tolower_table~0.base, 134 + ~#s_tolower_table~0.offset, 1);call write~init~int(135, ~#s_tolower_table~0.base, 135 + ~#s_tolower_table~0.offset, 1);call write~init~int(136, ~#s_tolower_table~0.base, 136 + ~#s_tolower_table~0.offset, 1);call write~init~int(137, ~#s_tolower_table~0.base, 137 + ~#s_tolower_table~0.offset, 1);call write~init~int(138, ~#s_tolower_table~0.base, 138 + ~#s_tolower_table~0.offset, 1);call write~init~int(139, ~#s_tolower_table~0.base, 139 + ~#s_tolower_table~0.offset, 1);call write~init~int(140, ~#s_tolower_table~0.base, 140 + ~#s_tolower_table~0.offset, 1);call write~init~int(141, ~#s_tolower_table~0.base, 141 + ~#s_tolower_table~0.offset, 1);call write~init~int(142, ~#s_tolower_table~0.base, 142 + ~#s_tolower_table~0.offset, 1);call write~init~int(143, ~#s_tolower_table~0.base, 143 + ~#s_tolower_table~0.offset, 1);call write~init~int(144, ~#s_tolower_table~0.base, 144 + ~#s_tolower_table~0.offset, 1);call write~init~int(145, ~#s_tolower_table~0.base, 145 + ~#s_tolower_table~0.offset, 1);call write~init~int(146, ~#s_tolower_table~0.base, 146 + ~#s_tolower_table~0.offset, 1);call write~init~int(147, ~#s_tolower_table~0.base, 147 + ~#s_tolower_table~0.offset, 1);call write~init~int(148, ~#s_tolower_table~0.base, 148 + ~#s_tolower_table~0.offset, 1);call write~init~int(149, ~#s_tolower_table~0.base, 149 + ~#s_tolower_table~0.offset, 1);call write~init~int(150, ~#s_tolower_table~0.base, 150 + ~#s_tolower_table~0.offset, 1);call write~init~int(151, ~#s_tolower_table~0.base, 151 + ~#s_tolower_table~0.offset, 1);call write~init~int(152, ~#s_tolower_table~0.base, 152 + ~#s_tolower_table~0.offset, 1);call write~init~int(153, ~#s_tolower_table~0.base, 153 + ~#s_tolower_table~0.offset, 1);call write~init~int(154, ~#s_tolower_table~0.base, 154 + ~#s_tolower_table~0.offset, 1);call write~init~int(155, ~#s_tolower_table~0.base, 155 + ~#s_tolower_table~0.offset, 1);call write~init~int(156, ~#s_tolower_table~0.base, 156 + ~#s_tolower_table~0.offset, 1);call write~init~int(157, ~#s_tolower_table~0.base, 157 + ~#s_tolower_table~0.offset, 1);call write~init~int(158, ~#s_tolower_table~0.base, 158 + ~#s_tolower_table~0.offset, 1);call write~init~int(159, ~#s_tolower_table~0.base, 159 + ~#s_tolower_table~0.offset, 1);call write~init~int(160, ~#s_tolower_table~0.base, 160 + ~#s_tolower_table~0.offset, 1);call write~init~int(161, ~#s_tolower_table~0.base, 161 + ~#s_tolower_table~0.offset, 1);call write~init~int(162, ~#s_tolower_table~0.base, 162 + ~#s_tolower_table~0.offset, 1);call write~init~int(163, ~#s_tolower_table~0.base, 163 + ~#s_tolower_table~0.offset, 1);call write~init~int(164, ~#s_tolower_table~0.base, 164 + ~#s_tolower_table~0.offset, 1);call write~init~int(165, ~#s_tolower_table~0.base, 165 + ~#s_tolower_table~0.offset, 1);call write~init~int(166, ~#s_tolower_table~0.base, 166 + ~#s_tolower_table~0.offset, 1);call write~init~int(167, ~#s_tolower_table~0.base, 167 + ~#s_tolower_table~0.offset, 1);call write~init~int(168, ~#s_tolower_table~0.base, 168 + ~#s_tolower_table~0.offset, 1);call write~init~int(169, ~#s_tolower_table~0.base, 169 + ~#s_tolower_table~0.offset, 1);call write~init~int(170, ~#s_tolower_table~0.base, 170 + ~#s_tolower_table~0.offset, 1);call write~init~int(171, ~#s_tolower_table~0.base, 171 + ~#s_tolower_table~0.offset, 1);call write~init~int(172, ~#s_tolower_table~0.base, 172 + ~#s_tolower_table~0.offset, 1);call write~init~int(173, ~#s_tolower_table~0.base, 173 + ~#s_tolower_table~0.offset, 1);call write~init~int(174, ~#s_tolower_table~0.base, 174 + ~#s_tolower_table~0.offset, 1);call write~init~int(175, ~#s_tolower_table~0.base, 175 + ~#s_tolower_table~0.offset, 1);call write~init~int(176, ~#s_tolower_table~0.base, 176 + ~#s_tolower_table~0.offset, 1);call write~init~int(177, ~#s_tolower_table~0.base, 177 + ~#s_tolower_table~0.offset, 1);call write~init~int(178, ~#s_tolower_table~0.base, 178 + ~#s_tolower_table~0.offset, 1);call write~init~int(179, ~#s_tolower_table~0.base, 179 + ~#s_tolower_table~0.offset, 1);call write~init~int(180, ~#s_tolower_table~0.base, 180 + ~#s_tolower_table~0.offset, 1);call write~init~int(181, ~#s_tolower_table~0.base, 181 + ~#s_tolower_table~0.offset, 1);call write~init~int(182, ~#s_tolower_table~0.base, 182 + ~#s_tolower_table~0.offset, 1);call write~init~int(183, ~#s_tolower_table~0.base, 183 + ~#s_tolower_table~0.offset, 1);call write~init~int(184, ~#s_tolower_table~0.base, 184 + ~#s_tolower_table~0.offset, 1);call write~init~int(185, ~#s_tolower_table~0.base, 185 + ~#s_tolower_table~0.offset, 1);call write~init~int(186, ~#s_tolower_table~0.base, 186 + ~#s_tolower_table~0.offset, 1);call write~init~int(187, ~#s_tolower_table~0.base, 187 + ~#s_tolower_table~0.offset, 1);call write~init~int(188, ~#s_tolower_table~0.base, 188 + ~#s_tolower_table~0.offset, 1);call write~init~int(189, ~#s_tolower_table~0.base, 189 + ~#s_tolower_table~0.offset, 1);call write~init~int(190, ~#s_tolower_table~0.base, 190 + ~#s_tolower_table~0.offset, 1);call write~init~int(191, ~#s_tolower_table~0.base, 191 + ~#s_tolower_table~0.offset, 1);call write~init~int(192, ~#s_tolower_table~0.base, 192 + ~#s_tolower_table~0.offset, 1);call write~init~int(193, ~#s_tolower_table~0.base, 193 + ~#s_tolower_table~0.offset, 1);call write~init~int(194, ~#s_tolower_table~0.base, 194 + ~#s_tolower_table~0.offset, 1);call write~init~int(195, ~#s_tolower_table~0.base, 195 + ~#s_tolower_table~0.offset, 1);call write~init~int(196, ~#s_tolower_table~0.base, 196 + ~#s_tolower_table~0.offset, 1);call write~init~int(197, ~#s_tolower_table~0.base, 197 + ~#s_tolower_table~0.offset, 1);call write~init~int(198, ~#s_tolower_table~0.base, 198 + ~#s_tolower_table~0.offset, 1);call write~init~int(199, ~#s_tolower_table~0.base, 199 + ~#s_tolower_table~0.offset, 1);call write~init~int(200, ~#s_tolower_table~0.base, 200 + ~#s_tolower_table~0.offset, 1);call write~init~int(201, ~#s_tolower_table~0.base, 201 + ~#s_tolower_table~0.offset, 1);call write~init~int(202, ~#s_tolower_table~0.base, 202 + ~#s_tolower_table~0.offset, 1);call write~init~int(203, ~#s_tolower_table~0.base, 203 + ~#s_tolower_table~0.offset, 1);call write~init~int(204, ~#s_tolower_table~0.base, 204 + ~#s_tolower_table~0.offset, 1);call write~init~int(205, ~#s_tolower_table~0.base, 205 + ~#s_tolower_table~0.offset, 1);call write~init~int(206, ~#s_tolower_table~0.base, 206 + ~#s_tolower_table~0.offset, 1);call write~init~int(207, ~#s_tolower_table~0.base, 207 + ~#s_tolower_table~0.offset, 1);call write~init~int(208, ~#s_tolower_table~0.base, 208 + ~#s_tolower_table~0.offset, 1);call write~init~int(209, ~#s_tolower_table~0.base, 209 + ~#s_tolower_table~0.offset, 1);call write~init~int(210, ~#s_tolower_table~0.base, 210 + ~#s_tolower_table~0.offset, 1);call write~init~int(211, ~#s_tolower_table~0.base, 211 + ~#s_tolower_table~0.offset, 1);call write~init~int(212, ~#s_tolower_table~0.base, 212 + ~#s_tolower_table~0.offset, 1);call write~init~int(213, ~#s_tolower_table~0.base, 213 + ~#s_tolower_table~0.offset, 1);call write~init~int(214, ~#s_tolower_table~0.base, 214 + ~#s_tolower_table~0.offset, 1);call write~init~int(215, ~#s_tolower_table~0.base, 215 + ~#s_tolower_table~0.offset, 1);call write~init~int(216, ~#s_tolower_table~0.base, 216 + ~#s_tolower_table~0.offset, 1);call write~init~int(217, ~#s_tolower_table~0.base, 217 + ~#s_tolower_table~0.offset, 1);call write~init~int(218, ~#s_tolower_table~0.base, 218 + ~#s_tolower_table~0.offset, 1);call write~init~int(219, ~#s_tolower_table~0.base, 219 + ~#s_tolower_table~0.offset, 1);call write~init~int(220, ~#s_tolower_table~0.base, 220 + ~#s_tolower_table~0.offset, 1);call write~init~int(221, ~#s_tolower_table~0.base, 221 + ~#s_tolower_table~0.offset, 1);call write~init~int(222, ~#s_tolower_table~0.base, 222 + ~#s_tolower_table~0.offset, 1);call write~init~int(223, ~#s_tolower_table~0.base, 223 + ~#s_tolower_table~0.offset, 1);call write~init~int(224, ~#s_tolower_table~0.base, 224 + ~#s_tolower_table~0.offset, 1);call write~init~int(225, ~#s_tolower_table~0.base, 225 + ~#s_tolower_table~0.offset, 1);call write~init~int(226, ~#s_tolower_table~0.base, 226 + ~#s_tolower_table~0.offset, 1);call write~init~int(227, ~#s_tolower_table~0.base, 227 + ~#s_tolower_table~0.offset, 1);call write~init~int(228, ~#s_tolower_table~0.base, 228 + ~#s_tolower_table~0.offset, 1);call write~init~int(229, ~#s_tolower_table~0.base, 229 + ~#s_tolower_table~0.offset, 1);call write~init~int(230, ~#s_tolower_table~0.base, 230 + ~#s_tolower_table~0.offset, 1);call write~init~int(231, ~#s_tolower_table~0.base, 231 + ~#s_tolower_table~0.offset, 1);call write~init~int(232, ~#s_tolower_table~0.base, 232 + ~#s_tolower_table~0.offset, 1);call write~init~int(233, ~#s_tolower_table~0.base, 233 + ~#s_tolower_table~0.offset, 1);call write~init~int(234, ~#s_tolower_table~0.base, 234 + ~#s_tolower_table~0.offset, 1);call write~init~int(235, ~#s_tolower_table~0.base, 235 + ~#s_tolower_table~0.offset, 1);call write~init~int(236, ~#s_tolower_table~0.base, 236 + ~#s_tolower_table~0.offset, 1);call write~init~int(237, ~#s_tolower_table~0.base, 237 + ~#s_tolower_table~0.offset, 1);call write~init~int(238, ~#s_tolower_table~0.base, 238 + ~#s_tolower_table~0.offset, 1);call write~init~int(239, ~#s_tolower_table~0.base, 239 + ~#s_tolower_table~0.offset, 1);call write~init~int(240, ~#s_tolower_table~0.base, 240 + ~#s_tolower_table~0.offset, 1);call write~init~int(241, ~#s_tolower_table~0.base, 241 + ~#s_tolower_table~0.offset, 1);call write~init~int(242, ~#s_tolower_table~0.base, 242 + ~#s_tolower_table~0.offset, 1);call write~init~int(243, ~#s_tolower_table~0.base, 243 + ~#s_tolower_table~0.offset, 1);call write~init~int(244, ~#s_tolower_table~0.base, 244 + ~#s_tolower_table~0.offset, 1);call write~init~int(245, ~#s_tolower_table~0.base, 245 + ~#s_tolower_table~0.offset, 1);call write~init~int(246, ~#s_tolower_table~0.base, 246 + ~#s_tolower_table~0.offset, 1);call write~init~int(247, ~#s_tolower_table~0.base, 247 + ~#s_tolower_table~0.offset, 1);call write~init~int(248, ~#s_tolower_table~0.base, 248 + ~#s_tolower_table~0.offset, 1);call write~init~int(249, ~#s_tolower_table~0.base, 249 + ~#s_tolower_table~0.offset, 1);call write~init~int(250, ~#s_tolower_table~0.base, 250 + ~#s_tolower_table~0.offset, 1);call write~init~int(251, ~#s_tolower_table~0.base, 251 + ~#s_tolower_table~0.offset, 1);call write~init~int(252, ~#s_tolower_table~0.base, 252 + ~#s_tolower_table~0.offset, 1);call write~init~int(253, ~#s_tolower_table~0.base, 253 + ~#s_tolower_table~0.offset, 1);call write~init~int(254, ~#s_tolower_table~0.base, 254 + ~#s_tolower_table~0.offset, 1);call write~init~int(255, ~#s_tolower_table~0.base, 255 + ~#s_tolower_table~0.offset, 1); {113#true} is VALID [2022-02-20 21:08:09,858 INFO L290 TraceCheckUtils]: 1: Hoare triple {113#true} assume { :end_inline_ULTIMATE.init } true;assume { :begin_inline_main } true;havoc main_#res#1;assume { :begin_inline_aws_hash_callback_string_eq_harness } true;havoc aws_hash_callback_string_eq_harness_#t~ret1963#1.base, aws_hash_callback_string_eq_harness_#t~ret1963#1.offset, aws_hash_callback_string_eq_harness_#t~ret1964#1, aws_hash_callback_string_eq_harness_#t~ite1966#1.base, aws_hash_callback_string_eq_harness_#t~ite1966#1.offset, aws_hash_callback_string_eq_harness_#t~ret1965#1.base, aws_hash_callback_string_eq_harness_#t~ret1965#1.offset, aws_hash_callback_string_eq_harness_#t~ret1967#1, aws_hash_callback_string_eq_harness_#t~mem1968#1, aws_hash_callback_string_eq_harness_#t~mem1969#1, aws_hash_callback_string_eq_harness_#t~mem1970#1, aws_hash_callback_string_eq_harness_~str1~0#1.base, aws_hash_callback_string_eq_harness_~str1~0#1.offset, aws_hash_callback_string_eq_harness_~str2~0#1.base, aws_hash_callback_string_eq_harness_~str2~0#1.offset, aws_hash_callback_string_eq_harness_~rval~21#1; {113#true} is VALID [2022-02-20 21:08:09,860 INFO L272 TraceCheckUtils]: 2: Hoare triple {113#true} call aws_hash_callback_string_eq_harness_#t~ret1963#1.base, aws_hash_callback_string_eq_harness_#t~ret1963#1.offset := ensure_string_is_allocated_bounded_length(96); {180#(and (= |old(#length)| |#length|) (= |old(#memory_real)| |#memory_real|) (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:08:09,860 INFO L290 TraceCheckUtils]: 3: Hoare triple {180#(and (= |old(#length)| |#length|) (= |old(#memory_real)| |#memory_real|) (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|) (= |old(#valid)| |#valid|))} ~max_size#1 := #in~max_size#1; {113#true} is VALID [2022-02-20 21:08:09,860 INFO L272 TraceCheckUtils]: 4: Hoare triple {113#true} call #t~ret540#1 := nondet_uint64_t(); {113#true} is VALID [2022-02-20 21:08:09,861 INFO L290 TraceCheckUtils]: 5: Hoare triple {113#true} #res := #t~nondet13;havoc #t~nondet13; {113#true} is VALID [2022-02-20 21:08:09,861 INFO L290 TraceCheckUtils]: 6: Hoare triple {113#true} assume true; {113#true} is VALID [2022-02-20 21:08:09,861 INFO L284 TraceCheckUtils]: 7: Hoare quadruple {113#true} {113#true} #182#return; {113#true} is VALID [2022-02-20 21:08:09,861 INFO L290 TraceCheckUtils]: 8: Hoare triple {113#true} ~len~1#1 := #t~ret540#1;havoc #t~ret540#1; {113#true} is VALID [2022-02-20 21:08:09,862 INFO L272 TraceCheckUtils]: 9: Hoare triple {113#true} call assume_abort_if_not((if 0 == (if ~len~1#1 % 18446744073709551616 < ~max_size#1 % 18446744073709551616 then 1 else 0) then 0 else 1)); {113#true} is VALID [2022-02-20 21:08:09,862 INFO L290 TraceCheckUtils]: 10: Hoare triple {113#true} ~cond := #in~cond; {113#true} is VALID [2022-02-20 21:08:09,862 INFO L290 TraceCheckUtils]: 11: Hoare triple {113#true} assume 0 == ~cond % 256;assume false; {114#false} is VALID [2022-02-20 21:08:09,863 INFO L290 TraceCheckUtils]: 12: Hoare triple {114#false} assume true; {114#false} is VALID [2022-02-20 21:08:09,863 INFO L284 TraceCheckUtils]: 13: Hoare quadruple {114#false} {113#true} #184#return; {114#false} is VALID [2022-02-20 21:08:09,863 INFO L290 TraceCheckUtils]: 14: Hoare triple {114#false} assume { :begin_inline_ensure_string_is_allocated } true;ensure_string_is_allocated_#in~len#1 := ~len~1#1;havoc ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset;havoc ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset, ensure_string_is_allocated_#t~ret543#1, ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset, ensure_string_is_allocated_#t~ret544#1.base, ensure_string_is_allocated_#t~ret544#1.offset, ensure_string_is_allocated_~len#1, ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset;ensure_string_is_allocated_~len#1 := ensure_string_is_allocated_#in~len#1; {114#false} is VALID [2022-02-20 21:08:09,863 INFO L272 TraceCheckUtils]: 15: Hoare triple {114#false} call ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset := bounded_malloc(-1234550 + ensure_string_is_allocated_~len#1); {200#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:08:09,863 INFO L290 TraceCheckUtils]: 16: Hoare triple {200#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size; {113#true} is VALID [2022-02-20 21:08:09,864 INFO L272 TraceCheckUtils]: 17: Hoare triple {113#true} call assume_abort_if_not((if 0 == (if ~size % 18446744073709551616 <= 36028797018963967 then 1 else 0) then 0 else 1)); {113#true} is VALID [2022-02-20 21:08:09,864 INFO L290 TraceCheckUtils]: 18: Hoare triple {113#true} ~cond := #in~cond; {113#true} is VALID [2022-02-20 21:08:09,864 INFO L290 TraceCheckUtils]: 19: Hoare triple {113#true} assume 0 == ~cond % 256;assume false; {114#false} is VALID [2022-02-20 21:08:09,865 INFO L290 TraceCheckUtils]: 20: Hoare triple {114#false} assume true; {114#false} is VALID [2022-02-20 21:08:09,865 INFO L284 TraceCheckUtils]: 21: Hoare quadruple {114#false} {113#true} #192#return; {114#false} is VALID [2022-02-20 21:08:09,865 INFO L290 TraceCheckUtils]: 22: Hoare triple {114#false} call #t~malloc555.base, #t~malloc555.offset := #Ultimate.allocOnHeap(~size);#res.base, #res.offset := #t~malloc555.base, #t~malloc555.offset;havoc #t~malloc555.base, #t~malloc555.offset; {114#false} is VALID [2022-02-20 21:08:09,865 INFO L290 TraceCheckUtils]: 23: Hoare triple {114#false} assume true; {114#false} is VALID [2022-02-20 21:08:09,865 INFO L284 TraceCheckUtils]: 24: Hoare quadruple {114#false} {114#false} #186#return; {114#false} is VALID [2022-02-20 21:08:09,866 INFO L290 TraceCheckUtils]: 25: Hoare triple {114#false} ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset := ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset;havoc ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset; {114#false} is VALID [2022-02-20 21:08:09,866 INFO L272 TraceCheckUtils]: 26: Hoare triple {114#false} call ensure_string_is_allocated_#t~ret543#1 := nondet_bool(); {113#true} is VALID [2022-02-20 21:08:09,866 INFO L290 TraceCheckUtils]: 27: Hoare triple {113#true} #res := #t~nondet8;havoc #t~nondet8; {113#true} is VALID [2022-02-20 21:08:09,866 INFO L290 TraceCheckUtils]: 28: Hoare triple {113#true} assume true; {113#true} is VALID [2022-02-20 21:08:09,867 INFO L284 TraceCheckUtils]: 29: Hoare quadruple {113#true} {114#false} #188#return; {114#false} is VALID [2022-02-20 21:08:09,867 INFO L290 TraceCheckUtils]: 30: Hoare triple {114#false} assume !(0 != ensure_string_is_allocated_#t~ret543#1 % 256);ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset := 0, 0; {114#false} is VALID [2022-02-20 21:08:09,867 INFO L290 TraceCheckUtils]: 31: Hoare triple {114#false} call write~$Pointer$(ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset, ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset, 8);havoc ensure_string_is_allocated_#t~ret543#1;havoc ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset;havoc ensure_string_is_allocated_#t~ret544#1.base, ensure_string_is_allocated_#t~ret544#1.offset;call write~int(ensure_string_is_allocated_~len#1, ensure_string_is_allocated_~str~0#1.base, 8 + ensure_string_is_allocated_~str~0#1.offset, 8);call write~int(0, ensure_string_is_allocated_~str~0#1.base, 16 + ensure_string_is_allocated_~str~0#1.offset + (if ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 else ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset := ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset; {114#false} is VALID [2022-02-20 21:08:09,867 INFO L290 TraceCheckUtils]: 32: Hoare triple {114#false} #t~ret541#1.base, #t~ret541#1.offset := ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset;assume { :end_inline_ensure_string_is_allocated } true;#res#1.base, #res#1.offset := #t~ret541#1.base, #t~ret541#1.offset;havoc #t~ret541#1.base, #t~ret541#1.offset; {114#false} is VALID [2022-02-20 21:08:09,868 INFO L290 TraceCheckUtils]: 33: Hoare triple {114#false} assume true; {114#false} is VALID [2022-02-20 21:08:09,868 INFO L284 TraceCheckUtils]: 34: Hoare quadruple {114#false} {113#true} #198#return; {114#false} is VALID [2022-02-20 21:08:09,868 INFO L290 TraceCheckUtils]: 35: Hoare triple {114#false} aws_hash_callback_string_eq_harness_~str1~0#1.base, aws_hash_callback_string_eq_harness_~str1~0#1.offset := aws_hash_callback_string_eq_harness_#t~ret1963#1.base, aws_hash_callback_string_eq_harness_#t~ret1963#1.offset;havoc aws_hash_callback_string_eq_harness_#t~ret1963#1.base, aws_hash_callback_string_eq_harness_#t~ret1963#1.offset; {114#false} is VALID [2022-02-20 21:08:09,868 INFO L272 TraceCheckUtils]: 36: Hoare triple {114#false} call aws_hash_callback_string_eq_harness_#t~ret1964#1 := nondet_bool(); {113#true} is VALID [2022-02-20 21:08:09,869 INFO L290 TraceCheckUtils]: 37: Hoare triple {113#true} #res := #t~nondet8;havoc #t~nondet8; {113#true} is VALID [2022-02-20 21:08:09,869 INFO L290 TraceCheckUtils]: 38: Hoare triple {113#true} assume true; {113#true} is VALID [2022-02-20 21:08:09,869 INFO L284 TraceCheckUtils]: 39: Hoare quadruple {113#true} {114#false} #200#return; {114#false} is VALID [2022-02-20 21:08:09,869 INFO L290 TraceCheckUtils]: 40: Hoare triple {114#false} assume 0 != aws_hash_callback_string_eq_harness_#t~ret1964#1 % 256;aws_hash_callback_string_eq_harness_#t~ite1966#1.base, aws_hash_callback_string_eq_harness_#t~ite1966#1.offset := aws_hash_callback_string_eq_harness_~str1~0#1.base, aws_hash_callback_string_eq_harness_~str1~0#1.offset; {114#false} is VALID [2022-02-20 21:08:09,870 INFO L290 TraceCheckUtils]: 41: Hoare triple {114#false} aws_hash_callback_string_eq_harness_~str2~0#1.base, aws_hash_callback_string_eq_harness_~str2~0#1.offset := aws_hash_callback_string_eq_harness_#t~ite1966#1.base, aws_hash_callback_string_eq_harness_#t~ite1966#1.offset;havoc aws_hash_callback_string_eq_harness_#t~ret1964#1;havoc aws_hash_callback_string_eq_harness_#t~ite1966#1.base, aws_hash_callback_string_eq_harness_#t~ite1966#1.offset;havoc aws_hash_callback_string_eq_harness_#t~ret1965#1.base, aws_hash_callback_string_eq_harness_#t~ret1965#1.offset;assume { :begin_inline_aws_hash_callback_string_eq } true;aws_hash_callback_string_eq_#in~a#1.base, aws_hash_callback_string_eq_#in~a#1.offset, aws_hash_callback_string_eq_#in~b#1.base, aws_hash_callback_string_eq_#in~b#1.offset := aws_hash_callback_string_eq_harness_~str1~0#1.base, aws_hash_callback_string_eq_harness_~str1~0#1.offset, aws_hash_callback_string_eq_harness_~str2~0#1.base, aws_hash_callback_string_eq_harness_~str2~0#1.offset;havoc aws_hash_callback_string_eq_#res#1;havoc aws_hash_callback_string_eq_#t~ret1811#1, aws_hash_callback_string_eq_#t~ret1812#1, aws_hash_callback_string_eq_#t~ret1813#1, aws_hash_callback_string_eq_#t~ret1814#1, aws_hash_callback_string_eq_#t~ret1815#1, aws_hash_callback_string_eq_#t~short1816#1, aws_hash_callback_string_eq_~a#1.base, aws_hash_callback_string_eq_~a#1.offset, aws_hash_callback_string_eq_~b#1.base, aws_hash_callback_string_eq_~b#1.offset, aws_hash_callback_string_eq_~rval~20#1;aws_hash_callback_string_eq_~a#1.base, aws_hash_callback_string_eq_~a#1.offset := aws_hash_callback_string_eq_#in~a#1.base, aws_hash_callback_string_eq_#in~a#1.offset;aws_hash_callback_string_eq_~b#1.base, aws_hash_callback_string_eq_~b#1.offset := aws_hash_callback_string_eq_#in~b#1.base, aws_hash_callback_string_eq_#in~b#1.offset; {114#false} is VALID [2022-02-20 21:08:09,870 INFO L272 TraceCheckUtils]: 42: Hoare triple {114#false} call aws_hash_callback_string_eq_#t~ret1811#1 := aws_string_is_valid(aws_hash_callback_string_eq_~a#1.base, aws_hash_callback_string_eq_~a#1.offset); {113#true} is VALID [2022-02-20 21:08:09,870 INFO L290 TraceCheckUtils]: 43: Hoare triple {113#true} ~str.base, ~str.offset := #in~str.base, #in~str.offset;#t~short464 := ~str.base != 0 || ~str.offset != 0; {113#true} is VALID [2022-02-20 21:08:09,870 INFO L290 TraceCheckUtils]: 44: Hoare triple {113#true} assume #t~short464;call #t~mem463 := read~int(~str.base, 8 + ~str.offset, 8);#t~short464 := 0 == (1 + #t~mem463) % 18446744073709551616 || ~str.base != 0 || 16 + ~str.offset != 0; {113#true} is VALID [2022-02-20 21:08:09,871 INFO L290 TraceCheckUtils]: 45: Hoare triple {113#true} #t~short467 := #t~short464; {113#true} is VALID [2022-02-20 21:08:09,871 INFO L290 TraceCheckUtils]: 46: Hoare triple {113#true} assume #t~short467;call #t~mem465 := read~int(~str.base, 8 + ~str.offset, 8);call #t~mem466 := read~int(~str.base, 16 + ~str.offset + (if #t~mem465 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then #t~mem465 % 18446744073709551616 % 18446744073709551616 else #t~mem465 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);#t~short467 := 0 == #t~mem466 % 256; {113#true} is VALID [2022-02-20 21:08:09,871 INFO L290 TraceCheckUtils]: 47: Hoare triple {113#true} #res := (if 0 == (if #t~short467 then 1 else 0) then 0 else 1);havoc #t~mem463;havoc #t~short464;havoc #t~mem465;havoc #t~mem466;havoc #t~short467; {113#true} is VALID [2022-02-20 21:08:09,871 INFO L290 TraceCheckUtils]: 48: Hoare triple {113#true} assume true; {113#true} is VALID [2022-02-20 21:08:09,871 INFO L284 TraceCheckUtils]: 49: Hoare quadruple {113#true} {114#false} #204#return; {114#false} is VALID [2022-02-20 21:08:09,872 INFO L272 TraceCheckUtils]: 50: Hoare triple {114#false} call assume_abort_if_not(aws_hash_callback_string_eq_#t~ret1811#1); {113#true} is VALID [2022-02-20 21:08:09,872 INFO L290 TraceCheckUtils]: 51: Hoare triple {113#true} ~cond := #in~cond; {113#true} is VALID [2022-02-20 21:08:09,873 INFO L290 TraceCheckUtils]: 52: Hoare triple {113#true} assume 0 == ~cond % 256;assume false; {114#false} is VALID [2022-02-20 21:08:09,873 INFO L290 TraceCheckUtils]: 53: Hoare triple {114#false} assume true; {114#false} is VALID [2022-02-20 21:08:09,873 INFO L284 TraceCheckUtils]: 54: Hoare quadruple {114#false} {114#false} #206#return; {114#false} is VALID [2022-02-20 21:08:09,873 INFO L290 TraceCheckUtils]: 55: Hoare triple {114#false} havoc aws_hash_callback_string_eq_#t~ret1811#1; {114#false} is VALID [2022-02-20 21:08:09,873 INFO L272 TraceCheckUtils]: 56: Hoare triple {114#false} call aws_hash_callback_string_eq_#t~ret1812#1 := aws_string_is_valid(aws_hash_callback_string_eq_~b#1.base, aws_hash_callback_string_eq_~b#1.offset); {113#true} is VALID [2022-02-20 21:08:09,874 INFO L290 TraceCheckUtils]: 57: Hoare triple {113#true} ~str.base, ~str.offset := #in~str.base, #in~str.offset;#t~short464 := ~str.base != 0 || ~str.offset != 0; {113#true} is VALID [2022-02-20 21:08:09,874 INFO L290 TraceCheckUtils]: 58: Hoare triple {113#true} assume #t~short464;call #t~mem463 := read~int(~str.base, 8 + ~str.offset, 8);#t~short464 := 0 == (1 + #t~mem463) % 18446744073709551616 || ~str.base != 0 || 16 + ~str.offset != 0; {113#true} is VALID [2022-02-20 21:08:09,874 INFO L290 TraceCheckUtils]: 59: Hoare triple {113#true} #t~short467 := #t~short464; {113#true} is VALID [2022-02-20 21:08:09,874 INFO L290 TraceCheckUtils]: 60: Hoare triple {113#true} assume #t~short467;call #t~mem465 := read~int(~str.base, 8 + ~str.offset, 8);call #t~mem466 := read~int(~str.base, 16 + ~str.offset + (if #t~mem465 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then #t~mem465 % 18446744073709551616 % 18446744073709551616 else #t~mem465 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);#t~short467 := 0 == #t~mem466 % 256; {113#true} is VALID [2022-02-20 21:08:09,874 INFO L290 TraceCheckUtils]: 61: Hoare triple {113#true} #res := (if 0 == (if #t~short467 then 1 else 0) then 0 else 1);havoc #t~mem463;havoc #t~short464;havoc #t~mem465;havoc #t~mem466;havoc #t~short467; {113#true} is VALID [2022-02-20 21:08:09,875 INFO L290 TraceCheckUtils]: 62: Hoare triple {113#true} assume true; {113#true} is VALID [2022-02-20 21:08:09,875 INFO L284 TraceCheckUtils]: 63: Hoare quadruple {113#true} {114#false} #208#return; {114#false} is VALID [2022-02-20 21:08:09,875 INFO L272 TraceCheckUtils]: 64: Hoare triple {114#false} call assume_abort_if_not(aws_hash_callback_string_eq_#t~ret1812#1); {113#true} is VALID [2022-02-20 21:08:09,875 INFO L290 TraceCheckUtils]: 65: Hoare triple {113#true} ~cond := #in~cond; {113#true} is VALID [2022-02-20 21:08:09,876 INFO L290 TraceCheckUtils]: 66: Hoare triple {113#true} assume 0 == ~cond % 256;assume false; {114#false} is VALID [2022-02-20 21:08:09,876 INFO L290 TraceCheckUtils]: 67: Hoare triple {114#false} assume true; {114#false} is VALID [2022-02-20 21:08:09,876 INFO L284 TraceCheckUtils]: 68: Hoare quadruple {114#false} {114#false} #210#return; {114#false} is VALID [2022-02-20 21:08:09,877 INFO L290 TraceCheckUtils]: 69: Hoare triple {114#false} havoc aws_hash_callback_string_eq_#t~ret1812#1;assume { :begin_inline_aws_string_eq } true;aws_string_eq_#in~a#1.base, aws_string_eq_#in~a#1.offset, aws_string_eq_#in~b#1.base, aws_string_eq_#in~b#1.offset := aws_hash_callback_string_eq_~a#1.base, aws_hash_callback_string_eq_~a#1.offset, aws_hash_callback_string_eq_~b#1.base, aws_hash_callback_string_eq_~b#1.offset;havoc aws_string_eq_#res#1;havoc aws_string_eq_#t~ret1893#1, aws_string_eq_#t~short1894#1, aws_string_eq_#t~ret1895#1, aws_string_eq_#t~short1896#1, aws_string_eq_#t~mem1897#1, aws_string_eq_#t~mem1898#1, aws_string_eq_#t~ret1899#1, aws_string_eq_~a#1.base, aws_string_eq_~a#1.offset, aws_string_eq_~b#1.base, aws_string_eq_~b#1.offset;aws_string_eq_~a#1.base, aws_string_eq_~a#1.offset := aws_string_eq_#in~a#1.base, aws_string_eq_#in~a#1.offset;aws_string_eq_~b#1.base, aws_string_eq_~b#1.offset := aws_string_eq_#in~b#1.base, aws_string_eq_#in~b#1.offset;aws_string_eq_#t~short1894#1 := aws_string_eq_~a#1.base == 0 && aws_string_eq_~a#1.offset == 0; {114#false} is VALID [2022-02-20 21:08:09,877 INFO L290 TraceCheckUtils]: 70: Hoare triple {114#false} assume aws_string_eq_#t~short1894#1; {114#false} is VALID [2022-02-20 21:08:09,877 INFO L272 TraceCheckUtils]: 71: Hoare triple {114#false} call assume_abort_if_not((if 0 == (if aws_string_eq_#t~short1894#1 then 1 else 0) then 0 else 1)); {113#true} is VALID [2022-02-20 21:08:09,877 INFO L290 TraceCheckUtils]: 72: Hoare triple {113#true} ~cond := #in~cond; {113#true} is VALID [2022-02-20 21:08:09,878 INFO L290 TraceCheckUtils]: 73: Hoare triple {113#true} assume 0 == ~cond % 256;assume false; {114#false} is VALID [2022-02-20 21:08:09,878 INFO L290 TraceCheckUtils]: 74: Hoare triple {114#false} assume true; {114#false} is VALID [2022-02-20 21:08:09,878 INFO L284 TraceCheckUtils]: 75: Hoare quadruple {114#false} {114#false} #214#return; {114#false} is VALID [2022-02-20 21:08:09,878 INFO L290 TraceCheckUtils]: 76: Hoare triple {114#false} havoc aws_string_eq_#t~ret1893#1;havoc aws_string_eq_#t~short1894#1;aws_string_eq_#t~short1896#1 := aws_string_eq_~b#1.base == 0 && aws_string_eq_~b#1.offset == 0; {114#false} is VALID [2022-02-20 21:08:09,879 INFO L290 TraceCheckUtils]: 77: Hoare triple {114#false} assume aws_string_eq_#t~short1896#1; {114#false} is VALID [2022-02-20 21:08:09,879 INFO L272 TraceCheckUtils]: 78: Hoare triple {114#false} call assume_abort_if_not((if 0 == (if aws_string_eq_#t~short1896#1 then 1 else 0) then 0 else 1)); {113#true} is VALID [2022-02-20 21:08:09,879 INFO L290 TraceCheckUtils]: 79: Hoare triple {113#true} ~cond := #in~cond; {113#true} is VALID [2022-02-20 21:08:09,880 INFO L290 TraceCheckUtils]: 80: Hoare triple {113#true} assume 0 == ~cond % 256;assume false; {114#false} is VALID [2022-02-20 21:08:09,880 INFO L290 TraceCheckUtils]: 81: Hoare triple {114#false} assume true; {114#false} is VALID [2022-02-20 21:08:09,880 INFO L284 TraceCheckUtils]: 82: Hoare quadruple {114#false} {114#false} #218#return; {114#false} is VALID [2022-02-20 21:08:09,880 INFO L290 TraceCheckUtils]: 83: Hoare triple {114#false} havoc aws_string_eq_#t~ret1895#1;havoc aws_string_eq_#t~short1896#1; {114#false} is VALID [2022-02-20 21:08:09,880 INFO L290 TraceCheckUtils]: 84: Hoare triple {114#false} assume aws_string_eq_~a#1.base == aws_string_eq_~b#1.base && aws_string_eq_~a#1.offset == aws_string_eq_~b#1.offset;aws_string_eq_#res#1 := 1; {114#false} is VALID [2022-02-20 21:08:09,881 INFO L290 TraceCheckUtils]: 85: Hoare triple {114#false} aws_hash_callback_string_eq_#t~ret1813#1 := aws_string_eq_#res#1;assume { :end_inline_aws_string_eq } true;aws_hash_callback_string_eq_~rval~20#1 := aws_hash_callback_string_eq_#t~ret1813#1;havoc aws_hash_callback_string_eq_#t~ret1813#1; {114#false} is VALID [2022-02-20 21:08:09,881 INFO L290 TraceCheckUtils]: 86: Hoare triple {114#false} assume !true; {114#false} is VALID [2022-02-20 21:08:09,881 INFO L290 TraceCheckUtils]: 87: Hoare triple {114#false} aws_hash_callback_string_eq_harness_#t~ret1967#1 := aws_hash_callback_string_eq_#res#1;assume { :end_inline_aws_hash_callback_string_eq } true;aws_hash_callback_string_eq_harness_~rval~21#1 := aws_hash_callback_string_eq_harness_#t~ret1967#1;havoc aws_hash_callback_string_eq_harness_#t~ret1967#1; {114#false} is VALID [2022-02-20 21:08:09,881 INFO L290 TraceCheckUtils]: 88: Hoare triple {114#false} assume 0 != aws_hash_callback_string_eq_harness_~rval~21#1 % 256;call aws_hash_callback_string_eq_harness_#t~mem1968#1 := read~int(aws_hash_callback_string_eq_harness_~str1~0#1.base, 8 + aws_hash_callback_string_eq_harness_~str1~0#1.offset, 8);call aws_hash_callback_string_eq_harness_#t~mem1969#1 := read~int(aws_hash_callback_string_eq_harness_~str2~0#1.base, 8 + aws_hash_callback_string_eq_harness_~str2~0#1.offset, 8); {114#false} is VALID [2022-02-20 21:08:09,882 INFO L272 TraceCheckUtils]: 89: Hoare triple {114#false} call __VERIFIER_assert((if 0 == (if aws_hash_callback_string_eq_harness_#t~mem1968#1 % 18446744073709551616 == aws_hash_callback_string_eq_harness_#t~mem1969#1 % 18446744073709551616 then 1 else 0) then 0 else 1)); {114#false} is VALID [2022-02-20 21:08:09,882 INFO L290 TraceCheckUtils]: 90: Hoare triple {114#false} ~cond := #in~cond; {114#false} is VALID [2022-02-20 21:08:09,882 INFO L290 TraceCheckUtils]: 91: Hoare triple {114#false} assume 0 == ~cond % 256; {114#false} is VALID [2022-02-20 21:08:09,882 INFO L290 TraceCheckUtils]: 92: Hoare triple {114#false} assume !false; {114#false} is VALID [2022-02-20 21:08:09,883 INFO L134 CoverageAnalysis]: Checked inductivity of 70 backedges. 0 proven. 0 refuted. 0 times theorem prover too weak. 70 trivial. 0 not checked. [2022-02-20 21:08:09,884 INFO L144 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-02-20 21:08:09,884 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [269402821] [2022-02-20 21:08:09,885 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleSmtInterpolCraig [269402821] provided 1 perfect and 0 imperfect interpolant sequences [2022-02-20 21:08:09,885 INFO L191 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-02-20 21:08:09,885 INFO L204 FreeRefinementEngine]: Number of different interpolants: perfect sequences [4] imperfect sequences [] total 4 [2022-02-20 21:08:09,886 INFO L118 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [2013773476] [2022-02-20 21:08:09,887 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-02-20 21:08:09,892 INFO L78 Accepts]: Start accepts. Automaton has has 4 states, 4 states have (on average 10.75) internal successors, (43), 2 states have internal predecessors, (43), 2 states have call successors, (14), 4 states have call predecessors, (14), 2 states have return successors, (13), 2 states have call predecessors, (13), 2 states have call successors, (13) Word has length 93 [2022-02-20 21:08:09,894 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-02-20 21:08:09,897 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with has 4 states, 4 states have (on average 10.75) internal successors, (43), 2 states have internal predecessors, (43), 2 states have call successors, (14), 4 states have call predecessors, (14), 2 states have return successors, (13), 2 states have call predecessors, (13), 2 states have call successors, (13) [2022-02-20 21:08:09,983 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 70 edges. 70 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 21:08:09,983 INFO L546 AbstractCegarLoop]: INTERPOLANT automaton has 4 states [2022-02-20 21:08:09,983 INFO L108 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2022-02-20 21:08:10,001 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 4 interpolants. [2022-02-20 21:08:10,001 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=6, Invalid=6, Unknown=0, NotChecked=0, Total=12 [2022-02-20 21:08:10,005 INFO L87 Difference]: Start difference. First operand has 110 states, 71 states have (on average 1.2253521126760563) internal successors, (87), 71 states have internal predecessors, (87), 28 states have call successors, (28), 10 states have call predecessors, (28), 10 states have return successors, (28), 28 states have call predecessors, (28), 28 states have call successors, (28) Second operand has 4 states, 4 states have (on average 10.75) internal successors, (43), 2 states have internal predecessors, (43), 2 states have call successors, (14), 4 states have call predecessors, (14), 2 states have return successors, (13), 2 states have call predecessors, (13), 2 states have call successors, (13) [2022-02-20 21:08:10,521 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 21:08:10,522 INFO L93 Difference]: Finished difference Result 217 states and 299 transitions. [2022-02-20 21:08:10,522 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 3 states. [2022-02-20 21:08:10,523 INFO L78 Accepts]: Start accepts. Automaton has has 4 states, 4 states have (on average 10.75) internal successors, (43), 2 states have internal predecessors, (43), 2 states have call successors, (14), 4 states have call predecessors, (14), 2 states have return successors, (13), 2 states have call predecessors, (13), 2 states have call successors, (13) Word has length 93 [2022-02-20 21:08:10,523 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-02-20 21:08:10,525 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 4 states, 4 states have (on average 10.75) internal successors, (43), 2 states have internal predecessors, (43), 2 states have call successors, (14), 4 states have call predecessors, (14), 2 states have return successors, (13), 2 states have call predecessors, (13), 2 states have call successors, (13) [2022-02-20 21:08:10,548 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 3 states to 3 states and 299 transitions. [2022-02-20 21:08:10,549 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 4 states, 4 states have (on average 10.75) internal successors, (43), 2 states have internal predecessors, (43), 2 states have call successors, (14), 4 states have call predecessors, (14), 2 states have return successors, (13), 2 states have call predecessors, (13), 2 states have call successors, (13) [2022-02-20 21:08:10,563 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 3 states to 3 states and 299 transitions. [2022-02-20 21:08:10,566 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with 3 states and 299 transitions. [2022-02-20 21:08:10,959 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 299 edges. 299 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 21:08:10,974 INFO L225 Difference]: With dead ends: 217 [2022-02-20 21:08:10,975 INFO L226 Difference]: Without dead ends: 104 [2022-02-20 21:08:10,978 INFO L932 BasicCegarLoop]: 0 DeclaredPredicates, 36 GetRequests, 34 SyntacticMatches, 0 SemanticMatches, 2 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 0 ImplicationChecksByTransitivity, 0.0s TimeCoverageRelationStatistics Valid=6, Invalid=6, Unknown=0, NotChecked=0, Total=12 [2022-02-20 21:08:10,981 INFO L933 BasicCegarLoop]: 132 mSDtfsCounter, 68 mSDsluCounter, 50 mSDsCounter, 0 mSdLazyCounter, 31 mSolverCounterSat, 60 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.1s Time, 0 mProtectedPredicate, 0 mProtectedAction, 73 SdHoareTripleChecker+Valid, 182 SdHoareTripleChecker+Invalid, 91 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 60 IncrementalHoareTripleChecker+Valid, 31 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.1s IncrementalHoareTripleChecker+Time [2022-02-20 21:08:10,982 INFO L934 BasicCegarLoop]: SdHoareTripleChecker [73 Valid, 182 Invalid, 91 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [60 Valid, 31 Invalid, 0 Unknown, 0 Unchecked, 0.1s Time] [2022-02-20 21:08:10,997 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 104 states. [2022-02-20 21:08:11,017 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 104 to 104. [2022-02-20 21:08:11,018 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-02-20 21:08:11,019 INFO L82 GeneralOperation]: Start isEquivalent. First operand 104 states. Second operand has 104 states, 65 states have (on average 1.1846153846153846) internal successors, (77), 66 states have internal predecessors, (77), 28 states have call successors, (28), 10 states have call predecessors, (28), 10 states have return successors, (27), 27 states have call predecessors, (27), 27 states have call successors, (27) [2022-02-20 21:08:11,020 INFO L74 IsIncluded]: Start isIncluded. First operand 104 states. Second operand has 104 states, 65 states have (on average 1.1846153846153846) internal successors, (77), 66 states have internal predecessors, (77), 28 states have call successors, (28), 10 states have call predecessors, (28), 10 states have return successors, (27), 27 states have call predecessors, (27), 27 states have call successors, (27) [2022-02-20 21:08:11,021 INFO L87 Difference]: Start difference. First operand 104 states. Second operand has 104 states, 65 states have (on average 1.1846153846153846) internal successors, (77), 66 states have internal predecessors, (77), 28 states have call successors, (28), 10 states have call predecessors, (28), 10 states have return successors, (27), 27 states have call predecessors, (27), 27 states have call successors, (27) [2022-02-20 21:08:11,031 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 21:08:11,031 INFO L93 Difference]: Finished difference Result 104 states and 132 transitions. [2022-02-20 21:08:11,031 INFO L276 IsEmpty]: Start isEmpty. Operand 104 states and 132 transitions. [2022-02-20 21:08:11,045 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 21:08:11,045 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 21:08:11,046 INFO L74 IsIncluded]: Start isIncluded. First operand has 104 states, 65 states have (on average 1.1846153846153846) internal successors, (77), 66 states have internal predecessors, (77), 28 states have call successors, (28), 10 states have call predecessors, (28), 10 states have return successors, (27), 27 states have call predecessors, (27), 27 states have call successors, (27) Second operand 104 states. [2022-02-20 21:08:11,052 INFO L87 Difference]: Start difference. First operand has 104 states, 65 states have (on average 1.1846153846153846) internal successors, (77), 66 states have internal predecessors, (77), 28 states have call successors, (28), 10 states have call predecessors, (28), 10 states have return successors, (27), 27 states have call predecessors, (27), 27 states have call successors, (27) Second operand 104 states. [2022-02-20 21:08:11,063 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 21:08:11,064 INFO L93 Difference]: Finished difference Result 104 states and 132 transitions. [2022-02-20 21:08:11,065 INFO L276 IsEmpty]: Start isEmpty. Operand 104 states and 132 transitions. [2022-02-20 21:08:11,069 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 21:08:11,080 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 21:08:11,080 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-02-20 21:08:11,081 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-02-20 21:08:11,082 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 104 states, 65 states have (on average 1.1846153846153846) internal successors, (77), 66 states have internal predecessors, (77), 28 states have call successors, (28), 10 states have call predecessors, (28), 10 states have return successors, (27), 27 states have call predecessors, (27), 27 states have call successors, (27) [2022-02-20 21:08:11,087 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 104 states to 104 states and 132 transitions. [2022-02-20 21:08:11,089 INFO L78 Accepts]: Start accepts. Automaton has 104 states and 132 transitions. Word has length 93 [2022-02-20 21:08:11,089 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-02-20 21:08:11,089 INFO L470 AbstractCegarLoop]: Abstraction has 104 states and 132 transitions. [2022-02-20 21:08:11,090 INFO L471 AbstractCegarLoop]: INTERPOLANT automaton has has 4 states, 4 states have (on average 10.75) internal successors, (43), 2 states have internal predecessors, (43), 2 states have call successors, (14), 4 states have call predecessors, (14), 2 states have return successors, (13), 2 states have call predecessors, (13), 2 states have call successors, (13) [2022-02-20 21:08:11,090 INFO L276 IsEmpty]: Start isEmpty. Operand 104 states and 132 transitions. [2022-02-20 21:08:11,093 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 97 [2022-02-20 21:08:11,101 INFO L506 BasicCegarLoop]: Found error trace [2022-02-20 21:08:11,101 INFO L514 BasicCegarLoop]: trace histogram [6, 6, 6, 2, 2, 2, 2, 2, 2, 2, 2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2022-02-20 21:08:11,102 WARN L452 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable0 [2022-02-20 21:08:11,102 INFO L402 AbstractCegarLoop]: === Iteration 2 === Targeting __VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION === [__VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-02-20 21:08:11,103 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-02-20 21:08:11,103 INFO L85 PathProgramCache]: Analyzing trace with hash 566240687, now seen corresponding path program 1 times [2022-02-20 21:08:11,103 INFO L126 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-02-20 21:08:11,103 INFO L338 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [348806456] [2022-02-20 21:08:11,104 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 21:08:11,104 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-02-20 21:08:11,176 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:11,294 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 2 [2022-02-20 21:08:11,360 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:11,554 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:08:11,557 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:11,567 INFO L290 TraceCheckUtils]: 0: Hoare triple {860#true} #res := #t~nondet13;havoc #t~nondet13; {860#true} is VALID [2022-02-20 21:08:11,567 INFO L290 TraceCheckUtils]: 1: Hoare triple {860#true} assume true; {860#true} is VALID [2022-02-20 21:08:11,568 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {860#true} {937#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} #182#return; {937#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} is VALID [2022-02-20 21:08:11,569 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 6 [2022-02-20 21:08:11,592 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:11,657 INFO L290 TraceCheckUtils]: 0: Hoare triple {860#true} ~cond := #in~cond; {960#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} is VALID [2022-02-20 21:08:11,658 INFO L290 TraceCheckUtils]: 1: Hoare triple {960#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} assume !(0 == ~cond % 256); {961#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} is VALID [2022-02-20 21:08:11,659 INFO L290 TraceCheckUtils]: 2: Hoare triple {961#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} assume true; {961#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} is VALID [2022-02-20 21:08:11,661 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {961#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} {937#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} #184#return; {945#(or (not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96)) (<= (* 18446744073709551616 (div |ensure_string_is_allocated_bounded_length_~len~1#1| 18446744073709551616)) (+ |ensure_string_is_allocated_bounded_length_~len~1#1| (* 18446744073709551616 (div (+ (* 18446744073709551616 (div |ensure_string_is_allocated_bounded_length_~len~1#1| 18446744073709551616)) 95 (* (- 1) |ensure_string_is_allocated_bounded_length_~len~1#1|)) 18446744073709551616)))))} is VALID [2022-02-20 21:08:11,680 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 12 [2022-02-20 21:08:11,696 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:11,822 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:08:11,827 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:11,854 INFO L290 TraceCheckUtils]: 0: Hoare triple {860#true} ~cond := #in~cond; {960#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} is VALID [2022-02-20 21:08:11,855 INFO L290 TraceCheckUtils]: 1: Hoare triple {960#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} assume !(0 == ~cond % 256); {961#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} is VALID [2022-02-20 21:08:11,855 INFO L290 TraceCheckUtils]: 2: Hoare triple {961#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} assume true; {961#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} is VALID [2022-02-20 21:08:11,856 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {961#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} {963#(= |bounded_malloc_#in~size| bounded_malloc_~size)} #192#return; {968#(and (= |bounded_malloc_#in~size| bounded_malloc_~size) (<= bounded_malloc_~size (+ (* (div bounded_malloc_~size 18446744073709551616) 18446744073709551616) 36028797018963967)))} is VALID [2022-02-20 21:08:11,857 INFO L290 TraceCheckUtils]: 0: Hoare triple {962#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size; {963#(= |bounded_malloc_#in~size| bounded_malloc_~size)} is VALID [2022-02-20 21:08:11,857 INFO L272 TraceCheckUtils]: 1: Hoare triple {963#(= |bounded_malloc_#in~size| bounded_malloc_~size)} call assume_abort_if_not((if 0 == (if ~size % 18446744073709551616 <= 36028797018963967 then 1 else 0) then 0 else 1)); {860#true} is VALID [2022-02-20 21:08:11,858 INFO L290 TraceCheckUtils]: 2: Hoare triple {860#true} ~cond := #in~cond; {960#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} is VALID [2022-02-20 21:08:11,859 INFO L290 TraceCheckUtils]: 3: Hoare triple {960#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} assume !(0 == ~cond % 256); {961#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} is VALID [2022-02-20 21:08:11,859 INFO L290 TraceCheckUtils]: 4: Hoare triple {961#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} assume true; {961#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} is VALID [2022-02-20 21:08:11,860 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {961#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} {963#(= |bounded_malloc_#in~size| bounded_malloc_~size)} #192#return; {968#(and (= |bounded_malloc_#in~size| bounded_malloc_~size) (<= bounded_malloc_~size (+ (* (div bounded_malloc_~size 18446744073709551616) 18446744073709551616) 36028797018963967)))} is VALID [2022-02-20 21:08:11,861 INFO L290 TraceCheckUtils]: 6: Hoare triple {968#(and (= |bounded_malloc_#in~size| bounded_malloc_~size) (<= bounded_malloc_~size (+ (* (div bounded_malloc_~size 18446744073709551616) 18446744073709551616) 36028797018963967)))} call #t~malloc555.base, #t~malloc555.offset := #Ultimate.allocOnHeap(~size);#res.base, #res.offset := #t~malloc555.base, #t~malloc555.offset;havoc #t~malloc555.base, #t~malloc555.offset; {969#(<= |bounded_malloc_#in~size| (+ 36028797018963967 (* 18446744073709551616 (div |bounded_malloc_#in~size| 18446744073709551616))))} is VALID [2022-02-20 21:08:11,861 INFO L290 TraceCheckUtils]: 7: Hoare triple {969#(<= |bounded_malloc_#in~size| (+ 36028797018963967 (* 18446744073709551616 (div |bounded_malloc_#in~size| 18446744073709551616))))} assume true; {969#(<= |bounded_malloc_#in~size| (+ 36028797018963967 (* 18446744073709551616 (div |bounded_malloc_#in~size| 18446744073709551616))))} is VALID [2022-02-20 21:08:11,863 INFO L284 TraceCheckUtils]: 8: Hoare quadruple {969#(<= |bounded_malloc_#in~size| (+ 36028797018963967 (* 18446744073709551616 (div |bounded_malloc_#in~size| 18446744073709551616))))} {946#(or (not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96)) (<= 0 (+ (* 18446744073709551616 (div (+ (* (- 1) |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~len#1|) 95) 18446744073709551616)) |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~len#1|)))} #186#return; {956#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} is VALID [2022-02-20 21:08:11,864 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 23 [2022-02-20 21:08:11,866 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:11,877 INFO L290 TraceCheckUtils]: 0: Hoare triple {860#true} #res := #t~nondet8;havoc #t~nondet8; {860#true} is VALID [2022-02-20 21:08:11,877 INFO L290 TraceCheckUtils]: 1: Hoare triple {860#true} assume true; {860#true} is VALID [2022-02-20 21:08:11,878 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {860#true} {956#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} #188#return; {956#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} is VALID [2022-02-20 21:08:11,879 INFO L290 TraceCheckUtils]: 0: Hoare triple {936#(and (= |old(#length)| |#length|) (= |old(#memory_real)| |#memory_real|) (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|) (= |old(#valid)| |#valid|))} ~max_size#1 := #in~max_size#1; {937#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} is VALID [2022-02-20 21:08:11,879 INFO L272 TraceCheckUtils]: 1: Hoare triple {937#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} call #t~ret540#1 := nondet_uint64_t(); {860#true} is VALID [2022-02-20 21:08:11,879 INFO L290 TraceCheckUtils]: 2: Hoare triple {860#true} #res := #t~nondet13;havoc #t~nondet13; {860#true} is VALID [2022-02-20 21:08:11,879 INFO L290 TraceCheckUtils]: 3: Hoare triple {860#true} assume true; {860#true} is VALID [2022-02-20 21:08:11,880 INFO L284 TraceCheckUtils]: 4: Hoare quadruple {860#true} {937#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} #182#return; {937#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} is VALID [2022-02-20 21:08:11,880 INFO L290 TraceCheckUtils]: 5: Hoare triple {937#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} ~len~1#1 := #t~ret540#1;havoc #t~ret540#1; {937#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} is VALID [2022-02-20 21:08:11,881 INFO L272 TraceCheckUtils]: 6: Hoare triple {937#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} call assume_abort_if_not((if 0 == (if ~len~1#1 % 18446744073709551616 < ~max_size#1 % 18446744073709551616 then 1 else 0) then 0 else 1)); {860#true} is VALID [2022-02-20 21:08:11,881 INFO L290 TraceCheckUtils]: 7: Hoare triple {860#true} ~cond := #in~cond; {960#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} is VALID [2022-02-20 21:08:11,882 INFO L290 TraceCheckUtils]: 8: Hoare triple {960#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} assume !(0 == ~cond % 256); {961#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} is VALID [2022-02-20 21:08:11,882 INFO L290 TraceCheckUtils]: 9: Hoare triple {961#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} assume true; {961#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} is VALID [2022-02-20 21:08:11,884 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {961#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} {937#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} #184#return; {945#(or (not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96)) (<= (* 18446744073709551616 (div |ensure_string_is_allocated_bounded_length_~len~1#1| 18446744073709551616)) (+ |ensure_string_is_allocated_bounded_length_~len~1#1| (* 18446744073709551616 (div (+ (* 18446744073709551616 (div |ensure_string_is_allocated_bounded_length_~len~1#1| 18446744073709551616)) 95 (* (- 1) |ensure_string_is_allocated_bounded_length_~len~1#1|)) 18446744073709551616)))))} is VALID [2022-02-20 21:08:11,886 INFO L290 TraceCheckUtils]: 11: Hoare triple {945#(or (not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96)) (<= (* 18446744073709551616 (div |ensure_string_is_allocated_bounded_length_~len~1#1| 18446744073709551616)) (+ |ensure_string_is_allocated_bounded_length_~len~1#1| (* 18446744073709551616 (div (+ (* 18446744073709551616 (div |ensure_string_is_allocated_bounded_length_~len~1#1| 18446744073709551616)) 95 (* (- 1) |ensure_string_is_allocated_bounded_length_~len~1#1|)) 18446744073709551616)))))} assume { :begin_inline_ensure_string_is_allocated } true;ensure_string_is_allocated_#in~len#1 := ~len~1#1;havoc ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset;havoc ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset, ensure_string_is_allocated_#t~ret543#1, ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset, ensure_string_is_allocated_#t~ret544#1.base, ensure_string_is_allocated_#t~ret544#1.offset, ensure_string_is_allocated_~len#1, ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset;ensure_string_is_allocated_~len#1 := ensure_string_is_allocated_#in~len#1; {946#(or (not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96)) (<= 0 (+ (* 18446744073709551616 (div (+ (* (- 1) |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~len#1|) 95) 18446744073709551616)) |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~len#1|)))} is VALID [2022-02-20 21:08:11,888 INFO L272 TraceCheckUtils]: 12: Hoare triple {946#(or (not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96)) (<= 0 (+ (* 18446744073709551616 (div (+ (* (- 1) |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~len#1|) 95) 18446744073709551616)) |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~len#1|)))} call ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset := bounded_malloc(-1234550 + ensure_string_is_allocated_~len#1); {962#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:08:11,888 INFO L290 TraceCheckUtils]: 13: Hoare triple {962#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size; {963#(= |bounded_malloc_#in~size| bounded_malloc_~size)} is VALID [2022-02-20 21:08:11,888 INFO L272 TraceCheckUtils]: 14: Hoare triple {963#(= |bounded_malloc_#in~size| bounded_malloc_~size)} call assume_abort_if_not((if 0 == (if ~size % 18446744073709551616 <= 36028797018963967 then 1 else 0) then 0 else 1)); {860#true} is VALID [2022-02-20 21:08:11,889 INFO L290 TraceCheckUtils]: 15: Hoare triple {860#true} ~cond := #in~cond; {960#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} is VALID [2022-02-20 21:08:11,889 INFO L290 TraceCheckUtils]: 16: Hoare triple {960#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} assume !(0 == ~cond % 256); {961#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} is VALID [2022-02-20 21:08:11,890 INFO L290 TraceCheckUtils]: 17: Hoare triple {961#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} assume true; {961#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} is VALID [2022-02-20 21:08:11,891 INFO L284 TraceCheckUtils]: 18: Hoare quadruple {961#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} {963#(= |bounded_malloc_#in~size| bounded_malloc_~size)} #192#return; {968#(and (= |bounded_malloc_#in~size| bounded_malloc_~size) (<= bounded_malloc_~size (+ (* (div bounded_malloc_~size 18446744073709551616) 18446744073709551616) 36028797018963967)))} is VALID [2022-02-20 21:08:11,892 INFO L290 TraceCheckUtils]: 19: Hoare triple {968#(and (= |bounded_malloc_#in~size| bounded_malloc_~size) (<= bounded_malloc_~size (+ (* (div bounded_malloc_~size 18446744073709551616) 18446744073709551616) 36028797018963967)))} call #t~malloc555.base, #t~malloc555.offset := #Ultimate.allocOnHeap(~size);#res.base, #res.offset := #t~malloc555.base, #t~malloc555.offset;havoc #t~malloc555.base, #t~malloc555.offset; {969#(<= |bounded_malloc_#in~size| (+ 36028797018963967 (* 18446744073709551616 (div |bounded_malloc_#in~size| 18446744073709551616))))} is VALID [2022-02-20 21:08:11,892 INFO L290 TraceCheckUtils]: 20: Hoare triple {969#(<= |bounded_malloc_#in~size| (+ 36028797018963967 (* 18446744073709551616 (div |bounded_malloc_#in~size| 18446744073709551616))))} assume true; {969#(<= |bounded_malloc_#in~size| (+ 36028797018963967 (* 18446744073709551616 (div |bounded_malloc_#in~size| 18446744073709551616))))} is VALID [2022-02-20 21:08:11,894 INFO L284 TraceCheckUtils]: 21: Hoare quadruple {969#(<= |bounded_malloc_#in~size| (+ 36028797018963967 (* 18446744073709551616 (div |bounded_malloc_#in~size| 18446744073709551616))))} {946#(or (not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96)) (<= 0 (+ (* 18446744073709551616 (div (+ (* (- 1) |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~len#1|) 95) 18446744073709551616)) |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~len#1|)))} #186#return; {956#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} is VALID [2022-02-20 21:08:11,894 INFO L290 TraceCheckUtils]: 22: Hoare triple {956#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset := ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset;havoc ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset; {956#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} is VALID [2022-02-20 21:08:11,894 INFO L272 TraceCheckUtils]: 23: Hoare triple {956#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} call ensure_string_is_allocated_#t~ret543#1 := nondet_bool(); {860#true} is VALID [2022-02-20 21:08:11,895 INFO L290 TraceCheckUtils]: 24: Hoare triple {860#true} #res := #t~nondet8;havoc #t~nondet8; {860#true} is VALID [2022-02-20 21:08:11,895 INFO L290 TraceCheckUtils]: 25: Hoare triple {860#true} assume true; {860#true} is VALID [2022-02-20 21:08:11,896 INFO L284 TraceCheckUtils]: 26: Hoare quadruple {860#true} {956#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} #188#return; {956#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} is VALID [2022-02-20 21:08:11,896 INFO L290 TraceCheckUtils]: 27: Hoare triple {956#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} assume !(0 != ensure_string_is_allocated_#t~ret543#1 % 256);ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset := 0, 0; {956#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} is VALID [2022-02-20 21:08:11,896 INFO L290 TraceCheckUtils]: 28: Hoare triple {956#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} call write~$Pointer$(ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset, ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset, 8);havoc ensure_string_is_allocated_#t~ret543#1;havoc ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset;havoc ensure_string_is_allocated_#t~ret544#1.base, ensure_string_is_allocated_#t~ret544#1.offset;call write~int(ensure_string_is_allocated_~len#1, ensure_string_is_allocated_~str~0#1.base, 8 + ensure_string_is_allocated_~str~0#1.offset, 8);call write~int(0, ensure_string_is_allocated_~str~0#1.base, 16 + ensure_string_is_allocated_~str~0#1.offset + (if ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 else ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset := ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset; {956#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} is VALID [2022-02-20 21:08:11,897 INFO L290 TraceCheckUtils]: 29: Hoare triple {956#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} #t~ret541#1.base, #t~ret541#1.offset := ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset;assume { :end_inline_ensure_string_is_allocated } true;#res#1.base, #res#1.offset := #t~ret541#1.base, #t~ret541#1.offset;havoc #t~ret541#1.base, #t~ret541#1.offset; {956#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} is VALID [2022-02-20 21:08:11,898 INFO L290 TraceCheckUtils]: 30: Hoare triple {956#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} assume true; {956#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} is VALID [2022-02-20 21:08:11,899 INFO L284 TraceCheckUtils]: 31: Hoare quadruple {956#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} {860#true} #198#return; {894#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_#t~ret1963#1.base| 0))} is VALID [2022-02-20 21:08:11,899 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 36 [2022-02-20 21:08:11,901 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:11,910 INFO L290 TraceCheckUtils]: 0: Hoare triple {860#true} #res := #t~nondet8;havoc #t~nondet8; {860#true} is VALID [2022-02-20 21:08:11,910 INFO L290 TraceCheckUtils]: 1: Hoare triple {860#true} assume true; {860#true} is VALID [2022-02-20 21:08:11,911 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {860#true} {895#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| 0))} #200#return; {895#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| 0))} is VALID [2022-02-20 21:08:11,911 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 42 [2022-02-20 21:08:11,917 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:11,934 INFO L290 TraceCheckUtils]: 0: Hoare triple {860#true} ~str.base, ~str.offset := #in~str.base, #in~str.offset;#t~short464 := ~str.base != 0 || ~str.offset != 0; {860#true} is VALID [2022-02-20 21:08:11,935 INFO L290 TraceCheckUtils]: 1: Hoare triple {860#true} assume #t~short464;call #t~mem463 := read~int(~str.base, 8 + ~str.offset, 8);#t~short464 := 0 == (1 + #t~mem463) % 18446744073709551616 || ~str.base != 0 || 16 + ~str.offset != 0; {860#true} is VALID [2022-02-20 21:08:11,935 INFO L290 TraceCheckUtils]: 2: Hoare triple {860#true} #t~short467 := #t~short464; {860#true} is VALID [2022-02-20 21:08:11,936 INFO L290 TraceCheckUtils]: 3: Hoare triple {860#true} assume #t~short467;call #t~mem465 := read~int(~str.base, 8 + ~str.offset, 8);call #t~mem466 := read~int(~str.base, 16 + ~str.offset + (if #t~mem465 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then #t~mem465 % 18446744073709551616 % 18446744073709551616 else #t~mem465 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);#t~short467 := 0 == #t~mem466 % 256; {860#true} is VALID [2022-02-20 21:08:11,936 INFO L290 TraceCheckUtils]: 4: Hoare triple {860#true} #res := (if 0 == (if #t~short467 then 1 else 0) then 0 else 1);havoc #t~mem463;havoc #t~short464;havoc #t~mem465;havoc #t~mem466;havoc #t~short467; {860#true} is VALID [2022-02-20 21:08:11,936 INFO L290 TraceCheckUtils]: 5: Hoare triple {860#true} assume true; {860#true} is VALID [2022-02-20 21:08:11,937 INFO L284 TraceCheckUtils]: 6: Hoare quadruple {860#true} {900#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} #204#return; {900#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} is VALID [2022-02-20 21:08:11,938 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 50 [2022-02-20 21:08:11,940 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:11,953 INFO L290 TraceCheckUtils]: 0: Hoare triple {860#true} ~cond := #in~cond; {860#true} is VALID [2022-02-20 21:08:11,955 INFO L290 TraceCheckUtils]: 1: Hoare triple {860#true} assume !(0 == ~cond % 256); {860#true} is VALID [2022-02-20 21:08:11,960 INFO L290 TraceCheckUtils]: 2: Hoare triple {860#true} assume true; {860#true} is VALID [2022-02-20 21:08:11,962 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {860#true} {900#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} #206#return; {900#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} is VALID [2022-02-20 21:08:11,962 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 56 [2022-02-20 21:08:11,971 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:11,987 INFO L290 TraceCheckUtils]: 0: Hoare triple {860#true} ~str.base, ~str.offset := #in~str.base, #in~str.offset;#t~short464 := ~str.base != 0 || ~str.offset != 0; {860#true} is VALID [2022-02-20 21:08:11,987 INFO L290 TraceCheckUtils]: 1: Hoare triple {860#true} assume #t~short464;call #t~mem463 := read~int(~str.base, 8 + ~str.offset, 8);#t~short464 := 0 == (1 + #t~mem463) % 18446744073709551616 || ~str.base != 0 || 16 + ~str.offset != 0; {860#true} is VALID [2022-02-20 21:08:11,988 INFO L290 TraceCheckUtils]: 2: Hoare triple {860#true} #t~short467 := #t~short464; {860#true} is VALID [2022-02-20 21:08:11,991 INFO L290 TraceCheckUtils]: 3: Hoare triple {860#true} assume #t~short467;call #t~mem465 := read~int(~str.base, 8 + ~str.offset, 8);call #t~mem466 := read~int(~str.base, 16 + ~str.offset + (if #t~mem465 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then #t~mem465 % 18446744073709551616 % 18446744073709551616 else #t~mem465 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);#t~short467 := 0 == #t~mem466 % 256; {860#true} is VALID [2022-02-20 21:08:11,993 INFO L290 TraceCheckUtils]: 4: Hoare triple {860#true} #res := (if 0 == (if #t~short467 then 1 else 0) then 0 else 1);havoc #t~mem463;havoc #t~short464;havoc #t~mem465;havoc #t~mem466;havoc #t~short467; {860#true} is VALID [2022-02-20 21:08:11,996 INFO L290 TraceCheckUtils]: 5: Hoare triple {860#true} assume true; {860#true} is VALID [2022-02-20 21:08:11,997 INFO L284 TraceCheckUtils]: 6: Hoare quadruple {860#true} {900#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} #208#return; {900#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} is VALID [2022-02-20 21:08:11,997 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 64 [2022-02-20 21:08:12,002 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:12,025 INFO L290 TraceCheckUtils]: 0: Hoare triple {860#true} ~cond := #in~cond; {860#true} is VALID [2022-02-20 21:08:12,025 INFO L290 TraceCheckUtils]: 1: Hoare triple {860#true} assume !(0 == ~cond % 256); {860#true} is VALID [2022-02-20 21:08:12,025 INFO L290 TraceCheckUtils]: 2: Hoare triple {860#true} assume true; {860#true} is VALID [2022-02-20 21:08:12,026 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {860#true} {900#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} #210#return; {900#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} is VALID [2022-02-20 21:08:12,026 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 71 [2022-02-20 21:08:12,031 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:12,043 INFO L290 TraceCheckUtils]: 0: Hoare triple {860#true} ~cond := #in~cond; {860#true} is VALID [2022-02-20 21:08:12,043 INFO L290 TraceCheckUtils]: 1: Hoare triple {860#true} assume !(0 == ~cond % 256); {860#true} is VALID [2022-02-20 21:08:12,043 INFO L290 TraceCheckUtils]: 2: Hoare triple {860#true} assume true; {860#true} is VALID [2022-02-20 21:08:12,044 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {860#true} {923#(not (= |ULTIMATE.start_aws_string_eq_~b#1.base| 0))} #214#return; {923#(not (= |ULTIMATE.start_aws_string_eq_~b#1.base| 0))} is VALID [2022-02-20 21:08:12,045 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 78 [2022-02-20 21:08:12,046 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:12,055 INFO L290 TraceCheckUtils]: 0: Hoare triple {860#true} ~cond := #in~cond; {860#true} is VALID [2022-02-20 21:08:12,055 INFO L290 TraceCheckUtils]: 1: Hoare triple {860#true} assume !(0 == ~cond % 256); {860#true} is VALID [2022-02-20 21:08:12,056 INFO L290 TraceCheckUtils]: 2: Hoare triple {860#true} assume true; {860#true} is VALID [2022-02-20 21:08:12,056 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {860#true} {861#false} #218#return; {861#false} is VALID [2022-02-20 21:08:12,056 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 86 [2022-02-20 21:08:12,057 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:12,074 INFO L290 TraceCheckUtils]: 0: Hoare triple {860#true} ~str.base, ~str.offset := #in~str.base, #in~str.offset;#res := (if 0 == (if (~str.base != 0 || ~str.offset != 0) && (~str.base != 0 || ~str.offset != 0) then 1 else 0) then 0 else 1); {860#true} is VALID [2022-02-20 21:08:12,074 INFO L290 TraceCheckUtils]: 1: Hoare triple {860#true} assume true; {860#true} is VALID [2022-02-20 21:08:12,074 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {860#true} {861#false} #222#return; {861#false} is VALID [2022-02-20 21:08:12,075 INFO L290 TraceCheckUtils]: 0: Hoare triple {860#true} assume { :begin_inline_ULTIMATE.init } true;#NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(38, 2);call #Ultimate.allocInit(12, 3);call #Ultimate.allocInit(78, 4);~#s_can_fail_allocator_static~0.base, ~#s_can_fail_allocator_static~0.offset := 5, 0;call #Ultimate.allocInit(40, 5);call write~init~$Pointer$(#funAddr~s_can_fail_malloc_allocator.base, #funAddr~s_can_fail_malloc_allocator.offset, ~#s_can_fail_allocator_static~0.base, ~#s_can_fail_allocator_static~0.offset, 8);call write~init~$Pointer$(#funAddr~s_can_fail_free_allocator.base, #funAddr~s_can_fail_free_allocator.offset, ~#s_can_fail_allocator_static~0.base, 8 + ~#s_can_fail_allocator_static~0.offset, 8);call write~init~$Pointer$(#funAddr~s_can_fail_realloc_allocator.base, #funAddr~s_can_fail_realloc_allocator.offset, ~#s_can_fail_allocator_static~0.base, 16 + ~#s_can_fail_allocator_static~0.offset, 8);call write~init~$Pointer$(#funAddr~s_can_fail_calloc_allocator.base, #funAddr~s_can_fail_calloc_allocator.offset, ~#s_can_fail_allocator_static~0.base, 24 + ~#s_can_fail_allocator_static~0.offset, 8);call write~init~$Pointer$(0, 0, ~#s_can_fail_allocator_static~0.base, 32 + ~#s_can_fail_allocator_static~0.offset, 8);~#s_tolower_table~0.base, ~#s_tolower_table~0.offset := 6, 0;call #Ultimate.allocInit(256, 6);call write~init~int(0, ~#s_tolower_table~0.base, ~#s_tolower_table~0.offset, 1);call write~init~int(1, ~#s_tolower_table~0.base, 1 + ~#s_tolower_table~0.offset, 1);call write~init~int(2, ~#s_tolower_table~0.base, 2 + ~#s_tolower_table~0.offset, 1);call write~init~int(3, ~#s_tolower_table~0.base, 3 + ~#s_tolower_table~0.offset, 1);call write~init~int(4, ~#s_tolower_table~0.base, 4 + ~#s_tolower_table~0.offset, 1);call write~init~int(5, ~#s_tolower_table~0.base, 5 + ~#s_tolower_table~0.offset, 1);call write~init~int(6, ~#s_tolower_table~0.base, 6 + ~#s_tolower_table~0.offset, 1);call write~init~int(7, ~#s_tolower_table~0.base, 7 + ~#s_tolower_table~0.offset, 1);call write~init~int(8, ~#s_tolower_table~0.base, 8 + ~#s_tolower_table~0.offset, 1);call write~init~int(9, ~#s_tolower_table~0.base, 9 + ~#s_tolower_table~0.offset, 1);call write~init~int(10, ~#s_tolower_table~0.base, 10 + ~#s_tolower_table~0.offset, 1);call write~init~int(11, ~#s_tolower_table~0.base, 11 + ~#s_tolower_table~0.offset, 1);call write~init~int(12, ~#s_tolower_table~0.base, 12 + ~#s_tolower_table~0.offset, 1);call write~init~int(13, ~#s_tolower_table~0.base, 13 + ~#s_tolower_table~0.offset, 1);call write~init~int(14, ~#s_tolower_table~0.base, 14 + ~#s_tolower_table~0.offset, 1);call write~init~int(15, ~#s_tolower_table~0.base, 15 + ~#s_tolower_table~0.offset, 1);call write~init~int(16, ~#s_tolower_table~0.base, 16 + ~#s_tolower_table~0.offset, 1);call write~init~int(17, ~#s_tolower_table~0.base, 17 + ~#s_tolower_table~0.offset, 1);call write~init~int(18, ~#s_tolower_table~0.base, 18 + ~#s_tolower_table~0.offset, 1);call write~init~int(19, ~#s_tolower_table~0.base, 19 + ~#s_tolower_table~0.offset, 1);call write~init~int(20, ~#s_tolower_table~0.base, 20 + ~#s_tolower_table~0.offset, 1);call write~init~int(21, ~#s_tolower_table~0.base, 21 + ~#s_tolower_table~0.offset, 1);call write~init~int(22, ~#s_tolower_table~0.base, 22 + ~#s_tolower_table~0.offset, 1);call write~init~int(23, ~#s_tolower_table~0.base, 23 + ~#s_tolower_table~0.offset, 1);call write~init~int(24, ~#s_tolower_table~0.base, 24 + ~#s_tolower_table~0.offset, 1);call write~init~int(25, ~#s_tolower_table~0.base, 25 + ~#s_tolower_table~0.offset, 1);call write~init~int(26, ~#s_tolower_table~0.base, 26 + ~#s_tolower_table~0.offset, 1);call write~init~int(27, ~#s_tolower_table~0.base, 27 + ~#s_tolower_table~0.offset, 1);call write~init~int(28, ~#s_tolower_table~0.base, 28 + ~#s_tolower_table~0.offset, 1);call write~init~int(29, ~#s_tolower_table~0.base, 29 + ~#s_tolower_table~0.offset, 1);call write~init~int(30, ~#s_tolower_table~0.base, 30 + ~#s_tolower_table~0.offset, 1);call write~init~int(31, ~#s_tolower_table~0.base, 31 + ~#s_tolower_table~0.offset, 1);call write~init~int(32, ~#s_tolower_table~0.base, 32 + ~#s_tolower_table~0.offset, 1);call write~init~int(33, ~#s_tolower_table~0.base, 33 + ~#s_tolower_table~0.offset, 1);call write~init~int(34, ~#s_tolower_table~0.base, 34 + ~#s_tolower_table~0.offset, 1);call write~init~int(35, ~#s_tolower_table~0.base, 35 + ~#s_tolower_table~0.offset, 1);call write~init~int(36, ~#s_tolower_table~0.base, 36 + ~#s_tolower_table~0.offset, 1);call write~init~int(37, ~#s_tolower_table~0.base, 37 + ~#s_tolower_table~0.offset, 1);call write~init~int(38, ~#s_tolower_table~0.base, 38 + ~#s_tolower_table~0.offset, 1);call write~init~int(39, ~#s_tolower_table~0.base, 39 + ~#s_tolower_table~0.offset, 1);call write~init~int(40, ~#s_tolower_table~0.base, 40 + ~#s_tolower_table~0.offset, 1);call write~init~int(41, ~#s_tolower_table~0.base, 41 + ~#s_tolower_table~0.offset, 1);call write~init~int(42, ~#s_tolower_table~0.base, 42 + ~#s_tolower_table~0.offset, 1);call write~init~int(43, ~#s_tolower_table~0.base, 43 + ~#s_tolower_table~0.offset, 1);call write~init~int(44, ~#s_tolower_table~0.base, 44 + ~#s_tolower_table~0.offset, 1);call write~init~int(45, ~#s_tolower_table~0.base, 45 + ~#s_tolower_table~0.offset, 1);call write~init~int(46, ~#s_tolower_table~0.base, 46 + ~#s_tolower_table~0.offset, 1);call write~init~int(47, ~#s_tolower_table~0.base, 47 + ~#s_tolower_table~0.offset, 1);call write~init~int(48, ~#s_tolower_table~0.base, 48 + ~#s_tolower_table~0.offset, 1);call write~init~int(49, ~#s_tolower_table~0.base, 49 + ~#s_tolower_table~0.offset, 1);call write~init~int(50, ~#s_tolower_table~0.base, 50 + ~#s_tolower_table~0.offset, 1);call write~init~int(51, ~#s_tolower_table~0.base, 51 + ~#s_tolower_table~0.offset, 1);call write~init~int(52, ~#s_tolower_table~0.base, 52 + ~#s_tolower_table~0.offset, 1);call write~init~int(53, ~#s_tolower_table~0.base, 53 + ~#s_tolower_table~0.offset, 1);call write~init~int(54, ~#s_tolower_table~0.base, 54 + ~#s_tolower_table~0.offset, 1);call write~init~int(55, ~#s_tolower_table~0.base, 55 + ~#s_tolower_table~0.offset, 1);call write~init~int(56, ~#s_tolower_table~0.base, 56 + ~#s_tolower_table~0.offset, 1);call write~init~int(57, ~#s_tolower_table~0.base, 57 + ~#s_tolower_table~0.offset, 1);call write~init~int(58, ~#s_tolower_table~0.base, 58 + ~#s_tolower_table~0.offset, 1);call write~init~int(59, ~#s_tolower_table~0.base, 59 + ~#s_tolower_table~0.offset, 1);call write~init~int(60, ~#s_tolower_table~0.base, 60 + ~#s_tolower_table~0.offset, 1);call write~init~int(61, ~#s_tolower_table~0.base, 61 + ~#s_tolower_table~0.offset, 1);call write~init~int(62, ~#s_tolower_table~0.base, 62 + ~#s_tolower_table~0.offset, 1);call write~init~int(63, ~#s_tolower_table~0.base, 63 + ~#s_tolower_table~0.offset, 1);call write~init~int(64, ~#s_tolower_table~0.base, 64 + ~#s_tolower_table~0.offset, 1);call write~init~int(97, ~#s_tolower_table~0.base, 65 + ~#s_tolower_table~0.offset, 1);call write~init~int(98, ~#s_tolower_table~0.base, 66 + ~#s_tolower_table~0.offset, 1);call write~init~int(99, ~#s_tolower_table~0.base, 67 + ~#s_tolower_table~0.offset, 1);call write~init~int(100, ~#s_tolower_table~0.base, 68 + ~#s_tolower_table~0.offset, 1);call write~init~int(101, ~#s_tolower_table~0.base, 69 + ~#s_tolower_table~0.offset, 1);call write~init~int(102, ~#s_tolower_table~0.base, 70 + ~#s_tolower_table~0.offset, 1);call write~init~int(103, ~#s_tolower_table~0.base, 71 + ~#s_tolower_table~0.offset, 1);call write~init~int(104, ~#s_tolower_table~0.base, 72 + ~#s_tolower_table~0.offset, 1);call write~init~int(105, ~#s_tolower_table~0.base, 73 + ~#s_tolower_table~0.offset, 1);call write~init~int(106, ~#s_tolower_table~0.base, 74 + ~#s_tolower_table~0.offset, 1);call write~init~int(107, ~#s_tolower_table~0.base, 75 + ~#s_tolower_table~0.offset, 1);call write~init~int(108, ~#s_tolower_table~0.base, 76 + ~#s_tolower_table~0.offset, 1);call write~init~int(109, ~#s_tolower_table~0.base, 77 + ~#s_tolower_table~0.offset, 1);call write~init~int(110, ~#s_tolower_table~0.base, 78 + ~#s_tolower_table~0.offset, 1);call write~init~int(111, ~#s_tolower_table~0.base, 79 + ~#s_tolower_table~0.offset, 1);call write~init~int(112, ~#s_tolower_table~0.base, 80 + ~#s_tolower_table~0.offset, 1);call write~init~int(113, ~#s_tolower_table~0.base, 81 + ~#s_tolower_table~0.offset, 1);call write~init~int(114, ~#s_tolower_table~0.base, 82 + ~#s_tolower_table~0.offset, 1);call write~init~int(115, ~#s_tolower_table~0.base, 83 + ~#s_tolower_table~0.offset, 1);call write~init~int(116, ~#s_tolower_table~0.base, 84 + ~#s_tolower_table~0.offset, 1);call write~init~int(117, ~#s_tolower_table~0.base, 85 + ~#s_tolower_table~0.offset, 1);call write~init~int(118, ~#s_tolower_table~0.base, 86 + ~#s_tolower_table~0.offset, 1);call write~init~int(119, ~#s_tolower_table~0.base, 87 + ~#s_tolower_table~0.offset, 1);call write~init~int(120, ~#s_tolower_table~0.base, 88 + ~#s_tolower_table~0.offset, 1);call write~init~int(121, ~#s_tolower_table~0.base, 89 + ~#s_tolower_table~0.offset, 1);call write~init~int(122, ~#s_tolower_table~0.base, 90 + ~#s_tolower_table~0.offset, 1);call write~init~int(91, ~#s_tolower_table~0.base, 91 + ~#s_tolower_table~0.offset, 1);call write~init~int(92, ~#s_tolower_table~0.base, 92 + ~#s_tolower_table~0.offset, 1);call write~init~int(93, ~#s_tolower_table~0.base, 93 + ~#s_tolower_table~0.offset, 1);call write~init~int(94, ~#s_tolower_table~0.base, 94 + ~#s_tolower_table~0.offset, 1);call write~init~int(95, ~#s_tolower_table~0.base, 95 + ~#s_tolower_table~0.offset, 1);call write~init~int(96, ~#s_tolower_table~0.base, 96 + ~#s_tolower_table~0.offset, 1);call write~init~int(97, ~#s_tolower_table~0.base, 97 + ~#s_tolower_table~0.offset, 1);call write~init~int(98, ~#s_tolower_table~0.base, 98 + ~#s_tolower_table~0.offset, 1);call write~init~int(99, ~#s_tolower_table~0.base, 99 + ~#s_tolower_table~0.offset, 1);call write~init~int(100, ~#s_tolower_table~0.base, 100 + ~#s_tolower_table~0.offset, 1);call write~init~int(101, ~#s_tolower_table~0.base, 101 + ~#s_tolower_table~0.offset, 1);call write~init~int(102, ~#s_tolower_table~0.base, 102 + ~#s_tolower_table~0.offset, 1);call write~init~int(103, ~#s_tolower_table~0.base, 103 + ~#s_tolower_table~0.offset, 1);call write~init~int(104, ~#s_tolower_table~0.base, 104 + ~#s_tolower_table~0.offset, 1);call write~init~int(105, ~#s_tolower_table~0.base, 105 + ~#s_tolower_table~0.offset, 1);call write~init~int(106, ~#s_tolower_table~0.base, 106 + ~#s_tolower_table~0.offset, 1);call write~init~int(107, ~#s_tolower_table~0.base, 107 + ~#s_tolower_table~0.offset, 1);call write~init~int(108, ~#s_tolower_table~0.base, 108 + ~#s_tolower_table~0.offset, 1);call write~init~int(109, ~#s_tolower_table~0.base, 109 + ~#s_tolower_table~0.offset, 1);call write~init~int(110, ~#s_tolower_table~0.base, 110 + ~#s_tolower_table~0.offset, 1);call write~init~int(111, ~#s_tolower_table~0.base, 111 + ~#s_tolower_table~0.offset, 1);call write~init~int(112, ~#s_tolower_table~0.base, 112 + ~#s_tolower_table~0.offset, 1);call write~init~int(113, ~#s_tolower_table~0.base, 113 + ~#s_tolower_table~0.offset, 1);call write~init~int(114, ~#s_tolower_table~0.base, 114 + ~#s_tolower_table~0.offset, 1);call write~init~int(115, ~#s_tolower_table~0.base, 115 + ~#s_tolower_table~0.offset, 1);call write~init~int(116, ~#s_tolower_table~0.base, 116 + ~#s_tolower_table~0.offset, 1);call write~init~int(117, ~#s_tolower_table~0.base, 117 + ~#s_tolower_table~0.offset, 1);call write~init~int(118, ~#s_tolower_table~0.base, 118 + ~#s_tolower_table~0.offset, 1);call write~init~int(119, ~#s_tolower_table~0.base, 119 + ~#s_tolower_table~0.offset, 1);call write~init~int(120, ~#s_tolower_table~0.base, 120 + ~#s_tolower_table~0.offset, 1);call write~init~int(121, ~#s_tolower_table~0.base, 121 + ~#s_tolower_table~0.offset, 1);call write~init~int(122, ~#s_tolower_table~0.base, 122 + ~#s_tolower_table~0.offset, 1);call write~init~int(123, ~#s_tolower_table~0.base, 123 + ~#s_tolower_table~0.offset, 1);call write~init~int(124, ~#s_tolower_table~0.base, 124 + ~#s_tolower_table~0.offset, 1);call write~init~int(125, ~#s_tolower_table~0.base, 125 + ~#s_tolower_table~0.offset, 1);call write~init~int(126, ~#s_tolower_table~0.base, 126 + ~#s_tolower_table~0.offset, 1);call write~init~int(127, ~#s_tolower_table~0.base, 127 + ~#s_tolower_table~0.offset, 1);call write~init~int(128, ~#s_tolower_table~0.base, 128 + ~#s_tolower_table~0.offset, 1);call write~init~int(129, ~#s_tolower_table~0.base, 129 + ~#s_tolower_table~0.offset, 1);call write~init~int(130, ~#s_tolower_table~0.base, 130 + ~#s_tolower_table~0.offset, 1);call write~init~int(131, ~#s_tolower_table~0.base, 131 + ~#s_tolower_table~0.offset, 1);call write~init~int(132, ~#s_tolower_table~0.base, 132 + ~#s_tolower_table~0.offset, 1);call write~init~int(133, ~#s_tolower_table~0.base, 133 + ~#s_tolower_table~0.offset, 1);call write~init~int(134, ~#s_tolower_table~0.base, 134 + ~#s_tolower_table~0.offset, 1);call write~init~int(135, ~#s_tolower_table~0.base, 135 + ~#s_tolower_table~0.offset, 1);call write~init~int(136, ~#s_tolower_table~0.base, 136 + ~#s_tolower_table~0.offset, 1);call write~init~int(137, ~#s_tolower_table~0.base, 137 + ~#s_tolower_table~0.offset, 1);call write~init~int(138, ~#s_tolower_table~0.base, 138 + ~#s_tolower_table~0.offset, 1);call write~init~int(139, ~#s_tolower_table~0.base, 139 + ~#s_tolower_table~0.offset, 1);call write~init~int(140, ~#s_tolower_table~0.base, 140 + ~#s_tolower_table~0.offset, 1);call write~init~int(141, ~#s_tolower_table~0.base, 141 + ~#s_tolower_table~0.offset, 1);call write~init~int(142, ~#s_tolower_table~0.base, 142 + ~#s_tolower_table~0.offset, 1);call write~init~int(143, ~#s_tolower_table~0.base, 143 + ~#s_tolower_table~0.offset, 1);call write~init~int(144, ~#s_tolower_table~0.base, 144 + ~#s_tolower_table~0.offset, 1);call write~init~int(145, ~#s_tolower_table~0.base, 145 + ~#s_tolower_table~0.offset, 1);call write~init~int(146, ~#s_tolower_table~0.base, 146 + ~#s_tolower_table~0.offset, 1);call write~init~int(147, ~#s_tolower_table~0.base, 147 + ~#s_tolower_table~0.offset, 1);call write~init~int(148, ~#s_tolower_table~0.base, 148 + ~#s_tolower_table~0.offset, 1);call write~init~int(149, ~#s_tolower_table~0.base, 149 + ~#s_tolower_table~0.offset, 1);call write~init~int(150, ~#s_tolower_table~0.base, 150 + ~#s_tolower_table~0.offset, 1);call write~init~int(151, ~#s_tolower_table~0.base, 151 + ~#s_tolower_table~0.offset, 1);call write~init~int(152, ~#s_tolower_table~0.base, 152 + ~#s_tolower_table~0.offset, 1);call write~init~int(153, ~#s_tolower_table~0.base, 153 + ~#s_tolower_table~0.offset, 1);call write~init~int(154, ~#s_tolower_table~0.base, 154 + ~#s_tolower_table~0.offset, 1);call write~init~int(155, ~#s_tolower_table~0.base, 155 + ~#s_tolower_table~0.offset, 1);call write~init~int(156, ~#s_tolower_table~0.base, 156 + ~#s_tolower_table~0.offset, 1);call write~init~int(157, ~#s_tolower_table~0.base, 157 + ~#s_tolower_table~0.offset, 1);call write~init~int(158, ~#s_tolower_table~0.base, 158 + ~#s_tolower_table~0.offset, 1);call write~init~int(159, ~#s_tolower_table~0.base, 159 + ~#s_tolower_table~0.offset, 1);call write~init~int(160, ~#s_tolower_table~0.base, 160 + ~#s_tolower_table~0.offset, 1);call write~init~int(161, ~#s_tolower_table~0.base, 161 + ~#s_tolower_table~0.offset, 1);call write~init~int(162, ~#s_tolower_table~0.base, 162 + ~#s_tolower_table~0.offset, 1);call write~init~int(163, ~#s_tolower_table~0.base, 163 + ~#s_tolower_table~0.offset, 1);call write~init~int(164, ~#s_tolower_table~0.base, 164 + ~#s_tolower_table~0.offset, 1);call write~init~int(165, ~#s_tolower_table~0.base, 165 + ~#s_tolower_table~0.offset, 1);call write~init~int(166, ~#s_tolower_table~0.base, 166 + ~#s_tolower_table~0.offset, 1);call write~init~int(167, ~#s_tolower_table~0.base, 167 + ~#s_tolower_table~0.offset, 1);call write~init~int(168, ~#s_tolower_table~0.base, 168 + ~#s_tolower_table~0.offset, 1);call write~init~int(169, ~#s_tolower_table~0.base, 169 + ~#s_tolower_table~0.offset, 1);call write~init~int(170, ~#s_tolower_table~0.base, 170 + ~#s_tolower_table~0.offset, 1);call write~init~int(171, ~#s_tolower_table~0.base, 171 + ~#s_tolower_table~0.offset, 1);call write~init~int(172, ~#s_tolower_table~0.base, 172 + ~#s_tolower_table~0.offset, 1);call write~init~int(173, ~#s_tolower_table~0.base, 173 + ~#s_tolower_table~0.offset, 1);call write~init~int(174, ~#s_tolower_table~0.base, 174 + ~#s_tolower_table~0.offset, 1);call write~init~int(175, ~#s_tolower_table~0.base, 175 + ~#s_tolower_table~0.offset, 1);call write~init~int(176, ~#s_tolower_table~0.base, 176 + ~#s_tolower_table~0.offset, 1);call write~init~int(177, ~#s_tolower_table~0.base, 177 + ~#s_tolower_table~0.offset, 1);call write~init~int(178, ~#s_tolower_table~0.base, 178 + ~#s_tolower_table~0.offset, 1);call write~init~int(179, ~#s_tolower_table~0.base, 179 + ~#s_tolower_table~0.offset, 1);call write~init~int(180, ~#s_tolower_table~0.base, 180 + ~#s_tolower_table~0.offset, 1);call write~init~int(181, ~#s_tolower_table~0.base, 181 + ~#s_tolower_table~0.offset, 1);call write~init~int(182, ~#s_tolower_table~0.base, 182 + ~#s_tolower_table~0.offset, 1);call write~init~int(183, ~#s_tolower_table~0.base, 183 + ~#s_tolower_table~0.offset, 1);call write~init~int(184, ~#s_tolower_table~0.base, 184 + ~#s_tolower_table~0.offset, 1);call write~init~int(185, ~#s_tolower_table~0.base, 185 + ~#s_tolower_table~0.offset, 1);call write~init~int(186, ~#s_tolower_table~0.base, 186 + ~#s_tolower_table~0.offset, 1);call write~init~int(187, ~#s_tolower_table~0.base, 187 + ~#s_tolower_table~0.offset, 1);call write~init~int(188, ~#s_tolower_table~0.base, 188 + ~#s_tolower_table~0.offset, 1);call write~init~int(189, ~#s_tolower_table~0.base, 189 + ~#s_tolower_table~0.offset, 1);call write~init~int(190, ~#s_tolower_table~0.base, 190 + ~#s_tolower_table~0.offset, 1);call write~init~int(191, ~#s_tolower_table~0.base, 191 + ~#s_tolower_table~0.offset, 1);call write~init~int(192, ~#s_tolower_table~0.base, 192 + ~#s_tolower_table~0.offset, 1);call write~init~int(193, ~#s_tolower_table~0.base, 193 + ~#s_tolower_table~0.offset, 1);call write~init~int(194, ~#s_tolower_table~0.base, 194 + ~#s_tolower_table~0.offset, 1);call write~init~int(195, ~#s_tolower_table~0.base, 195 + ~#s_tolower_table~0.offset, 1);call write~init~int(196, ~#s_tolower_table~0.base, 196 + ~#s_tolower_table~0.offset, 1);call write~init~int(197, ~#s_tolower_table~0.base, 197 + ~#s_tolower_table~0.offset, 1);call write~init~int(198, ~#s_tolower_table~0.base, 198 + ~#s_tolower_table~0.offset, 1);call write~init~int(199, ~#s_tolower_table~0.base, 199 + ~#s_tolower_table~0.offset, 1);call write~init~int(200, ~#s_tolower_table~0.base, 200 + ~#s_tolower_table~0.offset, 1);call write~init~int(201, ~#s_tolower_table~0.base, 201 + ~#s_tolower_table~0.offset, 1);call write~init~int(202, ~#s_tolower_table~0.base, 202 + ~#s_tolower_table~0.offset, 1);call write~init~int(203, ~#s_tolower_table~0.base, 203 + ~#s_tolower_table~0.offset, 1);call write~init~int(204, ~#s_tolower_table~0.base, 204 + ~#s_tolower_table~0.offset, 1);call write~init~int(205, ~#s_tolower_table~0.base, 205 + ~#s_tolower_table~0.offset, 1);call write~init~int(206, ~#s_tolower_table~0.base, 206 + ~#s_tolower_table~0.offset, 1);call write~init~int(207, ~#s_tolower_table~0.base, 207 + ~#s_tolower_table~0.offset, 1);call write~init~int(208, ~#s_tolower_table~0.base, 208 + ~#s_tolower_table~0.offset, 1);call write~init~int(209, ~#s_tolower_table~0.base, 209 + ~#s_tolower_table~0.offset, 1);call write~init~int(210, ~#s_tolower_table~0.base, 210 + ~#s_tolower_table~0.offset, 1);call write~init~int(211, ~#s_tolower_table~0.base, 211 + ~#s_tolower_table~0.offset, 1);call write~init~int(212, ~#s_tolower_table~0.base, 212 + ~#s_tolower_table~0.offset, 1);call write~init~int(213, ~#s_tolower_table~0.base, 213 + ~#s_tolower_table~0.offset, 1);call write~init~int(214, ~#s_tolower_table~0.base, 214 + ~#s_tolower_table~0.offset, 1);call write~init~int(215, ~#s_tolower_table~0.base, 215 + ~#s_tolower_table~0.offset, 1);call write~init~int(216, ~#s_tolower_table~0.base, 216 + ~#s_tolower_table~0.offset, 1);call write~init~int(217, ~#s_tolower_table~0.base, 217 + ~#s_tolower_table~0.offset, 1);call write~init~int(218, ~#s_tolower_table~0.base, 218 + ~#s_tolower_table~0.offset, 1);call write~init~int(219, ~#s_tolower_table~0.base, 219 + ~#s_tolower_table~0.offset, 1);call write~init~int(220, ~#s_tolower_table~0.base, 220 + ~#s_tolower_table~0.offset, 1);call write~init~int(221, ~#s_tolower_table~0.base, 221 + ~#s_tolower_table~0.offset, 1);call write~init~int(222, ~#s_tolower_table~0.base, 222 + ~#s_tolower_table~0.offset, 1);call write~init~int(223, ~#s_tolower_table~0.base, 223 + ~#s_tolower_table~0.offset, 1);call write~init~int(224, ~#s_tolower_table~0.base, 224 + ~#s_tolower_table~0.offset, 1);call write~init~int(225, ~#s_tolower_table~0.base, 225 + ~#s_tolower_table~0.offset, 1);call write~init~int(226, ~#s_tolower_table~0.base, 226 + ~#s_tolower_table~0.offset, 1);call write~init~int(227, ~#s_tolower_table~0.base, 227 + ~#s_tolower_table~0.offset, 1);call write~init~int(228, ~#s_tolower_table~0.base, 228 + ~#s_tolower_table~0.offset, 1);call write~init~int(229, ~#s_tolower_table~0.base, 229 + ~#s_tolower_table~0.offset, 1);call write~init~int(230, ~#s_tolower_table~0.base, 230 + ~#s_tolower_table~0.offset, 1);call write~init~int(231, ~#s_tolower_table~0.base, 231 + ~#s_tolower_table~0.offset, 1);call write~init~int(232, ~#s_tolower_table~0.base, 232 + ~#s_tolower_table~0.offset, 1);call write~init~int(233, ~#s_tolower_table~0.base, 233 + ~#s_tolower_table~0.offset, 1);call write~init~int(234, ~#s_tolower_table~0.base, 234 + ~#s_tolower_table~0.offset, 1);call write~init~int(235, ~#s_tolower_table~0.base, 235 + ~#s_tolower_table~0.offset, 1);call write~init~int(236, ~#s_tolower_table~0.base, 236 + ~#s_tolower_table~0.offset, 1);call write~init~int(237, ~#s_tolower_table~0.base, 237 + ~#s_tolower_table~0.offset, 1);call write~init~int(238, ~#s_tolower_table~0.base, 238 + ~#s_tolower_table~0.offset, 1);call write~init~int(239, ~#s_tolower_table~0.base, 239 + ~#s_tolower_table~0.offset, 1);call write~init~int(240, ~#s_tolower_table~0.base, 240 + ~#s_tolower_table~0.offset, 1);call write~init~int(241, ~#s_tolower_table~0.base, 241 + ~#s_tolower_table~0.offset, 1);call write~init~int(242, ~#s_tolower_table~0.base, 242 + ~#s_tolower_table~0.offset, 1);call write~init~int(243, ~#s_tolower_table~0.base, 243 + ~#s_tolower_table~0.offset, 1);call write~init~int(244, ~#s_tolower_table~0.base, 244 + ~#s_tolower_table~0.offset, 1);call write~init~int(245, ~#s_tolower_table~0.base, 245 + ~#s_tolower_table~0.offset, 1);call write~init~int(246, ~#s_tolower_table~0.base, 246 + ~#s_tolower_table~0.offset, 1);call write~init~int(247, ~#s_tolower_table~0.base, 247 + ~#s_tolower_table~0.offset, 1);call write~init~int(248, ~#s_tolower_table~0.base, 248 + ~#s_tolower_table~0.offset, 1);call write~init~int(249, ~#s_tolower_table~0.base, 249 + ~#s_tolower_table~0.offset, 1);call write~init~int(250, ~#s_tolower_table~0.base, 250 + ~#s_tolower_table~0.offset, 1);call write~init~int(251, ~#s_tolower_table~0.base, 251 + ~#s_tolower_table~0.offset, 1);call write~init~int(252, ~#s_tolower_table~0.base, 252 + ~#s_tolower_table~0.offset, 1);call write~init~int(253, ~#s_tolower_table~0.base, 253 + ~#s_tolower_table~0.offset, 1);call write~init~int(254, ~#s_tolower_table~0.base, 254 + ~#s_tolower_table~0.offset, 1);call write~init~int(255, ~#s_tolower_table~0.base, 255 + ~#s_tolower_table~0.offset, 1); {860#true} is VALID [2022-02-20 21:08:12,075 INFO L290 TraceCheckUtils]: 1: Hoare triple {860#true} assume { :end_inline_ULTIMATE.init } true;assume { :begin_inline_main } true;havoc main_#res#1;assume { :begin_inline_aws_hash_callback_string_eq_harness } true;havoc aws_hash_callback_string_eq_harness_#t~ret1963#1.base, aws_hash_callback_string_eq_harness_#t~ret1963#1.offset, aws_hash_callback_string_eq_harness_#t~ret1964#1, aws_hash_callback_string_eq_harness_#t~ite1966#1.base, aws_hash_callback_string_eq_harness_#t~ite1966#1.offset, aws_hash_callback_string_eq_harness_#t~ret1965#1.base, aws_hash_callback_string_eq_harness_#t~ret1965#1.offset, aws_hash_callback_string_eq_harness_#t~ret1967#1, aws_hash_callback_string_eq_harness_#t~mem1968#1, aws_hash_callback_string_eq_harness_#t~mem1969#1, aws_hash_callback_string_eq_harness_#t~mem1970#1, aws_hash_callback_string_eq_harness_~str1~0#1.base, aws_hash_callback_string_eq_harness_~str1~0#1.offset, aws_hash_callback_string_eq_harness_~str2~0#1.base, aws_hash_callback_string_eq_harness_~str2~0#1.offset, aws_hash_callback_string_eq_harness_~rval~21#1; {860#true} is VALID [2022-02-20 21:08:12,076 INFO L272 TraceCheckUtils]: 2: Hoare triple {860#true} call aws_hash_callback_string_eq_harness_#t~ret1963#1.base, aws_hash_callback_string_eq_harness_#t~ret1963#1.offset := ensure_string_is_allocated_bounded_length(96); {936#(and (= |old(#length)| |#length|) (= |old(#memory_real)| |#memory_real|) (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:08:12,077 INFO L290 TraceCheckUtils]: 3: Hoare triple {936#(and (= |old(#length)| |#length|) (= |old(#memory_real)| |#memory_real|) (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|) (= |old(#valid)| |#valid|))} ~max_size#1 := #in~max_size#1; {937#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} is VALID [2022-02-20 21:08:12,077 INFO L272 TraceCheckUtils]: 4: Hoare triple {937#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} call #t~ret540#1 := nondet_uint64_t(); {860#true} is VALID [2022-02-20 21:08:12,077 INFO L290 TraceCheckUtils]: 5: Hoare triple {860#true} #res := #t~nondet13;havoc #t~nondet13; {860#true} is VALID [2022-02-20 21:08:12,078 INFO L290 TraceCheckUtils]: 6: Hoare triple {860#true} assume true; {860#true} is VALID [2022-02-20 21:08:12,078 INFO L284 TraceCheckUtils]: 7: Hoare quadruple {860#true} {937#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} #182#return; {937#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} is VALID [2022-02-20 21:08:12,079 INFO L290 TraceCheckUtils]: 8: Hoare triple {937#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} ~len~1#1 := #t~ret540#1;havoc #t~ret540#1; {937#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} is VALID [2022-02-20 21:08:12,080 INFO L272 TraceCheckUtils]: 9: Hoare triple {937#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} call assume_abort_if_not((if 0 == (if ~len~1#1 % 18446744073709551616 < ~max_size#1 % 18446744073709551616 then 1 else 0) then 0 else 1)); {860#true} is VALID [2022-02-20 21:08:12,080 INFO L290 TraceCheckUtils]: 10: Hoare triple {860#true} ~cond := #in~cond; {960#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} is VALID [2022-02-20 21:08:12,081 INFO L290 TraceCheckUtils]: 11: Hoare triple {960#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} assume !(0 == ~cond % 256); {961#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} is VALID [2022-02-20 21:08:12,081 INFO L290 TraceCheckUtils]: 12: Hoare triple {961#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} assume true; {961#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} is VALID [2022-02-20 21:08:12,083 INFO L284 TraceCheckUtils]: 13: Hoare quadruple {961#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} {937#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} #184#return; {945#(or (not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96)) (<= (* 18446744073709551616 (div |ensure_string_is_allocated_bounded_length_~len~1#1| 18446744073709551616)) (+ |ensure_string_is_allocated_bounded_length_~len~1#1| (* 18446744073709551616 (div (+ (* 18446744073709551616 (div |ensure_string_is_allocated_bounded_length_~len~1#1| 18446744073709551616)) 95 (* (- 1) |ensure_string_is_allocated_bounded_length_~len~1#1|)) 18446744073709551616)))))} is VALID [2022-02-20 21:08:12,085 INFO L290 TraceCheckUtils]: 14: Hoare triple {945#(or (not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96)) (<= (* 18446744073709551616 (div |ensure_string_is_allocated_bounded_length_~len~1#1| 18446744073709551616)) (+ |ensure_string_is_allocated_bounded_length_~len~1#1| (* 18446744073709551616 (div (+ (* 18446744073709551616 (div |ensure_string_is_allocated_bounded_length_~len~1#1| 18446744073709551616)) 95 (* (- 1) |ensure_string_is_allocated_bounded_length_~len~1#1|)) 18446744073709551616)))))} assume { :begin_inline_ensure_string_is_allocated } true;ensure_string_is_allocated_#in~len#1 := ~len~1#1;havoc ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset;havoc ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset, ensure_string_is_allocated_#t~ret543#1, ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset, ensure_string_is_allocated_#t~ret544#1.base, ensure_string_is_allocated_#t~ret544#1.offset, ensure_string_is_allocated_~len#1, ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset;ensure_string_is_allocated_~len#1 := ensure_string_is_allocated_#in~len#1; {946#(or (not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96)) (<= 0 (+ (* 18446744073709551616 (div (+ (* (- 1) |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~len#1|) 95) 18446744073709551616)) |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~len#1|)))} is VALID [2022-02-20 21:08:12,086 INFO L272 TraceCheckUtils]: 15: Hoare triple {946#(or (not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96)) (<= 0 (+ (* 18446744073709551616 (div (+ (* (- 1) |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~len#1|) 95) 18446744073709551616)) |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~len#1|)))} call ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset := bounded_malloc(-1234550 + ensure_string_is_allocated_~len#1); {962#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:08:12,086 INFO L290 TraceCheckUtils]: 16: Hoare triple {962#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size; {963#(= |bounded_malloc_#in~size| bounded_malloc_~size)} is VALID [2022-02-20 21:08:12,086 INFO L272 TraceCheckUtils]: 17: Hoare triple {963#(= |bounded_malloc_#in~size| bounded_malloc_~size)} call assume_abort_if_not((if 0 == (if ~size % 18446744073709551616 <= 36028797018963967 then 1 else 0) then 0 else 1)); {860#true} is VALID [2022-02-20 21:08:12,087 INFO L290 TraceCheckUtils]: 18: Hoare triple {860#true} ~cond := #in~cond; {960#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} is VALID [2022-02-20 21:08:12,088 INFO L290 TraceCheckUtils]: 19: Hoare triple {960#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} assume !(0 == ~cond % 256); {961#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} is VALID [2022-02-20 21:08:12,089 INFO L290 TraceCheckUtils]: 20: Hoare triple {961#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} assume true; {961#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} is VALID [2022-02-20 21:08:12,090 INFO L284 TraceCheckUtils]: 21: Hoare quadruple {961#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} {963#(= |bounded_malloc_#in~size| bounded_malloc_~size)} #192#return; {968#(and (= |bounded_malloc_#in~size| bounded_malloc_~size) (<= bounded_malloc_~size (+ (* (div bounded_malloc_~size 18446744073709551616) 18446744073709551616) 36028797018963967)))} is VALID [2022-02-20 21:08:12,091 INFO L290 TraceCheckUtils]: 22: Hoare triple {968#(and (= |bounded_malloc_#in~size| bounded_malloc_~size) (<= bounded_malloc_~size (+ (* (div bounded_malloc_~size 18446744073709551616) 18446744073709551616) 36028797018963967)))} call #t~malloc555.base, #t~malloc555.offset := #Ultimate.allocOnHeap(~size);#res.base, #res.offset := #t~malloc555.base, #t~malloc555.offset;havoc #t~malloc555.base, #t~malloc555.offset; {969#(<= |bounded_malloc_#in~size| (+ 36028797018963967 (* 18446744073709551616 (div |bounded_malloc_#in~size| 18446744073709551616))))} is VALID [2022-02-20 21:08:12,092 INFO L290 TraceCheckUtils]: 23: Hoare triple {969#(<= |bounded_malloc_#in~size| (+ 36028797018963967 (* 18446744073709551616 (div |bounded_malloc_#in~size| 18446744073709551616))))} assume true; {969#(<= |bounded_malloc_#in~size| (+ 36028797018963967 (* 18446744073709551616 (div |bounded_malloc_#in~size| 18446744073709551616))))} is VALID [2022-02-20 21:08:12,093 INFO L284 TraceCheckUtils]: 24: Hoare quadruple {969#(<= |bounded_malloc_#in~size| (+ 36028797018963967 (* 18446744073709551616 (div |bounded_malloc_#in~size| 18446744073709551616))))} {946#(or (not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96)) (<= 0 (+ (* 18446744073709551616 (div (+ (* (- 1) |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~len#1|) 95) 18446744073709551616)) |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~len#1|)))} #186#return; {956#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} is VALID [2022-02-20 21:08:12,094 INFO L290 TraceCheckUtils]: 25: Hoare triple {956#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset := ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset;havoc ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset; {956#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} is VALID [2022-02-20 21:08:12,094 INFO L272 TraceCheckUtils]: 26: Hoare triple {956#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} call ensure_string_is_allocated_#t~ret543#1 := nondet_bool(); {860#true} is VALID [2022-02-20 21:08:12,094 INFO L290 TraceCheckUtils]: 27: Hoare triple {860#true} #res := #t~nondet8;havoc #t~nondet8; {860#true} is VALID [2022-02-20 21:08:12,094 INFO L290 TraceCheckUtils]: 28: Hoare triple {860#true} assume true; {860#true} is VALID [2022-02-20 21:08:12,095 INFO L284 TraceCheckUtils]: 29: Hoare quadruple {860#true} {956#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} #188#return; {956#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} is VALID [2022-02-20 21:08:12,095 INFO L290 TraceCheckUtils]: 30: Hoare triple {956#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} assume !(0 != ensure_string_is_allocated_#t~ret543#1 % 256);ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset := 0, 0; {956#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} is VALID [2022-02-20 21:08:12,096 INFO L290 TraceCheckUtils]: 31: Hoare triple {956#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} call write~$Pointer$(ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset, ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset, 8);havoc ensure_string_is_allocated_#t~ret543#1;havoc ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset;havoc ensure_string_is_allocated_#t~ret544#1.base, ensure_string_is_allocated_#t~ret544#1.offset;call write~int(ensure_string_is_allocated_~len#1, ensure_string_is_allocated_~str~0#1.base, 8 + ensure_string_is_allocated_~str~0#1.offset, 8);call write~int(0, ensure_string_is_allocated_~str~0#1.base, 16 + ensure_string_is_allocated_~str~0#1.offset + (if ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 else ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset := ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset; {956#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} is VALID [2022-02-20 21:08:12,096 INFO L290 TraceCheckUtils]: 32: Hoare triple {956#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} #t~ret541#1.base, #t~ret541#1.offset := ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset;assume { :end_inline_ensure_string_is_allocated } true;#res#1.base, #res#1.offset := #t~ret541#1.base, #t~ret541#1.offset;havoc #t~ret541#1.base, #t~ret541#1.offset; {956#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} is VALID [2022-02-20 21:08:12,098 INFO L290 TraceCheckUtils]: 33: Hoare triple {956#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} assume true; {956#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} is VALID [2022-02-20 21:08:12,102 INFO L284 TraceCheckUtils]: 34: Hoare quadruple {956#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} {860#true} #198#return; {894#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_#t~ret1963#1.base| 0))} is VALID [2022-02-20 21:08:12,103 INFO L290 TraceCheckUtils]: 35: Hoare triple {894#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_#t~ret1963#1.base| 0))} aws_hash_callback_string_eq_harness_~str1~0#1.base, aws_hash_callback_string_eq_harness_~str1~0#1.offset := aws_hash_callback_string_eq_harness_#t~ret1963#1.base, aws_hash_callback_string_eq_harness_#t~ret1963#1.offset;havoc aws_hash_callback_string_eq_harness_#t~ret1963#1.base, aws_hash_callback_string_eq_harness_#t~ret1963#1.offset; {895#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| 0))} is VALID [2022-02-20 21:08:12,105 INFO L272 TraceCheckUtils]: 36: Hoare triple {895#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| 0))} call aws_hash_callback_string_eq_harness_#t~ret1964#1 := nondet_bool(); {860#true} is VALID [2022-02-20 21:08:12,105 INFO L290 TraceCheckUtils]: 37: Hoare triple {860#true} #res := #t~nondet8;havoc #t~nondet8; {860#true} is VALID [2022-02-20 21:08:12,105 INFO L290 TraceCheckUtils]: 38: Hoare triple {860#true} assume true; {860#true} is VALID [2022-02-20 21:08:12,106 INFO L284 TraceCheckUtils]: 39: Hoare quadruple {860#true} {895#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| 0))} #200#return; {895#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| 0))} is VALID [2022-02-20 21:08:12,107 INFO L290 TraceCheckUtils]: 40: Hoare triple {895#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| 0))} assume 0 != aws_hash_callback_string_eq_harness_#t~ret1964#1 % 256;aws_hash_callback_string_eq_harness_#t~ite1966#1.base, aws_hash_callback_string_eq_harness_#t~ite1966#1.offset := aws_hash_callback_string_eq_harness_~str1~0#1.base, aws_hash_callback_string_eq_harness_~str1~0#1.offset; {899#(not (= 0 |ULTIMATE.start_aws_hash_callback_string_eq_harness_#t~ite1966#1.base|))} is VALID [2022-02-20 21:08:12,107 INFO L290 TraceCheckUtils]: 41: Hoare triple {899#(not (= 0 |ULTIMATE.start_aws_hash_callback_string_eq_harness_#t~ite1966#1.base|))} aws_hash_callback_string_eq_harness_~str2~0#1.base, aws_hash_callback_string_eq_harness_~str2~0#1.offset := aws_hash_callback_string_eq_harness_#t~ite1966#1.base, aws_hash_callback_string_eq_harness_#t~ite1966#1.offset;havoc aws_hash_callback_string_eq_harness_#t~ret1964#1;havoc aws_hash_callback_string_eq_harness_#t~ite1966#1.base, aws_hash_callback_string_eq_harness_#t~ite1966#1.offset;havoc aws_hash_callback_string_eq_harness_#t~ret1965#1.base, aws_hash_callback_string_eq_harness_#t~ret1965#1.offset;assume { :begin_inline_aws_hash_callback_string_eq } true;aws_hash_callback_string_eq_#in~a#1.base, aws_hash_callback_string_eq_#in~a#1.offset, aws_hash_callback_string_eq_#in~b#1.base, aws_hash_callback_string_eq_#in~b#1.offset := aws_hash_callback_string_eq_harness_~str1~0#1.base, aws_hash_callback_string_eq_harness_~str1~0#1.offset, aws_hash_callback_string_eq_harness_~str2~0#1.base, aws_hash_callback_string_eq_harness_~str2~0#1.offset;havoc aws_hash_callback_string_eq_#res#1;havoc aws_hash_callback_string_eq_#t~ret1811#1, aws_hash_callback_string_eq_#t~ret1812#1, aws_hash_callback_string_eq_#t~ret1813#1, aws_hash_callback_string_eq_#t~ret1814#1, aws_hash_callback_string_eq_#t~ret1815#1, aws_hash_callback_string_eq_#t~short1816#1, aws_hash_callback_string_eq_~a#1.base, aws_hash_callback_string_eq_~a#1.offset, aws_hash_callback_string_eq_~b#1.base, aws_hash_callback_string_eq_~b#1.offset, aws_hash_callback_string_eq_~rval~20#1;aws_hash_callback_string_eq_~a#1.base, aws_hash_callback_string_eq_~a#1.offset := aws_hash_callback_string_eq_#in~a#1.base, aws_hash_callback_string_eq_#in~a#1.offset;aws_hash_callback_string_eq_~b#1.base, aws_hash_callback_string_eq_~b#1.offset := aws_hash_callback_string_eq_#in~b#1.base, aws_hash_callback_string_eq_#in~b#1.offset; {900#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} is VALID [2022-02-20 21:08:12,108 INFO L272 TraceCheckUtils]: 42: Hoare triple {900#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} call aws_hash_callback_string_eq_#t~ret1811#1 := aws_string_is_valid(aws_hash_callback_string_eq_~a#1.base, aws_hash_callback_string_eq_~a#1.offset); {860#true} is VALID [2022-02-20 21:08:12,108 INFO L290 TraceCheckUtils]: 43: Hoare triple {860#true} ~str.base, ~str.offset := #in~str.base, #in~str.offset;#t~short464 := ~str.base != 0 || ~str.offset != 0; {860#true} is VALID [2022-02-20 21:08:12,108 INFO L290 TraceCheckUtils]: 44: Hoare triple {860#true} assume #t~short464;call #t~mem463 := read~int(~str.base, 8 + ~str.offset, 8);#t~short464 := 0 == (1 + #t~mem463) % 18446744073709551616 || ~str.base != 0 || 16 + ~str.offset != 0; {860#true} is VALID [2022-02-20 21:08:12,108 INFO L290 TraceCheckUtils]: 45: Hoare triple {860#true} #t~short467 := #t~short464; {860#true} is VALID [2022-02-20 21:08:12,108 INFO L290 TraceCheckUtils]: 46: Hoare triple {860#true} assume #t~short467;call #t~mem465 := read~int(~str.base, 8 + ~str.offset, 8);call #t~mem466 := read~int(~str.base, 16 + ~str.offset + (if #t~mem465 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then #t~mem465 % 18446744073709551616 % 18446744073709551616 else #t~mem465 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);#t~short467 := 0 == #t~mem466 % 256; {860#true} is VALID [2022-02-20 21:08:12,109 INFO L290 TraceCheckUtils]: 47: Hoare triple {860#true} #res := (if 0 == (if #t~short467 then 1 else 0) then 0 else 1);havoc #t~mem463;havoc #t~short464;havoc #t~mem465;havoc #t~mem466;havoc #t~short467; {860#true} is VALID [2022-02-20 21:08:12,109 INFO L290 TraceCheckUtils]: 48: Hoare triple {860#true} assume true; {860#true} is VALID [2022-02-20 21:08:12,110 INFO L284 TraceCheckUtils]: 49: Hoare quadruple {860#true} {900#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} #204#return; {900#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} is VALID [2022-02-20 21:08:12,110 INFO L272 TraceCheckUtils]: 50: Hoare triple {900#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} call assume_abort_if_not(aws_hash_callback_string_eq_#t~ret1811#1); {860#true} is VALID [2022-02-20 21:08:12,115 INFO L290 TraceCheckUtils]: 51: Hoare triple {860#true} ~cond := #in~cond; {860#true} is VALID [2022-02-20 21:08:12,116 INFO L290 TraceCheckUtils]: 52: Hoare triple {860#true} assume !(0 == ~cond % 256); {860#true} is VALID [2022-02-20 21:08:12,116 INFO L290 TraceCheckUtils]: 53: Hoare triple {860#true} assume true; {860#true} is VALID [2022-02-20 21:08:12,117 INFO L284 TraceCheckUtils]: 54: Hoare quadruple {860#true} {900#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} #206#return; {900#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} is VALID [2022-02-20 21:08:12,117 INFO L290 TraceCheckUtils]: 55: Hoare triple {900#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} havoc aws_hash_callback_string_eq_#t~ret1811#1; {900#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} is VALID [2022-02-20 21:08:12,117 INFO L272 TraceCheckUtils]: 56: Hoare triple {900#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} call aws_hash_callback_string_eq_#t~ret1812#1 := aws_string_is_valid(aws_hash_callback_string_eq_~b#1.base, aws_hash_callback_string_eq_~b#1.offset); {860#true} is VALID [2022-02-20 21:08:12,118 INFO L290 TraceCheckUtils]: 57: Hoare triple {860#true} ~str.base, ~str.offset := #in~str.base, #in~str.offset;#t~short464 := ~str.base != 0 || ~str.offset != 0; {860#true} is VALID [2022-02-20 21:08:12,118 INFO L290 TraceCheckUtils]: 58: Hoare triple {860#true} assume #t~short464;call #t~mem463 := read~int(~str.base, 8 + ~str.offset, 8);#t~short464 := 0 == (1 + #t~mem463) % 18446744073709551616 || ~str.base != 0 || 16 + ~str.offset != 0; {860#true} is VALID [2022-02-20 21:08:12,118 INFO L290 TraceCheckUtils]: 59: Hoare triple {860#true} #t~short467 := #t~short464; {860#true} is VALID [2022-02-20 21:08:12,118 INFO L290 TraceCheckUtils]: 60: Hoare triple {860#true} assume #t~short467;call #t~mem465 := read~int(~str.base, 8 + ~str.offset, 8);call #t~mem466 := read~int(~str.base, 16 + ~str.offset + (if #t~mem465 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then #t~mem465 % 18446744073709551616 % 18446744073709551616 else #t~mem465 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);#t~short467 := 0 == #t~mem466 % 256; {860#true} is VALID [2022-02-20 21:08:12,118 INFO L290 TraceCheckUtils]: 61: Hoare triple {860#true} #res := (if 0 == (if #t~short467 then 1 else 0) then 0 else 1);havoc #t~mem463;havoc #t~short464;havoc #t~mem465;havoc #t~mem466;havoc #t~short467; {860#true} is VALID [2022-02-20 21:08:12,119 INFO L290 TraceCheckUtils]: 62: Hoare triple {860#true} assume true; {860#true} is VALID [2022-02-20 21:08:12,119 INFO L284 TraceCheckUtils]: 63: Hoare quadruple {860#true} {900#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} #208#return; {900#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} is VALID [2022-02-20 21:08:12,120 INFO L272 TraceCheckUtils]: 64: Hoare triple {900#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} call assume_abort_if_not(aws_hash_callback_string_eq_#t~ret1812#1); {860#true} is VALID [2022-02-20 21:08:12,120 INFO L290 TraceCheckUtils]: 65: Hoare triple {860#true} ~cond := #in~cond; {860#true} is VALID [2022-02-20 21:08:12,120 INFO L290 TraceCheckUtils]: 66: Hoare triple {860#true} assume !(0 == ~cond % 256); {860#true} is VALID [2022-02-20 21:08:12,120 INFO L290 TraceCheckUtils]: 67: Hoare triple {860#true} assume true; {860#true} is VALID [2022-02-20 21:08:12,121 INFO L284 TraceCheckUtils]: 68: Hoare quadruple {860#true} {900#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} #210#return; {900#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} is VALID [2022-02-20 21:08:12,121 INFO L290 TraceCheckUtils]: 69: Hoare triple {900#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} havoc aws_hash_callback_string_eq_#t~ret1812#1;assume { :begin_inline_aws_string_eq } true;aws_string_eq_#in~a#1.base, aws_string_eq_#in~a#1.offset, aws_string_eq_#in~b#1.base, aws_string_eq_#in~b#1.offset := aws_hash_callback_string_eq_~a#1.base, aws_hash_callback_string_eq_~a#1.offset, aws_hash_callback_string_eq_~b#1.base, aws_hash_callback_string_eq_~b#1.offset;havoc aws_string_eq_#res#1;havoc aws_string_eq_#t~ret1893#1, aws_string_eq_#t~short1894#1, aws_string_eq_#t~ret1895#1, aws_string_eq_#t~short1896#1, aws_string_eq_#t~mem1897#1, aws_string_eq_#t~mem1898#1, aws_string_eq_#t~ret1899#1, aws_string_eq_~a#1.base, aws_string_eq_~a#1.offset, aws_string_eq_~b#1.base, aws_string_eq_~b#1.offset;aws_string_eq_~a#1.base, aws_string_eq_~a#1.offset := aws_string_eq_#in~a#1.base, aws_string_eq_#in~a#1.offset;aws_string_eq_~b#1.base, aws_string_eq_~b#1.offset := aws_string_eq_#in~b#1.base, aws_string_eq_#in~b#1.offset;aws_string_eq_#t~short1894#1 := aws_string_eq_~a#1.base == 0 && aws_string_eq_~a#1.offset == 0; {923#(not (= |ULTIMATE.start_aws_string_eq_~b#1.base| 0))} is VALID [2022-02-20 21:08:12,122 INFO L290 TraceCheckUtils]: 70: Hoare triple {923#(not (= |ULTIMATE.start_aws_string_eq_~b#1.base| 0))} assume aws_string_eq_#t~short1894#1; {923#(not (= |ULTIMATE.start_aws_string_eq_~b#1.base| 0))} is VALID [2022-02-20 21:08:12,122 INFO L272 TraceCheckUtils]: 71: Hoare triple {923#(not (= |ULTIMATE.start_aws_string_eq_~b#1.base| 0))} call assume_abort_if_not((if 0 == (if aws_string_eq_#t~short1894#1 then 1 else 0) then 0 else 1)); {860#true} is VALID [2022-02-20 21:08:12,122 INFO L290 TraceCheckUtils]: 72: Hoare triple {860#true} ~cond := #in~cond; {860#true} is VALID [2022-02-20 21:08:12,122 INFO L290 TraceCheckUtils]: 73: Hoare triple {860#true} assume !(0 == ~cond % 256); {860#true} is VALID [2022-02-20 21:08:12,123 INFO L290 TraceCheckUtils]: 74: Hoare triple {860#true} assume true; {860#true} is VALID [2022-02-20 21:08:12,123 INFO L284 TraceCheckUtils]: 75: Hoare quadruple {860#true} {923#(not (= |ULTIMATE.start_aws_string_eq_~b#1.base| 0))} #214#return; {923#(not (= |ULTIMATE.start_aws_string_eq_~b#1.base| 0))} is VALID [2022-02-20 21:08:12,124 INFO L290 TraceCheckUtils]: 76: Hoare triple {923#(not (= |ULTIMATE.start_aws_string_eq_~b#1.base| 0))} havoc aws_string_eq_#t~ret1893#1;havoc aws_string_eq_#t~short1894#1;aws_string_eq_#t~short1896#1 := aws_string_eq_~b#1.base == 0 && aws_string_eq_~b#1.offset == 0; {928#(not |ULTIMATE.start_aws_string_eq_#t~short1896#1|)} is VALID [2022-02-20 21:08:12,124 INFO L290 TraceCheckUtils]: 77: Hoare triple {928#(not |ULTIMATE.start_aws_string_eq_#t~short1896#1|)} assume aws_string_eq_#t~short1896#1; {861#false} is VALID [2022-02-20 21:08:12,124 INFO L272 TraceCheckUtils]: 78: Hoare triple {861#false} call assume_abort_if_not((if 0 == (if aws_string_eq_#t~short1896#1 then 1 else 0) then 0 else 1)); {860#true} is VALID [2022-02-20 21:08:12,125 INFO L290 TraceCheckUtils]: 79: Hoare triple {860#true} ~cond := #in~cond; {860#true} is VALID [2022-02-20 21:08:12,125 INFO L290 TraceCheckUtils]: 80: Hoare triple {860#true} assume !(0 == ~cond % 256); {860#true} is VALID [2022-02-20 21:08:12,125 INFO L290 TraceCheckUtils]: 81: Hoare triple {860#true} assume true; {860#true} is VALID [2022-02-20 21:08:12,125 INFO L284 TraceCheckUtils]: 82: Hoare quadruple {860#true} {861#false} #218#return; {861#false} is VALID [2022-02-20 21:08:12,125 INFO L290 TraceCheckUtils]: 83: Hoare triple {861#false} havoc aws_string_eq_#t~ret1895#1;havoc aws_string_eq_#t~short1896#1; {861#false} is VALID [2022-02-20 21:08:12,126 INFO L290 TraceCheckUtils]: 84: Hoare triple {861#false} assume aws_string_eq_~a#1.base == aws_string_eq_~b#1.base && aws_string_eq_~a#1.offset == aws_string_eq_~b#1.offset;aws_string_eq_#res#1 := 1; {861#false} is VALID [2022-02-20 21:08:12,126 INFO L290 TraceCheckUtils]: 85: Hoare triple {861#false} aws_hash_callback_string_eq_#t~ret1813#1 := aws_string_eq_#res#1;assume { :end_inline_aws_string_eq } true;aws_hash_callback_string_eq_~rval~20#1 := aws_hash_callback_string_eq_#t~ret1813#1;havoc aws_hash_callback_string_eq_#t~ret1813#1; {861#false} is VALID [2022-02-20 21:08:12,126 INFO L272 TraceCheckUtils]: 86: Hoare triple {861#false} call aws_hash_callback_string_eq_#t~ret1814#1 := aws_c_string_is_valid(aws_hash_callback_string_eq_~a#1.base, aws_hash_callback_string_eq_~a#1.offset); {860#true} is VALID [2022-02-20 21:08:12,126 INFO L290 TraceCheckUtils]: 87: Hoare triple {860#true} ~str.base, ~str.offset := #in~str.base, #in~str.offset;#res := (if 0 == (if (~str.base != 0 || ~str.offset != 0) && (~str.base != 0 || ~str.offset != 0) then 1 else 0) then 0 else 1); {860#true} is VALID [2022-02-20 21:08:12,127 INFO L290 TraceCheckUtils]: 88: Hoare triple {860#true} assume true; {860#true} is VALID [2022-02-20 21:08:12,127 INFO L284 TraceCheckUtils]: 89: Hoare quadruple {860#true} {861#false} #222#return; {861#false} is VALID [2022-02-20 21:08:12,127 INFO L290 TraceCheckUtils]: 90: Hoare triple {861#false} aws_hash_callback_string_eq_#t~short1816#1 := 0 != aws_hash_callback_string_eq_#t~ret1814#1 % 256; {861#false} is VALID [2022-02-20 21:08:12,127 INFO L290 TraceCheckUtils]: 91: Hoare triple {861#false} assume !aws_hash_callback_string_eq_#t~short1816#1; {861#false} is VALID [2022-02-20 21:08:12,127 INFO L272 TraceCheckUtils]: 92: Hoare triple {861#false} call __VERIFIER_assert((if 0 == (if aws_hash_callback_string_eq_#t~short1816#1 then 1 else 0) then 0 else 1)); {861#false} is VALID [2022-02-20 21:08:12,128 INFO L290 TraceCheckUtils]: 93: Hoare triple {861#false} ~cond := #in~cond; {861#false} is VALID [2022-02-20 21:08:12,128 INFO L290 TraceCheckUtils]: 94: Hoare triple {861#false} assume 0 == ~cond % 256; {861#false} is VALID [2022-02-20 21:08:12,128 INFO L290 TraceCheckUtils]: 95: Hoare triple {861#false} assume !false; {861#false} is VALID [2022-02-20 21:08:12,130 INFO L134 CoverageAnalysis]: Checked inductivity of 70 backedges. 0 proven. 24 refuted. 0 times theorem prover too weak. 46 trivial. 0 not checked. [2022-02-20 21:08:12,131 INFO L144 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-02-20 21:08:12,131 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [348806456] [2022-02-20 21:08:12,131 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleSmtInterpolCraig [348806456] provided 0 perfect and 1 imperfect interpolant sequences [2022-02-20 21:08:12,131 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [295030251] [2022-02-20 21:08:12,131 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 21:08:12,132 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-02-20 21:08:12,132 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-02-20 21:08:12,139 INFO L229 MonitoredProcess]: Starting monitored process 2 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2022-02-20 21:08:12,147 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (2)] Waiting until timeout for monitored process [2022-02-20 21:08:12,400 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:12,407 INFO L263 TraceCheckSpWp]: Trace formula consists of 907 conjuncts, 27 conjunts are in the unsatisfiable core [2022-02-20 21:08:12,438 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:12,444 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-02-20 21:08:12,903 INFO L290 TraceCheckUtils]: 0: Hoare triple {860#true} assume { :begin_inline_ULTIMATE.init } true;#NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(38, 2);call #Ultimate.allocInit(12, 3);call #Ultimate.allocInit(78, 4);~#s_can_fail_allocator_static~0.base, ~#s_can_fail_allocator_static~0.offset := 5, 0;call #Ultimate.allocInit(40, 5);call write~init~$Pointer$(#funAddr~s_can_fail_malloc_allocator.base, #funAddr~s_can_fail_malloc_allocator.offset, ~#s_can_fail_allocator_static~0.base, ~#s_can_fail_allocator_static~0.offset, 8);call write~init~$Pointer$(#funAddr~s_can_fail_free_allocator.base, #funAddr~s_can_fail_free_allocator.offset, ~#s_can_fail_allocator_static~0.base, 8 + ~#s_can_fail_allocator_static~0.offset, 8);call write~init~$Pointer$(#funAddr~s_can_fail_realloc_allocator.base, #funAddr~s_can_fail_realloc_allocator.offset, ~#s_can_fail_allocator_static~0.base, 16 + ~#s_can_fail_allocator_static~0.offset, 8);call write~init~$Pointer$(#funAddr~s_can_fail_calloc_allocator.base, #funAddr~s_can_fail_calloc_allocator.offset, ~#s_can_fail_allocator_static~0.base, 24 + ~#s_can_fail_allocator_static~0.offset, 8);call write~init~$Pointer$(0, 0, ~#s_can_fail_allocator_static~0.base, 32 + ~#s_can_fail_allocator_static~0.offset, 8);~#s_tolower_table~0.base, ~#s_tolower_table~0.offset := 6, 0;call #Ultimate.allocInit(256, 6);call write~init~int(0, ~#s_tolower_table~0.base, ~#s_tolower_table~0.offset, 1);call write~init~int(1, ~#s_tolower_table~0.base, 1 + ~#s_tolower_table~0.offset, 1);call write~init~int(2, ~#s_tolower_table~0.base, 2 + ~#s_tolower_table~0.offset, 1);call write~init~int(3, ~#s_tolower_table~0.base, 3 + ~#s_tolower_table~0.offset, 1);call write~init~int(4, ~#s_tolower_table~0.base, 4 + ~#s_tolower_table~0.offset, 1);call write~init~int(5, ~#s_tolower_table~0.base, 5 + ~#s_tolower_table~0.offset, 1);call write~init~int(6, ~#s_tolower_table~0.base, 6 + ~#s_tolower_table~0.offset, 1);call write~init~int(7, ~#s_tolower_table~0.base, 7 + ~#s_tolower_table~0.offset, 1);call write~init~int(8, ~#s_tolower_table~0.base, 8 + ~#s_tolower_table~0.offset, 1);call write~init~int(9, ~#s_tolower_table~0.base, 9 + ~#s_tolower_table~0.offset, 1);call write~init~int(10, ~#s_tolower_table~0.base, 10 + ~#s_tolower_table~0.offset, 1);call write~init~int(11, ~#s_tolower_table~0.base, 11 + ~#s_tolower_table~0.offset, 1);call write~init~int(12, ~#s_tolower_table~0.base, 12 + ~#s_tolower_table~0.offset, 1);call write~init~int(13, ~#s_tolower_table~0.base, 13 + ~#s_tolower_table~0.offset, 1);call write~init~int(14, ~#s_tolower_table~0.base, 14 + ~#s_tolower_table~0.offset, 1);call write~init~int(15, ~#s_tolower_table~0.base, 15 + ~#s_tolower_table~0.offset, 1);call write~init~int(16, ~#s_tolower_table~0.base, 16 + ~#s_tolower_table~0.offset, 1);call write~init~int(17, ~#s_tolower_table~0.base, 17 + ~#s_tolower_table~0.offset, 1);call write~init~int(18, ~#s_tolower_table~0.base, 18 + ~#s_tolower_table~0.offset, 1);call write~init~int(19, ~#s_tolower_table~0.base, 19 + ~#s_tolower_table~0.offset, 1);call write~init~int(20, ~#s_tolower_table~0.base, 20 + ~#s_tolower_table~0.offset, 1);call write~init~int(21, ~#s_tolower_table~0.base, 21 + ~#s_tolower_table~0.offset, 1);call write~init~int(22, ~#s_tolower_table~0.base, 22 + ~#s_tolower_table~0.offset, 1);call write~init~int(23, ~#s_tolower_table~0.base, 23 + ~#s_tolower_table~0.offset, 1);call write~init~int(24, ~#s_tolower_table~0.base, 24 + ~#s_tolower_table~0.offset, 1);call write~init~int(25, ~#s_tolower_table~0.base, 25 + ~#s_tolower_table~0.offset, 1);call write~init~int(26, ~#s_tolower_table~0.base, 26 + ~#s_tolower_table~0.offset, 1);call write~init~int(27, ~#s_tolower_table~0.base, 27 + ~#s_tolower_table~0.offset, 1);call write~init~int(28, ~#s_tolower_table~0.base, 28 + ~#s_tolower_table~0.offset, 1);call write~init~int(29, ~#s_tolower_table~0.base, 29 + ~#s_tolower_table~0.offset, 1);call write~init~int(30, ~#s_tolower_table~0.base, 30 + ~#s_tolower_table~0.offset, 1);call write~init~int(31, ~#s_tolower_table~0.base, 31 + ~#s_tolower_table~0.offset, 1);call write~init~int(32, ~#s_tolower_table~0.base, 32 + ~#s_tolower_table~0.offset, 1);call write~init~int(33, ~#s_tolower_table~0.base, 33 + ~#s_tolower_table~0.offset, 1);call write~init~int(34, ~#s_tolower_table~0.base, 34 + ~#s_tolower_table~0.offset, 1);call write~init~int(35, ~#s_tolower_table~0.base, 35 + ~#s_tolower_table~0.offset, 1);call write~init~int(36, ~#s_tolower_table~0.base, 36 + ~#s_tolower_table~0.offset, 1);call write~init~int(37, ~#s_tolower_table~0.base, 37 + ~#s_tolower_table~0.offset, 1);call write~init~int(38, ~#s_tolower_table~0.base, 38 + ~#s_tolower_table~0.offset, 1);call write~init~int(39, ~#s_tolower_table~0.base, 39 + ~#s_tolower_table~0.offset, 1);call write~init~int(40, ~#s_tolower_table~0.base, 40 + ~#s_tolower_table~0.offset, 1);call write~init~int(41, ~#s_tolower_table~0.base, 41 + ~#s_tolower_table~0.offset, 1);call write~init~int(42, ~#s_tolower_table~0.base, 42 + ~#s_tolower_table~0.offset, 1);call write~init~int(43, ~#s_tolower_table~0.base, 43 + ~#s_tolower_table~0.offset, 1);call write~init~int(44, ~#s_tolower_table~0.base, 44 + ~#s_tolower_table~0.offset, 1);call write~init~int(45, ~#s_tolower_table~0.base, 45 + ~#s_tolower_table~0.offset, 1);call write~init~int(46, ~#s_tolower_table~0.base, 46 + ~#s_tolower_table~0.offset, 1);call write~init~int(47, ~#s_tolower_table~0.base, 47 + ~#s_tolower_table~0.offset, 1);call write~init~int(48, ~#s_tolower_table~0.base, 48 + ~#s_tolower_table~0.offset, 1);call write~init~int(49, ~#s_tolower_table~0.base, 49 + ~#s_tolower_table~0.offset, 1);call write~init~int(50, ~#s_tolower_table~0.base, 50 + ~#s_tolower_table~0.offset, 1);call write~init~int(51, ~#s_tolower_table~0.base, 51 + ~#s_tolower_table~0.offset, 1);call write~init~int(52, ~#s_tolower_table~0.base, 52 + ~#s_tolower_table~0.offset, 1);call write~init~int(53, ~#s_tolower_table~0.base, 53 + ~#s_tolower_table~0.offset, 1);call write~init~int(54, ~#s_tolower_table~0.base, 54 + ~#s_tolower_table~0.offset, 1);call write~init~int(55, ~#s_tolower_table~0.base, 55 + ~#s_tolower_table~0.offset, 1);call write~init~int(56, ~#s_tolower_table~0.base, 56 + ~#s_tolower_table~0.offset, 1);call write~init~int(57, ~#s_tolower_table~0.base, 57 + ~#s_tolower_table~0.offset, 1);call write~init~int(58, ~#s_tolower_table~0.base, 58 + ~#s_tolower_table~0.offset, 1);call write~init~int(59, ~#s_tolower_table~0.base, 59 + ~#s_tolower_table~0.offset, 1);call write~init~int(60, ~#s_tolower_table~0.base, 60 + ~#s_tolower_table~0.offset, 1);call write~init~int(61, ~#s_tolower_table~0.base, 61 + ~#s_tolower_table~0.offset, 1);call write~init~int(62, ~#s_tolower_table~0.base, 62 + ~#s_tolower_table~0.offset, 1);call write~init~int(63, ~#s_tolower_table~0.base, 63 + ~#s_tolower_table~0.offset, 1);call write~init~int(64, ~#s_tolower_table~0.base, 64 + ~#s_tolower_table~0.offset, 1);call write~init~int(97, ~#s_tolower_table~0.base, 65 + ~#s_tolower_table~0.offset, 1);call write~init~int(98, ~#s_tolower_table~0.base, 66 + ~#s_tolower_table~0.offset, 1);call write~init~int(99, ~#s_tolower_table~0.base, 67 + ~#s_tolower_table~0.offset, 1);call write~init~int(100, ~#s_tolower_table~0.base, 68 + ~#s_tolower_table~0.offset, 1);call write~init~int(101, ~#s_tolower_table~0.base, 69 + ~#s_tolower_table~0.offset, 1);call write~init~int(102, ~#s_tolower_table~0.base, 70 + ~#s_tolower_table~0.offset, 1);call write~init~int(103, ~#s_tolower_table~0.base, 71 + ~#s_tolower_table~0.offset, 1);call write~init~int(104, ~#s_tolower_table~0.base, 72 + ~#s_tolower_table~0.offset, 1);call write~init~int(105, ~#s_tolower_table~0.base, 73 + ~#s_tolower_table~0.offset, 1);call write~init~int(106, ~#s_tolower_table~0.base, 74 + ~#s_tolower_table~0.offset, 1);call write~init~int(107, ~#s_tolower_table~0.base, 75 + ~#s_tolower_table~0.offset, 1);call write~init~int(108, ~#s_tolower_table~0.base, 76 + ~#s_tolower_table~0.offset, 1);call write~init~int(109, ~#s_tolower_table~0.base, 77 + ~#s_tolower_table~0.offset, 1);call write~init~int(110, ~#s_tolower_table~0.base, 78 + ~#s_tolower_table~0.offset, 1);call write~init~int(111, ~#s_tolower_table~0.base, 79 + ~#s_tolower_table~0.offset, 1);call write~init~int(112, ~#s_tolower_table~0.base, 80 + ~#s_tolower_table~0.offset, 1);call write~init~int(113, ~#s_tolower_table~0.base, 81 + ~#s_tolower_table~0.offset, 1);call write~init~int(114, ~#s_tolower_table~0.base, 82 + ~#s_tolower_table~0.offset, 1);call write~init~int(115, ~#s_tolower_table~0.base, 83 + ~#s_tolower_table~0.offset, 1);call write~init~int(116, ~#s_tolower_table~0.base, 84 + ~#s_tolower_table~0.offset, 1);call write~init~int(117, ~#s_tolower_table~0.base, 85 + ~#s_tolower_table~0.offset, 1);call write~init~int(118, ~#s_tolower_table~0.base, 86 + ~#s_tolower_table~0.offset, 1);call write~init~int(119, ~#s_tolower_table~0.base, 87 + ~#s_tolower_table~0.offset, 1);call write~init~int(120, ~#s_tolower_table~0.base, 88 + ~#s_tolower_table~0.offset, 1);call write~init~int(121, ~#s_tolower_table~0.base, 89 + ~#s_tolower_table~0.offset, 1);call write~init~int(122, ~#s_tolower_table~0.base, 90 + ~#s_tolower_table~0.offset, 1);call write~init~int(91, ~#s_tolower_table~0.base, 91 + ~#s_tolower_table~0.offset, 1);call write~init~int(92, ~#s_tolower_table~0.base, 92 + ~#s_tolower_table~0.offset, 1);call write~init~int(93, ~#s_tolower_table~0.base, 93 + ~#s_tolower_table~0.offset, 1);call write~init~int(94, ~#s_tolower_table~0.base, 94 + ~#s_tolower_table~0.offset, 1);call write~init~int(95, ~#s_tolower_table~0.base, 95 + ~#s_tolower_table~0.offset, 1);call write~init~int(96, ~#s_tolower_table~0.base, 96 + ~#s_tolower_table~0.offset, 1);call write~init~int(97, ~#s_tolower_table~0.base, 97 + ~#s_tolower_table~0.offset, 1);call write~init~int(98, ~#s_tolower_table~0.base, 98 + ~#s_tolower_table~0.offset, 1);call write~init~int(99, ~#s_tolower_table~0.base, 99 + ~#s_tolower_table~0.offset, 1);call write~init~int(100, ~#s_tolower_table~0.base, 100 + ~#s_tolower_table~0.offset, 1);call write~init~int(101, ~#s_tolower_table~0.base, 101 + ~#s_tolower_table~0.offset, 1);call write~init~int(102, ~#s_tolower_table~0.base, 102 + ~#s_tolower_table~0.offset, 1);call write~init~int(103, ~#s_tolower_table~0.base, 103 + ~#s_tolower_table~0.offset, 1);call write~init~int(104, ~#s_tolower_table~0.base, 104 + ~#s_tolower_table~0.offset, 1);call write~init~int(105, ~#s_tolower_table~0.base, 105 + ~#s_tolower_table~0.offset, 1);call write~init~int(106, ~#s_tolower_table~0.base, 106 + ~#s_tolower_table~0.offset, 1);call write~init~int(107, ~#s_tolower_table~0.base, 107 + ~#s_tolower_table~0.offset, 1);call write~init~int(108, ~#s_tolower_table~0.base, 108 + ~#s_tolower_table~0.offset, 1);call write~init~int(109, ~#s_tolower_table~0.base, 109 + ~#s_tolower_table~0.offset, 1);call write~init~int(110, ~#s_tolower_table~0.base, 110 + ~#s_tolower_table~0.offset, 1);call write~init~int(111, ~#s_tolower_table~0.base, 111 + ~#s_tolower_table~0.offset, 1);call write~init~int(112, ~#s_tolower_table~0.base, 112 + ~#s_tolower_table~0.offset, 1);call write~init~int(113, ~#s_tolower_table~0.base, 113 + ~#s_tolower_table~0.offset, 1);call write~init~int(114, ~#s_tolower_table~0.base, 114 + ~#s_tolower_table~0.offset, 1);call write~init~int(115, ~#s_tolower_table~0.base, 115 + ~#s_tolower_table~0.offset, 1);call write~init~int(116, ~#s_tolower_table~0.base, 116 + ~#s_tolower_table~0.offset, 1);call write~init~int(117, ~#s_tolower_table~0.base, 117 + ~#s_tolower_table~0.offset, 1);call write~init~int(118, ~#s_tolower_table~0.base, 118 + ~#s_tolower_table~0.offset, 1);call write~init~int(119, ~#s_tolower_table~0.base, 119 + ~#s_tolower_table~0.offset, 1);call write~init~int(120, ~#s_tolower_table~0.base, 120 + ~#s_tolower_table~0.offset, 1);call write~init~int(121, ~#s_tolower_table~0.base, 121 + ~#s_tolower_table~0.offset, 1);call write~init~int(122, ~#s_tolower_table~0.base, 122 + ~#s_tolower_table~0.offset, 1);call write~init~int(123, ~#s_tolower_table~0.base, 123 + ~#s_tolower_table~0.offset, 1);call write~init~int(124, ~#s_tolower_table~0.base, 124 + ~#s_tolower_table~0.offset, 1);call write~init~int(125, ~#s_tolower_table~0.base, 125 + ~#s_tolower_table~0.offset, 1);call write~init~int(126, ~#s_tolower_table~0.base, 126 + ~#s_tolower_table~0.offset, 1);call write~init~int(127, ~#s_tolower_table~0.base, 127 + ~#s_tolower_table~0.offset, 1);call write~init~int(128, ~#s_tolower_table~0.base, 128 + ~#s_tolower_table~0.offset, 1);call write~init~int(129, ~#s_tolower_table~0.base, 129 + ~#s_tolower_table~0.offset, 1);call write~init~int(130, ~#s_tolower_table~0.base, 130 + ~#s_tolower_table~0.offset, 1);call write~init~int(131, ~#s_tolower_table~0.base, 131 + ~#s_tolower_table~0.offset, 1);call write~init~int(132, ~#s_tolower_table~0.base, 132 + ~#s_tolower_table~0.offset, 1);call write~init~int(133, ~#s_tolower_table~0.base, 133 + ~#s_tolower_table~0.offset, 1);call write~init~int(134, ~#s_tolower_table~0.base, 134 + ~#s_tolower_table~0.offset, 1);call write~init~int(135, ~#s_tolower_table~0.base, 135 + ~#s_tolower_table~0.offset, 1);call write~init~int(136, ~#s_tolower_table~0.base, 136 + ~#s_tolower_table~0.offset, 1);call write~init~int(137, ~#s_tolower_table~0.base, 137 + ~#s_tolower_table~0.offset, 1);call write~init~int(138, ~#s_tolower_table~0.base, 138 + ~#s_tolower_table~0.offset, 1);call write~init~int(139, ~#s_tolower_table~0.base, 139 + ~#s_tolower_table~0.offset, 1);call write~init~int(140, ~#s_tolower_table~0.base, 140 + ~#s_tolower_table~0.offset, 1);call write~init~int(141, ~#s_tolower_table~0.base, 141 + ~#s_tolower_table~0.offset, 1);call write~init~int(142, ~#s_tolower_table~0.base, 142 + ~#s_tolower_table~0.offset, 1);call write~init~int(143, ~#s_tolower_table~0.base, 143 + ~#s_tolower_table~0.offset, 1);call write~init~int(144, ~#s_tolower_table~0.base, 144 + ~#s_tolower_table~0.offset, 1);call write~init~int(145, ~#s_tolower_table~0.base, 145 + ~#s_tolower_table~0.offset, 1);call write~init~int(146, ~#s_tolower_table~0.base, 146 + ~#s_tolower_table~0.offset, 1);call write~init~int(147, ~#s_tolower_table~0.base, 147 + ~#s_tolower_table~0.offset, 1);call write~init~int(148, ~#s_tolower_table~0.base, 148 + ~#s_tolower_table~0.offset, 1);call write~init~int(149, ~#s_tolower_table~0.base, 149 + ~#s_tolower_table~0.offset, 1);call write~init~int(150, ~#s_tolower_table~0.base, 150 + ~#s_tolower_table~0.offset, 1);call write~init~int(151, ~#s_tolower_table~0.base, 151 + ~#s_tolower_table~0.offset, 1);call write~init~int(152, ~#s_tolower_table~0.base, 152 + ~#s_tolower_table~0.offset, 1);call write~init~int(153, ~#s_tolower_table~0.base, 153 + ~#s_tolower_table~0.offset, 1);call write~init~int(154, ~#s_tolower_table~0.base, 154 + ~#s_tolower_table~0.offset, 1);call write~init~int(155, ~#s_tolower_table~0.base, 155 + ~#s_tolower_table~0.offset, 1);call write~init~int(156, ~#s_tolower_table~0.base, 156 + ~#s_tolower_table~0.offset, 1);call write~init~int(157, ~#s_tolower_table~0.base, 157 + ~#s_tolower_table~0.offset, 1);call write~init~int(158, ~#s_tolower_table~0.base, 158 + ~#s_tolower_table~0.offset, 1);call write~init~int(159, ~#s_tolower_table~0.base, 159 + ~#s_tolower_table~0.offset, 1);call write~init~int(160, ~#s_tolower_table~0.base, 160 + ~#s_tolower_table~0.offset, 1);call write~init~int(161, ~#s_tolower_table~0.base, 161 + ~#s_tolower_table~0.offset, 1);call write~init~int(162, ~#s_tolower_table~0.base, 162 + ~#s_tolower_table~0.offset, 1);call write~init~int(163, ~#s_tolower_table~0.base, 163 + ~#s_tolower_table~0.offset, 1);call write~init~int(164, ~#s_tolower_table~0.base, 164 + ~#s_tolower_table~0.offset, 1);call write~init~int(165, ~#s_tolower_table~0.base, 165 + ~#s_tolower_table~0.offset, 1);call write~init~int(166, ~#s_tolower_table~0.base, 166 + ~#s_tolower_table~0.offset, 1);call write~init~int(167, ~#s_tolower_table~0.base, 167 + ~#s_tolower_table~0.offset, 1);call write~init~int(168, ~#s_tolower_table~0.base, 168 + ~#s_tolower_table~0.offset, 1);call write~init~int(169, ~#s_tolower_table~0.base, 169 + ~#s_tolower_table~0.offset, 1);call write~init~int(170, ~#s_tolower_table~0.base, 170 + ~#s_tolower_table~0.offset, 1);call write~init~int(171, ~#s_tolower_table~0.base, 171 + ~#s_tolower_table~0.offset, 1);call write~init~int(172, ~#s_tolower_table~0.base, 172 + ~#s_tolower_table~0.offset, 1);call write~init~int(173, ~#s_tolower_table~0.base, 173 + ~#s_tolower_table~0.offset, 1);call write~init~int(174, ~#s_tolower_table~0.base, 174 + ~#s_tolower_table~0.offset, 1);call write~init~int(175, ~#s_tolower_table~0.base, 175 + ~#s_tolower_table~0.offset, 1);call write~init~int(176, ~#s_tolower_table~0.base, 176 + ~#s_tolower_table~0.offset, 1);call write~init~int(177, ~#s_tolower_table~0.base, 177 + ~#s_tolower_table~0.offset, 1);call write~init~int(178, ~#s_tolower_table~0.base, 178 + ~#s_tolower_table~0.offset, 1);call write~init~int(179, ~#s_tolower_table~0.base, 179 + ~#s_tolower_table~0.offset, 1);call write~init~int(180, ~#s_tolower_table~0.base, 180 + ~#s_tolower_table~0.offset, 1);call write~init~int(181, ~#s_tolower_table~0.base, 181 + ~#s_tolower_table~0.offset, 1);call write~init~int(182, ~#s_tolower_table~0.base, 182 + ~#s_tolower_table~0.offset, 1);call write~init~int(183, ~#s_tolower_table~0.base, 183 + ~#s_tolower_table~0.offset, 1);call write~init~int(184, ~#s_tolower_table~0.base, 184 + ~#s_tolower_table~0.offset, 1);call write~init~int(185, ~#s_tolower_table~0.base, 185 + ~#s_tolower_table~0.offset, 1);call write~init~int(186, ~#s_tolower_table~0.base, 186 + ~#s_tolower_table~0.offset, 1);call write~init~int(187, ~#s_tolower_table~0.base, 187 + ~#s_tolower_table~0.offset, 1);call write~init~int(188, ~#s_tolower_table~0.base, 188 + ~#s_tolower_table~0.offset, 1);call write~init~int(189, ~#s_tolower_table~0.base, 189 + ~#s_tolower_table~0.offset, 1);call write~init~int(190, ~#s_tolower_table~0.base, 190 + ~#s_tolower_table~0.offset, 1);call write~init~int(191, ~#s_tolower_table~0.base, 191 + ~#s_tolower_table~0.offset, 1);call write~init~int(192, ~#s_tolower_table~0.base, 192 + ~#s_tolower_table~0.offset, 1);call write~init~int(193, ~#s_tolower_table~0.base, 193 + ~#s_tolower_table~0.offset, 1);call write~init~int(194, ~#s_tolower_table~0.base, 194 + ~#s_tolower_table~0.offset, 1);call write~init~int(195, ~#s_tolower_table~0.base, 195 + ~#s_tolower_table~0.offset, 1);call write~init~int(196, ~#s_tolower_table~0.base, 196 + ~#s_tolower_table~0.offset, 1);call write~init~int(197, ~#s_tolower_table~0.base, 197 + ~#s_tolower_table~0.offset, 1);call write~init~int(198, ~#s_tolower_table~0.base, 198 + ~#s_tolower_table~0.offset, 1);call write~init~int(199, ~#s_tolower_table~0.base, 199 + ~#s_tolower_table~0.offset, 1);call write~init~int(200, ~#s_tolower_table~0.base, 200 + ~#s_tolower_table~0.offset, 1);call write~init~int(201, ~#s_tolower_table~0.base, 201 + ~#s_tolower_table~0.offset, 1);call write~init~int(202, ~#s_tolower_table~0.base, 202 + ~#s_tolower_table~0.offset, 1);call write~init~int(203, ~#s_tolower_table~0.base, 203 + ~#s_tolower_table~0.offset, 1);call write~init~int(204, ~#s_tolower_table~0.base, 204 + ~#s_tolower_table~0.offset, 1);call write~init~int(205, ~#s_tolower_table~0.base, 205 + ~#s_tolower_table~0.offset, 1);call write~init~int(206, ~#s_tolower_table~0.base, 206 + ~#s_tolower_table~0.offset, 1);call write~init~int(207, ~#s_tolower_table~0.base, 207 + ~#s_tolower_table~0.offset, 1);call write~init~int(208, ~#s_tolower_table~0.base, 208 + ~#s_tolower_table~0.offset, 1);call write~init~int(209, ~#s_tolower_table~0.base, 209 + ~#s_tolower_table~0.offset, 1);call write~init~int(210, ~#s_tolower_table~0.base, 210 + ~#s_tolower_table~0.offset, 1);call write~init~int(211, ~#s_tolower_table~0.base, 211 + ~#s_tolower_table~0.offset, 1);call write~init~int(212, ~#s_tolower_table~0.base, 212 + ~#s_tolower_table~0.offset, 1);call write~init~int(213, ~#s_tolower_table~0.base, 213 + ~#s_tolower_table~0.offset, 1);call write~init~int(214, ~#s_tolower_table~0.base, 214 + ~#s_tolower_table~0.offset, 1);call write~init~int(215, ~#s_tolower_table~0.base, 215 + ~#s_tolower_table~0.offset, 1);call write~init~int(216, ~#s_tolower_table~0.base, 216 + ~#s_tolower_table~0.offset, 1);call write~init~int(217, ~#s_tolower_table~0.base, 217 + ~#s_tolower_table~0.offset, 1);call write~init~int(218, ~#s_tolower_table~0.base, 218 + ~#s_tolower_table~0.offset, 1);call write~init~int(219, ~#s_tolower_table~0.base, 219 + ~#s_tolower_table~0.offset, 1);call write~init~int(220, ~#s_tolower_table~0.base, 220 + ~#s_tolower_table~0.offset, 1);call write~init~int(221, ~#s_tolower_table~0.base, 221 + ~#s_tolower_table~0.offset, 1);call write~init~int(222, ~#s_tolower_table~0.base, 222 + ~#s_tolower_table~0.offset, 1);call write~init~int(223, ~#s_tolower_table~0.base, 223 + ~#s_tolower_table~0.offset, 1);call write~init~int(224, ~#s_tolower_table~0.base, 224 + ~#s_tolower_table~0.offset, 1);call write~init~int(225, ~#s_tolower_table~0.base, 225 + ~#s_tolower_table~0.offset, 1);call write~init~int(226, ~#s_tolower_table~0.base, 226 + ~#s_tolower_table~0.offset, 1);call write~init~int(227, ~#s_tolower_table~0.base, 227 + ~#s_tolower_table~0.offset, 1);call write~init~int(228, ~#s_tolower_table~0.base, 228 + ~#s_tolower_table~0.offset, 1);call write~init~int(229, ~#s_tolower_table~0.base, 229 + ~#s_tolower_table~0.offset, 1);call write~init~int(230, ~#s_tolower_table~0.base, 230 + ~#s_tolower_table~0.offset, 1);call write~init~int(231, ~#s_tolower_table~0.base, 231 + ~#s_tolower_table~0.offset, 1);call write~init~int(232, ~#s_tolower_table~0.base, 232 + ~#s_tolower_table~0.offset, 1);call write~init~int(233, ~#s_tolower_table~0.base, 233 + ~#s_tolower_table~0.offset, 1);call write~init~int(234, ~#s_tolower_table~0.base, 234 + ~#s_tolower_table~0.offset, 1);call write~init~int(235, ~#s_tolower_table~0.base, 235 + ~#s_tolower_table~0.offset, 1);call write~init~int(236, ~#s_tolower_table~0.base, 236 + ~#s_tolower_table~0.offset, 1);call write~init~int(237, ~#s_tolower_table~0.base, 237 + ~#s_tolower_table~0.offset, 1);call write~init~int(238, ~#s_tolower_table~0.base, 238 + ~#s_tolower_table~0.offset, 1);call write~init~int(239, ~#s_tolower_table~0.base, 239 + ~#s_tolower_table~0.offset, 1);call write~init~int(240, ~#s_tolower_table~0.base, 240 + ~#s_tolower_table~0.offset, 1);call write~init~int(241, ~#s_tolower_table~0.base, 241 + ~#s_tolower_table~0.offset, 1);call write~init~int(242, ~#s_tolower_table~0.base, 242 + ~#s_tolower_table~0.offset, 1);call write~init~int(243, ~#s_tolower_table~0.base, 243 + ~#s_tolower_table~0.offset, 1);call write~init~int(244, ~#s_tolower_table~0.base, 244 + ~#s_tolower_table~0.offset, 1);call write~init~int(245, ~#s_tolower_table~0.base, 245 + ~#s_tolower_table~0.offset, 1);call write~init~int(246, ~#s_tolower_table~0.base, 246 + ~#s_tolower_table~0.offset, 1);call write~init~int(247, ~#s_tolower_table~0.base, 247 + ~#s_tolower_table~0.offset, 1);call write~init~int(248, ~#s_tolower_table~0.base, 248 + ~#s_tolower_table~0.offset, 1);call write~init~int(249, ~#s_tolower_table~0.base, 249 + ~#s_tolower_table~0.offset, 1);call write~init~int(250, ~#s_tolower_table~0.base, 250 + ~#s_tolower_table~0.offset, 1);call write~init~int(251, ~#s_tolower_table~0.base, 251 + ~#s_tolower_table~0.offset, 1);call write~init~int(252, ~#s_tolower_table~0.base, 252 + ~#s_tolower_table~0.offset, 1);call write~init~int(253, ~#s_tolower_table~0.base, 253 + ~#s_tolower_table~0.offset, 1);call write~init~int(254, ~#s_tolower_table~0.base, 254 + ~#s_tolower_table~0.offset, 1);call write~init~int(255, ~#s_tolower_table~0.base, 255 + ~#s_tolower_table~0.offset, 1); {860#true} is VALID [2022-02-20 21:08:12,911 INFO L290 TraceCheckUtils]: 1: Hoare triple {860#true} assume { :end_inline_ULTIMATE.init } true;assume { :begin_inline_main } true;havoc main_#res#1;assume { :begin_inline_aws_hash_callback_string_eq_harness } true;havoc aws_hash_callback_string_eq_harness_#t~ret1963#1.base, aws_hash_callback_string_eq_harness_#t~ret1963#1.offset, aws_hash_callback_string_eq_harness_#t~ret1964#1, aws_hash_callback_string_eq_harness_#t~ite1966#1.base, aws_hash_callback_string_eq_harness_#t~ite1966#1.offset, aws_hash_callback_string_eq_harness_#t~ret1965#1.base, aws_hash_callback_string_eq_harness_#t~ret1965#1.offset, aws_hash_callback_string_eq_harness_#t~ret1967#1, aws_hash_callback_string_eq_harness_#t~mem1968#1, aws_hash_callback_string_eq_harness_#t~mem1969#1, aws_hash_callback_string_eq_harness_#t~mem1970#1, aws_hash_callback_string_eq_harness_~str1~0#1.base, aws_hash_callback_string_eq_harness_~str1~0#1.offset, aws_hash_callback_string_eq_harness_~str2~0#1.base, aws_hash_callback_string_eq_harness_~str2~0#1.offset, aws_hash_callback_string_eq_harness_~rval~21#1; {860#true} is VALID [2022-02-20 21:08:12,912 INFO L272 TraceCheckUtils]: 2: Hoare triple {860#true} call aws_hash_callback_string_eq_harness_#t~ret1963#1.base, aws_hash_callback_string_eq_harness_#t~ret1963#1.offset := ensure_string_is_allocated_bounded_length(96); {860#true} is VALID [2022-02-20 21:08:12,912 INFO L290 TraceCheckUtils]: 3: Hoare triple {860#true} ~max_size#1 := #in~max_size#1; {860#true} is VALID [2022-02-20 21:08:12,912 INFO L272 TraceCheckUtils]: 4: Hoare triple {860#true} call #t~ret540#1 := nondet_uint64_t(); {860#true} is VALID [2022-02-20 21:08:12,915 INFO L290 TraceCheckUtils]: 5: Hoare triple {860#true} #res := #t~nondet13;havoc #t~nondet13; {860#true} is VALID [2022-02-20 21:08:12,916 INFO L290 TraceCheckUtils]: 6: Hoare triple {860#true} assume true; {860#true} is VALID [2022-02-20 21:08:12,917 INFO L284 TraceCheckUtils]: 7: Hoare quadruple {860#true} {860#true} #182#return; {860#true} is VALID [2022-02-20 21:08:12,918 INFO L290 TraceCheckUtils]: 8: Hoare triple {860#true} ~len~1#1 := #t~ret540#1;havoc #t~ret540#1; {860#true} is VALID [2022-02-20 21:08:12,918 INFO L272 TraceCheckUtils]: 9: Hoare triple {860#true} call assume_abort_if_not((if 0 == (if ~len~1#1 % 18446744073709551616 < ~max_size#1 % 18446744073709551616 then 1 else 0) then 0 else 1)); {860#true} is VALID [2022-02-20 21:08:12,918 INFO L290 TraceCheckUtils]: 10: Hoare triple {860#true} ~cond := #in~cond; {860#true} is VALID [2022-02-20 21:08:12,918 INFO L290 TraceCheckUtils]: 11: Hoare triple {860#true} assume !(0 == ~cond % 256); {860#true} is VALID [2022-02-20 21:08:12,918 INFO L290 TraceCheckUtils]: 12: Hoare triple {860#true} assume true; {860#true} is VALID [2022-02-20 21:08:12,918 INFO L284 TraceCheckUtils]: 13: Hoare quadruple {860#true} {860#true} #184#return; {860#true} is VALID [2022-02-20 21:08:12,918 INFO L290 TraceCheckUtils]: 14: Hoare triple {860#true} assume { :begin_inline_ensure_string_is_allocated } true;ensure_string_is_allocated_#in~len#1 := ~len~1#1;havoc ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset;havoc ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset, ensure_string_is_allocated_#t~ret543#1, ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset, ensure_string_is_allocated_#t~ret544#1.base, ensure_string_is_allocated_#t~ret544#1.offset, ensure_string_is_allocated_~len#1, ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset;ensure_string_is_allocated_~len#1 := ensure_string_is_allocated_#in~len#1; {860#true} is VALID [2022-02-20 21:08:12,919 INFO L272 TraceCheckUtils]: 15: Hoare triple {860#true} call ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset := bounded_malloc(-1234550 + ensure_string_is_allocated_~len#1); {860#true} is VALID [2022-02-20 21:08:12,919 INFO L290 TraceCheckUtils]: 16: Hoare triple {860#true} ~size := #in~size; {860#true} is VALID [2022-02-20 21:08:12,919 INFO L272 TraceCheckUtils]: 17: Hoare triple {860#true} call assume_abort_if_not((if 0 == (if ~size % 18446744073709551616 <= 36028797018963967 then 1 else 0) then 0 else 1)); {860#true} is VALID [2022-02-20 21:08:12,919 INFO L290 TraceCheckUtils]: 18: Hoare triple {860#true} ~cond := #in~cond; {860#true} is VALID [2022-02-20 21:08:12,919 INFO L290 TraceCheckUtils]: 19: Hoare triple {860#true} assume !(0 == ~cond % 256); {860#true} is VALID [2022-02-20 21:08:12,919 INFO L290 TraceCheckUtils]: 20: Hoare triple {860#true} assume true; {860#true} is VALID [2022-02-20 21:08:12,919 INFO L284 TraceCheckUtils]: 21: Hoare quadruple {860#true} {860#true} #192#return; {860#true} is VALID [2022-02-20 21:08:12,920 INFO L290 TraceCheckUtils]: 22: Hoare triple {860#true} call #t~malloc555.base, #t~malloc555.offset := #Ultimate.allocOnHeap(~size);#res.base, #res.offset := #t~malloc555.base, #t~malloc555.offset;havoc #t~malloc555.base, #t~malloc555.offset; {1039#(not (= |bounded_malloc_#res.base| 0))} is VALID [2022-02-20 21:08:12,920 INFO L290 TraceCheckUtils]: 23: Hoare triple {1039#(not (= |bounded_malloc_#res.base| 0))} assume true; {1039#(not (= |bounded_malloc_#res.base| 0))} is VALID [2022-02-20 21:08:12,921 INFO L284 TraceCheckUtils]: 24: Hoare quadruple {1039#(not (= |bounded_malloc_#res.base| 0))} {860#true} #186#return; {1046#(not (= |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_#t~ret542#1.base| 0))} is VALID [2022-02-20 21:08:12,922 INFO L290 TraceCheckUtils]: 25: Hoare triple {1046#(not (= |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_#t~ret542#1.base| 0))} ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset := ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset;havoc ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset; {1050#(not (= |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~str~0#1.base| 0))} is VALID [2022-02-20 21:08:12,922 INFO L272 TraceCheckUtils]: 26: Hoare triple {1050#(not (= |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~str~0#1.base| 0))} call ensure_string_is_allocated_#t~ret543#1 := nondet_bool(); {860#true} is VALID [2022-02-20 21:08:12,922 INFO L290 TraceCheckUtils]: 27: Hoare triple {860#true} #res := #t~nondet8;havoc #t~nondet8; {860#true} is VALID [2022-02-20 21:08:12,922 INFO L290 TraceCheckUtils]: 28: Hoare triple {860#true} assume true; {860#true} is VALID [2022-02-20 21:08:12,923 INFO L284 TraceCheckUtils]: 29: Hoare quadruple {860#true} {1050#(not (= |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~str~0#1.base| 0))} #188#return; {1050#(not (= |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~str~0#1.base| 0))} is VALID [2022-02-20 21:08:12,923 INFO L290 TraceCheckUtils]: 30: Hoare triple {1050#(not (= |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~str~0#1.base| 0))} assume !(0 != ensure_string_is_allocated_#t~ret543#1 % 256);ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset := 0, 0; {1050#(not (= |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~str~0#1.base| 0))} is VALID [2022-02-20 21:08:12,924 INFO L290 TraceCheckUtils]: 31: Hoare triple {1050#(not (= |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~str~0#1.base| 0))} call write~$Pointer$(ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset, ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset, 8);havoc ensure_string_is_allocated_#t~ret543#1;havoc ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset;havoc ensure_string_is_allocated_#t~ret544#1.base, ensure_string_is_allocated_#t~ret544#1.offset;call write~int(ensure_string_is_allocated_~len#1, ensure_string_is_allocated_~str~0#1.base, 8 + ensure_string_is_allocated_~str~0#1.offset, 8);call write~int(0, ensure_string_is_allocated_~str~0#1.base, 16 + ensure_string_is_allocated_~str~0#1.offset + (if ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 else ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset := ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset; {1069#(not (= |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_#res#1.base| 0))} is VALID [2022-02-20 21:08:12,925 INFO L290 TraceCheckUtils]: 32: Hoare triple {1069#(not (= |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_#res#1.base| 0))} #t~ret541#1.base, #t~ret541#1.offset := ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset;assume { :end_inline_ensure_string_is_allocated } true;#res#1.base, #res#1.offset := #t~ret541#1.base, #t~ret541#1.offset;havoc #t~ret541#1.base, #t~ret541#1.offset; {1073#(not (= |ensure_string_is_allocated_bounded_length_#res#1.base| 0))} is VALID [2022-02-20 21:08:12,925 INFO L290 TraceCheckUtils]: 33: Hoare triple {1073#(not (= |ensure_string_is_allocated_bounded_length_#res#1.base| 0))} assume true; {1073#(not (= |ensure_string_is_allocated_bounded_length_#res#1.base| 0))} is VALID [2022-02-20 21:08:12,926 INFO L284 TraceCheckUtils]: 34: Hoare quadruple {1073#(not (= |ensure_string_is_allocated_bounded_length_#res#1.base| 0))} {860#true} #198#return; {894#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_#t~ret1963#1.base| 0))} is VALID [2022-02-20 21:08:12,927 INFO L290 TraceCheckUtils]: 35: Hoare triple {894#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_#t~ret1963#1.base| 0))} aws_hash_callback_string_eq_harness_~str1~0#1.base, aws_hash_callback_string_eq_harness_~str1~0#1.offset := aws_hash_callback_string_eq_harness_#t~ret1963#1.base, aws_hash_callback_string_eq_harness_#t~ret1963#1.offset;havoc aws_hash_callback_string_eq_harness_#t~ret1963#1.base, aws_hash_callback_string_eq_harness_#t~ret1963#1.offset; {895#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| 0))} is VALID [2022-02-20 21:08:12,927 INFO L272 TraceCheckUtils]: 36: Hoare triple {895#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| 0))} call aws_hash_callback_string_eq_harness_#t~ret1964#1 := nondet_bool(); {860#true} is VALID [2022-02-20 21:08:12,927 INFO L290 TraceCheckUtils]: 37: Hoare triple {860#true} #res := #t~nondet8;havoc #t~nondet8; {860#true} is VALID [2022-02-20 21:08:12,927 INFO L290 TraceCheckUtils]: 38: Hoare triple {860#true} assume true; {860#true} is VALID [2022-02-20 21:08:12,928 INFO L284 TraceCheckUtils]: 39: Hoare quadruple {860#true} {895#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| 0))} #200#return; {895#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| 0))} is VALID [2022-02-20 21:08:12,928 INFO L290 TraceCheckUtils]: 40: Hoare triple {895#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| 0))} assume 0 != aws_hash_callback_string_eq_harness_#t~ret1964#1 % 256;aws_hash_callback_string_eq_harness_#t~ite1966#1.base, aws_hash_callback_string_eq_harness_#t~ite1966#1.offset := aws_hash_callback_string_eq_harness_~str1~0#1.base, aws_hash_callback_string_eq_harness_~str1~0#1.offset; {899#(not (= 0 |ULTIMATE.start_aws_hash_callback_string_eq_harness_#t~ite1966#1.base|))} is VALID [2022-02-20 21:08:12,929 INFO L290 TraceCheckUtils]: 41: Hoare triple {899#(not (= 0 |ULTIMATE.start_aws_hash_callback_string_eq_harness_#t~ite1966#1.base|))} aws_hash_callback_string_eq_harness_~str2~0#1.base, aws_hash_callback_string_eq_harness_~str2~0#1.offset := aws_hash_callback_string_eq_harness_#t~ite1966#1.base, aws_hash_callback_string_eq_harness_#t~ite1966#1.offset;havoc aws_hash_callback_string_eq_harness_#t~ret1964#1;havoc aws_hash_callback_string_eq_harness_#t~ite1966#1.base, aws_hash_callback_string_eq_harness_#t~ite1966#1.offset;havoc aws_hash_callback_string_eq_harness_#t~ret1965#1.base, aws_hash_callback_string_eq_harness_#t~ret1965#1.offset;assume { :begin_inline_aws_hash_callback_string_eq } true;aws_hash_callback_string_eq_#in~a#1.base, aws_hash_callback_string_eq_#in~a#1.offset, aws_hash_callback_string_eq_#in~b#1.base, aws_hash_callback_string_eq_#in~b#1.offset := aws_hash_callback_string_eq_harness_~str1~0#1.base, aws_hash_callback_string_eq_harness_~str1~0#1.offset, aws_hash_callback_string_eq_harness_~str2~0#1.base, aws_hash_callback_string_eq_harness_~str2~0#1.offset;havoc aws_hash_callback_string_eq_#res#1;havoc aws_hash_callback_string_eq_#t~ret1811#1, aws_hash_callback_string_eq_#t~ret1812#1, aws_hash_callback_string_eq_#t~ret1813#1, aws_hash_callback_string_eq_#t~ret1814#1, aws_hash_callback_string_eq_#t~ret1815#1, aws_hash_callback_string_eq_#t~short1816#1, aws_hash_callback_string_eq_~a#1.base, aws_hash_callback_string_eq_~a#1.offset, aws_hash_callback_string_eq_~b#1.base, aws_hash_callback_string_eq_~b#1.offset, aws_hash_callback_string_eq_~rval~20#1;aws_hash_callback_string_eq_~a#1.base, aws_hash_callback_string_eq_~a#1.offset := aws_hash_callback_string_eq_#in~a#1.base, aws_hash_callback_string_eq_#in~a#1.offset;aws_hash_callback_string_eq_~b#1.base, aws_hash_callback_string_eq_~b#1.offset := aws_hash_callback_string_eq_#in~b#1.base, aws_hash_callback_string_eq_#in~b#1.offset; {900#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} is VALID [2022-02-20 21:08:12,929 INFO L272 TraceCheckUtils]: 42: Hoare triple {900#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} call aws_hash_callback_string_eq_#t~ret1811#1 := aws_string_is_valid(aws_hash_callback_string_eq_~a#1.base, aws_hash_callback_string_eq_~a#1.offset); {860#true} is VALID [2022-02-20 21:08:12,929 INFO L290 TraceCheckUtils]: 43: Hoare triple {860#true} ~str.base, ~str.offset := #in~str.base, #in~str.offset;#t~short464 := ~str.base != 0 || ~str.offset != 0; {860#true} is VALID [2022-02-20 21:08:12,929 INFO L290 TraceCheckUtils]: 44: Hoare triple {860#true} assume #t~short464;call #t~mem463 := read~int(~str.base, 8 + ~str.offset, 8);#t~short464 := 0 == (1 + #t~mem463) % 18446744073709551616 || ~str.base != 0 || 16 + ~str.offset != 0; {860#true} is VALID [2022-02-20 21:08:12,929 INFO L290 TraceCheckUtils]: 45: Hoare triple {860#true} #t~short467 := #t~short464; {860#true} is VALID [2022-02-20 21:08:12,929 INFO L290 TraceCheckUtils]: 46: Hoare triple {860#true} assume #t~short467;call #t~mem465 := read~int(~str.base, 8 + ~str.offset, 8);call #t~mem466 := read~int(~str.base, 16 + ~str.offset + (if #t~mem465 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then #t~mem465 % 18446744073709551616 % 18446744073709551616 else #t~mem465 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);#t~short467 := 0 == #t~mem466 % 256; {860#true} is VALID [2022-02-20 21:08:12,929 INFO L290 TraceCheckUtils]: 47: Hoare triple {860#true} #res := (if 0 == (if #t~short467 then 1 else 0) then 0 else 1);havoc #t~mem463;havoc #t~short464;havoc #t~mem465;havoc #t~mem466;havoc #t~short467; {860#true} is VALID [2022-02-20 21:08:12,930 INFO L290 TraceCheckUtils]: 48: Hoare triple {860#true} assume true; {860#true} is VALID [2022-02-20 21:08:12,930 INFO L284 TraceCheckUtils]: 49: Hoare quadruple {860#true} {900#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} #204#return; {900#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} is VALID [2022-02-20 21:08:12,930 INFO L272 TraceCheckUtils]: 50: Hoare triple {900#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} call assume_abort_if_not(aws_hash_callback_string_eq_#t~ret1811#1); {860#true} is VALID [2022-02-20 21:08:12,931 INFO L290 TraceCheckUtils]: 51: Hoare triple {860#true} ~cond := #in~cond; {860#true} is VALID [2022-02-20 21:08:12,931 INFO L290 TraceCheckUtils]: 52: Hoare triple {860#true} assume !(0 == ~cond % 256); {860#true} is VALID [2022-02-20 21:08:12,931 INFO L290 TraceCheckUtils]: 53: Hoare triple {860#true} assume true; {860#true} is VALID [2022-02-20 21:08:12,931 INFO L284 TraceCheckUtils]: 54: Hoare quadruple {860#true} {900#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} #206#return; {900#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} is VALID [2022-02-20 21:08:12,932 INFO L290 TraceCheckUtils]: 55: Hoare triple {900#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} havoc aws_hash_callback_string_eq_#t~ret1811#1; {900#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} is VALID [2022-02-20 21:08:12,932 INFO L272 TraceCheckUtils]: 56: Hoare triple {900#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} call aws_hash_callback_string_eq_#t~ret1812#1 := aws_string_is_valid(aws_hash_callback_string_eq_~b#1.base, aws_hash_callback_string_eq_~b#1.offset); {860#true} is VALID [2022-02-20 21:08:12,932 INFO L290 TraceCheckUtils]: 57: Hoare triple {860#true} ~str.base, ~str.offset := #in~str.base, #in~str.offset;#t~short464 := ~str.base != 0 || ~str.offset != 0; {860#true} is VALID [2022-02-20 21:08:12,932 INFO L290 TraceCheckUtils]: 58: Hoare triple {860#true} assume #t~short464;call #t~mem463 := read~int(~str.base, 8 + ~str.offset, 8);#t~short464 := 0 == (1 + #t~mem463) % 18446744073709551616 || ~str.base != 0 || 16 + ~str.offset != 0; {860#true} is VALID [2022-02-20 21:08:12,932 INFO L290 TraceCheckUtils]: 59: Hoare triple {860#true} #t~short467 := #t~short464; {860#true} is VALID [2022-02-20 21:08:12,932 INFO L290 TraceCheckUtils]: 60: Hoare triple {860#true} assume #t~short467;call #t~mem465 := read~int(~str.base, 8 + ~str.offset, 8);call #t~mem466 := read~int(~str.base, 16 + ~str.offset + (if #t~mem465 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then #t~mem465 % 18446744073709551616 % 18446744073709551616 else #t~mem465 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);#t~short467 := 0 == #t~mem466 % 256; {860#true} is VALID [2022-02-20 21:08:12,932 INFO L290 TraceCheckUtils]: 61: Hoare triple {860#true} #res := (if 0 == (if #t~short467 then 1 else 0) then 0 else 1);havoc #t~mem463;havoc #t~short464;havoc #t~mem465;havoc #t~mem466;havoc #t~short467; {860#true} is VALID [2022-02-20 21:08:12,933 INFO L290 TraceCheckUtils]: 62: Hoare triple {860#true} assume true; {860#true} is VALID [2022-02-20 21:08:12,933 INFO L284 TraceCheckUtils]: 63: Hoare quadruple {860#true} {900#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} #208#return; {900#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} is VALID [2022-02-20 21:08:12,933 INFO L272 TraceCheckUtils]: 64: Hoare triple {900#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} call assume_abort_if_not(aws_hash_callback_string_eq_#t~ret1812#1); {860#true} is VALID [2022-02-20 21:08:12,934 INFO L290 TraceCheckUtils]: 65: Hoare triple {860#true} ~cond := #in~cond; {860#true} is VALID [2022-02-20 21:08:12,934 INFO L290 TraceCheckUtils]: 66: Hoare triple {860#true} assume !(0 == ~cond % 256); {860#true} is VALID [2022-02-20 21:08:12,934 INFO L290 TraceCheckUtils]: 67: Hoare triple {860#true} assume true; {860#true} is VALID [2022-02-20 21:08:12,934 INFO L284 TraceCheckUtils]: 68: Hoare quadruple {860#true} {900#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} #210#return; {900#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} is VALID [2022-02-20 21:08:12,935 INFO L290 TraceCheckUtils]: 69: Hoare triple {900#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} havoc aws_hash_callback_string_eq_#t~ret1812#1;assume { :begin_inline_aws_string_eq } true;aws_string_eq_#in~a#1.base, aws_string_eq_#in~a#1.offset, aws_string_eq_#in~b#1.base, aws_string_eq_#in~b#1.offset := aws_hash_callback_string_eq_~a#1.base, aws_hash_callback_string_eq_~a#1.offset, aws_hash_callback_string_eq_~b#1.base, aws_hash_callback_string_eq_~b#1.offset;havoc aws_string_eq_#res#1;havoc aws_string_eq_#t~ret1893#1, aws_string_eq_#t~short1894#1, aws_string_eq_#t~ret1895#1, aws_string_eq_#t~short1896#1, aws_string_eq_#t~mem1897#1, aws_string_eq_#t~mem1898#1, aws_string_eq_#t~ret1899#1, aws_string_eq_~a#1.base, aws_string_eq_~a#1.offset, aws_string_eq_~b#1.base, aws_string_eq_~b#1.offset;aws_string_eq_~a#1.base, aws_string_eq_~a#1.offset := aws_string_eq_#in~a#1.base, aws_string_eq_#in~a#1.offset;aws_string_eq_~b#1.base, aws_string_eq_~b#1.offset := aws_string_eq_#in~b#1.base, aws_string_eq_#in~b#1.offset;aws_string_eq_#t~short1894#1 := aws_string_eq_~a#1.base == 0 && aws_string_eq_~a#1.offset == 0; {923#(not (= |ULTIMATE.start_aws_string_eq_~b#1.base| 0))} is VALID [2022-02-20 21:08:12,936 INFO L290 TraceCheckUtils]: 70: Hoare triple {923#(not (= |ULTIMATE.start_aws_string_eq_~b#1.base| 0))} assume aws_string_eq_#t~short1894#1; {923#(not (= |ULTIMATE.start_aws_string_eq_~b#1.base| 0))} is VALID [2022-02-20 21:08:12,936 INFO L272 TraceCheckUtils]: 71: Hoare triple {923#(not (= |ULTIMATE.start_aws_string_eq_~b#1.base| 0))} call assume_abort_if_not((if 0 == (if aws_string_eq_#t~short1894#1 then 1 else 0) then 0 else 1)); {860#true} is VALID [2022-02-20 21:08:12,936 INFO L290 TraceCheckUtils]: 72: Hoare triple {860#true} ~cond := #in~cond; {860#true} is VALID [2022-02-20 21:08:12,936 INFO L290 TraceCheckUtils]: 73: Hoare triple {860#true} assume !(0 == ~cond % 256); {860#true} is VALID [2022-02-20 21:08:12,936 INFO L290 TraceCheckUtils]: 74: Hoare triple {860#true} assume true; {860#true} is VALID [2022-02-20 21:08:12,937 INFO L284 TraceCheckUtils]: 75: Hoare quadruple {860#true} {923#(not (= |ULTIMATE.start_aws_string_eq_~b#1.base| 0))} #214#return; {923#(not (= |ULTIMATE.start_aws_string_eq_~b#1.base| 0))} is VALID [2022-02-20 21:08:12,937 INFO L290 TraceCheckUtils]: 76: Hoare triple {923#(not (= |ULTIMATE.start_aws_string_eq_~b#1.base| 0))} havoc aws_string_eq_#t~ret1893#1;havoc aws_string_eq_#t~short1894#1;aws_string_eq_#t~short1896#1 := aws_string_eq_~b#1.base == 0 && aws_string_eq_~b#1.offset == 0; {928#(not |ULTIMATE.start_aws_string_eq_#t~short1896#1|)} is VALID [2022-02-20 21:08:12,937 INFO L290 TraceCheckUtils]: 77: Hoare triple {928#(not |ULTIMATE.start_aws_string_eq_#t~short1896#1|)} assume aws_string_eq_#t~short1896#1; {861#false} is VALID [2022-02-20 21:08:12,938 INFO L272 TraceCheckUtils]: 78: Hoare triple {861#false} call assume_abort_if_not((if 0 == (if aws_string_eq_#t~short1896#1 then 1 else 0) then 0 else 1)); {861#false} is VALID [2022-02-20 21:08:12,938 INFO L290 TraceCheckUtils]: 79: Hoare triple {861#false} ~cond := #in~cond; {861#false} is VALID [2022-02-20 21:08:12,938 INFO L290 TraceCheckUtils]: 80: Hoare triple {861#false} assume !(0 == ~cond % 256); {861#false} is VALID [2022-02-20 21:08:12,938 INFO L290 TraceCheckUtils]: 81: Hoare triple {861#false} assume true; {861#false} is VALID [2022-02-20 21:08:12,938 INFO L284 TraceCheckUtils]: 82: Hoare quadruple {861#false} {861#false} #218#return; {861#false} is VALID [2022-02-20 21:08:12,938 INFO L290 TraceCheckUtils]: 83: Hoare triple {861#false} havoc aws_string_eq_#t~ret1895#1;havoc aws_string_eq_#t~short1896#1; {861#false} is VALID [2022-02-20 21:08:12,938 INFO L290 TraceCheckUtils]: 84: Hoare triple {861#false} assume aws_string_eq_~a#1.base == aws_string_eq_~b#1.base && aws_string_eq_~a#1.offset == aws_string_eq_~b#1.offset;aws_string_eq_#res#1 := 1; {861#false} is VALID [2022-02-20 21:08:12,938 INFO L290 TraceCheckUtils]: 85: Hoare triple {861#false} aws_hash_callback_string_eq_#t~ret1813#1 := aws_string_eq_#res#1;assume { :end_inline_aws_string_eq } true;aws_hash_callback_string_eq_~rval~20#1 := aws_hash_callback_string_eq_#t~ret1813#1;havoc aws_hash_callback_string_eq_#t~ret1813#1; {861#false} is VALID [2022-02-20 21:08:12,939 INFO L272 TraceCheckUtils]: 86: Hoare triple {861#false} call aws_hash_callback_string_eq_#t~ret1814#1 := aws_c_string_is_valid(aws_hash_callback_string_eq_~a#1.base, aws_hash_callback_string_eq_~a#1.offset); {861#false} is VALID [2022-02-20 21:08:12,939 INFO L290 TraceCheckUtils]: 87: Hoare triple {861#false} ~str.base, ~str.offset := #in~str.base, #in~str.offset;#res := (if 0 == (if (~str.base != 0 || ~str.offset != 0) && (~str.base != 0 || ~str.offset != 0) then 1 else 0) then 0 else 1); {861#false} is VALID [2022-02-20 21:08:12,939 INFO L290 TraceCheckUtils]: 88: Hoare triple {861#false} assume true; {861#false} is VALID [2022-02-20 21:08:12,939 INFO L284 TraceCheckUtils]: 89: Hoare quadruple {861#false} {861#false} #222#return; {861#false} is VALID [2022-02-20 21:08:12,939 INFO L290 TraceCheckUtils]: 90: Hoare triple {861#false} aws_hash_callback_string_eq_#t~short1816#1 := 0 != aws_hash_callback_string_eq_#t~ret1814#1 % 256; {861#false} is VALID [2022-02-20 21:08:12,939 INFO L290 TraceCheckUtils]: 91: Hoare triple {861#false} assume !aws_hash_callback_string_eq_#t~short1816#1; {861#false} is VALID [2022-02-20 21:08:12,939 INFO L272 TraceCheckUtils]: 92: Hoare triple {861#false} call __VERIFIER_assert((if 0 == (if aws_hash_callback_string_eq_#t~short1816#1 then 1 else 0) then 0 else 1)); {861#false} is VALID [2022-02-20 21:08:12,939 INFO L290 TraceCheckUtils]: 93: Hoare triple {861#false} ~cond := #in~cond; {861#false} is VALID [2022-02-20 21:08:12,940 INFO L290 TraceCheckUtils]: 94: Hoare triple {861#false} assume 0 == ~cond % 256; {861#false} is VALID [2022-02-20 21:08:12,940 INFO L290 TraceCheckUtils]: 95: Hoare triple {861#false} assume !false; {861#false} is VALID [2022-02-20 21:08:12,940 INFO L134 CoverageAnalysis]: Checked inductivity of 70 backedges. 20 proven. 0 refuted. 0 times theorem prover too weak. 50 trivial. 0 not checked. [2022-02-20 21:08:12,940 INFO L324 TraceCheckSpWp]: Omiting computation of backward sequence because forward sequence was already perfect [2022-02-20 21:08:12,941 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleZ3 [295030251] provided 1 perfect and 0 imperfect interpolant sequences [2022-02-20 21:08:12,941 INFO L191 FreeRefinementEngine]: Found 1 perfect and 1 imperfect interpolant sequences. [2022-02-20 21:08:12,941 INFO L204 FreeRefinementEngine]: Number of different interpolants: perfect sequences [13] imperfect sequences [19] total 24 [2022-02-20 21:08:12,941 INFO L118 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [353843487] [2022-02-20 21:08:12,942 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-02-20 21:08:12,943 INFO L78 Accepts]: Start accepts. Automaton has has 13 states, 13 states have (on average 3.6153846153846154) internal successors, (47), 11 states have internal predecessors, (47), 6 states have call successors, (15), 2 states have call predecessors, (15), 4 states have return successors, (14), 8 states have call predecessors, (14), 6 states have call successors, (14) Word has length 96 [2022-02-20 21:08:12,944 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-02-20 21:08:12,945 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with has 13 states, 13 states have (on average 3.6153846153846154) internal successors, (47), 11 states have internal predecessors, (47), 6 states have call successors, (15), 2 states have call predecessors, (15), 4 states have return successors, (14), 8 states have call predecessors, (14), 6 states have call successors, (14) [2022-02-20 21:08:13,032 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 76 edges. 76 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 21:08:13,032 INFO L546 AbstractCegarLoop]: INTERPOLANT automaton has 13 states [2022-02-20 21:08:13,032 INFO L108 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2022-02-20 21:08:13,034 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 13 interpolants. [2022-02-20 21:08:13,035 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=50, Invalid=502, Unknown=0, NotChecked=0, Total=552 [2022-02-20 21:08:13,036 INFO L87 Difference]: Start difference. First operand 104 states and 132 transitions. Second operand has 13 states, 13 states have (on average 3.6153846153846154) internal successors, (47), 11 states have internal predecessors, (47), 6 states have call successors, (15), 2 states have call predecessors, (15), 4 states have return successors, (14), 8 states have call predecessors, (14), 6 states have call successors, (14) [2022-02-20 21:08:14,846 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 21:08:14,847 INFO L93 Difference]: Finished difference Result 192 states and 252 transitions. [2022-02-20 21:08:14,847 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 14 states. [2022-02-20 21:08:14,847 INFO L78 Accepts]: Start accepts. Automaton has has 13 states, 13 states have (on average 3.6153846153846154) internal successors, (47), 11 states have internal predecessors, (47), 6 states have call successors, (15), 2 states have call predecessors, (15), 4 states have return successors, (14), 8 states have call predecessors, (14), 6 states have call successors, (14) Word has length 96 [2022-02-20 21:08:14,848 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-02-20 21:08:14,848 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 13 states, 13 states have (on average 3.6153846153846154) internal successors, (47), 11 states have internal predecessors, (47), 6 states have call successors, (15), 2 states have call predecessors, (15), 4 states have return successors, (14), 8 states have call predecessors, (14), 6 states have call successors, (14) [2022-02-20 21:08:14,854 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 14 states to 14 states and 252 transitions. [2022-02-20 21:08:14,855 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 13 states, 13 states have (on average 3.6153846153846154) internal successors, (47), 11 states have internal predecessors, (47), 6 states have call successors, (15), 2 states have call predecessors, (15), 4 states have return successors, (14), 8 states have call predecessors, (14), 6 states have call successors, (14) [2022-02-20 21:08:14,861 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 14 states to 14 states and 252 transitions. [2022-02-20 21:08:14,861 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with 14 states and 252 transitions. [2022-02-20 21:08:15,102 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 252 edges. 252 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 21:08:15,109 INFO L225 Difference]: With dead ends: 192 [2022-02-20 21:08:15,109 INFO L226 Difference]: Without dead ends: 144 [2022-02-20 21:08:15,110 INFO L932 BasicCegarLoop]: 0 DeclaredPredicates, 145 GetRequests, 116 SyntacticMatches, 0 SemanticMatches, 29 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 61 ImplicationChecksByTransitivity, 0.4s TimeCoverageRelationStatistics Valid=87, Invalid=843, Unknown=0, NotChecked=0, Total=930 [2022-02-20 21:08:15,111 INFO L933 BasicCegarLoop]: 133 mSDtfsCounter, 113 mSDsluCounter, 1364 mSDsCounter, 0 mSdLazyCounter, 163 mSolverCounterSat, 44 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.2s Time, 0 mProtectedPredicate, 0 mProtectedAction, 130 SdHoareTripleChecker+Valid, 1497 SdHoareTripleChecker+Invalid, 207 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 44 IncrementalHoareTripleChecker+Valid, 163 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.2s IncrementalHoareTripleChecker+Time [2022-02-20 21:08:15,112 INFO L934 BasicCegarLoop]: SdHoareTripleChecker [130 Valid, 1497 Invalid, 207 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [44 Valid, 163 Invalid, 0 Unknown, 0 Unchecked, 0.2s Time] [2022-02-20 21:08:15,112 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 144 states. [2022-02-20 21:08:15,129 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 144 to 117. [2022-02-20 21:08:15,134 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-02-20 21:08:15,134 INFO L82 GeneralOperation]: Start isEquivalent. First operand 144 states. Second operand has 117 states, 72 states have (on average 1.1805555555555556) internal successors, (85), 73 states have internal predecessors, (85), 34 states have call successors, (34), 10 states have call predecessors, (34), 10 states have return successors, (33), 33 states have call predecessors, (33), 33 states have call successors, (33) [2022-02-20 21:08:15,136 INFO L74 IsIncluded]: Start isIncluded. First operand 144 states. Second operand has 117 states, 72 states have (on average 1.1805555555555556) internal successors, (85), 73 states have internal predecessors, (85), 34 states have call successors, (34), 10 states have call predecessors, (34), 10 states have return successors, (33), 33 states have call predecessors, (33), 33 states have call successors, (33) [2022-02-20 21:08:15,137 INFO L87 Difference]: Start difference. First operand 144 states. Second operand has 117 states, 72 states have (on average 1.1805555555555556) internal successors, (85), 73 states have internal predecessors, (85), 34 states have call successors, (34), 10 states have call predecessors, (34), 10 states have return successors, (33), 33 states have call predecessors, (33), 33 states have call successors, (33) [2022-02-20 21:08:15,143 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 21:08:15,145 INFO L93 Difference]: Finished difference Result 144 states and 192 transitions. [2022-02-20 21:08:15,145 INFO L276 IsEmpty]: Start isEmpty. Operand 144 states and 192 transitions. [2022-02-20 21:08:15,151 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 21:08:15,153 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 21:08:15,154 INFO L74 IsIncluded]: Start isIncluded. First operand has 117 states, 72 states have (on average 1.1805555555555556) internal successors, (85), 73 states have internal predecessors, (85), 34 states have call successors, (34), 10 states have call predecessors, (34), 10 states have return successors, (33), 33 states have call predecessors, (33), 33 states have call successors, (33) Second operand 144 states. [2022-02-20 21:08:15,157 INFO L87 Difference]: Start difference. First operand has 117 states, 72 states have (on average 1.1805555555555556) internal successors, (85), 73 states have internal predecessors, (85), 34 states have call successors, (34), 10 states have call predecessors, (34), 10 states have return successors, (33), 33 states have call predecessors, (33), 33 states have call successors, (33) Second operand 144 states. [2022-02-20 21:08:15,164 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 21:08:15,164 INFO L93 Difference]: Finished difference Result 144 states and 192 transitions. [2022-02-20 21:08:15,164 INFO L276 IsEmpty]: Start isEmpty. Operand 144 states and 192 transitions. [2022-02-20 21:08:15,167 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 21:08:15,167 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 21:08:15,167 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-02-20 21:08:15,167 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-02-20 21:08:15,168 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 117 states, 72 states have (on average 1.1805555555555556) internal successors, (85), 73 states have internal predecessors, (85), 34 states have call successors, (34), 10 states have call predecessors, (34), 10 states have return successors, (33), 33 states have call predecessors, (33), 33 states have call successors, (33) [2022-02-20 21:08:15,174 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 117 states to 117 states and 152 transitions. [2022-02-20 21:08:15,175 INFO L78 Accepts]: Start accepts. Automaton has 117 states and 152 transitions. Word has length 96 [2022-02-20 21:08:15,176 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-02-20 21:08:15,176 INFO L470 AbstractCegarLoop]: Abstraction has 117 states and 152 transitions. [2022-02-20 21:08:15,177 INFO L471 AbstractCegarLoop]: INTERPOLANT automaton has has 13 states, 13 states have (on average 3.6153846153846154) internal successors, (47), 11 states have internal predecessors, (47), 6 states have call successors, (15), 2 states have call predecessors, (15), 4 states have return successors, (14), 8 states have call predecessors, (14), 6 states have call successors, (14) [2022-02-20 21:08:15,177 INFO L276 IsEmpty]: Start isEmpty. Operand 117 states and 152 transitions. [2022-02-20 21:08:15,180 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 106 [2022-02-20 21:08:15,180 INFO L506 BasicCegarLoop]: Found error trace [2022-02-20 21:08:15,181 INFO L514 BasicCegarLoop]: trace histogram [6, 6, 6, 3, 3, 3, 3, 3, 3, 2, 2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2022-02-20 21:08:15,212 INFO L540 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (2)] Forceful destruction successful, exit code 0 [2022-02-20 21:08:15,406 WARN L452 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable1,2 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-02-20 21:08:15,406 INFO L402 AbstractCegarLoop]: === Iteration 3 === Targeting __VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION === [__VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-02-20 21:08:15,407 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-02-20 21:08:15,407 INFO L85 PathProgramCache]: Analyzing trace with hash 18133626, now seen corresponding path program 1 times [2022-02-20 21:08:15,407 INFO L126 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-02-20 21:08:15,407 INFO L338 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [1890334168] [2022-02-20 21:08:15,407 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 21:08:15,407 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-02-20 21:08:15,458 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:15,538 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 2 [2022-02-20 21:08:15,578 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:15,694 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:08:15,697 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:15,705 INFO L290 TraceCheckUtils]: 0: Hoare triple {1999#true} #res := #t~nondet13;havoc #t~nondet13; {1999#true} is VALID [2022-02-20 21:08:15,706 INFO L290 TraceCheckUtils]: 1: Hoare triple {1999#true} assume true; {1999#true} is VALID [2022-02-20 21:08:15,706 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {1999#true} {2081#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} #182#return; {2081#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} is VALID [2022-02-20 21:08:15,707 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 6 [2022-02-20 21:08:15,719 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:15,771 INFO L290 TraceCheckUtils]: 0: Hoare triple {1999#true} ~cond := #in~cond; {2104#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} is VALID [2022-02-20 21:08:15,772 INFO L290 TraceCheckUtils]: 1: Hoare triple {2104#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} assume !(0 == ~cond % 256); {2105#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} is VALID [2022-02-20 21:08:15,772 INFO L290 TraceCheckUtils]: 2: Hoare triple {2105#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} assume true; {2105#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} is VALID [2022-02-20 21:08:15,773 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {2105#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} {2081#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} #184#return; {2089#(or (not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96)) (<= (* 18446744073709551616 (div |ensure_string_is_allocated_bounded_length_~len~1#1| 18446744073709551616)) (+ |ensure_string_is_allocated_bounded_length_~len~1#1| (* 18446744073709551616 (div (+ (* 18446744073709551616 (div |ensure_string_is_allocated_bounded_length_~len~1#1| 18446744073709551616)) 95 (* (- 1) |ensure_string_is_allocated_bounded_length_~len~1#1|)) 18446744073709551616)))))} is VALID [2022-02-20 21:08:15,785 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 12 [2022-02-20 21:08:15,796 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:15,906 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:08:15,910 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:15,930 INFO L290 TraceCheckUtils]: 0: Hoare triple {1999#true} ~cond := #in~cond; {2104#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} is VALID [2022-02-20 21:08:15,931 INFO L290 TraceCheckUtils]: 1: Hoare triple {2104#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} assume !(0 == ~cond % 256); {2105#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} is VALID [2022-02-20 21:08:15,931 INFO L290 TraceCheckUtils]: 2: Hoare triple {2105#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} assume true; {2105#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} is VALID [2022-02-20 21:08:15,932 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {2105#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} {2107#(= |bounded_malloc_#in~size| bounded_malloc_~size)} #192#return; {2112#(and (= |bounded_malloc_#in~size| bounded_malloc_~size) (<= bounded_malloc_~size (+ (* (div bounded_malloc_~size 18446744073709551616) 18446744073709551616) 36028797018963967)))} is VALID [2022-02-20 21:08:15,933 INFO L290 TraceCheckUtils]: 0: Hoare triple {2106#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size; {2107#(= |bounded_malloc_#in~size| bounded_malloc_~size)} is VALID [2022-02-20 21:08:15,933 INFO L272 TraceCheckUtils]: 1: Hoare triple {2107#(= |bounded_malloc_#in~size| bounded_malloc_~size)} call assume_abort_if_not((if 0 == (if ~size % 18446744073709551616 <= 36028797018963967 then 1 else 0) then 0 else 1)); {1999#true} is VALID [2022-02-20 21:08:15,934 INFO L290 TraceCheckUtils]: 2: Hoare triple {1999#true} ~cond := #in~cond; {2104#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} is VALID [2022-02-20 21:08:15,934 INFO L290 TraceCheckUtils]: 3: Hoare triple {2104#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} assume !(0 == ~cond % 256); {2105#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} is VALID [2022-02-20 21:08:15,935 INFO L290 TraceCheckUtils]: 4: Hoare triple {2105#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} assume true; {2105#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} is VALID [2022-02-20 21:08:15,936 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {2105#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} {2107#(= |bounded_malloc_#in~size| bounded_malloc_~size)} #192#return; {2112#(and (= |bounded_malloc_#in~size| bounded_malloc_~size) (<= bounded_malloc_~size (+ (* (div bounded_malloc_~size 18446744073709551616) 18446744073709551616) 36028797018963967)))} is VALID [2022-02-20 21:08:15,936 INFO L290 TraceCheckUtils]: 6: Hoare triple {2112#(and (= |bounded_malloc_#in~size| bounded_malloc_~size) (<= bounded_malloc_~size (+ (* (div bounded_malloc_~size 18446744073709551616) 18446744073709551616) 36028797018963967)))} call #t~malloc555.base, #t~malloc555.offset := #Ultimate.allocOnHeap(~size);#res.base, #res.offset := #t~malloc555.base, #t~malloc555.offset;havoc #t~malloc555.base, #t~malloc555.offset; {2113#(<= |bounded_malloc_#in~size| (+ 36028797018963967 (* 18446744073709551616 (div |bounded_malloc_#in~size| 18446744073709551616))))} is VALID [2022-02-20 21:08:15,937 INFO L290 TraceCheckUtils]: 7: Hoare triple {2113#(<= |bounded_malloc_#in~size| (+ 36028797018963967 (* 18446744073709551616 (div |bounded_malloc_#in~size| 18446744073709551616))))} assume true; {2113#(<= |bounded_malloc_#in~size| (+ 36028797018963967 (* 18446744073709551616 (div |bounded_malloc_#in~size| 18446744073709551616))))} is VALID [2022-02-20 21:08:15,938 INFO L284 TraceCheckUtils]: 8: Hoare quadruple {2113#(<= |bounded_malloc_#in~size| (+ 36028797018963967 (* 18446744073709551616 (div |bounded_malloc_#in~size| 18446744073709551616))))} {2090#(or (not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96)) (<= 0 (+ (* 18446744073709551616 (div (+ (* (- 1) |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~len#1|) 95) 18446744073709551616)) |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~len#1|)))} #186#return; {2100#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} is VALID [2022-02-20 21:08:15,939 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 23 [2022-02-20 21:08:15,940 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:15,948 INFO L290 TraceCheckUtils]: 0: Hoare triple {1999#true} #res := #t~nondet8;havoc #t~nondet8; {1999#true} is VALID [2022-02-20 21:08:15,949 INFO L290 TraceCheckUtils]: 1: Hoare triple {1999#true} assume true; {1999#true} is VALID [2022-02-20 21:08:15,949 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {1999#true} {2100#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} #188#return; {2100#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} is VALID [2022-02-20 21:08:15,950 INFO L290 TraceCheckUtils]: 0: Hoare triple {2080#(and (= |old(#length)| |#length|) (= |old(#memory_real)| |#memory_real|) (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|) (= |old(#valid)| |#valid|))} ~max_size#1 := #in~max_size#1; {2081#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} is VALID [2022-02-20 21:08:15,950 INFO L272 TraceCheckUtils]: 1: Hoare triple {2081#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} call #t~ret540#1 := nondet_uint64_t(); {1999#true} is VALID [2022-02-20 21:08:15,950 INFO L290 TraceCheckUtils]: 2: Hoare triple {1999#true} #res := #t~nondet13;havoc #t~nondet13; {1999#true} is VALID [2022-02-20 21:08:15,951 INFO L290 TraceCheckUtils]: 3: Hoare triple {1999#true} assume true; {1999#true} is VALID [2022-02-20 21:08:15,951 INFO L284 TraceCheckUtils]: 4: Hoare quadruple {1999#true} {2081#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} #182#return; {2081#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} is VALID [2022-02-20 21:08:15,952 INFO L290 TraceCheckUtils]: 5: Hoare triple {2081#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} ~len~1#1 := #t~ret540#1;havoc #t~ret540#1; {2081#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} is VALID [2022-02-20 21:08:15,952 INFO L272 TraceCheckUtils]: 6: Hoare triple {2081#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} call assume_abort_if_not((if 0 == (if ~len~1#1 % 18446744073709551616 < ~max_size#1 % 18446744073709551616 then 1 else 0) then 0 else 1)); {1999#true} is VALID [2022-02-20 21:08:15,952 INFO L290 TraceCheckUtils]: 7: Hoare triple {1999#true} ~cond := #in~cond; {2104#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} is VALID [2022-02-20 21:08:15,953 INFO L290 TraceCheckUtils]: 8: Hoare triple {2104#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} assume !(0 == ~cond % 256); {2105#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} is VALID [2022-02-20 21:08:15,953 INFO L290 TraceCheckUtils]: 9: Hoare triple {2105#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} assume true; {2105#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} is VALID [2022-02-20 21:08:15,955 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {2105#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} {2081#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} #184#return; {2089#(or (not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96)) (<= (* 18446744073709551616 (div |ensure_string_is_allocated_bounded_length_~len~1#1| 18446744073709551616)) (+ |ensure_string_is_allocated_bounded_length_~len~1#1| (* 18446744073709551616 (div (+ (* 18446744073709551616 (div |ensure_string_is_allocated_bounded_length_~len~1#1| 18446744073709551616)) 95 (* (- 1) |ensure_string_is_allocated_bounded_length_~len~1#1|)) 18446744073709551616)))))} is VALID [2022-02-20 21:08:15,957 INFO L290 TraceCheckUtils]: 11: Hoare triple {2089#(or (not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96)) (<= (* 18446744073709551616 (div |ensure_string_is_allocated_bounded_length_~len~1#1| 18446744073709551616)) (+ |ensure_string_is_allocated_bounded_length_~len~1#1| (* 18446744073709551616 (div (+ (* 18446744073709551616 (div |ensure_string_is_allocated_bounded_length_~len~1#1| 18446744073709551616)) 95 (* (- 1) |ensure_string_is_allocated_bounded_length_~len~1#1|)) 18446744073709551616)))))} assume { :begin_inline_ensure_string_is_allocated } true;ensure_string_is_allocated_#in~len#1 := ~len~1#1;havoc ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset;havoc ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset, ensure_string_is_allocated_#t~ret543#1, ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset, ensure_string_is_allocated_#t~ret544#1.base, ensure_string_is_allocated_#t~ret544#1.offset, ensure_string_is_allocated_~len#1, ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset;ensure_string_is_allocated_~len#1 := ensure_string_is_allocated_#in~len#1; {2090#(or (not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96)) (<= 0 (+ (* 18446744073709551616 (div (+ (* (- 1) |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~len#1|) 95) 18446744073709551616)) |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~len#1|)))} is VALID [2022-02-20 21:08:15,958 INFO L272 TraceCheckUtils]: 12: Hoare triple {2090#(or (not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96)) (<= 0 (+ (* 18446744073709551616 (div (+ (* (- 1) |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~len#1|) 95) 18446744073709551616)) |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~len#1|)))} call ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset := bounded_malloc(-1234550 + ensure_string_is_allocated_~len#1); {2106#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:08:15,958 INFO L290 TraceCheckUtils]: 13: Hoare triple {2106#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size; {2107#(= |bounded_malloc_#in~size| bounded_malloc_~size)} is VALID [2022-02-20 21:08:15,959 INFO L272 TraceCheckUtils]: 14: Hoare triple {2107#(= |bounded_malloc_#in~size| bounded_malloc_~size)} call assume_abort_if_not((if 0 == (if ~size % 18446744073709551616 <= 36028797018963967 then 1 else 0) then 0 else 1)); {1999#true} is VALID [2022-02-20 21:08:15,959 INFO L290 TraceCheckUtils]: 15: Hoare triple {1999#true} ~cond := #in~cond; {2104#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} is VALID [2022-02-20 21:08:15,960 INFO L290 TraceCheckUtils]: 16: Hoare triple {2104#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} assume !(0 == ~cond % 256); {2105#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} is VALID [2022-02-20 21:08:15,960 INFO L290 TraceCheckUtils]: 17: Hoare triple {2105#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} assume true; {2105#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} is VALID [2022-02-20 21:08:15,961 INFO L284 TraceCheckUtils]: 18: Hoare quadruple {2105#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} {2107#(= |bounded_malloc_#in~size| bounded_malloc_~size)} #192#return; {2112#(and (= |bounded_malloc_#in~size| bounded_malloc_~size) (<= bounded_malloc_~size (+ (* (div bounded_malloc_~size 18446744073709551616) 18446744073709551616) 36028797018963967)))} is VALID [2022-02-20 21:08:15,962 INFO L290 TraceCheckUtils]: 19: Hoare triple {2112#(and (= |bounded_malloc_#in~size| bounded_malloc_~size) (<= bounded_malloc_~size (+ (* (div bounded_malloc_~size 18446744073709551616) 18446744073709551616) 36028797018963967)))} call #t~malloc555.base, #t~malloc555.offset := #Ultimate.allocOnHeap(~size);#res.base, #res.offset := #t~malloc555.base, #t~malloc555.offset;havoc #t~malloc555.base, #t~malloc555.offset; {2113#(<= |bounded_malloc_#in~size| (+ 36028797018963967 (* 18446744073709551616 (div |bounded_malloc_#in~size| 18446744073709551616))))} is VALID [2022-02-20 21:08:15,962 INFO L290 TraceCheckUtils]: 20: Hoare triple {2113#(<= |bounded_malloc_#in~size| (+ 36028797018963967 (* 18446744073709551616 (div |bounded_malloc_#in~size| 18446744073709551616))))} assume true; {2113#(<= |bounded_malloc_#in~size| (+ 36028797018963967 (* 18446744073709551616 (div |bounded_malloc_#in~size| 18446744073709551616))))} is VALID [2022-02-20 21:08:15,964 INFO L284 TraceCheckUtils]: 21: Hoare quadruple {2113#(<= |bounded_malloc_#in~size| (+ 36028797018963967 (* 18446744073709551616 (div |bounded_malloc_#in~size| 18446744073709551616))))} {2090#(or (not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96)) (<= 0 (+ (* 18446744073709551616 (div (+ (* (- 1) |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~len#1|) 95) 18446744073709551616)) |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~len#1|)))} #186#return; {2100#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} is VALID [2022-02-20 21:08:15,965 INFO L290 TraceCheckUtils]: 22: Hoare triple {2100#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset := ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset;havoc ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset; {2100#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} is VALID [2022-02-20 21:08:15,965 INFO L272 TraceCheckUtils]: 23: Hoare triple {2100#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} call ensure_string_is_allocated_#t~ret543#1 := nondet_bool(); {1999#true} is VALID [2022-02-20 21:08:15,965 INFO L290 TraceCheckUtils]: 24: Hoare triple {1999#true} #res := #t~nondet8;havoc #t~nondet8; {1999#true} is VALID [2022-02-20 21:08:15,965 INFO L290 TraceCheckUtils]: 25: Hoare triple {1999#true} assume true; {1999#true} is VALID [2022-02-20 21:08:15,966 INFO L284 TraceCheckUtils]: 26: Hoare quadruple {1999#true} {2100#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} #188#return; {2100#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} is VALID [2022-02-20 21:08:15,966 INFO L290 TraceCheckUtils]: 27: Hoare triple {2100#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} assume !(0 != ensure_string_is_allocated_#t~ret543#1 % 256);ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset := 0, 0; {2100#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} is VALID [2022-02-20 21:08:15,966 INFO L290 TraceCheckUtils]: 28: Hoare triple {2100#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} call write~$Pointer$(ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset, ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset, 8);havoc ensure_string_is_allocated_#t~ret543#1;havoc ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset;havoc ensure_string_is_allocated_#t~ret544#1.base, ensure_string_is_allocated_#t~ret544#1.offset;call write~int(ensure_string_is_allocated_~len#1, ensure_string_is_allocated_~str~0#1.base, 8 + ensure_string_is_allocated_~str~0#1.offset, 8);call write~int(0, ensure_string_is_allocated_~str~0#1.base, 16 + ensure_string_is_allocated_~str~0#1.offset + (if ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 else ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset := ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset; {2100#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} is VALID [2022-02-20 21:08:15,967 INFO L290 TraceCheckUtils]: 29: Hoare triple {2100#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} #t~ret541#1.base, #t~ret541#1.offset := ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset;assume { :end_inline_ensure_string_is_allocated } true;#res#1.base, #res#1.offset := #t~ret541#1.base, #t~ret541#1.offset;havoc #t~ret541#1.base, #t~ret541#1.offset; {2100#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} is VALID [2022-02-20 21:08:15,967 INFO L290 TraceCheckUtils]: 30: Hoare triple {2100#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} assume true; {2100#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} is VALID [2022-02-20 21:08:15,968 INFO L284 TraceCheckUtils]: 31: Hoare quadruple {2100#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} {1999#true} #198#return; {2033#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_#t~ret1963#1.base| 0))} is VALID [2022-02-20 21:08:15,968 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 36 [2022-02-20 21:08:15,970 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:15,977 INFO L290 TraceCheckUtils]: 0: Hoare triple {1999#true} #res := #t~nondet8;havoc #t~nondet8; {1999#true} is VALID [2022-02-20 21:08:15,978 INFO L290 TraceCheckUtils]: 1: Hoare triple {1999#true} assume true; {1999#true} is VALID [2022-02-20 21:08:15,978 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {1999#true} {2034#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| 0))} #200#return; {2034#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| 0))} is VALID [2022-02-20 21:08:15,979 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 42 [2022-02-20 21:08:15,982 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:15,993 INFO L290 TraceCheckUtils]: 0: Hoare triple {1999#true} ~str.base, ~str.offset := #in~str.base, #in~str.offset;#t~short464 := ~str.base != 0 || ~str.offset != 0; {1999#true} is VALID [2022-02-20 21:08:15,993 INFO L290 TraceCheckUtils]: 1: Hoare triple {1999#true} assume #t~short464;call #t~mem463 := read~int(~str.base, 8 + ~str.offset, 8);#t~short464 := 0 == (1 + #t~mem463) % 18446744073709551616 || ~str.base != 0 || 16 + ~str.offset != 0; {1999#true} is VALID [2022-02-20 21:08:15,993 INFO L290 TraceCheckUtils]: 2: Hoare triple {1999#true} #t~short467 := #t~short464; {1999#true} is VALID [2022-02-20 21:08:15,993 INFO L290 TraceCheckUtils]: 3: Hoare triple {1999#true} assume #t~short467;call #t~mem465 := read~int(~str.base, 8 + ~str.offset, 8);call #t~mem466 := read~int(~str.base, 16 + ~str.offset + (if #t~mem465 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then #t~mem465 % 18446744073709551616 % 18446744073709551616 else #t~mem465 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);#t~short467 := 0 == #t~mem466 % 256; {1999#true} is VALID [2022-02-20 21:08:15,994 INFO L290 TraceCheckUtils]: 4: Hoare triple {1999#true} #res := (if 0 == (if #t~short467 then 1 else 0) then 0 else 1);havoc #t~mem463;havoc #t~short464;havoc #t~mem465;havoc #t~mem466;havoc #t~short467; {1999#true} is VALID [2022-02-20 21:08:15,994 INFO L290 TraceCheckUtils]: 5: Hoare triple {1999#true} assume true; {1999#true} is VALID [2022-02-20 21:08:15,994 INFO L284 TraceCheckUtils]: 6: Hoare quadruple {1999#true} {2038#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} #204#return; {2038#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} is VALID [2022-02-20 21:08:15,995 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 50 [2022-02-20 21:08:15,996 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:16,005 INFO L290 TraceCheckUtils]: 0: Hoare triple {1999#true} ~cond := #in~cond; {1999#true} is VALID [2022-02-20 21:08:16,005 INFO L290 TraceCheckUtils]: 1: Hoare triple {1999#true} assume !(0 == ~cond % 256); {1999#true} is VALID [2022-02-20 21:08:16,005 INFO L290 TraceCheckUtils]: 2: Hoare triple {1999#true} assume true; {1999#true} is VALID [2022-02-20 21:08:16,006 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {1999#true} {2038#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} #206#return; {2038#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} is VALID [2022-02-20 21:08:16,006 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 56 [2022-02-20 21:08:16,010 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:16,020 INFO L290 TraceCheckUtils]: 0: Hoare triple {1999#true} ~str.base, ~str.offset := #in~str.base, #in~str.offset;#t~short464 := ~str.base != 0 || ~str.offset != 0; {1999#true} is VALID [2022-02-20 21:08:16,021 INFO L290 TraceCheckUtils]: 1: Hoare triple {1999#true} assume #t~short464;call #t~mem463 := read~int(~str.base, 8 + ~str.offset, 8);#t~short464 := 0 == (1 + #t~mem463) % 18446744073709551616 || ~str.base != 0 || 16 + ~str.offset != 0; {1999#true} is VALID [2022-02-20 21:08:16,021 INFO L290 TraceCheckUtils]: 2: Hoare triple {1999#true} #t~short467 := #t~short464; {1999#true} is VALID [2022-02-20 21:08:16,021 INFO L290 TraceCheckUtils]: 3: Hoare triple {1999#true} assume #t~short467;call #t~mem465 := read~int(~str.base, 8 + ~str.offset, 8);call #t~mem466 := read~int(~str.base, 16 + ~str.offset + (if #t~mem465 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then #t~mem465 % 18446744073709551616 % 18446744073709551616 else #t~mem465 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);#t~short467 := 0 == #t~mem466 % 256; {1999#true} is VALID [2022-02-20 21:08:16,021 INFO L290 TraceCheckUtils]: 4: Hoare triple {1999#true} #res := (if 0 == (if #t~short467 then 1 else 0) then 0 else 1);havoc #t~mem463;havoc #t~short464;havoc #t~mem465;havoc #t~mem466;havoc #t~short467; {1999#true} is VALID [2022-02-20 21:08:16,022 INFO L290 TraceCheckUtils]: 5: Hoare triple {1999#true} assume true; {1999#true} is VALID [2022-02-20 21:08:16,023 INFO L284 TraceCheckUtils]: 6: Hoare quadruple {1999#true} {2038#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} #208#return; {2038#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} is VALID [2022-02-20 21:08:16,023 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 64 [2022-02-20 21:08:16,025 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:16,033 INFO L290 TraceCheckUtils]: 0: Hoare triple {1999#true} ~cond := #in~cond; {1999#true} is VALID [2022-02-20 21:08:16,034 INFO L290 TraceCheckUtils]: 1: Hoare triple {1999#true} assume !(0 == ~cond % 256); {1999#true} is VALID [2022-02-20 21:08:16,034 INFO L290 TraceCheckUtils]: 2: Hoare triple {1999#true} assume true; {1999#true} is VALID [2022-02-20 21:08:16,035 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {1999#true} {2038#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} #210#return; {2038#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} is VALID [2022-02-20 21:08:16,035 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 71 [2022-02-20 21:08:16,036 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:16,043 INFO L290 TraceCheckUtils]: 0: Hoare triple {1999#true} ~cond := #in~cond; {1999#true} is VALID [2022-02-20 21:08:16,044 INFO L290 TraceCheckUtils]: 1: Hoare triple {1999#true} assume !(0 == ~cond % 256); {1999#true} is VALID [2022-02-20 21:08:16,044 INFO L290 TraceCheckUtils]: 2: Hoare triple {1999#true} assume true; {1999#true} is VALID [2022-02-20 21:08:16,044 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {1999#true} {2000#false} #214#return; {2000#false} is VALID [2022-02-20 21:08:16,044 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 78 [2022-02-20 21:08:16,047 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:16,057 INFO L290 TraceCheckUtils]: 0: Hoare triple {1999#true} ~str.base, ~str.offset := #in~str.base, #in~str.offset;#t~short464 := ~str.base != 0 || ~str.offset != 0; {1999#true} is VALID [2022-02-20 21:08:16,057 INFO L290 TraceCheckUtils]: 1: Hoare triple {1999#true} assume #t~short464;call #t~mem463 := read~int(~str.base, 8 + ~str.offset, 8);#t~short464 := 0 == (1 + #t~mem463) % 18446744073709551616 || ~str.base != 0 || 16 + ~str.offset != 0; {1999#true} is VALID [2022-02-20 21:08:16,057 INFO L290 TraceCheckUtils]: 2: Hoare triple {1999#true} #t~short467 := #t~short464; {1999#true} is VALID [2022-02-20 21:08:16,058 INFO L290 TraceCheckUtils]: 3: Hoare triple {1999#true} assume #t~short467;call #t~mem465 := read~int(~str.base, 8 + ~str.offset, 8);call #t~mem466 := read~int(~str.base, 16 + ~str.offset + (if #t~mem465 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then #t~mem465 % 18446744073709551616 % 18446744073709551616 else #t~mem465 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);#t~short467 := 0 == #t~mem466 % 256; {1999#true} is VALID [2022-02-20 21:08:16,058 INFO L290 TraceCheckUtils]: 4: Hoare triple {1999#true} #res := (if 0 == (if #t~short467 then 1 else 0) then 0 else 1);havoc #t~mem463;havoc #t~short464;havoc #t~mem465;havoc #t~mem466;havoc #t~short467; {1999#true} is VALID [2022-02-20 21:08:16,058 INFO L290 TraceCheckUtils]: 5: Hoare triple {1999#true} assume true; {1999#true} is VALID [2022-02-20 21:08:16,058 INFO L284 TraceCheckUtils]: 6: Hoare quadruple {1999#true} {2000#false} #216#return; {2000#false} is VALID [2022-02-20 21:08:16,058 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 87 [2022-02-20 21:08:16,059 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:16,067 INFO L290 TraceCheckUtils]: 0: Hoare triple {1999#true} ~cond := #in~cond; {1999#true} is VALID [2022-02-20 21:08:16,068 INFO L290 TraceCheckUtils]: 1: Hoare triple {1999#true} assume !(0 == ~cond % 256); {1999#true} is VALID [2022-02-20 21:08:16,068 INFO L290 TraceCheckUtils]: 2: Hoare triple {1999#true} assume true; {1999#true} is VALID [2022-02-20 21:08:16,068 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {1999#true} {2000#false} #218#return; {2000#false} is VALID [2022-02-20 21:08:16,068 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 95 [2022-02-20 21:08:16,069 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:16,077 INFO L290 TraceCheckUtils]: 0: Hoare triple {1999#true} ~str.base, ~str.offset := #in~str.base, #in~str.offset;#res := (if 0 == (if (~str.base != 0 || ~str.offset != 0) && (~str.base != 0 || ~str.offset != 0) then 1 else 0) then 0 else 1); {1999#true} is VALID [2022-02-20 21:08:16,077 INFO L290 TraceCheckUtils]: 1: Hoare triple {1999#true} assume true; {1999#true} is VALID [2022-02-20 21:08:16,077 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {1999#true} {2000#false} #222#return; {2000#false} is VALID [2022-02-20 21:08:16,078 INFO L290 TraceCheckUtils]: 0: Hoare triple {1999#true} assume { :begin_inline_ULTIMATE.init } true;#NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(38, 2);call #Ultimate.allocInit(12, 3);call #Ultimate.allocInit(78, 4);~#s_can_fail_allocator_static~0.base, ~#s_can_fail_allocator_static~0.offset := 5, 0;call #Ultimate.allocInit(40, 5);call write~init~$Pointer$(#funAddr~s_can_fail_malloc_allocator.base, #funAddr~s_can_fail_malloc_allocator.offset, ~#s_can_fail_allocator_static~0.base, ~#s_can_fail_allocator_static~0.offset, 8);call write~init~$Pointer$(#funAddr~s_can_fail_free_allocator.base, #funAddr~s_can_fail_free_allocator.offset, ~#s_can_fail_allocator_static~0.base, 8 + ~#s_can_fail_allocator_static~0.offset, 8);call write~init~$Pointer$(#funAddr~s_can_fail_realloc_allocator.base, #funAddr~s_can_fail_realloc_allocator.offset, ~#s_can_fail_allocator_static~0.base, 16 + ~#s_can_fail_allocator_static~0.offset, 8);call write~init~$Pointer$(#funAddr~s_can_fail_calloc_allocator.base, #funAddr~s_can_fail_calloc_allocator.offset, ~#s_can_fail_allocator_static~0.base, 24 + ~#s_can_fail_allocator_static~0.offset, 8);call write~init~$Pointer$(0, 0, ~#s_can_fail_allocator_static~0.base, 32 + ~#s_can_fail_allocator_static~0.offset, 8);~#s_tolower_table~0.base, ~#s_tolower_table~0.offset := 6, 0;call #Ultimate.allocInit(256, 6);call write~init~int(0, ~#s_tolower_table~0.base, ~#s_tolower_table~0.offset, 1);call write~init~int(1, ~#s_tolower_table~0.base, 1 + ~#s_tolower_table~0.offset, 1);call write~init~int(2, ~#s_tolower_table~0.base, 2 + ~#s_tolower_table~0.offset, 1);call write~init~int(3, ~#s_tolower_table~0.base, 3 + ~#s_tolower_table~0.offset, 1);call write~init~int(4, ~#s_tolower_table~0.base, 4 + ~#s_tolower_table~0.offset, 1);call write~init~int(5, ~#s_tolower_table~0.base, 5 + ~#s_tolower_table~0.offset, 1);call write~init~int(6, ~#s_tolower_table~0.base, 6 + ~#s_tolower_table~0.offset, 1);call write~init~int(7, ~#s_tolower_table~0.base, 7 + ~#s_tolower_table~0.offset, 1);call write~init~int(8, ~#s_tolower_table~0.base, 8 + ~#s_tolower_table~0.offset, 1);call write~init~int(9, ~#s_tolower_table~0.base, 9 + ~#s_tolower_table~0.offset, 1);call write~init~int(10, ~#s_tolower_table~0.base, 10 + ~#s_tolower_table~0.offset, 1);call write~init~int(11, ~#s_tolower_table~0.base, 11 + ~#s_tolower_table~0.offset, 1);call write~init~int(12, ~#s_tolower_table~0.base, 12 + ~#s_tolower_table~0.offset, 1);call write~init~int(13, ~#s_tolower_table~0.base, 13 + ~#s_tolower_table~0.offset, 1);call write~init~int(14, ~#s_tolower_table~0.base, 14 + ~#s_tolower_table~0.offset, 1);call write~init~int(15, ~#s_tolower_table~0.base, 15 + ~#s_tolower_table~0.offset, 1);call write~init~int(16, ~#s_tolower_table~0.base, 16 + ~#s_tolower_table~0.offset, 1);call write~init~int(17, ~#s_tolower_table~0.base, 17 + ~#s_tolower_table~0.offset, 1);call write~init~int(18, ~#s_tolower_table~0.base, 18 + ~#s_tolower_table~0.offset, 1);call write~init~int(19, ~#s_tolower_table~0.base, 19 + ~#s_tolower_table~0.offset, 1);call write~init~int(20, ~#s_tolower_table~0.base, 20 + ~#s_tolower_table~0.offset, 1);call write~init~int(21, ~#s_tolower_table~0.base, 21 + ~#s_tolower_table~0.offset, 1);call write~init~int(22, ~#s_tolower_table~0.base, 22 + ~#s_tolower_table~0.offset, 1);call write~init~int(23, ~#s_tolower_table~0.base, 23 + ~#s_tolower_table~0.offset, 1);call write~init~int(24, ~#s_tolower_table~0.base, 24 + ~#s_tolower_table~0.offset, 1);call write~init~int(25, ~#s_tolower_table~0.base, 25 + ~#s_tolower_table~0.offset, 1);call write~init~int(26, ~#s_tolower_table~0.base, 26 + ~#s_tolower_table~0.offset, 1);call write~init~int(27, ~#s_tolower_table~0.base, 27 + ~#s_tolower_table~0.offset, 1);call write~init~int(28, ~#s_tolower_table~0.base, 28 + ~#s_tolower_table~0.offset, 1);call write~init~int(29, ~#s_tolower_table~0.base, 29 + ~#s_tolower_table~0.offset, 1);call write~init~int(30, ~#s_tolower_table~0.base, 30 + ~#s_tolower_table~0.offset, 1);call write~init~int(31, ~#s_tolower_table~0.base, 31 + ~#s_tolower_table~0.offset, 1);call write~init~int(32, ~#s_tolower_table~0.base, 32 + ~#s_tolower_table~0.offset, 1);call write~init~int(33, ~#s_tolower_table~0.base, 33 + ~#s_tolower_table~0.offset, 1);call write~init~int(34, ~#s_tolower_table~0.base, 34 + ~#s_tolower_table~0.offset, 1);call write~init~int(35, ~#s_tolower_table~0.base, 35 + ~#s_tolower_table~0.offset, 1);call write~init~int(36, ~#s_tolower_table~0.base, 36 + ~#s_tolower_table~0.offset, 1);call write~init~int(37, ~#s_tolower_table~0.base, 37 + ~#s_tolower_table~0.offset, 1);call write~init~int(38, ~#s_tolower_table~0.base, 38 + ~#s_tolower_table~0.offset, 1);call write~init~int(39, ~#s_tolower_table~0.base, 39 + ~#s_tolower_table~0.offset, 1);call write~init~int(40, ~#s_tolower_table~0.base, 40 + ~#s_tolower_table~0.offset, 1);call write~init~int(41, ~#s_tolower_table~0.base, 41 + ~#s_tolower_table~0.offset, 1);call write~init~int(42, ~#s_tolower_table~0.base, 42 + ~#s_tolower_table~0.offset, 1);call write~init~int(43, ~#s_tolower_table~0.base, 43 + ~#s_tolower_table~0.offset, 1);call write~init~int(44, ~#s_tolower_table~0.base, 44 + ~#s_tolower_table~0.offset, 1);call write~init~int(45, ~#s_tolower_table~0.base, 45 + ~#s_tolower_table~0.offset, 1);call write~init~int(46, ~#s_tolower_table~0.base, 46 + ~#s_tolower_table~0.offset, 1);call write~init~int(47, ~#s_tolower_table~0.base, 47 + ~#s_tolower_table~0.offset, 1);call write~init~int(48, ~#s_tolower_table~0.base, 48 + ~#s_tolower_table~0.offset, 1);call write~init~int(49, ~#s_tolower_table~0.base, 49 + ~#s_tolower_table~0.offset, 1);call write~init~int(50, ~#s_tolower_table~0.base, 50 + ~#s_tolower_table~0.offset, 1);call write~init~int(51, ~#s_tolower_table~0.base, 51 + ~#s_tolower_table~0.offset, 1);call write~init~int(52, ~#s_tolower_table~0.base, 52 + ~#s_tolower_table~0.offset, 1);call write~init~int(53, ~#s_tolower_table~0.base, 53 + ~#s_tolower_table~0.offset, 1);call write~init~int(54, ~#s_tolower_table~0.base, 54 + ~#s_tolower_table~0.offset, 1);call write~init~int(55, ~#s_tolower_table~0.base, 55 + ~#s_tolower_table~0.offset, 1);call write~init~int(56, ~#s_tolower_table~0.base, 56 + ~#s_tolower_table~0.offset, 1);call write~init~int(57, ~#s_tolower_table~0.base, 57 + ~#s_tolower_table~0.offset, 1);call write~init~int(58, ~#s_tolower_table~0.base, 58 + ~#s_tolower_table~0.offset, 1);call write~init~int(59, ~#s_tolower_table~0.base, 59 + ~#s_tolower_table~0.offset, 1);call write~init~int(60, ~#s_tolower_table~0.base, 60 + ~#s_tolower_table~0.offset, 1);call write~init~int(61, ~#s_tolower_table~0.base, 61 + ~#s_tolower_table~0.offset, 1);call write~init~int(62, ~#s_tolower_table~0.base, 62 + ~#s_tolower_table~0.offset, 1);call write~init~int(63, ~#s_tolower_table~0.base, 63 + ~#s_tolower_table~0.offset, 1);call write~init~int(64, ~#s_tolower_table~0.base, 64 + ~#s_tolower_table~0.offset, 1);call write~init~int(97, ~#s_tolower_table~0.base, 65 + ~#s_tolower_table~0.offset, 1);call write~init~int(98, ~#s_tolower_table~0.base, 66 + ~#s_tolower_table~0.offset, 1);call write~init~int(99, ~#s_tolower_table~0.base, 67 + ~#s_tolower_table~0.offset, 1);call write~init~int(100, ~#s_tolower_table~0.base, 68 + ~#s_tolower_table~0.offset, 1);call write~init~int(101, ~#s_tolower_table~0.base, 69 + ~#s_tolower_table~0.offset, 1);call write~init~int(102, ~#s_tolower_table~0.base, 70 + ~#s_tolower_table~0.offset, 1);call write~init~int(103, ~#s_tolower_table~0.base, 71 + ~#s_tolower_table~0.offset, 1);call write~init~int(104, ~#s_tolower_table~0.base, 72 + ~#s_tolower_table~0.offset, 1);call write~init~int(105, ~#s_tolower_table~0.base, 73 + ~#s_tolower_table~0.offset, 1);call write~init~int(106, ~#s_tolower_table~0.base, 74 + ~#s_tolower_table~0.offset, 1);call write~init~int(107, ~#s_tolower_table~0.base, 75 + ~#s_tolower_table~0.offset, 1);call write~init~int(108, ~#s_tolower_table~0.base, 76 + ~#s_tolower_table~0.offset, 1);call write~init~int(109, ~#s_tolower_table~0.base, 77 + ~#s_tolower_table~0.offset, 1);call write~init~int(110, ~#s_tolower_table~0.base, 78 + ~#s_tolower_table~0.offset, 1);call write~init~int(111, ~#s_tolower_table~0.base, 79 + ~#s_tolower_table~0.offset, 1);call write~init~int(112, ~#s_tolower_table~0.base, 80 + ~#s_tolower_table~0.offset, 1);call write~init~int(113, ~#s_tolower_table~0.base, 81 + ~#s_tolower_table~0.offset, 1);call write~init~int(114, ~#s_tolower_table~0.base, 82 + ~#s_tolower_table~0.offset, 1);call write~init~int(115, ~#s_tolower_table~0.base, 83 + ~#s_tolower_table~0.offset, 1);call write~init~int(116, ~#s_tolower_table~0.base, 84 + ~#s_tolower_table~0.offset, 1);call write~init~int(117, ~#s_tolower_table~0.base, 85 + ~#s_tolower_table~0.offset, 1);call write~init~int(118, ~#s_tolower_table~0.base, 86 + ~#s_tolower_table~0.offset, 1);call write~init~int(119, ~#s_tolower_table~0.base, 87 + ~#s_tolower_table~0.offset, 1);call write~init~int(120, ~#s_tolower_table~0.base, 88 + ~#s_tolower_table~0.offset, 1);call write~init~int(121, ~#s_tolower_table~0.base, 89 + ~#s_tolower_table~0.offset, 1);call write~init~int(122, ~#s_tolower_table~0.base, 90 + ~#s_tolower_table~0.offset, 1);call write~init~int(91, ~#s_tolower_table~0.base, 91 + ~#s_tolower_table~0.offset, 1);call write~init~int(92, ~#s_tolower_table~0.base, 92 + ~#s_tolower_table~0.offset, 1);call write~init~int(93, ~#s_tolower_table~0.base, 93 + ~#s_tolower_table~0.offset, 1);call write~init~int(94, ~#s_tolower_table~0.base, 94 + ~#s_tolower_table~0.offset, 1);call write~init~int(95, ~#s_tolower_table~0.base, 95 + ~#s_tolower_table~0.offset, 1);call write~init~int(96, ~#s_tolower_table~0.base, 96 + ~#s_tolower_table~0.offset, 1);call write~init~int(97, ~#s_tolower_table~0.base, 97 + ~#s_tolower_table~0.offset, 1);call write~init~int(98, ~#s_tolower_table~0.base, 98 + ~#s_tolower_table~0.offset, 1);call write~init~int(99, ~#s_tolower_table~0.base, 99 + ~#s_tolower_table~0.offset, 1);call write~init~int(100, ~#s_tolower_table~0.base, 100 + ~#s_tolower_table~0.offset, 1);call write~init~int(101, ~#s_tolower_table~0.base, 101 + ~#s_tolower_table~0.offset, 1);call write~init~int(102, ~#s_tolower_table~0.base, 102 + ~#s_tolower_table~0.offset, 1);call write~init~int(103, ~#s_tolower_table~0.base, 103 + ~#s_tolower_table~0.offset, 1);call write~init~int(104, ~#s_tolower_table~0.base, 104 + ~#s_tolower_table~0.offset, 1);call write~init~int(105, ~#s_tolower_table~0.base, 105 + ~#s_tolower_table~0.offset, 1);call write~init~int(106, ~#s_tolower_table~0.base, 106 + ~#s_tolower_table~0.offset, 1);call write~init~int(107, ~#s_tolower_table~0.base, 107 + ~#s_tolower_table~0.offset, 1);call write~init~int(108, ~#s_tolower_table~0.base, 108 + ~#s_tolower_table~0.offset, 1);call write~init~int(109, ~#s_tolower_table~0.base, 109 + ~#s_tolower_table~0.offset, 1);call write~init~int(110, ~#s_tolower_table~0.base, 110 + ~#s_tolower_table~0.offset, 1);call write~init~int(111, ~#s_tolower_table~0.base, 111 + ~#s_tolower_table~0.offset, 1);call write~init~int(112, ~#s_tolower_table~0.base, 112 + ~#s_tolower_table~0.offset, 1);call write~init~int(113, ~#s_tolower_table~0.base, 113 + ~#s_tolower_table~0.offset, 1);call write~init~int(114, ~#s_tolower_table~0.base, 114 + ~#s_tolower_table~0.offset, 1);call write~init~int(115, ~#s_tolower_table~0.base, 115 + ~#s_tolower_table~0.offset, 1);call write~init~int(116, ~#s_tolower_table~0.base, 116 + ~#s_tolower_table~0.offset, 1);call write~init~int(117, ~#s_tolower_table~0.base, 117 + ~#s_tolower_table~0.offset, 1);call write~init~int(118, ~#s_tolower_table~0.base, 118 + ~#s_tolower_table~0.offset, 1);call write~init~int(119, ~#s_tolower_table~0.base, 119 + ~#s_tolower_table~0.offset, 1);call write~init~int(120, ~#s_tolower_table~0.base, 120 + ~#s_tolower_table~0.offset, 1);call write~init~int(121, ~#s_tolower_table~0.base, 121 + ~#s_tolower_table~0.offset, 1);call write~init~int(122, ~#s_tolower_table~0.base, 122 + ~#s_tolower_table~0.offset, 1);call write~init~int(123, ~#s_tolower_table~0.base, 123 + ~#s_tolower_table~0.offset, 1);call write~init~int(124, ~#s_tolower_table~0.base, 124 + ~#s_tolower_table~0.offset, 1);call write~init~int(125, ~#s_tolower_table~0.base, 125 + ~#s_tolower_table~0.offset, 1);call write~init~int(126, ~#s_tolower_table~0.base, 126 + ~#s_tolower_table~0.offset, 1);call write~init~int(127, ~#s_tolower_table~0.base, 127 + ~#s_tolower_table~0.offset, 1);call write~init~int(128, ~#s_tolower_table~0.base, 128 + ~#s_tolower_table~0.offset, 1);call write~init~int(129, ~#s_tolower_table~0.base, 129 + ~#s_tolower_table~0.offset, 1);call write~init~int(130, ~#s_tolower_table~0.base, 130 + ~#s_tolower_table~0.offset, 1);call write~init~int(131, ~#s_tolower_table~0.base, 131 + ~#s_tolower_table~0.offset, 1);call write~init~int(132, ~#s_tolower_table~0.base, 132 + ~#s_tolower_table~0.offset, 1);call write~init~int(133, ~#s_tolower_table~0.base, 133 + ~#s_tolower_table~0.offset, 1);call write~init~int(134, ~#s_tolower_table~0.base, 134 + ~#s_tolower_table~0.offset, 1);call write~init~int(135, ~#s_tolower_table~0.base, 135 + ~#s_tolower_table~0.offset, 1);call write~init~int(136, ~#s_tolower_table~0.base, 136 + ~#s_tolower_table~0.offset, 1);call write~init~int(137, ~#s_tolower_table~0.base, 137 + ~#s_tolower_table~0.offset, 1);call write~init~int(138, ~#s_tolower_table~0.base, 138 + ~#s_tolower_table~0.offset, 1);call write~init~int(139, ~#s_tolower_table~0.base, 139 + ~#s_tolower_table~0.offset, 1);call write~init~int(140, ~#s_tolower_table~0.base, 140 + ~#s_tolower_table~0.offset, 1);call write~init~int(141, ~#s_tolower_table~0.base, 141 + ~#s_tolower_table~0.offset, 1);call write~init~int(142, ~#s_tolower_table~0.base, 142 + ~#s_tolower_table~0.offset, 1);call write~init~int(143, ~#s_tolower_table~0.base, 143 + ~#s_tolower_table~0.offset, 1);call write~init~int(144, ~#s_tolower_table~0.base, 144 + ~#s_tolower_table~0.offset, 1);call write~init~int(145, ~#s_tolower_table~0.base, 145 + ~#s_tolower_table~0.offset, 1);call write~init~int(146, ~#s_tolower_table~0.base, 146 + ~#s_tolower_table~0.offset, 1);call write~init~int(147, ~#s_tolower_table~0.base, 147 + ~#s_tolower_table~0.offset, 1);call write~init~int(148, ~#s_tolower_table~0.base, 148 + ~#s_tolower_table~0.offset, 1);call write~init~int(149, ~#s_tolower_table~0.base, 149 + ~#s_tolower_table~0.offset, 1);call write~init~int(150, ~#s_tolower_table~0.base, 150 + ~#s_tolower_table~0.offset, 1);call write~init~int(151, ~#s_tolower_table~0.base, 151 + ~#s_tolower_table~0.offset, 1);call write~init~int(152, ~#s_tolower_table~0.base, 152 + ~#s_tolower_table~0.offset, 1);call write~init~int(153, ~#s_tolower_table~0.base, 153 + ~#s_tolower_table~0.offset, 1);call write~init~int(154, ~#s_tolower_table~0.base, 154 + ~#s_tolower_table~0.offset, 1);call write~init~int(155, ~#s_tolower_table~0.base, 155 + ~#s_tolower_table~0.offset, 1);call write~init~int(156, ~#s_tolower_table~0.base, 156 + ~#s_tolower_table~0.offset, 1);call write~init~int(157, ~#s_tolower_table~0.base, 157 + ~#s_tolower_table~0.offset, 1);call write~init~int(158, ~#s_tolower_table~0.base, 158 + ~#s_tolower_table~0.offset, 1);call write~init~int(159, ~#s_tolower_table~0.base, 159 + ~#s_tolower_table~0.offset, 1);call write~init~int(160, ~#s_tolower_table~0.base, 160 + ~#s_tolower_table~0.offset, 1);call write~init~int(161, ~#s_tolower_table~0.base, 161 + ~#s_tolower_table~0.offset, 1);call write~init~int(162, ~#s_tolower_table~0.base, 162 + ~#s_tolower_table~0.offset, 1);call write~init~int(163, ~#s_tolower_table~0.base, 163 + ~#s_tolower_table~0.offset, 1);call write~init~int(164, ~#s_tolower_table~0.base, 164 + ~#s_tolower_table~0.offset, 1);call write~init~int(165, ~#s_tolower_table~0.base, 165 + ~#s_tolower_table~0.offset, 1);call write~init~int(166, ~#s_tolower_table~0.base, 166 + ~#s_tolower_table~0.offset, 1);call write~init~int(167, ~#s_tolower_table~0.base, 167 + ~#s_tolower_table~0.offset, 1);call write~init~int(168, ~#s_tolower_table~0.base, 168 + ~#s_tolower_table~0.offset, 1);call write~init~int(169, ~#s_tolower_table~0.base, 169 + ~#s_tolower_table~0.offset, 1);call write~init~int(170, ~#s_tolower_table~0.base, 170 + ~#s_tolower_table~0.offset, 1);call write~init~int(171, ~#s_tolower_table~0.base, 171 + ~#s_tolower_table~0.offset, 1);call write~init~int(172, ~#s_tolower_table~0.base, 172 + ~#s_tolower_table~0.offset, 1);call write~init~int(173, ~#s_tolower_table~0.base, 173 + ~#s_tolower_table~0.offset, 1);call write~init~int(174, ~#s_tolower_table~0.base, 174 + ~#s_tolower_table~0.offset, 1);call write~init~int(175, ~#s_tolower_table~0.base, 175 + ~#s_tolower_table~0.offset, 1);call write~init~int(176, ~#s_tolower_table~0.base, 176 + ~#s_tolower_table~0.offset, 1);call write~init~int(177, ~#s_tolower_table~0.base, 177 + ~#s_tolower_table~0.offset, 1);call write~init~int(178, ~#s_tolower_table~0.base, 178 + ~#s_tolower_table~0.offset, 1);call write~init~int(179, ~#s_tolower_table~0.base, 179 + ~#s_tolower_table~0.offset, 1);call write~init~int(180, ~#s_tolower_table~0.base, 180 + ~#s_tolower_table~0.offset, 1);call write~init~int(181, ~#s_tolower_table~0.base, 181 + ~#s_tolower_table~0.offset, 1);call write~init~int(182, ~#s_tolower_table~0.base, 182 + ~#s_tolower_table~0.offset, 1);call write~init~int(183, ~#s_tolower_table~0.base, 183 + ~#s_tolower_table~0.offset, 1);call write~init~int(184, ~#s_tolower_table~0.base, 184 + ~#s_tolower_table~0.offset, 1);call write~init~int(185, ~#s_tolower_table~0.base, 185 + ~#s_tolower_table~0.offset, 1);call write~init~int(186, ~#s_tolower_table~0.base, 186 + ~#s_tolower_table~0.offset, 1);call write~init~int(187, ~#s_tolower_table~0.base, 187 + ~#s_tolower_table~0.offset, 1);call write~init~int(188, ~#s_tolower_table~0.base, 188 + ~#s_tolower_table~0.offset, 1);call write~init~int(189, ~#s_tolower_table~0.base, 189 + ~#s_tolower_table~0.offset, 1);call write~init~int(190, ~#s_tolower_table~0.base, 190 + ~#s_tolower_table~0.offset, 1);call write~init~int(191, ~#s_tolower_table~0.base, 191 + ~#s_tolower_table~0.offset, 1);call write~init~int(192, ~#s_tolower_table~0.base, 192 + ~#s_tolower_table~0.offset, 1);call write~init~int(193, ~#s_tolower_table~0.base, 193 + ~#s_tolower_table~0.offset, 1);call write~init~int(194, ~#s_tolower_table~0.base, 194 + ~#s_tolower_table~0.offset, 1);call write~init~int(195, ~#s_tolower_table~0.base, 195 + ~#s_tolower_table~0.offset, 1);call write~init~int(196, ~#s_tolower_table~0.base, 196 + ~#s_tolower_table~0.offset, 1);call write~init~int(197, ~#s_tolower_table~0.base, 197 + ~#s_tolower_table~0.offset, 1);call write~init~int(198, ~#s_tolower_table~0.base, 198 + ~#s_tolower_table~0.offset, 1);call write~init~int(199, ~#s_tolower_table~0.base, 199 + ~#s_tolower_table~0.offset, 1);call write~init~int(200, ~#s_tolower_table~0.base, 200 + ~#s_tolower_table~0.offset, 1);call write~init~int(201, ~#s_tolower_table~0.base, 201 + ~#s_tolower_table~0.offset, 1);call write~init~int(202, ~#s_tolower_table~0.base, 202 + ~#s_tolower_table~0.offset, 1);call write~init~int(203, ~#s_tolower_table~0.base, 203 + ~#s_tolower_table~0.offset, 1);call write~init~int(204, ~#s_tolower_table~0.base, 204 + ~#s_tolower_table~0.offset, 1);call write~init~int(205, ~#s_tolower_table~0.base, 205 + ~#s_tolower_table~0.offset, 1);call write~init~int(206, ~#s_tolower_table~0.base, 206 + ~#s_tolower_table~0.offset, 1);call write~init~int(207, ~#s_tolower_table~0.base, 207 + ~#s_tolower_table~0.offset, 1);call write~init~int(208, ~#s_tolower_table~0.base, 208 + ~#s_tolower_table~0.offset, 1);call write~init~int(209, ~#s_tolower_table~0.base, 209 + ~#s_tolower_table~0.offset, 1);call write~init~int(210, ~#s_tolower_table~0.base, 210 + ~#s_tolower_table~0.offset, 1);call write~init~int(211, ~#s_tolower_table~0.base, 211 + ~#s_tolower_table~0.offset, 1);call write~init~int(212, ~#s_tolower_table~0.base, 212 + ~#s_tolower_table~0.offset, 1);call write~init~int(213, ~#s_tolower_table~0.base, 213 + ~#s_tolower_table~0.offset, 1);call write~init~int(214, ~#s_tolower_table~0.base, 214 + ~#s_tolower_table~0.offset, 1);call write~init~int(215, ~#s_tolower_table~0.base, 215 + ~#s_tolower_table~0.offset, 1);call write~init~int(216, ~#s_tolower_table~0.base, 216 + ~#s_tolower_table~0.offset, 1);call write~init~int(217, ~#s_tolower_table~0.base, 217 + ~#s_tolower_table~0.offset, 1);call write~init~int(218, ~#s_tolower_table~0.base, 218 + ~#s_tolower_table~0.offset, 1);call write~init~int(219, ~#s_tolower_table~0.base, 219 + ~#s_tolower_table~0.offset, 1);call write~init~int(220, ~#s_tolower_table~0.base, 220 + ~#s_tolower_table~0.offset, 1);call write~init~int(221, ~#s_tolower_table~0.base, 221 + ~#s_tolower_table~0.offset, 1);call write~init~int(222, ~#s_tolower_table~0.base, 222 + ~#s_tolower_table~0.offset, 1);call write~init~int(223, ~#s_tolower_table~0.base, 223 + ~#s_tolower_table~0.offset, 1);call write~init~int(224, ~#s_tolower_table~0.base, 224 + ~#s_tolower_table~0.offset, 1);call write~init~int(225, ~#s_tolower_table~0.base, 225 + ~#s_tolower_table~0.offset, 1);call write~init~int(226, ~#s_tolower_table~0.base, 226 + ~#s_tolower_table~0.offset, 1);call write~init~int(227, ~#s_tolower_table~0.base, 227 + ~#s_tolower_table~0.offset, 1);call write~init~int(228, ~#s_tolower_table~0.base, 228 + ~#s_tolower_table~0.offset, 1);call write~init~int(229, ~#s_tolower_table~0.base, 229 + ~#s_tolower_table~0.offset, 1);call write~init~int(230, ~#s_tolower_table~0.base, 230 + ~#s_tolower_table~0.offset, 1);call write~init~int(231, ~#s_tolower_table~0.base, 231 + ~#s_tolower_table~0.offset, 1);call write~init~int(232, ~#s_tolower_table~0.base, 232 + ~#s_tolower_table~0.offset, 1);call write~init~int(233, ~#s_tolower_table~0.base, 233 + ~#s_tolower_table~0.offset, 1);call write~init~int(234, ~#s_tolower_table~0.base, 234 + ~#s_tolower_table~0.offset, 1);call write~init~int(235, ~#s_tolower_table~0.base, 235 + ~#s_tolower_table~0.offset, 1);call write~init~int(236, ~#s_tolower_table~0.base, 236 + ~#s_tolower_table~0.offset, 1);call write~init~int(237, ~#s_tolower_table~0.base, 237 + ~#s_tolower_table~0.offset, 1);call write~init~int(238, ~#s_tolower_table~0.base, 238 + ~#s_tolower_table~0.offset, 1);call write~init~int(239, ~#s_tolower_table~0.base, 239 + ~#s_tolower_table~0.offset, 1);call write~init~int(240, ~#s_tolower_table~0.base, 240 + ~#s_tolower_table~0.offset, 1);call write~init~int(241, ~#s_tolower_table~0.base, 241 + ~#s_tolower_table~0.offset, 1);call write~init~int(242, ~#s_tolower_table~0.base, 242 + ~#s_tolower_table~0.offset, 1);call write~init~int(243, ~#s_tolower_table~0.base, 243 + ~#s_tolower_table~0.offset, 1);call write~init~int(244, ~#s_tolower_table~0.base, 244 + ~#s_tolower_table~0.offset, 1);call write~init~int(245, ~#s_tolower_table~0.base, 245 + ~#s_tolower_table~0.offset, 1);call write~init~int(246, ~#s_tolower_table~0.base, 246 + ~#s_tolower_table~0.offset, 1);call write~init~int(247, ~#s_tolower_table~0.base, 247 + ~#s_tolower_table~0.offset, 1);call write~init~int(248, ~#s_tolower_table~0.base, 248 + ~#s_tolower_table~0.offset, 1);call write~init~int(249, ~#s_tolower_table~0.base, 249 + ~#s_tolower_table~0.offset, 1);call write~init~int(250, ~#s_tolower_table~0.base, 250 + ~#s_tolower_table~0.offset, 1);call write~init~int(251, ~#s_tolower_table~0.base, 251 + ~#s_tolower_table~0.offset, 1);call write~init~int(252, ~#s_tolower_table~0.base, 252 + ~#s_tolower_table~0.offset, 1);call write~init~int(253, ~#s_tolower_table~0.base, 253 + ~#s_tolower_table~0.offset, 1);call write~init~int(254, ~#s_tolower_table~0.base, 254 + ~#s_tolower_table~0.offset, 1);call write~init~int(255, ~#s_tolower_table~0.base, 255 + ~#s_tolower_table~0.offset, 1); {1999#true} is VALID [2022-02-20 21:08:16,078 INFO L290 TraceCheckUtils]: 1: Hoare triple {1999#true} assume { :end_inline_ULTIMATE.init } true;assume { :begin_inline_main } true;havoc main_#res#1;assume { :begin_inline_aws_hash_callback_string_eq_harness } true;havoc aws_hash_callback_string_eq_harness_#t~ret1963#1.base, aws_hash_callback_string_eq_harness_#t~ret1963#1.offset, aws_hash_callback_string_eq_harness_#t~ret1964#1, aws_hash_callback_string_eq_harness_#t~ite1966#1.base, aws_hash_callback_string_eq_harness_#t~ite1966#1.offset, aws_hash_callback_string_eq_harness_#t~ret1965#1.base, aws_hash_callback_string_eq_harness_#t~ret1965#1.offset, aws_hash_callback_string_eq_harness_#t~ret1967#1, aws_hash_callback_string_eq_harness_#t~mem1968#1, aws_hash_callback_string_eq_harness_#t~mem1969#1, aws_hash_callback_string_eq_harness_#t~mem1970#1, aws_hash_callback_string_eq_harness_~str1~0#1.base, aws_hash_callback_string_eq_harness_~str1~0#1.offset, aws_hash_callback_string_eq_harness_~str2~0#1.base, aws_hash_callback_string_eq_harness_~str2~0#1.offset, aws_hash_callback_string_eq_harness_~rval~21#1; {1999#true} is VALID [2022-02-20 21:08:16,079 INFO L272 TraceCheckUtils]: 2: Hoare triple {1999#true} call aws_hash_callback_string_eq_harness_#t~ret1963#1.base, aws_hash_callback_string_eq_harness_#t~ret1963#1.offset := ensure_string_is_allocated_bounded_length(96); {2080#(and (= |old(#length)| |#length|) (= |old(#memory_real)| |#memory_real|) (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:08:16,079 INFO L290 TraceCheckUtils]: 3: Hoare triple {2080#(and (= |old(#length)| |#length|) (= |old(#memory_real)| |#memory_real|) (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|) (= |old(#valid)| |#valid|))} ~max_size#1 := #in~max_size#1; {2081#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} is VALID [2022-02-20 21:08:16,080 INFO L272 TraceCheckUtils]: 4: Hoare triple {2081#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} call #t~ret540#1 := nondet_uint64_t(); {1999#true} is VALID [2022-02-20 21:08:16,080 INFO L290 TraceCheckUtils]: 5: Hoare triple {1999#true} #res := #t~nondet13;havoc #t~nondet13; {1999#true} is VALID [2022-02-20 21:08:16,080 INFO L290 TraceCheckUtils]: 6: Hoare triple {1999#true} assume true; {1999#true} is VALID [2022-02-20 21:08:16,080 INFO L284 TraceCheckUtils]: 7: Hoare quadruple {1999#true} {2081#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} #182#return; {2081#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} is VALID [2022-02-20 21:08:16,081 INFO L290 TraceCheckUtils]: 8: Hoare triple {2081#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} ~len~1#1 := #t~ret540#1;havoc #t~ret540#1; {2081#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} is VALID [2022-02-20 21:08:16,081 INFO L272 TraceCheckUtils]: 9: Hoare triple {2081#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} call assume_abort_if_not((if 0 == (if ~len~1#1 % 18446744073709551616 < ~max_size#1 % 18446744073709551616 then 1 else 0) then 0 else 1)); {1999#true} is VALID [2022-02-20 21:08:16,081 INFO L290 TraceCheckUtils]: 10: Hoare triple {1999#true} ~cond := #in~cond; {2104#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} is VALID [2022-02-20 21:08:16,082 INFO L290 TraceCheckUtils]: 11: Hoare triple {2104#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} assume !(0 == ~cond % 256); {2105#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} is VALID [2022-02-20 21:08:16,083 INFO L290 TraceCheckUtils]: 12: Hoare triple {2105#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} assume true; {2105#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} is VALID [2022-02-20 21:08:16,084 INFO L284 TraceCheckUtils]: 13: Hoare quadruple {2105#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} {2081#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} #184#return; {2089#(or (not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96)) (<= (* 18446744073709551616 (div |ensure_string_is_allocated_bounded_length_~len~1#1| 18446744073709551616)) (+ |ensure_string_is_allocated_bounded_length_~len~1#1| (* 18446744073709551616 (div (+ (* 18446744073709551616 (div |ensure_string_is_allocated_bounded_length_~len~1#1| 18446744073709551616)) 95 (* (- 1) |ensure_string_is_allocated_bounded_length_~len~1#1|)) 18446744073709551616)))))} is VALID [2022-02-20 21:08:16,085 INFO L290 TraceCheckUtils]: 14: Hoare triple {2089#(or (not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96)) (<= (* 18446744073709551616 (div |ensure_string_is_allocated_bounded_length_~len~1#1| 18446744073709551616)) (+ |ensure_string_is_allocated_bounded_length_~len~1#1| (* 18446744073709551616 (div (+ (* 18446744073709551616 (div |ensure_string_is_allocated_bounded_length_~len~1#1| 18446744073709551616)) 95 (* (- 1) |ensure_string_is_allocated_bounded_length_~len~1#1|)) 18446744073709551616)))))} assume { :begin_inline_ensure_string_is_allocated } true;ensure_string_is_allocated_#in~len#1 := ~len~1#1;havoc ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset;havoc ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset, ensure_string_is_allocated_#t~ret543#1, ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset, ensure_string_is_allocated_#t~ret544#1.base, ensure_string_is_allocated_#t~ret544#1.offset, ensure_string_is_allocated_~len#1, ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset;ensure_string_is_allocated_~len#1 := ensure_string_is_allocated_#in~len#1; {2090#(or (not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96)) (<= 0 (+ (* 18446744073709551616 (div (+ (* (- 1) |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~len#1|) 95) 18446744073709551616)) |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~len#1|)))} is VALID [2022-02-20 21:08:16,086 INFO L272 TraceCheckUtils]: 15: Hoare triple {2090#(or (not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96)) (<= 0 (+ (* 18446744073709551616 (div (+ (* (- 1) |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~len#1|) 95) 18446744073709551616)) |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~len#1|)))} call ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset := bounded_malloc(-1234550 + ensure_string_is_allocated_~len#1); {2106#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:08:16,087 INFO L290 TraceCheckUtils]: 16: Hoare triple {2106#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size; {2107#(= |bounded_malloc_#in~size| bounded_malloc_~size)} is VALID [2022-02-20 21:08:16,087 INFO L272 TraceCheckUtils]: 17: Hoare triple {2107#(= |bounded_malloc_#in~size| bounded_malloc_~size)} call assume_abort_if_not((if 0 == (if ~size % 18446744073709551616 <= 36028797018963967 then 1 else 0) then 0 else 1)); {1999#true} is VALID [2022-02-20 21:08:16,087 INFO L290 TraceCheckUtils]: 18: Hoare triple {1999#true} ~cond := #in~cond; {2104#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} is VALID [2022-02-20 21:08:16,088 INFO L290 TraceCheckUtils]: 19: Hoare triple {2104#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} assume !(0 == ~cond % 256); {2105#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} is VALID [2022-02-20 21:08:16,088 INFO L290 TraceCheckUtils]: 20: Hoare triple {2105#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} assume true; {2105#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} is VALID [2022-02-20 21:08:16,089 INFO L284 TraceCheckUtils]: 21: Hoare quadruple {2105#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} {2107#(= |bounded_malloc_#in~size| bounded_malloc_~size)} #192#return; {2112#(and (= |bounded_malloc_#in~size| bounded_malloc_~size) (<= bounded_malloc_~size (+ (* (div bounded_malloc_~size 18446744073709551616) 18446744073709551616) 36028797018963967)))} is VALID [2022-02-20 21:08:16,090 INFO L290 TraceCheckUtils]: 22: Hoare triple {2112#(and (= |bounded_malloc_#in~size| bounded_malloc_~size) (<= bounded_malloc_~size (+ (* (div bounded_malloc_~size 18446744073709551616) 18446744073709551616) 36028797018963967)))} call #t~malloc555.base, #t~malloc555.offset := #Ultimate.allocOnHeap(~size);#res.base, #res.offset := #t~malloc555.base, #t~malloc555.offset;havoc #t~malloc555.base, #t~malloc555.offset; {2113#(<= |bounded_malloc_#in~size| (+ 36028797018963967 (* 18446744073709551616 (div |bounded_malloc_#in~size| 18446744073709551616))))} is VALID [2022-02-20 21:08:16,090 INFO L290 TraceCheckUtils]: 23: Hoare triple {2113#(<= |bounded_malloc_#in~size| (+ 36028797018963967 (* 18446744073709551616 (div |bounded_malloc_#in~size| 18446744073709551616))))} assume true; {2113#(<= |bounded_malloc_#in~size| (+ 36028797018963967 (* 18446744073709551616 (div |bounded_malloc_#in~size| 18446744073709551616))))} is VALID [2022-02-20 21:08:16,092 INFO L284 TraceCheckUtils]: 24: Hoare quadruple {2113#(<= |bounded_malloc_#in~size| (+ 36028797018963967 (* 18446744073709551616 (div |bounded_malloc_#in~size| 18446744073709551616))))} {2090#(or (not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96)) (<= 0 (+ (* 18446744073709551616 (div (+ (* (- 1) |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~len#1|) 95) 18446744073709551616)) |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~len#1|)))} #186#return; {2100#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} is VALID [2022-02-20 21:08:16,092 INFO L290 TraceCheckUtils]: 25: Hoare triple {2100#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset := ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset;havoc ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset; {2100#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} is VALID [2022-02-20 21:08:16,092 INFO L272 TraceCheckUtils]: 26: Hoare triple {2100#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} call ensure_string_is_allocated_#t~ret543#1 := nondet_bool(); {1999#true} is VALID [2022-02-20 21:08:16,093 INFO L290 TraceCheckUtils]: 27: Hoare triple {1999#true} #res := #t~nondet8;havoc #t~nondet8; {1999#true} is VALID [2022-02-20 21:08:16,093 INFO L290 TraceCheckUtils]: 28: Hoare triple {1999#true} assume true; {1999#true} is VALID [2022-02-20 21:08:16,093 INFO L284 TraceCheckUtils]: 29: Hoare quadruple {1999#true} {2100#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} #188#return; {2100#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} is VALID [2022-02-20 21:08:16,094 INFO L290 TraceCheckUtils]: 30: Hoare triple {2100#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} assume !(0 != ensure_string_is_allocated_#t~ret543#1 % 256);ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset := 0, 0; {2100#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} is VALID [2022-02-20 21:08:16,094 INFO L290 TraceCheckUtils]: 31: Hoare triple {2100#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} call write~$Pointer$(ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset, ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset, 8);havoc ensure_string_is_allocated_#t~ret543#1;havoc ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset;havoc ensure_string_is_allocated_#t~ret544#1.base, ensure_string_is_allocated_#t~ret544#1.offset;call write~int(ensure_string_is_allocated_~len#1, ensure_string_is_allocated_~str~0#1.base, 8 + ensure_string_is_allocated_~str~0#1.offset, 8);call write~int(0, ensure_string_is_allocated_~str~0#1.base, 16 + ensure_string_is_allocated_~str~0#1.offset + (if ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 else ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset := ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset; {2100#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} is VALID [2022-02-20 21:08:16,094 INFO L290 TraceCheckUtils]: 32: Hoare triple {2100#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} #t~ret541#1.base, #t~ret541#1.offset := ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset;assume { :end_inline_ensure_string_is_allocated } true;#res#1.base, #res#1.offset := #t~ret541#1.base, #t~ret541#1.offset;havoc #t~ret541#1.base, #t~ret541#1.offset; {2100#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} is VALID [2022-02-20 21:08:16,095 INFO L290 TraceCheckUtils]: 33: Hoare triple {2100#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} assume true; {2100#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} is VALID [2022-02-20 21:08:16,096 INFO L284 TraceCheckUtils]: 34: Hoare quadruple {2100#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} {1999#true} #198#return; {2033#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_#t~ret1963#1.base| 0))} is VALID [2022-02-20 21:08:16,096 INFO L290 TraceCheckUtils]: 35: Hoare triple {2033#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_#t~ret1963#1.base| 0))} aws_hash_callback_string_eq_harness_~str1~0#1.base, aws_hash_callback_string_eq_harness_~str1~0#1.offset := aws_hash_callback_string_eq_harness_#t~ret1963#1.base, aws_hash_callback_string_eq_harness_#t~ret1963#1.offset;havoc aws_hash_callback_string_eq_harness_#t~ret1963#1.base, aws_hash_callback_string_eq_harness_#t~ret1963#1.offset; {2034#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| 0))} is VALID [2022-02-20 21:08:16,096 INFO L272 TraceCheckUtils]: 36: Hoare triple {2034#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| 0))} call aws_hash_callback_string_eq_harness_#t~ret1964#1 := nondet_bool(); {1999#true} is VALID [2022-02-20 21:08:16,096 INFO L290 TraceCheckUtils]: 37: Hoare triple {1999#true} #res := #t~nondet8;havoc #t~nondet8; {1999#true} is VALID [2022-02-20 21:08:16,096 INFO L290 TraceCheckUtils]: 38: Hoare triple {1999#true} assume true; {1999#true} is VALID [2022-02-20 21:08:16,097 INFO L284 TraceCheckUtils]: 39: Hoare quadruple {1999#true} {2034#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| 0))} #200#return; {2034#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| 0))} is VALID [2022-02-20 21:08:16,097 INFO L290 TraceCheckUtils]: 40: Hoare triple {2034#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| 0))} assume 0 != aws_hash_callback_string_eq_harness_#t~ret1964#1 % 256;aws_hash_callback_string_eq_harness_#t~ite1966#1.base, aws_hash_callback_string_eq_harness_#t~ite1966#1.offset := aws_hash_callback_string_eq_harness_~str1~0#1.base, aws_hash_callback_string_eq_harness_~str1~0#1.offset; {2034#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| 0))} is VALID [2022-02-20 21:08:16,098 INFO L290 TraceCheckUtils]: 41: Hoare triple {2034#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| 0))} aws_hash_callback_string_eq_harness_~str2~0#1.base, aws_hash_callback_string_eq_harness_~str2~0#1.offset := aws_hash_callback_string_eq_harness_#t~ite1966#1.base, aws_hash_callback_string_eq_harness_#t~ite1966#1.offset;havoc aws_hash_callback_string_eq_harness_#t~ret1964#1;havoc aws_hash_callback_string_eq_harness_#t~ite1966#1.base, aws_hash_callback_string_eq_harness_#t~ite1966#1.offset;havoc aws_hash_callback_string_eq_harness_#t~ret1965#1.base, aws_hash_callback_string_eq_harness_#t~ret1965#1.offset;assume { :begin_inline_aws_hash_callback_string_eq } true;aws_hash_callback_string_eq_#in~a#1.base, aws_hash_callback_string_eq_#in~a#1.offset, aws_hash_callback_string_eq_#in~b#1.base, aws_hash_callback_string_eq_#in~b#1.offset := aws_hash_callback_string_eq_harness_~str1~0#1.base, aws_hash_callback_string_eq_harness_~str1~0#1.offset, aws_hash_callback_string_eq_harness_~str2~0#1.base, aws_hash_callback_string_eq_harness_~str2~0#1.offset;havoc aws_hash_callback_string_eq_#res#1;havoc aws_hash_callback_string_eq_#t~ret1811#1, aws_hash_callback_string_eq_#t~ret1812#1, aws_hash_callback_string_eq_#t~ret1813#1, aws_hash_callback_string_eq_#t~ret1814#1, aws_hash_callback_string_eq_#t~ret1815#1, aws_hash_callback_string_eq_#t~short1816#1, aws_hash_callback_string_eq_~a#1.base, aws_hash_callback_string_eq_~a#1.offset, aws_hash_callback_string_eq_~b#1.base, aws_hash_callback_string_eq_~b#1.offset, aws_hash_callback_string_eq_~rval~20#1;aws_hash_callback_string_eq_~a#1.base, aws_hash_callback_string_eq_~a#1.offset := aws_hash_callback_string_eq_#in~a#1.base, aws_hash_callback_string_eq_#in~a#1.offset;aws_hash_callback_string_eq_~b#1.base, aws_hash_callback_string_eq_~b#1.offset := aws_hash_callback_string_eq_#in~b#1.base, aws_hash_callback_string_eq_#in~b#1.offset; {2038#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} is VALID [2022-02-20 21:08:16,098 INFO L272 TraceCheckUtils]: 42: Hoare triple {2038#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} call aws_hash_callback_string_eq_#t~ret1811#1 := aws_string_is_valid(aws_hash_callback_string_eq_~a#1.base, aws_hash_callback_string_eq_~a#1.offset); {1999#true} is VALID [2022-02-20 21:08:16,098 INFO L290 TraceCheckUtils]: 43: Hoare triple {1999#true} ~str.base, ~str.offset := #in~str.base, #in~str.offset;#t~short464 := ~str.base != 0 || ~str.offset != 0; {1999#true} is VALID [2022-02-20 21:08:16,099 INFO L290 TraceCheckUtils]: 44: Hoare triple {1999#true} assume #t~short464;call #t~mem463 := read~int(~str.base, 8 + ~str.offset, 8);#t~short464 := 0 == (1 + #t~mem463) % 18446744073709551616 || ~str.base != 0 || 16 + ~str.offset != 0; {1999#true} is VALID [2022-02-20 21:08:16,099 INFO L290 TraceCheckUtils]: 45: Hoare triple {1999#true} #t~short467 := #t~short464; {1999#true} is VALID [2022-02-20 21:08:16,099 INFO L290 TraceCheckUtils]: 46: Hoare triple {1999#true} assume #t~short467;call #t~mem465 := read~int(~str.base, 8 + ~str.offset, 8);call #t~mem466 := read~int(~str.base, 16 + ~str.offset + (if #t~mem465 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then #t~mem465 % 18446744073709551616 % 18446744073709551616 else #t~mem465 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);#t~short467 := 0 == #t~mem466 % 256; {1999#true} is VALID [2022-02-20 21:08:16,099 INFO L290 TraceCheckUtils]: 47: Hoare triple {1999#true} #res := (if 0 == (if #t~short467 then 1 else 0) then 0 else 1);havoc #t~mem463;havoc #t~short464;havoc #t~mem465;havoc #t~mem466;havoc #t~short467; {1999#true} is VALID [2022-02-20 21:08:16,099 INFO L290 TraceCheckUtils]: 48: Hoare triple {1999#true} assume true; {1999#true} is VALID [2022-02-20 21:08:16,100 INFO L284 TraceCheckUtils]: 49: Hoare quadruple {1999#true} {2038#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} #204#return; {2038#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} is VALID [2022-02-20 21:08:16,100 INFO L272 TraceCheckUtils]: 50: Hoare triple {2038#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} call assume_abort_if_not(aws_hash_callback_string_eq_#t~ret1811#1); {1999#true} is VALID [2022-02-20 21:08:16,100 INFO L290 TraceCheckUtils]: 51: Hoare triple {1999#true} ~cond := #in~cond; {1999#true} is VALID [2022-02-20 21:08:16,100 INFO L290 TraceCheckUtils]: 52: Hoare triple {1999#true} assume !(0 == ~cond % 256); {1999#true} is VALID [2022-02-20 21:08:16,101 INFO L290 TraceCheckUtils]: 53: Hoare triple {1999#true} assume true; {1999#true} is VALID [2022-02-20 21:08:16,101 INFO L284 TraceCheckUtils]: 54: Hoare quadruple {1999#true} {2038#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} #206#return; {2038#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} is VALID [2022-02-20 21:08:16,101 INFO L290 TraceCheckUtils]: 55: Hoare triple {2038#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} havoc aws_hash_callback_string_eq_#t~ret1811#1; {2038#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} is VALID [2022-02-20 21:08:16,102 INFO L272 TraceCheckUtils]: 56: Hoare triple {2038#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} call aws_hash_callback_string_eq_#t~ret1812#1 := aws_string_is_valid(aws_hash_callback_string_eq_~b#1.base, aws_hash_callback_string_eq_~b#1.offset); {1999#true} is VALID [2022-02-20 21:08:16,102 INFO L290 TraceCheckUtils]: 57: Hoare triple {1999#true} ~str.base, ~str.offset := #in~str.base, #in~str.offset;#t~short464 := ~str.base != 0 || ~str.offset != 0; {1999#true} is VALID [2022-02-20 21:08:16,102 INFO L290 TraceCheckUtils]: 58: Hoare triple {1999#true} assume #t~short464;call #t~mem463 := read~int(~str.base, 8 + ~str.offset, 8);#t~short464 := 0 == (1 + #t~mem463) % 18446744073709551616 || ~str.base != 0 || 16 + ~str.offset != 0; {1999#true} is VALID [2022-02-20 21:08:16,102 INFO L290 TraceCheckUtils]: 59: Hoare triple {1999#true} #t~short467 := #t~short464; {1999#true} is VALID [2022-02-20 21:08:16,102 INFO L290 TraceCheckUtils]: 60: Hoare triple {1999#true} assume #t~short467;call #t~mem465 := read~int(~str.base, 8 + ~str.offset, 8);call #t~mem466 := read~int(~str.base, 16 + ~str.offset + (if #t~mem465 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then #t~mem465 % 18446744073709551616 % 18446744073709551616 else #t~mem465 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);#t~short467 := 0 == #t~mem466 % 256; {1999#true} is VALID [2022-02-20 21:08:16,102 INFO L290 TraceCheckUtils]: 61: Hoare triple {1999#true} #res := (if 0 == (if #t~short467 then 1 else 0) then 0 else 1);havoc #t~mem463;havoc #t~short464;havoc #t~mem465;havoc #t~mem466;havoc #t~short467; {1999#true} is VALID [2022-02-20 21:08:16,103 INFO L290 TraceCheckUtils]: 62: Hoare triple {1999#true} assume true; {1999#true} is VALID [2022-02-20 21:08:16,103 INFO L284 TraceCheckUtils]: 63: Hoare quadruple {1999#true} {2038#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} #208#return; {2038#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} is VALID [2022-02-20 21:08:16,104 INFO L272 TraceCheckUtils]: 64: Hoare triple {2038#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} call assume_abort_if_not(aws_hash_callback_string_eq_#t~ret1812#1); {1999#true} is VALID [2022-02-20 21:08:16,104 INFO L290 TraceCheckUtils]: 65: Hoare triple {1999#true} ~cond := #in~cond; {1999#true} is VALID [2022-02-20 21:08:16,104 INFO L290 TraceCheckUtils]: 66: Hoare triple {1999#true} assume !(0 == ~cond % 256); {1999#true} is VALID [2022-02-20 21:08:16,104 INFO L290 TraceCheckUtils]: 67: Hoare triple {1999#true} assume true; {1999#true} is VALID [2022-02-20 21:08:16,105 INFO L284 TraceCheckUtils]: 68: Hoare quadruple {1999#true} {2038#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} #210#return; {2038#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} is VALID [2022-02-20 21:08:16,105 INFO L290 TraceCheckUtils]: 69: Hoare triple {2038#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} havoc aws_hash_callback_string_eq_#t~ret1812#1;assume { :begin_inline_aws_string_eq } true;aws_string_eq_#in~a#1.base, aws_string_eq_#in~a#1.offset, aws_string_eq_#in~b#1.base, aws_string_eq_#in~b#1.offset := aws_hash_callback_string_eq_~a#1.base, aws_hash_callback_string_eq_~a#1.offset, aws_hash_callback_string_eq_~b#1.base, aws_hash_callback_string_eq_~b#1.offset;havoc aws_string_eq_#res#1;havoc aws_string_eq_#t~ret1893#1, aws_string_eq_#t~short1894#1, aws_string_eq_#t~ret1895#1, aws_string_eq_#t~short1896#1, aws_string_eq_#t~mem1897#1, aws_string_eq_#t~mem1898#1, aws_string_eq_#t~ret1899#1, aws_string_eq_~a#1.base, aws_string_eq_~a#1.offset, aws_string_eq_~b#1.base, aws_string_eq_~b#1.offset;aws_string_eq_~a#1.base, aws_string_eq_~a#1.offset := aws_string_eq_#in~a#1.base, aws_string_eq_#in~a#1.offset;aws_string_eq_~b#1.base, aws_string_eq_~b#1.offset := aws_string_eq_#in~b#1.base, aws_string_eq_#in~b#1.offset;aws_string_eq_#t~short1894#1 := aws_string_eq_~a#1.base == 0 && aws_string_eq_~a#1.offset == 0; {2061#(not |ULTIMATE.start_aws_string_eq_#t~short1894#1|)} is VALID [2022-02-20 21:08:16,106 INFO L290 TraceCheckUtils]: 70: Hoare triple {2061#(not |ULTIMATE.start_aws_string_eq_#t~short1894#1|)} assume aws_string_eq_#t~short1894#1; {2000#false} is VALID [2022-02-20 21:08:16,106 INFO L272 TraceCheckUtils]: 71: Hoare triple {2000#false} call assume_abort_if_not((if 0 == (if aws_string_eq_#t~short1894#1 then 1 else 0) then 0 else 1)); {1999#true} is VALID [2022-02-20 21:08:16,106 INFO L290 TraceCheckUtils]: 72: Hoare triple {1999#true} ~cond := #in~cond; {1999#true} is VALID [2022-02-20 21:08:16,106 INFO L290 TraceCheckUtils]: 73: Hoare triple {1999#true} assume !(0 == ~cond % 256); {1999#true} is VALID [2022-02-20 21:08:16,106 INFO L290 TraceCheckUtils]: 74: Hoare triple {1999#true} assume true; {1999#true} is VALID [2022-02-20 21:08:16,106 INFO L284 TraceCheckUtils]: 75: Hoare quadruple {1999#true} {2000#false} #214#return; {2000#false} is VALID [2022-02-20 21:08:16,107 INFO L290 TraceCheckUtils]: 76: Hoare triple {2000#false} havoc aws_string_eq_#t~ret1893#1;havoc aws_string_eq_#t~short1894#1;aws_string_eq_#t~short1896#1 := aws_string_eq_~b#1.base == 0 && aws_string_eq_~b#1.offset == 0; {2000#false} is VALID [2022-02-20 21:08:16,107 INFO L290 TraceCheckUtils]: 77: Hoare triple {2000#false} assume !aws_string_eq_#t~short1896#1; {2000#false} is VALID [2022-02-20 21:08:16,107 INFO L272 TraceCheckUtils]: 78: Hoare triple {2000#false} call aws_string_eq_#t~ret1895#1 := aws_string_is_valid(aws_string_eq_~b#1.base, aws_string_eq_~b#1.offset); {1999#true} is VALID [2022-02-20 21:08:16,107 INFO L290 TraceCheckUtils]: 79: Hoare triple {1999#true} ~str.base, ~str.offset := #in~str.base, #in~str.offset;#t~short464 := ~str.base != 0 || ~str.offset != 0; {1999#true} is VALID [2022-02-20 21:08:16,107 INFO L290 TraceCheckUtils]: 80: Hoare triple {1999#true} assume #t~short464;call #t~mem463 := read~int(~str.base, 8 + ~str.offset, 8);#t~short464 := 0 == (1 + #t~mem463) % 18446744073709551616 || ~str.base != 0 || 16 + ~str.offset != 0; {1999#true} is VALID [2022-02-20 21:08:16,108 INFO L290 TraceCheckUtils]: 81: Hoare triple {1999#true} #t~short467 := #t~short464; {1999#true} is VALID [2022-02-20 21:08:16,108 INFO L290 TraceCheckUtils]: 82: Hoare triple {1999#true} assume #t~short467;call #t~mem465 := read~int(~str.base, 8 + ~str.offset, 8);call #t~mem466 := read~int(~str.base, 16 + ~str.offset + (if #t~mem465 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then #t~mem465 % 18446744073709551616 % 18446744073709551616 else #t~mem465 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);#t~short467 := 0 == #t~mem466 % 256; {1999#true} is VALID [2022-02-20 21:08:16,108 INFO L290 TraceCheckUtils]: 83: Hoare triple {1999#true} #res := (if 0 == (if #t~short467 then 1 else 0) then 0 else 1);havoc #t~mem463;havoc #t~short464;havoc #t~mem465;havoc #t~mem466;havoc #t~short467; {1999#true} is VALID [2022-02-20 21:08:16,108 INFO L290 TraceCheckUtils]: 84: Hoare triple {1999#true} assume true; {1999#true} is VALID [2022-02-20 21:08:16,108 INFO L284 TraceCheckUtils]: 85: Hoare quadruple {1999#true} {2000#false} #216#return; {2000#false} is VALID [2022-02-20 21:08:16,108 INFO L290 TraceCheckUtils]: 86: Hoare triple {2000#false} aws_string_eq_#t~short1896#1 := 0 != aws_string_eq_#t~ret1895#1 % 256; {2000#false} is VALID [2022-02-20 21:08:16,109 INFO L272 TraceCheckUtils]: 87: Hoare triple {2000#false} call assume_abort_if_not((if 0 == (if aws_string_eq_#t~short1896#1 then 1 else 0) then 0 else 1)); {1999#true} is VALID [2022-02-20 21:08:16,109 INFO L290 TraceCheckUtils]: 88: Hoare triple {1999#true} ~cond := #in~cond; {1999#true} is VALID [2022-02-20 21:08:16,109 INFO L290 TraceCheckUtils]: 89: Hoare triple {1999#true} assume !(0 == ~cond % 256); {1999#true} is VALID [2022-02-20 21:08:16,109 INFO L290 TraceCheckUtils]: 90: Hoare triple {1999#true} assume true; {1999#true} is VALID [2022-02-20 21:08:16,109 INFO L284 TraceCheckUtils]: 91: Hoare quadruple {1999#true} {2000#false} #218#return; {2000#false} is VALID [2022-02-20 21:08:16,109 INFO L290 TraceCheckUtils]: 92: Hoare triple {2000#false} havoc aws_string_eq_#t~ret1895#1;havoc aws_string_eq_#t~short1896#1; {2000#false} is VALID [2022-02-20 21:08:16,110 INFO L290 TraceCheckUtils]: 93: Hoare triple {2000#false} assume aws_string_eq_~a#1.base == aws_string_eq_~b#1.base && aws_string_eq_~a#1.offset == aws_string_eq_~b#1.offset;aws_string_eq_#res#1 := 1; {2000#false} is VALID [2022-02-20 21:08:16,110 INFO L290 TraceCheckUtils]: 94: Hoare triple {2000#false} aws_hash_callback_string_eq_#t~ret1813#1 := aws_string_eq_#res#1;assume { :end_inline_aws_string_eq } true;aws_hash_callback_string_eq_~rval~20#1 := aws_hash_callback_string_eq_#t~ret1813#1;havoc aws_hash_callback_string_eq_#t~ret1813#1; {2000#false} is VALID [2022-02-20 21:08:16,110 INFO L272 TraceCheckUtils]: 95: Hoare triple {2000#false} call aws_hash_callback_string_eq_#t~ret1814#1 := aws_c_string_is_valid(aws_hash_callback_string_eq_~a#1.base, aws_hash_callback_string_eq_~a#1.offset); {1999#true} is VALID [2022-02-20 21:08:16,110 INFO L290 TraceCheckUtils]: 96: Hoare triple {1999#true} ~str.base, ~str.offset := #in~str.base, #in~str.offset;#res := (if 0 == (if (~str.base != 0 || ~str.offset != 0) && (~str.base != 0 || ~str.offset != 0) then 1 else 0) then 0 else 1); {1999#true} is VALID [2022-02-20 21:08:16,110 INFO L290 TraceCheckUtils]: 97: Hoare triple {1999#true} assume true; {1999#true} is VALID [2022-02-20 21:08:16,110 INFO L284 TraceCheckUtils]: 98: Hoare quadruple {1999#true} {2000#false} #222#return; {2000#false} is VALID [2022-02-20 21:08:16,111 INFO L290 TraceCheckUtils]: 99: Hoare triple {2000#false} aws_hash_callback_string_eq_#t~short1816#1 := 0 != aws_hash_callback_string_eq_#t~ret1814#1 % 256; {2000#false} is VALID [2022-02-20 21:08:16,111 INFO L290 TraceCheckUtils]: 100: Hoare triple {2000#false} assume !aws_hash_callback_string_eq_#t~short1816#1; {2000#false} is VALID [2022-02-20 21:08:16,111 INFO L272 TraceCheckUtils]: 101: Hoare triple {2000#false} call __VERIFIER_assert((if 0 == (if aws_hash_callback_string_eq_#t~short1816#1 then 1 else 0) then 0 else 1)); {2000#false} is VALID [2022-02-20 21:08:16,111 INFO L290 TraceCheckUtils]: 102: Hoare triple {2000#false} ~cond := #in~cond; {2000#false} is VALID [2022-02-20 21:08:16,111 INFO L290 TraceCheckUtils]: 103: Hoare triple {2000#false} assume 0 == ~cond % 256; {2000#false} is VALID [2022-02-20 21:08:16,111 INFO L290 TraceCheckUtils]: 104: Hoare triple {2000#false} assume !false; {2000#false} is VALID [2022-02-20 21:08:16,112 INFO L134 CoverageAnalysis]: Checked inductivity of 84 backedges. 0 proven. 24 refuted. 0 times theorem prover too weak. 60 trivial. 0 not checked. [2022-02-20 21:08:16,112 INFO L144 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-02-20 21:08:16,112 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [1890334168] [2022-02-20 21:08:16,112 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleSmtInterpolCraig [1890334168] provided 0 perfect and 1 imperfect interpolant sequences [2022-02-20 21:08:16,113 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [1196316240] [2022-02-20 21:08:16,113 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 21:08:16,113 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-02-20 21:08:16,113 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-02-20 21:08:16,114 INFO L229 MonitoredProcess]: Starting monitored process 3 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2022-02-20 21:08:16,142 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (3)] Waiting until timeout for monitored process [2022-02-20 21:08:16,347 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:16,351 INFO L263 TraceCheckSpWp]: Trace formula consists of 935 conjuncts, 29 conjunts are in the unsatisfiable core [2022-02-20 21:08:16,381 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:16,391 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-02-20 21:08:17,038 INFO L290 TraceCheckUtils]: 0: Hoare triple {1999#true} assume { :begin_inline_ULTIMATE.init } true;#NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(38, 2);call #Ultimate.allocInit(12, 3);call #Ultimate.allocInit(78, 4);~#s_can_fail_allocator_static~0.base, ~#s_can_fail_allocator_static~0.offset := 5, 0;call #Ultimate.allocInit(40, 5);call write~init~$Pointer$(#funAddr~s_can_fail_malloc_allocator.base, #funAddr~s_can_fail_malloc_allocator.offset, ~#s_can_fail_allocator_static~0.base, ~#s_can_fail_allocator_static~0.offset, 8);call write~init~$Pointer$(#funAddr~s_can_fail_free_allocator.base, #funAddr~s_can_fail_free_allocator.offset, ~#s_can_fail_allocator_static~0.base, 8 + ~#s_can_fail_allocator_static~0.offset, 8);call write~init~$Pointer$(#funAddr~s_can_fail_realloc_allocator.base, #funAddr~s_can_fail_realloc_allocator.offset, ~#s_can_fail_allocator_static~0.base, 16 + ~#s_can_fail_allocator_static~0.offset, 8);call write~init~$Pointer$(#funAddr~s_can_fail_calloc_allocator.base, #funAddr~s_can_fail_calloc_allocator.offset, ~#s_can_fail_allocator_static~0.base, 24 + ~#s_can_fail_allocator_static~0.offset, 8);call write~init~$Pointer$(0, 0, ~#s_can_fail_allocator_static~0.base, 32 + ~#s_can_fail_allocator_static~0.offset, 8);~#s_tolower_table~0.base, ~#s_tolower_table~0.offset := 6, 0;call #Ultimate.allocInit(256, 6);call write~init~int(0, ~#s_tolower_table~0.base, ~#s_tolower_table~0.offset, 1);call write~init~int(1, ~#s_tolower_table~0.base, 1 + ~#s_tolower_table~0.offset, 1);call write~init~int(2, ~#s_tolower_table~0.base, 2 + ~#s_tolower_table~0.offset, 1);call write~init~int(3, ~#s_tolower_table~0.base, 3 + ~#s_tolower_table~0.offset, 1);call write~init~int(4, ~#s_tolower_table~0.base, 4 + ~#s_tolower_table~0.offset, 1);call write~init~int(5, ~#s_tolower_table~0.base, 5 + ~#s_tolower_table~0.offset, 1);call write~init~int(6, ~#s_tolower_table~0.base, 6 + ~#s_tolower_table~0.offset, 1);call write~init~int(7, ~#s_tolower_table~0.base, 7 + ~#s_tolower_table~0.offset, 1);call write~init~int(8, ~#s_tolower_table~0.base, 8 + ~#s_tolower_table~0.offset, 1);call write~init~int(9, ~#s_tolower_table~0.base, 9 + ~#s_tolower_table~0.offset, 1);call write~init~int(10, ~#s_tolower_table~0.base, 10 + ~#s_tolower_table~0.offset, 1);call write~init~int(11, ~#s_tolower_table~0.base, 11 + ~#s_tolower_table~0.offset, 1);call write~init~int(12, ~#s_tolower_table~0.base, 12 + ~#s_tolower_table~0.offset, 1);call write~init~int(13, ~#s_tolower_table~0.base, 13 + ~#s_tolower_table~0.offset, 1);call write~init~int(14, ~#s_tolower_table~0.base, 14 + ~#s_tolower_table~0.offset, 1);call write~init~int(15, ~#s_tolower_table~0.base, 15 + ~#s_tolower_table~0.offset, 1);call write~init~int(16, ~#s_tolower_table~0.base, 16 + ~#s_tolower_table~0.offset, 1);call write~init~int(17, ~#s_tolower_table~0.base, 17 + ~#s_tolower_table~0.offset, 1);call write~init~int(18, ~#s_tolower_table~0.base, 18 + ~#s_tolower_table~0.offset, 1);call write~init~int(19, ~#s_tolower_table~0.base, 19 + ~#s_tolower_table~0.offset, 1);call write~init~int(20, ~#s_tolower_table~0.base, 20 + ~#s_tolower_table~0.offset, 1);call write~init~int(21, ~#s_tolower_table~0.base, 21 + ~#s_tolower_table~0.offset, 1);call write~init~int(22, ~#s_tolower_table~0.base, 22 + ~#s_tolower_table~0.offset, 1);call write~init~int(23, ~#s_tolower_table~0.base, 23 + ~#s_tolower_table~0.offset, 1);call write~init~int(24, ~#s_tolower_table~0.base, 24 + ~#s_tolower_table~0.offset, 1);call write~init~int(25, ~#s_tolower_table~0.base, 25 + ~#s_tolower_table~0.offset, 1);call write~init~int(26, ~#s_tolower_table~0.base, 26 + ~#s_tolower_table~0.offset, 1);call write~init~int(27, ~#s_tolower_table~0.base, 27 + ~#s_tolower_table~0.offset, 1);call write~init~int(28, ~#s_tolower_table~0.base, 28 + ~#s_tolower_table~0.offset, 1);call write~init~int(29, ~#s_tolower_table~0.base, 29 + ~#s_tolower_table~0.offset, 1);call write~init~int(30, ~#s_tolower_table~0.base, 30 + ~#s_tolower_table~0.offset, 1);call write~init~int(31, ~#s_tolower_table~0.base, 31 + ~#s_tolower_table~0.offset, 1);call write~init~int(32, ~#s_tolower_table~0.base, 32 + ~#s_tolower_table~0.offset, 1);call write~init~int(33, ~#s_tolower_table~0.base, 33 + ~#s_tolower_table~0.offset, 1);call write~init~int(34, ~#s_tolower_table~0.base, 34 + ~#s_tolower_table~0.offset, 1);call write~init~int(35, ~#s_tolower_table~0.base, 35 + ~#s_tolower_table~0.offset, 1);call write~init~int(36, ~#s_tolower_table~0.base, 36 + ~#s_tolower_table~0.offset, 1);call write~init~int(37, ~#s_tolower_table~0.base, 37 + ~#s_tolower_table~0.offset, 1);call write~init~int(38, ~#s_tolower_table~0.base, 38 + ~#s_tolower_table~0.offset, 1);call write~init~int(39, ~#s_tolower_table~0.base, 39 + ~#s_tolower_table~0.offset, 1);call write~init~int(40, ~#s_tolower_table~0.base, 40 + ~#s_tolower_table~0.offset, 1);call write~init~int(41, ~#s_tolower_table~0.base, 41 + ~#s_tolower_table~0.offset, 1);call write~init~int(42, ~#s_tolower_table~0.base, 42 + ~#s_tolower_table~0.offset, 1);call write~init~int(43, ~#s_tolower_table~0.base, 43 + ~#s_tolower_table~0.offset, 1);call write~init~int(44, ~#s_tolower_table~0.base, 44 + ~#s_tolower_table~0.offset, 1);call write~init~int(45, ~#s_tolower_table~0.base, 45 + ~#s_tolower_table~0.offset, 1);call write~init~int(46, ~#s_tolower_table~0.base, 46 + ~#s_tolower_table~0.offset, 1);call write~init~int(47, ~#s_tolower_table~0.base, 47 + ~#s_tolower_table~0.offset, 1);call write~init~int(48, ~#s_tolower_table~0.base, 48 + ~#s_tolower_table~0.offset, 1);call write~init~int(49, ~#s_tolower_table~0.base, 49 + ~#s_tolower_table~0.offset, 1);call write~init~int(50, ~#s_tolower_table~0.base, 50 + ~#s_tolower_table~0.offset, 1);call write~init~int(51, ~#s_tolower_table~0.base, 51 + ~#s_tolower_table~0.offset, 1);call write~init~int(52, ~#s_tolower_table~0.base, 52 + ~#s_tolower_table~0.offset, 1);call write~init~int(53, ~#s_tolower_table~0.base, 53 + ~#s_tolower_table~0.offset, 1);call write~init~int(54, ~#s_tolower_table~0.base, 54 + ~#s_tolower_table~0.offset, 1);call write~init~int(55, ~#s_tolower_table~0.base, 55 + ~#s_tolower_table~0.offset, 1);call write~init~int(56, ~#s_tolower_table~0.base, 56 + ~#s_tolower_table~0.offset, 1);call write~init~int(57, ~#s_tolower_table~0.base, 57 + ~#s_tolower_table~0.offset, 1);call write~init~int(58, ~#s_tolower_table~0.base, 58 + ~#s_tolower_table~0.offset, 1);call write~init~int(59, ~#s_tolower_table~0.base, 59 + ~#s_tolower_table~0.offset, 1);call write~init~int(60, ~#s_tolower_table~0.base, 60 + ~#s_tolower_table~0.offset, 1);call write~init~int(61, ~#s_tolower_table~0.base, 61 + ~#s_tolower_table~0.offset, 1);call write~init~int(62, ~#s_tolower_table~0.base, 62 + ~#s_tolower_table~0.offset, 1);call write~init~int(63, ~#s_tolower_table~0.base, 63 + ~#s_tolower_table~0.offset, 1);call write~init~int(64, ~#s_tolower_table~0.base, 64 + ~#s_tolower_table~0.offset, 1);call write~init~int(97, ~#s_tolower_table~0.base, 65 + ~#s_tolower_table~0.offset, 1);call write~init~int(98, ~#s_tolower_table~0.base, 66 + ~#s_tolower_table~0.offset, 1);call write~init~int(99, ~#s_tolower_table~0.base, 67 + ~#s_tolower_table~0.offset, 1);call write~init~int(100, ~#s_tolower_table~0.base, 68 + ~#s_tolower_table~0.offset, 1);call write~init~int(101, ~#s_tolower_table~0.base, 69 + ~#s_tolower_table~0.offset, 1);call write~init~int(102, ~#s_tolower_table~0.base, 70 + ~#s_tolower_table~0.offset, 1);call write~init~int(103, ~#s_tolower_table~0.base, 71 + ~#s_tolower_table~0.offset, 1);call write~init~int(104, ~#s_tolower_table~0.base, 72 + ~#s_tolower_table~0.offset, 1);call write~init~int(105, ~#s_tolower_table~0.base, 73 + ~#s_tolower_table~0.offset, 1);call write~init~int(106, ~#s_tolower_table~0.base, 74 + ~#s_tolower_table~0.offset, 1);call write~init~int(107, ~#s_tolower_table~0.base, 75 + ~#s_tolower_table~0.offset, 1);call write~init~int(108, ~#s_tolower_table~0.base, 76 + ~#s_tolower_table~0.offset, 1);call write~init~int(109, ~#s_tolower_table~0.base, 77 + ~#s_tolower_table~0.offset, 1);call write~init~int(110, ~#s_tolower_table~0.base, 78 + ~#s_tolower_table~0.offset, 1);call write~init~int(111, ~#s_tolower_table~0.base, 79 + ~#s_tolower_table~0.offset, 1);call write~init~int(112, ~#s_tolower_table~0.base, 80 + ~#s_tolower_table~0.offset, 1);call write~init~int(113, ~#s_tolower_table~0.base, 81 + ~#s_tolower_table~0.offset, 1);call write~init~int(114, ~#s_tolower_table~0.base, 82 + ~#s_tolower_table~0.offset, 1);call write~init~int(115, ~#s_tolower_table~0.base, 83 + ~#s_tolower_table~0.offset, 1);call write~init~int(116, ~#s_tolower_table~0.base, 84 + ~#s_tolower_table~0.offset, 1);call write~init~int(117, ~#s_tolower_table~0.base, 85 + ~#s_tolower_table~0.offset, 1);call write~init~int(118, ~#s_tolower_table~0.base, 86 + ~#s_tolower_table~0.offset, 1);call write~init~int(119, ~#s_tolower_table~0.base, 87 + ~#s_tolower_table~0.offset, 1);call write~init~int(120, ~#s_tolower_table~0.base, 88 + ~#s_tolower_table~0.offset, 1);call write~init~int(121, ~#s_tolower_table~0.base, 89 + ~#s_tolower_table~0.offset, 1);call write~init~int(122, ~#s_tolower_table~0.base, 90 + ~#s_tolower_table~0.offset, 1);call write~init~int(91, ~#s_tolower_table~0.base, 91 + ~#s_tolower_table~0.offset, 1);call write~init~int(92, ~#s_tolower_table~0.base, 92 + ~#s_tolower_table~0.offset, 1);call write~init~int(93, ~#s_tolower_table~0.base, 93 + ~#s_tolower_table~0.offset, 1);call write~init~int(94, ~#s_tolower_table~0.base, 94 + ~#s_tolower_table~0.offset, 1);call write~init~int(95, ~#s_tolower_table~0.base, 95 + ~#s_tolower_table~0.offset, 1);call write~init~int(96, ~#s_tolower_table~0.base, 96 + ~#s_tolower_table~0.offset, 1);call write~init~int(97, ~#s_tolower_table~0.base, 97 + ~#s_tolower_table~0.offset, 1);call write~init~int(98, ~#s_tolower_table~0.base, 98 + ~#s_tolower_table~0.offset, 1);call write~init~int(99, ~#s_tolower_table~0.base, 99 + ~#s_tolower_table~0.offset, 1);call write~init~int(100, ~#s_tolower_table~0.base, 100 + ~#s_tolower_table~0.offset, 1);call write~init~int(101, ~#s_tolower_table~0.base, 101 + ~#s_tolower_table~0.offset, 1);call write~init~int(102, ~#s_tolower_table~0.base, 102 + ~#s_tolower_table~0.offset, 1);call write~init~int(103, ~#s_tolower_table~0.base, 103 + ~#s_tolower_table~0.offset, 1);call write~init~int(104, ~#s_tolower_table~0.base, 104 + ~#s_tolower_table~0.offset, 1);call write~init~int(105, ~#s_tolower_table~0.base, 105 + ~#s_tolower_table~0.offset, 1);call write~init~int(106, ~#s_tolower_table~0.base, 106 + ~#s_tolower_table~0.offset, 1);call write~init~int(107, ~#s_tolower_table~0.base, 107 + ~#s_tolower_table~0.offset, 1);call write~init~int(108, ~#s_tolower_table~0.base, 108 + ~#s_tolower_table~0.offset, 1);call write~init~int(109, ~#s_tolower_table~0.base, 109 + ~#s_tolower_table~0.offset, 1);call write~init~int(110, ~#s_tolower_table~0.base, 110 + ~#s_tolower_table~0.offset, 1);call write~init~int(111, ~#s_tolower_table~0.base, 111 + ~#s_tolower_table~0.offset, 1);call write~init~int(112, ~#s_tolower_table~0.base, 112 + ~#s_tolower_table~0.offset, 1);call write~init~int(113, ~#s_tolower_table~0.base, 113 + ~#s_tolower_table~0.offset, 1);call write~init~int(114, ~#s_tolower_table~0.base, 114 + ~#s_tolower_table~0.offset, 1);call write~init~int(115, ~#s_tolower_table~0.base, 115 + ~#s_tolower_table~0.offset, 1);call write~init~int(116, ~#s_tolower_table~0.base, 116 + ~#s_tolower_table~0.offset, 1);call write~init~int(117, ~#s_tolower_table~0.base, 117 + ~#s_tolower_table~0.offset, 1);call write~init~int(118, ~#s_tolower_table~0.base, 118 + ~#s_tolower_table~0.offset, 1);call write~init~int(119, ~#s_tolower_table~0.base, 119 + ~#s_tolower_table~0.offset, 1);call write~init~int(120, ~#s_tolower_table~0.base, 120 + ~#s_tolower_table~0.offset, 1);call write~init~int(121, ~#s_tolower_table~0.base, 121 + ~#s_tolower_table~0.offset, 1);call write~init~int(122, ~#s_tolower_table~0.base, 122 + ~#s_tolower_table~0.offset, 1);call write~init~int(123, ~#s_tolower_table~0.base, 123 + ~#s_tolower_table~0.offset, 1);call write~init~int(124, ~#s_tolower_table~0.base, 124 + ~#s_tolower_table~0.offset, 1);call write~init~int(125, ~#s_tolower_table~0.base, 125 + ~#s_tolower_table~0.offset, 1);call write~init~int(126, ~#s_tolower_table~0.base, 126 + ~#s_tolower_table~0.offset, 1);call write~init~int(127, ~#s_tolower_table~0.base, 127 + ~#s_tolower_table~0.offset, 1);call write~init~int(128, ~#s_tolower_table~0.base, 128 + ~#s_tolower_table~0.offset, 1);call write~init~int(129, ~#s_tolower_table~0.base, 129 + ~#s_tolower_table~0.offset, 1);call write~init~int(130, ~#s_tolower_table~0.base, 130 + ~#s_tolower_table~0.offset, 1);call write~init~int(131, ~#s_tolower_table~0.base, 131 + ~#s_tolower_table~0.offset, 1);call write~init~int(132, ~#s_tolower_table~0.base, 132 + ~#s_tolower_table~0.offset, 1);call write~init~int(133, ~#s_tolower_table~0.base, 133 + ~#s_tolower_table~0.offset, 1);call write~init~int(134, ~#s_tolower_table~0.base, 134 + ~#s_tolower_table~0.offset, 1);call write~init~int(135, ~#s_tolower_table~0.base, 135 + ~#s_tolower_table~0.offset, 1);call write~init~int(136, ~#s_tolower_table~0.base, 136 + ~#s_tolower_table~0.offset, 1);call write~init~int(137, ~#s_tolower_table~0.base, 137 + ~#s_tolower_table~0.offset, 1);call write~init~int(138, ~#s_tolower_table~0.base, 138 + ~#s_tolower_table~0.offset, 1);call write~init~int(139, ~#s_tolower_table~0.base, 139 + ~#s_tolower_table~0.offset, 1);call write~init~int(140, ~#s_tolower_table~0.base, 140 + ~#s_tolower_table~0.offset, 1);call write~init~int(141, ~#s_tolower_table~0.base, 141 + ~#s_tolower_table~0.offset, 1);call write~init~int(142, ~#s_tolower_table~0.base, 142 + ~#s_tolower_table~0.offset, 1);call write~init~int(143, ~#s_tolower_table~0.base, 143 + ~#s_tolower_table~0.offset, 1);call write~init~int(144, ~#s_tolower_table~0.base, 144 + ~#s_tolower_table~0.offset, 1);call write~init~int(145, ~#s_tolower_table~0.base, 145 + ~#s_tolower_table~0.offset, 1);call write~init~int(146, ~#s_tolower_table~0.base, 146 + ~#s_tolower_table~0.offset, 1);call write~init~int(147, ~#s_tolower_table~0.base, 147 + ~#s_tolower_table~0.offset, 1);call write~init~int(148, ~#s_tolower_table~0.base, 148 + ~#s_tolower_table~0.offset, 1);call write~init~int(149, ~#s_tolower_table~0.base, 149 + ~#s_tolower_table~0.offset, 1);call write~init~int(150, ~#s_tolower_table~0.base, 150 + ~#s_tolower_table~0.offset, 1);call write~init~int(151, ~#s_tolower_table~0.base, 151 + ~#s_tolower_table~0.offset, 1);call write~init~int(152, ~#s_tolower_table~0.base, 152 + ~#s_tolower_table~0.offset, 1);call write~init~int(153, ~#s_tolower_table~0.base, 153 + ~#s_tolower_table~0.offset, 1);call write~init~int(154, ~#s_tolower_table~0.base, 154 + ~#s_tolower_table~0.offset, 1);call write~init~int(155, ~#s_tolower_table~0.base, 155 + ~#s_tolower_table~0.offset, 1);call write~init~int(156, ~#s_tolower_table~0.base, 156 + ~#s_tolower_table~0.offset, 1);call write~init~int(157, ~#s_tolower_table~0.base, 157 + ~#s_tolower_table~0.offset, 1);call write~init~int(158, ~#s_tolower_table~0.base, 158 + ~#s_tolower_table~0.offset, 1);call write~init~int(159, ~#s_tolower_table~0.base, 159 + ~#s_tolower_table~0.offset, 1);call write~init~int(160, ~#s_tolower_table~0.base, 160 + ~#s_tolower_table~0.offset, 1);call write~init~int(161, ~#s_tolower_table~0.base, 161 + ~#s_tolower_table~0.offset, 1);call write~init~int(162, ~#s_tolower_table~0.base, 162 + ~#s_tolower_table~0.offset, 1);call write~init~int(163, ~#s_tolower_table~0.base, 163 + ~#s_tolower_table~0.offset, 1);call write~init~int(164, ~#s_tolower_table~0.base, 164 + ~#s_tolower_table~0.offset, 1);call write~init~int(165, ~#s_tolower_table~0.base, 165 + ~#s_tolower_table~0.offset, 1);call write~init~int(166, ~#s_tolower_table~0.base, 166 + ~#s_tolower_table~0.offset, 1);call write~init~int(167, ~#s_tolower_table~0.base, 167 + ~#s_tolower_table~0.offset, 1);call write~init~int(168, ~#s_tolower_table~0.base, 168 + ~#s_tolower_table~0.offset, 1);call write~init~int(169, ~#s_tolower_table~0.base, 169 + ~#s_tolower_table~0.offset, 1);call write~init~int(170, ~#s_tolower_table~0.base, 170 + ~#s_tolower_table~0.offset, 1);call write~init~int(171, ~#s_tolower_table~0.base, 171 + ~#s_tolower_table~0.offset, 1);call write~init~int(172, ~#s_tolower_table~0.base, 172 + ~#s_tolower_table~0.offset, 1);call write~init~int(173, ~#s_tolower_table~0.base, 173 + ~#s_tolower_table~0.offset, 1);call write~init~int(174, ~#s_tolower_table~0.base, 174 + ~#s_tolower_table~0.offset, 1);call write~init~int(175, ~#s_tolower_table~0.base, 175 + ~#s_tolower_table~0.offset, 1);call write~init~int(176, ~#s_tolower_table~0.base, 176 + ~#s_tolower_table~0.offset, 1);call write~init~int(177, ~#s_tolower_table~0.base, 177 + ~#s_tolower_table~0.offset, 1);call write~init~int(178, ~#s_tolower_table~0.base, 178 + ~#s_tolower_table~0.offset, 1);call write~init~int(179, ~#s_tolower_table~0.base, 179 + ~#s_tolower_table~0.offset, 1);call write~init~int(180, ~#s_tolower_table~0.base, 180 + ~#s_tolower_table~0.offset, 1);call write~init~int(181, ~#s_tolower_table~0.base, 181 + ~#s_tolower_table~0.offset, 1);call write~init~int(182, ~#s_tolower_table~0.base, 182 + ~#s_tolower_table~0.offset, 1);call write~init~int(183, ~#s_tolower_table~0.base, 183 + ~#s_tolower_table~0.offset, 1);call write~init~int(184, ~#s_tolower_table~0.base, 184 + ~#s_tolower_table~0.offset, 1);call write~init~int(185, ~#s_tolower_table~0.base, 185 + ~#s_tolower_table~0.offset, 1);call write~init~int(186, ~#s_tolower_table~0.base, 186 + ~#s_tolower_table~0.offset, 1);call write~init~int(187, ~#s_tolower_table~0.base, 187 + ~#s_tolower_table~0.offset, 1);call write~init~int(188, ~#s_tolower_table~0.base, 188 + ~#s_tolower_table~0.offset, 1);call write~init~int(189, ~#s_tolower_table~0.base, 189 + ~#s_tolower_table~0.offset, 1);call write~init~int(190, ~#s_tolower_table~0.base, 190 + ~#s_tolower_table~0.offset, 1);call write~init~int(191, ~#s_tolower_table~0.base, 191 + ~#s_tolower_table~0.offset, 1);call write~init~int(192, ~#s_tolower_table~0.base, 192 + ~#s_tolower_table~0.offset, 1);call write~init~int(193, ~#s_tolower_table~0.base, 193 + ~#s_tolower_table~0.offset, 1);call write~init~int(194, ~#s_tolower_table~0.base, 194 + ~#s_tolower_table~0.offset, 1);call write~init~int(195, ~#s_tolower_table~0.base, 195 + ~#s_tolower_table~0.offset, 1);call write~init~int(196, ~#s_tolower_table~0.base, 196 + ~#s_tolower_table~0.offset, 1);call write~init~int(197, ~#s_tolower_table~0.base, 197 + ~#s_tolower_table~0.offset, 1);call write~init~int(198, ~#s_tolower_table~0.base, 198 + ~#s_tolower_table~0.offset, 1);call write~init~int(199, ~#s_tolower_table~0.base, 199 + ~#s_tolower_table~0.offset, 1);call write~init~int(200, ~#s_tolower_table~0.base, 200 + ~#s_tolower_table~0.offset, 1);call write~init~int(201, ~#s_tolower_table~0.base, 201 + ~#s_tolower_table~0.offset, 1);call write~init~int(202, ~#s_tolower_table~0.base, 202 + ~#s_tolower_table~0.offset, 1);call write~init~int(203, ~#s_tolower_table~0.base, 203 + ~#s_tolower_table~0.offset, 1);call write~init~int(204, ~#s_tolower_table~0.base, 204 + ~#s_tolower_table~0.offset, 1);call write~init~int(205, ~#s_tolower_table~0.base, 205 + ~#s_tolower_table~0.offset, 1);call write~init~int(206, ~#s_tolower_table~0.base, 206 + ~#s_tolower_table~0.offset, 1);call write~init~int(207, ~#s_tolower_table~0.base, 207 + ~#s_tolower_table~0.offset, 1);call write~init~int(208, ~#s_tolower_table~0.base, 208 + ~#s_tolower_table~0.offset, 1);call write~init~int(209, ~#s_tolower_table~0.base, 209 + ~#s_tolower_table~0.offset, 1);call write~init~int(210, ~#s_tolower_table~0.base, 210 + ~#s_tolower_table~0.offset, 1);call write~init~int(211, ~#s_tolower_table~0.base, 211 + ~#s_tolower_table~0.offset, 1);call write~init~int(212, ~#s_tolower_table~0.base, 212 + ~#s_tolower_table~0.offset, 1);call write~init~int(213, ~#s_tolower_table~0.base, 213 + ~#s_tolower_table~0.offset, 1);call write~init~int(214, ~#s_tolower_table~0.base, 214 + ~#s_tolower_table~0.offset, 1);call write~init~int(215, ~#s_tolower_table~0.base, 215 + ~#s_tolower_table~0.offset, 1);call write~init~int(216, ~#s_tolower_table~0.base, 216 + ~#s_tolower_table~0.offset, 1);call write~init~int(217, ~#s_tolower_table~0.base, 217 + ~#s_tolower_table~0.offset, 1);call write~init~int(218, ~#s_tolower_table~0.base, 218 + ~#s_tolower_table~0.offset, 1);call write~init~int(219, ~#s_tolower_table~0.base, 219 + ~#s_tolower_table~0.offset, 1);call write~init~int(220, ~#s_tolower_table~0.base, 220 + ~#s_tolower_table~0.offset, 1);call write~init~int(221, ~#s_tolower_table~0.base, 221 + ~#s_tolower_table~0.offset, 1);call write~init~int(222, ~#s_tolower_table~0.base, 222 + ~#s_tolower_table~0.offset, 1);call write~init~int(223, ~#s_tolower_table~0.base, 223 + ~#s_tolower_table~0.offset, 1);call write~init~int(224, ~#s_tolower_table~0.base, 224 + ~#s_tolower_table~0.offset, 1);call write~init~int(225, ~#s_tolower_table~0.base, 225 + ~#s_tolower_table~0.offset, 1);call write~init~int(226, ~#s_tolower_table~0.base, 226 + ~#s_tolower_table~0.offset, 1);call write~init~int(227, ~#s_tolower_table~0.base, 227 + ~#s_tolower_table~0.offset, 1);call write~init~int(228, ~#s_tolower_table~0.base, 228 + ~#s_tolower_table~0.offset, 1);call write~init~int(229, ~#s_tolower_table~0.base, 229 + ~#s_tolower_table~0.offset, 1);call write~init~int(230, ~#s_tolower_table~0.base, 230 + ~#s_tolower_table~0.offset, 1);call write~init~int(231, ~#s_tolower_table~0.base, 231 + ~#s_tolower_table~0.offset, 1);call write~init~int(232, ~#s_tolower_table~0.base, 232 + ~#s_tolower_table~0.offset, 1);call write~init~int(233, ~#s_tolower_table~0.base, 233 + ~#s_tolower_table~0.offset, 1);call write~init~int(234, ~#s_tolower_table~0.base, 234 + ~#s_tolower_table~0.offset, 1);call write~init~int(235, ~#s_tolower_table~0.base, 235 + ~#s_tolower_table~0.offset, 1);call write~init~int(236, ~#s_tolower_table~0.base, 236 + ~#s_tolower_table~0.offset, 1);call write~init~int(237, ~#s_tolower_table~0.base, 237 + ~#s_tolower_table~0.offset, 1);call write~init~int(238, ~#s_tolower_table~0.base, 238 + ~#s_tolower_table~0.offset, 1);call write~init~int(239, ~#s_tolower_table~0.base, 239 + ~#s_tolower_table~0.offset, 1);call write~init~int(240, ~#s_tolower_table~0.base, 240 + ~#s_tolower_table~0.offset, 1);call write~init~int(241, ~#s_tolower_table~0.base, 241 + ~#s_tolower_table~0.offset, 1);call write~init~int(242, ~#s_tolower_table~0.base, 242 + ~#s_tolower_table~0.offset, 1);call write~init~int(243, ~#s_tolower_table~0.base, 243 + ~#s_tolower_table~0.offset, 1);call write~init~int(244, ~#s_tolower_table~0.base, 244 + ~#s_tolower_table~0.offset, 1);call write~init~int(245, ~#s_tolower_table~0.base, 245 + ~#s_tolower_table~0.offset, 1);call write~init~int(246, ~#s_tolower_table~0.base, 246 + ~#s_tolower_table~0.offset, 1);call write~init~int(247, ~#s_tolower_table~0.base, 247 + ~#s_tolower_table~0.offset, 1);call write~init~int(248, ~#s_tolower_table~0.base, 248 + ~#s_tolower_table~0.offset, 1);call write~init~int(249, ~#s_tolower_table~0.base, 249 + ~#s_tolower_table~0.offset, 1);call write~init~int(250, ~#s_tolower_table~0.base, 250 + ~#s_tolower_table~0.offset, 1);call write~init~int(251, ~#s_tolower_table~0.base, 251 + ~#s_tolower_table~0.offset, 1);call write~init~int(252, ~#s_tolower_table~0.base, 252 + ~#s_tolower_table~0.offset, 1);call write~init~int(253, ~#s_tolower_table~0.base, 253 + ~#s_tolower_table~0.offset, 1);call write~init~int(254, ~#s_tolower_table~0.base, 254 + ~#s_tolower_table~0.offset, 1);call write~init~int(255, ~#s_tolower_table~0.base, 255 + ~#s_tolower_table~0.offset, 1); {1999#true} is VALID [2022-02-20 21:08:17,039 INFO L290 TraceCheckUtils]: 1: Hoare triple {1999#true} assume { :end_inline_ULTIMATE.init } true;assume { :begin_inline_main } true;havoc main_#res#1;assume { :begin_inline_aws_hash_callback_string_eq_harness } true;havoc aws_hash_callback_string_eq_harness_#t~ret1963#1.base, aws_hash_callback_string_eq_harness_#t~ret1963#1.offset, aws_hash_callback_string_eq_harness_#t~ret1964#1, aws_hash_callback_string_eq_harness_#t~ite1966#1.base, aws_hash_callback_string_eq_harness_#t~ite1966#1.offset, aws_hash_callback_string_eq_harness_#t~ret1965#1.base, aws_hash_callback_string_eq_harness_#t~ret1965#1.offset, aws_hash_callback_string_eq_harness_#t~ret1967#1, aws_hash_callback_string_eq_harness_#t~mem1968#1, aws_hash_callback_string_eq_harness_#t~mem1969#1, aws_hash_callback_string_eq_harness_#t~mem1970#1, aws_hash_callback_string_eq_harness_~str1~0#1.base, aws_hash_callback_string_eq_harness_~str1~0#1.offset, aws_hash_callback_string_eq_harness_~str2~0#1.base, aws_hash_callback_string_eq_harness_~str2~0#1.offset, aws_hash_callback_string_eq_harness_~rval~21#1; {1999#true} is VALID [2022-02-20 21:08:17,039 INFO L272 TraceCheckUtils]: 2: Hoare triple {1999#true} call aws_hash_callback_string_eq_harness_#t~ret1963#1.base, aws_hash_callback_string_eq_harness_#t~ret1963#1.offset := ensure_string_is_allocated_bounded_length(96); {1999#true} is VALID [2022-02-20 21:08:17,040 INFO L290 TraceCheckUtils]: 3: Hoare triple {1999#true} ~max_size#1 := #in~max_size#1; {1999#true} is VALID [2022-02-20 21:08:17,040 INFO L272 TraceCheckUtils]: 4: Hoare triple {1999#true} call #t~ret540#1 := nondet_uint64_t(); {1999#true} is VALID [2022-02-20 21:08:17,040 INFO L290 TraceCheckUtils]: 5: Hoare triple {1999#true} #res := #t~nondet13;havoc #t~nondet13; {1999#true} is VALID [2022-02-20 21:08:17,040 INFO L290 TraceCheckUtils]: 6: Hoare triple {1999#true} assume true; {1999#true} is VALID [2022-02-20 21:08:17,040 INFO L284 TraceCheckUtils]: 7: Hoare quadruple {1999#true} {1999#true} #182#return; {1999#true} is VALID [2022-02-20 21:08:17,041 INFO L290 TraceCheckUtils]: 8: Hoare triple {1999#true} ~len~1#1 := #t~ret540#1;havoc #t~ret540#1; {1999#true} is VALID [2022-02-20 21:08:17,041 INFO L272 TraceCheckUtils]: 9: Hoare triple {1999#true} call assume_abort_if_not((if 0 == (if ~len~1#1 % 18446744073709551616 < ~max_size#1 % 18446744073709551616 then 1 else 0) then 0 else 1)); {1999#true} is VALID [2022-02-20 21:08:17,041 INFO L290 TraceCheckUtils]: 10: Hoare triple {1999#true} ~cond := #in~cond; {1999#true} is VALID [2022-02-20 21:08:17,041 INFO L290 TraceCheckUtils]: 11: Hoare triple {1999#true} assume !(0 == ~cond % 256); {1999#true} is VALID [2022-02-20 21:08:17,041 INFO L290 TraceCheckUtils]: 12: Hoare triple {1999#true} assume true; {1999#true} is VALID [2022-02-20 21:08:17,041 INFO L284 TraceCheckUtils]: 13: Hoare quadruple {1999#true} {1999#true} #184#return; {1999#true} is VALID [2022-02-20 21:08:17,042 INFO L290 TraceCheckUtils]: 14: Hoare triple {1999#true} assume { :begin_inline_ensure_string_is_allocated } true;ensure_string_is_allocated_#in~len#1 := ~len~1#1;havoc ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset;havoc ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset, ensure_string_is_allocated_#t~ret543#1, ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset, ensure_string_is_allocated_#t~ret544#1.base, ensure_string_is_allocated_#t~ret544#1.offset, ensure_string_is_allocated_~len#1, ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset;ensure_string_is_allocated_~len#1 := ensure_string_is_allocated_#in~len#1; {1999#true} is VALID [2022-02-20 21:08:17,042 INFO L272 TraceCheckUtils]: 15: Hoare triple {1999#true} call ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset := bounded_malloc(-1234550 + ensure_string_is_allocated_~len#1); {1999#true} is VALID [2022-02-20 21:08:17,042 INFO L290 TraceCheckUtils]: 16: Hoare triple {1999#true} ~size := #in~size; {1999#true} is VALID [2022-02-20 21:08:17,042 INFO L272 TraceCheckUtils]: 17: Hoare triple {1999#true} call assume_abort_if_not((if 0 == (if ~size % 18446744073709551616 <= 36028797018963967 then 1 else 0) then 0 else 1)); {1999#true} is VALID [2022-02-20 21:08:17,042 INFO L290 TraceCheckUtils]: 18: Hoare triple {1999#true} ~cond := #in~cond; {1999#true} is VALID [2022-02-20 21:08:17,043 INFO L290 TraceCheckUtils]: 19: Hoare triple {1999#true} assume !(0 == ~cond % 256); {1999#true} is VALID [2022-02-20 21:08:17,043 INFO L290 TraceCheckUtils]: 20: Hoare triple {1999#true} assume true; {1999#true} is VALID [2022-02-20 21:08:17,043 INFO L284 TraceCheckUtils]: 21: Hoare quadruple {1999#true} {1999#true} #192#return; {1999#true} is VALID [2022-02-20 21:08:17,043 INFO L290 TraceCheckUtils]: 22: Hoare triple {1999#true} call #t~malloc555.base, #t~malloc555.offset := #Ultimate.allocOnHeap(~size);#res.base, #res.offset := #t~malloc555.base, #t~malloc555.offset;havoc #t~malloc555.base, #t~malloc555.offset; {2183#(not (= |bounded_malloc_#res.base| 0))} is VALID [2022-02-20 21:08:17,044 INFO L290 TraceCheckUtils]: 23: Hoare triple {2183#(not (= |bounded_malloc_#res.base| 0))} assume true; {2183#(not (= |bounded_malloc_#res.base| 0))} is VALID [2022-02-20 21:08:17,045 INFO L284 TraceCheckUtils]: 24: Hoare quadruple {2183#(not (= |bounded_malloc_#res.base| 0))} {1999#true} #186#return; {2190#(not (= |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_#t~ret542#1.base| 0))} is VALID [2022-02-20 21:08:17,045 INFO L290 TraceCheckUtils]: 25: Hoare triple {2190#(not (= |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_#t~ret542#1.base| 0))} ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset := ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset;havoc ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset; {2194#(not (= |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~str~0#1.base| 0))} is VALID [2022-02-20 21:08:17,046 INFO L272 TraceCheckUtils]: 26: Hoare triple {2194#(not (= |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~str~0#1.base| 0))} call ensure_string_is_allocated_#t~ret543#1 := nondet_bool(); {1999#true} is VALID [2022-02-20 21:08:17,046 INFO L290 TraceCheckUtils]: 27: Hoare triple {1999#true} #res := #t~nondet8;havoc #t~nondet8; {1999#true} is VALID [2022-02-20 21:08:17,046 INFO L290 TraceCheckUtils]: 28: Hoare triple {1999#true} assume true; {1999#true} is VALID [2022-02-20 21:08:17,047 INFO L284 TraceCheckUtils]: 29: Hoare quadruple {1999#true} {2194#(not (= |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~str~0#1.base| 0))} #188#return; {2194#(not (= |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~str~0#1.base| 0))} is VALID [2022-02-20 21:08:17,047 INFO L290 TraceCheckUtils]: 30: Hoare triple {2194#(not (= |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~str~0#1.base| 0))} assume !(0 != ensure_string_is_allocated_#t~ret543#1 % 256);ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset := 0, 0; {2194#(not (= |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~str~0#1.base| 0))} is VALID [2022-02-20 21:08:17,048 INFO L290 TraceCheckUtils]: 31: Hoare triple {2194#(not (= |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~str~0#1.base| 0))} call write~$Pointer$(ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset, ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset, 8);havoc ensure_string_is_allocated_#t~ret543#1;havoc ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset;havoc ensure_string_is_allocated_#t~ret544#1.base, ensure_string_is_allocated_#t~ret544#1.offset;call write~int(ensure_string_is_allocated_~len#1, ensure_string_is_allocated_~str~0#1.base, 8 + ensure_string_is_allocated_~str~0#1.offset, 8);call write~int(0, ensure_string_is_allocated_~str~0#1.base, 16 + ensure_string_is_allocated_~str~0#1.offset + (if ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 else ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset := ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset; {2213#(not (= |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_#res#1.base| 0))} is VALID [2022-02-20 21:08:17,049 INFO L290 TraceCheckUtils]: 32: Hoare triple {2213#(not (= |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_#res#1.base| 0))} #t~ret541#1.base, #t~ret541#1.offset := ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset;assume { :end_inline_ensure_string_is_allocated } true;#res#1.base, #res#1.offset := #t~ret541#1.base, #t~ret541#1.offset;havoc #t~ret541#1.base, #t~ret541#1.offset; {2217#(not (= |ensure_string_is_allocated_bounded_length_#res#1.base| 0))} is VALID [2022-02-20 21:08:17,049 INFO L290 TraceCheckUtils]: 33: Hoare triple {2217#(not (= |ensure_string_is_allocated_bounded_length_#res#1.base| 0))} assume true; {2217#(not (= |ensure_string_is_allocated_bounded_length_#res#1.base| 0))} is VALID [2022-02-20 21:08:17,050 INFO L284 TraceCheckUtils]: 34: Hoare quadruple {2217#(not (= |ensure_string_is_allocated_bounded_length_#res#1.base| 0))} {1999#true} #198#return; {2033#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_#t~ret1963#1.base| 0))} is VALID [2022-02-20 21:08:17,051 INFO L290 TraceCheckUtils]: 35: Hoare triple {2033#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_#t~ret1963#1.base| 0))} aws_hash_callback_string_eq_harness_~str1~0#1.base, aws_hash_callback_string_eq_harness_~str1~0#1.offset := aws_hash_callback_string_eq_harness_#t~ret1963#1.base, aws_hash_callback_string_eq_harness_#t~ret1963#1.offset;havoc aws_hash_callback_string_eq_harness_#t~ret1963#1.base, aws_hash_callback_string_eq_harness_#t~ret1963#1.offset; {2034#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| 0))} is VALID [2022-02-20 21:08:17,051 INFO L272 TraceCheckUtils]: 36: Hoare triple {2034#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| 0))} call aws_hash_callback_string_eq_harness_#t~ret1964#1 := nondet_bool(); {1999#true} is VALID [2022-02-20 21:08:17,051 INFO L290 TraceCheckUtils]: 37: Hoare triple {1999#true} #res := #t~nondet8;havoc #t~nondet8; {1999#true} is VALID [2022-02-20 21:08:17,051 INFO L290 TraceCheckUtils]: 38: Hoare triple {1999#true} assume true; {1999#true} is VALID [2022-02-20 21:08:17,057 INFO L284 TraceCheckUtils]: 39: Hoare quadruple {1999#true} {2034#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| 0))} #200#return; {2034#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| 0))} is VALID [2022-02-20 21:08:17,057 INFO L290 TraceCheckUtils]: 40: Hoare triple {2034#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| 0))} assume 0 != aws_hash_callback_string_eq_harness_#t~ret1964#1 % 256;aws_hash_callback_string_eq_harness_#t~ite1966#1.base, aws_hash_callback_string_eq_harness_#t~ite1966#1.offset := aws_hash_callback_string_eq_harness_~str1~0#1.base, aws_hash_callback_string_eq_harness_~str1~0#1.offset; {2242#(not (= 0 |ULTIMATE.start_aws_hash_callback_string_eq_harness_#t~ite1966#1.base|))} is VALID [2022-02-20 21:08:17,058 INFO L290 TraceCheckUtils]: 41: Hoare triple {2242#(not (= 0 |ULTIMATE.start_aws_hash_callback_string_eq_harness_#t~ite1966#1.base|))} aws_hash_callback_string_eq_harness_~str2~0#1.base, aws_hash_callback_string_eq_harness_~str2~0#1.offset := aws_hash_callback_string_eq_harness_#t~ite1966#1.base, aws_hash_callback_string_eq_harness_#t~ite1966#1.offset;havoc aws_hash_callback_string_eq_harness_#t~ret1964#1;havoc aws_hash_callback_string_eq_harness_#t~ite1966#1.base, aws_hash_callback_string_eq_harness_#t~ite1966#1.offset;havoc aws_hash_callback_string_eq_harness_#t~ret1965#1.base, aws_hash_callback_string_eq_harness_#t~ret1965#1.offset;assume { :begin_inline_aws_hash_callback_string_eq } true;aws_hash_callback_string_eq_#in~a#1.base, aws_hash_callback_string_eq_#in~a#1.offset, aws_hash_callback_string_eq_#in~b#1.base, aws_hash_callback_string_eq_#in~b#1.offset := aws_hash_callback_string_eq_harness_~str1~0#1.base, aws_hash_callback_string_eq_harness_~str1~0#1.offset, aws_hash_callback_string_eq_harness_~str2~0#1.base, aws_hash_callback_string_eq_harness_~str2~0#1.offset;havoc aws_hash_callback_string_eq_#res#1;havoc aws_hash_callback_string_eq_#t~ret1811#1, aws_hash_callback_string_eq_#t~ret1812#1, aws_hash_callback_string_eq_#t~ret1813#1, aws_hash_callback_string_eq_#t~ret1814#1, aws_hash_callback_string_eq_#t~ret1815#1, aws_hash_callback_string_eq_#t~short1816#1, aws_hash_callback_string_eq_~a#1.base, aws_hash_callback_string_eq_~a#1.offset, aws_hash_callback_string_eq_~b#1.base, aws_hash_callback_string_eq_~b#1.offset, aws_hash_callback_string_eq_~rval~20#1;aws_hash_callback_string_eq_~a#1.base, aws_hash_callback_string_eq_~a#1.offset := aws_hash_callback_string_eq_#in~a#1.base, aws_hash_callback_string_eq_#in~a#1.offset;aws_hash_callback_string_eq_~b#1.base, aws_hash_callback_string_eq_~b#1.offset := aws_hash_callback_string_eq_#in~b#1.base, aws_hash_callback_string_eq_#in~b#1.offset; {2246#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} is VALID [2022-02-20 21:08:17,058 INFO L272 TraceCheckUtils]: 42: Hoare triple {2246#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} call aws_hash_callback_string_eq_#t~ret1811#1 := aws_string_is_valid(aws_hash_callback_string_eq_~a#1.base, aws_hash_callback_string_eq_~a#1.offset); {1999#true} is VALID [2022-02-20 21:08:17,059 INFO L290 TraceCheckUtils]: 43: Hoare triple {1999#true} ~str.base, ~str.offset := #in~str.base, #in~str.offset;#t~short464 := ~str.base != 0 || ~str.offset != 0; {1999#true} is VALID [2022-02-20 21:08:17,059 INFO L290 TraceCheckUtils]: 44: Hoare triple {1999#true} assume #t~short464;call #t~mem463 := read~int(~str.base, 8 + ~str.offset, 8);#t~short464 := 0 == (1 + #t~mem463) % 18446744073709551616 || ~str.base != 0 || 16 + ~str.offset != 0; {1999#true} is VALID [2022-02-20 21:08:17,059 INFO L290 TraceCheckUtils]: 45: Hoare triple {1999#true} #t~short467 := #t~short464; {1999#true} is VALID [2022-02-20 21:08:17,059 INFO L290 TraceCheckUtils]: 46: Hoare triple {1999#true} assume #t~short467;call #t~mem465 := read~int(~str.base, 8 + ~str.offset, 8);call #t~mem466 := read~int(~str.base, 16 + ~str.offset + (if #t~mem465 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then #t~mem465 % 18446744073709551616 % 18446744073709551616 else #t~mem465 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);#t~short467 := 0 == #t~mem466 % 256; {1999#true} is VALID [2022-02-20 21:08:17,059 INFO L290 TraceCheckUtils]: 47: Hoare triple {1999#true} #res := (if 0 == (if #t~short467 then 1 else 0) then 0 else 1);havoc #t~mem463;havoc #t~short464;havoc #t~mem465;havoc #t~mem466;havoc #t~short467; {1999#true} is VALID [2022-02-20 21:08:17,060 INFO L290 TraceCheckUtils]: 48: Hoare triple {1999#true} assume true; {1999#true} is VALID [2022-02-20 21:08:17,060 INFO L284 TraceCheckUtils]: 49: Hoare quadruple {1999#true} {2246#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} #204#return; {2246#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} is VALID [2022-02-20 21:08:17,061 INFO L272 TraceCheckUtils]: 50: Hoare triple {2246#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} call assume_abort_if_not(aws_hash_callback_string_eq_#t~ret1811#1); {1999#true} is VALID [2022-02-20 21:08:17,061 INFO L290 TraceCheckUtils]: 51: Hoare triple {1999#true} ~cond := #in~cond; {1999#true} is VALID [2022-02-20 21:08:17,061 INFO L290 TraceCheckUtils]: 52: Hoare triple {1999#true} assume !(0 == ~cond % 256); {1999#true} is VALID [2022-02-20 21:08:17,061 INFO L290 TraceCheckUtils]: 53: Hoare triple {1999#true} assume true; {1999#true} is VALID [2022-02-20 21:08:17,062 INFO L284 TraceCheckUtils]: 54: Hoare quadruple {1999#true} {2246#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} #206#return; {2246#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} is VALID [2022-02-20 21:08:17,062 INFO L290 TraceCheckUtils]: 55: Hoare triple {2246#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} havoc aws_hash_callback_string_eq_#t~ret1811#1; {2246#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} is VALID [2022-02-20 21:08:17,062 INFO L272 TraceCheckUtils]: 56: Hoare triple {2246#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} call aws_hash_callback_string_eq_#t~ret1812#1 := aws_string_is_valid(aws_hash_callback_string_eq_~b#1.base, aws_hash_callback_string_eq_~b#1.offset); {1999#true} is VALID [2022-02-20 21:08:17,063 INFO L290 TraceCheckUtils]: 57: Hoare triple {1999#true} ~str.base, ~str.offset := #in~str.base, #in~str.offset;#t~short464 := ~str.base != 0 || ~str.offset != 0; {1999#true} is VALID [2022-02-20 21:08:17,063 INFO L290 TraceCheckUtils]: 58: Hoare triple {1999#true} assume #t~short464;call #t~mem463 := read~int(~str.base, 8 + ~str.offset, 8);#t~short464 := 0 == (1 + #t~mem463) % 18446744073709551616 || ~str.base != 0 || 16 + ~str.offset != 0; {1999#true} is VALID [2022-02-20 21:08:17,063 INFO L290 TraceCheckUtils]: 59: Hoare triple {1999#true} #t~short467 := #t~short464; {1999#true} is VALID [2022-02-20 21:08:17,063 INFO L290 TraceCheckUtils]: 60: Hoare triple {1999#true} assume #t~short467;call #t~mem465 := read~int(~str.base, 8 + ~str.offset, 8);call #t~mem466 := read~int(~str.base, 16 + ~str.offset + (if #t~mem465 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then #t~mem465 % 18446744073709551616 % 18446744073709551616 else #t~mem465 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);#t~short467 := 0 == #t~mem466 % 256; {1999#true} is VALID [2022-02-20 21:08:17,063 INFO L290 TraceCheckUtils]: 61: Hoare triple {1999#true} #res := (if 0 == (if #t~short467 then 1 else 0) then 0 else 1);havoc #t~mem463;havoc #t~short464;havoc #t~mem465;havoc #t~mem466;havoc #t~short467; {1999#true} is VALID [2022-02-20 21:08:17,064 INFO L290 TraceCheckUtils]: 62: Hoare triple {1999#true} assume true; {1999#true} is VALID [2022-02-20 21:08:17,064 INFO L284 TraceCheckUtils]: 63: Hoare quadruple {1999#true} {2246#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} #208#return; {2246#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} is VALID [2022-02-20 21:08:17,065 INFO L272 TraceCheckUtils]: 64: Hoare triple {2246#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} call assume_abort_if_not(aws_hash_callback_string_eq_#t~ret1812#1); {1999#true} is VALID [2022-02-20 21:08:17,065 INFO L290 TraceCheckUtils]: 65: Hoare triple {1999#true} ~cond := #in~cond; {1999#true} is VALID [2022-02-20 21:08:17,065 INFO L290 TraceCheckUtils]: 66: Hoare triple {1999#true} assume !(0 == ~cond % 256); {1999#true} is VALID [2022-02-20 21:08:17,065 INFO L290 TraceCheckUtils]: 67: Hoare triple {1999#true} assume true; {1999#true} is VALID [2022-02-20 21:08:17,067 INFO L284 TraceCheckUtils]: 68: Hoare quadruple {1999#true} {2246#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} #210#return; {2246#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} is VALID [2022-02-20 21:08:17,068 INFO L290 TraceCheckUtils]: 69: Hoare triple {2246#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} havoc aws_hash_callback_string_eq_#t~ret1812#1;assume { :begin_inline_aws_string_eq } true;aws_string_eq_#in~a#1.base, aws_string_eq_#in~a#1.offset, aws_string_eq_#in~b#1.base, aws_string_eq_#in~b#1.offset := aws_hash_callback_string_eq_~a#1.base, aws_hash_callback_string_eq_~a#1.offset, aws_hash_callback_string_eq_~b#1.base, aws_hash_callback_string_eq_~b#1.offset;havoc aws_string_eq_#res#1;havoc aws_string_eq_#t~ret1893#1, aws_string_eq_#t~short1894#1, aws_string_eq_#t~ret1895#1, aws_string_eq_#t~short1896#1, aws_string_eq_#t~mem1897#1, aws_string_eq_#t~mem1898#1, aws_string_eq_#t~ret1899#1, aws_string_eq_~a#1.base, aws_string_eq_~a#1.offset, aws_string_eq_~b#1.base, aws_string_eq_~b#1.offset;aws_string_eq_~a#1.base, aws_string_eq_~a#1.offset := aws_string_eq_#in~a#1.base, aws_string_eq_#in~a#1.offset;aws_string_eq_~b#1.base, aws_string_eq_~b#1.offset := aws_string_eq_#in~b#1.base, aws_string_eq_#in~b#1.offset;aws_string_eq_#t~short1894#1 := aws_string_eq_~a#1.base == 0 && aws_string_eq_~a#1.offset == 0; {2331#(and (or (not |ULTIMATE.start_aws_string_eq_#t~short1894#1|) (= |ULTIMATE.start_aws_string_eq_~a#1.base| 0)) (not (= |ULTIMATE.start_aws_string_eq_~b#1.base| 0)))} is VALID [2022-02-20 21:08:17,069 INFO L290 TraceCheckUtils]: 70: Hoare triple {2331#(and (or (not |ULTIMATE.start_aws_string_eq_#t~short1894#1|) (= |ULTIMATE.start_aws_string_eq_~a#1.base| 0)) (not (= |ULTIMATE.start_aws_string_eq_~b#1.base| 0)))} assume aws_string_eq_#t~short1894#1; {2335#(and (= |ULTIMATE.start_aws_string_eq_~a#1.base| 0) (not (= |ULTIMATE.start_aws_string_eq_~b#1.base| 0)))} is VALID [2022-02-20 21:08:17,069 INFO L272 TraceCheckUtils]: 71: Hoare triple {2335#(and (= |ULTIMATE.start_aws_string_eq_~a#1.base| 0) (not (= |ULTIMATE.start_aws_string_eq_~b#1.base| 0)))} call assume_abort_if_not((if 0 == (if aws_string_eq_#t~short1894#1 then 1 else 0) then 0 else 1)); {1999#true} is VALID [2022-02-20 21:08:17,069 INFO L290 TraceCheckUtils]: 72: Hoare triple {1999#true} ~cond := #in~cond; {1999#true} is VALID [2022-02-20 21:08:17,069 INFO L290 TraceCheckUtils]: 73: Hoare triple {1999#true} assume !(0 == ~cond % 256); {1999#true} is VALID [2022-02-20 21:08:17,069 INFO L290 TraceCheckUtils]: 74: Hoare triple {1999#true} assume true; {1999#true} is VALID [2022-02-20 21:08:17,070 INFO L284 TraceCheckUtils]: 75: Hoare quadruple {1999#true} {2335#(and (= |ULTIMATE.start_aws_string_eq_~a#1.base| 0) (not (= |ULTIMATE.start_aws_string_eq_~b#1.base| 0)))} #214#return; {2335#(and (= |ULTIMATE.start_aws_string_eq_~a#1.base| 0) (not (= |ULTIMATE.start_aws_string_eq_~b#1.base| 0)))} is VALID [2022-02-20 21:08:17,071 INFO L290 TraceCheckUtils]: 76: Hoare triple {2335#(and (= |ULTIMATE.start_aws_string_eq_~a#1.base| 0) (not (= |ULTIMATE.start_aws_string_eq_~b#1.base| 0)))} havoc aws_string_eq_#t~ret1893#1;havoc aws_string_eq_#t~short1894#1;aws_string_eq_#t~short1896#1 := aws_string_eq_~b#1.base == 0 && aws_string_eq_~b#1.offset == 0; {2335#(and (= |ULTIMATE.start_aws_string_eq_~a#1.base| 0) (not (= |ULTIMATE.start_aws_string_eq_~b#1.base| 0)))} is VALID [2022-02-20 21:08:17,071 INFO L290 TraceCheckUtils]: 77: Hoare triple {2335#(and (= |ULTIMATE.start_aws_string_eq_~a#1.base| 0) (not (= |ULTIMATE.start_aws_string_eq_~b#1.base| 0)))} assume !aws_string_eq_#t~short1896#1; {2335#(and (= |ULTIMATE.start_aws_string_eq_~a#1.base| 0) (not (= |ULTIMATE.start_aws_string_eq_~b#1.base| 0)))} is VALID [2022-02-20 21:08:17,071 INFO L272 TraceCheckUtils]: 78: Hoare triple {2335#(and (= |ULTIMATE.start_aws_string_eq_~a#1.base| 0) (not (= |ULTIMATE.start_aws_string_eq_~b#1.base| 0)))} call aws_string_eq_#t~ret1895#1 := aws_string_is_valid(aws_string_eq_~b#1.base, aws_string_eq_~b#1.offset); {1999#true} is VALID [2022-02-20 21:08:17,072 INFO L290 TraceCheckUtils]: 79: Hoare triple {1999#true} ~str.base, ~str.offset := #in~str.base, #in~str.offset;#t~short464 := ~str.base != 0 || ~str.offset != 0; {1999#true} is VALID [2022-02-20 21:08:17,072 INFO L290 TraceCheckUtils]: 80: Hoare triple {1999#true} assume #t~short464;call #t~mem463 := read~int(~str.base, 8 + ~str.offset, 8);#t~short464 := 0 == (1 + #t~mem463) % 18446744073709551616 || ~str.base != 0 || 16 + ~str.offset != 0; {1999#true} is VALID [2022-02-20 21:08:17,072 INFO L290 TraceCheckUtils]: 81: Hoare triple {1999#true} #t~short467 := #t~short464; {1999#true} is VALID [2022-02-20 21:08:17,072 INFO L290 TraceCheckUtils]: 82: Hoare triple {1999#true} assume #t~short467;call #t~mem465 := read~int(~str.base, 8 + ~str.offset, 8);call #t~mem466 := read~int(~str.base, 16 + ~str.offset + (if #t~mem465 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then #t~mem465 % 18446744073709551616 % 18446744073709551616 else #t~mem465 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);#t~short467 := 0 == #t~mem466 % 256; {1999#true} is VALID [2022-02-20 21:08:17,072 INFO L290 TraceCheckUtils]: 83: Hoare triple {1999#true} #res := (if 0 == (if #t~short467 then 1 else 0) then 0 else 1);havoc #t~mem463;havoc #t~short464;havoc #t~mem465;havoc #t~mem466;havoc #t~short467; {1999#true} is VALID [2022-02-20 21:08:17,073 INFO L290 TraceCheckUtils]: 84: Hoare triple {1999#true} assume true; {1999#true} is VALID [2022-02-20 21:08:17,073 INFO L284 TraceCheckUtils]: 85: Hoare quadruple {1999#true} {2335#(and (= |ULTIMATE.start_aws_string_eq_~a#1.base| 0) (not (= |ULTIMATE.start_aws_string_eq_~b#1.base| 0)))} #216#return; {2335#(and (= |ULTIMATE.start_aws_string_eq_~a#1.base| 0) (not (= |ULTIMATE.start_aws_string_eq_~b#1.base| 0)))} is VALID [2022-02-20 21:08:17,074 INFO L290 TraceCheckUtils]: 86: Hoare triple {2335#(and (= |ULTIMATE.start_aws_string_eq_~a#1.base| 0) (not (= |ULTIMATE.start_aws_string_eq_~b#1.base| 0)))} aws_string_eq_#t~short1896#1 := 0 != aws_string_eq_#t~ret1895#1 % 256; {2335#(and (= |ULTIMATE.start_aws_string_eq_~a#1.base| 0) (not (= |ULTIMATE.start_aws_string_eq_~b#1.base| 0)))} is VALID [2022-02-20 21:08:17,074 INFO L272 TraceCheckUtils]: 87: Hoare triple {2335#(and (= |ULTIMATE.start_aws_string_eq_~a#1.base| 0) (not (= |ULTIMATE.start_aws_string_eq_~b#1.base| 0)))} call assume_abort_if_not((if 0 == (if aws_string_eq_#t~short1896#1 then 1 else 0) then 0 else 1)); {1999#true} is VALID [2022-02-20 21:08:17,074 INFO L290 TraceCheckUtils]: 88: Hoare triple {1999#true} ~cond := #in~cond; {1999#true} is VALID [2022-02-20 21:08:17,075 INFO L290 TraceCheckUtils]: 89: Hoare triple {1999#true} assume !(0 == ~cond % 256); {1999#true} is VALID [2022-02-20 21:08:17,075 INFO L290 TraceCheckUtils]: 90: Hoare triple {1999#true} assume true; {1999#true} is VALID [2022-02-20 21:08:17,076 INFO L284 TraceCheckUtils]: 91: Hoare quadruple {1999#true} {2335#(and (= |ULTIMATE.start_aws_string_eq_~a#1.base| 0) (not (= |ULTIMATE.start_aws_string_eq_~b#1.base| 0)))} #218#return; {2335#(and (= |ULTIMATE.start_aws_string_eq_~a#1.base| 0) (not (= |ULTIMATE.start_aws_string_eq_~b#1.base| 0)))} is VALID [2022-02-20 21:08:17,076 INFO L290 TraceCheckUtils]: 92: Hoare triple {2335#(and (= |ULTIMATE.start_aws_string_eq_~a#1.base| 0) (not (= |ULTIMATE.start_aws_string_eq_~b#1.base| 0)))} havoc aws_string_eq_#t~ret1895#1;havoc aws_string_eq_#t~short1896#1; {2335#(and (= |ULTIMATE.start_aws_string_eq_~a#1.base| 0) (not (= |ULTIMATE.start_aws_string_eq_~b#1.base| 0)))} is VALID [2022-02-20 21:08:17,077 INFO L290 TraceCheckUtils]: 93: Hoare triple {2335#(and (= |ULTIMATE.start_aws_string_eq_~a#1.base| 0) (not (= |ULTIMATE.start_aws_string_eq_~b#1.base| 0)))} assume aws_string_eq_~a#1.base == aws_string_eq_~b#1.base && aws_string_eq_~a#1.offset == aws_string_eq_~b#1.offset;aws_string_eq_#res#1 := 1; {2000#false} is VALID [2022-02-20 21:08:17,077 INFO L290 TraceCheckUtils]: 94: Hoare triple {2000#false} aws_hash_callback_string_eq_#t~ret1813#1 := aws_string_eq_#res#1;assume { :end_inline_aws_string_eq } true;aws_hash_callback_string_eq_~rval~20#1 := aws_hash_callback_string_eq_#t~ret1813#1;havoc aws_hash_callback_string_eq_#t~ret1813#1; {2000#false} is VALID [2022-02-20 21:08:17,077 INFO L272 TraceCheckUtils]: 95: Hoare triple {2000#false} call aws_hash_callback_string_eq_#t~ret1814#1 := aws_c_string_is_valid(aws_hash_callback_string_eq_~a#1.base, aws_hash_callback_string_eq_~a#1.offset); {2000#false} is VALID [2022-02-20 21:08:17,077 INFO L290 TraceCheckUtils]: 96: Hoare triple {2000#false} ~str.base, ~str.offset := #in~str.base, #in~str.offset;#res := (if 0 == (if (~str.base != 0 || ~str.offset != 0) && (~str.base != 0 || ~str.offset != 0) then 1 else 0) then 0 else 1); {2000#false} is VALID [2022-02-20 21:08:17,077 INFO L290 TraceCheckUtils]: 97: Hoare triple {2000#false} assume true; {2000#false} is VALID [2022-02-20 21:08:17,078 INFO L284 TraceCheckUtils]: 98: Hoare quadruple {2000#false} {2000#false} #222#return; {2000#false} is VALID [2022-02-20 21:08:17,078 INFO L290 TraceCheckUtils]: 99: Hoare triple {2000#false} aws_hash_callback_string_eq_#t~short1816#1 := 0 != aws_hash_callback_string_eq_#t~ret1814#1 % 256; {2000#false} is VALID [2022-02-20 21:08:17,078 INFO L290 TraceCheckUtils]: 100: Hoare triple {2000#false} assume !aws_hash_callback_string_eq_#t~short1816#1; {2000#false} is VALID [2022-02-20 21:08:17,078 INFO L272 TraceCheckUtils]: 101: Hoare triple {2000#false} call __VERIFIER_assert((if 0 == (if aws_hash_callback_string_eq_#t~short1816#1 then 1 else 0) then 0 else 1)); {2000#false} is VALID [2022-02-20 21:08:17,078 INFO L290 TraceCheckUtils]: 102: Hoare triple {2000#false} ~cond := #in~cond; {2000#false} is VALID [2022-02-20 21:08:17,079 INFO L290 TraceCheckUtils]: 103: Hoare triple {2000#false} assume 0 == ~cond % 256; {2000#false} is VALID [2022-02-20 21:08:17,079 INFO L290 TraceCheckUtils]: 104: Hoare triple {2000#false} assume !false; {2000#false} is VALID [2022-02-20 21:08:17,079 INFO L134 CoverageAnalysis]: Checked inductivity of 84 backedges. 0 proven. 0 refuted. 0 times theorem prover too weak. 84 trivial. 0 not checked. [2022-02-20 21:08:17,080 INFO L324 TraceCheckSpWp]: Omiting computation of backward sequence because forward sequence was already perfect [2022-02-20 21:08:17,080 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleZ3 [1196316240] provided 1 perfect and 0 imperfect interpolant sequences [2022-02-20 21:08:17,080 INFO L191 FreeRefinementEngine]: Found 1 perfect and 1 imperfect interpolant sequences. [2022-02-20 21:08:17,080 INFO L204 FreeRefinementEngine]: Number of different interpolants: perfect sequences [13] imperfect sequences [17] total 26 [2022-02-20 21:08:17,080 INFO L118 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [1116533062] [2022-02-20 21:08:17,081 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-02-20 21:08:17,081 INFO L78 Accepts]: Start accepts. Automaton has has 13 states, 13 states have (on average 3.4615384615384617) internal successors, (45), 11 states have internal predecessors, (45), 6 states have call successors, (16), 2 states have call predecessors, (16), 4 states have return successors, (15), 8 states have call predecessors, (15), 6 states have call successors, (15) Word has length 105 [2022-02-20 21:08:17,082 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-02-20 21:08:17,082 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with has 13 states, 13 states have (on average 3.4615384615384617) internal successors, (45), 11 states have internal predecessors, (45), 6 states have call successors, (16), 2 states have call predecessors, (16), 4 states have return successors, (15), 8 states have call predecessors, (15), 6 states have call successors, (15) [2022-02-20 21:08:17,165 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 76 edges. 76 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 21:08:17,166 INFO L546 AbstractCegarLoop]: INTERPOLANT automaton has 13 states [2022-02-20 21:08:17,166 INFO L108 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2022-02-20 21:08:17,166 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 13 interpolants. [2022-02-20 21:08:17,167 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=55, Invalid=595, Unknown=0, NotChecked=0, Total=650 [2022-02-20 21:08:17,167 INFO L87 Difference]: Start difference. First operand 117 states and 152 transitions. Second operand has 13 states, 13 states have (on average 3.4615384615384617) internal successors, (45), 11 states have internal predecessors, (45), 6 states have call successors, (16), 2 states have call predecessors, (16), 4 states have return successors, (15), 8 states have call predecessors, (15), 6 states have call successors, (15) [2022-02-20 21:08:18,880 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 21:08:18,880 INFO L93 Difference]: Finished difference Result 209 states and 275 transitions. [2022-02-20 21:08:18,880 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 13 states. [2022-02-20 21:08:18,881 INFO L78 Accepts]: Start accepts. Automaton has has 13 states, 13 states have (on average 3.4615384615384617) internal successors, (45), 11 states have internal predecessors, (45), 6 states have call successors, (16), 2 states have call predecessors, (16), 4 states have return successors, (15), 8 states have call predecessors, (15), 6 states have call successors, (15) Word has length 105 [2022-02-20 21:08:18,885 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-02-20 21:08:18,885 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 13 states, 13 states have (on average 3.4615384615384617) internal successors, (45), 11 states have internal predecessors, (45), 6 states have call successors, (16), 2 states have call predecessors, (16), 4 states have return successors, (15), 8 states have call predecessors, (15), 6 states have call successors, (15) [2022-02-20 21:08:18,896 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 13 states to 13 states and 275 transitions. [2022-02-20 21:08:18,897 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 13 states, 13 states have (on average 3.4615384615384617) internal successors, (45), 11 states have internal predecessors, (45), 6 states have call successors, (16), 2 states have call predecessors, (16), 4 states have return successors, (15), 8 states have call predecessors, (15), 6 states have call successors, (15) [2022-02-20 21:08:18,907 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 13 states to 13 states and 275 transitions. [2022-02-20 21:08:18,908 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with 13 states and 275 transitions. [2022-02-20 21:08:19,137 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 275 edges. 275 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 21:08:19,142 INFO L225 Difference]: With dead ends: 209 [2022-02-20 21:08:19,142 INFO L226 Difference]: Without dead ends: 174 [2022-02-20 21:08:19,143 INFO L932 BasicCegarLoop]: 0 DeclaredPredicates, 153 GetRequests, 123 SyntacticMatches, 0 SemanticMatches, 30 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 73 ImplicationChecksByTransitivity, 0.4s TimeCoverageRelationStatistics Valid=87, Invalid=905, Unknown=0, NotChecked=0, Total=992 [2022-02-20 21:08:19,144 INFO L933 BasicCegarLoop]: 144 mSDtfsCounter, 151 mSDsluCounter, 1453 mSDsCounter, 0 mSdLazyCounter, 165 mSolverCounterSat, 63 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.2s Time, 0 mProtectedPredicate, 0 mProtectedAction, 169 SdHoareTripleChecker+Valid, 1597 SdHoareTripleChecker+Invalid, 228 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 63 IncrementalHoareTripleChecker+Valid, 165 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.2s IncrementalHoareTripleChecker+Time [2022-02-20 21:08:19,144 INFO L934 BasicCegarLoop]: SdHoareTripleChecker [169 Valid, 1597 Invalid, 228 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [63 Valid, 165 Invalid, 0 Unknown, 0 Unchecked, 0.2s Time] [2022-02-20 21:08:19,145 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 174 states. [2022-02-20 21:08:19,160 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 174 to 125. [2022-02-20 21:08:19,162 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-02-20 21:08:19,162 INFO L82 GeneralOperation]: Start isEquivalent. First operand 174 states. Second operand has 125 states, 77 states have (on average 1.1688311688311688) internal successors, (90), 78 states have internal predecessors, (90), 37 states have call successors, (37), 10 states have call predecessors, (37), 10 states have return successors, (36), 36 states have call predecessors, (36), 36 states have call successors, (36) [2022-02-20 21:08:19,163 INFO L74 IsIncluded]: Start isIncluded. First operand 174 states. Second operand has 125 states, 77 states have (on average 1.1688311688311688) internal successors, (90), 78 states have internal predecessors, (90), 37 states have call successors, (37), 10 states have call predecessors, (37), 10 states have return successors, (36), 36 states have call predecessors, (36), 36 states have call successors, (36) [2022-02-20 21:08:19,164 INFO L87 Difference]: Start difference. First operand 174 states. Second operand has 125 states, 77 states have (on average 1.1688311688311688) internal successors, (90), 78 states have internal predecessors, (90), 37 states have call successors, (37), 10 states have call predecessors, (37), 10 states have return successors, (36), 36 states have call predecessors, (36), 36 states have call successors, (36) [2022-02-20 21:08:19,171 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 21:08:19,173 INFO L93 Difference]: Finished difference Result 174 states and 235 transitions. [2022-02-20 21:08:19,174 INFO L276 IsEmpty]: Start isEmpty. Operand 174 states and 235 transitions. [2022-02-20 21:08:19,176 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 21:08:19,176 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 21:08:19,177 INFO L74 IsIncluded]: Start isIncluded. First operand has 125 states, 77 states have (on average 1.1688311688311688) internal successors, (90), 78 states have internal predecessors, (90), 37 states have call successors, (37), 10 states have call predecessors, (37), 10 states have return successors, (36), 36 states have call predecessors, (36), 36 states have call successors, (36) Second operand 174 states. [2022-02-20 21:08:19,177 INFO L87 Difference]: Start difference. First operand has 125 states, 77 states have (on average 1.1688311688311688) internal successors, (90), 78 states have internal predecessors, (90), 37 states have call successors, (37), 10 states have call predecessors, (37), 10 states have return successors, (36), 36 states have call predecessors, (36), 36 states have call successors, (36) Second operand 174 states. [2022-02-20 21:08:19,192 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 21:08:19,195 INFO L93 Difference]: Finished difference Result 174 states and 235 transitions. [2022-02-20 21:08:19,195 INFO L276 IsEmpty]: Start isEmpty. Operand 174 states and 235 transitions. [2022-02-20 21:08:19,196 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 21:08:19,196 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 21:08:19,196 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-02-20 21:08:19,196 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-02-20 21:08:19,197 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 125 states, 77 states have (on average 1.1688311688311688) internal successors, (90), 78 states have internal predecessors, (90), 37 states have call successors, (37), 10 states have call predecessors, (37), 10 states have return successors, (36), 36 states have call predecessors, (36), 36 states have call successors, (36) [2022-02-20 21:08:19,206 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 125 states to 125 states and 163 transitions. [2022-02-20 21:08:19,206 INFO L78 Accepts]: Start accepts. Automaton has 125 states and 163 transitions. Word has length 105 [2022-02-20 21:08:19,206 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-02-20 21:08:19,206 INFO L470 AbstractCegarLoop]: Abstraction has 125 states and 163 transitions. [2022-02-20 21:08:19,207 INFO L471 AbstractCegarLoop]: INTERPOLANT automaton has has 13 states, 13 states have (on average 3.4615384615384617) internal successors, (45), 11 states have internal predecessors, (45), 6 states have call successors, (16), 2 states have call predecessors, (16), 4 states have return successors, (15), 8 states have call predecessors, (15), 6 states have call successors, (15) [2022-02-20 21:08:19,207 INFO L276 IsEmpty]: Start isEmpty. Operand 125 states and 163 transitions. [2022-02-20 21:08:19,208 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 107 [2022-02-20 21:08:19,208 INFO L506 BasicCegarLoop]: Found error trace [2022-02-20 21:08:19,208 INFO L514 BasicCegarLoop]: trace histogram [6, 6, 6, 3, 3, 3, 3, 3, 3, 2, 2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2022-02-20 21:08:19,229 INFO L552 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (3)] Ended with exit code 0 [2022-02-20 21:08:19,418 WARN L452 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: 3 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true,SelfDestructingSolverStorable2 [2022-02-20 21:08:19,418 INFO L402 AbstractCegarLoop]: === Iteration 4 === Targeting __VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION === [__VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-02-20 21:08:19,419 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-02-20 21:08:19,419 INFO L85 PathProgramCache]: Analyzing trace with hash 864229612, now seen corresponding path program 1 times [2022-02-20 21:08:19,419 INFO L126 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-02-20 21:08:19,419 INFO L338 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [2006530522] [2022-02-20 21:08:19,419 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 21:08:19,420 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-02-20 21:08:19,469 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:19,565 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 2 [2022-02-20 21:08:19,571 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:19,594 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:08:19,596 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:19,608 INFO L290 TraceCheckUtils]: 0: Hoare triple {3269#true} #res := #t~nondet13;havoc #t~nondet13; {3269#true} is VALID [2022-02-20 21:08:19,609 INFO L290 TraceCheckUtils]: 1: Hoare triple {3269#true} assume true; {3269#true} is VALID [2022-02-20 21:08:19,609 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {3269#true} {3269#true} #182#return; {3269#true} is VALID [2022-02-20 21:08:19,609 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 6 [2022-02-20 21:08:19,610 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:19,620 INFO L290 TraceCheckUtils]: 0: Hoare triple {3269#true} ~cond := #in~cond; {3269#true} is VALID [2022-02-20 21:08:19,620 INFO L290 TraceCheckUtils]: 1: Hoare triple {3269#true} assume !(0 == ~cond % 256); {3269#true} is VALID [2022-02-20 21:08:19,620 INFO L290 TraceCheckUtils]: 2: Hoare triple {3269#true} assume true; {3269#true} is VALID [2022-02-20 21:08:19,621 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {3269#true} {3269#true} #184#return; {3269#true} is VALID [2022-02-20 21:08:19,627 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 12 [2022-02-20 21:08:19,629 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:19,652 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:08:19,654 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:19,664 INFO L290 TraceCheckUtils]: 0: Hoare triple {3269#true} ~cond := #in~cond; {3269#true} is VALID [2022-02-20 21:08:19,664 INFO L290 TraceCheckUtils]: 1: Hoare triple {3269#true} assume !(0 == ~cond % 256); {3269#true} is VALID [2022-02-20 21:08:19,664 INFO L290 TraceCheckUtils]: 2: Hoare triple {3269#true} assume true; {3269#true} is VALID [2022-02-20 21:08:19,664 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {3269#true} {3269#true} #192#return; {3269#true} is VALID [2022-02-20 21:08:19,664 INFO L290 TraceCheckUtils]: 0: Hoare triple {3369#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size; {3269#true} is VALID [2022-02-20 21:08:19,665 INFO L272 TraceCheckUtils]: 1: Hoare triple {3269#true} call assume_abort_if_not((if 0 == (if ~size % 18446744073709551616 <= 36028797018963967 then 1 else 0) then 0 else 1)); {3269#true} is VALID [2022-02-20 21:08:19,665 INFO L290 TraceCheckUtils]: 2: Hoare triple {3269#true} ~cond := #in~cond; {3269#true} is VALID [2022-02-20 21:08:19,665 INFO L290 TraceCheckUtils]: 3: Hoare triple {3269#true} assume !(0 == ~cond % 256); {3269#true} is VALID [2022-02-20 21:08:19,665 INFO L290 TraceCheckUtils]: 4: Hoare triple {3269#true} assume true; {3269#true} is VALID [2022-02-20 21:08:19,665 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {3269#true} {3269#true} #192#return; {3269#true} is VALID [2022-02-20 21:08:19,665 INFO L290 TraceCheckUtils]: 6: Hoare triple {3269#true} call #t~malloc555.base, #t~malloc555.offset := #Ultimate.allocOnHeap(~size);#res.base, #res.offset := #t~malloc555.base, #t~malloc555.offset;havoc #t~malloc555.base, #t~malloc555.offset; {3269#true} is VALID [2022-02-20 21:08:19,666 INFO L290 TraceCheckUtils]: 7: Hoare triple {3269#true} assume true; {3269#true} is VALID [2022-02-20 21:08:19,666 INFO L284 TraceCheckUtils]: 8: Hoare quadruple {3269#true} {3269#true} #186#return; {3269#true} is VALID [2022-02-20 21:08:19,666 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 23 [2022-02-20 21:08:19,667 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:19,675 INFO L290 TraceCheckUtils]: 0: Hoare triple {3269#true} #res := #t~nondet8;havoc #t~nondet8; {3269#true} is VALID [2022-02-20 21:08:19,676 INFO L290 TraceCheckUtils]: 1: Hoare triple {3269#true} assume true; {3269#true} is VALID [2022-02-20 21:08:19,676 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {3269#true} {3269#true} #188#return; {3269#true} is VALID [2022-02-20 21:08:19,676 INFO L290 TraceCheckUtils]: 0: Hoare triple {3349#(and (= |old(#length)| |#length|) (= |old(#memory_real)| |#memory_real|) (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|) (= |old(#valid)| |#valid|))} ~max_size#1 := #in~max_size#1; {3269#true} is VALID [2022-02-20 21:08:19,676 INFO L272 TraceCheckUtils]: 1: Hoare triple {3269#true} call #t~ret540#1 := nondet_uint64_t(); {3269#true} is VALID [2022-02-20 21:08:19,684 INFO L290 TraceCheckUtils]: 2: Hoare triple {3269#true} #res := #t~nondet13;havoc #t~nondet13; {3269#true} is VALID [2022-02-20 21:08:19,684 INFO L290 TraceCheckUtils]: 3: Hoare triple {3269#true} assume true; {3269#true} is VALID [2022-02-20 21:08:19,684 INFO L284 TraceCheckUtils]: 4: Hoare quadruple {3269#true} {3269#true} #182#return; {3269#true} is VALID [2022-02-20 21:08:19,685 INFO L290 TraceCheckUtils]: 5: Hoare triple {3269#true} ~len~1#1 := #t~ret540#1;havoc #t~ret540#1; {3269#true} is VALID [2022-02-20 21:08:19,685 INFO L272 TraceCheckUtils]: 6: Hoare triple {3269#true} call assume_abort_if_not((if 0 == (if ~len~1#1 % 18446744073709551616 < ~max_size#1 % 18446744073709551616 then 1 else 0) then 0 else 1)); {3269#true} is VALID [2022-02-20 21:08:19,685 INFO L290 TraceCheckUtils]: 7: Hoare triple {3269#true} ~cond := #in~cond; {3269#true} is VALID [2022-02-20 21:08:19,685 INFO L290 TraceCheckUtils]: 8: Hoare triple {3269#true} assume !(0 == ~cond % 256); {3269#true} is VALID [2022-02-20 21:08:19,685 INFO L290 TraceCheckUtils]: 9: Hoare triple {3269#true} assume true; {3269#true} is VALID [2022-02-20 21:08:19,685 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {3269#true} {3269#true} #184#return; {3269#true} is VALID [2022-02-20 21:08:19,685 INFO L290 TraceCheckUtils]: 11: Hoare triple {3269#true} assume { :begin_inline_ensure_string_is_allocated } true;ensure_string_is_allocated_#in~len#1 := ~len~1#1;havoc ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset;havoc ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset, ensure_string_is_allocated_#t~ret543#1, ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset, ensure_string_is_allocated_#t~ret544#1.base, ensure_string_is_allocated_#t~ret544#1.offset, ensure_string_is_allocated_~len#1, ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset;ensure_string_is_allocated_~len#1 := ensure_string_is_allocated_#in~len#1; {3269#true} is VALID [2022-02-20 21:08:19,686 INFO L272 TraceCheckUtils]: 12: Hoare triple {3269#true} call ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset := bounded_malloc(-1234550 + ensure_string_is_allocated_~len#1); {3369#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:08:19,686 INFO L290 TraceCheckUtils]: 13: Hoare triple {3369#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size; {3269#true} is VALID [2022-02-20 21:08:19,687 INFO L272 TraceCheckUtils]: 14: Hoare triple {3269#true} call assume_abort_if_not((if 0 == (if ~size % 18446744073709551616 <= 36028797018963967 then 1 else 0) then 0 else 1)); {3269#true} is VALID [2022-02-20 21:08:19,687 INFO L290 TraceCheckUtils]: 15: Hoare triple {3269#true} ~cond := #in~cond; {3269#true} is VALID [2022-02-20 21:08:19,687 INFO L290 TraceCheckUtils]: 16: Hoare triple {3269#true} assume !(0 == ~cond % 256); {3269#true} is VALID [2022-02-20 21:08:19,687 INFO L290 TraceCheckUtils]: 17: Hoare triple {3269#true} assume true; {3269#true} is VALID [2022-02-20 21:08:19,687 INFO L284 TraceCheckUtils]: 18: Hoare quadruple {3269#true} {3269#true} #192#return; {3269#true} is VALID [2022-02-20 21:08:19,687 INFO L290 TraceCheckUtils]: 19: Hoare triple {3269#true} call #t~malloc555.base, #t~malloc555.offset := #Ultimate.allocOnHeap(~size);#res.base, #res.offset := #t~malloc555.base, #t~malloc555.offset;havoc #t~malloc555.base, #t~malloc555.offset; {3269#true} is VALID [2022-02-20 21:08:19,687 INFO L290 TraceCheckUtils]: 20: Hoare triple {3269#true} assume true; {3269#true} is VALID [2022-02-20 21:08:19,688 INFO L284 TraceCheckUtils]: 21: Hoare quadruple {3269#true} {3269#true} #186#return; {3269#true} is VALID [2022-02-20 21:08:19,688 INFO L290 TraceCheckUtils]: 22: Hoare triple {3269#true} ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset := ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset;havoc ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset; {3269#true} is VALID [2022-02-20 21:08:19,688 INFO L272 TraceCheckUtils]: 23: Hoare triple {3269#true} call ensure_string_is_allocated_#t~ret543#1 := nondet_bool(); {3269#true} is VALID [2022-02-20 21:08:19,688 INFO L290 TraceCheckUtils]: 24: Hoare triple {3269#true} #res := #t~nondet8;havoc #t~nondet8; {3269#true} is VALID [2022-02-20 21:08:19,688 INFO L290 TraceCheckUtils]: 25: Hoare triple {3269#true} assume true; {3269#true} is VALID [2022-02-20 21:08:19,688 INFO L284 TraceCheckUtils]: 26: Hoare quadruple {3269#true} {3269#true} #188#return; {3269#true} is VALID [2022-02-20 21:08:19,689 INFO L290 TraceCheckUtils]: 27: Hoare triple {3269#true} assume !(0 != ensure_string_is_allocated_#t~ret543#1 % 256);ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset := 0, 0; {3269#true} is VALID [2022-02-20 21:08:19,689 INFO L290 TraceCheckUtils]: 28: Hoare triple {3269#true} call write~$Pointer$(ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset, ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset, 8);havoc ensure_string_is_allocated_#t~ret543#1;havoc ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset;havoc ensure_string_is_allocated_#t~ret544#1.base, ensure_string_is_allocated_#t~ret544#1.offset;call write~int(ensure_string_is_allocated_~len#1, ensure_string_is_allocated_~str~0#1.base, 8 + ensure_string_is_allocated_~str~0#1.offset, 8);call write~int(0, ensure_string_is_allocated_~str~0#1.base, 16 + ensure_string_is_allocated_~str~0#1.offset + (if ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 else ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset := ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset; {3269#true} is VALID [2022-02-20 21:08:19,689 INFO L290 TraceCheckUtils]: 29: Hoare triple {3269#true} #t~ret541#1.base, #t~ret541#1.offset := ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset;assume { :end_inline_ensure_string_is_allocated } true;#res#1.base, #res#1.offset := #t~ret541#1.base, #t~ret541#1.offset;havoc #t~ret541#1.base, #t~ret541#1.offset; {3269#true} is VALID [2022-02-20 21:08:19,689 INFO L290 TraceCheckUtils]: 30: Hoare triple {3269#true} assume true; {3269#true} is VALID [2022-02-20 21:08:19,689 INFO L284 TraceCheckUtils]: 31: Hoare quadruple {3269#true} {3269#true} #198#return; {3269#true} is VALID [2022-02-20 21:08:19,690 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 36 [2022-02-20 21:08:19,693 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:19,700 INFO L290 TraceCheckUtils]: 0: Hoare triple {3269#true} #res := #t~nondet8;havoc #t~nondet8; {3269#true} is VALID [2022-02-20 21:08:19,700 INFO L290 TraceCheckUtils]: 1: Hoare triple {3269#true} assume true; {3269#true} is VALID [2022-02-20 21:08:19,700 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {3269#true} {3269#true} #200#return; {3269#true} is VALID [2022-02-20 21:08:19,700 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 42 [2022-02-20 21:08:19,705 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:19,718 INFO L290 TraceCheckUtils]: 0: Hoare triple {3269#true} ~str.base, ~str.offset := #in~str.base, #in~str.offset;#t~short464 := ~str.base != 0 || ~str.offset != 0; {3269#true} is VALID [2022-02-20 21:08:19,719 INFO L290 TraceCheckUtils]: 1: Hoare triple {3269#true} assume #t~short464;call #t~mem463 := read~int(~str.base, 8 + ~str.offset, 8);#t~short464 := 0 == (1 + #t~mem463) % 18446744073709551616 || ~str.base != 0 || 16 + ~str.offset != 0; {3269#true} is VALID [2022-02-20 21:08:19,719 INFO L290 TraceCheckUtils]: 2: Hoare triple {3269#true} #t~short467 := #t~short464; {3269#true} is VALID [2022-02-20 21:08:19,719 INFO L290 TraceCheckUtils]: 3: Hoare triple {3269#true} assume #t~short467;call #t~mem465 := read~int(~str.base, 8 + ~str.offset, 8);call #t~mem466 := read~int(~str.base, 16 + ~str.offset + (if #t~mem465 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then #t~mem465 % 18446744073709551616 % 18446744073709551616 else #t~mem465 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);#t~short467 := 0 == #t~mem466 % 256; {3269#true} is VALID [2022-02-20 21:08:19,719 INFO L290 TraceCheckUtils]: 4: Hoare triple {3269#true} #res := (if 0 == (if #t~short467 then 1 else 0) then 0 else 1);havoc #t~mem463;havoc #t~short464;havoc #t~mem465;havoc #t~mem466;havoc #t~short467; {3269#true} is VALID [2022-02-20 21:08:19,719 INFO L290 TraceCheckUtils]: 5: Hoare triple {3269#true} assume true; {3269#true} is VALID [2022-02-20 21:08:19,720 INFO L284 TraceCheckUtils]: 6: Hoare quadruple {3269#true} {3307#(and (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.offset| |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base|))} #204#return; {3307#(and (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.offset| |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base|))} is VALID [2022-02-20 21:08:19,720 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 50 [2022-02-20 21:08:19,724 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:19,732 INFO L290 TraceCheckUtils]: 0: Hoare triple {3269#true} ~cond := #in~cond; {3269#true} is VALID [2022-02-20 21:08:19,733 INFO L290 TraceCheckUtils]: 1: Hoare triple {3269#true} assume !(0 == ~cond % 256); {3269#true} is VALID [2022-02-20 21:08:19,733 INFO L290 TraceCheckUtils]: 2: Hoare triple {3269#true} assume true; {3269#true} is VALID [2022-02-20 21:08:19,734 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {3269#true} {3307#(and (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.offset| |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base|))} #206#return; {3307#(and (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.offset| |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base|))} is VALID [2022-02-20 21:08:19,734 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 56 [2022-02-20 21:08:19,738 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:19,770 INFO L290 TraceCheckUtils]: 0: Hoare triple {3269#true} ~str.base, ~str.offset := #in~str.base, #in~str.offset;#t~short464 := ~str.base != 0 || ~str.offset != 0; {3269#true} is VALID [2022-02-20 21:08:19,770 INFO L290 TraceCheckUtils]: 1: Hoare triple {3269#true} assume #t~short464;call #t~mem463 := read~int(~str.base, 8 + ~str.offset, 8);#t~short464 := 0 == (1 + #t~mem463) % 18446744073709551616 || ~str.base != 0 || 16 + ~str.offset != 0; {3269#true} is VALID [2022-02-20 21:08:19,771 INFO L290 TraceCheckUtils]: 2: Hoare triple {3269#true} #t~short467 := #t~short464; {3269#true} is VALID [2022-02-20 21:08:19,771 INFO L290 TraceCheckUtils]: 3: Hoare triple {3269#true} assume #t~short467;call #t~mem465 := read~int(~str.base, 8 + ~str.offset, 8);call #t~mem466 := read~int(~str.base, 16 + ~str.offset + (if #t~mem465 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then #t~mem465 % 18446744073709551616 % 18446744073709551616 else #t~mem465 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);#t~short467 := 0 == #t~mem466 % 256; {3269#true} is VALID [2022-02-20 21:08:19,771 INFO L290 TraceCheckUtils]: 4: Hoare triple {3269#true} #res := (if 0 == (if #t~short467 then 1 else 0) then 0 else 1);havoc #t~mem463;havoc #t~short464;havoc #t~mem465;havoc #t~mem466;havoc #t~short467; {3269#true} is VALID [2022-02-20 21:08:19,771 INFO L290 TraceCheckUtils]: 5: Hoare triple {3269#true} assume true; {3269#true} is VALID [2022-02-20 21:08:19,772 INFO L284 TraceCheckUtils]: 6: Hoare quadruple {3269#true} {3307#(and (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.offset| |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base|))} #208#return; {3307#(and (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.offset| |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base|))} is VALID [2022-02-20 21:08:19,772 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 64 [2022-02-20 21:08:19,774 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:19,782 INFO L290 TraceCheckUtils]: 0: Hoare triple {3269#true} ~cond := #in~cond; {3269#true} is VALID [2022-02-20 21:08:19,782 INFO L290 TraceCheckUtils]: 1: Hoare triple {3269#true} assume !(0 == ~cond % 256); {3269#true} is VALID [2022-02-20 21:08:19,782 INFO L290 TraceCheckUtils]: 2: Hoare triple {3269#true} assume true; {3269#true} is VALID [2022-02-20 21:08:19,783 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {3269#true} {3307#(and (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.offset| |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base|))} #210#return; {3307#(and (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.offset| |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base|))} is VALID [2022-02-20 21:08:19,783 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 71 [2022-02-20 21:08:19,785 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:19,793 INFO L290 TraceCheckUtils]: 0: Hoare triple {3269#true} ~cond := #in~cond; {3269#true} is VALID [2022-02-20 21:08:19,794 INFO L290 TraceCheckUtils]: 1: Hoare triple {3269#true} assume !(0 == ~cond % 256); {3269#true} is VALID [2022-02-20 21:08:19,794 INFO L290 TraceCheckUtils]: 2: Hoare triple {3269#true} assume true; {3269#true} is VALID [2022-02-20 21:08:19,794 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {3269#true} {3330#(and (= |ULTIMATE.start_aws_string_eq_~b#1.offset| |ULTIMATE.start_aws_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_string_eq_~a#1.base| |ULTIMATE.start_aws_string_eq_~b#1.base|))} #214#return; {3330#(and (= |ULTIMATE.start_aws_string_eq_~b#1.offset| |ULTIMATE.start_aws_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_string_eq_~a#1.base| |ULTIMATE.start_aws_string_eq_~b#1.base|))} is VALID [2022-02-20 21:08:19,795 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 78 [2022-02-20 21:08:19,799 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:19,810 INFO L290 TraceCheckUtils]: 0: Hoare triple {3269#true} ~str.base, ~str.offset := #in~str.base, #in~str.offset;#t~short464 := ~str.base != 0 || ~str.offset != 0; {3269#true} is VALID [2022-02-20 21:08:19,811 INFO L290 TraceCheckUtils]: 1: Hoare triple {3269#true} assume #t~short464;call #t~mem463 := read~int(~str.base, 8 + ~str.offset, 8);#t~short464 := 0 == (1 + #t~mem463) % 18446744073709551616 || ~str.base != 0 || 16 + ~str.offset != 0; {3269#true} is VALID [2022-02-20 21:08:19,811 INFO L290 TraceCheckUtils]: 2: Hoare triple {3269#true} #t~short467 := #t~short464; {3269#true} is VALID [2022-02-20 21:08:19,811 INFO L290 TraceCheckUtils]: 3: Hoare triple {3269#true} assume #t~short467;call #t~mem465 := read~int(~str.base, 8 + ~str.offset, 8);call #t~mem466 := read~int(~str.base, 16 + ~str.offset + (if #t~mem465 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then #t~mem465 % 18446744073709551616 % 18446744073709551616 else #t~mem465 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);#t~short467 := 0 == #t~mem466 % 256; {3269#true} is VALID [2022-02-20 21:08:19,812 INFO L290 TraceCheckUtils]: 4: Hoare triple {3269#true} #res := (if 0 == (if #t~short467 then 1 else 0) then 0 else 1);havoc #t~mem463;havoc #t~short464;havoc #t~mem465;havoc #t~mem466;havoc #t~short467; {3269#true} is VALID [2022-02-20 21:08:19,812 INFO L290 TraceCheckUtils]: 5: Hoare triple {3269#true} assume true; {3269#true} is VALID [2022-02-20 21:08:19,812 INFO L284 TraceCheckUtils]: 6: Hoare quadruple {3269#true} {3330#(and (= |ULTIMATE.start_aws_string_eq_~b#1.offset| |ULTIMATE.start_aws_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_string_eq_~a#1.base| |ULTIMATE.start_aws_string_eq_~b#1.base|))} #216#return; {3330#(and (= |ULTIMATE.start_aws_string_eq_~b#1.offset| |ULTIMATE.start_aws_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_string_eq_~a#1.base| |ULTIMATE.start_aws_string_eq_~b#1.base|))} is VALID [2022-02-20 21:08:19,813 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 87 [2022-02-20 21:08:19,815 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:19,823 INFO L290 TraceCheckUtils]: 0: Hoare triple {3269#true} ~cond := #in~cond; {3269#true} is VALID [2022-02-20 21:08:19,824 INFO L290 TraceCheckUtils]: 1: Hoare triple {3269#true} assume !(0 == ~cond % 256); {3269#true} is VALID [2022-02-20 21:08:19,824 INFO L290 TraceCheckUtils]: 2: Hoare triple {3269#true} assume true; {3269#true} is VALID [2022-02-20 21:08:19,825 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {3269#true} {3330#(and (= |ULTIMATE.start_aws_string_eq_~b#1.offset| |ULTIMATE.start_aws_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_string_eq_~a#1.base| |ULTIMATE.start_aws_string_eq_~b#1.base|))} #218#return; {3330#(and (= |ULTIMATE.start_aws_string_eq_~b#1.offset| |ULTIMATE.start_aws_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_string_eq_~a#1.base| |ULTIMATE.start_aws_string_eq_~b#1.base|))} is VALID [2022-02-20 21:08:19,825 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 96 [2022-02-20 21:08:19,826 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:19,833 INFO L290 TraceCheckUtils]: 0: Hoare triple {3269#true} ~str.base, ~str.offset := #in~str.base, #in~str.offset;#res := (if 0 == (if (~str.base != 0 || ~str.offset != 0) && (~str.base != 0 || ~str.offset != 0) then 1 else 0) then 0 else 1); {3269#true} is VALID [2022-02-20 21:08:19,835 INFO L290 TraceCheckUtils]: 1: Hoare triple {3269#true} assume true; {3269#true} is VALID [2022-02-20 21:08:19,835 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {3269#true} {3270#false} #222#return; {3270#false} is VALID [2022-02-20 21:08:19,835 INFO L290 TraceCheckUtils]: 0: Hoare triple {3269#true} assume { :begin_inline_ULTIMATE.init } true;#NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(38, 2);call #Ultimate.allocInit(12, 3);call #Ultimate.allocInit(78, 4);~#s_can_fail_allocator_static~0.base, ~#s_can_fail_allocator_static~0.offset := 5, 0;call #Ultimate.allocInit(40, 5);call write~init~$Pointer$(#funAddr~s_can_fail_malloc_allocator.base, #funAddr~s_can_fail_malloc_allocator.offset, ~#s_can_fail_allocator_static~0.base, ~#s_can_fail_allocator_static~0.offset, 8);call write~init~$Pointer$(#funAddr~s_can_fail_free_allocator.base, #funAddr~s_can_fail_free_allocator.offset, ~#s_can_fail_allocator_static~0.base, 8 + ~#s_can_fail_allocator_static~0.offset, 8);call write~init~$Pointer$(#funAddr~s_can_fail_realloc_allocator.base, #funAddr~s_can_fail_realloc_allocator.offset, ~#s_can_fail_allocator_static~0.base, 16 + ~#s_can_fail_allocator_static~0.offset, 8);call write~init~$Pointer$(#funAddr~s_can_fail_calloc_allocator.base, #funAddr~s_can_fail_calloc_allocator.offset, ~#s_can_fail_allocator_static~0.base, 24 + ~#s_can_fail_allocator_static~0.offset, 8);call write~init~$Pointer$(0, 0, ~#s_can_fail_allocator_static~0.base, 32 + ~#s_can_fail_allocator_static~0.offset, 8);~#s_tolower_table~0.base, ~#s_tolower_table~0.offset := 6, 0;call #Ultimate.allocInit(256, 6);call write~init~int(0, ~#s_tolower_table~0.base, ~#s_tolower_table~0.offset, 1);call write~init~int(1, ~#s_tolower_table~0.base, 1 + ~#s_tolower_table~0.offset, 1);call write~init~int(2, ~#s_tolower_table~0.base, 2 + ~#s_tolower_table~0.offset, 1);call write~init~int(3, ~#s_tolower_table~0.base, 3 + ~#s_tolower_table~0.offset, 1);call write~init~int(4, ~#s_tolower_table~0.base, 4 + ~#s_tolower_table~0.offset, 1);call write~init~int(5, ~#s_tolower_table~0.base, 5 + ~#s_tolower_table~0.offset, 1);call write~init~int(6, ~#s_tolower_table~0.base, 6 + ~#s_tolower_table~0.offset, 1);call write~init~int(7, ~#s_tolower_table~0.base, 7 + ~#s_tolower_table~0.offset, 1);call write~init~int(8, ~#s_tolower_table~0.base, 8 + ~#s_tolower_table~0.offset, 1);call write~init~int(9, ~#s_tolower_table~0.base, 9 + ~#s_tolower_table~0.offset, 1);call write~init~int(10, ~#s_tolower_table~0.base, 10 + ~#s_tolower_table~0.offset, 1);call write~init~int(11, ~#s_tolower_table~0.base, 11 + ~#s_tolower_table~0.offset, 1);call write~init~int(12, ~#s_tolower_table~0.base, 12 + ~#s_tolower_table~0.offset, 1);call write~init~int(13, ~#s_tolower_table~0.base, 13 + ~#s_tolower_table~0.offset, 1);call write~init~int(14, ~#s_tolower_table~0.base, 14 + ~#s_tolower_table~0.offset, 1);call write~init~int(15, ~#s_tolower_table~0.base, 15 + ~#s_tolower_table~0.offset, 1);call write~init~int(16, ~#s_tolower_table~0.base, 16 + ~#s_tolower_table~0.offset, 1);call write~init~int(17, ~#s_tolower_table~0.base, 17 + ~#s_tolower_table~0.offset, 1);call write~init~int(18, ~#s_tolower_table~0.base, 18 + ~#s_tolower_table~0.offset, 1);call write~init~int(19, ~#s_tolower_table~0.base, 19 + ~#s_tolower_table~0.offset, 1);call write~init~int(20, ~#s_tolower_table~0.base, 20 + ~#s_tolower_table~0.offset, 1);call write~init~int(21, ~#s_tolower_table~0.base, 21 + ~#s_tolower_table~0.offset, 1);call write~init~int(22, ~#s_tolower_table~0.base, 22 + ~#s_tolower_table~0.offset, 1);call write~init~int(23, ~#s_tolower_table~0.base, 23 + ~#s_tolower_table~0.offset, 1);call write~init~int(24, ~#s_tolower_table~0.base, 24 + ~#s_tolower_table~0.offset, 1);call write~init~int(25, ~#s_tolower_table~0.base, 25 + ~#s_tolower_table~0.offset, 1);call write~init~int(26, ~#s_tolower_table~0.base, 26 + ~#s_tolower_table~0.offset, 1);call write~init~int(27, ~#s_tolower_table~0.base, 27 + ~#s_tolower_table~0.offset, 1);call write~init~int(28, ~#s_tolower_table~0.base, 28 + ~#s_tolower_table~0.offset, 1);call write~init~int(29, ~#s_tolower_table~0.base, 29 + ~#s_tolower_table~0.offset, 1);call write~init~int(30, ~#s_tolower_table~0.base, 30 + ~#s_tolower_table~0.offset, 1);call write~init~int(31, ~#s_tolower_table~0.base, 31 + ~#s_tolower_table~0.offset, 1);call write~init~int(32, ~#s_tolower_table~0.base, 32 + ~#s_tolower_table~0.offset, 1);call write~init~int(33, ~#s_tolower_table~0.base, 33 + ~#s_tolower_table~0.offset, 1);call write~init~int(34, ~#s_tolower_table~0.base, 34 + ~#s_tolower_table~0.offset, 1);call write~init~int(35, ~#s_tolower_table~0.base, 35 + ~#s_tolower_table~0.offset, 1);call write~init~int(36, ~#s_tolower_table~0.base, 36 + ~#s_tolower_table~0.offset, 1);call write~init~int(37, ~#s_tolower_table~0.base, 37 + ~#s_tolower_table~0.offset, 1);call write~init~int(38, ~#s_tolower_table~0.base, 38 + ~#s_tolower_table~0.offset, 1);call write~init~int(39, ~#s_tolower_table~0.base, 39 + ~#s_tolower_table~0.offset, 1);call write~init~int(40, ~#s_tolower_table~0.base, 40 + ~#s_tolower_table~0.offset, 1);call write~init~int(41, ~#s_tolower_table~0.base, 41 + ~#s_tolower_table~0.offset, 1);call write~init~int(42, ~#s_tolower_table~0.base, 42 + ~#s_tolower_table~0.offset, 1);call write~init~int(43, ~#s_tolower_table~0.base, 43 + ~#s_tolower_table~0.offset, 1);call write~init~int(44, ~#s_tolower_table~0.base, 44 + ~#s_tolower_table~0.offset, 1);call write~init~int(45, ~#s_tolower_table~0.base, 45 + ~#s_tolower_table~0.offset, 1);call write~init~int(46, ~#s_tolower_table~0.base, 46 + ~#s_tolower_table~0.offset, 1);call write~init~int(47, ~#s_tolower_table~0.base, 47 + ~#s_tolower_table~0.offset, 1);call write~init~int(48, ~#s_tolower_table~0.base, 48 + ~#s_tolower_table~0.offset, 1);call write~init~int(49, ~#s_tolower_table~0.base, 49 + ~#s_tolower_table~0.offset, 1);call write~init~int(50, ~#s_tolower_table~0.base, 50 + ~#s_tolower_table~0.offset, 1);call write~init~int(51, ~#s_tolower_table~0.base, 51 + ~#s_tolower_table~0.offset, 1);call write~init~int(52, ~#s_tolower_table~0.base, 52 + ~#s_tolower_table~0.offset, 1);call write~init~int(53, ~#s_tolower_table~0.base, 53 + ~#s_tolower_table~0.offset, 1);call write~init~int(54, ~#s_tolower_table~0.base, 54 + ~#s_tolower_table~0.offset, 1);call write~init~int(55, ~#s_tolower_table~0.base, 55 + ~#s_tolower_table~0.offset, 1);call write~init~int(56, ~#s_tolower_table~0.base, 56 + ~#s_tolower_table~0.offset, 1);call write~init~int(57, ~#s_tolower_table~0.base, 57 + ~#s_tolower_table~0.offset, 1);call write~init~int(58, ~#s_tolower_table~0.base, 58 + ~#s_tolower_table~0.offset, 1);call write~init~int(59, ~#s_tolower_table~0.base, 59 + ~#s_tolower_table~0.offset, 1);call write~init~int(60, ~#s_tolower_table~0.base, 60 + ~#s_tolower_table~0.offset, 1);call write~init~int(61, ~#s_tolower_table~0.base, 61 + ~#s_tolower_table~0.offset, 1);call write~init~int(62, ~#s_tolower_table~0.base, 62 + ~#s_tolower_table~0.offset, 1);call write~init~int(63, ~#s_tolower_table~0.base, 63 + ~#s_tolower_table~0.offset, 1);call write~init~int(64, ~#s_tolower_table~0.base, 64 + ~#s_tolower_table~0.offset, 1);call write~init~int(97, ~#s_tolower_table~0.base, 65 + ~#s_tolower_table~0.offset, 1);call write~init~int(98, ~#s_tolower_table~0.base, 66 + ~#s_tolower_table~0.offset, 1);call write~init~int(99, ~#s_tolower_table~0.base, 67 + ~#s_tolower_table~0.offset, 1);call write~init~int(100, ~#s_tolower_table~0.base, 68 + ~#s_tolower_table~0.offset, 1);call write~init~int(101, ~#s_tolower_table~0.base, 69 + ~#s_tolower_table~0.offset, 1);call write~init~int(102, ~#s_tolower_table~0.base, 70 + ~#s_tolower_table~0.offset, 1);call write~init~int(103, ~#s_tolower_table~0.base, 71 + ~#s_tolower_table~0.offset, 1);call write~init~int(104, ~#s_tolower_table~0.base, 72 + ~#s_tolower_table~0.offset, 1);call write~init~int(105, ~#s_tolower_table~0.base, 73 + ~#s_tolower_table~0.offset, 1);call write~init~int(106, ~#s_tolower_table~0.base, 74 + ~#s_tolower_table~0.offset, 1);call write~init~int(107, ~#s_tolower_table~0.base, 75 + ~#s_tolower_table~0.offset, 1);call write~init~int(108, ~#s_tolower_table~0.base, 76 + ~#s_tolower_table~0.offset, 1);call write~init~int(109, ~#s_tolower_table~0.base, 77 + ~#s_tolower_table~0.offset, 1);call write~init~int(110, ~#s_tolower_table~0.base, 78 + ~#s_tolower_table~0.offset, 1);call write~init~int(111, ~#s_tolower_table~0.base, 79 + ~#s_tolower_table~0.offset, 1);call write~init~int(112, ~#s_tolower_table~0.base, 80 + ~#s_tolower_table~0.offset, 1);call write~init~int(113, ~#s_tolower_table~0.base, 81 + ~#s_tolower_table~0.offset, 1);call write~init~int(114, ~#s_tolower_table~0.base, 82 + ~#s_tolower_table~0.offset, 1);call write~init~int(115, ~#s_tolower_table~0.base, 83 + ~#s_tolower_table~0.offset, 1);call write~init~int(116, ~#s_tolower_table~0.base, 84 + ~#s_tolower_table~0.offset, 1);call write~init~int(117, ~#s_tolower_table~0.base, 85 + ~#s_tolower_table~0.offset, 1);call write~init~int(118, ~#s_tolower_table~0.base, 86 + ~#s_tolower_table~0.offset, 1);call write~init~int(119, ~#s_tolower_table~0.base, 87 + ~#s_tolower_table~0.offset, 1);call write~init~int(120, ~#s_tolower_table~0.base, 88 + ~#s_tolower_table~0.offset, 1);call write~init~int(121, ~#s_tolower_table~0.base, 89 + ~#s_tolower_table~0.offset, 1);call write~init~int(122, ~#s_tolower_table~0.base, 90 + ~#s_tolower_table~0.offset, 1);call write~init~int(91, ~#s_tolower_table~0.base, 91 + ~#s_tolower_table~0.offset, 1);call write~init~int(92, ~#s_tolower_table~0.base, 92 + ~#s_tolower_table~0.offset, 1);call write~init~int(93, ~#s_tolower_table~0.base, 93 + ~#s_tolower_table~0.offset, 1);call write~init~int(94, ~#s_tolower_table~0.base, 94 + ~#s_tolower_table~0.offset, 1);call write~init~int(95, ~#s_tolower_table~0.base, 95 + ~#s_tolower_table~0.offset, 1);call write~init~int(96, ~#s_tolower_table~0.base, 96 + ~#s_tolower_table~0.offset, 1);call write~init~int(97, ~#s_tolower_table~0.base, 97 + ~#s_tolower_table~0.offset, 1);call write~init~int(98, ~#s_tolower_table~0.base, 98 + ~#s_tolower_table~0.offset, 1);call write~init~int(99, ~#s_tolower_table~0.base, 99 + ~#s_tolower_table~0.offset, 1);call write~init~int(100, ~#s_tolower_table~0.base, 100 + ~#s_tolower_table~0.offset, 1);call write~init~int(101, ~#s_tolower_table~0.base, 101 + ~#s_tolower_table~0.offset, 1);call write~init~int(102, ~#s_tolower_table~0.base, 102 + ~#s_tolower_table~0.offset, 1);call write~init~int(103, ~#s_tolower_table~0.base, 103 + ~#s_tolower_table~0.offset, 1);call write~init~int(104, ~#s_tolower_table~0.base, 104 + ~#s_tolower_table~0.offset, 1);call write~init~int(105, ~#s_tolower_table~0.base, 105 + ~#s_tolower_table~0.offset, 1);call write~init~int(106, ~#s_tolower_table~0.base, 106 + ~#s_tolower_table~0.offset, 1);call write~init~int(107, ~#s_tolower_table~0.base, 107 + ~#s_tolower_table~0.offset, 1);call write~init~int(108, ~#s_tolower_table~0.base, 108 + ~#s_tolower_table~0.offset, 1);call write~init~int(109, ~#s_tolower_table~0.base, 109 + ~#s_tolower_table~0.offset, 1);call write~init~int(110, ~#s_tolower_table~0.base, 110 + ~#s_tolower_table~0.offset, 1);call write~init~int(111, ~#s_tolower_table~0.base, 111 + ~#s_tolower_table~0.offset, 1);call write~init~int(112, ~#s_tolower_table~0.base, 112 + ~#s_tolower_table~0.offset, 1);call write~init~int(113, ~#s_tolower_table~0.base, 113 + ~#s_tolower_table~0.offset, 1);call write~init~int(114, ~#s_tolower_table~0.base, 114 + ~#s_tolower_table~0.offset, 1);call write~init~int(115, ~#s_tolower_table~0.base, 115 + ~#s_tolower_table~0.offset, 1);call write~init~int(116, ~#s_tolower_table~0.base, 116 + ~#s_tolower_table~0.offset, 1);call write~init~int(117, ~#s_tolower_table~0.base, 117 + ~#s_tolower_table~0.offset, 1);call write~init~int(118, ~#s_tolower_table~0.base, 118 + ~#s_tolower_table~0.offset, 1);call write~init~int(119, ~#s_tolower_table~0.base, 119 + ~#s_tolower_table~0.offset, 1);call write~init~int(120, ~#s_tolower_table~0.base, 120 + ~#s_tolower_table~0.offset, 1);call write~init~int(121, ~#s_tolower_table~0.base, 121 + ~#s_tolower_table~0.offset, 1);call write~init~int(122, ~#s_tolower_table~0.base, 122 + ~#s_tolower_table~0.offset, 1);call write~init~int(123, ~#s_tolower_table~0.base, 123 + ~#s_tolower_table~0.offset, 1);call write~init~int(124, ~#s_tolower_table~0.base, 124 + ~#s_tolower_table~0.offset, 1);call write~init~int(125, ~#s_tolower_table~0.base, 125 + ~#s_tolower_table~0.offset, 1);call write~init~int(126, ~#s_tolower_table~0.base, 126 + ~#s_tolower_table~0.offset, 1);call write~init~int(127, ~#s_tolower_table~0.base, 127 + ~#s_tolower_table~0.offset, 1);call write~init~int(128, ~#s_tolower_table~0.base, 128 + ~#s_tolower_table~0.offset, 1);call write~init~int(129, ~#s_tolower_table~0.base, 129 + ~#s_tolower_table~0.offset, 1);call write~init~int(130, ~#s_tolower_table~0.base, 130 + ~#s_tolower_table~0.offset, 1);call write~init~int(131, ~#s_tolower_table~0.base, 131 + ~#s_tolower_table~0.offset, 1);call write~init~int(132, ~#s_tolower_table~0.base, 132 + ~#s_tolower_table~0.offset, 1);call write~init~int(133, ~#s_tolower_table~0.base, 133 + ~#s_tolower_table~0.offset, 1);call write~init~int(134, ~#s_tolower_table~0.base, 134 + ~#s_tolower_table~0.offset, 1);call write~init~int(135, ~#s_tolower_table~0.base, 135 + ~#s_tolower_table~0.offset, 1);call write~init~int(136, ~#s_tolower_table~0.base, 136 + ~#s_tolower_table~0.offset, 1);call write~init~int(137, ~#s_tolower_table~0.base, 137 + ~#s_tolower_table~0.offset, 1);call write~init~int(138, ~#s_tolower_table~0.base, 138 + ~#s_tolower_table~0.offset, 1);call write~init~int(139, ~#s_tolower_table~0.base, 139 + ~#s_tolower_table~0.offset, 1);call write~init~int(140, ~#s_tolower_table~0.base, 140 + ~#s_tolower_table~0.offset, 1);call write~init~int(141, ~#s_tolower_table~0.base, 141 + ~#s_tolower_table~0.offset, 1);call write~init~int(142, ~#s_tolower_table~0.base, 142 + ~#s_tolower_table~0.offset, 1);call write~init~int(143, ~#s_tolower_table~0.base, 143 + ~#s_tolower_table~0.offset, 1);call write~init~int(144, ~#s_tolower_table~0.base, 144 + ~#s_tolower_table~0.offset, 1);call write~init~int(145, ~#s_tolower_table~0.base, 145 + ~#s_tolower_table~0.offset, 1);call write~init~int(146, ~#s_tolower_table~0.base, 146 + ~#s_tolower_table~0.offset, 1);call write~init~int(147, ~#s_tolower_table~0.base, 147 + ~#s_tolower_table~0.offset, 1);call write~init~int(148, ~#s_tolower_table~0.base, 148 + ~#s_tolower_table~0.offset, 1);call write~init~int(149, ~#s_tolower_table~0.base, 149 + ~#s_tolower_table~0.offset, 1);call write~init~int(150, ~#s_tolower_table~0.base, 150 + ~#s_tolower_table~0.offset, 1);call write~init~int(151, ~#s_tolower_table~0.base, 151 + ~#s_tolower_table~0.offset, 1);call write~init~int(152, ~#s_tolower_table~0.base, 152 + ~#s_tolower_table~0.offset, 1);call write~init~int(153, ~#s_tolower_table~0.base, 153 + ~#s_tolower_table~0.offset, 1);call write~init~int(154, ~#s_tolower_table~0.base, 154 + ~#s_tolower_table~0.offset, 1);call write~init~int(155, ~#s_tolower_table~0.base, 155 + ~#s_tolower_table~0.offset, 1);call write~init~int(156, ~#s_tolower_table~0.base, 156 + ~#s_tolower_table~0.offset, 1);call write~init~int(157, ~#s_tolower_table~0.base, 157 + ~#s_tolower_table~0.offset, 1);call write~init~int(158, ~#s_tolower_table~0.base, 158 + ~#s_tolower_table~0.offset, 1);call write~init~int(159, ~#s_tolower_table~0.base, 159 + ~#s_tolower_table~0.offset, 1);call write~init~int(160, ~#s_tolower_table~0.base, 160 + ~#s_tolower_table~0.offset, 1);call write~init~int(161, ~#s_tolower_table~0.base, 161 + ~#s_tolower_table~0.offset, 1);call write~init~int(162, ~#s_tolower_table~0.base, 162 + ~#s_tolower_table~0.offset, 1);call write~init~int(163, ~#s_tolower_table~0.base, 163 + ~#s_tolower_table~0.offset, 1);call write~init~int(164, ~#s_tolower_table~0.base, 164 + ~#s_tolower_table~0.offset, 1);call write~init~int(165, ~#s_tolower_table~0.base, 165 + ~#s_tolower_table~0.offset, 1);call write~init~int(166, ~#s_tolower_table~0.base, 166 + ~#s_tolower_table~0.offset, 1);call write~init~int(167, ~#s_tolower_table~0.base, 167 + ~#s_tolower_table~0.offset, 1);call write~init~int(168, ~#s_tolower_table~0.base, 168 + ~#s_tolower_table~0.offset, 1);call write~init~int(169, ~#s_tolower_table~0.base, 169 + ~#s_tolower_table~0.offset, 1);call write~init~int(170, ~#s_tolower_table~0.base, 170 + ~#s_tolower_table~0.offset, 1);call write~init~int(171, ~#s_tolower_table~0.base, 171 + ~#s_tolower_table~0.offset, 1);call write~init~int(172, ~#s_tolower_table~0.base, 172 + ~#s_tolower_table~0.offset, 1);call write~init~int(173, ~#s_tolower_table~0.base, 173 + ~#s_tolower_table~0.offset, 1);call write~init~int(174, ~#s_tolower_table~0.base, 174 + ~#s_tolower_table~0.offset, 1);call write~init~int(175, ~#s_tolower_table~0.base, 175 + ~#s_tolower_table~0.offset, 1);call write~init~int(176, ~#s_tolower_table~0.base, 176 + ~#s_tolower_table~0.offset, 1);call write~init~int(177, ~#s_tolower_table~0.base, 177 + ~#s_tolower_table~0.offset, 1);call write~init~int(178, ~#s_tolower_table~0.base, 178 + ~#s_tolower_table~0.offset, 1);call write~init~int(179, ~#s_tolower_table~0.base, 179 + ~#s_tolower_table~0.offset, 1);call write~init~int(180, ~#s_tolower_table~0.base, 180 + ~#s_tolower_table~0.offset, 1);call write~init~int(181, ~#s_tolower_table~0.base, 181 + ~#s_tolower_table~0.offset, 1);call write~init~int(182, ~#s_tolower_table~0.base, 182 + ~#s_tolower_table~0.offset, 1);call write~init~int(183, ~#s_tolower_table~0.base, 183 + ~#s_tolower_table~0.offset, 1);call write~init~int(184, ~#s_tolower_table~0.base, 184 + ~#s_tolower_table~0.offset, 1);call write~init~int(185, ~#s_tolower_table~0.base, 185 + ~#s_tolower_table~0.offset, 1);call write~init~int(186, ~#s_tolower_table~0.base, 186 + ~#s_tolower_table~0.offset, 1);call write~init~int(187, ~#s_tolower_table~0.base, 187 + ~#s_tolower_table~0.offset, 1);call write~init~int(188, ~#s_tolower_table~0.base, 188 + ~#s_tolower_table~0.offset, 1);call write~init~int(189, ~#s_tolower_table~0.base, 189 + ~#s_tolower_table~0.offset, 1);call write~init~int(190, ~#s_tolower_table~0.base, 190 + ~#s_tolower_table~0.offset, 1);call write~init~int(191, ~#s_tolower_table~0.base, 191 + ~#s_tolower_table~0.offset, 1);call write~init~int(192, ~#s_tolower_table~0.base, 192 + ~#s_tolower_table~0.offset, 1);call write~init~int(193, ~#s_tolower_table~0.base, 193 + ~#s_tolower_table~0.offset, 1);call write~init~int(194, ~#s_tolower_table~0.base, 194 + ~#s_tolower_table~0.offset, 1);call write~init~int(195, ~#s_tolower_table~0.base, 195 + ~#s_tolower_table~0.offset, 1);call write~init~int(196, ~#s_tolower_table~0.base, 196 + ~#s_tolower_table~0.offset, 1);call write~init~int(197, ~#s_tolower_table~0.base, 197 + ~#s_tolower_table~0.offset, 1);call write~init~int(198, ~#s_tolower_table~0.base, 198 + ~#s_tolower_table~0.offset, 1);call write~init~int(199, ~#s_tolower_table~0.base, 199 + ~#s_tolower_table~0.offset, 1);call write~init~int(200, ~#s_tolower_table~0.base, 200 + ~#s_tolower_table~0.offset, 1);call write~init~int(201, ~#s_tolower_table~0.base, 201 + ~#s_tolower_table~0.offset, 1);call write~init~int(202, ~#s_tolower_table~0.base, 202 + ~#s_tolower_table~0.offset, 1);call write~init~int(203, ~#s_tolower_table~0.base, 203 + ~#s_tolower_table~0.offset, 1);call write~init~int(204, ~#s_tolower_table~0.base, 204 + ~#s_tolower_table~0.offset, 1);call write~init~int(205, ~#s_tolower_table~0.base, 205 + ~#s_tolower_table~0.offset, 1);call write~init~int(206, ~#s_tolower_table~0.base, 206 + ~#s_tolower_table~0.offset, 1);call write~init~int(207, ~#s_tolower_table~0.base, 207 + ~#s_tolower_table~0.offset, 1);call write~init~int(208, ~#s_tolower_table~0.base, 208 + ~#s_tolower_table~0.offset, 1);call write~init~int(209, ~#s_tolower_table~0.base, 209 + ~#s_tolower_table~0.offset, 1);call write~init~int(210, ~#s_tolower_table~0.base, 210 + ~#s_tolower_table~0.offset, 1);call write~init~int(211, ~#s_tolower_table~0.base, 211 + ~#s_tolower_table~0.offset, 1);call write~init~int(212, ~#s_tolower_table~0.base, 212 + ~#s_tolower_table~0.offset, 1);call write~init~int(213, ~#s_tolower_table~0.base, 213 + ~#s_tolower_table~0.offset, 1);call write~init~int(214, ~#s_tolower_table~0.base, 214 + ~#s_tolower_table~0.offset, 1);call write~init~int(215, ~#s_tolower_table~0.base, 215 + ~#s_tolower_table~0.offset, 1);call write~init~int(216, ~#s_tolower_table~0.base, 216 + ~#s_tolower_table~0.offset, 1);call write~init~int(217, ~#s_tolower_table~0.base, 217 + ~#s_tolower_table~0.offset, 1);call write~init~int(218, ~#s_tolower_table~0.base, 218 + ~#s_tolower_table~0.offset, 1);call write~init~int(219, ~#s_tolower_table~0.base, 219 + ~#s_tolower_table~0.offset, 1);call write~init~int(220, ~#s_tolower_table~0.base, 220 + ~#s_tolower_table~0.offset, 1);call write~init~int(221, ~#s_tolower_table~0.base, 221 + ~#s_tolower_table~0.offset, 1);call write~init~int(222, ~#s_tolower_table~0.base, 222 + ~#s_tolower_table~0.offset, 1);call write~init~int(223, ~#s_tolower_table~0.base, 223 + ~#s_tolower_table~0.offset, 1);call write~init~int(224, ~#s_tolower_table~0.base, 224 + ~#s_tolower_table~0.offset, 1);call write~init~int(225, ~#s_tolower_table~0.base, 225 + ~#s_tolower_table~0.offset, 1);call write~init~int(226, ~#s_tolower_table~0.base, 226 + ~#s_tolower_table~0.offset, 1);call write~init~int(227, ~#s_tolower_table~0.base, 227 + ~#s_tolower_table~0.offset, 1);call write~init~int(228, ~#s_tolower_table~0.base, 228 + ~#s_tolower_table~0.offset, 1);call write~init~int(229, ~#s_tolower_table~0.base, 229 + ~#s_tolower_table~0.offset, 1);call write~init~int(230, ~#s_tolower_table~0.base, 230 + ~#s_tolower_table~0.offset, 1);call write~init~int(231, ~#s_tolower_table~0.base, 231 + ~#s_tolower_table~0.offset, 1);call write~init~int(232, ~#s_tolower_table~0.base, 232 + ~#s_tolower_table~0.offset, 1);call write~init~int(233, ~#s_tolower_table~0.base, 233 + ~#s_tolower_table~0.offset, 1);call write~init~int(234, ~#s_tolower_table~0.base, 234 + ~#s_tolower_table~0.offset, 1);call write~init~int(235, ~#s_tolower_table~0.base, 235 + ~#s_tolower_table~0.offset, 1);call write~init~int(236, ~#s_tolower_table~0.base, 236 + ~#s_tolower_table~0.offset, 1);call write~init~int(237, ~#s_tolower_table~0.base, 237 + ~#s_tolower_table~0.offset, 1);call write~init~int(238, ~#s_tolower_table~0.base, 238 + ~#s_tolower_table~0.offset, 1);call write~init~int(239, ~#s_tolower_table~0.base, 239 + ~#s_tolower_table~0.offset, 1);call write~init~int(240, ~#s_tolower_table~0.base, 240 + ~#s_tolower_table~0.offset, 1);call write~init~int(241, ~#s_tolower_table~0.base, 241 + ~#s_tolower_table~0.offset, 1);call write~init~int(242, ~#s_tolower_table~0.base, 242 + ~#s_tolower_table~0.offset, 1);call write~init~int(243, ~#s_tolower_table~0.base, 243 + ~#s_tolower_table~0.offset, 1);call write~init~int(244, ~#s_tolower_table~0.base, 244 + ~#s_tolower_table~0.offset, 1);call write~init~int(245, ~#s_tolower_table~0.base, 245 + ~#s_tolower_table~0.offset, 1);call write~init~int(246, ~#s_tolower_table~0.base, 246 + ~#s_tolower_table~0.offset, 1);call write~init~int(247, ~#s_tolower_table~0.base, 247 + ~#s_tolower_table~0.offset, 1);call write~init~int(248, ~#s_tolower_table~0.base, 248 + ~#s_tolower_table~0.offset, 1);call write~init~int(249, ~#s_tolower_table~0.base, 249 + ~#s_tolower_table~0.offset, 1);call write~init~int(250, ~#s_tolower_table~0.base, 250 + ~#s_tolower_table~0.offset, 1);call write~init~int(251, ~#s_tolower_table~0.base, 251 + ~#s_tolower_table~0.offset, 1);call write~init~int(252, ~#s_tolower_table~0.base, 252 + ~#s_tolower_table~0.offset, 1);call write~init~int(253, ~#s_tolower_table~0.base, 253 + ~#s_tolower_table~0.offset, 1);call write~init~int(254, ~#s_tolower_table~0.base, 254 + ~#s_tolower_table~0.offset, 1);call write~init~int(255, ~#s_tolower_table~0.base, 255 + ~#s_tolower_table~0.offset, 1); {3269#true} is VALID [2022-02-20 21:08:19,836 INFO L290 TraceCheckUtils]: 1: Hoare triple {3269#true} assume { :end_inline_ULTIMATE.init } true;assume { :begin_inline_main } true;havoc main_#res#1;assume { :begin_inline_aws_hash_callback_string_eq_harness } true;havoc aws_hash_callback_string_eq_harness_#t~ret1963#1.base, aws_hash_callback_string_eq_harness_#t~ret1963#1.offset, aws_hash_callback_string_eq_harness_#t~ret1964#1, aws_hash_callback_string_eq_harness_#t~ite1966#1.base, aws_hash_callback_string_eq_harness_#t~ite1966#1.offset, aws_hash_callback_string_eq_harness_#t~ret1965#1.base, aws_hash_callback_string_eq_harness_#t~ret1965#1.offset, aws_hash_callback_string_eq_harness_#t~ret1967#1, aws_hash_callback_string_eq_harness_#t~mem1968#1, aws_hash_callback_string_eq_harness_#t~mem1969#1, aws_hash_callback_string_eq_harness_#t~mem1970#1, aws_hash_callback_string_eq_harness_~str1~0#1.base, aws_hash_callback_string_eq_harness_~str1~0#1.offset, aws_hash_callback_string_eq_harness_~str2~0#1.base, aws_hash_callback_string_eq_harness_~str2~0#1.offset, aws_hash_callback_string_eq_harness_~rval~21#1; {3269#true} is VALID [2022-02-20 21:08:19,837 INFO L272 TraceCheckUtils]: 2: Hoare triple {3269#true} call aws_hash_callback_string_eq_harness_#t~ret1963#1.base, aws_hash_callback_string_eq_harness_#t~ret1963#1.offset := ensure_string_is_allocated_bounded_length(96); {3349#(and (= |old(#length)| |#length|) (= |old(#memory_real)| |#memory_real|) (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:08:19,837 INFO L290 TraceCheckUtils]: 3: Hoare triple {3349#(and (= |old(#length)| |#length|) (= |old(#memory_real)| |#memory_real|) (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|) (= |old(#valid)| |#valid|))} ~max_size#1 := #in~max_size#1; {3269#true} is VALID [2022-02-20 21:08:19,837 INFO L272 TraceCheckUtils]: 4: Hoare triple {3269#true} call #t~ret540#1 := nondet_uint64_t(); {3269#true} is VALID [2022-02-20 21:08:19,837 INFO L290 TraceCheckUtils]: 5: Hoare triple {3269#true} #res := #t~nondet13;havoc #t~nondet13; {3269#true} is VALID [2022-02-20 21:08:19,837 INFO L290 TraceCheckUtils]: 6: Hoare triple {3269#true} assume true; {3269#true} is VALID [2022-02-20 21:08:19,837 INFO L284 TraceCheckUtils]: 7: Hoare quadruple {3269#true} {3269#true} #182#return; {3269#true} is VALID [2022-02-20 21:08:19,837 INFO L290 TraceCheckUtils]: 8: Hoare triple {3269#true} ~len~1#1 := #t~ret540#1;havoc #t~ret540#1; {3269#true} is VALID [2022-02-20 21:08:19,838 INFO L272 TraceCheckUtils]: 9: Hoare triple {3269#true} call assume_abort_if_not((if 0 == (if ~len~1#1 % 18446744073709551616 < ~max_size#1 % 18446744073709551616 then 1 else 0) then 0 else 1)); {3269#true} is VALID [2022-02-20 21:08:19,838 INFO L290 TraceCheckUtils]: 10: Hoare triple {3269#true} ~cond := #in~cond; {3269#true} is VALID [2022-02-20 21:08:19,838 INFO L290 TraceCheckUtils]: 11: Hoare triple {3269#true} assume !(0 == ~cond % 256); {3269#true} is VALID [2022-02-20 21:08:19,838 INFO L290 TraceCheckUtils]: 12: Hoare triple {3269#true} assume true; {3269#true} is VALID [2022-02-20 21:08:19,838 INFO L284 TraceCheckUtils]: 13: Hoare quadruple {3269#true} {3269#true} #184#return; {3269#true} is VALID [2022-02-20 21:08:19,838 INFO L290 TraceCheckUtils]: 14: Hoare triple {3269#true} assume { :begin_inline_ensure_string_is_allocated } true;ensure_string_is_allocated_#in~len#1 := ~len~1#1;havoc ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset;havoc ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset, ensure_string_is_allocated_#t~ret543#1, ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset, ensure_string_is_allocated_#t~ret544#1.base, ensure_string_is_allocated_#t~ret544#1.offset, ensure_string_is_allocated_~len#1, ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset;ensure_string_is_allocated_~len#1 := ensure_string_is_allocated_#in~len#1; {3269#true} is VALID [2022-02-20 21:08:19,839 INFO L272 TraceCheckUtils]: 15: Hoare triple {3269#true} call ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset := bounded_malloc(-1234550 + ensure_string_is_allocated_~len#1); {3369#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:08:19,839 INFO L290 TraceCheckUtils]: 16: Hoare triple {3369#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size; {3269#true} is VALID [2022-02-20 21:08:19,839 INFO L272 TraceCheckUtils]: 17: Hoare triple {3269#true} call assume_abort_if_not((if 0 == (if ~size % 18446744073709551616 <= 36028797018963967 then 1 else 0) then 0 else 1)); {3269#true} is VALID [2022-02-20 21:08:19,840 INFO L290 TraceCheckUtils]: 18: Hoare triple {3269#true} ~cond := #in~cond; {3269#true} is VALID [2022-02-20 21:08:19,840 INFO L290 TraceCheckUtils]: 19: Hoare triple {3269#true} assume !(0 == ~cond % 256); {3269#true} is VALID [2022-02-20 21:08:19,840 INFO L290 TraceCheckUtils]: 20: Hoare triple {3269#true} assume true; {3269#true} is VALID [2022-02-20 21:08:19,840 INFO L284 TraceCheckUtils]: 21: Hoare quadruple {3269#true} {3269#true} #192#return; {3269#true} is VALID [2022-02-20 21:08:19,840 INFO L290 TraceCheckUtils]: 22: Hoare triple {3269#true} call #t~malloc555.base, #t~malloc555.offset := #Ultimate.allocOnHeap(~size);#res.base, #res.offset := #t~malloc555.base, #t~malloc555.offset;havoc #t~malloc555.base, #t~malloc555.offset; {3269#true} is VALID [2022-02-20 21:08:19,840 INFO L290 TraceCheckUtils]: 23: Hoare triple {3269#true} assume true; {3269#true} is VALID [2022-02-20 21:08:19,840 INFO L284 TraceCheckUtils]: 24: Hoare quadruple {3269#true} {3269#true} #186#return; {3269#true} is VALID [2022-02-20 21:08:19,841 INFO L290 TraceCheckUtils]: 25: Hoare triple {3269#true} ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset := ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset;havoc ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset; {3269#true} is VALID [2022-02-20 21:08:19,841 INFO L272 TraceCheckUtils]: 26: Hoare triple {3269#true} call ensure_string_is_allocated_#t~ret543#1 := nondet_bool(); {3269#true} is VALID [2022-02-20 21:08:19,841 INFO L290 TraceCheckUtils]: 27: Hoare triple {3269#true} #res := #t~nondet8;havoc #t~nondet8; {3269#true} is VALID [2022-02-20 21:08:19,841 INFO L290 TraceCheckUtils]: 28: Hoare triple {3269#true} assume true; {3269#true} is VALID [2022-02-20 21:08:19,841 INFO L284 TraceCheckUtils]: 29: Hoare quadruple {3269#true} {3269#true} #188#return; {3269#true} is VALID [2022-02-20 21:08:19,841 INFO L290 TraceCheckUtils]: 30: Hoare triple {3269#true} assume !(0 != ensure_string_is_allocated_#t~ret543#1 % 256);ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset := 0, 0; {3269#true} is VALID [2022-02-20 21:08:19,842 INFO L290 TraceCheckUtils]: 31: Hoare triple {3269#true} call write~$Pointer$(ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset, ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset, 8);havoc ensure_string_is_allocated_#t~ret543#1;havoc ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset;havoc ensure_string_is_allocated_#t~ret544#1.base, ensure_string_is_allocated_#t~ret544#1.offset;call write~int(ensure_string_is_allocated_~len#1, ensure_string_is_allocated_~str~0#1.base, 8 + ensure_string_is_allocated_~str~0#1.offset, 8);call write~int(0, ensure_string_is_allocated_~str~0#1.base, 16 + ensure_string_is_allocated_~str~0#1.offset + (if ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 else ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset := ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset; {3269#true} is VALID [2022-02-20 21:08:19,842 INFO L290 TraceCheckUtils]: 32: Hoare triple {3269#true} #t~ret541#1.base, #t~ret541#1.offset := ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset;assume { :end_inline_ensure_string_is_allocated } true;#res#1.base, #res#1.offset := #t~ret541#1.base, #t~ret541#1.offset;havoc #t~ret541#1.base, #t~ret541#1.offset; {3269#true} is VALID [2022-02-20 21:08:19,842 INFO L290 TraceCheckUtils]: 33: Hoare triple {3269#true} assume true; {3269#true} is VALID [2022-02-20 21:08:19,842 INFO L284 TraceCheckUtils]: 34: Hoare quadruple {3269#true} {3269#true} #198#return; {3269#true} is VALID [2022-02-20 21:08:19,842 INFO L290 TraceCheckUtils]: 35: Hoare triple {3269#true} aws_hash_callback_string_eq_harness_~str1~0#1.base, aws_hash_callback_string_eq_harness_~str1~0#1.offset := aws_hash_callback_string_eq_harness_#t~ret1963#1.base, aws_hash_callback_string_eq_harness_#t~ret1963#1.offset;havoc aws_hash_callback_string_eq_harness_#t~ret1963#1.base, aws_hash_callback_string_eq_harness_#t~ret1963#1.offset; {3269#true} is VALID [2022-02-20 21:08:19,842 INFO L272 TraceCheckUtils]: 36: Hoare triple {3269#true} call aws_hash_callback_string_eq_harness_#t~ret1964#1 := nondet_bool(); {3269#true} is VALID [2022-02-20 21:08:19,842 INFO L290 TraceCheckUtils]: 37: Hoare triple {3269#true} #res := #t~nondet8;havoc #t~nondet8; {3269#true} is VALID [2022-02-20 21:08:19,843 INFO L290 TraceCheckUtils]: 38: Hoare triple {3269#true} assume true; {3269#true} is VALID [2022-02-20 21:08:19,843 INFO L284 TraceCheckUtils]: 39: Hoare quadruple {3269#true} {3269#true} #200#return; {3269#true} is VALID [2022-02-20 21:08:19,843 INFO L290 TraceCheckUtils]: 40: Hoare triple {3269#true} assume 0 != aws_hash_callback_string_eq_harness_#t~ret1964#1 % 256;aws_hash_callback_string_eq_harness_#t~ite1966#1.base, aws_hash_callback_string_eq_harness_#t~ite1966#1.offset := aws_hash_callback_string_eq_harness_~str1~0#1.base, aws_hash_callback_string_eq_harness_~str1~0#1.offset; {3306#(and (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_#t~ite1966#1.offset| |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.offset|) (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| |ULTIMATE.start_aws_hash_callback_string_eq_harness_#t~ite1966#1.base|))} is VALID [2022-02-20 21:08:19,844 INFO L290 TraceCheckUtils]: 41: Hoare triple {3306#(and (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_#t~ite1966#1.offset| |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.offset|) (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| |ULTIMATE.start_aws_hash_callback_string_eq_harness_#t~ite1966#1.base|))} aws_hash_callback_string_eq_harness_~str2~0#1.base, aws_hash_callback_string_eq_harness_~str2~0#1.offset := aws_hash_callback_string_eq_harness_#t~ite1966#1.base, aws_hash_callback_string_eq_harness_#t~ite1966#1.offset;havoc aws_hash_callback_string_eq_harness_#t~ret1964#1;havoc aws_hash_callback_string_eq_harness_#t~ite1966#1.base, aws_hash_callback_string_eq_harness_#t~ite1966#1.offset;havoc aws_hash_callback_string_eq_harness_#t~ret1965#1.base, aws_hash_callback_string_eq_harness_#t~ret1965#1.offset;assume { :begin_inline_aws_hash_callback_string_eq } true;aws_hash_callback_string_eq_#in~a#1.base, aws_hash_callback_string_eq_#in~a#1.offset, aws_hash_callback_string_eq_#in~b#1.base, aws_hash_callback_string_eq_#in~b#1.offset := aws_hash_callback_string_eq_harness_~str1~0#1.base, aws_hash_callback_string_eq_harness_~str1~0#1.offset, aws_hash_callback_string_eq_harness_~str2~0#1.base, aws_hash_callback_string_eq_harness_~str2~0#1.offset;havoc aws_hash_callback_string_eq_#res#1;havoc aws_hash_callback_string_eq_#t~ret1811#1, aws_hash_callback_string_eq_#t~ret1812#1, aws_hash_callback_string_eq_#t~ret1813#1, aws_hash_callback_string_eq_#t~ret1814#1, aws_hash_callback_string_eq_#t~ret1815#1, aws_hash_callback_string_eq_#t~short1816#1, aws_hash_callback_string_eq_~a#1.base, aws_hash_callback_string_eq_~a#1.offset, aws_hash_callback_string_eq_~b#1.base, aws_hash_callback_string_eq_~b#1.offset, aws_hash_callback_string_eq_~rval~20#1;aws_hash_callback_string_eq_~a#1.base, aws_hash_callback_string_eq_~a#1.offset := aws_hash_callback_string_eq_#in~a#1.base, aws_hash_callback_string_eq_#in~a#1.offset;aws_hash_callback_string_eq_~b#1.base, aws_hash_callback_string_eq_~b#1.offset := aws_hash_callback_string_eq_#in~b#1.base, aws_hash_callback_string_eq_#in~b#1.offset; {3307#(and (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.offset| |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base|))} is VALID [2022-02-20 21:08:19,844 INFO L272 TraceCheckUtils]: 42: Hoare triple {3307#(and (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.offset| |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base|))} call aws_hash_callback_string_eq_#t~ret1811#1 := aws_string_is_valid(aws_hash_callback_string_eq_~a#1.base, aws_hash_callback_string_eq_~a#1.offset); {3269#true} is VALID [2022-02-20 21:08:19,844 INFO L290 TraceCheckUtils]: 43: Hoare triple {3269#true} ~str.base, ~str.offset := #in~str.base, #in~str.offset;#t~short464 := ~str.base != 0 || ~str.offset != 0; {3269#true} is VALID [2022-02-20 21:08:19,844 INFO L290 TraceCheckUtils]: 44: Hoare triple {3269#true} assume #t~short464;call #t~mem463 := read~int(~str.base, 8 + ~str.offset, 8);#t~short464 := 0 == (1 + #t~mem463) % 18446744073709551616 || ~str.base != 0 || 16 + ~str.offset != 0; {3269#true} is VALID [2022-02-20 21:08:19,845 INFO L290 TraceCheckUtils]: 45: Hoare triple {3269#true} #t~short467 := #t~short464; {3269#true} is VALID [2022-02-20 21:08:19,845 INFO L290 TraceCheckUtils]: 46: Hoare triple {3269#true} assume #t~short467;call #t~mem465 := read~int(~str.base, 8 + ~str.offset, 8);call #t~mem466 := read~int(~str.base, 16 + ~str.offset + (if #t~mem465 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then #t~mem465 % 18446744073709551616 % 18446744073709551616 else #t~mem465 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);#t~short467 := 0 == #t~mem466 % 256; {3269#true} is VALID [2022-02-20 21:08:19,845 INFO L290 TraceCheckUtils]: 47: Hoare triple {3269#true} #res := (if 0 == (if #t~short467 then 1 else 0) then 0 else 1);havoc #t~mem463;havoc #t~short464;havoc #t~mem465;havoc #t~mem466;havoc #t~short467; {3269#true} is VALID [2022-02-20 21:08:19,845 INFO L290 TraceCheckUtils]: 48: Hoare triple {3269#true} assume true; {3269#true} is VALID [2022-02-20 21:08:19,846 INFO L284 TraceCheckUtils]: 49: Hoare quadruple {3269#true} {3307#(and (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.offset| |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base|))} #204#return; {3307#(and (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.offset| |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base|))} is VALID [2022-02-20 21:08:19,846 INFO L272 TraceCheckUtils]: 50: Hoare triple {3307#(and (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.offset| |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base|))} call assume_abort_if_not(aws_hash_callback_string_eq_#t~ret1811#1); {3269#true} is VALID [2022-02-20 21:08:19,846 INFO L290 TraceCheckUtils]: 51: Hoare triple {3269#true} ~cond := #in~cond; {3269#true} is VALID [2022-02-20 21:08:19,846 INFO L290 TraceCheckUtils]: 52: Hoare triple {3269#true} assume !(0 == ~cond % 256); {3269#true} is VALID [2022-02-20 21:08:19,846 INFO L290 TraceCheckUtils]: 53: Hoare triple {3269#true} assume true; {3269#true} is VALID [2022-02-20 21:08:19,847 INFO L284 TraceCheckUtils]: 54: Hoare quadruple {3269#true} {3307#(and (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.offset| |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base|))} #206#return; {3307#(and (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.offset| |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base|))} is VALID [2022-02-20 21:08:19,847 INFO L290 TraceCheckUtils]: 55: Hoare triple {3307#(and (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.offset| |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base|))} havoc aws_hash_callback_string_eq_#t~ret1811#1; {3307#(and (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.offset| |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base|))} is VALID [2022-02-20 21:08:19,848 INFO L272 TraceCheckUtils]: 56: Hoare triple {3307#(and (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.offset| |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base|))} call aws_hash_callback_string_eq_#t~ret1812#1 := aws_string_is_valid(aws_hash_callback_string_eq_~b#1.base, aws_hash_callback_string_eq_~b#1.offset); {3269#true} is VALID [2022-02-20 21:08:19,848 INFO L290 TraceCheckUtils]: 57: Hoare triple {3269#true} ~str.base, ~str.offset := #in~str.base, #in~str.offset;#t~short464 := ~str.base != 0 || ~str.offset != 0; {3269#true} is VALID [2022-02-20 21:08:19,848 INFO L290 TraceCheckUtils]: 58: Hoare triple {3269#true} assume #t~short464;call #t~mem463 := read~int(~str.base, 8 + ~str.offset, 8);#t~short464 := 0 == (1 + #t~mem463) % 18446744073709551616 || ~str.base != 0 || 16 + ~str.offset != 0; {3269#true} is VALID [2022-02-20 21:08:19,848 INFO L290 TraceCheckUtils]: 59: Hoare triple {3269#true} #t~short467 := #t~short464; {3269#true} is VALID [2022-02-20 21:08:19,848 INFO L290 TraceCheckUtils]: 60: Hoare triple {3269#true} assume #t~short467;call #t~mem465 := read~int(~str.base, 8 + ~str.offset, 8);call #t~mem466 := read~int(~str.base, 16 + ~str.offset + (if #t~mem465 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then #t~mem465 % 18446744073709551616 % 18446744073709551616 else #t~mem465 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);#t~short467 := 0 == #t~mem466 % 256; {3269#true} is VALID [2022-02-20 21:08:19,848 INFO L290 TraceCheckUtils]: 61: Hoare triple {3269#true} #res := (if 0 == (if #t~short467 then 1 else 0) then 0 else 1);havoc #t~mem463;havoc #t~short464;havoc #t~mem465;havoc #t~mem466;havoc #t~short467; {3269#true} is VALID [2022-02-20 21:08:19,848 INFO L290 TraceCheckUtils]: 62: Hoare triple {3269#true} assume true; {3269#true} is VALID [2022-02-20 21:08:19,849 INFO L284 TraceCheckUtils]: 63: Hoare quadruple {3269#true} {3307#(and (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.offset| |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base|))} #208#return; {3307#(and (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.offset| |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base|))} is VALID [2022-02-20 21:08:19,849 INFO L272 TraceCheckUtils]: 64: Hoare triple {3307#(and (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.offset| |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base|))} call assume_abort_if_not(aws_hash_callback_string_eq_#t~ret1812#1); {3269#true} is VALID [2022-02-20 21:08:19,850 INFO L290 TraceCheckUtils]: 65: Hoare triple {3269#true} ~cond := #in~cond; {3269#true} is VALID [2022-02-20 21:08:19,850 INFO L290 TraceCheckUtils]: 66: Hoare triple {3269#true} assume !(0 == ~cond % 256); {3269#true} is VALID [2022-02-20 21:08:19,850 INFO L290 TraceCheckUtils]: 67: Hoare triple {3269#true} assume true; {3269#true} is VALID [2022-02-20 21:08:19,850 INFO L284 TraceCheckUtils]: 68: Hoare quadruple {3269#true} {3307#(and (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.offset| |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base|))} #210#return; {3307#(and (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.offset| |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base|))} is VALID [2022-02-20 21:08:19,851 INFO L290 TraceCheckUtils]: 69: Hoare triple {3307#(and (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.offset| |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base|))} havoc aws_hash_callback_string_eq_#t~ret1812#1;assume { :begin_inline_aws_string_eq } true;aws_string_eq_#in~a#1.base, aws_string_eq_#in~a#1.offset, aws_string_eq_#in~b#1.base, aws_string_eq_#in~b#1.offset := aws_hash_callback_string_eq_~a#1.base, aws_hash_callback_string_eq_~a#1.offset, aws_hash_callback_string_eq_~b#1.base, aws_hash_callback_string_eq_~b#1.offset;havoc aws_string_eq_#res#1;havoc aws_string_eq_#t~ret1893#1, aws_string_eq_#t~short1894#1, aws_string_eq_#t~ret1895#1, aws_string_eq_#t~short1896#1, aws_string_eq_#t~mem1897#1, aws_string_eq_#t~mem1898#1, aws_string_eq_#t~ret1899#1, aws_string_eq_~a#1.base, aws_string_eq_~a#1.offset, aws_string_eq_~b#1.base, aws_string_eq_~b#1.offset;aws_string_eq_~a#1.base, aws_string_eq_~a#1.offset := aws_string_eq_#in~a#1.base, aws_string_eq_#in~a#1.offset;aws_string_eq_~b#1.base, aws_string_eq_~b#1.offset := aws_string_eq_#in~b#1.base, aws_string_eq_#in~b#1.offset;aws_string_eq_#t~short1894#1 := aws_string_eq_~a#1.base == 0 && aws_string_eq_~a#1.offset == 0; {3330#(and (= |ULTIMATE.start_aws_string_eq_~b#1.offset| |ULTIMATE.start_aws_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_string_eq_~a#1.base| |ULTIMATE.start_aws_string_eq_~b#1.base|))} is VALID [2022-02-20 21:08:19,852 INFO L290 TraceCheckUtils]: 70: Hoare triple {3330#(and (= |ULTIMATE.start_aws_string_eq_~b#1.offset| |ULTIMATE.start_aws_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_string_eq_~a#1.base| |ULTIMATE.start_aws_string_eq_~b#1.base|))} assume aws_string_eq_#t~short1894#1; {3330#(and (= |ULTIMATE.start_aws_string_eq_~b#1.offset| |ULTIMATE.start_aws_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_string_eq_~a#1.base| |ULTIMATE.start_aws_string_eq_~b#1.base|))} is VALID [2022-02-20 21:08:19,852 INFO L272 TraceCheckUtils]: 71: Hoare triple {3330#(and (= |ULTIMATE.start_aws_string_eq_~b#1.offset| |ULTIMATE.start_aws_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_string_eq_~a#1.base| |ULTIMATE.start_aws_string_eq_~b#1.base|))} call assume_abort_if_not((if 0 == (if aws_string_eq_#t~short1894#1 then 1 else 0) then 0 else 1)); {3269#true} is VALID [2022-02-20 21:08:19,852 INFO L290 TraceCheckUtils]: 72: Hoare triple {3269#true} ~cond := #in~cond; {3269#true} is VALID [2022-02-20 21:08:19,852 INFO L290 TraceCheckUtils]: 73: Hoare triple {3269#true} assume !(0 == ~cond % 256); {3269#true} is VALID [2022-02-20 21:08:19,852 INFO L290 TraceCheckUtils]: 74: Hoare triple {3269#true} assume true; {3269#true} is VALID [2022-02-20 21:08:19,853 INFO L284 TraceCheckUtils]: 75: Hoare quadruple {3269#true} {3330#(and (= |ULTIMATE.start_aws_string_eq_~b#1.offset| |ULTIMATE.start_aws_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_string_eq_~a#1.base| |ULTIMATE.start_aws_string_eq_~b#1.base|))} #214#return; {3330#(and (= |ULTIMATE.start_aws_string_eq_~b#1.offset| |ULTIMATE.start_aws_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_string_eq_~a#1.base| |ULTIMATE.start_aws_string_eq_~b#1.base|))} is VALID [2022-02-20 21:08:19,853 INFO L290 TraceCheckUtils]: 76: Hoare triple {3330#(and (= |ULTIMATE.start_aws_string_eq_~b#1.offset| |ULTIMATE.start_aws_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_string_eq_~a#1.base| |ULTIMATE.start_aws_string_eq_~b#1.base|))} havoc aws_string_eq_#t~ret1893#1;havoc aws_string_eq_#t~short1894#1;aws_string_eq_#t~short1896#1 := aws_string_eq_~b#1.base == 0 && aws_string_eq_~b#1.offset == 0; {3330#(and (= |ULTIMATE.start_aws_string_eq_~b#1.offset| |ULTIMATE.start_aws_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_string_eq_~a#1.base| |ULTIMATE.start_aws_string_eq_~b#1.base|))} is VALID [2022-02-20 21:08:19,854 INFO L290 TraceCheckUtils]: 77: Hoare triple {3330#(and (= |ULTIMATE.start_aws_string_eq_~b#1.offset| |ULTIMATE.start_aws_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_string_eq_~a#1.base| |ULTIMATE.start_aws_string_eq_~b#1.base|))} assume !aws_string_eq_#t~short1896#1; {3330#(and (= |ULTIMATE.start_aws_string_eq_~b#1.offset| |ULTIMATE.start_aws_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_string_eq_~a#1.base| |ULTIMATE.start_aws_string_eq_~b#1.base|))} is VALID [2022-02-20 21:08:19,854 INFO L272 TraceCheckUtils]: 78: Hoare triple {3330#(and (= |ULTIMATE.start_aws_string_eq_~b#1.offset| |ULTIMATE.start_aws_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_string_eq_~a#1.base| |ULTIMATE.start_aws_string_eq_~b#1.base|))} call aws_string_eq_#t~ret1895#1 := aws_string_is_valid(aws_string_eq_~b#1.base, aws_string_eq_~b#1.offset); {3269#true} is VALID [2022-02-20 21:08:19,854 INFO L290 TraceCheckUtils]: 79: Hoare triple {3269#true} ~str.base, ~str.offset := #in~str.base, #in~str.offset;#t~short464 := ~str.base != 0 || ~str.offset != 0; {3269#true} is VALID [2022-02-20 21:08:19,854 INFO L290 TraceCheckUtils]: 80: Hoare triple {3269#true} assume #t~short464;call #t~mem463 := read~int(~str.base, 8 + ~str.offset, 8);#t~short464 := 0 == (1 + #t~mem463) % 18446744073709551616 || ~str.base != 0 || 16 + ~str.offset != 0; {3269#true} is VALID [2022-02-20 21:08:19,854 INFO L290 TraceCheckUtils]: 81: Hoare triple {3269#true} #t~short467 := #t~short464; {3269#true} is VALID [2022-02-20 21:08:19,855 INFO L290 TraceCheckUtils]: 82: Hoare triple {3269#true} assume #t~short467;call #t~mem465 := read~int(~str.base, 8 + ~str.offset, 8);call #t~mem466 := read~int(~str.base, 16 + ~str.offset + (if #t~mem465 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then #t~mem465 % 18446744073709551616 % 18446744073709551616 else #t~mem465 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);#t~short467 := 0 == #t~mem466 % 256; {3269#true} is VALID [2022-02-20 21:08:19,855 INFO L290 TraceCheckUtils]: 83: Hoare triple {3269#true} #res := (if 0 == (if #t~short467 then 1 else 0) then 0 else 1);havoc #t~mem463;havoc #t~short464;havoc #t~mem465;havoc #t~mem466;havoc #t~short467; {3269#true} is VALID [2022-02-20 21:08:19,855 INFO L290 TraceCheckUtils]: 84: Hoare triple {3269#true} assume true; {3269#true} is VALID [2022-02-20 21:08:19,856 INFO L284 TraceCheckUtils]: 85: Hoare quadruple {3269#true} {3330#(and (= |ULTIMATE.start_aws_string_eq_~b#1.offset| |ULTIMATE.start_aws_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_string_eq_~a#1.base| |ULTIMATE.start_aws_string_eq_~b#1.base|))} #216#return; {3330#(and (= |ULTIMATE.start_aws_string_eq_~b#1.offset| |ULTIMATE.start_aws_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_string_eq_~a#1.base| |ULTIMATE.start_aws_string_eq_~b#1.base|))} is VALID [2022-02-20 21:08:19,856 INFO L290 TraceCheckUtils]: 86: Hoare triple {3330#(and (= |ULTIMATE.start_aws_string_eq_~b#1.offset| |ULTIMATE.start_aws_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_string_eq_~a#1.base| |ULTIMATE.start_aws_string_eq_~b#1.base|))} aws_string_eq_#t~short1896#1 := 0 != aws_string_eq_#t~ret1895#1 % 256; {3330#(and (= |ULTIMATE.start_aws_string_eq_~b#1.offset| |ULTIMATE.start_aws_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_string_eq_~a#1.base| |ULTIMATE.start_aws_string_eq_~b#1.base|))} is VALID [2022-02-20 21:08:19,856 INFO L272 TraceCheckUtils]: 87: Hoare triple {3330#(and (= |ULTIMATE.start_aws_string_eq_~b#1.offset| |ULTIMATE.start_aws_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_string_eq_~a#1.base| |ULTIMATE.start_aws_string_eq_~b#1.base|))} call assume_abort_if_not((if 0 == (if aws_string_eq_#t~short1896#1 then 1 else 0) then 0 else 1)); {3269#true} is VALID [2022-02-20 21:08:19,856 INFO L290 TraceCheckUtils]: 88: Hoare triple {3269#true} ~cond := #in~cond; {3269#true} is VALID [2022-02-20 21:08:19,856 INFO L290 TraceCheckUtils]: 89: Hoare triple {3269#true} assume !(0 == ~cond % 256); {3269#true} is VALID [2022-02-20 21:08:19,857 INFO L290 TraceCheckUtils]: 90: Hoare triple {3269#true} assume true; {3269#true} is VALID [2022-02-20 21:08:19,857 INFO L284 TraceCheckUtils]: 91: Hoare quadruple {3269#true} {3330#(and (= |ULTIMATE.start_aws_string_eq_~b#1.offset| |ULTIMATE.start_aws_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_string_eq_~a#1.base| |ULTIMATE.start_aws_string_eq_~b#1.base|))} #218#return; {3330#(and (= |ULTIMATE.start_aws_string_eq_~b#1.offset| |ULTIMATE.start_aws_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_string_eq_~a#1.base| |ULTIMATE.start_aws_string_eq_~b#1.base|))} is VALID [2022-02-20 21:08:19,858 INFO L290 TraceCheckUtils]: 92: Hoare triple {3330#(and (= |ULTIMATE.start_aws_string_eq_~b#1.offset| |ULTIMATE.start_aws_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_string_eq_~a#1.base| |ULTIMATE.start_aws_string_eq_~b#1.base|))} havoc aws_string_eq_#t~ret1895#1;havoc aws_string_eq_#t~short1896#1; {3330#(and (= |ULTIMATE.start_aws_string_eq_~b#1.offset| |ULTIMATE.start_aws_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_string_eq_~a#1.base| |ULTIMATE.start_aws_string_eq_~b#1.base|))} is VALID [2022-02-20 21:08:19,858 INFO L290 TraceCheckUtils]: 93: Hoare triple {3330#(and (= |ULTIMATE.start_aws_string_eq_~b#1.offset| |ULTIMATE.start_aws_string_eq_~a#1.offset|) (= |ULTIMATE.start_aws_string_eq_~a#1.base| |ULTIMATE.start_aws_string_eq_~b#1.base|))} assume !(aws_string_eq_~a#1.base == aws_string_eq_~b#1.base && aws_string_eq_~a#1.offset == aws_string_eq_~b#1.offset); {3270#false} is VALID [2022-02-20 21:08:19,858 INFO L290 TraceCheckUtils]: 94: Hoare triple {3270#false} assume (aws_string_eq_~a#1.base == 0 && aws_string_eq_~a#1.offset == 0) || (aws_string_eq_~b#1.base == 0 && aws_string_eq_~b#1.offset == 0);aws_string_eq_#res#1 := 0; {3270#false} is VALID [2022-02-20 21:08:19,859 INFO L290 TraceCheckUtils]: 95: Hoare triple {3270#false} aws_hash_callback_string_eq_#t~ret1813#1 := aws_string_eq_#res#1;assume { :end_inline_aws_string_eq } true;aws_hash_callback_string_eq_~rval~20#1 := aws_hash_callback_string_eq_#t~ret1813#1;havoc aws_hash_callback_string_eq_#t~ret1813#1; {3270#false} is VALID [2022-02-20 21:08:19,859 INFO L272 TraceCheckUtils]: 96: Hoare triple {3270#false} call aws_hash_callback_string_eq_#t~ret1814#1 := aws_c_string_is_valid(aws_hash_callback_string_eq_~a#1.base, aws_hash_callback_string_eq_~a#1.offset); {3269#true} is VALID [2022-02-20 21:08:19,859 INFO L290 TraceCheckUtils]: 97: Hoare triple {3269#true} ~str.base, ~str.offset := #in~str.base, #in~str.offset;#res := (if 0 == (if (~str.base != 0 || ~str.offset != 0) && (~str.base != 0 || ~str.offset != 0) then 1 else 0) then 0 else 1); {3269#true} is VALID [2022-02-20 21:08:19,859 INFO L290 TraceCheckUtils]: 98: Hoare triple {3269#true} assume true; {3269#true} is VALID [2022-02-20 21:08:19,859 INFO L284 TraceCheckUtils]: 99: Hoare quadruple {3269#true} {3270#false} #222#return; {3270#false} is VALID [2022-02-20 21:08:19,859 INFO L290 TraceCheckUtils]: 100: Hoare triple {3270#false} aws_hash_callback_string_eq_#t~short1816#1 := 0 != aws_hash_callback_string_eq_#t~ret1814#1 % 256; {3270#false} is VALID [2022-02-20 21:08:19,859 INFO L290 TraceCheckUtils]: 101: Hoare triple {3270#false} assume !aws_hash_callback_string_eq_#t~short1816#1; {3270#false} is VALID [2022-02-20 21:08:19,860 INFO L272 TraceCheckUtils]: 102: Hoare triple {3270#false} call __VERIFIER_assert((if 0 == (if aws_hash_callback_string_eq_#t~short1816#1 then 1 else 0) then 0 else 1)); {3270#false} is VALID [2022-02-20 21:08:19,860 INFO L290 TraceCheckUtils]: 103: Hoare triple {3270#false} ~cond := #in~cond; {3270#false} is VALID [2022-02-20 21:08:19,860 INFO L290 TraceCheckUtils]: 104: Hoare triple {3270#false} assume 0 == ~cond % 256; {3270#false} is VALID [2022-02-20 21:08:19,860 INFO L290 TraceCheckUtils]: 105: Hoare triple {3270#false} assume !false; {3270#false} is VALID [2022-02-20 21:08:19,860 INFO L134 CoverageAnalysis]: Checked inductivity of 84 backedges. 0 proven. 0 refuted. 0 times theorem prover too weak. 84 trivial. 0 not checked. [2022-02-20 21:08:19,861 INFO L144 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-02-20 21:08:19,861 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [2006530522] [2022-02-20 21:08:19,861 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleSmtInterpolCraig [2006530522] provided 1 perfect and 0 imperfect interpolant sequences [2022-02-20 21:08:19,861 INFO L191 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-02-20 21:08:19,861 INFO L204 FreeRefinementEngine]: Number of different interpolants: perfect sequences [7] imperfect sequences [] total 7 [2022-02-20 21:08:19,861 INFO L118 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [1488826920] [2022-02-20 21:08:19,862 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-02-20 21:08:19,864 INFO L78 Accepts]: Start accepts. Automaton has has 7 states, 7 states have (on average 6.571428571428571) internal successors, (46), 5 states have internal predecessors, (46), 4 states have call successors, (16), 4 states have call predecessors, (16), 1 states have return successors, (15), 4 states have call predecessors, (15), 4 states have call successors, (15) Word has length 106 [2022-02-20 21:08:19,866 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-02-20 21:08:19,866 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with has 7 states, 7 states have (on average 6.571428571428571) internal successors, (46), 5 states have internal predecessors, (46), 4 states have call successors, (16), 4 states have call predecessors, (16), 1 states have return successors, (15), 4 states have call predecessors, (15), 4 states have call successors, (15) [2022-02-20 21:08:19,936 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 77 edges. 77 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 21:08:19,936 INFO L546 AbstractCegarLoop]: INTERPOLANT automaton has 7 states [2022-02-20 21:08:19,936 INFO L108 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2022-02-20 21:08:19,937 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 7 interpolants. [2022-02-20 21:08:19,938 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=12, Invalid=30, Unknown=0, NotChecked=0, Total=42 [2022-02-20 21:08:19,938 INFO L87 Difference]: Start difference. First operand 125 states and 163 transitions. Second operand has 7 states, 7 states have (on average 6.571428571428571) internal successors, (46), 5 states have internal predecessors, (46), 4 states have call successors, (16), 4 states have call predecessors, (16), 1 states have return successors, (15), 4 states have call predecessors, (15), 4 states have call successors, (15) [2022-02-20 21:08:21,440 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 21:08:21,441 INFO L93 Difference]: Finished difference Result 213 states and 279 transitions. [2022-02-20 21:08:21,441 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 7 states. [2022-02-20 21:08:21,441 INFO L78 Accepts]: Start accepts. Automaton has has 7 states, 7 states have (on average 6.571428571428571) internal successors, (46), 5 states have internal predecessors, (46), 4 states have call successors, (16), 4 states have call predecessors, (16), 1 states have return successors, (15), 4 states have call predecessors, (15), 4 states have call successors, (15) Word has length 106 [2022-02-20 21:08:21,442 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-02-20 21:08:21,442 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 7 states, 7 states have (on average 6.571428571428571) internal successors, (46), 5 states have internal predecessors, (46), 4 states have call successors, (16), 4 states have call predecessors, (16), 1 states have return successors, (15), 4 states have call predecessors, (15), 4 states have call successors, (15) [2022-02-20 21:08:21,448 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 7 states to 7 states and 268 transitions. [2022-02-20 21:08:21,448 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 7 states, 7 states have (on average 6.571428571428571) internal successors, (46), 5 states have internal predecessors, (46), 4 states have call successors, (16), 4 states have call predecessors, (16), 1 states have return successors, (15), 4 states have call predecessors, (15), 4 states have call successors, (15) [2022-02-20 21:08:21,454 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 7 states to 7 states and 268 transitions. [2022-02-20 21:08:21,454 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with 7 states and 268 transitions. [2022-02-20 21:08:21,690 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 268 edges. 268 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 21:08:21,694 INFO L225 Difference]: With dead ends: 213 [2022-02-20 21:08:21,694 INFO L226 Difference]: Without dead ends: 160 [2022-02-20 21:08:21,695 INFO L932 BasicCegarLoop]: 0 DeclaredPredicates, 36 GetRequests, 30 SyntacticMatches, 0 SemanticMatches, 6 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 0 ImplicationChecksByTransitivity, 0.0s TimeCoverageRelationStatistics Valid=16, Invalid=40, Unknown=0, NotChecked=0, Total=56 [2022-02-20 21:08:21,695 INFO L933 BasicCegarLoop]: 142 mSDtfsCounter, 82 mSDsluCounter, 275 mSDsCounter, 0 mSdLazyCounter, 341 mSolverCounterSat, 70 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.5s Time, 0 mProtectedPredicate, 0 mProtectedAction, 94 SdHoareTripleChecker+Valid, 417 SdHoareTripleChecker+Invalid, 411 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 70 IncrementalHoareTripleChecker+Valid, 341 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.5s IncrementalHoareTripleChecker+Time [2022-02-20 21:08:21,696 INFO L934 BasicCegarLoop]: SdHoareTripleChecker [94 Valid, 417 Invalid, 411 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [70 Valid, 341 Invalid, 0 Unknown, 0 Unchecked, 0.5s Time] [2022-02-20 21:08:21,697 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 160 states. [2022-02-20 21:08:21,708 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 160 to 122. [2022-02-20 21:08:21,709 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-02-20 21:08:21,709 INFO L82 GeneralOperation]: Start isEquivalent. First operand 160 states. Second operand has 122 states, 75 states have (on average 1.16) internal successors, (87), 76 states have internal predecessors, (87), 36 states have call successors, (36), 10 states have call predecessors, (36), 10 states have return successors, (35), 35 states have call predecessors, (35), 35 states have call successors, (35) [2022-02-20 21:08:21,710 INFO L74 IsIncluded]: Start isIncluded. First operand 160 states. Second operand has 122 states, 75 states have (on average 1.16) internal successors, (87), 76 states have internal predecessors, (87), 36 states have call successors, (36), 10 states have call predecessors, (36), 10 states have return successors, (35), 35 states have call predecessors, (35), 35 states have call successors, (35) [2022-02-20 21:08:21,710 INFO L87 Difference]: Start difference. First operand 160 states. Second operand has 122 states, 75 states have (on average 1.16) internal successors, (87), 76 states have internal predecessors, (87), 36 states have call successors, (36), 10 states have call predecessors, (36), 10 states have return successors, (35), 35 states have call predecessors, (35), 35 states have call successors, (35) [2022-02-20 21:08:21,717 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 21:08:21,717 INFO L93 Difference]: Finished difference Result 160 states and 212 transitions. [2022-02-20 21:08:21,717 INFO L276 IsEmpty]: Start isEmpty. Operand 160 states and 212 transitions. [2022-02-20 21:08:21,718 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 21:08:21,719 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 21:08:21,719 INFO L74 IsIncluded]: Start isIncluded. First operand has 122 states, 75 states have (on average 1.16) internal successors, (87), 76 states have internal predecessors, (87), 36 states have call successors, (36), 10 states have call predecessors, (36), 10 states have return successors, (35), 35 states have call predecessors, (35), 35 states have call successors, (35) Second operand 160 states. [2022-02-20 21:08:21,720 INFO L87 Difference]: Start difference. First operand has 122 states, 75 states have (on average 1.16) internal successors, (87), 76 states have internal predecessors, (87), 36 states have call successors, (36), 10 states have call predecessors, (36), 10 states have return successors, (35), 35 states have call predecessors, (35), 35 states have call successors, (35) Second operand 160 states. [2022-02-20 21:08:21,726 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 21:08:21,726 INFO L93 Difference]: Finished difference Result 160 states and 212 transitions. [2022-02-20 21:08:21,727 INFO L276 IsEmpty]: Start isEmpty. Operand 160 states and 212 transitions. [2022-02-20 21:08:21,727 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 21:08:21,728 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 21:08:21,728 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-02-20 21:08:21,728 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-02-20 21:08:21,728 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 122 states, 75 states have (on average 1.16) internal successors, (87), 76 states have internal predecessors, (87), 36 states have call successors, (36), 10 states have call predecessors, (36), 10 states have return successors, (35), 35 states have call predecessors, (35), 35 states have call successors, (35) [2022-02-20 21:08:21,733 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 122 states to 122 states and 158 transitions. [2022-02-20 21:08:21,733 INFO L78 Accepts]: Start accepts. Automaton has 122 states and 158 transitions. Word has length 106 [2022-02-20 21:08:21,733 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-02-20 21:08:21,734 INFO L470 AbstractCegarLoop]: Abstraction has 122 states and 158 transitions. [2022-02-20 21:08:21,734 INFO L471 AbstractCegarLoop]: INTERPOLANT automaton has has 7 states, 7 states have (on average 6.571428571428571) internal successors, (46), 5 states have internal predecessors, (46), 4 states have call successors, (16), 4 states have call predecessors, (16), 1 states have return successors, (15), 4 states have call predecessors, (15), 4 states have call successors, (15) [2022-02-20 21:08:21,734 INFO L276 IsEmpty]: Start isEmpty. Operand 122 states and 158 transitions. [2022-02-20 21:08:21,735 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 131 [2022-02-20 21:08:21,735 INFO L506 BasicCegarLoop]: Found error trace [2022-02-20 21:08:21,736 INFO L514 BasicCegarLoop]: trace histogram [8, 8, 8, 3, 3, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2022-02-20 21:08:21,736 WARN L452 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable3 [2022-02-20 21:08:21,736 INFO L402 AbstractCegarLoop]: === Iteration 5 === Targeting __VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION === [__VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-02-20 21:08:21,736 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-02-20 21:08:21,736 INFO L85 PathProgramCache]: Analyzing trace with hash -704073469, now seen corresponding path program 1 times [2022-02-20 21:08:21,737 INFO L126 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-02-20 21:08:21,737 INFO L338 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [1786260496] [2022-02-20 21:08:21,737 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 21:08:21,737 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-02-20 21:08:21,788 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:21,873 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 2 [2022-02-20 21:08:21,880 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:21,892 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:08:21,893 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:21,900 INFO L290 TraceCheckUtils]: 0: Hoare triple {4172#true} #res := #t~nondet13;havoc #t~nondet13; {4172#true} is VALID [2022-02-20 21:08:21,900 INFO L290 TraceCheckUtils]: 1: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:21,900 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {4172#true} {4172#true} #182#return; {4172#true} is VALID [2022-02-20 21:08:21,901 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 6 [2022-02-20 21:08:21,901 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:21,908 INFO L290 TraceCheckUtils]: 0: Hoare triple {4172#true} ~cond := #in~cond; {4172#true} is VALID [2022-02-20 21:08:21,909 INFO L290 TraceCheckUtils]: 1: Hoare triple {4172#true} assume !(0 == ~cond % 256); {4172#true} is VALID [2022-02-20 21:08:21,909 INFO L290 TraceCheckUtils]: 2: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:21,909 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {4172#true} {4172#true} #184#return; {4172#true} is VALID [2022-02-20 21:08:21,917 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 12 [2022-02-20 21:08:21,921 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:21,928 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:08:21,929 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:21,937 INFO L290 TraceCheckUtils]: 0: Hoare triple {4172#true} ~cond := #in~cond; {4172#true} is VALID [2022-02-20 21:08:21,937 INFO L290 TraceCheckUtils]: 1: Hoare triple {4172#true} assume !(0 == ~cond % 256); {4172#true} is VALID [2022-02-20 21:08:21,937 INFO L290 TraceCheckUtils]: 2: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:21,937 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {4172#true} {4172#true} #192#return; {4172#true} is VALID [2022-02-20 21:08:21,938 INFO L290 TraceCheckUtils]: 0: Hoare triple {4299#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size; {4172#true} is VALID [2022-02-20 21:08:21,938 INFO L272 TraceCheckUtils]: 1: Hoare triple {4172#true} call assume_abort_if_not((if 0 == (if ~size % 18446744073709551616 <= 36028797018963967 then 1 else 0) then 0 else 1)); {4172#true} is VALID [2022-02-20 21:08:21,938 INFO L290 TraceCheckUtils]: 2: Hoare triple {4172#true} ~cond := #in~cond; {4172#true} is VALID [2022-02-20 21:08:21,938 INFO L290 TraceCheckUtils]: 3: Hoare triple {4172#true} assume !(0 == ~cond % 256); {4172#true} is VALID [2022-02-20 21:08:21,938 INFO L290 TraceCheckUtils]: 4: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:21,939 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {4172#true} {4172#true} #192#return; {4172#true} is VALID [2022-02-20 21:08:21,939 INFO L290 TraceCheckUtils]: 6: Hoare triple {4172#true} call #t~malloc555.base, #t~malloc555.offset := #Ultimate.allocOnHeap(~size);#res.base, #res.offset := #t~malloc555.base, #t~malloc555.offset;havoc #t~malloc555.base, #t~malloc555.offset; {4172#true} is VALID [2022-02-20 21:08:21,939 INFO L290 TraceCheckUtils]: 7: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:21,939 INFO L284 TraceCheckUtils]: 8: Hoare quadruple {4172#true} {4172#true} #186#return; {4172#true} is VALID [2022-02-20 21:08:21,939 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 23 [2022-02-20 21:08:21,940 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:21,947 INFO L290 TraceCheckUtils]: 0: Hoare triple {4172#true} #res := #t~nondet8;havoc #t~nondet8; {4172#true} is VALID [2022-02-20 21:08:21,947 INFO L290 TraceCheckUtils]: 1: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:21,947 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {4172#true} {4172#true} #188#return; {4172#true} is VALID [2022-02-20 21:08:21,947 INFO L290 TraceCheckUtils]: 0: Hoare triple {4279#(and (= |old(#length)| |#length|) (= |old(#memory_real)| |#memory_real|) (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|) (= |old(#valid)| |#valid|))} ~max_size#1 := #in~max_size#1; {4172#true} is VALID [2022-02-20 21:08:21,948 INFO L272 TraceCheckUtils]: 1: Hoare triple {4172#true} call #t~ret540#1 := nondet_uint64_t(); {4172#true} is VALID [2022-02-20 21:08:21,948 INFO L290 TraceCheckUtils]: 2: Hoare triple {4172#true} #res := #t~nondet13;havoc #t~nondet13; {4172#true} is VALID [2022-02-20 21:08:21,948 INFO L290 TraceCheckUtils]: 3: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:21,948 INFO L284 TraceCheckUtils]: 4: Hoare quadruple {4172#true} {4172#true} #182#return; {4172#true} is VALID [2022-02-20 21:08:21,948 INFO L290 TraceCheckUtils]: 5: Hoare triple {4172#true} ~len~1#1 := #t~ret540#1;havoc #t~ret540#1; {4172#true} is VALID [2022-02-20 21:08:21,948 INFO L272 TraceCheckUtils]: 6: Hoare triple {4172#true} call assume_abort_if_not((if 0 == (if ~len~1#1 % 18446744073709551616 < ~max_size#1 % 18446744073709551616 then 1 else 0) then 0 else 1)); {4172#true} is VALID [2022-02-20 21:08:21,949 INFO L290 TraceCheckUtils]: 7: Hoare triple {4172#true} ~cond := #in~cond; {4172#true} is VALID [2022-02-20 21:08:21,949 INFO L290 TraceCheckUtils]: 8: Hoare triple {4172#true} assume !(0 == ~cond % 256); {4172#true} is VALID [2022-02-20 21:08:21,949 INFO L290 TraceCheckUtils]: 9: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:21,949 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {4172#true} {4172#true} #184#return; {4172#true} is VALID [2022-02-20 21:08:21,949 INFO L290 TraceCheckUtils]: 11: Hoare triple {4172#true} assume { :begin_inline_ensure_string_is_allocated } true;ensure_string_is_allocated_#in~len#1 := ~len~1#1;havoc ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset;havoc ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset, ensure_string_is_allocated_#t~ret543#1, ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset, ensure_string_is_allocated_#t~ret544#1.base, ensure_string_is_allocated_#t~ret544#1.offset, ensure_string_is_allocated_~len#1, ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset;ensure_string_is_allocated_~len#1 := ensure_string_is_allocated_#in~len#1; {4172#true} is VALID [2022-02-20 21:08:21,950 INFO L272 TraceCheckUtils]: 12: Hoare triple {4172#true} call ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset := bounded_malloc(-1234550 + ensure_string_is_allocated_~len#1); {4299#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:08:21,950 INFO L290 TraceCheckUtils]: 13: Hoare triple {4299#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size; {4172#true} is VALID [2022-02-20 21:08:21,950 INFO L272 TraceCheckUtils]: 14: Hoare triple {4172#true} call assume_abort_if_not((if 0 == (if ~size % 18446744073709551616 <= 36028797018963967 then 1 else 0) then 0 else 1)); {4172#true} is VALID [2022-02-20 21:08:21,950 INFO L290 TraceCheckUtils]: 15: Hoare triple {4172#true} ~cond := #in~cond; {4172#true} is VALID [2022-02-20 21:08:21,951 INFO L290 TraceCheckUtils]: 16: Hoare triple {4172#true} assume !(0 == ~cond % 256); {4172#true} is VALID [2022-02-20 21:08:21,951 INFO L290 TraceCheckUtils]: 17: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:21,951 INFO L284 TraceCheckUtils]: 18: Hoare quadruple {4172#true} {4172#true} #192#return; {4172#true} is VALID [2022-02-20 21:08:21,951 INFO L290 TraceCheckUtils]: 19: Hoare triple {4172#true} call #t~malloc555.base, #t~malloc555.offset := #Ultimate.allocOnHeap(~size);#res.base, #res.offset := #t~malloc555.base, #t~malloc555.offset;havoc #t~malloc555.base, #t~malloc555.offset; {4172#true} is VALID [2022-02-20 21:08:21,951 INFO L290 TraceCheckUtils]: 20: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:21,951 INFO L284 TraceCheckUtils]: 21: Hoare quadruple {4172#true} {4172#true} #186#return; {4172#true} is VALID [2022-02-20 21:08:21,951 INFO L290 TraceCheckUtils]: 22: Hoare triple {4172#true} ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset := ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset;havoc ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset; {4172#true} is VALID [2022-02-20 21:08:21,952 INFO L272 TraceCheckUtils]: 23: Hoare triple {4172#true} call ensure_string_is_allocated_#t~ret543#1 := nondet_bool(); {4172#true} is VALID [2022-02-20 21:08:21,952 INFO L290 TraceCheckUtils]: 24: Hoare triple {4172#true} #res := #t~nondet8;havoc #t~nondet8; {4172#true} is VALID [2022-02-20 21:08:21,952 INFO L290 TraceCheckUtils]: 25: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:21,952 INFO L284 TraceCheckUtils]: 26: Hoare quadruple {4172#true} {4172#true} #188#return; {4172#true} is VALID [2022-02-20 21:08:21,952 INFO L290 TraceCheckUtils]: 27: Hoare triple {4172#true} assume !(0 != ensure_string_is_allocated_#t~ret543#1 % 256);ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset := 0, 0; {4172#true} is VALID [2022-02-20 21:08:21,952 INFO L290 TraceCheckUtils]: 28: Hoare triple {4172#true} call write~$Pointer$(ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset, ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset, 8);havoc ensure_string_is_allocated_#t~ret543#1;havoc ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset;havoc ensure_string_is_allocated_#t~ret544#1.base, ensure_string_is_allocated_#t~ret544#1.offset;call write~int(ensure_string_is_allocated_~len#1, ensure_string_is_allocated_~str~0#1.base, 8 + ensure_string_is_allocated_~str~0#1.offset, 8);call write~int(0, ensure_string_is_allocated_~str~0#1.base, 16 + ensure_string_is_allocated_~str~0#1.offset + (if ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 else ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset := ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset; {4172#true} is VALID [2022-02-20 21:08:21,953 INFO L290 TraceCheckUtils]: 29: Hoare triple {4172#true} #t~ret541#1.base, #t~ret541#1.offset := ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset;assume { :end_inline_ensure_string_is_allocated } true;#res#1.base, #res#1.offset := #t~ret541#1.base, #t~ret541#1.offset;havoc #t~ret541#1.base, #t~ret541#1.offset; {4172#true} is VALID [2022-02-20 21:08:21,953 INFO L290 TraceCheckUtils]: 30: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:21,953 INFO L284 TraceCheckUtils]: 31: Hoare quadruple {4172#true} {4172#true} #198#return; {4172#true} is VALID [2022-02-20 21:08:21,953 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 36 [2022-02-20 21:08:21,954 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:21,961 INFO L290 TraceCheckUtils]: 0: Hoare triple {4172#true} #res := #t~nondet8;havoc #t~nondet8; {4172#true} is VALID [2022-02-20 21:08:21,961 INFO L290 TraceCheckUtils]: 1: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:21,961 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {4172#true} {4172#true} #200#return; {4172#true} is VALID [2022-02-20 21:08:21,961 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 41 [2022-02-20 21:08:21,981 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:22,085 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:08:22,088 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:22,096 INFO L290 TraceCheckUtils]: 0: Hoare triple {4172#true} #res := #t~nondet13;havoc #t~nondet13; {4172#true} is VALID [2022-02-20 21:08:22,096 INFO L290 TraceCheckUtils]: 1: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:22,097 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {4172#true} {4304#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} #182#return; {4304#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} is VALID [2022-02-20 21:08:22,097 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 6 [2022-02-20 21:08:22,104 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:22,150 INFO L290 TraceCheckUtils]: 0: Hoare triple {4172#true} ~cond := #in~cond; {4327#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} is VALID [2022-02-20 21:08:22,151 INFO L290 TraceCheckUtils]: 1: Hoare triple {4327#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} assume !(0 == ~cond % 256); {4328#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} is VALID [2022-02-20 21:08:22,151 INFO L290 TraceCheckUtils]: 2: Hoare triple {4328#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} assume true; {4328#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} is VALID [2022-02-20 21:08:22,153 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {4328#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} {4304#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} #184#return; {4312#(or (not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96)) (<= |ensure_string_is_allocated_bounded_length_~len~1#1| (+ (* 18446744073709551616 (div |ensure_string_is_allocated_bounded_length_~len~1#1| 18446744073709551616)) 95)))} is VALID [2022-02-20 21:08:22,153 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 12 [2022-02-20 21:08:22,172 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:22,252 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:08:22,261 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:22,294 INFO L290 TraceCheckUtils]: 0: Hoare triple {4172#true} ~cond := #in~cond; {4327#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} is VALID [2022-02-20 21:08:22,295 INFO L290 TraceCheckUtils]: 1: Hoare triple {4327#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} assume !(0 == ~cond % 256); {4328#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} is VALID [2022-02-20 21:08:22,296 INFO L290 TraceCheckUtils]: 2: Hoare triple {4328#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} assume true; {4328#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} is VALID [2022-02-20 21:08:22,296 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {4328#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} {4329#(= |bounded_malloc_#in~size| bounded_malloc_~size)} #192#return; {4334#(and (= |bounded_malloc_#in~size| bounded_malloc_~size) (<= bounded_malloc_~size (+ (* (div bounded_malloc_~size 18446744073709551616) 18446744073709551616) 36028797018963967)))} is VALID [2022-02-20 21:08:22,297 INFO L290 TraceCheckUtils]: 0: Hoare triple {4299#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size; {4329#(= |bounded_malloc_#in~size| bounded_malloc_~size)} is VALID [2022-02-20 21:08:22,297 INFO L272 TraceCheckUtils]: 1: Hoare triple {4329#(= |bounded_malloc_#in~size| bounded_malloc_~size)} call assume_abort_if_not((if 0 == (if ~size % 18446744073709551616 <= 36028797018963967 then 1 else 0) then 0 else 1)); {4172#true} is VALID [2022-02-20 21:08:22,297 INFO L290 TraceCheckUtils]: 2: Hoare triple {4172#true} ~cond := #in~cond; {4327#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} is VALID [2022-02-20 21:08:22,298 INFO L290 TraceCheckUtils]: 3: Hoare triple {4327#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} assume !(0 == ~cond % 256); {4328#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} is VALID [2022-02-20 21:08:22,299 INFO L290 TraceCheckUtils]: 4: Hoare triple {4328#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} assume true; {4328#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} is VALID [2022-02-20 21:08:22,299 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {4328#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} {4329#(= |bounded_malloc_#in~size| bounded_malloc_~size)} #192#return; {4334#(and (= |bounded_malloc_#in~size| bounded_malloc_~size) (<= bounded_malloc_~size (+ (* (div bounded_malloc_~size 18446744073709551616) 18446744073709551616) 36028797018963967)))} is VALID [2022-02-20 21:08:22,300 INFO L290 TraceCheckUtils]: 6: Hoare triple {4334#(and (= |bounded_malloc_#in~size| bounded_malloc_~size) (<= bounded_malloc_~size (+ (* (div bounded_malloc_~size 18446744073709551616) 18446744073709551616) 36028797018963967)))} call #t~malloc555.base, #t~malloc555.offset := #Ultimate.allocOnHeap(~size);#res.base, #res.offset := #t~malloc555.base, #t~malloc555.offset;havoc #t~malloc555.base, #t~malloc555.offset; {4335#(<= |bounded_malloc_#in~size| (+ 36028797018963967 (* 18446744073709551616 (div |bounded_malloc_#in~size| 18446744073709551616))))} is VALID [2022-02-20 21:08:22,301 INFO L290 TraceCheckUtils]: 7: Hoare triple {4335#(<= |bounded_malloc_#in~size| (+ 36028797018963967 (* 18446744073709551616 (div |bounded_malloc_#in~size| 18446744073709551616))))} assume true; {4335#(<= |bounded_malloc_#in~size| (+ 36028797018963967 (* 18446744073709551616 (div |bounded_malloc_#in~size| 18446744073709551616))))} is VALID [2022-02-20 21:08:22,313 INFO L284 TraceCheckUtils]: 8: Hoare quadruple {4335#(<= |bounded_malloc_#in~size| (+ 36028797018963967 (* 18446744073709551616 (div |bounded_malloc_#in~size| 18446744073709551616))))} {4313#(or (not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96)) (<= (* (div (+ 18446744073709551520 |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~len#1|) 18446744073709551616) 18446744073709551616) |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~len#1|))} #186#return; {4323#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} is VALID [2022-02-20 21:08:22,313 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 23 [2022-02-20 21:08:22,315 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:22,328 INFO L290 TraceCheckUtils]: 0: Hoare triple {4172#true} #res := #t~nondet8;havoc #t~nondet8; {4172#true} is VALID [2022-02-20 21:08:22,328 INFO L290 TraceCheckUtils]: 1: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:22,331 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {4172#true} {4323#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} #188#return; {4323#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} is VALID [2022-02-20 21:08:22,332 INFO L290 TraceCheckUtils]: 0: Hoare triple {4279#(and (= |old(#length)| |#length|) (= |old(#memory_real)| |#memory_real|) (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|) (= |old(#valid)| |#valid|))} ~max_size#1 := #in~max_size#1; {4304#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} is VALID [2022-02-20 21:08:22,332 INFO L272 TraceCheckUtils]: 1: Hoare triple {4304#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} call #t~ret540#1 := nondet_uint64_t(); {4172#true} is VALID [2022-02-20 21:08:22,332 INFO L290 TraceCheckUtils]: 2: Hoare triple {4172#true} #res := #t~nondet13;havoc #t~nondet13; {4172#true} is VALID [2022-02-20 21:08:22,333 INFO L290 TraceCheckUtils]: 3: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:22,333 INFO L284 TraceCheckUtils]: 4: Hoare quadruple {4172#true} {4304#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} #182#return; {4304#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} is VALID [2022-02-20 21:08:22,333 INFO L290 TraceCheckUtils]: 5: Hoare triple {4304#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} ~len~1#1 := #t~ret540#1;havoc #t~ret540#1; {4304#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} is VALID [2022-02-20 21:08:22,334 INFO L272 TraceCheckUtils]: 6: Hoare triple {4304#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} call assume_abort_if_not((if 0 == (if ~len~1#1 % 18446744073709551616 < ~max_size#1 % 18446744073709551616 then 1 else 0) then 0 else 1)); {4172#true} is VALID [2022-02-20 21:08:22,334 INFO L290 TraceCheckUtils]: 7: Hoare triple {4172#true} ~cond := #in~cond; {4327#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} is VALID [2022-02-20 21:08:22,335 INFO L290 TraceCheckUtils]: 8: Hoare triple {4327#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} assume !(0 == ~cond % 256); {4328#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} is VALID [2022-02-20 21:08:22,335 INFO L290 TraceCheckUtils]: 9: Hoare triple {4328#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} assume true; {4328#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} is VALID [2022-02-20 21:08:22,336 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {4328#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} {4304#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} #184#return; {4312#(or (not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96)) (<= |ensure_string_is_allocated_bounded_length_~len~1#1| (+ (* 18446744073709551616 (div |ensure_string_is_allocated_bounded_length_~len~1#1| 18446744073709551616)) 95)))} is VALID [2022-02-20 21:08:22,358 INFO L290 TraceCheckUtils]: 11: Hoare triple {4312#(or (not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96)) (<= |ensure_string_is_allocated_bounded_length_~len~1#1| (+ (* 18446744073709551616 (div |ensure_string_is_allocated_bounded_length_~len~1#1| 18446744073709551616)) 95)))} assume { :begin_inline_ensure_string_is_allocated } true;ensure_string_is_allocated_#in~len#1 := ~len~1#1;havoc ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset;havoc ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset, ensure_string_is_allocated_#t~ret543#1, ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset, ensure_string_is_allocated_#t~ret544#1.base, ensure_string_is_allocated_#t~ret544#1.offset, ensure_string_is_allocated_~len#1, ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset;ensure_string_is_allocated_~len#1 := ensure_string_is_allocated_#in~len#1; {4313#(or (not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96)) (<= (* (div (+ 18446744073709551520 |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~len#1|) 18446744073709551616) 18446744073709551616) |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~len#1|))} is VALID [2022-02-20 21:08:22,360 INFO L272 TraceCheckUtils]: 12: Hoare triple {4313#(or (not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96)) (<= (* (div (+ 18446744073709551520 |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~len#1|) 18446744073709551616) 18446744073709551616) |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~len#1|))} call ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset := bounded_malloc(-1234550 + ensure_string_is_allocated_~len#1); {4299#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:08:22,360 INFO L290 TraceCheckUtils]: 13: Hoare triple {4299#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size; {4329#(= |bounded_malloc_#in~size| bounded_malloc_~size)} is VALID [2022-02-20 21:08:22,360 INFO L272 TraceCheckUtils]: 14: Hoare triple {4329#(= |bounded_malloc_#in~size| bounded_malloc_~size)} call assume_abort_if_not((if 0 == (if ~size % 18446744073709551616 <= 36028797018963967 then 1 else 0) then 0 else 1)); {4172#true} is VALID [2022-02-20 21:08:22,361 INFO L290 TraceCheckUtils]: 15: Hoare triple {4172#true} ~cond := #in~cond; {4327#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} is VALID [2022-02-20 21:08:22,361 INFO L290 TraceCheckUtils]: 16: Hoare triple {4327#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} assume !(0 == ~cond % 256); {4328#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} is VALID [2022-02-20 21:08:22,362 INFO L290 TraceCheckUtils]: 17: Hoare triple {4328#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} assume true; {4328#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} is VALID [2022-02-20 21:08:22,363 INFO L284 TraceCheckUtils]: 18: Hoare quadruple {4328#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} {4329#(= |bounded_malloc_#in~size| bounded_malloc_~size)} #192#return; {4334#(and (= |bounded_malloc_#in~size| bounded_malloc_~size) (<= bounded_malloc_~size (+ (* (div bounded_malloc_~size 18446744073709551616) 18446744073709551616) 36028797018963967)))} is VALID [2022-02-20 21:08:22,363 INFO L290 TraceCheckUtils]: 19: Hoare triple {4334#(and (= |bounded_malloc_#in~size| bounded_malloc_~size) (<= bounded_malloc_~size (+ (* (div bounded_malloc_~size 18446744073709551616) 18446744073709551616) 36028797018963967)))} call #t~malloc555.base, #t~malloc555.offset := #Ultimate.allocOnHeap(~size);#res.base, #res.offset := #t~malloc555.base, #t~malloc555.offset;havoc #t~malloc555.base, #t~malloc555.offset; {4335#(<= |bounded_malloc_#in~size| (+ 36028797018963967 (* 18446744073709551616 (div |bounded_malloc_#in~size| 18446744073709551616))))} is VALID [2022-02-20 21:08:22,364 INFO L290 TraceCheckUtils]: 20: Hoare triple {4335#(<= |bounded_malloc_#in~size| (+ 36028797018963967 (* 18446744073709551616 (div |bounded_malloc_#in~size| 18446744073709551616))))} assume true; {4335#(<= |bounded_malloc_#in~size| (+ 36028797018963967 (* 18446744073709551616 (div |bounded_malloc_#in~size| 18446744073709551616))))} is VALID [2022-02-20 21:08:22,366 INFO L284 TraceCheckUtils]: 21: Hoare quadruple {4335#(<= |bounded_malloc_#in~size| (+ 36028797018963967 (* 18446744073709551616 (div |bounded_malloc_#in~size| 18446744073709551616))))} {4313#(or (not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96)) (<= (* (div (+ 18446744073709551520 |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~len#1|) 18446744073709551616) 18446744073709551616) |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~len#1|))} #186#return; {4323#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} is VALID [2022-02-20 21:08:22,366 INFO L290 TraceCheckUtils]: 22: Hoare triple {4323#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset := ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset;havoc ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset; {4323#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} is VALID [2022-02-20 21:08:22,366 INFO L272 TraceCheckUtils]: 23: Hoare triple {4323#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} call ensure_string_is_allocated_#t~ret543#1 := nondet_bool(); {4172#true} is VALID [2022-02-20 21:08:22,366 INFO L290 TraceCheckUtils]: 24: Hoare triple {4172#true} #res := #t~nondet8;havoc #t~nondet8; {4172#true} is VALID [2022-02-20 21:08:22,366 INFO L290 TraceCheckUtils]: 25: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:22,367 INFO L284 TraceCheckUtils]: 26: Hoare quadruple {4172#true} {4323#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} #188#return; {4323#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} is VALID [2022-02-20 21:08:22,367 INFO L290 TraceCheckUtils]: 27: Hoare triple {4323#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} assume !(0 != ensure_string_is_allocated_#t~ret543#1 % 256);ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset := 0, 0; {4323#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} is VALID [2022-02-20 21:08:22,368 INFO L290 TraceCheckUtils]: 28: Hoare triple {4323#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} call write~$Pointer$(ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset, ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset, 8);havoc ensure_string_is_allocated_#t~ret543#1;havoc ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset;havoc ensure_string_is_allocated_#t~ret544#1.base, ensure_string_is_allocated_#t~ret544#1.offset;call write~int(ensure_string_is_allocated_~len#1, ensure_string_is_allocated_~str~0#1.base, 8 + ensure_string_is_allocated_~str~0#1.offset, 8);call write~int(0, ensure_string_is_allocated_~str~0#1.base, 16 + ensure_string_is_allocated_~str~0#1.offset + (if ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 else ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset := ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset; {4323#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} is VALID [2022-02-20 21:08:22,368 INFO L290 TraceCheckUtils]: 29: Hoare triple {4323#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} #t~ret541#1.base, #t~ret541#1.offset := ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset;assume { :end_inline_ensure_string_is_allocated } true;#res#1.base, #res#1.offset := #t~ret541#1.base, #t~ret541#1.offset;havoc #t~ret541#1.base, #t~ret541#1.offset; {4323#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} is VALID [2022-02-20 21:08:22,369 INFO L290 TraceCheckUtils]: 30: Hoare triple {4323#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} assume true; {4323#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} is VALID [2022-02-20 21:08:22,369 INFO L284 TraceCheckUtils]: 31: Hoare quadruple {4323#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} {4172#true} #202#return; {4241#(not (= 0 |ULTIMATE.start_aws_hash_callback_string_eq_harness_#t~ret1965#1.base|))} is VALID [2022-02-20 21:08:22,370 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 76 [2022-02-20 21:08:22,374 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:22,385 INFO L290 TraceCheckUtils]: 0: Hoare triple {4172#true} ~str.base, ~str.offset := #in~str.base, #in~str.offset;#t~short464 := ~str.base != 0 || ~str.offset != 0; {4172#true} is VALID [2022-02-20 21:08:22,386 INFO L290 TraceCheckUtils]: 1: Hoare triple {4172#true} assume #t~short464;call #t~mem463 := read~int(~str.base, 8 + ~str.offset, 8);#t~short464 := 0 == (1 + #t~mem463) % 18446744073709551616 || ~str.base != 0 || 16 + ~str.offset != 0; {4172#true} is VALID [2022-02-20 21:08:22,386 INFO L290 TraceCheckUtils]: 2: Hoare triple {4172#true} #t~short467 := #t~short464; {4172#true} is VALID [2022-02-20 21:08:22,386 INFO L290 TraceCheckUtils]: 3: Hoare triple {4172#true} assume #t~short467;call #t~mem465 := read~int(~str.base, 8 + ~str.offset, 8);call #t~mem466 := read~int(~str.base, 16 + ~str.offset + (if #t~mem465 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then #t~mem465 % 18446744073709551616 % 18446744073709551616 else #t~mem465 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);#t~short467 := 0 == #t~mem466 % 256; {4172#true} is VALID [2022-02-20 21:08:22,386 INFO L290 TraceCheckUtils]: 4: Hoare triple {4172#true} #res := (if 0 == (if #t~short467 then 1 else 0) then 0 else 1);havoc #t~mem463;havoc #t~short464;havoc #t~mem465;havoc #t~mem466;havoc #t~short467; {4172#true} is VALID [2022-02-20 21:08:22,386 INFO L290 TraceCheckUtils]: 5: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:22,387 INFO L284 TraceCheckUtils]: 6: Hoare quadruple {4172#true} {4243#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} #204#return; {4243#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} is VALID [2022-02-20 21:08:22,387 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 84 [2022-02-20 21:08:22,389 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:22,398 INFO L290 TraceCheckUtils]: 0: Hoare triple {4172#true} ~cond := #in~cond; {4172#true} is VALID [2022-02-20 21:08:22,398 INFO L290 TraceCheckUtils]: 1: Hoare triple {4172#true} assume !(0 == ~cond % 256); {4172#true} is VALID [2022-02-20 21:08:22,398 INFO L290 TraceCheckUtils]: 2: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:22,399 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {4172#true} {4243#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} #206#return; {4243#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} is VALID [2022-02-20 21:08:22,399 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 90 [2022-02-20 21:08:22,403 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:22,414 INFO L290 TraceCheckUtils]: 0: Hoare triple {4172#true} ~str.base, ~str.offset := #in~str.base, #in~str.offset;#t~short464 := ~str.base != 0 || ~str.offset != 0; {4172#true} is VALID [2022-02-20 21:08:22,414 INFO L290 TraceCheckUtils]: 1: Hoare triple {4172#true} assume #t~short464;call #t~mem463 := read~int(~str.base, 8 + ~str.offset, 8);#t~short464 := 0 == (1 + #t~mem463) % 18446744073709551616 || ~str.base != 0 || 16 + ~str.offset != 0; {4172#true} is VALID [2022-02-20 21:08:22,415 INFO L290 TraceCheckUtils]: 2: Hoare triple {4172#true} #t~short467 := #t~short464; {4172#true} is VALID [2022-02-20 21:08:22,415 INFO L290 TraceCheckUtils]: 3: Hoare triple {4172#true} assume #t~short467;call #t~mem465 := read~int(~str.base, 8 + ~str.offset, 8);call #t~mem466 := read~int(~str.base, 16 + ~str.offset + (if #t~mem465 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then #t~mem465 % 18446744073709551616 % 18446744073709551616 else #t~mem465 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);#t~short467 := 0 == #t~mem466 % 256; {4172#true} is VALID [2022-02-20 21:08:22,415 INFO L290 TraceCheckUtils]: 4: Hoare triple {4172#true} #res := (if 0 == (if #t~short467 then 1 else 0) then 0 else 1);havoc #t~mem463;havoc #t~short464;havoc #t~mem465;havoc #t~mem466;havoc #t~short467; {4172#true} is VALID [2022-02-20 21:08:22,415 INFO L290 TraceCheckUtils]: 5: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:22,416 INFO L284 TraceCheckUtils]: 6: Hoare quadruple {4172#true} {4243#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} #208#return; {4243#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} is VALID [2022-02-20 21:08:22,416 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 98 [2022-02-20 21:08:22,418 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:22,427 INFO L290 TraceCheckUtils]: 0: Hoare triple {4172#true} ~cond := #in~cond; {4172#true} is VALID [2022-02-20 21:08:22,427 INFO L290 TraceCheckUtils]: 1: Hoare triple {4172#true} assume !(0 == ~cond % 256); {4172#true} is VALID [2022-02-20 21:08:22,427 INFO L290 TraceCheckUtils]: 2: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:22,428 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {4172#true} {4243#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} #210#return; {4243#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} is VALID [2022-02-20 21:08:22,428 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 105 [2022-02-20 21:08:22,430 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:22,439 INFO L290 TraceCheckUtils]: 0: Hoare triple {4172#true} ~cond := #in~cond; {4172#true} is VALID [2022-02-20 21:08:22,439 INFO L290 TraceCheckUtils]: 1: Hoare triple {4172#true} assume !(0 == ~cond % 256); {4172#true} is VALID [2022-02-20 21:08:22,440 INFO L290 TraceCheckUtils]: 2: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:22,440 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {4172#true} {4266#(not (= |ULTIMATE.start_aws_string_eq_~b#1.base| 0))} #214#return; {4266#(not (= |ULTIMATE.start_aws_string_eq_~b#1.base| 0))} is VALID [2022-02-20 21:08:22,440 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 112 [2022-02-20 21:08:22,441 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:22,449 INFO L290 TraceCheckUtils]: 0: Hoare triple {4172#true} ~cond := #in~cond; {4172#true} is VALID [2022-02-20 21:08:22,449 INFO L290 TraceCheckUtils]: 1: Hoare triple {4172#true} assume !(0 == ~cond % 256); {4172#true} is VALID [2022-02-20 21:08:22,449 INFO L290 TraceCheckUtils]: 2: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:22,449 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {4172#true} {4173#false} #218#return; {4173#false} is VALID [2022-02-20 21:08:22,449 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 120 [2022-02-20 21:08:22,450 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:22,457 INFO L290 TraceCheckUtils]: 0: Hoare triple {4172#true} ~str.base, ~str.offset := #in~str.base, #in~str.offset;#res := (if 0 == (if (~str.base != 0 || ~str.offset != 0) && (~str.base != 0 || ~str.offset != 0) then 1 else 0) then 0 else 1); {4172#true} is VALID [2022-02-20 21:08:22,458 INFO L290 TraceCheckUtils]: 1: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:22,458 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {4172#true} {4173#false} #222#return; {4173#false} is VALID [2022-02-20 21:08:22,458 INFO L290 TraceCheckUtils]: 0: Hoare triple {4172#true} assume { :begin_inline_ULTIMATE.init } true;#NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(38, 2);call #Ultimate.allocInit(12, 3);call #Ultimate.allocInit(78, 4);~#s_can_fail_allocator_static~0.base, ~#s_can_fail_allocator_static~0.offset := 5, 0;call #Ultimate.allocInit(40, 5);call write~init~$Pointer$(#funAddr~s_can_fail_malloc_allocator.base, #funAddr~s_can_fail_malloc_allocator.offset, ~#s_can_fail_allocator_static~0.base, ~#s_can_fail_allocator_static~0.offset, 8);call write~init~$Pointer$(#funAddr~s_can_fail_free_allocator.base, #funAddr~s_can_fail_free_allocator.offset, ~#s_can_fail_allocator_static~0.base, 8 + ~#s_can_fail_allocator_static~0.offset, 8);call write~init~$Pointer$(#funAddr~s_can_fail_realloc_allocator.base, #funAddr~s_can_fail_realloc_allocator.offset, ~#s_can_fail_allocator_static~0.base, 16 + ~#s_can_fail_allocator_static~0.offset, 8);call write~init~$Pointer$(#funAddr~s_can_fail_calloc_allocator.base, #funAddr~s_can_fail_calloc_allocator.offset, ~#s_can_fail_allocator_static~0.base, 24 + ~#s_can_fail_allocator_static~0.offset, 8);call write~init~$Pointer$(0, 0, ~#s_can_fail_allocator_static~0.base, 32 + ~#s_can_fail_allocator_static~0.offset, 8);~#s_tolower_table~0.base, ~#s_tolower_table~0.offset := 6, 0;call #Ultimate.allocInit(256, 6);call write~init~int(0, ~#s_tolower_table~0.base, ~#s_tolower_table~0.offset, 1);call write~init~int(1, ~#s_tolower_table~0.base, 1 + ~#s_tolower_table~0.offset, 1);call write~init~int(2, ~#s_tolower_table~0.base, 2 + ~#s_tolower_table~0.offset, 1);call write~init~int(3, ~#s_tolower_table~0.base, 3 + ~#s_tolower_table~0.offset, 1);call write~init~int(4, ~#s_tolower_table~0.base, 4 + ~#s_tolower_table~0.offset, 1);call write~init~int(5, ~#s_tolower_table~0.base, 5 + ~#s_tolower_table~0.offset, 1);call write~init~int(6, ~#s_tolower_table~0.base, 6 + ~#s_tolower_table~0.offset, 1);call write~init~int(7, ~#s_tolower_table~0.base, 7 + ~#s_tolower_table~0.offset, 1);call write~init~int(8, ~#s_tolower_table~0.base, 8 + ~#s_tolower_table~0.offset, 1);call write~init~int(9, ~#s_tolower_table~0.base, 9 + ~#s_tolower_table~0.offset, 1);call write~init~int(10, ~#s_tolower_table~0.base, 10 + ~#s_tolower_table~0.offset, 1);call write~init~int(11, ~#s_tolower_table~0.base, 11 + ~#s_tolower_table~0.offset, 1);call write~init~int(12, ~#s_tolower_table~0.base, 12 + ~#s_tolower_table~0.offset, 1);call write~init~int(13, ~#s_tolower_table~0.base, 13 + ~#s_tolower_table~0.offset, 1);call write~init~int(14, ~#s_tolower_table~0.base, 14 + ~#s_tolower_table~0.offset, 1);call write~init~int(15, ~#s_tolower_table~0.base, 15 + ~#s_tolower_table~0.offset, 1);call write~init~int(16, ~#s_tolower_table~0.base, 16 + ~#s_tolower_table~0.offset, 1);call write~init~int(17, ~#s_tolower_table~0.base, 17 + ~#s_tolower_table~0.offset, 1);call write~init~int(18, ~#s_tolower_table~0.base, 18 + ~#s_tolower_table~0.offset, 1);call write~init~int(19, ~#s_tolower_table~0.base, 19 + ~#s_tolower_table~0.offset, 1);call write~init~int(20, ~#s_tolower_table~0.base, 20 + ~#s_tolower_table~0.offset, 1);call write~init~int(21, ~#s_tolower_table~0.base, 21 + ~#s_tolower_table~0.offset, 1);call write~init~int(22, ~#s_tolower_table~0.base, 22 + ~#s_tolower_table~0.offset, 1);call write~init~int(23, ~#s_tolower_table~0.base, 23 + ~#s_tolower_table~0.offset, 1);call write~init~int(24, ~#s_tolower_table~0.base, 24 + ~#s_tolower_table~0.offset, 1);call write~init~int(25, ~#s_tolower_table~0.base, 25 + ~#s_tolower_table~0.offset, 1);call write~init~int(26, ~#s_tolower_table~0.base, 26 + ~#s_tolower_table~0.offset, 1);call write~init~int(27, ~#s_tolower_table~0.base, 27 + ~#s_tolower_table~0.offset, 1);call write~init~int(28, ~#s_tolower_table~0.base, 28 + ~#s_tolower_table~0.offset, 1);call write~init~int(29, ~#s_tolower_table~0.base, 29 + ~#s_tolower_table~0.offset, 1);call write~init~int(30, ~#s_tolower_table~0.base, 30 + ~#s_tolower_table~0.offset, 1);call write~init~int(31, ~#s_tolower_table~0.base, 31 + ~#s_tolower_table~0.offset, 1);call write~init~int(32, ~#s_tolower_table~0.base, 32 + ~#s_tolower_table~0.offset, 1);call write~init~int(33, ~#s_tolower_table~0.base, 33 + ~#s_tolower_table~0.offset, 1);call write~init~int(34, ~#s_tolower_table~0.base, 34 + ~#s_tolower_table~0.offset, 1);call write~init~int(35, ~#s_tolower_table~0.base, 35 + ~#s_tolower_table~0.offset, 1);call write~init~int(36, ~#s_tolower_table~0.base, 36 + ~#s_tolower_table~0.offset, 1);call write~init~int(37, ~#s_tolower_table~0.base, 37 + ~#s_tolower_table~0.offset, 1);call write~init~int(38, ~#s_tolower_table~0.base, 38 + ~#s_tolower_table~0.offset, 1);call write~init~int(39, ~#s_tolower_table~0.base, 39 + ~#s_tolower_table~0.offset, 1);call write~init~int(40, ~#s_tolower_table~0.base, 40 + ~#s_tolower_table~0.offset, 1);call write~init~int(41, ~#s_tolower_table~0.base, 41 + ~#s_tolower_table~0.offset, 1);call write~init~int(42, ~#s_tolower_table~0.base, 42 + ~#s_tolower_table~0.offset, 1);call write~init~int(43, ~#s_tolower_table~0.base, 43 + ~#s_tolower_table~0.offset, 1);call write~init~int(44, ~#s_tolower_table~0.base, 44 + ~#s_tolower_table~0.offset, 1);call write~init~int(45, ~#s_tolower_table~0.base, 45 + ~#s_tolower_table~0.offset, 1);call write~init~int(46, ~#s_tolower_table~0.base, 46 + ~#s_tolower_table~0.offset, 1);call write~init~int(47, ~#s_tolower_table~0.base, 47 + ~#s_tolower_table~0.offset, 1);call write~init~int(48, ~#s_tolower_table~0.base, 48 + ~#s_tolower_table~0.offset, 1);call write~init~int(49, ~#s_tolower_table~0.base, 49 + ~#s_tolower_table~0.offset, 1);call write~init~int(50, ~#s_tolower_table~0.base, 50 + ~#s_tolower_table~0.offset, 1);call write~init~int(51, ~#s_tolower_table~0.base, 51 + ~#s_tolower_table~0.offset, 1);call write~init~int(52, ~#s_tolower_table~0.base, 52 + ~#s_tolower_table~0.offset, 1);call write~init~int(53, ~#s_tolower_table~0.base, 53 + ~#s_tolower_table~0.offset, 1);call write~init~int(54, ~#s_tolower_table~0.base, 54 + ~#s_tolower_table~0.offset, 1);call write~init~int(55, ~#s_tolower_table~0.base, 55 + ~#s_tolower_table~0.offset, 1);call write~init~int(56, ~#s_tolower_table~0.base, 56 + ~#s_tolower_table~0.offset, 1);call write~init~int(57, ~#s_tolower_table~0.base, 57 + ~#s_tolower_table~0.offset, 1);call write~init~int(58, ~#s_tolower_table~0.base, 58 + ~#s_tolower_table~0.offset, 1);call write~init~int(59, ~#s_tolower_table~0.base, 59 + ~#s_tolower_table~0.offset, 1);call write~init~int(60, ~#s_tolower_table~0.base, 60 + ~#s_tolower_table~0.offset, 1);call write~init~int(61, ~#s_tolower_table~0.base, 61 + ~#s_tolower_table~0.offset, 1);call write~init~int(62, ~#s_tolower_table~0.base, 62 + ~#s_tolower_table~0.offset, 1);call write~init~int(63, ~#s_tolower_table~0.base, 63 + ~#s_tolower_table~0.offset, 1);call write~init~int(64, ~#s_tolower_table~0.base, 64 + ~#s_tolower_table~0.offset, 1);call write~init~int(97, ~#s_tolower_table~0.base, 65 + ~#s_tolower_table~0.offset, 1);call write~init~int(98, ~#s_tolower_table~0.base, 66 + ~#s_tolower_table~0.offset, 1);call write~init~int(99, ~#s_tolower_table~0.base, 67 + ~#s_tolower_table~0.offset, 1);call write~init~int(100, ~#s_tolower_table~0.base, 68 + ~#s_tolower_table~0.offset, 1);call write~init~int(101, ~#s_tolower_table~0.base, 69 + ~#s_tolower_table~0.offset, 1);call write~init~int(102, ~#s_tolower_table~0.base, 70 + ~#s_tolower_table~0.offset, 1);call write~init~int(103, ~#s_tolower_table~0.base, 71 + ~#s_tolower_table~0.offset, 1);call write~init~int(104, ~#s_tolower_table~0.base, 72 + ~#s_tolower_table~0.offset, 1);call write~init~int(105, ~#s_tolower_table~0.base, 73 + ~#s_tolower_table~0.offset, 1);call write~init~int(106, ~#s_tolower_table~0.base, 74 + ~#s_tolower_table~0.offset, 1);call write~init~int(107, ~#s_tolower_table~0.base, 75 + ~#s_tolower_table~0.offset, 1);call write~init~int(108, ~#s_tolower_table~0.base, 76 + ~#s_tolower_table~0.offset, 1);call write~init~int(109, ~#s_tolower_table~0.base, 77 + ~#s_tolower_table~0.offset, 1);call write~init~int(110, ~#s_tolower_table~0.base, 78 + ~#s_tolower_table~0.offset, 1);call write~init~int(111, ~#s_tolower_table~0.base, 79 + ~#s_tolower_table~0.offset, 1);call write~init~int(112, ~#s_tolower_table~0.base, 80 + ~#s_tolower_table~0.offset, 1);call write~init~int(113, ~#s_tolower_table~0.base, 81 + ~#s_tolower_table~0.offset, 1);call write~init~int(114, ~#s_tolower_table~0.base, 82 + ~#s_tolower_table~0.offset, 1);call write~init~int(115, ~#s_tolower_table~0.base, 83 + ~#s_tolower_table~0.offset, 1);call write~init~int(116, ~#s_tolower_table~0.base, 84 + ~#s_tolower_table~0.offset, 1);call write~init~int(117, ~#s_tolower_table~0.base, 85 + ~#s_tolower_table~0.offset, 1);call write~init~int(118, ~#s_tolower_table~0.base, 86 + ~#s_tolower_table~0.offset, 1);call write~init~int(119, ~#s_tolower_table~0.base, 87 + ~#s_tolower_table~0.offset, 1);call write~init~int(120, ~#s_tolower_table~0.base, 88 + ~#s_tolower_table~0.offset, 1);call write~init~int(121, ~#s_tolower_table~0.base, 89 + ~#s_tolower_table~0.offset, 1);call write~init~int(122, ~#s_tolower_table~0.base, 90 + ~#s_tolower_table~0.offset, 1);call write~init~int(91, ~#s_tolower_table~0.base, 91 + ~#s_tolower_table~0.offset, 1);call write~init~int(92, ~#s_tolower_table~0.base, 92 + ~#s_tolower_table~0.offset, 1);call write~init~int(93, ~#s_tolower_table~0.base, 93 + ~#s_tolower_table~0.offset, 1);call write~init~int(94, ~#s_tolower_table~0.base, 94 + ~#s_tolower_table~0.offset, 1);call write~init~int(95, ~#s_tolower_table~0.base, 95 + ~#s_tolower_table~0.offset, 1);call write~init~int(96, ~#s_tolower_table~0.base, 96 + ~#s_tolower_table~0.offset, 1);call write~init~int(97, ~#s_tolower_table~0.base, 97 + ~#s_tolower_table~0.offset, 1);call write~init~int(98, ~#s_tolower_table~0.base, 98 + ~#s_tolower_table~0.offset, 1);call write~init~int(99, ~#s_tolower_table~0.base, 99 + ~#s_tolower_table~0.offset, 1);call write~init~int(100, ~#s_tolower_table~0.base, 100 + ~#s_tolower_table~0.offset, 1);call write~init~int(101, ~#s_tolower_table~0.base, 101 + ~#s_tolower_table~0.offset, 1);call write~init~int(102, ~#s_tolower_table~0.base, 102 + ~#s_tolower_table~0.offset, 1);call write~init~int(103, ~#s_tolower_table~0.base, 103 + ~#s_tolower_table~0.offset, 1);call write~init~int(104, ~#s_tolower_table~0.base, 104 + ~#s_tolower_table~0.offset, 1);call write~init~int(105, ~#s_tolower_table~0.base, 105 + ~#s_tolower_table~0.offset, 1);call write~init~int(106, ~#s_tolower_table~0.base, 106 + ~#s_tolower_table~0.offset, 1);call write~init~int(107, ~#s_tolower_table~0.base, 107 + ~#s_tolower_table~0.offset, 1);call write~init~int(108, ~#s_tolower_table~0.base, 108 + ~#s_tolower_table~0.offset, 1);call write~init~int(109, ~#s_tolower_table~0.base, 109 + ~#s_tolower_table~0.offset, 1);call write~init~int(110, ~#s_tolower_table~0.base, 110 + ~#s_tolower_table~0.offset, 1);call write~init~int(111, ~#s_tolower_table~0.base, 111 + ~#s_tolower_table~0.offset, 1);call write~init~int(112, ~#s_tolower_table~0.base, 112 + ~#s_tolower_table~0.offset, 1);call write~init~int(113, ~#s_tolower_table~0.base, 113 + ~#s_tolower_table~0.offset, 1);call write~init~int(114, ~#s_tolower_table~0.base, 114 + ~#s_tolower_table~0.offset, 1);call write~init~int(115, ~#s_tolower_table~0.base, 115 + ~#s_tolower_table~0.offset, 1);call write~init~int(116, ~#s_tolower_table~0.base, 116 + ~#s_tolower_table~0.offset, 1);call write~init~int(117, ~#s_tolower_table~0.base, 117 + ~#s_tolower_table~0.offset, 1);call write~init~int(118, ~#s_tolower_table~0.base, 118 + ~#s_tolower_table~0.offset, 1);call write~init~int(119, ~#s_tolower_table~0.base, 119 + ~#s_tolower_table~0.offset, 1);call write~init~int(120, ~#s_tolower_table~0.base, 120 + ~#s_tolower_table~0.offset, 1);call write~init~int(121, ~#s_tolower_table~0.base, 121 + ~#s_tolower_table~0.offset, 1);call write~init~int(122, ~#s_tolower_table~0.base, 122 + ~#s_tolower_table~0.offset, 1);call write~init~int(123, ~#s_tolower_table~0.base, 123 + ~#s_tolower_table~0.offset, 1);call write~init~int(124, ~#s_tolower_table~0.base, 124 + ~#s_tolower_table~0.offset, 1);call write~init~int(125, ~#s_tolower_table~0.base, 125 + ~#s_tolower_table~0.offset, 1);call write~init~int(126, ~#s_tolower_table~0.base, 126 + ~#s_tolower_table~0.offset, 1);call write~init~int(127, ~#s_tolower_table~0.base, 127 + ~#s_tolower_table~0.offset, 1);call write~init~int(128, ~#s_tolower_table~0.base, 128 + ~#s_tolower_table~0.offset, 1);call write~init~int(129, ~#s_tolower_table~0.base, 129 + ~#s_tolower_table~0.offset, 1);call write~init~int(130, ~#s_tolower_table~0.base, 130 + ~#s_tolower_table~0.offset, 1);call write~init~int(131, ~#s_tolower_table~0.base, 131 + ~#s_tolower_table~0.offset, 1);call write~init~int(132, ~#s_tolower_table~0.base, 132 + ~#s_tolower_table~0.offset, 1);call write~init~int(133, ~#s_tolower_table~0.base, 133 + ~#s_tolower_table~0.offset, 1);call write~init~int(134, ~#s_tolower_table~0.base, 134 + ~#s_tolower_table~0.offset, 1);call write~init~int(135, ~#s_tolower_table~0.base, 135 + ~#s_tolower_table~0.offset, 1);call write~init~int(136, ~#s_tolower_table~0.base, 136 + ~#s_tolower_table~0.offset, 1);call write~init~int(137, ~#s_tolower_table~0.base, 137 + ~#s_tolower_table~0.offset, 1);call write~init~int(138, ~#s_tolower_table~0.base, 138 + ~#s_tolower_table~0.offset, 1);call write~init~int(139, ~#s_tolower_table~0.base, 139 + ~#s_tolower_table~0.offset, 1);call write~init~int(140, ~#s_tolower_table~0.base, 140 + ~#s_tolower_table~0.offset, 1);call write~init~int(141, ~#s_tolower_table~0.base, 141 + ~#s_tolower_table~0.offset, 1);call write~init~int(142, ~#s_tolower_table~0.base, 142 + ~#s_tolower_table~0.offset, 1);call write~init~int(143, ~#s_tolower_table~0.base, 143 + ~#s_tolower_table~0.offset, 1);call write~init~int(144, ~#s_tolower_table~0.base, 144 + ~#s_tolower_table~0.offset, 1);call write~init~int(145, ~#s_tolower_table~0.base, 145 + ~#s_tolower_table~0.offset, 1);call write~init~int(146, ~#s_tolower_table~0.base, 146 + ~#s_tolower_table~0.offset, 1);call write~init~int(147, ~#s_tolower_table~0.base, 147 + ~#s_tolower_table~0.offset, 1);call write~init~int(148, ~#s_tolower_table~0.base, 148 + ~#s_tolower_table~0.offset, 1);call write~init~int(149, ~#s_tolower_table~0.base, 149 + ~#s_tolower_table~0.offset, 1);call write~init~int(150, ~#s_tolower_table~0.base, 150 + ~#s_tolower_table~0.offset, 1);call write~init~int(151, ~#s_tolower_table~0.base, 151 + ~#s_tolower_table~0.offset, 1);call write~init~int(152, ~#s_tolower_table~0.base, 152 + ~#s_tolower_table~0.offset, 1);call write~init~int(153, ~#s_tolower_table~0.base, 153 + ~#s_tolower_table~0.offset, 1);call write~init~int(154, ~#s_tolower_table~0.base, 154 + ~#s_tolower_table~0.offset, 1);call write~init~int(155, ~#s_tolower_table~0.base, 155 + ~#s_tolower_table~0.offset, 1);call write~init~int(156, ~#s_tolower_table~0.base, 156 + ~#s_tolower_table~0.offset, 1);call write~init~int(157, ~#s_tolower_table~0.base, 157 + ~#s_tolower_table~0.offset, 1);call write~init~int(158, ~#s_tolower_table~0.base, 158 + ~#s_tolower_table~0.offset, 1);call write~init~int(159, ~#s_tolower_table~0.base, 159 + ~#s_tolower_table~0.offset, 1);call write~init~int(160, ~#s_tolower_table~0.base, 160 + ~#s_tolower_table~0.offset, 1);call write~init~int(161, ~#s_tolower_table~0.base, 161 + ~#s_tolower_table~0.offset, 1);call write~init~int(162, ~#s_tolower_table~0.base, 162 + ~#s_tolower_table~0.offset, 1);call write~init~int(163, ~#s_tolower_table~0.base, 163 + ~#s_tolower_table~0.offset, 1);call write~init~int(164, ~#s_tolower_table~0.base, 164 + ~#s_tolower_table~0.offset, 1);call write~init~int(165, ~#s_tolower_table~0.base, 165 + ~#s_tolower_table~0.offset, 1);call write~init~int(166, ~#s_tolower_table~0.base, 166 + ~#s_tolower_table~0.offset, 1);call write~init~int(167, ~#s_tolower_table~0.base, 167 + ~#s_tolower_table~0.offset, 1);call write~init~int(168, ~#s_tolower_table~0.base, 168 + ~#s_tolower_table~0.offset, 1);call write~init~int(169, ~#s_tolower_table~0.base, 169 + ~#s_tolower_table~0.offset, 1);call write~init~int(170, ~#s_tolower_table~0.base, 170 + ~#s_tolower_table~0.offset, 1);call write~init~int(171, ~#s_tolower_table~0.base, 171 + ~#s_tolower_table~0.offset, 1);call write~init~int(172, ~#s_tolower_table~0.base, 172 + ~#s_tolower_table~0.offset, 1);call write~init~int(173, ~#s_tolower_table~0.base, 173 + ~#s_tolower_table~0.offset, 1);call write~init~int(174, ~#s_tolower_table~0.base, 174 + ~#s_tolower_table~0.offset, 1);call write~init~int(175, ~#s_tolower_table~0.base, 175 + ~#s_tolower_table~0.offset, 1);call write~init~int(176, ~#s_tolower_table~0.base, 176 + ~#s_tolower_table~0.offset, 1);call write~init~int(177, ~#s_tolower_table~0.base, 177 + ~#s_tolower_table~0.offset, 1);call write~init~int(178, ~#s_tolower_table~0.base, 178 + ~#s_tolower_table~0.offset, 1);call write~init~int(179, ~#s_tolower_table~0.base, 179 + ~#s_tolower_table~0.offset, 1);call write~init~int(180, ~#s_tolower_table~0.base, 180 + ~#s_tolower_table~0.offset, 1);call write~init~int(181, ~#s_tolower_table~0.base, 181 + ~#s_tolower_table~0.offset, 1);call write~init~int(182, ~#s_tolower_table~0.base, 182 + ~#s_tolower_table~0.offset, 1);call write~init~int(183, ~#s_tolower_table~0.base, 183 + ~#s_tolower_table~0.offset, 1);call write~init~int(184, ~#s_tolower_table~0.base, 184 + ~#s_tolower_table~0.offset, 1);call write~init~int(185, ~#s_tolower_table~0.base, 185 + ~#s_tolower_table~0.offset, 1);call write~init~int(186, ~#s_tolower_table~0.base, 186 + ~#s_tolower_table~0.offset, 1);call write~init~int(187, ~#s_tolower_table~0.base, 187 + ~#s_tolower_table~0.offset, 1);call write~init~int(188, ~#s_tolower_table~0.base, 188 + ~#s_tolower_table~0.offset, 1);call write~init~int(189, ~#s_tolower_table~0.base, 189 + ~#s_tolower_table~0.offset, 1);call write~init~int(190, ~#s_tolower_table~0.base, 190 + ~#s_tolower_table~0.offset, 1);call write~init~int(191, ~#s_tolower_table~0.base, 191 + ~#s_tolower_table~0.offset, 1);call write~init~int(192, ~#s_tolower_table~0.base, 192 + ~#s_tolower_table~0.offset, 1);call write~init~int(193, ~#s_tolower_table~0.base, 193 + ~#s_tolower_table~0.offset, 1);call write~init~int(194, ~#s_tolower_table~0.base, 194 + ~#s_tolower_table~0.offset, 1);call write~init~int(195, ~#s_tolower_table~0.base, 195 + ~#s_tolower_table~0.offset, 1);call write~init~int(196, ~#s_tolower_table~0.base, 196 + ~#s_tolower_table~0.offset, 1);call write~init~int(197, ~#s_tolower_table~0.base, 197 + ~#s_tolower_table~0.offset, 1);call write~init~int(198, ~#s_tolower_table~0.base, 198 + ~#s_tolower_table~0.offset, 1);call write~init~int(199, ~#s_tolower_table~0.base, 199 + ~#s_tolower_table~0.offset, 1);call write~init~int(200, ~#s_tolower_table~0.base, 200 + ~#s_tolower_table~0.offset, 1);call write~init~int(201, ~#s_tolower_table~0.base, 201 + ~#s_tolower_table~0.offset, 1);call write~init~int(202, ~#s_tolower_table~0.base, 202 + ~#s_tolower_table~0.offset, 1);call write~init~int(203, ~#s_tolower_table~0.base, 203 + ~#s_tolower_table~0.offset, 1);call write~init~int(204, ~#s_tolower_table~0.base, 204 + ~#s_tolower_table~0.offset, 1);call write~init~int(205, ~#s_tolower_table~0.base, 205 + ~#s_tolower_table~0.offset, 1);call write~init~int(206, ~#s_tolower_table~0.base, 206 + ~#s_tolower_table~0.offset, 1);call write~init~int(207, ~#s_tolower_table~0.base, 207 + ~#s_tolower_table~0.offset, 1);call write~init~int(208, ~#s_tolower_table~0.base, 208 + ~#s_tolower_table~0.offset, 1);call write~init~int(209, ~#s_tolower_table~0.base, 209 + ~#s_tolower_table~0.offset, 1);call write~init~int(210, ~#s_tolower_table~0.base, 210 + ~#s_tolower_table~0.offset, 1);call write~init~int(211, ~#s_tolower_table~0.base, 211 + ~#s_tolower_table~0.offset, 1);call write~init~int(212, ~#s_tolower_table~0.base, 212 + ~#s_tolower_table~0.offset, 1);call write~init~int(213, ~#s_tolower_table~0.base, 213 + ~#s_tolower_table~0.offset, 1);call write~init~int(214, ~#s_tolower_table~0.base, 214 + ~#s_tolower_table~0.offset, 1);call write~init~int(215, ~#s_tolower_table~0.base, 215 + ~#s_tolower_table~0.offset, 1);call write~init~int(216, ~#s_tolower_table~0.base, 216 + ~#s_tolower_table~0.offset, 1);call write~init~int(217, ~#s_tolower_table~0.base, 217 + ~#s_tolower_table~0.offset, 1);call write~init~int(218, ~#s_tolower_table~0.base, 218 + ~#s_tolower_table~0.offset, 1);call write~init~int(219, ~#s_tolower_table~0.base, 219 + ~#s_tolower_table~0.offset, 1);call write~init~int(220, ~#s_tolower_table~0.base, 220 + ~#s_tolower_table~0.offset, 1);call write~init~int(221, ~#s_tolower_table~0.base, 221 + ~#s_tolower_table~0.offset, 1);call write~init~int(222, ~#s_tolower_table~0.base, 222 + ~#s_tolower_table~0.offset, 1);call write~init~int(223, ~#s_tolower_table~0.base, 223 + ~#s_tolower_table~0.offset, 1);call write~init~int(224, ~#s_tolower_table~0.base, 224 + ~#s_tolower_table~0.offset, 1);call write~init~int(225, ~#s_tolower_table~0.base, 225 + ~#s_tolower_table~0.offset, 1);call write~init~int(226, ~#s_tolower_table~0.base, 226 + ~#s_tolower_table~0.offset, 1);call write~init~int(227, ~#s_tolower_table~0.base, 227 + ~#s_tolower_table~0.offset, 1);call write~init~int(228, ~#s_tolower_table~0.base, 228 + ~#s_tolower_table~0.offset, 1);call write~init~int(229, ~#s_tolower_table~0.base, 229 + ~#s_tolower_table~0.offset, 1);call write~init~int(230, ~#s_tolower_table~0.base, 230 + ~#s_tolower_table~0.offset, 1);call write~init~int(231, ~#s_tolower_table~0.base, 231 + ~#s_tolower_table~0.offset, 1);call write~init~int(232, ~#s_tolower_table~0.base, 232 + ~#s_tolower_table~0.offset, 1);call write~init~int(233, ~#s_tolower_table~0.base, 233 + ~#s_tolower_table~0.offset, 1);call write~init~int(234, ~#s_tolower_table~0.base, 234 + ~#s_tolower_table~0.offset, 1);call write~init~int(235, ~#s_tolower_table~0.base, 235 + ~#s_tolower_table~0.offset, 1);call write~init~int(236, ~#s_tolower_table~0.base, 236 + ~#s_tolower_table~0.offset, 1);call write~init~int(237, ~#s_tolower_table~0.base, 237 + ~#s_tolower_table~0.offset, 1);call write~init~int(238, ~#s_tolower_table~0.base, 238 + ~#s_tolower_table~0.offset, 1);call write~init~int(239, ~#s_tolower_table~0.base, 239 + ~#s_tolower_table~0.offset, 1);call write~init~int(240, ~#s_tolower_table~0.base, 240 + ~#s_tolower_table~0.offset, 1);call write~init~int(241, ~#s_tolower_table~0.base, 241 + ~#s_tolower_table~0.offset, 1);call write~init~int(242, ~#s_tolower_table~0.base, 242 + ~#s_tolower_table~0.offset, 1);call write~init~int(243, ~#s_tolower_table~0.base, 243 + ~#s_tolower_table~0.offset, 1);call write~init~int(244, ~#s_tolower_table~0.base, 244 + ~#s_tolower_table~0.offset, 1);call write~init~int(245, ~#s_tolower_table~0.base, 245 + ~#s_tolower_table~0.offset, 1);call write~init~int(246, ~#s_tolower_table~0.base, 246 + ~#s_tolower_table~0.offset, 1);call write~init~int(247, ~#s_tolower_table~0.base, 247 + ~#s_tolower_table~0.offset, 1);call write~init~int(248, ~#s_tolower_table~0.base, 248 + ~#s_tolower_table~0.offset, 1);call write~init~int(249, ~#s_tolower_table~0.base, 249 + ~#s_tolower_table~0.offset, 1);call write~init~int(250, ~#s_tolower_table~0.base, 250 + ~#s_tolower_table~0.offset, 1);call write~init~int(251, ~#s_tolower_table~0.base, 251 + ~#s_tolower_table~0.offset, 1);call write~init~int(252, ~#s_tolower_table~0.base, 252 + ~#s_tolower_table~0.offset, 1);call write~init~int(253, ~#s_tolower_table~0.base, 253 + ~#s_tolower_table~0.offset, 1);call write~init~int(254, ~#s_tolower_table~0.base, 254 + ~#s_tolower_table~0.offset, 1);call write~init~int(255, ~#s_tolower_table~0.base, 255 + ~#s_tolower_table~0.offset, 1); {4172#true} is VALID [2022-02-20 21:08:22,458 INFO L290 TraceCheckUtils]: 1: Hoare triple {4172#true} assume { :end_inline_ULTIMATE.init } true;assume { :begin_inline_main } true;havoc main_#res#1;assume { :begin_inline_aws_hash_callback_string_eq_harness } true;havoc aws_hash_callback_string_eq_harness_#t~ret1963#1.base, aws_hash_callback_string_eq_harness_#t~ret1963#1.offset, aws_hash_callback_string_eq_harness_#t~ret1964#1, aws_hash_callback_string_eq_harness_#t~ite1966#1.base, aws_hash_callback_string_eq_harness_#t~ite1966#1.offset, aws_hash_callback_string_eq_harness_#t~ret1965#1.base, aws_hash_callback_string_eq_harness_#t~ret1965#1.offset, aws_hash_callback_string_eq_harness_#t~ret1967#1, aws_hash_callback_string_eq_harness_#t~mem1968#1, aws_hash_callback_string_eq_harness_#t~mem1969#1, aws_hash_callback_string_eq_harness_#t~mem1970#1, aws_hash_callback_string_eq_harness_~str1~0#1.base, aws_hash_callback_string_eq_harness_~str1~0#1.offset, aws_hash_callback_string_eq_harness_~str2~0#1.base, aws_hash_callback_string_eq_harness_~str2~0#1.offset, aws_hash_callback_string_eq_harness_~rval~21#1; {4172#true} is VALID [2022-02-20 21:08:22,459 INFO L272 TraceCheckUtils]: 2: Hoare triple {4172#true} call aws_hash_callback_string_eq_harness_#t~ret1963#1.base, aws_hash_callback_string_eq_harness_#t~ret1963#1.offset := ensure_string_is_allocated_bounded_length(96); {4279#(and (= |old(#length)| |#length|) (= |old(#memory_real)| |#memory_real|) (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:08:22,459 INFO L290 TraceCheckUtils]: 3: Hoare triple {4279#(and (= |old(#length)| |#length|) (= |old(#memory_real)| |#memory_real|) (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|) (= |old(#valid)| |#valid|))} ~max_size#1 := #in~max_size#1; {4172#true} is VALID [2022-02-20 21:08:22,460 INFO L272 TraceCheckUtils]: 4: Hoare triple {4172#true} call #t~ret540#1 := nondet_uint64_t(); {4172#true} is VALID [2022-02-20 21:08:22,460 INFO L290 TraceCheckUtils]: 5: Hoare triple {4172#true} #res := #t~nondet13;havoc #t~nondet13; {4172#true} is VALID [2022-02-20 21:08:22,460 INFO L290 TraceCheckUtils]: 6: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:22,460 INFO L284 TraceCheckUtils]: 7: Hoare quadruple {4172#true} {4172#true} #182#return; {4172#true} is VALID [2022-02-20 21:08:22,460 INFO L290 TraceCheckUtils]: 8: Hoare triple {4172#true} ~len~1#1 := #t~ret540#1;havoc #t~ret540#1; {4172#true} is VALID [2022-02-20 21:08:22,460 INFO L272 TraceCheckUtils]: 9: Hoare triple {4172#true} call assume_abort_if_not((if 0 == (if ~len~1#1 % 18446744073709551616 < ~max_size#1 % 18446744073709551616 then 1 else 0) then 0 else 1)); {4172#true} is VALID [2022-02-20 21:08:22,461 INFO L290 TraceCheckUtils]: 10: Hoare triple {4172#true} ~cond := #in~cond; {4172#true} is VALID [2022-02-20 21:08:22,461 INFO L290 TraceCheckUtils]: 11: Hoare triple {4172#true} assume !(0 == ~cond % 256); {4172#true} is VALID [2022-02-20 21:08:22,461 INFO L290 TraceCheckUtils]: 12: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:22,461 INFO L284 TraceCheckUtils]: 13: Hoare quadruple {4172#true} {4172#true} #184#return; {4172#true} is VALID [2022-02-20 21:08:22,461 INFO L290 TraceCheckUtils]: 14: Hoare triple {4172#true} assume { :begin_inline_ensure_string_is_allocated } true;ensure_string_is_allocated_#in~len#1 := ~len~1#1;havoc ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset;havoc ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset, ensure_string_is_allocated_#t~ret543#1, ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset, ensure_string_is_allocated_#t~ret544#1.base, ensure_string_is_allocated_#t~ret544#1.offset, ensure_string_is_allocated_~len#1, ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset;ensure_string_is_allocated_~len#1 := ensure_string_is_allocated_#in~len#1; {4172#true} is VALID [2022-02-20 21:08:22,462 INFO L272 TraceCheckUtils]: 15: Hoare triple {4172#true} call ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset := bounded_malloc(-1234550 + ensure_string_is_allocated_~len#1); {4299#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:08:22,462 INFO L290 TraceCheckUtils]: 16: Hoare triple {4299#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size; {4172#true} is VALID [2022-02-20 21:08:22,462 INFO L272 TraceCheckUtils]: 17: Hoare triple {4172#true} call assume_abort_if_not((if 0 == (if ~size % 18446744073709551616 <= 36028797018963967 then 1 else 0) then 0 else 1)); {4172#true} is VALID [2022-02-20 21:08:22,462 INFO L290 TraceCheckUtils]: 18: Hoare triple {4172#true} ~cond := #in~cond; {4172#true} is VALID [2022-02-20 21:08:22,462 INFO L290 TraceCheckUtils]: 19: Hoare triple {4172#true} assume !(0 == ~cond % 256); {4172#true} is VALID [2022-02-20 21:08:22,463 INFO L290 TraceCheckUtils]: 20: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:22,463 INFO L284 TraceCheckUtils]: 21: Hoare quadruple {4172#true} {4172#true} #192#return; {4172#true} is VALID [2022-02-20 21:08:22,463 INFO L290 TraceCheckUtils]: 22: Hoare triple {4172#true} call #t~malloc555.base, #t~malloc555.offset := #Ultimate.allocOnHeap(~size);#res.base, #res.offset := #t~malloc555.base, #t~malloc555.offset;havoc #t~malloc555.base, #t~malloc555.offset; {4172#true} is VALID [2022-02-20 21:08:22,463 INFO L290 TraceCheckUtils]: 23: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:22,463 INFO L284 TraceCheckUtils]: 24: Hoare quadruple {4172#true} {4172#true} #186#return; {4172#true} is VALID [2022-02-20 21:08:22,463 INFO L290 TraceCheckUtils]: 25: Hoare triple {4172#true} ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset := ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset;havoc ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset; {4172#true} is VALID [2022-02-20 21:08:22,463 INFO L272 TraceCheckUtils]: 26: Hoare triple {4172#true} call ensure_string_is_allocated_#t~ret543#1 := nondet_bool(); {4172#true} is VALID [2022-02-20 21:08:22,464 INFO L290 TraceCheckUtils]: 27: Hoare triple {4172#true} #res := #t~nondet8;havoc #t~nondet8; {4172#true} is VALID [2022-02-20 21:08:22,464 INFO L290 TraceCheckUtils]: 28: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:22,464 INFO L284 TraceCheckUtils]: 29: Hoare quadruple {4172#true} {4172#true} #188#return; {4172#true} is VALID [2022-02-20 21:08:22,464 INFO L290 TraceCheckUtils]: 30: Hoare triple {4172#true} assume !(0 != ensure_string_is_allocated_#t~ret543#1 % 256);ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset := 0, 0; {4172#true} is VALID [2022-02-20 21:08:22,464 INFO L290 TraceCheckUtils]: 31: Hoare triple {4172#true} call write~$Pointer$(ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset, ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset, 8);havoc ensure_string_is_allocated_#t~ret543#1;havoc ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset;havoc ensure_string_is_allocated_#t~ret544#1.base, ensure_string_is_allocated_#t~ret544#1.offset;call write~int(ensure_string_is_allocated_~len#1, ensure_string_is_allocated_~str~0#1.base, 8 + ensure_string_is_allocated_~str~0#1.offset, 8);call write~int(0, ensure_string_is_allocated_~str~0#1.base, 16 + ensure_string_is_allocated_~str~0#1.offset + (if ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 else ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset := ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset; {4172#true} is VALID [2022-02-20 21:08:22,464 INFO L290 TraceCheckUtils]: 32: Hoare triple {4172#true} #t~ret541#1.base, #t~ret541#1.offset := ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset;assume { :end_inline_ensure_string_is_allocated } true;#res#1.base, #res#1.offset := #t~ret541#1.base, #t~ret541#1.offset;havoc #t~ret541#1.base, #t~ret541#1.offset; {4172#true} is VALID [2022-02-20 21:08:22,464 INFO L290 TraceCheckUtils]: 33: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:22,465 INFO L284 TraceCheckUtils]: 34: Hoare quadruple {4172#true} {4172#true} #198#return; {4172#true} is VALID [2022-02-20 21:08:22,465 INFO L290 TraceCheckUtils]: 35: Hoare triple {4172#true} aws_hash_callback_string_eq_harness_~str1~0#1.base, aws_hash_callback_string_eq_harness_~str1~0#1.offset := aws_hash_callback_string_eq_harness_#t~ret1963#1.base, aws_hash_callback_string_eq_harness_#t~ret1963#1.offset;havoc aws_hash_callback_string_eq_harness_#t~ret1963#1.base, aws_hash_callback_string_eq_harness_#t~ret1963#1.offset; {4172#true} is VALID [2022-02-20 21:08:22,465 INFO L272 TraceCheckUtils]: 36: Hoare triple {4172#true} call aws_hash_callback_string_eq_harness_#t~ret1964#1 := nondet_bool(); {4172#true} is VALID [2022-02-20 21:08:22,465 INFO L290 TraceCheckUtils]: 37: Hoare triple {4172#true} #res := #t~nondet8;havoc #t~nondet8; {4172#true} is VALID [2022-02-20 21:08:22,465 INFO L290 TraceCheckUtils]: 38: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:22,465 INFO L284 TraceCheckUtils]: 39: Hoare quadruple {4172#true} {4172#true} #200#return; {4172#true} is VALID [2022-02-20 21:08:22,466 INFO L290 TraceCheckUtils]: 40: Hoare triple {4172#true} assume !(0 != aws_hash_callback_string_eq_harness_#t~ret1964#1 % 256); {4172#true} is VALID [2022-02-20 21:08:22,466 INFO L272 TraceCheckUtils]: 41: Hoare triple {4172#true} call aws_hash_callback_string_eq_harness_#t~ret1965#1.base, aws_hash_callback_string_eq_harness_#t~ret1965#1.offset := ensure_string_is_allocated_bounded_length(96); {4279#(and (= |old(#length)| |#length|) (= |old(#memory_real)| |#memory_real|) (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:08:22,467 INFO L290 TraceCheckUtils]: 42: Hoare triple {4279#(and (= |old(#length)| |#length|) (= |old(#memory_real)| |#memory_real|) (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|) (= |old(#valid)| |#valid|))} ~max_size#1 := #in~max_size#1; {4304#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} is VALID [2022-02-20 21:08:22,467 INFO L272 TraceCheckUtils]: 43: Hoare triple {4304#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} call #t~ret540#1 := nondet_uint64_t(); {4172#true} is VALID [2022-02-20 21:08:22,467 INFO L290 TraceCheckUtils]: 44: Hoare triple {4172#true} #res := #t~nondet13;havoc #t~nondet13; {4172#true} is VALID [2022-02-20 21:08:22,467 INFO L290 TraceCheckUtils]: 45: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:22,468 INFO L284 TraceCheckUtils]: 46: Hoare quadruple {4172#true} {4304#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} #182#return; {4304#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} is VALID [2022-02-20 21:08:22,468 INFO L290 TraceCheckUtils]: 47: Hoare triple {4304#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} ~len~1#1 := #t~ret540#1;havoc #t~ret540#1; {4304#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} is VALID [2022-02-20 21:08:22,468 INFO L272 TraceCheckUtils]: 48: Hoare triple {4304#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} call assume_abort_if_not((if 0 == (if ~len~1#1 % 18446744073709551616 < ~max_size#1 % 18446744073709551616 then 1 else 0) then 0 else 1)); {4172#true} is VALID [2022-02-20 21:08:22,469 INFO L290 TraceCheckUtils]: 49: Hoare triple {4172#true} ~cond := #in~cond; {4327#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} is VALID [2022-02-20 21:08:22,469 INFO L290 TraceCheckUtils]: 50: Hoare triple {4327#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} assume !(0 == ~cond % 256); {4328#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} is VALID [2022-02-20 21:08:22,470 INFO L290 TraceCheckUtils]: 51: Hoare triple {4328#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} assume true; {4328#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} is VALID [2022-02-20 21:08:22,471 INFO L284 TraceCheckUtils]: 52: Hoare quadruple {4328#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} {4304#(or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))} #184#return; {4312#(or (not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96)) (<= |ensure_string_is_allocated_bounded_length_~len~1#1| (+ (* 18446744073709551616 (div |ensure_string_is_allocated_bounded_length_~len~1#1| 18446744073709551616)) 95)))} is VALID [2022-02-20 21:08:22,472 INFO L290 TraceCheckUtils]: 53: Hoare triple {4312#(or (not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96)) (<= |ensure_string_is_allocated_bounded_length_~len~1#1| (+ (* 18446744073709551616 (div |ensure_string_is_allocated_bounded_length_~len~1#1| 18446744073709551616)) 95)))} assume { :begin_inline_ensure_string_is_allocated } true;ensure_string_is_allocated_#in~len#1 := ~len~1#1;havoc ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset;havoc ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset, ensure_string_is_allocated_#t~ret543#1, ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset, ensure_string_is_allocated_#t~ret544#1.base, ensure_string_is_allocated_#t~ret544#1.offset, ensure_string_is_allocated_~len#1, ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset;ensure_string_is_allocated_~len#1 := ensure_string_is_allocated_#in~len#1; {4313#(or (not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96)) (<= (* (div (+ 18446744073709551520 |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~len#1|) 18446744073709551616) 18446744073709551616) |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~len#1|))} is VALID [2022-02-20 21:08:22,473 INFO L272 TraceCheckUtils]: 54: Hoare triple {4313#(or (not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96)) (<= (* (div (+ 18446744073709551520 |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~len#1|) 18446744073709551616) 18446744073709551616) |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~len#1|))} call ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset := bounded_malloc(-1234550 + ensure_string_is_allocated_~len#1); {4299#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:08:22,473 INFO L290 TraceCheckUtils]: 55: Hoare triple {4299#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size; {4329#(= |bounded_malloc_#in~size| bounded_malloc_~size)} is VALID [2022-02-20 21:08:22,473 INFO L272 TraceCheckUtils]: 56: Hoare triple {4329#(= |bounded_malloc_#in~size| bounded_malloc_~size)} call assume_abort_if_not((if 0 == (if ~size % 18446744073709551616 <= 36028797018963967 then 1 else 0) then 0 else 1)); {4172#true} is VALID [2022-02-20 21:08:22,474 INFO L290 TraceCheckUtils]: 57: Hoare triple {4172#true} ~cond := #in~cond; {4327#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} is VALID [2022-02-20 21:08:22,475 INFO L290 TraceCheckUtils]: 58: Hoare triple {4327#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} assume !(0 == ~cond % 256); {4328#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} is VALID [2022-02-20 21:08:22,475 INFO L290 TraceCheckUtils]: 59: Hoare triple {4328#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} assume true; {4328#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} is VALID [2022-02-20 21:08:22,476 INFO L284 TraceCheckUtils]: 60: Hoare quadruple {4328#(or (<= 1 |assume_abort_if_not_#in~cond|) (<= (+ |assume_abort_if_not_#in~cond| 1) 0))} {4329#(= |bounded_malloc_#in~size| bounded_malloc_~size)} #192#return; {4334#(and (= |bounded_malloc_#in~size| bounded_malloc_~size) (<= bounded_malloc_~size (+ (* (div bounded_malloc_~size 18446744073709551616) 18446744073709551616) 36028797018963967)))} is VALID [2022-02-20 21:08:22,477 INFO L290 TraceCheckUtils]: 61: Hoare triple {4334#(and (= |bounded_malloc_#in~size| bounded_malloc_~size) (<= bounded_malloc_~size (+ (* (div bounded_malloc_~size 18446744073709551616) 18446744073709551616) 36028797018963967)))} call #t~malloc555.base, #t~malloc555.offset := #Ultimate.allocOnHeap(~size);#res.base, #res.offset := #t~malloc555.base, #t~malloc555.offset;havoc #t~malloc555.base, #t~malloc555.offset; {4335#(<= |bounded_malloc_#in~size| (+ 36028797018963967 (* 18446744073709551616 (div |bounded_malloc_#in~size| 18446744073709551616))))} is VALID [2022-02-20 21:08:22,477 INFO L290 TraceCheckUtils]: 62: Hoare triple {4335#(<= |bounded_malloc_#in~size| (+ 36028797018963967 (* 18446744073709551616 (div |bounded_malloc_#in~size| 18446744073709551616))))} assume true; {4335#(<= |bounded_malloc_#in~size| (+ 36028797018963967 (* 18446744073709551616 (div |bounded_malloc_#in~size| 18446744073709551616))))} is VALID [2022-02-20 21:08:22,478 INFO L284 TraceCheckUtils]: 63: Hoare quadruple {4335#(<= |bounded_malloc_#in~size| (+ 36028797018963967 (* 18446744073709551616 (div |bounded_malloc_#in~size| 18446744073709551616))))} {4313#(or (not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96)) (<= (* (div (+ 18446744073709551520 |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~len#1|) 18446744073709551616) 18446744073709551616) |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~len#1|))} #186#return; {4323#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} is VALID [2022-02-20 21:08:22,479 INFO L290 TraceCheckUtils]: 64: Hoare triple {4323#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset := ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset;havoc ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset; {4323#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} is VALID [2022-02-20 21:08:22,479 INFO L272 TraceCheckUtils]: 65: Hoare triple {4323#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} call ensure_string_is_allocated_#t~ret543#1 := nondet_bool(); {4172#true} is VALID [2022-02-20 21:08:22,479 INFO L290 TraceCheckUtils]: 66: Hoare triple {4172#true} #res := #t~nondet8;havoc #t~nondet8; {4172#true} is VALID [2022-02-20 21:08:22,479 INFO L290 TraceCheckUtils]: 67: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:22,480 INFO L284 TraceCheckUtils]: 68: Hoare quadruple {4172#true} {4323#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} #188#return; {4323#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} is VALID [2022-02-20 21:08:22,480 INFO L290 TraceCheckUtils]: 69: Hoare triple {4323#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} assume !(0 != ensure_string_is_allocated_#t~ret543#1 % 256);ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset := 0, 0; {4323#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} is VALID [2022-02-20 21:08:22,481 INFO L290 TraceCheckUtils]: 70: Hoare triple {4323#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} call write~$Pointer$(ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset, ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset, 8);havoc ensure_string_is_allocated_#t~ret543#1;havoc ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset;havoc ensure_string_is_allocated_#t~ret544#1.base, ensure_string_is_allocated_#t~ret544#1.offset;call write~int(ensure_string_is_allocated_~len#1, ensure_string_is_allocated_~str~0#1.base, 8 + ensure_string_is_allocated_~str~0#1.offset, 8);call write~int(0, ensure_string_is_allocated_~str~0#1.base, 16 + ensure_string_is_allocated_~str~0#1.offset + (if ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 else ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset := ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset; {4323#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} is VALID [2022-02-20 21:08:22,481 INFO L290 TraceCheckUtils]: 71: Hoare triple {4323#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} #t~ret541#1.base, #t~ret541#1.offset := ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset;assume { :end_inline_ensure_string_is_allocated } true;#res#1.base, #res#1.offset := #t~ret541#1.base, #t~ret541#1.offset;havoc #t~ret541#1.base, #t~ret541#1.offset; {4323#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} is VALID [2022-02-20 21:08:22,481 INFO L290 TraceCheckUtils]: 72: Hoare triple {4323#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} assume true; {4323#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} is VALID [2022-02-20 21:08:22,482 INFO L284 TraceCheckUtils]: 73: Hoare quadruple {4323#(not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96))} {4172#true} #202#return; {4241#(not (= 0 |ULTIMATE.start_aws_hash_callback_string_eq_harness_#t~ret1965#1.base|))} is VALID [2022-02-20 21:08:22,482 INFO L290 TraceCheckUtils]: 74: Hoare triple {4241#(not (= 0 |ULTIMATE.start_aws_hash_callback_string_eq_harness_#t~ret1965#1.base|))} aws_hash_callback_string_eq_harness_#t~ite1966#1.base, aws_hash_callback_string_eq_harness_#t~ite1966#1.offset := aws_hash_callback_string_eq_harness_#t~ret1965#1.base, aws_hash_callback_string_eq_harness_#t~ret1965#1.offset; {4242#(not (= 0 |ULTIMATE.start_aws_hash_callback_string_eq_harness_#t~ite1966#1.base|))} is VALID [2022-02-20 21:08:22,483 INFO L290 TraceCheckUtils]: 75: Hoare triple {4242#(not (= 0 |ULTIMATE.start_aws_hash_callback_string_eq_harness_#t~ite1966#1.base|))} aws_hash_callback_string_eq_harness_~str2~0#1.base, aws_hash_callback_string_eq_harness_~str2~0#1.offset := aws_hash_callback_string_eq_harness_#t~ite1966#1.base, aws_hash_callback_string_eq_harness_#t~ite1966#1.offset;havoc aws_hash_callback_string_eq_harness_#t~ret1964#1;havoc aws_hash_callback_string_eq_harness_#t~ite1966#1.base, aws_hash_callback_string_eq_harness_#t~ite1966#1.offset;havoc aws_hash_callback_string_eq_harness_#t~ret1965#1.base, aws_hash_callback_string_eq_harness_#t~ret1965#1.offset;assume { :begin_inline_aws_hash_callback_string_eq } true;aws_hash_callback_string_eq_#in~a#1.base, aws_hash_callback_string_eq_#in~a#1.offset, aws_hash_callback_string_eq_#in~b#1.base, aws_hash_callback_string_eq_#in~b#1.offset := aws_hash_callback_string_eq_harness_~str1~0#1.base, aws_hash_callback_string_eq_harness_~str1~0#1.offset, aws_hash_callback_string_eq_harness_~str2~0#1.base, aws_hash_callback_string_eq_harness_~str2~0#1.offset;havoc aws_hash_callback_string_eq_#res#1;havoc aws_hash_callback_string_eq_#t~ret1811#1, aws_hash_callback_string_eq_#t~ret1812#1, aws_hash_callback_string_eq_#t~ret1813#1, aws_hash_callback_string_eq_#t~ret1814#1, aws_hash_callback_string_eq_#t~ret1815#1, aws_hash_callback_string_eq_#t~short1816#1, aws_hash_callback_string_eq_~a#1.base, aws_hash_callback_string_eq_~a#1.offset, aws_hash_callback_string_eq_~b#1.base, aws_hash_callback_string_eq_~b#1.offset, aws_hash_callback_string_eq_~rval~20#1;aws_hash_callback_string_eq_~a#1.base, aws_hash_callback_string_eq_~a#1.offset := aws_hash_callback_string_eq_#in~a#1.base, aws_hash_callback_string_eq_#in~a#1.offset;aws_hash_callback_string_eq_~b#1.base, aws_hash_callback_string_eq_~b#1.offset := aws_hash_callback_string_eq_#in~b#1.base, aws_hash_callback_string_eq_#in~b#1.offset; {4243#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} is VALID [2022-02-20 21:08:22,483 INFO L272 TraceCheckUtils]: 76: Hoare triple {4243#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} call aws_hash_callback_string_eq_#t~ret1811#1 := aws_string_is_valid(aws_hash_callback_string_eq_~a#1.base, aws_hash_callback_string_eq_~a#1.offset); {4172#true} is VALID [2022-02-20 21:08:22,483 INFO L290 TraceCheckUtils]: 77: Hoare triple {4172#true} ~str.base, ~str.offset := #in~str.base, #in~str.offset;#t~short464 := ~str.base != 0 || ~str.offset != 0; {4172#true} is VALID [2022-02-20 21:08:22,483 INFO L290 TraceCheckUtils]: 78: Hoare triple {4172#true} assume #t~short464;call #t~mem463 := read~int(~str.base, 8 + ~str.offset, 8);#t~short464 := 0 == (1 + #t~mem463) % 18446744073709551616 || ~str.base != 0 || 16 + ~str.offset != 0; {4172#true} is VALID [2022-02-20 21:08:22,484 INFO L290 TraceCheckUtils]: 79: Hoare triple {4172#true} #t~short467 := #t~short464; {4172#true} is VALID [2022-02-20 21:08:22,484 INFO L290 TraceCheckUtils]: 80: Hoare triple {4172#true} assume #t~short467;call #t~mem465 := read~int(~str.base, 8 + ~str.offset, 8);call #t~mem466 := read~int(~str.base, 16 + ~str.offset + (if #t~mem465 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then #t~mem465 % 18446744073709551616 % 18446744073709551616 else #t~mem465 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);#t~short467 := 0 == #t~mem466 % 256; {4172#true} is VALID [2022-02-20 21:08:22,484 INFO L290 TraceCheckUtils]: 81: Hoare triple {4172#true} #res := (if 0 == (if #t~short467 then 1 else 0) then 0 else 1);havoc #t~mem463;havoc #t~short464;havoc #t~mem465;havoc #t~mem466;havoc #t~short467; {4172#true} is VALID [2022-02-20 21:08:22,484 INFO L290 TraceCheckUtils]: 82: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:22,485 INFO L284 TraceCheckUtils]: 83: Hoare quadruple {4172#true} {4243#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} #204#return; {4243#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} is VALID [2022-02-20 21:08:22,485 INFO L272 TraceCheckUtils]: 84: Hoare triple {4243#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} call assume_abort_if_not(aws_hash_callback_string_eq_#t~ret1811#1); {4172#true} is VALID [2022-02-20 21:08:22,485 INFO L290 TraceCheckUtils]: 85: Hoare triple {4172#true} ~cond := #in~cond; {4172#true} is VALID [2022-02-20 21:08:22,485 INFO L290 TraceCheckUtils]: 86: Hoare triple {4172#true} assume !(0 == ~cond % 256); {4172#true} is VALID [2022-02-20 21:08:22,485 INFO L290 TraceCheckUtils]: 87: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:22,486 INFO L284 TraceCheckUtils]: 88: Hoare quadruple {4172#true} {4243#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} #206#return; {4243#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} is VALID [2022-02-20 21:08:22,486 INFO L290 TraceCheckUtils]: 89: Hoare triple {4243#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} havoc aws_hash_callback_string_eq_#t~ret1811#1; {4243#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} is VALID [2022-02-20 21:08:22,486 INFO L272 TraceCheckUtils]: 90: Hoare triple {4243#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} call aws_hash_callback_string_eq_#t~ret1812#1 := aws_string_is_valid(aws_hash_callback_string_eq_~b#1.base, aws_hash_callback_string_eq_~b#1.offset); {4172#true} is VALID [2022-02-20 21:08:22,487 INFO L290 TraceCheckUtils]: 91: Hoare triple {4172#true} ~str.base, ~str.offset := #in~str.base, #in~str.offset;#t~short464 := ~str.base != 0 || ~str.offset != 0; {4172#true} is VALID [2022-02-20 21:08:22,487 INFO L290 TraceCheckUtils]: 92: Hoare triple {4172#true} assume #t~short464;call #t~mem463 := read~int(~str.base, 8 + ~str.offset, 8);#t~short464 := 0 == (1 + #t~mem463) % 18446744073709551616 || ~str.base != 0 || 16 + ~str.offset != 0; {4172#true} is VALID [2022-02-20 21:08:22,487 INFO L290 TraceCheckUtils]: 93: Hoare triple {4172#true} #t~short467 := #t~short464; {4172#true} is VALID [2022-02-20 21:08:22,487 INFO L290 TraceCheckUtils]: 94: Hoare triple {4172#true} assume #t~short467;call #t~mem465 := read~int(~str.base, 8 + ~str.offset, 8);call #t~mem466 := read~int(~str.base, 16 + ~str.offset + (if #t~mem465 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then #t~mem465 % 18446744073709551616 % 18446744073709551616 else #t~mem465 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);#t~short467 := 0 == #t~mem466 % 256; {4172#true} is VALID [2022-02-20 21:08:22,487 INFO L290 TraceCheckUtils]: 95: Hoare triple {4172#true} #res := (if 0 == (if #t~short467 then 1 else 0) then 0 else 1);havoc #t~mem463;havoc #t~short464;havoc #t~mem465;havoc #t~mem466;havoc #t~short467; {4172#true} is VALID [2022-02-20 21:08:22,487 INFO L290 TraceCheckUtils]: 96: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:22,488 INFO L284 TraceCheckUtils]: 97: Hoare quadruple {4172#true} {4243#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} #208#return; {4243#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} is VALID [2022-02-20 21:08:22,488 INFO L272 TraceCheckUtils]: 98: Hoare triple {4243#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} call assume_abort_if_not(aws_hash_callback_string_eq_#t~ret1812#1); {4172#true} is VALID [2022-02-20 21:08:22,488 INFO L290 TraceCheckUtils]: 99: Hoare triple {4172#true} ~cond := #in~cond; {4172#true} is VALID [2022-02-20 21:08:22,488 INFO L290 TraceCheckUtils]: 100: Hoare triple {4172#true} assume !(0 == ~cond % 256); {4172#true} is VALID [2022-02-20 21:08:22,489 INFO L290 TraceCheckUtils]: 101: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:22,489 INFO L284 TraceCheckUtils]: 102: Hoare quadruple {4172#true} {4243#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} #210#return; {4243#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} is VALID [2022-02-20 21:08:22,490 INFO L290 TraceCheckUtils]: 103: Hoare triple {4243#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~b#1.base| 0))} havoc aws_hash_callback_string_eq_#t~ret1812#1;assume { :begin_inline_aws_string_eq } true;aws_string_eq_#in~a#1.base, aws_string_eq_#in~a#1.offset, aws_string_eq_#in~b#1.base, aws_string_eq_#in~b#1.offset := aws_hash_callback_string_eq_~a#1.base, aws_hash_callback_string_eq_~a#1.offset, aws_hash_callback_string_eq_~b#1.base, aws_hash_callback_string_eq_~b#1.offset;havoc aws_string_eq_#res#1;havoc aws_string_eq_#t~ret1893#1, aws_string_eq_#t~short1894#1, aws_string_eq_#t~ret1895#1, aws_string_eq_#t~short1896#1, aws_string_eq_#t~mem1897#1, aws_string_eq_#t~mem1898#1, aws_string_eq_#t~ret1899#1, aws_string_eq_~a#1.base, aws_string_eq_~a#1.offset, aws_string_eq_~b#1.base, aws_string_eq_~b#1.offset;aws_string_eq_~a#1.base, aws_string_eq_~a#1.offset := aws_string_eq_#in~a#1.base, aws_string_eq_#in~a#1.offset;aws_string_eq_~b#1.base, aws_string_eq_~b#1.offset := aws_string_eq_#in~b#1.base, aws_string_eq_#in~b#1.offset;aws_string_eq_#t~short1894#1 := aws_string_eq_~a#1.base == 0 && aws_string_eq_~a#1.offset == 0; {4266#(not (= |ULTIMATE.start_aws_string_eq_~b#1.base| 0))} is VALID [2022-02-20 21:08:22,490 INFO L290 TraceCheckUtils]: 104: Hoare triple {4266#(not (= |ULTIMATE.start_aws_string_eq_~b#1.base| 0))} assume aws_string_eq_#t~short1894#1; {4266#(not (= |ULTIMATE.start_aws_string_eq_~b#1.base| 0))} is VALID [2022-02-20 21:08:22,490 INFO L272 TraceCheckUtils]: 105: Hoare triple {4266#(not (= |ULTIMATE.start_aws_string_eq_~b#1.base| 0))} call assume_abort_if_not((if 0 == (if aws_string_eq_#t~short1894#1 then 1 else 0) then 0 else 1)); {4172#true} is VALID [2022-02-20 21:08:22,491 INFO L290 TraceCheckUtils]: 106: Hoare triple {4172#true} ~cond := #in~cond; {4172#true} is VALID [2022-02-20 21:08:22,491 INFO L290 TraceCheckUtils]: 107: Hoare triple {4172#true} assume !(0 == ~cond % 256); {4172#true} is VALID [2022-02-20 21:08:22,491 INFO L290 TraceCheckUtils]: 108: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:22,491 INFO L284 TraceCheckUtils]: 109: Hoare quadruple {4172#true} {4266#(not (= |ULTIMATE.start_aws_string_eq_~b#1.base| 0))} #214#return; {4266#(not (= |ULTIMATE.start_aws_string_eq_~b#1.base| 0))} is VALID [2022-02-20 21:08:22,492 INFO L290 TraceCheckUtils]: 110: Hoare triple {4266#(not (= |ULTIMATE.start_aws_string_eq_~b#1.base| 0))} havoc aws_string_eq_#t~ret1893#1;havoc aws_string_eq_#t~short1894#1;aws_string_eq_#t~short1896#1 := aws_string_eq_~b#1.base == 0 && aws_string_eq_~b#1.offset == 0; {4271#(not |ULTIMATE.start_aws_string_eq_#t~short1896#1|)} is VALID [2022-02-20 21:08:22,492 INFO L290 TraceCheckUtils]: 111: Hoare triple {4271#(not |ULTIMATE.start_aws_string_eq_#t~short1896#1|)} assume aws_string_eq_#t~short1896#1; {4173#false} is VALID [2022-02-20 21:08:22,492 INFO L272 TraceCheckUtils]: 112: Hoare triple {4173#false} call assume_abort_if_not((if 0 == (if aws_string_eq_#t~short1896#1 then 1 else 0) then 0 else 1)); {4172#true} is VALID [2022-02-20 21:08:22,493 INFO L290 TraceCheckUtils]: 113: Hoare triple {4172#true} ~cond := #in~cond; {4172#true} is VALID [2022-02-20 21:08:22,493 INFO L290 TraceCheckUtils]: 114: Hoare triple {4172#true} assume !(0 == ~cond % 256); {4172#true} is VALID [2022-02-20 21:08:22,493 INFO L290 TraceCheckUtils]: 115: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:22,493 INFO L284 TraceCheckUtils]: 116: Hoare quadruple {4172#true} {4173#false} #218#return; {4173#false} is VALID [2022-02-20 21:08:22,493 INFO L290 TraceCheckUtils]: 117: Hoare triple {4173#false} havoc aws_string_eq_#t~ret1895#1;havoc aws_string_eq_#t~short1896#1; {4173#false} is VALID [2022-02-20 21:08:22,493 INFO L290 TraceCheckUtils]: 118: Hoare triple {4173#false} assume aws_string_eq_~a#1.base == aws_string_eq_~b#1.base && aws_string_eq_~a#1.offset == aws_string_eq_~b#1.offset;aws_string_eq_#res#1 := 1; {4173#false} is VALID [2022-02-20 21:08:22,493 INFO L290 TraceCheckUtils]: 119: Hoare triple {4173#false} aws_hash_callback_string_eq_#t~ret1813#1 := aws_string_eq_#res#1;assume { :end_inline_aws_string_eq } true;aws_hash_callback_string_eq_~rval~20#1 := aws_hash_callback_string_eq_#t~ret1813#1;havoc aws_hash_callback_string_eq_#t~ret1813#1; {4173#false} is VALID [2022-02-20 21:08:22,494 INFO L272 TraceCheckUtils]: 120: Hoare triple {4173#false} call aws_hash_callback_string_eq_#t~ret1814#1 := aws_c_string_is_valid(aws_hash_callback_string_eq_~a#1.base, aws_hash_callback_string_eq_~a#1.offset); {4172#true} is VALID [2022-02-20 21:08:22,494 INFO L290 TraceCheckUtils]: 121: Hoare triple {4172#true} ~str.base, ~str.offset := #in~str.base, #in~str.offset;#res := (if 0 == (if (~str.base != 0 || ~str.offset != 0) && (~str.base != 0 || ~str.offset != 0) then 1 else 0) then 0 else 1); {4172#true} is VALID [2022-02-20 21:08:22,494 INFO L290 TraceCheckUtils]: 122: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:22,494 INFO L284 TraceCheckUtils]: 123: Hoare quadruple {4172#true} {4173#false} #222#return; {4173#false} is VALID [2022-02-20 21:08:22,494 INFO L290 TraceCheckUtils]: 124: Hoare triple {4173#false} aws_hash_callback_string_eq_#t~short1816#1 := 0 != aws_hash_callback_string_eq_#t~ret1814#1 % 256; {4173#false} is VALID [2022-02-20 21:08:22,494 INFO L290 TraceCheckUtils]: 125: Hoare triple {4173#false} assume !aws_hash_callback_string_eq_#t~short1816#1; {4173#false} is VALID [2022-02-20 21:08:22,494 INFO L272 TraceCheckUtils]: 126: Hoare triple {4173#false} call __VERIFIER_assert((if 0 == (if aws_hash_callback_string_eq_#t~short1816#1 then 1 else 0) then 0 else 1)); {4173#false} is VALID [2022-02-20 21:08:22,495 INFO L290 TraceCheckUtils]: 127: Hoare triple {4173#false} ~cond := #in~cond; {4173#false} is VALID [2022-02-20 21:08:22,495 INFO L290 TraceCheckUtils]: 128: Hoare triple {4173#false} assume 0 == ~cond % 256; {4173#false} is VALID [2022-02-20 21:08:22,495 INFO L290 TraceCheckUtils]: 129: Hoare triple {4173#false} assume !false; {4173#false} is VALID [2022-02-20 21:08:22,495 INFO L134 CoverageAnalysis]: Checked inductivity of 149 backedges. 28 proven. 24 refuted. 0 times theorem prover too weak. 97 trivial. 0 not checked. [2022-02-20 21:08:22,496 INFO L144 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-02-20 21:08:22,496 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [1786260496] [2022-02-20 21:08:22,496 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleSmtInterpolCraig [1786260496] provided 0 perfect and 1 imperfect interpolant sequences [2022-02-20 21:08:22,496 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [1561592506] [2022-02-20 21:08:22,496 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 21:08:22,497 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-02-20 21:08:22,497 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-02-20 21:08:22,498 INFO L229 MonitoredProcess]: Starting monitored process 4 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2022-02-20 21:08:22,499 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (4)] Waiting until timeout for monitored process [2022-02-20 21:08:22,737 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:22,743 INFO L263 TraceCheckSpWp]: Trace formula consists of 1054 conjuncts, 23 conjunts are in the unsatisfiable core [2022-02-20 21:08:22,775 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:08:22,778 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-02-20 21:08:23,286 INFO L290 TraceCheckUtils]: 0: Hoare triple {4172#true} assume { :begin_inline_ULTIMATE.init } true;#NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(38, 2);call #Ultimate.allocInit(12, 3);call #Ultimate.allocInit(78, 4);~#s_can_fail_allocator_static~0.base, ~#s_can_fail_allocator_static~0.offset := 5, 0;call #Ultimate.allocInit(40, 5);call write~init~$Pointer$(#funAddr~s_can_fail_malloc_allocator.base, #funAddr~s_can_fail_malloc_allocator.offset, ~#s_can_fail_allocator_static~0.base, ~#s_can_fail_allocator_static~0.offset, 8);call write~init~$Pointer$(#funAddr~s_can_fail_free_allocator.base, #funAddr~s_can_fail_free_allocator.offset, ~#s_can_fail_allocator_static~0.base, 8 + ~#s_can_fail_allocator_static~0.offset, 8);call write~init~$Pointer$(#funAddr~s_can_fail_realloc_allocator.base, #funAddr~s_can_fail_realloc_allocator.offset, ~#s_can_fail_allocator_static~0.base, 16 + ~#s_can_fail_allocator_static~0.offset, 8);call write~init~$Pointer$(#funAddr~s_can_fail_calloc_allocator.base, #funAddr~s_can_fail_calloc_allocator.offset, ~#s_can_fail_allocator_static~0.base, 24 + ~#s_can_fail_allocator_static~0.offset, 8);call write~init~$Pointer$(0, 0, ~#s_can_fail_allocator_static~0.base, 32 + ~#s_can_fail_allocator_static~0.offset, 8);~#s_tolower_table~0.base, ~#s_tolower_table~0.offset := 6, 0;call #Ultimate.allocInit(256, 6);call write~init~int(0, ~#s_tolower_table~0.base, ~#s_tolower_table~0.offset, 1);call write~init~int(1, ~#s_tolower_table~0.base, 1 + ~#s_tolower_table~0.offset, 1);call write~init~int(2, ~#s_tolower_table~0.base, 2 + ~#s_tolower_table~0.offset, 1);call write~init~int(3, ~#s_tolower_table~0.base, 3 + ~#s_tolower_table~0.offset, 1);call write~init~int(4, ~#s_tolower_table~0.base, 4 + ~#s_tolower_table~0.offset, 1);call write~init~int(5, ~#s_tolower_table~0.base, 5 + ~#s_tolower_table~0.offset, 1);call write~init~int(6, ~#s_tolower_table~0.base, 6 + ~#s_tolower_table~0.offset, 1);call write~init~int(7, ~#s_tolower_table~0.base, 7 + ~#s_tolower_table~0.offset, 1);call write~init~int(8, ~#s_tolower_table~0.base, 8 + ~#s_tolower_table~0.offset, 1);call write~init~int(9, ~#s_tolower_table~0.base, 9 + ~#s_tolower_table~0.offset, 1);call write~init~int(10, ~#s_tolower_table~0.base, 10 + ~#s_tolower_table~0.offset, 1);call write~init~int(11, ~#s_tolower_table~0.base, 11 + ~#s_tolower_table~0.offset, 1);call write~init~int(12, ~#s_tolower_table~0.base, 12 + ~#s_tolower_table~0.offset, 1);call write~init~int(13, ~#s_tolower_table~0.base, 13 + ~#s_tolower_table~0.offset, 1);call write~init~int(14, ~#s_tolower_table~0.base, 14 + ~#s_tolower_table~0.offset, 1);call write~init~int(15, ~#s_tolower_table~0.base, 15 + ~#s_tolower_table~0.offset, 1);call write~init~int(16, ~#s_tolower_table~0.base, 16 + ~#s_tolower_table~0.offset, 1);call write~init~int(17, ~#s_tolower_table~0.base, 17 + ~#s_tolower_table~0.offset, 1);call write~init~int(18, ~#s_tolower_table~0.base, 18 + ~#s_tolower_table~0.offset, 1);call write~init~int(19, ~#s_tolower_table~0.base, 19 + ~#s_tolower_table~0.offset, 1);call write~init~int(20, ~#s_tolower_table~0.base, 20 + ~#s_tolower_table~0.offset, 1);call write~init~int(21, ~#s_tolower_table~0.base, 21 + ~#s_tolower_table~0.offset, 1);call write~init~int(22, ~#s_tolower_table~0.base, 22 + ~#s_tolower_table~0.offset, 1);call write~init~int(23, ~#s_tolower_table~0.base, 23 + ~#s_tolower_table~0.offset, 1);call write~init~int(24, ~#s_tolower_table~0.base, 24 + ~#s_tolower_table~0.offset, 1);call write~init~int(25, ~#s_tolower_table~0.base, 25 + ~#s_tolower_table~0.offset, 1);call write~init~int(26, ~#s_tolower_table~0.base, 26 + ~#s_tolower_table~0.offset, 1);call write~init~int(27, ~#s_tolower_table~0.base, 27 + ~#s_tolower_table~0.offset, 1);call write~init~int(28, ~#s_tolower_table~0.base, 28 + ~#s_tolower_table~0.offset, 1);call write~init~int(29, ~#s_tolower_table~0.base, 29 + ~#s_tolower_table~0.offset, 1);call write~init~int(30, ~#s_tolower_table~0.base, 30 + ~#s_tolower_table~0.offset, 1);call write~init~int(31, ~#s_tolower_table~0.base, 31 + ~#s_tolower_table~0.offset, 1);call write~init~int(32, ~#s_tolower_table~0.base, 32 + ~#s_tolower_table~0.offset, 1);call write~init~int(33, ~#s_tolower_table~0.base, 33 + ~#s_tolower_table~0.offset, 1);call write~init~int(34, ~#s_tolower_table~0.base, 34 + ~#s_tolower_table~0.offset, 1);call write~init~int(35, ~#s_tolower_table~0.base, 35 + ~#s_tolower_table~0.offset, 1);call write~init~int(36, ~#s_tolower_table~0.base, 36 + ~#s_tolower_table~0.offset, 1);call write~init~int(37, ~#s_tolower_table~0.base, 37 + ~#s_tolower_table~0.offset, 1);call write~init~int(38, ~#s_tolower_table~0.base, 38 + ~#s_tolower_table~0.offset, 1);call write~init~int(39, ~#s_tolower_table~0.base, 39 + ~#s_tolower_table~0.offset, 1);call write~init~int(40, ~#s_tolower_table~0.base, 40 + ~#s_tolower_table~0.offset, 1);call write~init~int(41, ~#s_tolower_table~0.base, 41 + ~#s_tolower_table~0.offset, 1);call write~init~int(42, ~#s_tolower_table~0.base, 42 + ~#s_tolower_table~0.offset, 1);call write~init~int(43, ~#s_tolower_table~0.base, 43 + ~#s_tolower_table~0.offset, 1);call write~init~int(44, ~#s_tolower_table~0.base, 44 + ~#s_tolower_table~0.offset, 1);call write~init~int(45, ~#s_tolower_table~0.base, 45 + ~#s_tolower_table~0.offset, 1);call write~init~int(46, ~#s_tolower_table~0.base, 46 + ~#s_tolower_table~0.offset, 1);call write~init~int(47, ~#s_tolower_table~0.base, 47 + ~#s_tolower_table~0.offset, 1);call write~init~int(48, ~#s_tolower_table~0.base, 48 + ~#s_tolower_table~0.offset, 1);call write~init~int(49, ~#s_tolower_table~0.base, 49 + ~#s_tolower_table~0.offset, 1);call write~init~int(50, ~#s_tolower_table~0.base, 50 + ~#s_tolower_table~0.offset, 1);call write~init~int(51, ~#s_tolower_table~0.base, 51 + ~#s_tolower_table~0.offset, 1);call write~init~int(52, ~#s_tolower_table~0.base, 52 + ~#s_tolower_table~0.offset, 1);call write~init~int(53, ~#s_tolower_table~0.base, 53 + ~#s_tolower_table~0.offset, 1);call write~init~int(54, ~#s_tolower_table~0.base, 54 + ~#s_tolower_table~0.offset, 1);call write~init~int(55, ~#s_tolower_table~0.base, 55 + ~#s_tolower_table~0.offset, 1);call write~init~int(56, ~#s_tolower_table~0.base, 56 + ~#s_tolower_table~0.offset, 1);call write~init~int(57, ~#s_tolower_table~0.base, 57 + ~#s_tolower_table~0.offset, 1);call write~init~int(58, ~#s_tolower_table~0.base, 58 + ~#s_tolower_table~0.offset, 1);call write~init~int(59, ~#s_tolower_table~0.base, 59 + ~#s_tolower_table~0.offset, 1);call write~init~int(60, ~#s_tolower_table~0.base, 60 + ~#s_tolower_table~0.offset, 1);call write~init~int(61, ~#s_tolower_table~0.base, 61 + ~#s_tolower_table~0.offset, 1);call write~init~int(62, ~#s_tolower_table~0.base, 62 + ~#s_tolower_table~0.offset, 1);call write~init~int(63, ~#s_tolower_table~0.base, 63 + ~#s_tolower_table~0.offset, 1);call write~init~int(64, ~#s_tolower_table~0.base, 64 + ~#s_tolower_table~0.offset, 1);call write~init~int(97, ~#s_tolower_table~0.base, 65 + ~#s_tolower_table~0.offset, 1);call write~init~int(98, ~#s_tolower_table~0.base, 66 + ~#s_tolower_table~0.offset, 1);call write~init~int(99, ~#s_tolower_table~0.base, 67 + ~#s_tolower_table~0.offset, 1);call write~init~int(100, ~#s_tolower_table~0.base, 68 + ~#s_tolower_table~0.offset, 1);call write~init~int(101, ~#s_tolower_table~0.base, 69 + ~#s_tolower_table~0.offset, 1);call write~init~int(102, ~#s_tolower_table~0.base, 70 + ~#s_tolower_table~0.offset, 1);call write~init~int(103, ~#s_tolower_table~0.base, 71 + ~#s_tolower_table~0.offset, 1);call write~init~int(104, ~#s_tolower_table~0.base, 72 + ~#s_tolower_table~0.offset, 1);call write~init~int(105, ~#s_tolower_table~0.base, 73 + ~#s_tolower_table~0.offset, 1);call write~init~int(106, ~#s_tolower_table~0.base, 74 + ~#s_tolower_table~0.offset, 1);call write~init~int(107, ~#s_tolower_table~0.base, 75 + ~#s_tolower_table~0.offset, 1);call write~init~int(108, ~#s_tolower_table~0.base, 76 + ~#s_tolower_table~0.offset, 1);call write~init~int(109, ~#s_tolower_table~0.base, 77 + ~#s_tolower_table~0.offset, 1);call write~init~int(110, ~#s_tolower_table~0.base, 78 + ~#s_tolower_table~0.offset, 1);call write~init~int(111, ~#s_tolower_table~0.base, 79 + ~#s_tolower_table~0.offset, 1);call write~init~int(112, ~#s_tolower_table~0.base, 80 + ~#s_tolower_table~0.offset, 1);call write~init~int(113, ~#s_tolower_table~0.base, 81 + ~#s_tolower_table~0.offset, 1);call write~init~int(114, ~#s_tolower_table~0.base, 82 + ~#s_tolower_table~0.offset, 1);call write~init~int(115, ~#s_tolower_table~0.base, 83 + ~#s_tolower_table~0.offset, 1);call write~init~int(116, ~#s_tolower_table~0.base, 84 + ~#s_tolower_table~0.offset, 1);call write~init~int(117, ~#s_tolower_table~0.base, 85 + ~#s_tolower_table~0.offset, 1);call write~init~int(118, ~#s_tolower_table~0.base, 86 + ~#s_tolower_table~0.offset, 1);call write~init~int(119, ~#s_tolower_table~0.base, 87 + ~#s_tolower_table~0.offset, 1);call write~init~int(120, ~#s_tolower_table~0.base, 88 + ~#s_tolower_table~0.offset, 1);call write~init~int(121, ~#s_tolower_table~0.base, 89 + ~#s_tolower_table~0.offset, 1);call write~init~int(122, ~#s_tolower_table~0.base, 90 + ~#s_tolower_table~0.offset, 1);call write~init~int(91, ~#s_tolower_table~0.base, 91 + ~#s_tolower_table~0.offset, 1);call write~init~int(92, ~#s_tolower_table~0.base, 92 + ~#s_tolower_table~0.offset, 1);call write~init~int(93, ~#s_tolower_table~0.base, 93 + ~#s_tolower_table~0.offset, 1);call write~init~int(94, ~#s_tolower_table~0.base, 94 + ~#s_tolower_table~0.offset, 1);call write~init~int(95, ~#s_tolower_table~0.base, 95 + ~#s_tolower_table~0.offset, 1);call write~init~int(96, ~#s_tolower_table~0.base, 96 + ~#s_tolower_table~0.offset, 1);call write~init~int(97, ~#s_tolower_table~0.base, 97 + ~#s_tolower_table~0.offset, 1);call write~init~int(98, ~#s_tolower_table~0.base, 98 + ~#s_tolower_table~0.offset, 1);call write~init~int(99, ~#s_tolower_table~0.base, 99 + ~#s_tolower_table~0.offset, 1);call write~init~int(100, ~#s_tolower_table~0.base, 100 + ~#s_tolower_table~0.offset, 1);call write~init~int(101, ~#s_tolower_table~0.base, 101 + ~#s_tolower_table~0.offset, 1);call write~init~int(102, ~#s_tolower_table~0.base, 102 + ~#s_tolower_table~0.offset, 1);call write~init~int(103, ~#s_tolower_table~0.base, 103 + ~#s_tolower_table~0.offset, 1);call write~init~int(104, ~#s_tolower_table~0.base, 104 + ~#s_tolower_table~0.offset, 1);call write~init~int(105, ~#s_tolower_table~0.base, 105 + ~#s_tolower_table~0.offset, 1);call write~init~int(106, ~#s_tolower_table~0.base, 106 + ~#s_tolower_table~0.offset, 1);call write~init~int(107, ~#s_tolower_table~0.base, 107 + ~#s_tolower_table~0.offset, 1);call write~init~int(108, ~#s_tolower_table~0.base, 108 + ~#s_tolower_table~0.offset, 1);call write~init~int(109, ~#s_tolower_table~0.base, 109 + ~#s_tolower_table~0.offset, 1);call write~init~int(110, ~#s_tolower_table~0.base, 110 + ~#s_tolower_table~0.offset, 1);call write~init~int(111, ~#s_tolower_table~0.base, 111 + ~#s_tolower_table~0.offset, 1);call write~init~int(112, ~#s_tolower_table~0.base, 112 + ~#s_tolower_table~0.offset, 1);call write~init~int(113, ~#s_tolower_table~0.base, 113 + ~#s_tolower_table~0.offset, 1);call write~init~int(114, ~#s_tolower_table~0.base, 114 + ~#s_tolower_table~0.offset, 1);call write~init~int(115, ~#s_tolower_table~0.base, 115 + ~#s_tolower_table~0.offset, 1);call write~init~int(116, ~#s_tolower_table~0.base, 116 + ~#s_tolower_table~0.offset, 1);call write~init~int(117, ~#s_tolower_table~0.base, 117 + ~#s_tolower_table~0.offset, 1);call write~init~int(118, ~#s_tolower_table~0.base, 118 + ~#s_tolower_table~0.offset, 1);call write~init~int(119, ~#s_tolower_table~0.base, 119 + ~#s_tolower_table~0.offset, 1);call write~init~int(120, ~#s_tolower_table~0.base, 120 + ~#s_tolower_table~0.offset, 1);call write~init~int(121, ~#s_tolower_table~0.base, 121 + ~#s_tolower_table~0.offset, 1);call write~init~int(122, ~#s_tolower_table~0.base, 122 + ~#s_tolower_table~0.offset, 1);call write~init~int(123, ~#s_tolower_table~0.base, 123 + ~#s_tolower_table~0.offset, 1);call write~init~int(124, ~#s_tolower_table~0.base, 124 + ~#s_tolower_table~0.offset, 1);call write~init~int(125, ~#s_tolower_table~0.base, 125 + ~#s_tolower_table~0.offset, 1);call write~init~int(126, ~#s_tolower_table~0.base, 126 + ~#s_tolower_table~0.offset, 1);call write~init~int(127, ~#s_tolower_table~0.base, 127 + ~#s_tolower_table~0.offset, 1);call write~init~int(128, ~#s_tolower_table~0.base, 128 + ~#s_tolower_table~0.offset, 1);call write~init~int(129, ~#s_tolower_table~0.base, 129 + ~#s_tolower_table~0.offset, 1);call write~init~int(130, ~#s_tolower_table~0.base, 130 + ~#s_tolower_table~0.offset, 1);call write~init~int(131, ~#s_tolower_table~0.base, 131 + ~#s_tolower_table~0.offset, 1);call write~init~int(132, ~#s_tolower_table~0.base, 132 + ~#s_tolower_table~0.offset, 1);call write~init~int(133, ~#s_tolower_table~0.base, 133 + ~#s_tolower_table~0.offset, 1);call write~init~int(134, ~#s_tolower_table~0.base, 134 + ~#s_tolower_table~0.offset, 1);call write~init~int(135, ~#s_tolower_table~0.base, 135 + ~#s_tolower_table~0.offset, 1);call write~init~int(136, ~#s_tolower_table~0.base, 136 + ~#s_tolower_table~0.offset, 1);call write~init~int(137, ~#s_tolower_table~0.base, 137 + ~#s_tolower_table~0.offset, 1);call write~init~int(138, ~#s_tolower_table~0.base, 138 + ~#s_tolower_table~0.offset, 1);call write~init~int(139, ~#s_tolower_table~0.base, 139 + ~#s_tolower_table~0.offset, 1);call write~init~int(140, ~#s_tolower_table~0.base, 140 + ~#s_tolower_table~0.offset, 1);call write~init~int(141, ~#s_tolower_table~0.base, 141 + ~#s_tolower_table~0.offset, 1);call write~init~int(142, ~#s_tolower_table~0.base, 142 + ~#s_tolower_table~0.offset, 1);call write~init~int(143, ~#s_tolower_table~0.base, 143 + ~#s_tolower_table~0.offset, 1);call write~init~int(144, ~#s_tolower_table~0.base, 144 + ~#s_tolower_table~0.offset, 1);call write~init~int(145, ~#s_tolower_table~0.base, 145 + ~#s_tolower_table~0.offset, 1);call write~init~int(146, ~#s_tolower_table~0.base, 146 + ~#s_tolower_table~0.offset, 1);call write~init~int(147, ~#s_tolower_table~0.base, 147 + ~#s_tolower_table~0.offset, 1);call write~init~int(148, ~#s_tolower_table~0.base, 148 + ~#s_tolower_table~0.offset, 1);call write~init~int(149, ~#s_tolower_table~0.base, 149 + ~#s_tolower_table~0.offset, 1);call write~init~int(150, ~#s_tolower_table~0.base, 150 + ~#s_tolower_table~0.offset, 1);call write~init~int(151, ~#s_tolower_table~0.base, 151 + ~#s_tolower_table~0.offset, 1);call write~init~int(152, ~#s_tolower_table~0.base, 152 + ~#s_tolower_table~0.offset, 1);call write~init~int(153, ~#s_tolower_table~0.base, 153 + ~#s_tolower_table~0.offset, 1);call write~init~int(154, ~#s_tolower_table~0.base, 154 + ~#s_tolower_table~0.offset, 1);call write~init~int(155, ~#s_tolower_table~0.base, 155 + ~#s_tolower_table~0.offset, 1);call write~init~int(156, ~#s_tolower_table~0.base, 156 + ~#s_tolower_table~0.offset, 1);call write~init~int(157, ~#s_tolower_table~0.base, 157 + ~#s_tolower_table~0.offset, 1);call write~init~int(158, ~#s_tolower_table~0.base, 158 + ~#s_tolower_table~0.offset, 1);call write~init~int(159, ~#s_tolower_table~0.base, 159 + ~#s_tolower_table~0.offset, 1);call write~init~int(160, ~#s_tolower_table~0.base, 160 + ~#s_tolower_table~0.offset, 1);call write~init~int(161, ~#s_tolower_table~0.base, 161 + ~#s_tolower_table~0.offset, 1);call write~init~int(162, ~#s_tolower_table~0.base, 162 + ~#s_tolower_table~0.offset, 1);call write~init~int(163, ~#s_tolower_table~0.base, 163 + ~#s_tolower_table~0.offset, 1);call write~init~int(164, ~#s_tolower_table~0.base, 164 + ~#s_tolower_table~0.offset, 1);call write~init~int(165, ~#s_tolower_table~0.base, 165 + ~#s_tolower_table~0.offset, 1);call write~init~int(166, ~#s_tolower_table~0.base, 166 + ~#s_tolower_table~0.offset, 1);call write~init~int(167, ~#s_tolower_table~0.base, 167 + ~#s_tolower_table~0.offset, 1);call write~init~int(168, ~#s_tolower_table~0.base, 168 + ~#s_tolower_table~0.offset, 1);call write~init~int(169, ~#s_tolower_table~0.base, 169 + ~#s_tolower_table~0.offset, 1);call write~init~int(170, ~#s_tolower_table~0.base, 170 + ~#s_tolower_table~0.offset, 1);call write~init~int(171, ~#s_tolower_table~0.base, 171 + ~#s_tolower_table~0.offset, 1);call write~init~int(172, ~#s_tolower_table~0.base, 172 + ~#s_tolower_table~0.offset, 1);call write~init~int(173, ~#s_tolower_table~0.base, 173 + ~#s_tolower_table~0.offset, 1);call write~init~int(174, ~#s_tolower_table~0.base, 174 + ~#s_tolower_table~0.offset, 1);call write~init~int(175, ~#s_tolower_table~0.base, 175 + ~#s_tolower_table~0.offset, 1);call write~init~int(176, ~#s_tolower_table~0.base, 176 + ~#s_tolower_table~0.offset, 1);call write~init~int(177, ~#s_tolower_table~0.base, 177 + ~#s_tolower_table~0.offset, 1);call write~init~int(178, ~#s_tolower_table~0.base, 178 + ~#s_tolower_table~0.offset, 1);call write~init~int(179, ~#s_tolower_table~0.base, 179 + ~#s_tolower_table~0.offset, 1);call write~init~int(180, ~#s_tolower_table~0.base, 180 + ~#s_tolower_table~0.offset, 1);call write~init~int(181, ~#s_tolower_table~0.base, 181 + ~#s_tolower_table~0.offset, 1);call write~init~int(182, ~#s_tolower_table~0.base, 182 + ~#s_tolower_table~0.offset, 1);call write~init~int(183, ~#s_tolower_table~0.base, 183 + ~#s_tolower_table~0.offset, 1);call write~init~int(184, ~#s_tolower_table~0.base, 184 + ~#s_tolower_table~0.offset, 1);call write~init~int(185, ~#s_tolower_table~0.base, 185 + ~#s_tolower_table~0.offset, 1);call write~init~int(186, ~#s_tolower_table~0.base, 186 + ~#s_tolower_table~0.offset, 1);call write~init~int(187, ~#s_tolower_table~0.base, 187 + ~#s_tolower_table~0.offset, 1);call write~init~int(188, ~#s_tolower_table~0.base, 188 + ~#s_tolower_table~0.offset, 1);call write~init~int(189, ~#s_tolower_table~0.base, 189 + ~#s_tolower_table~0.offset, 1);call write~init~int(190, ~#s_tolower_table~0.base, 190 + ~#s_tolower_table~0.offset, 1);call write~init~int(191, ~#s_tolower_table~0.base, 191 + ~#s_tolower_table~0.offset, 1);call write~init~int(192, ~#s_tolower_table~0.base, 192 + ~#s_tolower_table~0.offset, 1);call write~init~int(193, ~#s_tolower_table~0.base, 193 + ~#s_tolower_table~0.offset, 1);call write~init~int(194, ~#s_tolower_table~0.base, 194 + ~#s_tolower_table~0.offset, 1);call write~init~int(195, ~#s_tolower_table~0.base, 195 + ~#s_tolower_table~0.offset, 1);call write~init~int(196, ~#s_tolower_table~0.base, 196 + ~#s_tolower_table~0.offset, 1);call write~init~int(197, ~#s_tolower_table~0.base, 197 + ~#s_tolower_table~0.offset, 1);call write~init~int(198, ~#s_tolower_table~0.base, 198 + ~#s_tolower_table~0.offset, 1);call write~init~int(199, ~#s_tolower_table~0.base, 199 + ~#s_tolower_table~0.offset, 1);call write~init~int(200, ~#s_tolower_table~0.base, 200 + ~#s_tolower_table~0.offset, 1);call write~init~int(201, ~#s_tolower_table~0.base, 201 + ~#s_tolower_table~0.offset, 1);call write~init~int(202, ~#s_tolower_table~0.base, 202 + ~#s_tolower_table~0.offset, 1);call write~init~int(203, ~#s_tolower_table~0.base, 203 + ~#s_tolower_table~0.offset, 1);call write~init~int(204, ~#s_tolower_table~0.base, 204 + ~#s_tolower_table~0.offset, 1);call write~init~int(205, ~#s_tolower_table~0.base, 205 + ~#s_tolower_table~0.offset, 1);call write~init~int(206, ~#s_tolower_table~0.base, 206 + ~#s_tolower_table~0.offset, 1);call write~init~int(207, ~#s_tolower_table~0.base, 207 + ~#s_tolower_table~0.offset, 1);call write~init~int(208, ~#s_tolower_table~0.base, 208 + ~#s_tolower_table~0.offset, 1);call write~init~int(209, ~#s_tolower_table~0.base, 209 + ~#s_tolower_table~0.offset, 1);call write~init~int(210, ~#s_tolower_table~0.base, 210 + ~#s_tolower_table~0.offset, 1);call write~init~int(211, ~#s_tolower_table~0.base, 211 + ~#s_tolower_table~0.offset, 1);call write~init~int(212, ~#s_tolower_table~0.base, 212 + ~#s_tolower_table~0.offset, 1);call write~init~int(213, ~#s_tolower_table~0.base, 213 + ~#s_tolower_table~0.offset, 1);call write~init~int(214, ~#s_tolower_table~0.base, 214 + ~#s_tolower_table~0.offset, 1);call write~init~int(215, ~#s_tolower_table~0.base, 215 + ~#s_tolower_table~0.offset, 1);call write~init~int(216, ~#s_tolower_table~0.base, 216 + ~#s_tolower_table~0.offset, 1);call write~init~int(217, ~#s_tolower_table~0.base, 217 + ~#s_tolower_table~0.offset, 1);call write~init~int(218, ~#s_tolower_table~0.base, 218 + ~#s_tolower_table~0.offset, 1);call write~init~int(219, ~#s_tolower_table~0.base, 219 + ~#s_tolower_table~0.offset, 1);call write~init~int(220, ~#s_tolower_table~0.base, 220 + ~#s_tolower_table~0.offset, 1);call write~init~int(221, ~#s_tolower_table~0.base, 221 + ~#s_tolower_table~0.offset, 1);call write~init~int(222, ~#s_tolower_table~0.base, 222 + ~#s_tolower_table~0.offset, 1);call write~init~int(223, ~#s_tolower_table~0.base, 223 + ~#s_tolower_table~0.offset, 1);call write~init~int(224, ~#s_tolower_table~0.base, 224 + ~#s_tolower_table~0.offset, 1);call write~init~int(225, ~#s_tolower_table~0.base, 225 + ~#s_tolower_table~0.offset, 1);call write~init~int(226, ~#s_tolower_table~0.base, 226 + ~#s_tolower_table~0.offset, 1);call write~init~int(227, ~#s_tolower_table~0.base, 227 + ~#s_tolower_table~0.offset, 1);call write~init~int(228, ~#s_tolower_table~0.base, 228 + ~#s_tolower_table~0.offset, 1);call write~init~int(229, ~#s_tolower_table~0.base, 229 + ~#s_tolower_table~0.offset, 1);call write~init~int(230, ~#s_tolower_table~0.base, 230 + ~#s_tolower_table~0.offset, 1);call write~init~int(231, ~#s_tolower_table~0.base, 231 + ~#s_tolower_table~0.offset, 1);call write~init~int(232, ~#s_tolower_table~0.base, 232 + ~#s_tolower_table~0.offset, 1);call write~init~int(233, ~#s_tolower_table~0.base, 233 + ~#s_tolower_table~0.offset, 1);call write~init~int(234, ~#s_tolower_table~0.base, 234 + ~#s_tolower_table~0.offset, 1);call write~init~int(235, ~#s_tolower_table~0.base, 235 + ~#s_tolower_table~0.offset, 1);call write~init~int(236, ~#s_tolower_table~0.base, 236 + ~#s_tolower_table~0.offset, 1);call write~init~int(237, ~#s_tolower_table~0.base, 237 + ~#s_tolower_table~0.offset, 1);call write~init~int(238, ~#s_tolower_table~0.base, 238 + ~#s_tolower_table~0.offset, 1);call write~init~int(239, ~#s_tolower_table~0.base, 239 + ~#s_tolower_table~0.offset, 1);call write~init~int(240, ~#s_tolower_table~0.base, 240 + ~#s_tolower_table~0.offset, 1);call write~init~int(241, ~#s_tolower_table~0.base, 241 + ~#s_tolower_table~0.offset, 1);call write~init~int(242, ~#s_tolower_table~0.base, 242 + ~#s_tolower_table~0.offset, 1);call write~init~int(243, ~#s_tolower_table~0.base, 243 + ~#s_tolower_table~0.offset, 1);call write~init~int(244, ~#s_tolower_table~0.base, 244 + ~#s_tolower_table~0.offset, 1);call write~init~int(245, ~#s_tolower_table~0.base, 245 + ~#s_tolower_table~0.offset, 1);call write~init~int(246, ~#s_tolower_table~0.base, 246 + ~#s_tolower_table~0.offset, 1);call write~init~int(247, ~#s_tolower_table~0.base, 247 + ~#s_tolower_table~0.offset, 1);call write~init~int(248, ~#s_tolower_table~0.base, 248 + ~#s_tolower_table~0.offset, 1);call write~init~int(249, ~#s_tolower_table~0.base, 249 + ~#s_tolower_table~0.offset, 1);call write~init~int(250, ~#s_tolower_table~0.base, 250 + ~#s_tolower_table~0.offset, 1);call write~init~int(251, ~#s_tolower_table~0.base, 251 + ~#s_tolower_table~0.offset, 1);call write~init~int(252, ~#s_tolower_table~0.base, 252 + ~#s_tolower_table~0.offset, 1);call write~init~int(253, ~#s_tolower_table~0.base, 253 + ~#s_tolower_table~0.offset, 1);call write~init~int(254, ~#s_tolower_table~0.base, 254 + ~#s_tolower_table~0.offset, 1);call write~init~int(255, ~#s_tolower_table~0.base, 255 + ~#s_tolower_table~0.offset, 1); {4172#true} is VALID [2022-02-20 21:08:23,286 INFO L290 TraceCheckUtils]: 1: Hoare triple {4172#true} assume { :end_inline_ULTIMATE.init } true;assume { :begin_inline_main } true;havoc main_#res#1;assume { :begin_inline_aws_hash_callback_string_eq_harness } true;havoc aws_hash_callback_string_eq_harness_#t~ret1963#1.base, aws_hash_callback_string_eq_harness_#t~ret1963#1.offset, aws_hash_callback_string_eq_harness_#t~ret1964#1, aws_hash_callback_string_eq_harness_#t~ite1966#1.base, aws_hash_callback_string_eq_harness_#t~ite1966#1.offset, aws_hash_callback_string_eq_harness_#t~ret1965#1.base, aws_hash_callback_string_eq_harness_#t~ret1965#1.offset, aws_hash_callback_string_eq_harness_#t~ret1967#1, aws_hash_callback_string_eq_harness_#t~mem1968#1, aws_hash_callback_string_eq_harness_#t~mem1969#1, aws_hash_callback_string_eq_harness_#t~mem1970#1, aws_hash_callback_string_eq_harness_~str1~0#1.base, aws_hash_callback_string_eq_harness_~str1~0#1.offset, aws_hash_callback_string_eq_harness_~str2~0#1.base, aws_hash_callback_string_eq_harness_~str2~0#1.offset, aws_hash_callback_string_eq_harness_~rval~21#1; {4172#true} is VALID [2022-02-20 21:08:23,286 INFO L272 TraceCheckUtils]: 2: Hoare triple {4172#true} call aws_hash_callback_string_eq_harness_#t~ret1963#1.base, aws_hash_callback_string_eq_harness_#t~ret1963#1.offset := ensure_string_is_allocated_bounded_length(96); {4172#true} is VALID [2022-02-20 21:08:23,286 INFO L290 TraceCheckUtils]: 3: Hoare triple {4172#true} ~max_size#1 := #in~max_size#1; {4172#true} is VALID [2022-02-20 21:08:23,286 INFO L272 TraceCheckUtils]: 4: Hoare triple {4172#true} call #t~ret540#1 := nondet_uint64_t(); {4172#true} is VALID [2022-02-20 21:08:23,286 INFO L290 TraceCheckUtils]: 5: Hoare triple {4172#true} #res := #t~nondet13;havoc #t~nondet13; {4172#true} is VALID [2022-02-20 21:08:23,286 INFO L290 TraceCheckUtils]: 6: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:23,286 INFO L284 TraceCheckUtils]: 7: Hoare quadruple {4172#true} {4172#true} #182#return; {4172#true} is VALID [2022-02-20 21:08:23,286 INFO L290 TraceCheckUtils]: 8: Hoare triple {4172#true} ~len~1#1 := #t~ret540#1;havoc #t~ret540#1; {4172#true} is VALID [2022-02-20 21:08:23,287 INFO L272 TraceCheckUtils]: 9: Hoare triple {4172#true} call assume_abort_if_not((if 0 == (if ~len~1#1 % 18446744073709551616 < ~max_size#1 % 18446744073709551616 then 1 else 0) then 0 else 1)); {4172#true} is VALID [2022-02-20 21:08:23,287 INFO L290 TraceCheckUtils]: 10: Hoare triple {4172#true} ~cond := #in~cond; {4172#true} is VALID [2022-02-20 21:08:23,287 INFO L290 TraceCheckUtils]: 11: Hoare triple {4172#true} assume !(0 == ~cond % 256); {4172#true} is VALID [2022-02-20 21:08:23,287 INFO L290 TraceCheckUtils]: 12: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:23,287 INFO L284 TraceCheckUtils]: 13: Hoare quadruple {4172#true} {4172#true} #184#return; {4172#true} is VALID [2022-02-20 21:08:23,287 INFO L290 TraceCheckUtils]: 14: Hoare triple {4172#true} assume { :begin_inline_ensure_string_is_allocated } true;ensure_string_is_allocated_#in~len#1 := ~len~1#1;havoc ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset;havoc ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset, ensure_string_is_allocated_#t~ret543#1, ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset, ensure_string_is_allocated_#t~ret544#1.base, ensure_string_is_allocated_#t~ret544#1.offset, ensure_string_is_allocated_~len#1, ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset;ensure_string_is_allocated_~len#1 := ensure_string_is_allocated_#in~len#1; {4172#true} is VALID [2022-02-20 21:08:23,287 INFO L272 TraceCheckUtils]: 15: Hoare triple {4172#true} call ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset := bounded_malloc(-1234550 + ensure_string_is_allocated_~len#1); {4172#true} is VALID [2022-02-20 21:08:23,287 INFO L290 TraceCheckUtils]: 16: Hoare triple {4172#true} ~size := #in~size; {4172#true} is VALID [2022-02-20 21:08:23,287 INFO L272 TraceCheckUtils]: 17: Hoare triple {4172#true} call assume_abort_if_not((if 0 == (if ~size % 18446744073709551616 <= 36028797018963967 then 1 else 0) then 0 else 1)); {4172#true} is VALID [2022-02-20 21:08:23,287 INFO L290 TraceCheckUtils]: 18: Hoare triple {4172#true} ~cond := #in~cond; {4172#true} is VALID [2022-02-20 21:08:23,287 INFO L290 TraceCheckUtils]: 19: Hoare triple {4172#true} assume !(0 == ~cond % 256); {4172#true} is VALID [2022-02-20 21:08:23,287 INFO L290 TraceCheckUtils]: 20: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:23,287 INFO L284 TraceCheckUtils]: 21: Hoare quadruple {4172#true} {4172#true} #192#return; {4172#true} is VALID [2022-02-20 21:08:23,288 INFO L290 TraceCheckUtils]: 22: Hoare triple {4172#true} call #t~malloc555.base, #t~malloc555.offset := #Ultimate.allocOnHeap(~size);#res.base, #res.offset := #t~malloc555.base, #t~malloc555.offset;havoc #t~malloc555.base, #t~malloc555.offset; {4405#(not (= |bounded_malloc_#res.base| 0))} is VALID [2022-02-20 21:08:23,289 INFO L290 TraceCheckUtils]: 23: Hoare triple {4405#(not (= |bounded_malloc_#res.base| 0))} assume true; {4405#(not (= |bounded_malloc_#res.base| 0))} is VALID [2022-02-20 21:08:23,289 INFO L284 TraceCheckUtils]: 24: Hoare quadruple {4405#(not (= |bounded_malloc_#res.base| 0))} {4172#true} #186#return; {4412#(not (= |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_#t~ret542#1.base| 0))} is VALID [2022-02-20 21:08:23,290 INFO L290 TraceCheckUtils]: 25: Hoare triple {4412#(not (= |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_#t~ret542#1.base| 0))} ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset := ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset;havoc ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset; {4416#(not (= |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~str~0#1.base| 0))} is VALID [2022-02-20 21:08:23,290 INFO L272 TraceCheckUtils]: 26: Hoare triple {4416#(not (= |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~str~0#1.base| 0))} call ensure_string_is_allocated_#t~ret543#1 := nondet_bool(); {4172#true} is VALID [2022-02-20 21:08:23,290 INFO L290 TraceCheckUtils]: 27: Hoare triple {4172#true} #res := #t~nondet8;havoc #t~nondet8; {4172#true} is VALID [2022-02-20 21:08:23,290 INFO L290 TraceCheckUtils]: 28: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:23,290 INFO L284 TraceCheckUtils]: 29: Hoare quadruple {4172#true} {4416#(not (= |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~str~0#1.base| 0))} #188#return; {4416#(not (= |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~str~0#1.base| 0))} is VALID [2022-02-20 21:08:23,291 INFO L290 TraceCheckUtils]: 30: Hoare triple {4416#(not (= |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~str~0#1.base| 0))} assume !(0 != ensure_string_is_allocated_#t~ret543#1 % 256);ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset := 0, 0; {4416#(not (= |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~str~0#1.base| 0))} is VALID [2022-02-20 21:08:23,292 INFO L290 TraceCheckUtils]: 31: Hoare triple {4416#(not (= |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~str~0#1.base| 0))} call write~$Pointer$(ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset, ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset, 8);havoc ensure_string_is_allocated_#t~ret543#1;havoc ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset;havoc ensure_string_is_allocated_#t~ret544#1.base, ensure_string_is_allocated_#t~ret544#1.offset;call write~int(ensure_string_is_allocated_~len#1, ensure_string_is_allocated_~str~0#1.base, 8 + ensure_string_is_allocated_~str~0#1.offset, 8);call write~int(0, ensure_string_is_allocated_~str~0#1.base, 16 + ensure_string_is_allocated_~str~0#1.offset + (if ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 else ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset := ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset; {4435#(not (= |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_#res#1.base| 0))} is VALID [2022-02-20 21:08:23,292 INFO L290 TraceCheckUtils]: 32: Hoare triple {4435#(not (= |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_#res#1.base| 0))} #t~ret541#1.base, #t~ret541#1.offset := ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset;assume { :end_inline_ensure_string_is_allocated } true;#res#1.base, #res#1.offset := #t~ret541#1.base, #t~ret541#1.offset;havoc #t~ret541#1.base, #t~ret541#1.offset; {4439#(not (= |ensure_string_is_allocated_bounded_length_#res#1.base| 0))} is VALID [2022-02-20 21:08:23,292 INFO L290 TraceCheckUtils]: 33: Hoare triple {4439#(not (= |ensure_string_is_allocated_bounded_length_#res#1.base| 0))} assume true; {4439#(not (= |ensure_string_is_allocated_bounded_length_#res#1.base| 0))} is VALID [2022-02-20 21:08:23,293 INFO L284 TraceCheckUtils]: 34: Hoare quadruple {4439#(not (= |ensure_string_is_allocated_bounded_length_#res#1.base| 0))} {4172#true} #198#return; {4446#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_#t~ret1963#1.base| 0))} is VALID [2022-02-20 21:08:23,293 INFO L290 TraceCheckUtils]: 35: Hoare triple {4446#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_#t~ret1963#1.base| 0))} aws_hash_callback_string_eq_harness_~str1~0#1.base, aws_hash_callback_string_eq_harness_~str1~0#1.offset := aws_hash_callback_string_eq_harness_#t~ret1963#1.base, aws_hash_callback_string_eq_harness_#t~ret1963#1.offset;havoc aws_hash_callback_string_eq_harness_#t~ret1963#1.base, aws_hash_callback_string_eq_harness_#t~ret1963#1.offset; {4450#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| 0))} is VALID [2022-02-20 21:08:23,293 INFO L272 TraceCheckUtils]: 36: Hoare triple {4450#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| 0))} call aws_hash_callback_string_eq_harness_#t~ret1964#1 := nondet_bool(); {4172#true} is VALID [2022-02-20 21:08:23,293 INFO L290 TraceCheckUtils]: 37: Hoare triple {4172#true} #res := #t~nondet8;havoc #t~nondet8; {4172#true} is VALID [2022-02-20 21:08:23,293 INFO L290 TraceCheckUtils]: 38: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:23,294 INFO L284 TraceCheckUtils]: 39: Hoare quadruple {4172#true} {4450#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| 0))} #200#return; {4450#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| 0))} is VALID [2022-02-20 21:08:23,295 INFO L290 TraceCheckUtils]: 40: Hoare triple {4450#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| 0))} assume !(0 != aws_hash_callback_string_eq_harness_#t~ret1964#1 % 256); {4450#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| 0))} is VALID [2022-02-20 21:08:23,296 INFO L272 TraceCheckUtils]: 41: Hoare triple {4450#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| 0))} call aws_hash_callback_string_eq_harness_#t~ret1965#1.base, aws_hash_callback_string_eq_harness_#t~ret1965#1.offset := ensure_string_is_allocated_bounded_length(96); {4172#true} is VALID [2022-02-20 21:08:23,296 INFO L290 TraceCheckUtils]: 42: Hoare triple {4172#true} ~max_size#1 := #in~max_size#1; {4172#true} is VALID [2022-02-20 21:08:23,296 INFO L272 TraceCheckUtils]: 43: Hoare triple {4172#true} call #t~ret540#1 := nondet_uint64_t(); {4172#true} is VALID [2022-02-20 21:08:23,296 INFO L290 TraceCheckUtils]: 44: Hoare triple {4172#true} #res := #t~nondet13;havoc #t~nondet13; {4172#true} is VALID [2022-02-20 21:08:23,296 INFO L290 TraceCheckUtils]: 45: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:23,296 INFO L284 TraceCheckUtils]: 46: Hoare quadruple {4172#true} {4172#true} #182#return; {4172#true} is VALID [2022-02-20 21:08:23,296 INFO L290 TraceCheckUtils]: 47: Hoare triple {4172#true} ~len~1#1 := #t~ret540#1;havoc #t~ret540#1; {4172#true} is VALID [2022-02-20 21:08:23,296 INFO L272 TraceCheckUtils]: 48: Hoare triple {4172#true} call assume_abort_if_not((if 0 == (if ~len~1#1 % 18446744073709551616 < ~max_size#1 % 18446744073709551616 then 1 else 0) then 0 else 1)); {4172#true} is VALID [2022-02-20 21:08:23,296 INFO L290 TraceCheckUtils]: 49: Hoare triple {4172#true} ~cond := #in~cond; {4172#true} is VALID [2022-02-20 21:08:23,296 INFO L290 TraceCheckUtils]: 50: Hoare triple {4172#true} assume !(0 == ~cond % 256); {4172#true} is VALID [2022-02-20 21:08:23,296 INFO L290 TraceCheckUtils]: 51: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:23,297 INFO L284 TraceCheckUtils]: 52: Hoare quadruple {4172#true} {4172#true} #184#return; {4172#true} is VALID [2022-02-20 21:08:23,297 INFO L290 TraceCheckUtils]: 53: Hoare triple {4172#true} assume { :begin_inline_ensure_string_is_allocated } true;ensure_string_is_allocated_#in~len#1 := ~len~1#1;havoc ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset;havoc ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset, ensure_string_is_allocated_#t~ret543#1, ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset, ensure_string_is_allocated_#t~ret544#1.base, ensure_string_is_allocated_#t~ret544#1.offset, ensure_string_is_allocated_~len#1, ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset;ensure_string_is_allocated_~len#1 := ensure_string_is_allocated_#in~len#1; {4172#true} is VALID [2022-02-20 21:08:23,297 INFO L272 TraceCheckUtils]: 54: Hoare triple {4172#true} call ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset := bounded_malloc(-1234550 + ensure_string_is_allocated_~len#1); {4172#true} is VALID [2022-02-20 21:08:23,297 INFO L290 TraceCheckUtils]: 55: Hoare triple {4172#true} ~size := #in~size; {4172#true} is VALID [2022-02-20 21:08:23,297 INFO L272 TraceCheckUtils]: 56: Hoare triple {4172#true} call assume_abort_if_not((if 0 == (if ~size % 18446744073709551616 <= 36028797018963967 then 1 else 0) then 0 else 1)); {4172#true} is VALID [2022-02-20 21:08:23,298 INFO L290 TraceCheckUtils]: 57: Hoare triple {4172#true} ~cond := #in~cond; {4172#true} is VALID [2022-02-20 21:08:23,298 INFO L290 TraceCheckUtils]: 58: Hoare triple {4172#true} assume !(0 == ~cond % 256); {4172#true} is VALID [2022-02-20 21:08:23,299 INFO L290 TraceCheckUtils]: 59: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:23,299 INFO L284 TraceCheckUtils]: 60: Hoare quadruple {4172#true} {4172#true} #192#return; {4172#true} is VALID [2022-02-20 21:08:23,299 INFO L290 TraceCheckUtils]: 61: Hoare triple {4172#true} call #t~malloc555.base, #t~malloc555.offset := #Ultimate.allocOnHeap(~size);#res.base, #res.offset := #t~malloc555.base, #t~malloc555.offset;havoc #t~malloc555.base, #t~malloc555.offset; {4172#true} is VALID [2022-02-20 21:08:23,299 INFO L290 TraceCheckUtils]: 62: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:23,299 INFO L284 TraceCheckUtils]: 63: Hoare quadruple {4172#true} {4172#true} #186#return; {4172#true} is VALID [2022-02-20 21:08:23,299 INFO L290 TraceCheckUtils]: 64: Hoare triple {4172#true} ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset := ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset;havoc ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset; {4172#true} is VALID [2022-02-20 21:08:23,303 INFO L272 TraceCheckUtils]: 65: Hoare triple {4172#true} call ensure_string_is_allocated_#t~ret543#1 := nondet_bool(); {4172#true} is VALID [2022-02-20 21:08:23,303 INFO L290 TraceCheckUtils]: 66: Hoare triple {4172#true} #res := #t~nondet8;havoc #t~nondet8; {4172#true} is VALID [2022-02-20 21:08:23,303 INFO L290 TraceCheckUtils]: 67: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:23,303 INFO L284 TraceCheckUtils]: 68: Hoare quadruple {4172#true} {4172#true} #188#return; {4172#true} is VALID [2022-02-20 21:08:23,303 INFO L290 TraceCheckUtils]: 69: Hoare triple {4172#true} assume !(0 != ensure_string_is_allocated_#t~ret543#1 % 256);ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset := 0, 0; {4172#true} is VALID [2022-02-20 21:08:23,304 INFO L290 TraceCheckUtils]: 70: Hoare triple {4172#true} call write~$Pointer$(ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset, ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset, 8);havoc ensure_string_is_allocated_#t~ret543#1;havoc ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset;havoc ensure_string_is_allocated_#t~ret544#1.base, ensure_string_is_allocated_#t~ret544#1.offset;call write~int(ensure_string_is_allocated_~len#1, ensure_string_is_allocated_~str~0#1.base, 8 + ensure_string_is_allocated_~str~0#1.offset, 8);call write~int(0, ensure_string_is_allocated_~str~0#1.base, 16 + ensure_string_is_allocated_~str~0#1.offset + (if ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 else ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset := ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset; {4172#true} is VALID [2022-02-20 21:08:23,304 INFO L290 TraceCheckUtils]: 71: Hoare triple {4172#true} #t~ret541#1.base, #t~ret541#1.offset := ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset;assume { :end_inline_ensure_string_is_allocated } true;#res#1.base, #res#1.offset := #t~ret541#1.base, #t~ret541#1.offset;havoc #t~ret541#1.base, #t~ret541#1.offset; {4172#true} is VALID [2022-02-20 21:08:23,304 INFO L290 TraceCheckUtils]: 72: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:23,307 INFO L284 TraceCheckUtils]: 73: Hoare quadruple {4172#true} {4450#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| 0))} #202#return; {4450#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| 0))} is VALID [2022-02-20 21:08:23,308 INFO L290 TraceCheckUtils]: 74: Hoare triple {4450#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| 0))} aws_hash_callback_string_eq_harness_#t~ite1966#1.base, aws_hash_callback_string_eq_harness_#t~ite1966#1.offset := aws_hash_callback_string_eq_harness_#t~ret1965#1.base, aws_hash_callback_string_eq_harness_#t~ret1965#1.offset; {4450#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| 0))} is VALID [2022-02-20 21:08:23,308 INFO L290 TraceCheckUtils]: 75: Hoare triple {4450#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| 0))} aws_hash_callback_string_eq_harness_~str2~0#1.base, aws_hash_callback_string_eq_harness_~str2~0#1.offset := aws_hash_callback_string_eq_harness_#t~ite1966#1.base, aws_hash_callback_string_eq_harness_#t~ite1966#1.offset;havoc aws_hash_callback_string_eq_harness_#t~ret1964#1;havoc aws_hash_callback_string_eq_harness_#t~ite1966#1.base, aws_hash_callback_string_eq_harness_#t~ite1966#1.offset;havoc aws_hash_callback_string_eq_harness_#t~ret1965#1.base, aws_hash_callback_string_eq_harness_#t~ret1965#1.offset;assume { :begin_inline_aws_hash_callback_string_eq } true;aws_hash_callback_string_eq_#in~a#1.base, aws_hash_callback_string_eq_#in~a#1.offset, aws_hash_callback_string_eq_#in~b#1.base, aws_hash_callback_string_eq_#in~b#1.offset := aws_hash_callback_string_eq_harness_~str1~0#1.base, aws_hash_callback_string_eq_harness_~str1~0#1.offset, aws_hash_callback_string_eq_harness_~str2~0#1.base, aws_hash_callback_string_eq_harness_~str2~0#1.offset;havoc aws_hash_callback_string_eq_#res#1;havoc aws_hash_callback_string_eq_#t~ret1811#1, aws_hash_callback_string_eq_#t~ret1812#1, aws_hash_callback_string_eq_#t~ret1813#1, aws_hash_callback_string_eq_#t~ret1814#1, aws_hash_callback_string_eq_#t~ret1815#1, aws_hash_callback_string_eq_#t~short1816#1, aws_hash_callback_string_eq_~a#1.base, aws_hash_callback_string_eq_~a#1.offset, aws_hash_callback_string_eq_~b#1.base, aws_hash_callback_string_eq_~b#1.offset, aws_hash_callback_string_eq_~rval~20#1;aws_hash_callback_string_eq_~a#1.base, aws_hash_callback_string_eq_~a#1.offset := aws_hash_callback_string_eq_#in~a#1.base, aws_hash_callback_string_eq_#in~a#1.offset;aws_hash_callback_string_eq_~b#1.base, aws_hash_callback_string_eq_~b#1.offset := aws_hash_callback_string_eq_#in~b#1.base, aws_hash_callback_string_eq_#in~b#1.offset; {4571#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} is VALID [2022-02-20 21:08:23,309 INFO L272 TraceCheckUtils]: 76: Hoare triple {4571#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} call aws_hash_callback_string_eq_#t~ret1811#1 := aws_string_is_valid(aws_hash_callback_string_eq_~a#1.base, aws_hash_callback_string_eq_~a#1.offset); {4172#true} is VALID [2022-02-20 21:08:23,309 INFO L290 TraceCheckUtils]: 77: Hoare triple {4172#true} ~str.base, ~str.offset := #in~str.base, #in~str.offset;#t~short464 := ~str.base != 0 || ~str.offset != 0; {4172#true} is VALID [2022-02-20 21:08:23,309 INFO L290 TraceCheckUtils]: 78: Hoare triple {4172#true} assume #t~short464;call #t~mem463 := read~int(~str.base, 8 + ~str.offset, 8);#t~short464 := 0 == (1 + #t~mem463) % 18446744073709551616 || ~str.base != 0 || 16 + ~str.offset != 0; {4172#true} is VALID [2022-02-20 21:08:23,309 INFO L290 TraceCheckUtils]: 79: Hoare triple {4172#true} #t~short467 := #t~short464; {4172#true} is VALID [2022-02-20 21:08:23,309 INFO L290 TraceCheckUtils]: 80: Hoare triple {4172#true} assume #t~short467;call #t~mem465 := read~int(~str.base, 8 + ~str.offset, 8);call #t~mem466 := read~int(~str.base, 16 + ~str.offset + (if #t~mem465 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then #t~mem465 % 18446744073709551616 % 18446744073709551616 else #t~mem465 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);#t~short467 := 0 == #t~mem466 % 256; {4172#true} is VALID [2022-02-20 21:08:23,309 INFO L290 TraceCheckUtils]: 81: Hoare triple {4172#true} #res := (if 0 == (if #t~short467 then 1 else 0) then 0 else 1);havoc #t~mem463;havoc #t~short464;havoc #t~mem465;havoc #t~mem466;havoc #t~short467; {4172#true} is VALID [2022-02-20 21:08:23,309 INFO L290 TraceCheckUtils]: 82: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:23,310 INFO L284 TraceCheckUtils]: 83: Hoare quadruple {4172#true} {4571#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} #204#return; {4571#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} is VALID [2022-02-20 21:08:23,310 INFO L272 TraceCheckUtils]: 84: Hoare triple {4571#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} call assume_abort_if_not(aws_hash_callback_string_eq_#t~ret1811#1); {4172#true} is VALID [2022-02-20 21:08:23,311 INFO L290 TraceCheckUtils]: 85: Hoare triple {4172#true} ~cond := #in~cond; {4172#true} is VALID [2022-02-20 21:08:23,311 INFO L290 TraceCheckUtils]: 86: Hoare triple {4172#true} assume !(0 == ~cond % 256); {4172#true} is VALID [2022-02-20 21:08:23,311 INFO L290 TraceCheckUtils]: 87: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:23,311 INFO L284 TraceCheckUtils]: 88: Hoare quadruple {4172#true} {4571#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} #206#return; {4571#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} is VALID [2022-02-20 21:08:23,312 INFO L290 TraceCheckUtils]: 89: Hoare triple {4571#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} havoc aws_hash_callback_string_eq_#t~ret1811#1; {4571#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} is VALID [2022-02-20 21:08:23,312 INFO L272 TraceCheckUtils]: 90: Hoare triple {4571#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} call aws_hash_callback_string_eq_#t~ret1812#1 := aws_string_is_valid(aws_hash_callback_string_eq_~b#1.base, aws_hash_callback_string_eq_~b#1.offset); {4172#true} is VALID [2022-02-20 21:08:23,312 INFO L290 TraceCheckUtils]: 91: Hoare triple {4172#true} ~str.base, ~str.offset := #in~str.base, #in~str.offset;#t~short464 := ~str.base != 0 || ~str.offset != 0; {4172#true} is VALID [2022-02-20 21:08:23,312 INFO L290 TraceCheckUtils]: 92: Hoare triple {4172#true} assume #t~short464;call #t~mem463 := read~int(~str.base, 8 + ~str.offset, 8);#t~short464 := 0 == (1 + #t~mem463) % 18446744073709551616 || ~str.base != 0 || 16 + ~str.offset != 0; {4172#true} is VALID [2022-02-20 21:08:23,312 INFO L290 TraceCheckUtils]: 93: Hoare triple {4172#true} #t~short467 := #t~short464; {4172#true} is VALID [2022-02-20 21:08:23,313 INFO L290 TraceCheckUtils]: 94: Hoare triple {4172#true} assume #t~short467;call #t~mem465 := read~int(~str.base, 8 + ~str.offset, 8);call #t~mem466 := read~int(~str.base, 16 + ~str.offset + (if #t~mem465 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then #t~mem465 % 18446744073709551616 % 18446744073709551616 else #t~mem465 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);#t~short467 := 0 == #t~mem466 % 256; {4172#true} is VALID [2022-02-20 21:08:23,313 INFO L290 TraceCheckUtils]: 95: Hoare triple {4172#true} #res := (if 0 == (if #t~short467 then 1 else 0) then 0 else 1);havoc #t~mem463;havoc #t~short464;havoc #t~mem465;havoc #t~mem466;havoc #t~short467; {4172#true} is VALID [2022-02-20 21:08:23,313 INFO L290 TraceCheckUtils]: 96: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:23,314 INFO L284 TraceCheckUtils]: 97: Hoare quadruple {4172#true} {4571#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} #208#return; {4571#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} is VALID [2022-02-20 21:08:23,314 INFO L272 TraceCheckUtils]: 98: Hoare triple {4571#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} call assume_abort_if_not(aws_hash_callback_string_eq_#t~ret1812#1); {4172#true} is VALID [2022-02-20 21:08:23,314 INFO L290 TraceCheckUtils]: 99: Hoare triple {4172#true} ~cond := #in~cond; {4172#true} is VALID [2022-02-20 21:08:23,314 INFO L290 TraceCheckUtils]: 100: Hoare triple {4172#true} assume !(0 == ~cond % 256); {4172#true} is VALID [2022-02-20 21:08:23,314 INFO L290 TraceCheckUtils]: 101: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:23,315 INFO L284 TraceCheckUtils]: 102: Hoare quadruple {4172#true} {4571#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} #210#return; {4571#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} is VALID [2022-02-20 21:08:23,315 INFO L290 TraceCheckUtils]: 103: Hoare triple {4571#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} havoc aws_hash_callback_string_eq_#t~ret1812#1;assume { :begin_inline_aws_string_eq } true;aws_string_eq_#in~a#1.base, aws_string_eq_#in~a#1.offset, aws_string_eq_#in~b#1.base, aws_string_eq_#in~b#1.offset := aws_hash_callback_string_eq_~a#1.base, aws_hash_callback_string_eq_~a#1.offset, aws_hash_callback_string_eq_~b#1.base, aws_hash_callback_string_eq_~b#1.offset;havoc aws_string_eq_#res#1;havoc aws_string_eq_#t~ret1893#1, aws_string_eq_#t~short1894#1, aws_string_eq_#t~ret1895#1, aws_string_eq_#t~short1896#1, aws_string_eq_#t~mem1897#1, aws_string_eq_#t~mem1898#1, aws_string_eq_#t~ret1899#1, aws_string_eq_~a#1.base, aws_string_eq_~a#1.offset, aws_string_eq_~b#1.base, aws_string_eq_~b#1.offset;aws_string_eq_~a#1.base, aws_string_eq_~a#1.offset := aws_string_eq_#in~a#1.base, aws_string_eq_#in~a#1.offset;aws_string_eq_~b#1.base, aws_string_eq_~b#1.offset := aws_string_eq_#in~b#1.base, aws_string_eq_#in~b#1.offset;aws_string_eq_#t~short1894#1 := aws_string_eq_~a#1.base == 0 && aws_string_eq_~a#1.offset == 0; {4656#(not |ULTIMATE.start_aws_string_eq_#t~short1894#1|)} is VALID [2022-02-20 21:08:23,316 INFO L290 TraceCheckUtils]: 104: Hoare triple {4656#(not |ULTIMATE.start_aws_string_eq_#t~short1894#1|)} assume aws_string_eq_#t~short1894#1; {4173#false} is VALID [2022-02-20 21:08:23,316 INFO L272 TraceCheckUtils]: 105: Hoare triple {4173#false} call assume_abort_if_not((if 0 == (if aws_string_eq_#t~short1894#1 then 1 else 0) then 0 else 1)); {4173#false} is VALID [2022-02-20 21:08:23,316 INFO L290 TraceCheckUtils]: 106: Hoare triple {4173#false} ~cond := #in~cond; {4173#false} is VALID [2022-02-20 21:08:23,316 INFO L290 TraceCheckUtils]: 107: Hoare triple {4173#false} assume !(0 == ~cond % 256); {4173#false} is VALID [2022-02-20 21:08:23,316 INFO L290 TraceCheckUtils]: 108: Hoare triple {4173#false} assume true; {4173#false} is VALID [2022-02-20 21:08:23,317 INFO L284 TraceCheckUtils]: 109: Hoare quadruple {4173#false} {4173#false} #214#return; {4173#false} is VALID [2022-02-20 21:08:23,317 INFO L290 TraceCheckUtils]: 110: Hoare triple {4173#false} havoc aws_string_eq_#t~ret1893#1;havoc aws_string_eq_#t~short1894#1;aws_string_eq_#t~short1896#1 := aws_string_eq_~b#1.base == 0 && aws_string_eq_~b#1.offset == 0; {4173#false} is VALID [2022-02-20 21:08:23,317 INFO L290 TraceCheckUtils]: 111: Hoare triple {4173#false} assume aws_string_eq_#t~short1896#1; {4173#false} is VALID [2022-02-20 21:08:23,317 INFO L272 TraceCheckUtils]: 112: Hoare triple {4173#false} call assume_abort_if_not((if 0 == (if aws_string_eq_#t~short1896#1 then 1 else 0) then 0 else 1)); {4173#false} is VALID [2022-02-20 21:08:23,317 INFO L290 TraceCheckUtils]: 113: Hoare triple {4173#false} ~cond := #in~cond; {4173#false} is VALID [2022-02-20 21:08:23,317 INFO L290 TraceCheckUtils]: 114: Hoare triple {4173#false} assume !(0 == ~cond % 256); {4173#false} is VALID [2022-02-20 21:08:23,318 INFO L290 TraceCheckUtils]: 115: Hoare triple {4173#false} assume true; {4173#false} is VALID [2022-02-20 21:08:23,318 INFO L284 TraceCheckUtils]: 116: Hoare quadruple {4173#false} {4173#false} #218#return; {4173#false} is VALID [2022-02-20 21:08:23,318 INFO L290 TraceCheckUtils]: 117: Hoare triple {4173#false} havoc aws_string_eq_#t~ret1895#1;havoc aws_string_eq_#t~short1896#1; {4173#false} is VALID [2022-02-20 21:08:23,318 INFO L290 TraceCheckUtils]: 118: Hoare triple {4173#false} assume aws_string_eq_~a#1.base == aws_string_eq_~b#1.base && aws_string_eq_~a#1.offset == aws_string_eq_~b#1.offset;aws_string_eq_#res#1 := 1; {4173#false} is VALID [2022-02-20 21:08:23,318 INFO L290 TraceCheckUtils]: 119: Hoare triple {4173#false} aws_hash_callback_string_eq_#t~ret1813#1 := aws_string_eq_#res#1;assume { :end_inline_aws_string_eq } true;aws_hash_callback_string_eq_~rval~20#1 := aws_hash_callback_string_eq_#t~ret1813#1;havoc aws_hash_callback_string_eq_#t~ret1813#1; {4173#false} is VALID [2022-02-20 21:08:23,318 INFO L272 TraceCheckUtils]: 120: Hoare triple {4173#false} call aws_hash_callback_string_eq_#t~ret1814#1 := aws_c_string_is_valid(aws_hash_callback_string_eq_~a#1.base, aws_hash_callback_string_eq_~a#1.offset); {4173#false} is VALID [2022-02-20 21:08:23,318 INFO L290 TraceCheckUtils]: 121: Hoare triple {4173#false} ~str.base, ~str.offset := #in~str.base, #in~str.offset;#res := (if 0 == (if (~str.base != 0 || ~str.offset != 0) && (~str.base != 0 || ~str.offset != 0) then 1 else 0) then 0 else 1); {4173#false} is VALID [2022-02-20 21:08:23,319 INFO L290 TraceCheckUtils]: 122: Hoare triple {4173#false} assume true; {4173#false} is VALID [2022-02-20 21:08:23,319 INFO L284 TraceCheckUtils]: 123: Hoare quadruple {4173#false} {4173#false} #222#return; {4173#false} is VALID [2022-02-20 21:08:23,319 INFO L290 TraceCheckUtils]: 124: Hoare triple {4173#false} aws_hash_callback_string_eq_#t~short1816#1 := 0 != aws_hash_callback_string_eq_#t~ret1814#1 % 256; {4173#false} is VALID [2022-02-20 21:08:23,319 INFO L290 TraceCheckUtils]: 125: Hoare triple {4173#false} assume !aws_hash_callback_string_eq_#t~short1816#1; {4173#false} is VALID [2022-02-20 21:08:23,319 INFO L272 TraceCheckUtils]: 126: Hoare triple {4173#false} call __VERIFIER_assert((if 0 == (if aws_hash_callback_string_eq_#t~short1816#1 then 1 else 0) then 0 else 1)); {4173#false} is VALID [2022-02-20 21:08:23,319 INFO L290 TraceCheckUtils]: 127: Hoare triple {4173#false} ~cond := #in~cond; {4173#false} is VALID [2022-02-20 21:08:23,320 INFO L290 TraceCheckUtils]: 128: Hoare triple {4173#false} assume 0 == ~cond % 256; {4173#false} is VALID [2022-02-20 21:08:23,320 INFO L290 TraceCheckUtils]: 129: Hoare triple {4173#false} assume !false; {4173#false} is VALID [2022-02-20 21:08:23,320 INFO L134 CoverageAnalysis]: Checked inductivity of 149 backedges. 48 proven. 9 refuted. 0 times theorem prover too weak. 92 trivial. 0 not checked. [2022-02-20 21:08:23,320 INFO L328 TraceCheckSpWp]: Computing backward predicates... [2022-02-20 21:08:23,836 INFO L290 TraceCheckUtils]: 129: Hoare triple {4173#false} assume !false; {4173#false} is VALID [2022-02-20 21:08:23,836 INFO L290 TraceCheckUtils]: 128: Hoare triple {4173#false} assume 0 == ~cond % 256; {4173#false} is VALID [2022-02-20 21:08:23,836 INFO L290 TraceCheckUtils]: 127: Hoare triple {4173#false} ~cond := #in~cond; {4173#false} is VALID [2022-02-20 21:08:23,836 INFO L272 TraceCheckUtils]: 126: Hoare triple {4173#false} call __VERIFIER_assert((if 0 == (if aws_hash_callback_string_eq_#t~short1816#1 then 1 else 0) then 0 else 1)); {4173#false} is VALID [2022-02-20 21:08:23,837 INFO L290 TraceCheckUtils]: 125: Hoare triple {4173#false} assume !aws_hash_callback_string_eq_#t~short1816#1; {4173#false} is VALID [2022-02-20 21:08:23,837 INFO L290 TraceCheckUtils]: 124: Hoare triple {4173#false} aws_hash_callback_string_eq_#t~short1816#1 := 0 != aws_hash_callback_string_eq_#t~ret1814#1 % 256; {4173#false} is VALID [2022-02-20 21:08:23,837 INFO L284 TraceCheckUtils]: 123: Hoare quadruple {4172#true} {4173#false} #222#return; {4173#false} is VALID [2022-02-20 21:08:23,837 INFO L290 TraceCheckUtils]: 122: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:23,837 INFO L290 TraceCheckUtils]: 121: Hoare triple {4172#true} ~str.base, ~str.offset := #in~str.base, #in~str.offset;#res := (if 0 == (if (~str.base != 0 || ~str.offset != 0) && (~str.base != 0 || ~str.offset != 0) then 1 else 0) then 0 else 1); {4172#true} is VALID [2022-02-20 21:08:23,837 INFO L272 TraceCheckUtils]: 120: Hoare triple {4173#false} call aws_hash_callback_string_eq_#t~ret1814#1 := aws_c_string_is_valid(aws_hash_callback_string_eq_~a#1.base, aws_hash_callback_string_eq_~a#1.offset); {4172#true} is VALID [2022-02-20 21:08:23,837 INFO L290 TraceCheckUtils]: 119: Hoare triple {4173#false} aws_hash_callback_string_eq_#t~ret1813#1 := aws_string_eq_#res#1;assume { :end_inline_aws_string_eq } true;aws_hash_callback_string_eq_~rval~20#1 := aws_hash_callback_string_eq_#t~ret1813#1;havoc aws_hash_callback_string_eq_#t~ret1813#1; {4173#false} is VALID [2022-02-20 21:08:23,837 INFO L290 TraceCheckUtils]: 118: Hoare triple {4173#false} assume aws_string_eq_~a#1.base == aws_string_eq_~b#1.base && aws_string_eq_~a#1.offset == aws_string_eq_~b#1.offset;aws_string_eq_#res#1 := 1; {4173#false} is VALID [2022-02-20 21:08:23,837 INFO L290 TraceCheckUtils]: 117: Hoare triple {4173#false} havoc aws_string_eq_#t~ret1895#1;havoc aws_string_eq_#t~short1896#1; {4173#false} is VALID [2022-02-20 21:08:23,838 INFO L284 TraceCheckUtils]: 116: Hoare quadruple {4172#true} {4173#false} #218#return; {4173#false} is VALID [2022-02-20 21:08:23,838 INFO L290 TraceCheckUtils]: 115: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:23,838 INFO L290 TraceCheckUtils]: 114: Hoare triple {4172#true} assume !(0 == ~cond % 256); {4172#true} is VALID [2022-02-20 21:08:23,838 INFO L290 TraceCheckUtils]: 113: Hoare triple {4172#true} ~cond := #in~cond; {4172#true} is VALID [2022-02-20 21:08:23,838 INFO L272 TraceCheckUtils]: 112: Hoare triple {4173#false} call assume_abort_if_not((if 0 == (if aws_string_eq_#t~short1896#1 then 1 else 0) then 0 else 1)); {4172#true} is VALID [2022-02-20 21:08:23,838 INFO L290 TraceCheckUtils]: 111: Hoare triple {4173#false} assume aws_string_eq_#t~short1896#1; {4173#false} is VALID [2022-02-20 21:08:23,838 INFO L290 TraceCheckUtils]: 110: Hoare triple {4173#false} havoc aws_string_eq_#t~ret1893#1;havoc aws_string_eq_#t~short1894#1;aws_string_eq_#t~short1896#1 := aws_string_eq_~b#1.base == 0 && aws_string_eq_~b#1.offset == 0; {4173#false} is VALID [2022-02-20 21:08:23,838 INFO L284 TraceCheckUtils]: 109: Hoare quadruple {4172#true} {4173#false} #214#return; {4173#false} is VALID [2022-02-20 21:08:23,838 INFO L290 TraceCheckUtils]: 108: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:23,838 INFO L290 TraceCheckUtils]: 107: Hoare triple {4172#true} assume !(0 == ~cond % 256); {4172#true} is VALID [2022-02-20 21:08:23,839 INFO L290 TraceCheckUtils]: 106: Hoare triple {4172#true} ~cond := #in~cond; {4172#true} is VALID [2022-02-20 21:08:23,839 INFO L272 TraceCheckUtils]: 105: Hoare triple {4173#false} call assume_abort_if_not((if 0 == (if aws_string_eq_#t~short1894#1 then 1 else 0) then 0 else 1)); {4172#true} is VALID [2022-02-20 21:08:23,843 INFO L290 TraceCheckUtils]: 104: Hoare triple {4656#(not |ULTIMATE.start_aws_string_eq_#t~short1894#1|)} assume aws_string_eq_#t~short1894#1; {4173#false} is VALID [2022-02-20 21:08:23,844 INFO L290 TraceCheckUtils]: 103: Hoare triple {4571#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} havoc aws_hash_callback_string_eq_#t~ret1812#1;assume { :begin_inline_aws_string_eq } true;aws_string_eq_#in~a#1.base, aws_string_eq_#in~a#1.offset, aws_string_eq_#in~b#1.base, aws_string_eq_#in~b#1.offset := aws_hash_callback_string_eq_~a#1.base, aws_hash_callback_string_eq_~a#1.offset, aws_hash_callback_string_eq_~b#1.base, aws_hash_callback_string_eq_~b#1.offset;havoc aws_string_eq_#res#1;havoc aws_string_eq_#t~ret1893#1, aws_string_eq_#t~short1894#1, aws_string_eq_#t~ret1895#1, aws_string_eq_#t~short1896#1, aws_string_eq_#t~mem1897#1, aws_string_eq_#t~mem1898#1, aws_string_eq_#t~ret1899#1, aws_string_eq_~a#1.base, aws_string_eq_~a#1.offset, aws_string_eq_~b#1.base, aws_string_eq_~b#1.offset;aws_string_eq_~a#1.base, aws_string_eq_~a#1.offset := aws_string_eq_#in~a#1.base, aws_string_eq_#in~a#1.offset;aws_string_eq_~b#1.base, aws_string_eq_~b#1.offset := aws_string_eq_#in~b#1.base, aws_string_eq_#in~b#1.offset;aws_string_eq_#t~short1894#1 := aws_string_eq_~a#1.base == 0 && aws_string_eq_~a#1.offset == 0; {4656#(not |ULTIMATE.start_aws_string_eq_#t~short1894#1|)} is VALID [2022-02-20 21:08:23,845 INFO L284 TraceCheckUtils]: 102: Hoare quadruple {4172#true} {4571#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} #210#return; {4571#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} is VALID [2022-02-20 21:08:23,845 INFO L290 TraceCheckUtils]: 101: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:23,845 INFO L290 TraceCheckUtils]: 100: Hoare triple {4172#true} assume !(0 == ~cond % 256); {4172#true} is VALID [2022-02-20 21:08:23,845 INFO L290 TraceCheckUtils]: 99: Hoare triple {4172#true} ~cond := #in~cond; {4172#true} is VALID [2022-02-20 21:08:23,845 INFO L272 TraceCheckUtils]: 98: Hoare triple {4571#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} call assume_abort_if_not(aws_hash_callback_string_eq_#t~ret1812#1); {4172#true} is VALID [2022-02-20 21:08:23,846 INFO L284 TraceCheckUtils]: 97: Hoare quadruple {4172#true} {4571#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} #208#return; {4571#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} is VALID [2022-02-20 21:08:23,846 INFO L290 TraceCheckUtils]: 96: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:23,859 INFO L290 TraceCheckUtils]: 95: Hoare triple {4172#true} #res := (if 0 == (if #t~short467 then 1 else 0) then 0 else 1);havoc #t~mem463;havoc #t~short464;havoc #t~mem465;havoc #t~mem466;havoc #t~short467; {4172#true} is VALID [2022-02-20 21:08:23,859 INFO L290 TraceCheckUtils]: 94: Hoare triple {4172#true} assume #t~short467;call #t~mem465 := read~int(~str.base, 8 + ~str.offset, 8);call #t~mem466 := read~int(~str.base, 16 + ~str.offset + (if #t~mem465 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then #t~mem465 % 18446744073709551616 % 18446744073709551616 else #t~mem465 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);#t~short467 := 0 == #t~mem466 % 256; {4172#true} is VALID [2022-02-20 21:08:23,862 INFO L290 TraceCheckUtils]: 93: Hoare triple {4172#true} #t~short467 := #t~short464; {4172#true} is VALID [2022-02-20 21:08:23,862 INFO L290 TraceCheckUtils]: 92: Hoare triple {4172#true} assume #t~short464;call #t~mem463 := read~int(~str.base, 8 + ~str.offset, 8);#t~short464 := 0 == (1 + #t~mem463) % 18446744073709551616 || ~str.base != 0 || 16 + ~str.offset != 0; {4172#true} is VALID [2022-02-20 21:08:23,862 INFO L290 TraceCheckUtils]: 91: Hoare triple {4172#true} ~str.base, ~str.offset := #in~str.base, #in~str.offset;#t~short464 := ~str.base != 0 || ~str.offset != 0; {4172#true} is VALID [2022-02-20 21:08:23,862 INFO L272 TraceCheckUtils]: 90: Hoare triple {4571#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} call aws_hash_callback_string_eq_#t~ret1812#1 := aws_string_is_valid(aws_hash_callback_string_eq_~b#1.base, aws_hash_callback_string_eq_~b#1.offset); {4172#true} is VALID [2022-02-20 21:08:23,863 INFO L290 TraceCheckUtils]: 89: Hoare triple {4571#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} havoc aws_hash_callback_string_eq_#t~ret1811#1; {4571#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} is VALID [2022-02-20 21:08:23,863 INFO L284 TraceCheckUtils]: 88: Hoare quadruple {4172#true} {4571#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} #206#return; {4571#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} is VALID [2022-02-20 21:08:23,864 INFO L290 TraceCheckUtils]: 87: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:23,864 INFO L290 TraceCheckUtils]: 86: Hoare triple {4172#true} assume !(0 == ~cond % 256); {4172#true} is VALID [2022-02-20 21:08:23,864 INFO L290 TraceCheckUtils]: 85: Hoare triple {4172#true} ~cond := #in~cond; {4172#true} is VALID [2022-02-20 21:08:23,864 INFO L272 TraceCheckUtils]: 84: Hoare triple {4571#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} call assume_abort_if_not(aws_hash_callback_string_eq_#t~ret1811#1); {4172#true} is VALID [2022-02-20 21:08:23,865 INFO L284 TraceCheckUtils]: 83: Hoare quadruple {4172#true} {4571#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} #204#return; {4571#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} is VALID [2022-02-20 21:08:23,865 INFO L290 TraceCheckUtils]: 82: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:23,865 INFO L290 TraceCheckUtils]: 81: Hoare triple {4172#true} #res := (if 0 == (if #t~short467 then 1 else 0) then 0 else 1);havoc #t~mem463;havoc #t~short464;havoc #t~mem465;havoc #t~mem466;havoc #t~short467; {4172#true} is VALID [2022-02-20 21:08:23,865 INFO L290 TraceCheckUtils]: 80: Hoare triple {4172#true} assume #t~short467;call #t~mem465 := read~int(~str.base, 8 + ~str.offset, 8);call #t~mem466 := read~int(~str.base, 16 + ~str.offset + (if #t~mem465 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then #t~mem465 % 18446744073709551616 % 18446744073709551616 else #t~mem465 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);#t~short467 := 0 == #t~mem466 % 256; {4172#true} is VALID [2022-02-20 21:08:23,867 INFO L290 TraceCheckUtils]: 79: Hoare triple {4172#true} #t~short467 := #t~short464; {4172#true} is VALID [2022-02-20 21:08:23,867 INFO L290 TraceCheckUtils]: 78: Hoare triple {4172#true} assume #t~short464;call #t~mem463 := read~int(~str.base, 8 + ~str.offset, 8);#t~short464 := 0 == (1 + #t~mem463) % 18446744073709551616 || ~str.base != 0 || 16 + ~str.offset != 0; {4172#true} is VALID [2022-02-20 21:08:23,867 INFO L290 TraceCheckUtils]: 77: Hoare triple {4172#true} ~str.base, ~str.offset := #in~str.base, #in~str.offset;#t~short464 := ~str.base != 0 || ~str.offset != 0; {4172#true} is VALID [2022-02-20 21:08:23,867 INFO L272 TraceCheckUtils]: 76: Hoare triple {4571#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} call aws_hash_callback_string_eq_#t~ret1811#1 := aws_string_is_valid(aws_hash_callback_string_eq_~a#1.base, aws_hash_callback_string_eq_~a#1.offset); {4172#true} is VALID [2022-02-20 21:08:23,868 INFO L290 TraceCheckUtils]: 75: Hoare triple {4450#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| 0))} aws_hash_callback_string_eq_harness_~str2~0#1.base, aws_hash_callback_string_eq_harness_~str2~0#1.offset := aws_hash_callback_string_eq_harness_#t~ite1966#1.base, aws_hash_callback_string_eq_harness_#t~ite1966#1.offset;havoc aws_hash_callback_string_eq_harness_#t~ret1964#1;havoc aws_hash_callback_string_eq_harness_#t~ite1966#1.base, aws_hash_callback_string_eq_harness_#t~ite1966#1.offset;havoc aws_hash_callback_string_eq_harness_#t~ret1965#1.base, aws_hash_callback_string_eq_harness_#t~ret1965#1.offset;assume { :begin_inline_aws_hash_callback_string_eq } true;aws_hash_callback_string_eq_#in~a#1.base, aws_hash_callback_string_eq_#in~a#1.offset, aws_hash_callback_string_eq_#in~b#1.base, aws_hash_callback_string_eq_#in~b#1.offset := aws_hash_callback_string_eq_harness_~str1~0#1.base, aws_hash_callback_string_eq_harness_~str1~0#1.offset, aws_hash_callback_string_eq_harness_~str2~0#1.base, aws_hash_callback_string_eq_harness_~str2~0#1.offset;havoc aws_hash_callback_string_eq_#res#1;havoc aws_hash_callback_string_eq_#t~ret1811#1, aws_hash_callback_string_eq_#t~ret1812#1, aws_hash_callback_string_eq_#t~ret1813#1, aws_hash_callback_string_eq_#t~ret1814#1, aws_hash_callback_string_eq_#t~ret1815#1, aws_hash_callback_string_eq_#t~short1816#1, aws_hash_callback_string_eq_~a#1.base, aws_hash_callback_string_eq_~a#1.offset, aws_hash_callback_string_eq_~b#1.base, aws_hash_callback_string_eq_~b#1.offset, aws_hash_callback_string_eq_~rval~20#1;aws_hash_callback_string_eq_~a#1.base, aws_hash_callback_string_eq_~a#1.offset := aws_hash_callback_string_eq_#in~a#1.base, aws_hash_callback_string_eq_#in~a#1.offset;aws_hash_callback_string_eq_~b#1.base, aws_hash_callback_string_eq_~b#1.offset := aws_hash_callback_string_eq_#in~b#1.base, aws_hash_callback_string_eq_#in~b#1.offset; {4571#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_~a#1.base| 0))} is VALID [2022-02-20 21:08:23,868 INFO L290 TraceCheckUtils]: 74: Hoare triple {4450#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| 0))} aws_hash_callback_string_eq_harness_#t~ite1966#1.base, aws_hash_callback_string_eq_harness_#t~ite1966#1.offset := aws_hash_callback_string_eq_harness_#t~ret1965#1.base, aws_hash_callback_string_eq_harness_#t~ret1965#1.offset; {4450#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| 0))} is VALID [2022-02-20 21:08:23,869 INFO L284 TraceCheckUtils]: 73: Hoare quadruple {4172#true} {4450#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| 0))} #202#return; {4450#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| 0))} is VALID [2022-02-20 21:08:23,873 INFO L290 TraceCheckUtils]: 72: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:23,873 INFO L290 TraceCheckUtils]: 71: Hoare triple {4172#true} #t~ret541#1.base, #t~ret541#1.offset := ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset;assume { :end_inline_ensure_string_is_allocated } true;#res#1.base, #res#1.offset := #t~ret541#1.base, #t~ret541#1.offset;havoc #t~ret541#1.base, #t~ret541#1.offset; {4172#true} is VALID [2022-02-20 21:08:23,873 INFO L290 TraceCheckUtils]: 70: Hoare triple {4172#true} call write~$Pointer$(ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset, ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset, 8);havoc ensure_string_is_allocated_#t~ret543#1;havoc ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset;havoc ensure_string_is_allocated_#t~ret544#1.base, ensure_string_is_allocated_#t~ret544#1.offset;call write~int(ensure_string_is_allocated_~len#1, ensure_string_is_allocated_~str~0#1.base, 8 + ensure_string_is_allocated_~str~0#1.offset, 8);call write~int(0, ensure_string_is_allocated_~str~0#1.base, 16 + ensure_string_is_allocated_~str~0#1.offset + (if ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 else ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset := ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset; {4172#true} is VALID [2022-02-20 21:08:23,873 INFO L290 TraceCheckUtils]: 69: Hoare triple {4172#true} assume !(0 != ensure_string_is_allocated_#t~ret543#1 % 256);ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset := 0, 0; {4172#true} is VALID [2022-02-20 21:08:23,873 INFO L284 TraceCheckUtils]: 68: Hoare quadruple {4172#true} {4172#true} #188#return; {4172#true} is VALID [2022-02-20 21:08:23,873 INFO L290 TraceCheckUtils]: 67: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:23,874 INFO L290 TraceCheckUtils]: 66: Hoare triple {4172#true} #res := #t~nondet8;havoc #t~nondet8; {4172#true} is VALID [2022-02-20 21:08:23,874 INFO L272 TraceCheckUtils]: 65: Hoare triple {4172#true} call ensure_string_is_allocated_#t~ret543#1 := nondet_bool(); {4172#true} is VALID [2022-02-20 21:08:23,874 INFO L290 TraceCheckUtils]: 64: Hoare triple {4172#true} ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset := ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset;havoc ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset; {4172#true} is VALID [2022-02-20 21:08:23,874 INFO L284 TraceCheckUtils]: 63: Hoare quadruple {4172#true} {4172#true} #186#return; {4172#true} is VALID [2022-02-20 21:08:23,874 INFO L290 TraceCheckUtils]: 62: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:23,874 INFO L290 TraceCheckUtils]: 61: Hoare triple {4172#true} call #t~malloc555.base, #t~malloc555.offset := #Ultimate.allocOnHeap(~size);#res.base, #res.offset := #t~malloc555.base, #t~malloc555.offset;havoc #t~malloc555.base, #t~malloc555.offset; {4172#true} is VALID [2022-02-20 21:08:23,875 INFO L284 TraceCheckUtils]: 60: Hoare quadruple {4172#true} {4172#true} #192#return; {4172#true} is VALID [2022-02-20 21:08:23,875 INFO L290 TraceCheckUtils]: 59: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:23,875 INFO L290 TraceCheckUtils]: 58: Hoare triple {4172#true} assume !(0 == ~cond % 256); {4172#true} is VALID [2022-02-20 21:08:23,875 INFO L290 TraceCheckUtils]: 57: Hoare triple {4172#true} ~cond := #in~cond; {4172#true} is VALID [2022-02-20 21:08:23,875 INFO L272 TraceCheckUtils]: 56: Hoare triple {4172#true} call assume_abort_if_not((if 0 == (if ~size % 18446744073709551616 <= 36028797018963967 then 1 else 0) then 0 else 1)); {4172#true} is VALID [2022-02-20 21:08:23,875 INFO L290 TraceCheckUtils]: 55: Hoare triple {4172#true} ~size := #in~size; {4172#true} is VALID [2022-02-20 21:08:23,875 INFO L272 TraceCheckUtils]: 54: Hoare triple {4172#true} call ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset := bounded_malloc(-1234550 + ensure_string_is_allocated_~len#1); {4172#true} is VALID [2022-02-20 21:08:23,876 INFO L290 TraceCheckUtils]: 53: Hoare triple {4172#true} assume { :begin_inline_ensure_string_is_allocated } true;ensure_string_is_allocated_#in~len#1 := ~len~1#1;havoc ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset;havoc ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset, ensure_string_is_allocated_#t~ret543#1, ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset, ensure_string_is_allocated_#t~ret544#1.base, ensure_string_is_allocated_#t~ret544#1.offset, ensure_string_is_allocated_~len#1, ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset;ensure_string_is_allocated_~len#1 := ensure_string_is_allocated_#in~len#1; {4172#true} is VALID [2022-02-20 21:08:23,876 INFO L284 TraceCheckUtils]: 52: Hoare quadruple {4172#true} {4172#true} #184#return; {4172#true} is VALID [2022-02-20 21:08:23,876 INFO L290 TraceCheckUtils]: 51: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:23,876 INFO L290 TraceCheckUtils]: 50: Hoare triple {4172#true} assume !(0 == ~cond % 256); {4172#true} is VALID [2022-02-20 21:08:23,876 INFO L290 TraceCheckUtils]: 49: Hoare triple {4172#true} ~cond := #in~cond; {4172#true} is VALID [2022-02-20 21:08:23,876 INFO L272 TraceCheckUtils]: 48: Hoare triple {4172#true} call assume_abort_if_not((if 0 == (if ~len~1#1 % 18446744073709551616 < ~max_size#1 % 18446744073709551616 then 1 else 0) then 0 else 1)); {4172#true} is VALID [2022-02-20 21:08:23,877 INFO L290 TraceCheckUtils]: 47: Hoare triple {4172#true} ~len~1#1 := #t~ret540#1;havoc #t~ret540#1; {4172#true} is VALID [2022-02-20 21:08:23,877 INFO L284 TraceCheckUtils]: 46: Hoare quadruple {4172#true} {4172#true} #182#return; {4172#true} is VALID [2022-02-20 21:08:23,879 INFO L290 TraceCheckUtils]: 45: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:23,879 INFO L290 TraceCheckUtils]: 44: Hoare triple {4172#true} #res := #t~nondet13;havoc #t~nondet13; {4172#true} is VALID [2022-02-20 21:08:23,879 INFO L272 TraceCheckUtils]: 43: Hoare triple {4172#true} call #t~ret540#1 := nondet_uint64_t(); {4172#true} is VALID [2022-02-20 21:08:23,879 INFO L290 TraceCheckUtils]: 42: Hoare triple {4172#true} ~max_size#1 := #in~max_size#1; {4172#true} is VALID [2022-02-20 21:08:23,879 INFO L272 TraceCheckUtils]: 41: Hoare triple {4450#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| 0))} call aws_hash_callback_string_eq_harness_#t~ret1965#1.base, aws_hash_callback_string_eq_harness_#t~ret1965#1.offset := ensure_string_is_allocated_bounded_length(96); {4172#true} is VALID [2022-02-20 21:08:23,880 INFO L290 TraceCheckUtils]: 40: Hoare triple {4450#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| 0))} assume !(0 != aws_hash_callback_string_eq_harness_#t~ret1964#1 % 256); {4450#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| 0))} is VALID [2022-02-20 21:08:23,880 INFO L284 TraceCheckUtils]: 39: Hoare quadruple {4172#true} {4450#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| 0))} #200#return; {4450#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| 0))} is VALID [2022-02-20 21:08:23,881 INFO L290 TraceCheckUtils]: 38: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:23,881 INFO L290 TraceCheckUtils]: 37: Hoare triple {4172#true} #res := #t~nondet8;havoc #t~nondet8; {4172#true} is VALID [2022-02-20 21:08:23,881 INFO L272 TraceCheckUtils]: 36: Hoare triple {4450#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| 0))} call aws_hash_callback_string_eq_harness_#t~ret1964#1 := nondet_bool(); {4172#true} is VALID [2022-02-20 21:08:23,881 INFO L290 TraceCheckUtils]: 35: Hoare triple {4446#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_#t~ret1963#1.base| 0))} aws_hash_callback_string_eq_harness_~str1~0#1.base, aws_hash_callback_string_eq_harness_~str1~0#1.offset := aws_hash_callback_string_eq_harness_#t~ret1963#1.base, aws_hash_callback_string_eq_harness_#t~ret1963#1.offset;havoc aws_hash_callback_string_eq_harness_#t~ret1963#1.base, aws_hash_callback_string_eq_harness_#t~ret1963#1.offset; {4450#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_~str1~0#1.base| 0))} is VALID [2022-02-20 21:08:23,883 INFO L284 TraceCheckUtils]: 34: Hoare quadruple {4439#(not (= |ensure_string_is_allocated_bounded_length_#res#1.base| 0))} {4172#true} #198#return; {4446#(not (= |ULTIMATE.start_aws_hash_callback_string_eq_harness_#t~ret1963#1.base| 0))} is VALID [2022-02-20 21:08:23,883 INFO L290 TraceCheckUtils]: 33: Hoare triple {4439#(not (= |ensure_string_is_allocated_bounded_length_#res#1.base| 0))} assume true; {4439#(not (= |ensure_string_is_allocated_bounded_length_#res#1.base| 0))} is VALID [2022-02-20 21:08:23,884 INFO L290 TraceCheckUtils]: 32: Hoare triple {4435#(not (= |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_#res#1.base| 0))} #t~ret541#1.base, #t~ret541#1.offset := ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset;assume { :end_inline_ensure_string_is_allocated } true;#res#1.base, #res#1.offset := #t~ret541#1.base, #t~ret541#1.offset;havoc #t~ret541#1.base, #t~ret541#1.offset; {4439#(not (= |ensure_string_is_allocated_bounded_length_#res#1.base| 0))} is VALID [2022-02-20 21:08:23,885 INFO L290 TraceCheckUtils]: 31: Hoare triple {4416#(not (= |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~str~0#1.base| 0))} call write~$Pointer$(ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset, ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset, 8);havoc ensure_string_is_allocated_#t~ret543#1;havoc ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset;havoc ensure_string_is_allocated_#t~ret544#1.base, ensure_string_is_allocated_#t~ret544#1.offset;call write~int(ensure_string_is_allocated_~len#1, ensure_string_is_allocated_~str~0#1.base, 8 + ensure_string_is_allocated_~str~0#1.offset, 8);call write~int(0, ensure_string_is_allocated_~str~0#1.base, 16 + ensure_string_is_allocated_~str~0#1.offset + (if ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 else ensure_string_is_allocated_~len#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 1);ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset := ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset; {4435#(not (= |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_#res#1.base| 0))} is VALID [2022-02-20 21:08:23,885 INFO L290 TraceCheckUtils]: 30: Hoare triple {4416#(not (= |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~str~0#1.base| 0))} assume !(0 != ensure_string_is_allocated_#t~ret543#1 % 256);ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset := 0, 0; {4416#(not (= |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~str~0#1.base| 0))} is VALID [2022-02-20 21:08:23,886 INFO L284 TraceCheckUtils]: 29: Hoare quadruple {4172#true} {4416#(not (= |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~str~0#1.base| 0))} #188#return; {4416#(not (= |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~str~0#1.base| 0))} is VALID [2022-02-20 21:08:23,886 INFO L290 TraceCheckUtils]: 28: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:23,886 INFO L290 TraceCheckUtils]: 27: Hoare triple {4172#true} #res := #t~nondet8;havoc #t~nondet8; {4172#true} is VALID [2022-02-20 21:08:23,886 INFO L272 TraceCheckUtils]: 26: Hoare triple {4416#(not (= |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~str~0#1.base| 0))} call ensure_string_is_allocated_#t~ret543#1 := nondet_bool(); {4172#true} is VALID [2022-02-20 21:08:23,887 INFO L290 TraceCheckUtils]: 25: Hoare triple {4412#(not (= |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_#t~ret542#1.base| 0))} ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset := ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset;havoc ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset; {4416#(not (= |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~str~0#1.base| 0))} is VALID [2022-02-20 21:08:23,887 INFO L284 TraceCheckUtils]: 24: Hoare quadruple {4405#(not (= |bounded_malloc_#res.base| 0))} {4172#true} #186#return; {4412#(not (= |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_#t~ret542#1.base| 0))} is VALID [2022-02-20 21:08:23,889 INFO L290 TraceCheckUtils]: 23: Hoare triple {4405#(not (= |bounded_malloc_#res.base| 0))} assume true; {4405#(not (= |bounded_malloc_#res.base| 0))} is VALID [2022-02-20 21:08:23,889 INFO L290 TraceCheckUtils]: 22: Hoare triple {4172#true} call #t~malloc555.base, #t~malloc555.offset := #Ultimate.allocOnHeap(~size);#res.base, #res.offset := #t~malloc555.base, #t~malloc555.offset;havoc #t~malloc555.base, #t~malloc555.offset; {4405#(not (= |bounded_malloc_#res.base| 0))} is VALID [2022-02-20 21:08:23,889 INFO L284 TraceCheckUtils]: 21: Hoare quadruple {4172#true} {4172#true} #192#return; {4172#true} is VALID [2022-02-20 21:08:23,889 INFO L290 TraceCheckUtils]: 20: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:23,889 INFO L290 TraceCheckUtils]: 19: Hoare triple {4172#true} assume !(0 == ~cond % 256); {4172#true} is VALID [2022-02-20 21:08:23,890 INFO L290 TraceCheckUtils]: 18: Hoare triple {4172#true} ~cond := #in~cond; {4172#true} is VALID [2022-02-20 21:08:23,890 INFO L272 TraceCheckUtils]: 17: Hoare triple {4172#true} call assume_abort_if_not((if 0 == (if ~size % 18446744073709551616 <= 36028797018963967 then 1 else 0) then 0 else 1)); {4172#true} is VALID [2022-02-20 21:08:23,890 INFO L290 TraceCheckUtils]: 16: Hoare triple {4172#true} ~size := #in~size; {4172#true} is VALID [2022-02-20 21:08:23,890 INFO L272 TraceCheckUtils]: 15: Hoare triple {4172#true} call ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset := bounded_malloc(-1234550 + ensure_string_is_allocated_~len#1); {4172#true} is VALID [2022-02-20 21:08:23,890 INFO L290 TraceCheckUtils]: 14: Hoare triple {4172#true} assume { :begin_inline_ensure_string_is_allocated } true;ensure_string_is_allocated_#in~len#1 := ~len~1#1;havoc ensure_string_is_allocated_#res#1.base, ensure_string_is_allocated_#res#1.offset;havoc ensure_string_is_allocated_#t~ret542#1.base, ensure_string_is_allocated_#t~ret542#1.offset, ensure_string_is_allocated_#t~ret543#1, ensure_string_is_allocated_#t~ite545#1.base, ensure_string_is_allocated_#t~ite545#1.offset, ensure_string_is_allocated_#t~ret544#1.base, ensure_string_is_allocated_#t~ret544#1.offset, ensure_string_is_allocated_~len#1, ensure_string_is_allocated_~str~0#1.base, ensure_string_is_allocated_~str~0#1.offset;ensure_string_is_allocated_~len#1 := ensure_string_is_allocated_#in~len#1; {4172#true} is VALID [2022-02-20 21:08:23,890 INFO L284 TraceCheckUtils]: 13: Hoare quadruple {4172#true} {4172#true} #184#return; {4172#true} is VALID [2022-02-20 21:08:23,891 INFO L290 TraceCheckUtils]: 12: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:23,891 INFO L290 TraceCheckUtils]: 11: Hoare triple {4172#true} assume !(0 == ~cond % 256); {4172#true} is VALID [2022-02-20 21:08:23,891 INFO L290 TraceCheckUtils]: 10: Hoare triple {4172#true} ~cond := #in~cond; {4172#true} is VALID [2022-02-20 21:08:23,891 INFO L272 TraceCheckUtils]: 9: Hoare triple {4172#true} call assume_abort_if_not((if 0 == (if ~len~1#1 % 18446744073709551616 < ~max_size#1 % 18446744073709551616 then 1 else 0) then 0 else 1)); {4172#true} is VALID [2022-02-20 21:08:23,891 INFO L290 TraceCheckUtils]: 8: Hoare triple {4172#true} ~len~1#1 := #t~ret540#1;havoc #t~ret540#1; {4172#true} is VALID [2022-02-20 21:08:23,891 INFO L284 TraceCheckUtils]: 7: Hoare quadruple {4172#true} {4172#true} #182#return; {4172#true} is VALID [2022-02-20 21:08:23,891 INFO L290 TraceCheckUtils]: 6: Hoare triple {4172#true} assume true; {4172#true} is VALID [2022-02-20 21:08:23,892 INFO L290 TraceCheckUtils]: 5: Hoare triple {4172#true} #res := #t~nondet13;havoc #t~nondet13; {4172#true} is VALID [2022-02-20 21:08:23,892 INFO L272 TraceCheckUtils]: 4: Hoare triple {4172#true} call #t~ret540#1 := nondet_uint64_t(); {4172#true} is VALID [2022-02-20 21:08:23,892 INFO L290 TraceCheckUtils]: 3: Hoare triple {4172#true} ~max_size#1 := #in~max_size#1; {4172#true} is VALID [2022-02-20 21:08:23,892 INFO L272 TraceCheckUtils]: 2: Hoare triple {4172#true} call aws_hash_callback_string_eq_harness_#t~ret1963#1.base, aws_hash_callback_string_eq_harness_#t~ret1963#1.offset := ensure_string_is_allocated_bounded_length(96); {4172#true} is VALID [2022-02-20 21:08:23,892 INFO L290 TraceCheckUtils]: 1: Hoare triple {4172#true} assume { :end_inline_ULTIMATE.init } true;assume { :begin_inline_main } true;havoc main_#res#1;assume { :begin_inline_aws_hash_callback_string_eq_harness } true;havoc aws_hash_callback_string_eq_harness_#t~ret1963#1.base, aws_hash_callback_string_eq_harness_#t~ret1963#1.offset, aws_hash_callback_string_eq_harness_#t~ret1964#1, aws_hash_callback_string_eq_harness_#t~ite1966#1.base, aws_hash_callback_string_eq_harness_#t~ite1966#1.offset, aws_hash_callback_string_eq_harness_#t~ret1965#1.base, aws_hash_callback_string_eq_harness_#t~ret1965#1.offset, aws_hash_callback_string_eq_harness_#t~ret1967#1, aws_hash_callback_string_eq_harness_#t~mem1968#1, aws_hash_callback_string_eq_harness_#t~mem1969#1, aws_hash_callback_string_eq_harness_#t~mem1970#1, aws_hash_callback_string_eq_harness_~str1~0#1.base, aws_hash_callback_string_eq_harness_~str1~0#1.offset, aws_hash_callback_string_eq_harness_~str2~0#1.base, aws_hash_callback_string_eq_harness_~str2~0#1.offset, aws_hash_callback_string_eq_harness_~rval~21#1; {4172#true} is VALID [2022-02-20 21:08:23,892 INFO L290 TraceCheckUtils]: 0: Hoare triple {4172#true} assume { :begin_inline_ULTIMATE.init } true;#NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(38, 2);call #Ultimate.allocInit(12, 3);call #Ultimate.allocInit(78, 4);~#s_can_fail_allocator_static~0.base, ~#s_can_fail_allocator_static~0.offset := 5, 0;call #Ultimate.allocInit(40, 5);call write~init~$Pointer$(#funAddr~s_can_fail_malloc_allocator.base, #funAddr~s_can_fail_malloc_allocator.offset, ~#s_can_fail_allocator_static~0.base, ~#s_can_fail_allocator_static~0.offset, 8);call write~init~$Pointer$(#funAddr~s_can_fail_free_allocator.base, #funAddr~s_can_fail_free_allocator.offset, ~#s_can_fail_allocator_static~0.base, 8 + ~#s_can_fail_allocator_static~0.offset, 8);call write~init~$Pointer$(#funAddr~s_can_fail_realloc_allocator.base, #funAddr~s_can_fail_realloc_allocator.offset, ~#s_can_fail_allocator_static~0.base, 16 + ~#s_can_fail_allocator_static~0.offset, 8);call write~init~$Pointer$(#funAddr~s_can_fail_calloc_allocator.base, #funAddr~s_can_fail_calloc_allocator.offset, ~#s_can_fail_allocator_static~0.base, 24 + ~#s_can_fail_allocator_static~0.offset, 8);call write~init~$Pointer$(0, 0, ~#s_can_fail_allocator_static~0.base, 32 + ~#s_can_fail_allocator_static~0.offset, 8);~#s_tolower_table~0.base, ~#s_tolower_table~0.offset := 6, 0;call #Ultimate.allocInit(256, 6);call write~init~int(0, ~#s_tolower_table~0.base, ~#s_tolower_table~0.offset, 1);call write~init~int(1, ~#s_tolower_table~0.base, 1 + ~#s_tolower_table~0.offset, 1);call write~init~int(2, ~#s_tolower_table~0.base, 2 + ~#s_tolower_table~0.offset, 1);call write~init~int(3, ~#s_tolower_table~0.base, 3 + ~#s_tolower_table~0.offset, 1);call write~init~int(4, ~#s_tolower_table~0.base, 4 + ~#s_tolower_table~0.offset, 1);call write~init~int(5, ~#s_tolower_table~0.base, 5 + ~#s_tolower_table~0.offset, 1);call write~init~int(6, ~#s_tolower_table~0.base, 6 + ~#s_tolower_table~0.offset, 1);call write~init~int(7, ~#s_tolower_table~0.base, 7 + ~#s_tolower_table~0.offset, 1);call write~init~int(8, ~#s_tolower_table~0.base, 8 + ~#s_tolower_table~0.offset, 1);call write~init~int(9, ~#s_tolower_table~0.base, 9 + ~#s_tolower_table~0.offset, 1);call write~init~int(10, ~#s_tolower_table~0.base, 10 + ~#s_tolower_table~0.offset, 1);call write~init~int(11, ~#s_tolower_table~0.base, 11 + ~#s_tolower_table~0.offset, 1);call write~init~int(12, ~#s_tolower_table~0.base, 12 + ~#s_tolower_table~0.offset, 1);call write~init~int(13, ~#s_tolower_table~0.base, 13 + ~#s_tolower_table~0.offset, 1);call write~init~int(14, ~#s_tolower_table~0.base, 14 + ~#s_tolower_table~0.offset, 1);call write~init~int(15, ~#s_tolower_table~0.base, 15 + ~#s_tolower_table~0.offset, 1);call write~init~int(16, ~#s_tolower_table~0.base, 16 + ~#s_tolower_table~0.offset, 1);call write~init~int(17, ~#s_tolower_table~0.base, 17 + ~#s_tolower_table~0.offset, 1);call write~init~int(18, ~#s_tolower_table~0.base, 18 + ~#s_tolower_table~0.offset, 1);call write~init~int(19, ~#s_tolower_table~0.base, 19 + ~#s_tolower_table~0.offset, 1);call write~init~int(20, ~#s_tolower_table~0.base, 20 + ~#s_tolower_table~0.offset, 1);call write~init~int(21, ~#s_tolower_table~0.base, 21 + ~#s_tolower_table~0.offset, 1);call write~init~int(22, ~#s_tolower_table~0.base, 22 + ~#s_tolower_table~0.offset, 1);call write~init~int(23, ~#s_tolower_table~0.base, 23 + ~#s_tolower_table~0.offset, 1);call write~init~int(24, ~#s_tolower_table~0.base, 24 + ~#s_tolower_table~0.offset, 1);call write~init~int(25, ~#s_tolower_table~0.base, 25 + ~#s_tolower_table~0.offset, 1);call write~init~int(26, ~#s_tolower_table~0.base, 26 + ~#s_tolower_table~0.offset, 1);call write~init~int(27, ~#s_tolower_table~0.base, 27 + ~#s_tolower_table~0.offset, 1);call write~init~int(28, ~#s_tolower_table~0.base, 28 + ~#s_tolower_table~0.offset, 1);call write~init~int(29, ~#s_tolower_table~0.base, 29 + ~#s_tolower_table~0.offset, 1);call write~init~int(30, ~#s_tolower_table~0.base, 30 + ~#s_tolower_table~0.offset, 1);call write~init~int(31, ~#s_tolower_table~0.base, 31 + ~#s_tolower_table~0.offset, 1);call write~init~int(32, ~#s_tolower_table~0.base, 32 + ~#s_tolower_table~0.offset, 1);call write~init~int(33, ~#s_tolower_table~0.base, 33 + ~#s_tolower_table~0.offset, 1);call write~init~int(34, ~#s_tolower_table~0.base, 34 + ~#s_tolower_table~0.offset, 1);call write~init~int(35, ~#s_tolower_table~0.base, 35 + ~#s_tolower_table~0.offset, 1);call write~init~int(36, ~#s_tolower_table~0.base, 36 + ~#s_tolower_table~0.offset, 1);call write~init~int(37, ~#s_tolower_table~0.base, 37 + ~#s_tolower_table~0.offset, 1);call write~init~int(38, ~#s_tolower_table~0.base, 38 + ~#s_tolower_table~0.offset, 1);call write~init~int(39, ~#s_tolower_table~0.base, 39 + ~#s_tolower_table~0.offset, 1);call write~init~int(40, ~#s_tolower_table~0.base, 40 + ~#s_tolower_table~0.offset, 1);call write~init~int(41, ~#s_tolower_table~0.base, 41 + ~#s_tolower_table~0.offset, 1);call write~init~int(42, ~#s_tolower_table~0.base, 42 + ~#s_tolower_table~0.offset, 1);call write~init~int(43, ~#s_tolower_table~0.base, 43 + ~#s_tolower_table~0.offset, 1);call write~init~int(44, ~#s_tolower_table~0.base, 44 + ~#s_tolower_table~0.offset, 1);call write~init~int(45, ~#s_tolower_table~0.base, 45 + ~#s_tolower_table~0.offset, 1);call write~init~int(46, ~#s_tolower_table~0.base, 46 + ~#s_tolower_table~0.offset, 1);call write~init~int(47, ~#s_tolower_table~0.base, 47 + ~#s_tolower_table~0.offset, 1);call write~init~int(48, ~#s_tolower_table~0.base, 48 + ~#s_tolower_table~0.offset, 1);call write~init~int(49, ~#s_tolower_table~0.base, 49 + ~#s_tolower_table~0.offset, 1);call write~init~int(50, ~#s_tolower_table~0.base, 50 + ~#s_tolower_table~0.offset, 1);call write~init~int(51, ~#s_tolower_table~0.base, 51 + ~#s_tolower_table~0.offset, 1);call write~init~int(52, ~#s_tolower_table~0.base, 52 + ~#s_tolower_table~0.offset, 1);call write~init~int(53, ~#s_tolower_table~0.base, 53 + ~#s_tolower_table~0.offset, 1);call write~init~int(54, ~#s_tolower_table~0.base, 54 + ~#s_tolower_table~0.offset, 1);call write~init~int(55, ~#s_tolower_table~0.base, 55 + ~#s_tolower_table~0.offset, 1);call write~init~int(56, ~#s_tolower_table~0.base, 56 + ~#s_tolower_table~0.offset, 1);call write~init~int(57, ~#s_tolower_table~0.base, 57 + ~#s_tolower_table~0.offset, 1);call write~init~int(58, ~#s_tolower_table~0.base, 58 + ~#s_tolower_table~0.offset, 1);call write~init~int(59, ~#s_tolower_table~0.base, 59 + ~#s_tolower_table~0.offset, 1);call write~init~int(60, ~#s_tolower_table~0.base, 60 + ~#s_tolower_table~0.offset, 1);call write~init~int(61, ~#s_tolower_table~0.base, 61 + ~#s_tolower_table~0.offset, 1);call write~init~int(62, ~#s_tolower_table~0.base, 62 + ~#s_tolower_table~0.offset, 1);call write~init~int(63, ~#s_tolower_table~0.base, 63 + ~#s_tolower_table~0.offset, 1);call write~init~int(64, ~#s_tolower_table~0.base, 64 + ~#s_tolower_table~0.offset, 1);call write~init~int(97, ~#s_tolower_table~0.base, 65 + ~#s_tolower_table~0.offset, 1);call write~init~int(98, ~#s_tolower_table~0.base, 66 + ~#s_tolower_table~0.offset, 1);call write~init~int(99, ~#s_tolower_table~0.base, 67 + ~#s_tolower_table~0.offset, 1);call write~init~int(100, ~#s_tolower_table~0.base, 68 + ~#s_tolower_table~0.offset, 1);call write~init~int(101, ~#s_tolower_table~0.base, 69 + ~#s_tolower_table~0.offset, 1);call write~init~int(102, ~#s_tolower_table~0.base, 70 + ~#s_tolower_table~0.offset, 1);call write~init~int(103, ~#s_tolower_table~0.base, 71 + ~#s_tolower_table~0.offset, 1);call write~init~int(104, ~#s_tolower_table~0.base, 72 + ~#s_tolower_table~0.offset, 1);call write~init~int(105, ~#s_tolower_table~0.base, 73 + ~#s_tolower_table~0.offset, 1);call write~init~int(106, ~#s_tolower_table~0.base, 74 + ~#s_tolower_table~0.offset, 1);call write~init~int(107, ~#s_tolower_table~0.base, 75 + ~#s_tolower_table~0.offset, 1);call write~init~int(108, ~#s_tolower_table~0.base, 76 + ~#s_tolower_table~0.offset, 1);call write~init~int(109, ~#s_tolower_table~0.base, 77 + ~#s_tolower_table~0.offset, 1);call write~init~int(110, ~#s_tolower_table~0.base, 78 + ~#s_tolower_table~0.offset, 1);call write~init~int(111, ~#s_tolower_table~0.base, 79 + ~#s_tolower_table~0.offset, 1);call write~init~int(112, ~#s_tolower_table~0.base, 80 + ~#s_tolower_table~0.offset, 1);call write~init~int(113, ~#s_tolower_table~0.base, 81 + ~#s_tolower_table~0.offset, 1);call write~init~int(114, ~#s_tolower_table~0.base, 82 + ~#s_tolower_table~0.offset, 1);call write~init~int(115, ~#s_tolower_table~0.base, 83 + ~#s_tolower_table~0.offset, 1);call write~init~int(116, ~#s_tolower_table~0.base, 84 + ~#s_tolower_table~0.offset, 1);call write~init~int(117, ~#s_tolower_table~0.base, 85 + ~#s_tolower_table~0.offset, 1);call write~init~int(118, ~#s_tolower_table~0.base, 86 + ~#s_tolower_table~0.offset, 1);call write~init~int(119, ~#s_tolower_table~0.base, 87 + ~#s_tolower_table~0.offset, 1);call write~init~int(120, ~#s_tolower_table~0.base, 88 + ~#s_tolower_table~0.offset, 1);call write~init~int(121, ~#s_tolower_table~0.base, 89 + ~#s_tolower_table~0.offset, 1);call write~init~int(122, ~#s_tolower_table~0.base, 90 + ~#s_tolower_table~0.offset, 1);call write~init~int(91, ~#s_tolower_table~0.base, 91 + ~#s_tolower_table~0.offset, 1);call write~init~int(92, ~#s_tolower_table~0.base, 92 + ~#s_tolower_table~0.offset, 1);call write~init~int(93, ~#s_tolower_table~0.base, 93 + ~#s_tolower_table~0.offset, 1);call write~init~int(94, ~#s_tolower_table~0.base, 94 + ~#s_tolower_table~0.offset, 1);call write~init~int(95, ~#s_tolower_table~0.base, 95 + ~#s_tolower_table~0.offset, 1);call write~init~int(96, ~#s_tolower_table~0.base, 96 + ~#s_tolower_table~0.offset, 1);call write~init~int(97, ~#s_tolower_table~0.base, 97 + ~#s_tolower_table~0.offset, 1);call write~init~int(98, ~#s_tolower_table~0.base, 98 + ~#s_tolower_table~0.offset, 1);call write~init~int(99, ~#s_tolower_table~0.base, 99 + ~#s_tolower_table~0.offset, 1);call write~init~int(100, ~#s_tolower_table~0.base, 100 + ~#s_tolower_table~0.offset, 1);call write~init~int(101, ~#s_tolower_table~0.base, 101 + ~#s_tolower_table~0.offset, 1);call write~init~int(102, ~#s_tolower_table~0.base, 102 + ~#s_tolower_table~0.offset, 1);call write~init~int(103, ~#s_tolower_table~0.base, 103 + ~#s_tolower_table~0.offset, 1);call write~init~int(104, ~#s_tolower_table~0.base, 104 + ~#s_tolower_table~0.offset, 1);call write~init~int(105, ~#s_tolower_table~0.base, 105 + ~#s_tolower_table~0.offset, 1);call write~init~int(106, ~#s_tolower_table~0.base, 106 + ~#s_tolower_table~0.offset, 1);call write~init~int(107, ~#s_tolower_table~0.base, 107 + ~#s_tolower_table~0.offset, 1);call write~init~int(108, ~#s_tolower_table~0.base, 108 + ~#s_tolower_table~0.offset, 1);call write~init~int(109, ~#s_tolower_table~0.base, 109 + ~#s_tolower_table~0.offset, 1);call write~init~int(110, ~#s_tolower_table~0.base, 110 + ~#s_tolower_table~0.offset, 1);call write~init~int(111, ~#s_tolower_table~0.base, 111 + ~#s_tolower_table~0.offset, 1);call write~init~int(112, ~#s_tolower_table~0.base, 112 + ~#s_tolower_table~0.offset, 1);call write~init~int(113, ~#s_tolower_table~0.base, 113 + ~#s_tolower_table~0.offset, 1);call write~init~int(114, ~#s_tolower_table~0.base, 114 + ~#s_tolower_table~0.offset, 1);call write~init~int(115, ~#s_tolower_table~0.base, 115 + ~#s_tolower_table~0.offset, 1);call write~init~int(116, ~#s_tolower_table~0.base, 116 + ~#s_tolower_table~0.offset, 1);call write~init~int(117, ~#s_tolower_table~0.base, 117 + ~#s_tolower_table~0.offset, 1);call write~init~int(118, ~#s_tolower_table~0.base, 118 + ~#s_tolower_table~0.offset, 1);call write~init~int(119, ~#s_tolower_table~0.base, 119 + ~#s_tolower_table~0.offset, 1);call write~init~int(120, ~#s_tolower_table~0.base, 120 + ~#s_tolower_table~0.offset, 1);call write~init~int(121, ~#s_tolower_table~0.base, 121 + ~#s_tolower_table~0.offset, 1);call write~init~int(122, ~#s_tolower_table~0.base, 122 + ~#s_tolower_table~0.offset, 1);call write~init~int(123, ~#s_tolower_table~0.base, 123 + ~#s_tolower_table~0.offset, 1);call write~init~int(124, ~#s_tolower_table~0.base, 124 + ~#s_tolower_table~0.offset, 1);call write~init~int(125, ~#s_tolower_table~0.base, 125 + ~#s_tolower_table~0.offset, 1);call write~init~int(126, ~#s_tolower_table~0.base, 126 + ~#s_tolower_table~0.offset, 1);call write~init~int(127, ~#s_tolower_table~0.base, 127 + ~#s_tolower_table~0.offset, 1);call write~init~int(128, ~#s_tolower_table~0.base, 128 + ~#s_tolower_table~0.offset, 1);call write~init~int(129, ~#s_tolower_table~0.base, 129 + ~#s_tolower_table~0.offset, 1);call write~init~int(130, ~#s_tolower_table~0.base, 130 + ~#s_tolower_table~0.offset, 1);call write~init~int(131, ~#s_tolower_table~0.base, 131 + ~#s_tolower_table~0.offset, 1);call write~init~int(132, ~#s_tolower_table~0.base, 132 + ~#s_tolower_table~0.offset, 1);call write~init~int(133, ~#s_tolower_table~0.base, 133 + ~#s_tolower_table~0.offset, 1);call write~init~int(134, ~#s_tolower_table~0.base, 134 + ~#s_tolower_table~0.offset, 1);call write~init~int(135, ~#s_tolower_table~0.base, 135 + ~#s_tolower_table~0.offset, 1);call write~init~int(136, ~#s_tolower_table~0.base, 136 + ~#s_tolower_table~0.offset, 1);call write~init~int(137, ~#s_tolower_table~0.base, 137 + ~#s_tolower_table~0.offset, 1);call write~init~int(138, ~#s_tolower_table~0.base, 138 + ~#s_tolower_table~0.offset, 1);call write~init~int(139, ~#s_tolower_table~0.base, 139 + ~#s_tolower_table~0.offset, 1);call write~init~int(140, ~#s_tolower_table~0.base, 140 + ~#s_tolower_table~0.offset, 1);call write~init~int(141, ~#s_tolower_table~0.base, 141 + ~#s_tolower_table~0.offset, 1);call write~init~int(142, ~#s_tolower_table~0.base, 142 + ~#s_tolower_table~0.offset, 1);call write~init~int(143, ~#s_tolower_table~0.base, 143 + ~#s_tolower_table~0.offset, 1);call write~init~int(144, ~#s_tolower_table~0.base, 144 + ~#s_tolower_table~0.offset, 1);call write~init~int(145, ~#s_tolower_table~0.base, 145 + ~#s_tolower_table~0.offset, 1);call write~init~int(146, ~#s_tolower_table~0.base, 146 + ~#s_tolower_table~0.offset, 1);call write~init~int(147, ~#s_tolower_table~0.base, 147 + ~#s_tolower_table~0.offset, 1);call write~init~int(148, ~#s_tolower_table~0.base, 148 + ~#s_tolower_table~0.offset, 1);call write~init~int(149, ~#s_tolower_table~0.base, 149 + ~#s_tolower_table~0.offset, 1);call write~init~int(150, ~#s_tolower_table~0.base, 150 + ~#s_tolower_table~0.offset, 1);call write~init~int(151, ~#s_tolower_table~0.base, 151 + ~#s_tolower_table~0.offset, 1);call write~init~int(152, ~#s_tolower_table~0.base, 152 + ~#s_tolower_table~0.offset, 1);call write~init~int(153, ~#s_tolower_table~0.base, 153 + ~#s_tolower_table~0.offset, 1);call write~init~int(154, ~#s_tolower_table~0.base, 154 + ~#s_tolower_table~0.offset, 1);call write~init~int(155, ~#s_tolower_table~0.base, 155 + ~#s_tolower_table~0.offset, 1);call write~init~int(156, ~#s_tolower_table~0.base, 156 + ~#s_tolower_table~0.offset, 1);call write~init~int(157, ~#s_tolower_table~0.base, 157 + ~#s_tolower_table~0.offset, 1);call write~init~int(158, ~#s_tolower_table~0.base, 158 + ~#s_tolower_table~0.offset, 1);call write~init~int(159, ~#s_tolower_table~0.base, 159 + ~#s_tolower_table~0.offset, 1);call write~init~int(160, ~#s_tolower_table~0.base, 160 + ~#s_tolower_table~0.offset, 1);call write~init~int(161, ~#s_tolower_table~0.base, 161 + ~#s_tolower_table~0.offset, 1);call write~init~int(162, ~#s_tolower_table~0.base, 162 + ~#s_tolower_table~0.offset, 1);call write~init~int(163, ~#s_tolower_table~0.base, 163 + ~#s_tolower_table~0.offset, 1);call write~init~int(164, ~#s_tolower_table~0.base, 164 + ~#s_tolower_table~0.offset, 1);call write~init~int(165, ~#s_tolower_table~0.base, 165 + ~#s_tolower_table~0.offset, 1);call write~init~int(166, ~#s_tolower_table~0.base, 166 + ~#s_tolower_table~0.offset, 1);call write~init~int(167, ~#s_tolower_table~0.base, 167 + ~#s_tolower_table~0.offset, 1);call write~init~int(168, ~#s_tolower_table~0.base, 168 + ~#s_tolower_table~0.offset, 1);call write~init~int(169, ~#s_tolower_table~0.base, 169 + ~#s_tolower_table~0.offset, 1);call write~init~int(170, ~#s_tolower_table~0.base, 170 + ~#s_tolower_table~0.offset, 1);call write~init~int(171, ~#s_tolower_table~0.base, 171 + ~#s_tolower_table~0.offset, 1);call write~init~int(172, ~#s_tolower_table~0.base, 172 + ~#s_tolower_table~0.offset, 1);call write~init~int(173, ~#s_tolower_table~0.base, 173 + ~#s_tolower_table~0.offset, 1);call write~init~int(174, ~#s_tolower_table~0.base, 174 + ~#s_tolower_table~0.offset, 1);call write~init~int(175, ~#s_tolower_table~0.base, 175 + ~#s_tolower_table~0.offset, 1);call write~init~int(176, ~#s_tolower_table~0.base, 176 + ~#s_tolower_table~0.offset, 1);call write~init~int(177, ~#s_tolower_table~0.base, 177 + ~#s_tolower_table~0.offset, 1);call write~init~int(178, ~#s_tolower_table~0.base, 178 + ~#s_tolower_table~0.offset, 1);call write~init~int(179, ~#s_tolower_table~0.base, 179 + ~#s_tolower_table~0.offset, 1);call write~init~int(180, ~#s_tolower_table~0.base, 180 + ~#s_tolower_table~0.offset, 1);call write~init~int(181, ~#s_tolower_table~0.base, 181 + ~#s_tolower_table~0.offset, 1);call write~init~int(182, ~#s_tolower_table~0.base, 182 + ~#s_tolower_table~0.offset, 1);call write~init~int(183, ~#s_tolower_table~0.base, 183 + ~#s_tolower_table~0.offset, 1);call write~init~int(184, ~#s_tolower_table~0.base, 184 + ~#s_tolower_table~0.offset, 1);call write~init~int(185, ~#s_tolower_table~0.base, 185 + ~#s_tolower_table~0.offset, 1);call write~init~int(186, ~#s_tolower_table~0.base, 186 + ~#s_tolower_table~0.offset, 1);call write~init~int(187, ~#s_tolower_table~0.base, 187 + ~#s_tolower_table~0.offset, 1);call write~init~int(188, ~#s_tolower_table~0.base, 188 + ~#s_tolower_table~0.offset, 1);call write~init~int(189, ~#s_tolower_table~0.base, 189 + ~#s_tolower_table~0.offset, 1);call write~init~int(190, ~#s_tolower_table~0.base, 190 + ~#s_tolower_table~0.offset, 1);call write~init~int(191, ~#s_tolower_table~0.base, 191 + ~#s_tolower_table~0.offset, 1);call write~init~int(192, ~#s_tolower_table~0.base, 192 + ~#s_tolower_table~0.offset, 1);call write~init~int(193, ~#s_tolower_table~0.base, 193 + ~#s_tolower_table~0.offset, 1);call write~init~int(194, ~#s_tolower_table~0.base, 194 + ~#s_tolower_table~0.offset, 1);call write~init~int(195, ~#s_tolower_table~0.base, 195 + ~#s_tolower_table~0.offset, 1);call write~init~int(196, ~#s_tolower_table~0.base, 196 + ~#s_tolower_table~0.offset, 1);call write~init~int(197, ~#s_tolower_table~0.base, 197 + ~#s_tolower_table~0.offset, 1);call write~init~int(198, ~#s_tolower_table~0.base, 198 + ~#s_tolower_table~0.offset, 1);call write~init~int(199, ~#s_tolower_table~0.base, 199 + ~#s_tolower_table~0.offset, 1);call write~init~int(200, ~#s_tolower_table~0.base, 200 + ~#s_tolower_table~0.offset, 1);call write~init~int(201, ~#s_tolower_table~0.base, 201 + ~#s_tolower_table~0.offset, 1);call write~init~int(202, ~#s_tolower_table~0.base, 202 + ~#s_tolower_table~0.offset, 1);call write~init~int(203, ~#s_tolower_table~0.base, 203 + ~#s_tolower_table~0.offset, 1);call write~init~int(204, ~#s_tolower_table~0.base, 204 + ~#s_tolower_table~0.offset, 1);call write~init~int(205, ~#s_tolower_table~0.base, 205 + ~#s_tolower_table~0.offset, 1);call write~init~int(206, ~#s_tolower_table~0.base, 206 + ~#s_tolower_table~0.offset, 1);call write~init~int(207, ~#s_tolower_table~0.base, 207 + ~#s_tolower_table~0.offset, 1);call write~init~int(208, ~#s_tolower_table~0.base, 208 + ~#s_tolower_table~0.offset, 1);call write~init~int(209, ~#s_tolower_table~0.base, 209 + ~#s_tolower_table~0.offset, 1);call write~init~int(210, ~#s_tolower_table~0.base, 210 + ~#s_tolower_table~0.offset, 1);call write~init~int(211, ~#s_tolower_table~0.base, 211 + ~#s_tolower_table~0.offset, 1);call write~init~int(212, ~#s_tolower_table~0.base, 212 + ~#s_tolower_table~0.offset, 1);call write~init~int(213, ~#s_tolower_table~0.base, 213 + ~#s_tolower_table~0.offset, 1);call write~init~int(214, ~#s_tolower_table~0.base, 214 + ~#s_tolower_table~0.offset, 1);call write~init~int(215, ~#s_tolower_table~0.base, 215 + ~#s_tolower_table~0.offset, 1);call write~init~int(216, ~#s_tolower_table~0.base, 216 + ~#s_tolower_table~0.offset, 1);call write~init~int(217, ~#s_tolower_table~0.base, 217 + ~#s_tolower_table~0.offset, 1);call write~init~int(218, ~#s_tolower_table~0.base, 218 + ~#s_tolower_table~0.offset, 1);call write~init~int(219, ~#s_tolower_table~0.base, 219 + ~#s_tolower_table~0.offset, 1);call write~init~int(220, ~#s_tolower_table~0.base, 220 + ~#s_tolower_table~0.offset, 1);call write~init~int(221, ~#s_tolower_table~0.base, 221 + ~#s_tolower_table~0.offset, 1);call write~init~int(222, ~#s_tolower_table~0.base, 222 + ~#s_tolower_table~0.offset, 1);call write~init~int(223, ~#s_tolower_table~0.base, 223 + ~#s_tolower_table~0.offset, 1);call write~init~int(224, ~#s_tolower_table~0.base, 224 + ~#s_tolower_table~0.offset, 1);call write~init~int(225, ~#s_tolower_table~0.base, 225 + ~#s_tolower_table~0.offset, 1);call write~init~int(226, ~#s_tolower_table~0.base, 226 + ~#s_tolower_table~0.offset, 1);call write~init~int(227, ~#s_tolower_table~0.base, 227 + ~#s_tolower_table~0.offset, 1);call write~init~int(228, ~#s_tolower_table~0.base, 228 + ~#s_tolower_table~0.offset, 1);call write~init~int(229, ~#s_tolower_table~0.base, 229 + ~#s_tolower_table~0.offset, 1);call write~init~int(230, ~#s_tolower_table~0.base, 230 + ~#s_tolower_table~0.offset, 1);call write~init~int(231, ~#s_tolower_table~0.base, 231 + ~#s_tolower_table~0.offset, 1);call write~init~int(232, ~#s_tolower_table~0.base, 232 + ~#s_tolower_table~0.offset, 1);call write~init~int(233, ~#s_tolower_table~0.base, 233 + ~#s_tolower_table~0.offset, 1);call write~init~int(234, ~#s_tolower_table~0.base, 234 + ~#s_tolower_table~0.offset, 1);call write~init~int(235, ~#s_tolower_table~0.base, 235 + ~#s_tolower_table~0.offset, 1);call write~init~int(236, ~#s_tolower_table~0.base, 236 + ~#s_tolower_table~0.offset, 1);call write~init~int(237, ~#s_tolower_table~0.base, 237 + ~#s_tolower_table~0.offset, 1);call write~init~int(238, ~#s_tolower_table~0.base, 238 + ~#s_tolower_table~0.offset, 1);call write~init~int(239, ~#s_tolower_table~0.base, 239 + ~#s_tolower_table~0.offset, 1);call write~init~int(240, ~#s_tolower_table~0.base, 240 + ~#s_tolower_table~0.offset, 1);call write~init~int(241, ~#s_tolower_table~0.base, 241 + ~#s_tolower_table~0.offset, 1);call write~init~int(242, ~#s_tolower_table~0.base, 242 + ~#s_tolower_table~0.offset, 1);call write~init~int(243, ~#s_tolower_table~0.base, 243 + ~#s_tolower_table~0.offset, 1);call write~init~int(244, ~#s_tolower_table~0.base, 244 + ~#s_tolower_table~0.offset, 1);call write~init~int(245, ~#s_tolower_table~0.base, 245 + ~#s_tolower_table~0.offset, 1);call write~init~int(246, ~#s_tolower_table~0.base, 246 + ~#s_tolower_table~0.offset, 1);call write~init~int(247, ~#s_tolower_table~0.base, 247 + ~#s_tolower_table~0.offset, 1);call write~init~int(248, ~#s_tolower_table~0.base, 248 + ~#s_tolower_table~0.offset, 1);call write~init~int(249, ~#s_tolower_table~0.base, 249 + ~#s_tolower_table~0.offset, 1);call write~init~int(250, ~#s_tolower_table~0.base, 250 + ~#s_tolower_table~0.offset, 1);call write~init~int(251, ~#s_tolower_table~0.base, 251 + ~#s_tolower_table~0.offset, 1);call write~init~int(252, ~#s_tolower_table~0.base, 252 + ~#s_tolower_table~0.offset, 1);call write~init~int(253, ~#s_tolower_table~0.base, 253 + ~#s_tolower_table~0.offset, 1);call write~init~int(254, ~#s_tolower_table~0.base, 254 + ~#s_tolower_table~0.offset, 1);call write~init~int(255, ~#s_tolower_table~0.base, 255 + ~#s_tolower_table~0.offset, 1); {4172#true} is VALID [2022-02-20 21:08:23,893 INFO L134 CoverageAnalysis]: Checked inductivity of 149 backedges. 0 proven. 9 refuted. 0 times theorem prover too weak. 140 trivial. 0 not checked. [2022-02-20 21:08:23,893 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleZ3 [1561592506] provided 0 perfect and 2 imperfect interpolant sequences [2022-02-20 21:08:23,893 INFO L191 FreeRefinementEngine]: Found 0 perfect and 3 imperfect interpolant sequences. [2022-02-20 21:08:23,894 INFO L204 FreeRefinementEngine]: Number of different interpolants: perfect sequences [] imperfect sequences [18, 11, 11] total 27 [2022-02-20 21:08:23,894 INFO L118 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [2114118357] [2022-02-20 21:08:23,894 INFO L85 oduleStraightlineAll]: Using 3 imperfect interpolants to construct interpolant automaton [2022-02-20 21:08:23,895 INFO L78 Accepts]: Start accepts. Automaton has has 27 states, 25 states have (on average 3.28) internal successors, (82), 20 states have internal predecessors, (82), 11 states have call successors, (34), 4 states have call predecessors, (34), 7 states have return successors, (33), 14 states have call predecessors, (33), 11 states have call successors, (33) Word has length 130 [2022-02-20 21:08:23,901 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-02-20 21:08:23,901 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with has 27 states, 25 states have (on average 3.28) internal successors, (82), 20 states have internal predecessors, (82), 11 states have call successors, (34), 4 states have call predecessors, (34), 7 states have return successors, (33), 14 states have call predecessors, (33), 11 states have call successors, (33) [2022-02-20 21:08:24,029 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 149 edges. 149 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 21:08:24,030 INFO L546 AbstractCegarLoop]: INTERPOLANT automaton has 27 states [2022-02-20 21:08:24,030 INFO L108 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2022-02-20 21:08:24,030 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 27 interpolants. [2022-02-20 21:08:24,031 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=56, Invalid=646, Unknown=0, NotChecked=0, Total=702 [2022-02-20 21:08:24,031 INFO L87 Difference]: Start difference. First operand 122 states and 158 transitions. Second operand has 27 states, 25 states have (on average 3.28) internal successors, (82), 20 states have internal predecessors, (82), 11 states have call successors, (34), 4 states have call predecessors, (34), 7 states have return successors, (33), 14 states have call predecessors, (33), 11 states have call successors, (33) [2022-02-20 21:08:25,808 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 21:08:25,808 INFO L93 Difference]: Finished difference Result 155 states and 192 transitions. [2022-02-20 21:08:25,809 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 15 states. [2022-02-20 21:08:25,809 INFO L78 Accepts]: Start accepts. Automaton has has 27 states, 25 states have (on average 3.28) internal successors, (82), 20 states have internal predecessors, (82), 11 states have call successors, (34), 4 states have call predecessors, (34), 7 states have return successors, (33), 14 states have call predecessors, (33), 11 states have call successors, (33) Word has length 130 [2022-02-20 21:08:25,809 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-02-20 21:08:25,809 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 27 states, 25 states have (on average 3.28) internal successors, (82), 20 states have internal predecessors, (82), 11 states have call successors, (34), 4 states have call predecessors, (34), 7 states have return successors, (33), 14 states have call predecessors, (33), 11 states have call successors, (33) [2022-02-20 21:08:25,813 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 15 states to 15 states and 166 transitions. [2022-02-20 21:08:25,813 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 27 states, 25 states have (on average 3.28) internal successors, (82), 20 states have internal predecessors, (82), 11 states have call successors, (34), 4 states have call predecessors, (34), 7 states have return successors, (33), 14 states have call predecessors, (33), 11 states have call successors, (33) [2022-02-20 21:08:25,816 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 15 states to 15 states and 166 transitions. [2022-02-20 21:08:25,816 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with 15 states and 166 transitions. [2022-02-20 21:08:25,952 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 166 edges. 166 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 21:08:25,952 INFO L225 Difference]: With dead ends: 155 [2022-02-20 21:08:25,952 INFO L226 Difference]: Without dead ends: 0 [2022-02-20 21:08:25,953 INFO L932 BasicCegarLoop]: 0 DeclaredPredicates, 325 GetRequests, 288 SyntacticMatches, 0 SemanticMatches, 37 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 125 ImplicationChecksByTransitivity, 0.6s TimeCoverageRelationStatistics Valid=142, Invalid=1340, Unknown=0, NotChecked=0, Total=1482 [2022-02-20 21:08:25,954 INFO L933 BasicCegarLoop]: 27 mSDtfsCounter, 41 mSDsluCounter, 311 mSDsCounter, 0 mSdLazyCounter, 498 mSolverCounterSat, 27 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.6s Time, 0 mProtectedPredicate, 0 mProtectedAction, 41 SdHoareTripleChecker+Valid, 338 SdHoareTripleChecker+Invalid, 525 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 27 IncrementalHoareTripleChecker+Valid, 498 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.6s IncrementalHoareTripleChecker+Time [2022-02-20 21:08:25,955 INFO L934 BasicCegarLoop]: SdHoareTripleChecker [41 Valid, 338 Invalid, 525 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [27 Valid, 498 Invalid, 0 Unknown, 0 Unchecked, 0.6s Time] [2022-02-20 21:08:25,955 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 0 states. [2022-02-20 21:08:25,955 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 0 to 0. [2022-02-20 21:08:25,955 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-02-20 21:08:25,955 INFO L82 GeneralOperation]: Start isEquivalent. First operand 0 states. Second operand has 0 states, 0 states have (on average 0.0) internal successors, (0), 0 states have internal predecessors, (0), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 21:08:25,955 INFO L74 IsIncluded]: Start isIncluded. First operand 0 states. Second operand has 0 states, 0 states have (on average 0.0) internal successors, (0), 0 states have internal predecessors, (0), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 21:08:25,956 INFO L87 Difference]: Start difference. First operand 0 states. Second operand has 0 states, 0 states have (on average 0.0) internal successors, (0), 0 states have internal predecessors, (0), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 21:08:25,956 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 21:08:25,956 INFO L93 Difference]: Finished difference Result 0 states and 0 transitions. [2022-02-20 21:08:25,956 INFO L276 IsEmpty]: Start isEmpty. Operand 0 states and 0 transitions. [2022-02-20 21:08:25,956 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 21:08:25,956 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 21:08:25,956 INFO L74 IsIncluded]: Start isIncluded. First operand has 0 states, 0 states have (on average 0.0) internal successors, (0), 0 states have internal predecessors, (0), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) Second operand 0 states. [2022-02-20 21:08:25,956 INFO L87 Difference]: Start difference. First operand has 0 states, 0 states have (on average 0.0) internal successors, (0), 0 states have internal predecessors, (0), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) Second operand 0 states. [2022-02-20 21:08:25,956 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 21:08:25,956 INFO L93 Difference]: Finished difference Result 0 states and 0 transitions. [2022-02-20 21:08:25,956 INFO L276 IsEmpty]: Start isEmpty. Operand 0 states and 0 transitions. [2022-02-20 21:08:25,957 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 21:08:25,958 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 21:08:25,958 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-02-20 21:08:25,958 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-02-20 21:08:25,958 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 0 states, 0 states have (on average 0.0) internal successors, (0), 0 states have internal predecessors, (0), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 21:08:25,958 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 0 states to 0 states and 0 transitions. [2022-02-20 21:08:25,958 INFO L78 Accepts]: Start accepts. Automaton has 0 states and 0 transitions. Word has length 130 [2022-02-20 21:08:25,958 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-02-20 21:08:25,958 INFO L470 AbstractCegarLoop]: Abstraction has 0 states and 0 transitions. [2022-02-20 21:08:25,959 INFO L471 AbstractCegarLoop]: INTERPOLANT automaton has has 27 states, 25 states have (on average 3.28) internal successors, (82), 20 states have internal predecessors, (82), 11 states have call successors, (34), 4 states have call predecessors, (34), 7 states have return successors, (33), 14 states have call predecessors, (33), 11 states have call successors, (33) [2022-02-20 21:08:25,959 INFO L276 IsEmpty]: Start isEmpty. Operand 0 states and 0 transitions. [2022-02-20 21:08:25,959 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 21:08:25,961 INFO L764 garLoopResultBuilder]: Registering result SAFE for location __VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION (0 of 1 remaining) [2022-02-20 21:08:25,979 INFO L552 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (4)] Ended with exit code 0 [2022-02-20 21:08:26,161 WARN L452 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable4,4 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-02-20 21:08:26,163 INFO L343 DoubleDeckerVisitor]: Before removal of dead ends 0 states and 0 transitions. [2022-02-20 21:08:26,336 INFO L854 garLoopResultBuilder]: At program point L6814(line 6814) the Hoare annotation is: (and (= |old(#length)| |#length|) (= |old(#memory_real)| |#memory_real|) (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|) (or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0)) (= |old(#valid)| |#valid|)) [2022-02-20 21:08:26,336 INFO L858 garLoopResultBuilder]: For program point L6815-1(line 6815) no Hoare annotation was computed. [2022-02-20 21:08:26,336 INFO L854 garLoopResultBuilder]: At program point L6815(line 6815) the Hoare annotation is: (and (= |old(#length)| |#length|) (= |old(#memory_real)| |#memory_real|) (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|) (or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0)) (= |old(#valid)| |#valid|)) [2022-02-20 21:08:26,336 INFO L858 garLoopResultBuilder]: For program point ensure_string_is_allocated_bounded_lengthEXIT(lines 6813 6817) no Hoare annotation was computed. [2022-02-20 21:08:26,336 INFO L858 garLoopResultBuilder]: For program point L6814-1(line 6814) no Hoare annotation was computed. [2022-02-20 21:08:26,336 INFO L854 garLoopResultBuilder]: At program point ensure_string_is_allocated_bounded_lengthENTRY(lines 6813 6817) the Hoare annotation is: (and (= |old(#length)| |#length|) (= |old(#memory_real)| |#memory_real|) (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|) (= |old(#valid)| |#valid|)) [2022-02-20 21:08:26,336 INFO L854 garLoopResultBuilder]: At program point L6828(lines 6819 6829) the Hoare annotation is: (and (not (= |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~str~0#1.base| 0)) (not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96)) (not (= |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_#res#1.base| 0)) (or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))) [2022-02-20 21:08:26,336 INFO L858 garLoopResultBuilder]: For program point L6823-1(lines 6823 6824) no Hoare annotation was computed. [2022-02-20 21:08:26,336 INFO L854 garLoopResultBuilder]: At program point L6823(line 6823) the Hoare annotation is: (and (not (= |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~str~0#1.base| 0)) (not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96)) (or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))) [2022-02-20 21:08:26,336 INFO L858 garLoopResultBuilder]: For program point L6823-5(lines 6823 6824) no Hoare annotation was computed. [2022-02-20 21:08:26,336 INFO L858 garLoopResultBuilder]: For program point L6820-1(line 6820) no Hoare annotation was computed. [2022-02-20 21:08:26,337 INFO L854 garLoopResultBuilder]: At program point L6820(line 6820) the Hoare annotation is: (let ((.cse0 (not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96)))) (and (= |old(#length)| |#length|) (= |old(#memory_real)| |#memory_real|) (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|) (or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0)) (or .cse0 (<= (* (div (+ 18446744073709551520 |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~len#1|) 18446744073709551616) 18446744073709551616) |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~len#1|)) (or .cse0 (<= |ensure_string_is_allocated_bounded_length_~len~1#1| (+ (* 18446744073709551616 (div |ensure_string_is_allocated_bounded_length_~len~1#1| 18446744073709551616)) 95))) (= |old(#valid)| |#valid|))) [2022-02-20 21:08:26,337 INFO L858 garLoopResultBuilder]: For program point L6823-3(line 6823) no Hoare annotation was computed. [2022-02-20 21:08:26,337 INFO L858 garLoopResultBuilder]: For program point ensure_string_is_allocated_bounded_lengthFINAL(lines 6813 6817) no Hoare annotation was computed. [2022-02-20 21:08:26,337 INFO L854 garLoopResultBuilder]: At program point L6823-2(line 6823) the Hoare annotation is: (and (not (= |ensure_string_is_allocated_bounded_length_ensure_string_is_allocated_~str~0#1.base| 0)) (not (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| 96)) (or (= |ensure_string_is_allocated_bounded_length_#in~max_size#1| |ensure_string_is_allocated_bounded_length_~max_size#1|) (= (+ |ensure_string_is_allocated_bounded_length_~max_size#1| (- 96)) 0))) [2022-02-20 21:08:26,337 INFO L858 garLoopResultBuilder]: For program point L6896-1(lines 6896 6898) no Hoare annotation was computed. [2022-02-20 21:08:26,337 INFO L854 garLoopResultBuilder]: At program point L6896(lines 6896 6898) the Hoare annotation is: (and (= |bounded_malloc_#in~size| bounded_malloc_~size) (= |old(#length)| |#length|) (= |old(#valid)| |#valid|)) [2022-02-20 21:08:26,337 INFO L854 garLoopResultBuilder]: At program point bounded_mallocENTRY(lines 6895 6900) the Hoare annotation is: (and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|)) [2022-02-20 21:08:26,337 INFO L858 garLoopResultBuilder]: For program point bounded_mallocFINAL(lines 6895 6900) no Hoare annotation was computed. [2022-02-20 21:08:26,338 INFO L858 garLoopResultBuilder]: For program point bounded_mallocEXIT(lines 6895 6900) no Hoare annotation was computed. [2022-02-20 21:08:26,338 INFO L861 garLoopResultBuilder]: At program point aws_array_eqENTRY(lines 7686 7706) the Hoare annotation is: true [2022-02-20 21:08:26,338 INFO L858 garLoopResultBuilder]: For program point L7690(lines 7687 7706) no Hoare annotation was computed. [2022-02-20 21:08:26,338 INFO L858 garLoopResultBuilder]: For program point aws_array_eqEXIT(lines 7686 7706) no Hoare annotation was computed. [2022-02-20 21:08:26,338 INFO L861 garLoopResultBuilder]: At program point L7688-1(line 7688) the Hoare annotation is: true [2022-02-20 21:08:26,338 INFO L861 garLoopResultBuilder]: At program point L7688(line 7688) the Hoare annotation is: true [2022-02-20 21:08:26,338 INFO L858 garLoopResultBuilder]: For program point aws_array_eqFINAL(lines 7686 7706) no Hoare annotation was computed. [2022-02-20 21:08:26,338 INFO L858 garLoopResultBuilder]: For program point L7699(lines 7699 7703) no Hoare annotation was computed. [2022-02-20 21:08:26,338 INFO L858 garLoopResultBuilder]: For program point nondet_boolFINAL(line 261) no Hoare annotation was computed. [2022-02-20 21:08:26,338 INFO L858 garLoopResultBuilder]: For program point nondet_boolEXIT(line 261) no Hoare annotation was computed. [2022-02-20 21:08:26,338 INFO L861 garLoopResultBuilder]: At program point nondet_boolENTRY(line 261) the Hoare annotation is: true [2022-02-20 21:08:26,339 INFO L858 garLoopResultBuilder]: For program point L211-2(lines 210 212) no Hoare annotation was computed. [2022-02-20 21:08:26,339 INFO L861 garLoopResultBuilder]: At program point assume_abort_if_notENTRY(lines 210 212) the Hoare annotation is: true [2022-02-20 21:08:26,339 INFO L858 garLoopResultBuilder]: For program point L211(line 211) no Hoare annotation was computed. [2022-02-20 21:08:26,339 INFO L858 garLoopResultBuilder]: For program point assume_abort_if_notEXIT(lines 210 212) no Hoare annotation was computed. [2022-02-20 21:08:26,339 INFO L858 garLoopResultBuilder]: For program point aws_c_string_is_validFINAL(lines 6263 6273) no Hoare annotation was computed. [2022-02-20 21:08:26,339 INFO L861 garLoopResultBuilder]: At program point aws_c_string_is_validENTRY(lines 6263 6273) the Hoare annotation is: true [2022-02-20 21:08:26,339 INFO L858 garLoopResultBuilder]: For program point aws_c_string_is_validEXIT(lines 6263 6273) no Hoare annotation was computed. [2022-02-20 21:08:26,339 INFO L858 garLoopResultBuilder]: For program point can_fail_allocatorFINAL(lines 6902 6904) no Hoare annotation was computed. [2022-02-20 21:08:26,339 INFO L858 garLoopResultBuilder]: For program point can_fail_allocatorEXIT(lines 6902 6904) no Hoare annotation was computed. [2022-02-20 21:08:26,339 INFO L861 garLoopResultBuilder]: At program point can_fail_allocatorENTRY(lines 6902 6904) the Hoare annotation is: true [2022-02-20 21:08:26,339 INFO L861 garLoopResultBuilder]: At program point aws_string_is_validENTRY(lines 6253 6258) the Hoare annotation is: true [2022-02-20 21:08:26,340 INFO L858 garLoopResultBuilder]: For program point L6257-2(line 6257) no Hoare annotation was computed. [2022-02-20 21:08:26,340 INFO L858 garLoopResultBuilder]: For program point L6257-3(line 6257) no Hoare annotation was computed. [2022-02-20 21:08:26,340 INFO L858 garLoopResultBuilder]: For program point L6257(line 6257) no Hoare annotation was computed. [2022-02-20 21:08:26,340 INFO L858 garLoopResultBuilder]: For program point aws_string_is_validFINAL(lines 6253 6258) no Hoare annotation was computed. [2022-02-20 21:08:26,340 INFO L858 garLoopResultBuilder]: For program point L6257-5(line 6257) no Hoare annotation was computed. [2022-02-20 21:08:26,340 INFO L858 garLoopResultBuilder]: For program point aws_string_is_validEXIT(lines 6253 6258) no Hoare annotation was computed. [2022-02-20 21:08:26,340 INFO L858 garLoopResultBuilder]: For program point nondet_uint64_tEXIT(line 266) no Hoare annotation was computed. [2022-02-20 21:08:26,340 INFO L861 garLoopResultBuilder]: At program point nondet_uint64_tENTRY(line 266) the Hoare annotation is: true [2022-02-20 21:08:26,340 INFO L858 garLoopResultBuilder]: For program point nondet_uint64_tFINAL(line 266) no Hoare annotation was computed. [2022-02-20 21:08:26,340 INFO L854 garLoopResultBuilder]: At program point L11324(line 11324) the Hoare annotation is: false [2022-02-20 21:08:26,340 INFO L858 garLoopResultBuilder]: For program point L11324-1(line 11324) no Hoare annotation was computed. [2022-02-20 21:08:26,340 INFO L861 garLoopResultBuilder]: At program point L11328(line 11328) the Hoare annotation is: true [2022-02-20 21:08:26,340 INFO L858 garLoopResultBuilder]: For program point L11060(lines 11060 11064) no Hoare annotation was computed. [2022-02-20 21:08:26,340 INFO L858 garLoopResultBuilder]: For program point L7113-1(lines 7112 7125) no Hoare annotation was computed. [2022-02-20 21:08:26,340 INFO L854 garLoopResultBuilder]: At program point L7113(line 7113) the Hoare annotation is: false [2022-02-20 21:08:26,340 INFO L858 garLoopResultBuilder]: For program point L-1(line -1) no Hoare annotation was computed. [2022-02-20 21:08:26,341 INFO L858 garLoopResultBuilder]: For program point ULTIMATE.startENTRY(line -1) no Hoare annotation was computed. [2022-02-20 21:08:26,341 INFO L858 garLoopResultBuilder]: For program point ULTIMATE.startFINAL(line -1) no Hoare annotation was computed. [2022-02-20 21:08:26,341 INFO L854 garLoopResultBuilder]: At program point L10805-1(line 10805) the Hoare annotation is: false [2022-02-20 21:08:26,341 INFO L854 garLoopResultBuilder]: At program point L10805(line 10805) the Hoare annotation is: false [2022-02-20 21:08:26,341 INFO L858 garLoopResultBuilder]: For program point L11317(lines 11317 11327) no Hoare annotation was computed. [2022-02-20 21:08:26,342 INFO L858 garLoopResultBuilder]: For program point L10805-2(line 10805) no Hoare annotation was computed. [2022-02-20 21:08:26,342 INFO L858 garLoopResultBuilder]: For program point L11065(lines 11065 11073) no Hoare annotation was computed. [2022-02-20 21:08:26,342 INFO L854 garLoopResultBuilder]: At program point L11074(line 11074) the Hoare annotation is: false [2022-02-20 21:08:26,342 INFO L858 garLoopResultBuilder]: For program point ULTIMATE.startEXIT(line -1) no Hoare annotation was computed. [2022-02-20 21:08:26,342 INFO L854 garLoopResultBuilder]: At program point L11074-2(lines 11056 11075) the Hoare annotation is: false [2022-02-20 21:08:26,342 INFO L858 garLoopResultBuilder]: For program point L11074-1(line 11074) no Hoare annotation was computed. [2022-02-20 21:08:26,342 INFO L858 garLoopResultBuilder]: For program point L10806-2(line 10806) no Hoare annotation was computed. [2022-02-20 21:08:26,343 INFO L854 garLoopResultBuilder]: At program point L10810-6(line 10810) the Hoare annotation is: false [2022-02-20 21:08:26,343 INFO L858 garLoopResultBuilder]: For program point L11318-1(line 11318) no Hoare annotation was computed. [2022-02-20 21:08:26,343 INFO L854 garLoopResultBuilder]: At program point L10806-1(line 10806) the Hoare annotation is: false [2022-02-20 21:08:26,343 INFO L858 garLoopResultBuilder]: For program point L11058(line 11058) no Hoare annotation was computed. [2022-02-20 21:08:26,343 INFO L858 garLoopResultBuilder]: For program point L10810-7(line 10810) no Hoare annotation was computed. [2022-02-20 21:08:26,343 INFO L858 garLoopResultBuilder]: For program point L10810-2(line 10810) no Hoare annotation was computed. [2022-02-20 21:08:26,343 INFO L858 garLoopResultBuilder]: For program point L7123-1(line 7123) no Hoare annotation was computed. [2022-02-20 21:08:26,343 INFO L858 garLoopResultBuilder]: For program point L10810-1(line 10810) no Hoare annotation was computed. [2022-02-20 21:08:26,343 INFO L854 garLoopResultBuilder]: At program point L7123(line 7123) the Hoare annotation is: false [2022-02-20 21:08:26,343 INFO L861 garLoopResultBuilder]: At program point L11318(line 11318) the Hoare annotation is: true [2022-02-20 21:08:26,344 INFO L854 garLoopResultBuilder]: At program point L10806(line 10806) the Hoare annotation is: false [2022-02-20 21:08:26,344 INFO L858 garLoopResultBuilder]: For program point L10810-4(line 10810) no Hoare annotation was computed. [2022-02-20 21:08:26,344 INFO L854 garLoopResultBuilder]: At program point L10810-3(line 10810) the Hoare annotation is: false [2022-02-20 21:08:26,344 INFO L858 garLoopResultBuilder]: For program point L7119-1(line 7119) no Hoare annotation was computed. [2022-02-20 21:08:26,344 INFO L858 garLoopResultBuilder]: For program point L11058-5(line 11058) no Hoare annotation was computed. [2022-02-20 21:08:26,344 INFO L854 garLoopResultBuilder]: At program point L7119(line 7119) the Hoare annotation is: false [2022-02-20 21:08:26,345 INFO L854 garLoopResultBuilder]: At program point L11058-2(line 11058) the Hoare annotation is: false [2022-02-20 21:08:26,345 INFO L854 garLoopResultBuilder]: At program point L10810-9(line 10810) the Hoare annotation is: false [2022-02-20 21:08:26,345 INFO L854 garLoopResultBuilder]: At program point L11058-4(line 11058) the Hoare annotation is: false [2022-02-20 21:08:26,345 INFO L858 garLoopResultBuilder]: For program point L11058-3(line 11058) no Hoare annotation was computed. [2022-02-20 21:08:26,345 INFO L858 garLoopResultBuilder]: For program point L11323(lines 11323 11326) no Hoare annotation was computed. [2022-02-20 21:08:26,345 INFO L854 garLoopResultBuilder]: At program point L11319-3(line 11319) the Hoare annotation is: false [2022-02-20 21:08:26,345 INFO L858 garLoopResultBuilder]: For program point L11319-5(line 11319) no Hoare annotation was computed. [2022-02-20 21:08:26,345 INFO L858 garLoopResultBuilder]: For program point L11319-4(line 11319) no Hoare annotation was computed. [2022-02-20 21:08:26,345 INFO L858 garLoopResultBuilder]: For program point L11059(line 11059) no Hoare annotation was computed. [2022-02-20 21:08:26,345 INFO L854 garLoopResultBuilder]: At program point L10803(lines 10803 10811) the Hoare annotation is: false [2022-02-20 21:08:26,345 INFO L858 garLoopResultBuilder]: For program point L11319-1(line 11319) no Hoare annotation was computed. [2022-02-20 21:08:26,346 INFO L854 garLoopResultBuilder]: At program point L11319(line 11319) the Hoare annotation is: false [2022-02-20 21:08:26,346 INFO L858 garLoopResultBuilder]: For program point L7120-1(lines 7120 7122) no Hoare annotation was computed. [2022-02-20 21:08:26,346 INFO L854 garLoopResultBuilder]: At program point L7120(lines 7120 7122) the Hoare annotation is: false [2022-02-20 21:08:26,346 INFO L858 garLoopResultBuilder]: For program point L11059-3(line 11059) no Hoare annotation was computed. [2022-02-20 21:08:26,346 INFO L854 garLoopResultBuilder]: At program point L11059-2(line 11059) the Hoare annotation is: false [2022-02-20 21:08:26,346 INFO L858 garLoopResultBuilder]: For program point L11059-5(line 11059) no Hoare annotation was computed. [2022-02-20 21:08:26,346 INFO L854 garLoopResultBuilder]: At program point L11059-4(line 11059) the Hoare annotation is: false [2022-02-20 21:08:26,346 INFO L858 garLoopResultBuilder]: For program point L7112(lines 7112 7125) no Hoare annotation was computed. [2022-02-20 21:08:26,346 INFO L858 garLoopResultBuilder]: For program point L223(line 223) no Hoare annotation was computed. [2022-02-20 21:08:26,346 INFO L861 garLoopResultBuilder]: At program point __VERIFIER_assertENTRY(lines 222 224) the Hoare annotation is: true [2022-02-20 21:08:26,346 INFO L858 garLoopResultBuilder]: For program point L223-1(line 223) no Hoare annotation was computed. [2022-02-20 21:08:26,346 INFO L858 garLoopResultBuilder]: For program point L223-3(lines 222 224) no Hoare annotation was computed. [2022-02-20 21:08:26,346 INFO L858 garLoopResultBuilder]: For program point __VERIFIER_assertEXIT(lines 222 224) no Hoare annotation was computed. [2022-02-20 21:08:26,346 INFO L858 garLoopResultBuilder]: For program point __VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION(line 223) no Hoare annotation was computed. [2022-02-20 21:08:26,349 INFO L732 BasicCegarLoop]: Path program histogram: [1, 1, 1, 1, 1] [2022-02-20 21:08:26,350 INFO L180 ceAbstractionStarter]: Computing trace abstraction results [2022-02-20 21:08:26,354 WARN L170 areAnnotationChecker]: nondet_uint64_tFINAL has no Hoare annotation [2022-02-20 21:08:26,354 WARN L170 areAnnotationChecker]: nondet_boolFINAL has no Hoare annotation [2022-02-20 21:08:26,354 WARN L170 areAnnotationChecker]: ULTIMATE.startENTRY has no Hoare annotation [2022-02-20 21:08:26,354 WARN L170 areAnnotationChecker]: L211 has no Hoare annotation [2022-02-20 21:08:26,355 WARN L170 areAnnotationChecker]: L223 has no Hoare annotation [2022-02-20 21:08:26,355 WARN L170 areAnnotationChecker]: aws_c_string_is_validFINAL has no Hoare annotation [2022-02-20 21:08:26,355 WARN L170 areAnnotationChecker]: can_fail_allocatorFINAL has no Hoare annotation [2022-02-20 21:08:26,355 WARN L170 areAnnotationChecker]: L6257 has no Hoare annotation [2022-02-20 21:08:26,355 WARN L170 areAnnotationChecker]: L6814-1 has no Hoare annotation [2022-02-20 21:08:26,355 WARN L170 areAnnotationChecker]: L6896-1 has no Hoare annotation [2022-02-20 21:08:26,355 WARN L170 areAnnotationChecker]: nondet_uint64_tFINAL has no Hoare annotation [2022-02-20 21:08:26,355 WARN L170 areAnnotationChecker]: nondet_boolFINAL has no Hoare annotation [2022-02-20 21:08:26,355 WARN L170 areAnnotationChecker]: L-1 has no Hoare annotation [2022-02-20 21:08:26,356 WARN L170 areAnnotationChecker]: L211 has no Hoare annotation [2022-02-20 21:08:26,356 WARN L170 areAnnotationChecker]: L211 has no Hoare annotation [2022-02-20 21:08:26,356 WARN L170 areAnnotationChecker]: L223 has no Hoare annotation [2022-02-20 21:08:26,356 WARN L170 areAnnotationChecker]: L223 has no Hoare annotation [2022-02-20 21:08:26,356 WARN L170 areAnnotationChecker]: aws_c_string_is_validFINAL has no Hoare annotation [2022-02-20 21:08:26,356 WARN L170 areAnnotationChecker]: can_fail_allocatorFINAL has no Hoare annotation [2022-02-20 21:08:26,356 WARN L170 areAnnotationChecker]: L6257 has no Hoare annotation [2022-02-20 21:08:26,356 WARN L170 areAnnotationChecker]: L6257 has no Hoare annotation [2022-02-20 21:08:26,356 WARN L170 areAnnotationChecker]: L6814-1 has no Hoare annotation [2022-02-20 21:08:26,357 WARN L170 areAnnotationChecker]: L6896-1 has no Hoare annotation [2022-02-20 21:08:26,357 WARN L170 areAnnotationChecker]: L7690 has no Hoare annotation [2022-02-20 21:08:26,357 WARN L170 areAnnotationChecker]: nondet_uint64_tEXIT has no Hoare annotation [2022-02-20 21:08:26,357 WARN L170 areAnnotationChecker]: nondet_uint64_tEXIT has no Hoare annotation [2022-02-20 21:08:26,357 WARN L170 areAnnotationChecker]: nondet_boolEXIT has no Hoare annotation [2022-02-20 21:08:26,357 WARN L170 areAnnotationChecker]: nondet_boolEXIT has no Hoare annotation [2022-02-20 21:08:26,357 WARN L170 areAnnotationChecker]: L11318-1 has no Hoare annotation [2022-02-20 21:08:26,358 WARN L170 areAnnotationChecker]: L211-2 has no Hoare annotation [2022-02-20 21:08:26,358 WARN L170 areAnnotationChecker]: L223-1 has no Hoare annotation [2022-02-20 21:08:26,359 WARN L170 areAnnotationChecker]: L223-1 has no Hoare annotation [2022-02-20 21:08:26,359 WARN L170 areAnnotationChecker]: L223-3 has no Hoare annotation [2022-02-20 21:08:26,359 WARN L170 areAnnotationChecker]: aws_c_string_is_validEXIT has no Hoare annotation [2022-02-20 21:08:26,359 WARN L170 areAnnotationChecker]: aws_c_string_is_validEXIT has no Hoare annotation [2022-02-20 21:08:26,359 WARN L170 areAnnotationChecker]: can_fail_allocatorEXIT has no Hoare annotation [2022-02-20 21:08:26,359 WARN L170 areAnnotationChecker]: L6257-2 has no Hoare annotation [2022-02-20 21:08:26,359 WARN L170 areAnnotationChecker]: L6815-1 has no Hoare annotation [2022-02-20 21:08:26,359 WARN L170 areAnnotationChecker]: bounded_mallocFINAL has no Hoare annotation [2022-02-20 21:08:26,359 WARN L170 areAnnotationChecker]: L7690 has no Hoare annotation [2022-02-20 21:08:26,360 WARN L170 areAnnotationChecker]: L7690 has no Hoare annotation [2022-02-20 21:08:26,360 WARN L170 areAnnotationChecker]: L7119-1 has no Hoare annotation [2022-02-20 21:08:26,360 WARN L170 areAnnotationChecker]: L6823-1 has no Hoare annotation [2022-02-20 21:08:26,360 WARN L170 areAnnotationChecker]: L6823-1 has no Hoare annotation [2022-02-20 21:08:26,360 WARN L170 areAnnotationChecker]: L11319-1 has no Hoare annotation [2022-02-20 21:08:26,360 WARN L170 areAnnotationChecker]: L11319-1 has no Hoare annotation [2022-02-20 21:08:26,360 WARN L170 areAnnotationChecker]: L11318-1 has no Hoare annotation [2022-02-20 21:08:26,360 WARN L170 areAnnotationChecker]: assume_abort_if_notEXIT has no Hoare annotation [2022-02-20 21:08:26,360 WARN L170 areAnnotationChecker]: assume_abort_if_notEXIT has no Hoare annotation [2022-02-20 21:08:26,361 WARN L170 areAnnotationChecker]: assume_abort_if_notEXIT has no Hoare annotation [2022-02-20 21:08:26,361 WARN L170 areAnnotationChecker]: assume_abort_if_notEXIT has no Hoare annotation [2022-02-20 21:08:26,361 WARN L170 areAnnotationChecker]: assume_abort_if_notEXIT has no Hoare annotation [2022-02-20 21:08:26,361 WARN L170 areAnnotationChecker]: assume_abort_if_notEXIT has no Hoare annotation [2022-02-20 21:08:26,361 WARN L170 areAnnotationChecker]: assume_abort_if_notEXIT has no Hoare annotation [2022-02-20 21:08:26,361 WARN L170 areAnnotationChecker]: assume_abort_if_notEXIT has no Hoare annotation [2022-02-20 21:08:26,361 WARN L170 areAnnotationChecker]: assume_abort_if_notEXIT has no Hoare annotation [2022-02-20 21:08:26,361 WARN L170 areAnnotationChecker]: __VERIFIER_assertEXIT has no Hoare annotation [2022-02-20 21:08:26,361 WARN L170 areAnnotationChecker]: __VERIFIER_assertEXIT has no Hoare annotation [2022-02-20 21:08:26,362 WARN L170 areAnnotationChecker]: __VERIFIER_assertEXIT has no Hoare annotation [2022-02-20 21:08:26,362 WARN L170 areAnnotationChecker]: __VERIFIER_assertEXIT has no Hoare annotation [2022-02-20 21:08:26,362 WARN L170 areAnnotationChecker]: L10810-1 has no Hoare annotation [2022-02-20 21:08:26,362 WARN L170 areAnnotationChecker]: L10810-4 has no Hoare annotation [2022-02-20 21:08:26,362 WARN L170 areAnnotationChecker]: L6823-3 has no Hoare annotation [2022-02-20 21:08:26,362 WARN L170 areAnnotationChecker]: L6257-3 has no Hoare annotation [2022-02-20 21:08:26,362 WARN L170 areAnnotationChecker]: L6257-3 has no Hoare annotation [2022-02-20 21:08:26,362 WARN L170 areAnnotationChecker]: L6815-1 has no Hoare annotation [2022-02-20 21:08:26,362 WARN L170 areAnnotationChecker]: bounded_mallocEXIT has no Hoare annotation [2022-02-20 21:08:26,362 WARN L170 areAnnotationChecker]: aws_array_eqFINAL has no Hoare annotation [2022-02-20 21:08:26,363 WARN L170 areAnnotationChecker]: L7699 has no Hoare annotation [2022-02-20 21:08:26,363 WARN L170 areAnnotationChecker]: L7699 has no Hoare annotation [2022-02-20 21:08:26,363 WARN L170 areAnnotationChecker]: L7120-1 has no Hoare annotation [2022-02-20 21:08:26,364 WARN L170 areAnnotationChecker]: L6823-3 has no Hoare annotation [2022-02-20 21:08:26,364 WARN L170 areAnnotationChecker]: L6823-5 has no Hoare annotation [2022-02-20 21:08:26,364 WARN L170 areAnnotationChecker]: L11319-5 has no Hoare annotation [2022-02-20 21:08:26,364 WARN L170 areAnnotationChecker]: L11319-4 has no Hoare annotation [2022-02-20 21:08:26,364 WARN L170 areAnnotationChecker]: L11319-1 has no Hoare annotation [2022-02-20 21:08:26,364 WARN L170 areAnnotationChecker]: L10805-2 has no Hoare annotation [2022-02-20 21:08:26,364 WARN L170 areAnnotationChecker]: L10806-2 has no Hoare annotation [2022-02-20 21:08:26,364 WARN L170 areAnnotationChecker]: L11058-5 has no Hoare annotation [2022-02-20 21:08:26,365 WARN L170 areAnnotationChecker]: L11059-5 has no Hoare annotation [2022-02-20 21:08:26,365 WARN L170 areAnnotationChecker]: L7120-1 has no Hoare annotation [2022-02-20 21:08:26,365 WARN L170 areAnnotationChecker]: L10810-7 has no Hoare annotation [2022-02-20 21:08:26,365 WARN L170 areAnnotationChecker]: L11324-1 has no Hoare annotation [2022-02-20 21:08:26,365 WARN L170 areAnnotationChecker]: L7113-1 has no Hoare annotation [2022-02-20 21:08:26,365 WARN L170 areAnnotationChecker]: L7113-1 has no Hoare annotation [2022-02-20 21:08:26,365 WARN L170 areAnnotationChecker]: L7123-1 has no Hoare annotation [2022-02-20 21:08:26,365 WARN L170 areAnnotationChecker]: L10810-2 has no Hoare annotation [2022-02-20 21:08:26,365 WARN L170 areAnnotationChecker]: L10810-2 has no Hoare annotation [2022-02-20 21:08:26,365 WARN L170 areAnnotationChecker]: L10810-7 has no Hoare annotation [2022-02-20 21:08:26,366 WARN L170 areAnnotationChecker]: L6257-5 has no Hoare annotation [2022-02-20 21:08:26,366 WARN L170 areAnnotationChecker]: L6820-1 has no Hoare annotation [2022-02-20 21:08:26,368 WARN L170 areAnnotationChecker]: L6820-1 has no Hoare annotation [2022-02-20 21:08:26,368 WARN L170 areAnnotationChecker]: aws_array_eqEXIT has no Hoare annotation [2022-02-20 21:08:26,368 WARN L170 areAnnotationChecker]: ensure_string_is_allocated_bounded_lengthFINAL has no Hoare annotation [2022-02-20 21:08:26,368 WARN L170 areAnnotationChecker]: L11319-4 has no Hoare annotation [2022-02-20 21:08:26,368 WARN L170 areAnnotationChecker]: L11058 has no Hoare annotation [2022-02-20 21:08:26,368 WARN L170 areAnnotationChecker]: L11058 has no Hoare annotation [2022-02-20 21:08:26,368 WARN L170 areAnnotationChecker]: L11059 has no Hoare annotation [2022-02-20 21:08:26,368 WARN L170 areAnnotationChecker]: L11059 has no Hoare annotation [2022-02-20 21:08:26,369 WARN L170 areAnnotationChecker]: L11060 has no Hoare annotation [2022-02-20 21:08:26,369 WARN L170 areAnnotationChecker]: L11060 has no Hoare annotation [2022-02-20 21:08:26,369 WARN L170 areAnnotationChecker]: L7123-1 has no Hoare annotation [2022-02-20 21:08:26,369 WARN L170 areAnnotationChecker]: L11323 has no Hoare annotation [2022-02-20 21:08:26,369 WARN L170 areAnnotationChecker]: L7113-1 has no Hoare annotation [2022-02-20 21:08:26,369 WARN L170 areAnnotationChecker]: L7119-1 has no Hoare annotation [2022-02-20 21:08:26,369 WARN L170 areAnnotationChecker]: L7112 has no Hoare annotation [2022-02-20 21:08:26,369 WARN L170 areAnnotationChecker]: L10810-4 has no Hoare annotation [2022-02-20 21:08:26,369 WARN L170 areAnnotationChecker]: aws_string_is_validFINAL has no Hoare annotation [2022-02-20 21:08:26,370 WARN L170 areAnnotationChecker]: L6823-1 has no Hoare annotation [2022-02-20 21:08:26,370 WARN L170 areAnnotationChecker]: L11074-1 has no Hoare annotation [2022-02-20 21:08:26,370 WARN L170 areAnnotationChecker]: ensure_string_is_allocated_bounded_lengthFINAL has no Hoare annotation [2022-02-20 21:08:26,370 WARN L170 areAnnotationChecker]: L10805-2 has no Hoare annotation [2022-02-20 21:08:26,370 WARN L170 areAnnotationChecker]: L10806-2 has no Hoare annotation [2022-02-20 21:08:26,370 WARN L170 areAnnotationChecker]: L11058-5 has no Hoare annotation [2022-02-20 21:08:26,370 WARN L170 areAnnotationChecker]: L11058-3 has no Hoare annotation [2022-02-20 21:08:26,370 WARN L170 areAnnotationChecker]: L11059-5 has no Hoare annotation [2022-02-20 21:08:26,370 WARN L170 areAnnotationChecker]: L11059-3 has no Hoare annotation [2022-02-20 21:08:26,371 WARN L170 areAnnotationChecker]: L11065 has no Hoare annotation [2022-02-20 21:08:26,371 WARN L170 areAnnotationChecker]: L11065 has no Hoare annotation [2022-02-20 21:08:26,371 WARN L170 areAnnotationChecker]: L11323 has no Hoare annotation [2022-02-20 21:08:26,371 WARN L170 areAnnotationChecker]: L11323 has no Hoare annotation [2022-02-20 21:08:26,371 WARN L170 areAnnotationChecker]: L11317 has no Hoare annotation [2022-02-20 21:08:26,371 WARN L170 areAnnotationChecker]: aws_string_is_validEXIT has no Hoare annotation [2022-02-20 21:08:26,371 WARN L170 areAnnotationChecker]: aws_string_is_validEXIT has no Hoare annotation [2022-02-20 21:08:26,372 WARN L170 areAnnotationChecker]: aws_string_is_validEXIT has no Hoare annotation [2022-02-20 21:08:26,372 WARN L170 areAnnotationChecker]: aws_string_is_validEXIT has no Hoare annotation [2022-02-20 21:08:26,372 WARN L170 areAnnotationChecker]: ensure_string_is_allocated_bounded_lengthEXIT has no Hoare annotation [2022-02-20 21:08:26,372 WARN L170 areAnnotationChecker]: ensure_string_is_allocated_bounded_lengthEXIT has no Hoare annotation [2022-02-20 21:08:26,372 WARN L170 areAnnotationChecker]: L11058-3 has no Hoare annotation [2022-02-20 21:08:26,372 WARN L170 areAnnotationChecker]: L11059-3 has no Hoare annotation [2022-02-20 21:08:26,372 WARN L170 areAnnotationChecker]: L10810-1 has no Hoare annotation [2022-02-20 21:08:26,372 WARN L170 areAnnotationChecker]: L11074-1 has no Hoare annotation [2022-02-20 21:08:26,372 WARN L170 areAnnotationChecker]: L11324-1 has no Hoare annotation [2022-02-20 21:08:26,373 WARN L170 areAnnotationChecker]: ULTIMATE.startFINAL has no Hoare annotation [2022-02-20 21:08:26,373 WARN L170 areAnnotationChecker]: ULTIMATE.startFINAL has no Hoare annotation [2022-02-20 21:08:26,373 INFO L163 areAnnotationChecker]: CFG has 33 edges. 33 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. 0 times interpolants missing. [2022-02-20 21:08:26,384 INFO L202 PluginConnector]: Adding new model de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction CFG 20.02 09:08:26 BoogieIcfgContainer [2022-02-20 21:08:26,384 INFO L132 PluginConnector]: ------------------------ END TraceAbstraction---------------------------- [2022-02-20 21:08:26,385 INFO L113 PluginConnector]: ------------------------Witness Printer---------------------------- [2022-02-20 21:08:26,385 INFO L271 PluginConnector]: Initializing Witness Printer... [2022-02-20 21:08:26,385 INFO L275 PluginConnector]: Witness Printer initialized [2022-02-20 21:08:26,385 INFO L185 PluginConnector]: Executing the observer RCFGCatcher from plugin Witness Printer for "de.uni_freiburg.informatik.ultimate.plugins.generator.rcfgbuilder CFG 20.02 09:08:08" (3/4) ... [2022-02-20 21:08:26,388 INFO L137 WitnessPrinter]: Generating witness for correct program [2022-02-20 21:08:26,392 INFO L354 RCFGBacktranslator]: Ignoring RootEdge to procedure ensure_string_is_allocated_bounded_length [2022-02-20 21:08:26,393 INFO L354 RCFGBacktranslator]: Ignoring RootEdge to procedure bounded_malloc [2022-02-20 21:08:26,393 INFO L354 RCFGBacktranslator]: Ignoring RootEdge to procedure aws_array_eq [2022-02-20 21:08:26,393 INFO L354 RCFGBacktranslator]: Ignoring RootEdge to procedure nondet_uint64_t [2022-02-20 21:08:26,393 INFO L354 RCFGBacktranslator]: Ignoring RootEdge to procedure nondet_bool [2022-02-20 21:08:26,393 INFO L354 RCFGBacktranslator]: Ignoring RootEdge to procedure assume_abort_if_not [2022-02-20 21:08:26,393 INFO L354 RCFGBacktranslator]: Ignoring RootEdge to procedure __VERIFIER_assert [2022-02-20 21:08:26,393 INFO L354 RCFGBacktranslator]: Ignoring RootEdge to procedure aws_c_string_is_valid [2022-02-20 21:08:26,394 INFO L354 RCFGBacktranslator]: Ignoring RootEdge to procedure can_fail_allocator [2022-02-20 21:08:26,394 INFO L354 RCFGBacktranslator]: Ignoring RootEdge to procedure aws_string_is_valid [2022-02-20 21:08:26,407 INFO L910 BoogieBacktranslator]: Reduced CFG by removing 29 nodes and edges [2022-02-20 21:08:26,408 INFO L910 BoogieBacktranslator]: Reduced CFG by removing 9 nodes and edges [2022-02-20 21:08:26,409 INFO L910 BoogieBacktranslator]: Reduced CFG by removing 2 nodes and edges [2022-02-20 21:08:26,409 INFO L910 BoogieBacktranslator]: Reduced CFG by removing 1 nodes and edges [2022-02-20 21:08:26,443 WARN L220 nessWitnessGenerator]: Not writing invariant because ACSL is forbidden: ((!(str == 0) && !(\old(max_size) == 96)) && !(\result == 0)) && (\old(max_size) == max_size || max_size + -96 == 0) [2022-02-20 21:08:26,558 INFO L141 WitnessManager]: Wrote witness to /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/witness.graphml [2022-02-20 21:08:26,558 INFO L132 PluginConnector]: ------------------------ END Witness Printer---------------------------- [2022-02-20 21:08:26,559 INFO L158 Benchmark]: Toolchain (without parser) took 21817.67ms. Allocated memory was 73.4MB in the beginning and 352.3MB in the end (delta: 278.9MB). Free memory was 39.5MB in the beginning and 146.0MB in the end (delta: -106.5MB). Peak memory consumption was 170.8MB. Max. memory is 16.1GB. [2022-02-20 21:08:26,559 INFO L158 Benchmark]: CDTParser took 0.19ms. Allocated memory is still 73.4MB. Free memory was 52.3MB in the beginning and 52.2MB in the end (delta: 41.4kB). There was no memory consumed. Max. memory is 16.1GB. [2022-02-20 21:08:26,560 INFO L158 Benchmark]: CACSL2BoogieTranslator took 3184.52ms. Allocated memory was 73.4MB in the beginning and 153.1MB in the end (delta: 79.7MB). Free memory was 39.3MB in the beginning and 74.9MB in the end (delta: -35.6MB). Peak memory consumption was 65.8MB. Max. memory is 16.1GB. [2022-02-20 21:08:26,560 INFO L158 Benchmark]: Boogie Procedure Inliner took 200.77ms. Allocated memory is still 153.1MB. Free memory was 74.9MB in the beginning and 61.8MB in the end (delta: 13.1MB). Peak memory consumption was 12.6MB. Max. memory is 16.1GB. [2022-02-20 21:08:26,560 INFO L158 Benchmark]: Boogie Preprocessor took 96.46ms. Allocated memory is still 153.1MB. Free memory was 61.8MB in the beginning and 53.9MB in the end (delta: 7.9MB). Peak memory consumption was 8.4MB. Max. memory is 16.1GB. [2022-02-20 21:08:26,561 INFO L158 Benchmark]: RCFGBuilder took 763.78ms. Allocated memory is still 153.1MB. Free memory was 53.9MB in the beginning and 51.3MB in the end (delta: 2.6MB). Peak memory consumption was 6.5MB. Max. memory is 16.1GB. [2022-02-20 21:08:26,561 INFO L158 Benchmark]: TraceAbstraction took 17390.36ms. Allocated memory was 153.1MB in the beginning and 352.3MB in the end (delta: 199.2MB). Free memory was 51.3MB in the beginning and 165.4MB in the end (delta: -114.1MB). Peak memory consumption was 85.9MB. Max. memory is 16.1GB. [2022-02-20 21:08:26,561 INFO L158 Benchmark]: Witness Printer took 173.27ms. Allocated memory is still 352.3MB. Free memory was 165.4MB in the beginning and 146.0MB in the end (delta: 19.4MB). Peak memory consumption was 16.8MB. Max. memory is 16.1GB. [2022-02-20 21:08:26,563 INFO L339 ainManager$Toolchain]: ####################### End [Toolchain 1] ####################### --- Results --- * Results from de.uni_freiburg.informatik.ultimate.core: - AssertionsEnabledResult: Assertions are enabled Assertions are enabled - StatisticsResult: Toolchain Benchmarks Benchmark results are: * CDTParser took 0.19ms. Allocated memory is still 73.4MB. Free memory was 52.3MB in the beginning and 52.2MB in the end (delta: 41.4kB). There was no memory consumed. Max. memory is 16.1GB. * CACSL2BoogieTranslator took 3184.52ms. Allocated memory was 73.4MB in the beginning and 153.1MB in the end (delta: 79.7MB). Free memory was 39.3MB in the beginning and 74.9MB in the end (delta: -35.6MB). Peak memory consumption was 65.8MB. Max. memory is 16.1GB. * Boogie Procedure Inliner took 200.77ms. Allocated memory is still 153.1MB. Free memory was 74.9MB in the beginning and 61.8MB in the end (delta: 13.1MB). Peak memory consumption was 12.6MB. Max. memory is 16.1GB. * Boogie Preprocessor took 96.46ms. Allocated memory is still 153.1MB. Free memory was 61.8MB in the beginning and 53.9MB in the end (delta: 7.9MB). Peak memory consumption was 8.4MB. Max. memory is 16.1GB. * RCFGBuilder took 763.78ms. Allocated memory is still 153.1MB. Free memory was 53.9MB in the beginning and 51.3MB in the end (delta: 2.6MB). Peak memory consumption was 6.5MB. Max. memory is 16.1GB. * TraceAbstraction took 17390.36ms. Allocated memory was 153.1MB in the beginning and 352.3MB in the end (delta: 199.2MB). Free memory was 51.3MB in the beginning and 165.4MB in the end (delta: -114.1MB). Peak memory consumption was 85.9MB. Max. memory is 16.1GB. * Witness Printer took 173.27ms. Allocated memory is still 352.3MB. Free memory was 165.4MB in the beginning and 146.0MB in the end (delta: 19.4MB). Peak memory consumption was 16.8MB. Max. memory is 16.1GB. * Results from de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction: - StatisticsResult: ErrorAutomatonStatistics NumberErrorTraces: 0, NumberStatementsAllTraces: 0, NumberRelevantStatements: 0, 0.0s ErrorAutomatonConstructionTimeTotal, 0.0s FaulLocalizationTime, NumberStatementsFirstTrace: -1, TraceLengthAvg: 0, 0.0s ErrorAutomatonConstructionTimeAvg, 0.0s ErrorAutomatonDifferenceTimeAvg, 0.0s ErrorAutomatonDifferenceTimeTotal, NumberOfNoEnhancement: 0, NumberOfFiniteEnhancement: 0, NumberOfInfiniteEnhancement: 0 - PositiveResult [Line: 223]: call to reach_error is unreachable For all program executions holds that call to reach_error is unreachable at this location - StatisticsResult: Ultimate Automizer benchmark data CFG has 11 procedures, 110 locations, 1 error locations. Started 1 CEGAR loops. OverallTime: 17.3s, OverallIterations: 5, TraceHistogramMax: 8, PathProgramHistogramMax: 1, EmptinessCheckTime: 0.0s, AutomataDifference: 8.7s, DeadEndRemovalTime: 0.0s, HoareAnnotationTime: 0.2s, InitialAbstractionConstructionTime: 0.0s, PartialOrderReductionTime: 0.0s, HoareTripleCheckerStatistics: 0 mSolverCounterUnknown, 507 SdHoareTripleChecker+Valid, 1.7s IncrementalHoareTripleChecker+Time, 0 mSdLazyCounter, 455 mSDsluCounter, 4031 SdHoareTripleChecker+Invalid, 1.7s Time, 0 mProtectedAction, 0 SdHoareTripleChecker+Unchecked, 0 IncrementalHoareTripleChecker+Unchecked, 3453 mSDsCounter, 264 IncrementalHoareTripleChecker+Valid, 0 mProtectedPredicate, 1198 IncrementalHoareTripleChecker+Invalid, 1462 SdHoareTripleChecker+Unknown, 0 mSolverCounterNotChecked, 264 mSolverCounterUnsat, 578 mSDtfsCounter, 1198 mSolverCounterSat, 0.0s SdHoareTripleChecker+Time, 0 IncrementalHoareTripleChecker+Unknown, PredicateUnifierStatistics: 0 DeclaredPredicates, 695 GetRequests, 591 SyntacticMatches, 0 SemanticMatches, 104 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 259 ImplicationChecksByTransitivity, 1.4s Time, 0.0s BasicInterpolantAutomatonTime, BiggestAbstraction: size=125occurred in iteration=3, InterpolantAutomatonStates: 52, traceCheckStatistics: No data available, InterpolantConsolidationStatistics: No data available, PathInvariantsStatistics: No data available, 0/0 InterpolantCoveringCapability, TotalInterpolationStatistics: No data available, 0.0s DumpTime, AutomataMinimizationStatistics: 0.3s AutomataMinimizationTime, 5 MinimizatonAttempts, 114 StatesRemovedByMinimization, 3 NontrivialMinimizations, HoareAnnotationStatistics: 0.0s HoareAnnotationTime, 42 LocationsWithAnnotation, 155 PreInvPairs, 163 NumberOfFragments, 239 HoareAnnotationTreeSize, 155 FomulaSimplifications, 18 FormulaSimplificationTreeSizeReduction, 0.0s HoareSimplificationTime, 42 FomulaSimplificationsInter, 104 FormulaSimplificationTreeSizeReductionInter, 0.1s HoareSimplificationTimeInter, RefinementEngineStatistics: TRACE_CHECK: 0.1s SsaConstructionTime, 0.6s SatisfiabilityAnalysisTime, 5.6s InterpolantComputationTime, 861 NumberOfCodeBlocks, 861 NumberOfCodeBlocksAsserted, 8 NumberOfCheckSat, 982 ConstructedInterpolants, 0 QuantifiedInterpolants, 2090 SizeOfPredicates, 27 NumberOfNonLiveVariables, 2896 ConjunctsInSsa, 79 ConjunctsInUnsatCore, 9 InterpolantComputations, 4 PerfectInterpolantSequences, 819/909 InterpolantCoveringCapability, INVARIANT_SYNTHESIS: No data available, INTERPOLANT_CONSOLIDATION: No data available, ABSTRACT_INTERPRETATION: No data available, PDR: No data available, ACCELERATED_INTERPOLATION: No data available, SIFA: No data available, ReuseStatistics: No data available - AllSpecificationsHoldResult: All specifications hold 1 specifications checked. All of them hold - InvariantResult [Line: 6819]: Loop Invariant Derived loop invariant: ((!(str == 0) && !(\old(max_size) == 96)) && !(\result == 0)) && (\old(max_size) == max_size || max_size + -96 == 0) - InvariantResult [Line: 10803]: Loop Invariant Derived loop invariant: 0 - InvariantResult [Line: 11056]: Loop Invariant Derived loop invariant: 0 - InvariantResult [Line: 10810]: Loop Invariant Derived loop invariant: 0 - InvariantResult [Line: 11328]: Loop Invariant Derived loop invariant: 1 RESULT: Ultimate proved your program to be correct! [2022-02-20 21:08:26,597 INFO L540 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 SMTLIB2_COMPLIANT=true -memory:2024 -smt2 -in -t:2000 (1)] Forceful destruction successful, exit code 0 Received shutdown request... --- End real Ultimate output --- Execution finished normally Writing output log to file Ultimate.log Result: TRUE