./Ultimate.py --spec ../sv-benchmarks/c/properties/unreach-call.prp --file ../sv-benchmarks/c/ldv-commit-tester/m0_drivers-hwmon-ibmpex-ko--130_7a--d631323.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/ldv-commit-tester/m0_drivers-hwmon-ibmpex-ko--130_7a--d631323.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 e4e522f7269f01a0f0108ec2341cf17a6d715eaf63b892b25236d9e51e23a874 --- Real Ultimate output --- This is Ultimate 0.2.2-dev-03d7b7b [2022-02-20 21:35:13,698 INFO L177 SettingsManager]: Resetting all preferences to default values... [2022-02-20 21:35:13,700 INFO L181 SettingsManager]: Resetting UltimateCore preferences to default values [2022-02-20 21:35:13,727 INFO L184 SettingsManager]: Ultimate Commandline Interface provides no preferences, ignoring... [2022-02-20 21:35:13,728 INFO L181 SettingsManager]: Resetting Boogie Preprocessor preferences to default values [2022-02-20 21:35:13,729 INFO L181 SettingsManager]: Resetting Boogie Procedure Inliner preferences to default values [2022-02-20 21:35:13,730 INFO L181 SettingsManager]: Resetting Abstract Interpretation preferences to default values [2022-02-20 21:35:13,731 INFO L181 SettingsManager]: Resetting LassoRanker preferences to default values [2022-02-20 21:35:13,733 INFO L181 SettingsManager]: Resetting Reaching Definitions preferences to default values [2022-02-20 21:35:13,734 INFO L181 SettingsManager]: Resetting SyntaxChecker preferences to default values [2022-02-20 21:35:13,734 INFO L181 SettingsManager]: Resetting Sifa preferences to default values [2022-02-20 21:35:13,735 INFO L184 SettingsManager]: Büchi Program Product provides no preferences, ignoring... [2022-02-20 21:35:13,736 INFO L181 SettingsManager]: Resetting LTL2Aut preferences to default values [2022-02-20 21:35:13,737 INFO L181 SettingsManager]: Resetting PEA to Boogie preferences to default values [2022-02-20 21:35:13,738 INFO L181 SettingsManager]: Resetting BlockEncodingV2 preferences to default values [2022-02-20 21:35:13,738 INFO L181 SettingsManager]: Resetting ChcToBoogie preferences to default values [2022-02-20 21:35:13,739 INFO L181 SettingsManager]: Resetting AutomataScriptInterpreter preferences to default values [2022-02-20 21:35:13,740 INFO L181 SettingsManager]: Resetting BuchiAutomizer preferences to default values [2022-02-20 21:35:13,742 INFO L181 SettingsManager]: Resetting CACSL2BoogieTranslator preferences to default values [2022-02-20 21:35:13,743 INFO L181 SettingsManager]: Resetting CodeCheck preferences to default values [2022-02-20 21:35:13,745 INFO L181 SettingsManager]: Resetting InvariantSynthesis preferences to default values [2022-02-20 21:35:13,746 INFO L181 SettingsManager]: Resetting RCFGBuilder preferences to default values [2022-02-20 21:35:13,747 INFO L181 SettingsManager]: Resetting Referee preferences to default values [2022-02-20 21:35:13,748 INFO L181 SettingsManager]: Resetting TraceAbstraction preferences to default values [2022-02-20 21:35:13,750 INFO L184 SettingsManager]: TraceAbstractionConcurrent provides no preferences, ignoring... [2022-02-20 21:35:13,750 INFO L184 SettingsManager]: TraceAbstractionWithAFAs provides no preferences, ignoring... [2022-02-20 21:35:13,751 INFO L181 SettingsManager]: Resetting TreeAutomizer preferences to default values [2022-02-20 21:35:13,751 INFO L181 SettingsManager]: Resetting IcfgToChc preferences to default values [2022-02-20 21:35:13,752 INFO L181 SettingsManager]: Resetting IcfgTransformer preferences to default values [2022-02-20 21:35:13,753 INFO L184 SettingsManager]: ReqToTest provides no preferences, ignoring... [2022-02-20 21:35:13,753 INFO L181 SettingsManager]: Resetting Boogie Printer preferences to default values [2022-02-20 21:35:13,754 INFO L181 SettingsManager]: Resetting ChcSmtPrinter preferences to default values [2022-02-20 21:35:13,754 INFO L181 SettingsManager]: Resetting ReqPrinter preferences to default values [2022-02-20 21:35:13,755 INFO L181 SettingsManager]: Resetting Witness Printer preferences to default values [2022-02-20 21:35:13,756 INFO L184 SettingsManager]: Boogie PL CUP Parser provides no preferences, ignoring... [2022-02-20 21:35:13,756 INFO L181 SettingsManager]: Resetting CDTParser preferences to default values [2022-02-20 21:35:13,757 INFO L184 SettingsManager]: AutomataScriptParser provides no preferences, ignoring... [2022-02-20 21:35:13,757 INFO L184 SettingsManager]: ReqParser provides no preferences, ignoring... [2022-02-20 21:35:13,757 INFO L181 SettingsManager]: Resetting SmtParser preferences to default values [2022-02-20 21:35:13,758 INFO L181 SettingsManager]: Resetting Witness Parser preferences to default values [2022-02-20 21:35:13,758 INFO L188 SettingsManager]: Finished resetting all preferences to default values... [2022-02-20 21:35:13,759 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:35:13,776 INFO L113 SettingsManager]: Loading preferences was successful [2022-02-20 21:35:13,776 INFO L115 SettingsManager]: Preferences different from defaults after loading the file: [2022-02-20 21:35:13,776 INFO L136 SettingsManager]: Preferences of UltimateCore differ from their defaults: [2022-02-20 21:35:13,777 INFO L138 SettingsManager]: * Log level for class=de.uni_freiburg.informatik.ultimate.lib.smtlibutils.quantifier.QuantifierPusher=ERROR; [2022-02-20 21:35:13,777 INFO L136 SettingsManager]: Preferences of Boogie Procedure Inliner differ from their defaults: [2022-02-20 21:35:13,777 INFO L138 SettingsManager]: * Ignore calls to procedures called more than once=ONLY_FOR_SEQUENTIAL_PROGRAMS [2022-02-20 21:35:13,778 INFO L136 SettingsManager]: Preferences of BlockEncodingV2 differ from their defaults: [2022-02-20 21:35:13,778 INFO L138 SettingsManager]: * Create parallel compositions if possible=false [2022-02-20 21:35:13,778 INFO L138 SettingsManager]: * Use SBE=true [2022-02-20 21:35:13,779 INFO L136 SettingsManager]: Preferences of CACSL2BoogieTranslator differ from their defaults: [2022-02-20 21:35:13,779 INFO L138 SettingsManager]: * Overapproximate operations on floating types=true [2022-02-20 21:35:13,779 INFO L138 SettingsManager]: * Check division by zero=IGNORE [2022-02-20 21:35:13,779 INFO L138 SettingsManager]: * Pointer to allocated memory at dereference=IGNORE [2022-02-20 21:35:13,779 INFO L138 SettingsManager]: * If two pointers are subtracted or compared they have the same base address=IGNORE [2022-02-20 21:35:13,779 INFO L138 SettingsManager]: * Check array bounds for arrays that are off heap=IGNORE [2022-02-20 21:35:13,780 INFO L138 SettingsManager]: * Check if freed pointer was valid=false [2022-02-20 21:35:13,780 INFO L138 SettingsManager]: * Use constant arrays=true [2022-02-20 21:35:13,780 INFO L138 SettingsManager]: * Pointer base address is valid at dereference=IGNORE [2022-02-20 21:35:13,780 INFO L136 SettingsManager]: Preferences of RCFGBuilder differ from their defaults: [2022-02-20 21:35:13,780 INFO L138 SettingsManager]: * Size of a code block=SequenceOfStatements [2022-02-20 21:35:13,781 INFO L138 SettingsManager]: * SMT solver=External_DefaultMode [2022-02-20 21:35:13,781 INFO L138 SettingsManager]: * Command for external solver=z3 SMTLIB2_COMPLIANT=true -memory:2024 -smt2 -in -t:2000 [2022-02-20 21:35:13,781 INFO L136 SettingsManager]: Preferences of TraceAbstraction differ from their defaults: [2022-02-20 21:35:13,781 INFO L138 SettingsManager]: * Compute Interpolants along a Counterexample=FPandBP [2022-02-20 21:35:13,781 INFO L138 SettingsManager]: * Positions where we compute the Hoare Annotation=LoopsAndPotentialCycles [2022-02-20 21:35:13,782 INFO L138 SettingsManager]: * Trace refinement strategy=CAMEL [2022-02-20 21:35:13,782 INFO L138 SettingsManager]: * Command for external solver=z3 SMTLIB2_COMPLIANT=true -memory:2024 -smt2 -in [2022-02-20 21:35:13,782 INFO L138 SettingsManager]: * Large block encoding in concurrent analysis=OFF [2022-02-20 21:35:13,782 INFO L138 SettingsManager]: * Automaton type used in concurrency analysis=PETRI_NET [2022-02-20 21:35:13,782 INFO L138 SettingsManager]: * Compute Hoare Annotation of negated interpolant automaton, abstraction and CFG=true [2022-02-20 21:35:13,783 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 -> e4e522f7269f01a0f0108ec2341cf17a6d715eaf63b892b25236d9e51e23a874 [2022-02-20 21:35:13,965 INFO L75 nceAwareModelManager]: Repository-Root is: /tmp [2022-02-20 21:35:13,996 INFO L261 ainManager$Toolchain]: [Toolchain 1]: Applicable parser(s) successfully (re)initialized [2022-02-20 21:35:13,997 INFO L217 ainManager$Toolchain]: [Toolchain 1]: Toolchain selected. [2022-02-20 21:35:13,998 INFO L271 PluginConnector]: Initializing CDTParser... [2022-02-20 21:35:13,999 INFO L275 PluginConnector]: CDTParser initialized [2022-02-20 21:35:13,999 INFO L432 ainManager$Toolchain]: [Toolchain 1]: Parsing single file: /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/../sv-benchmarks/c/ldv-commit-tester/m0_drivers-hwmon-ibmpex-ko--130_7a--d631323.i [2022-02-20 21:35:14,053 INFO L220 CDTParser]: Created temporary CDT project at /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/data/895b4194a/7bfd982e335b4437a3c258eb63495ce8/FLAGd9709b36f [2022-02-20 21:35:14,593 INFO L306 CDTParser]: Found 1 translation units. [2022-02-20 21:35:14,593 INFO L160 CDTParser]: Scanning /storage/repos/ultimate/releaseScripts/default/sv-benchmarks/c/ldv-commit-tester/m0_drivers-hwmon-ibmpex-ko--130_7a--d631323.i [2022-02-20 21:35:14,622 INFO L349 CDTParser]: About to delete temporary CDT project at /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/data/895b4194a/7bfd982e335b4437a3c258eb63495ce8/FLAGd9709b36f [2022-02-20 21:35:15,074 INFO L357 CDTParser]: Successfully deleted /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/data/895b4194a/7bfd982e335b4437a3c258eb63495ce8 [2022-02-20 21:35:15,077 INFO L299 ainManager$Toolchain]: ####################### [Toolchain 1] ####################### [2022-02-20 21:35:15,078 INFO L131 ToolchainWalker]: Walking toolchain with 6 elements. [2022-02-20 21:35:15,087 INFO L113 PluginConnector]: ------------------------CACSL2BoogieTranslator---------------------------- [2022-02-20 21:35:15,088 INFO L271 PluginConnector]: Initializing CACSL2BoogieTranslator... [2022-02-20 21:35:15,090 INFO L275 PluginConnector]: CACSL2BoogieTranslator initialized [2022-02-20 21:35:15,091 INFO L185 PluginConnector]: Executing the observer ACSLObjectContainerObserver from plugin CACSL2BoogieTranslator for "CDTParser AST 20.02 09:35:15" (1/1) ... [2022-02-20 21:35:15,092 INFO L205 PluginConnector]: Invalid model from CACSL2BoogieTranslator for observer de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator.ACSLObjectContainerObserver@69b7ff22 and model type de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 09:35:15, skipping insertion in model container [2022-02-20 21:35:15,093 INFO L185 PluginConnector]: Executing the observer CACSL2BoogieTranslatorObserver from plugin CACSL2BoogieTranslator for "CDTParser AST 20.02 09:35:15" (1/1) ... [2022-02-20 21:35:15,098 INFO L145 MainTranslator]: Starting translation in SV-COMP mode [2022-02-20 21:35:15,153 INFO L178 MainTranslator]: Built tables and reachable declarations [2022-02-20 21:35:15,676 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/ldv-commit-tester/m0_drivers-hwmon-ibmpex-ko--130_7a--d631323.i[71148,71161] [2022-02-20 21:35:15,690 INFO L210 PostProcessor]: Analyzing one entry point: main [2022-02-20 21:35:15,705 INFO L203 MainTranslator]: Completed pre-run [2022-02-20 21:35:15,826 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/ldv-commit-tester/m0_drivers-hwmon-ibmpex-ko--130_7a--d631323.i[71148,71161] [2022-02-20 21:35:15,840 INFO L210 PostProcessor]: Analyzing one entry point: main [2022-02-20 21:35:15,887 INFO L208 MainTranslator]: Completed translation [2022-02-20 21:35:15,888 INFO L202 PluginConnector]: Adding new model de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 09:35:15 WrapperNode [2022-02-20 21:35:15,888 INFO L132 PluginConnector]: ------------------------ END CACSL2BoogieTranslator---------------------------- [2022-02-20 21:35:15,889 INFO L113 PluginConnector]: ------------------------Boogie Procedure Inliner---------------------------- [2022-02-20 21:35:15,889 INFO L271 PluginConnector]: Initializing Boogie Procedure Inliner... [2022-02-20 21:35:15,889 INFO L275 PluginConnector]: Boogie Procedure Inliner initialized [2022-02-20 21:35:15,895 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:35:15" (1/1) ... [2022-02-20 21:35:15,949 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:35:15" (1/1) ... [2022-02-20 21:35:16,035 INFO L137 Inliner]: procedures = 102, calls = 421, calls flagged for inlining = 48, calls inlined = 43, statements flattened = 1101 [2022-02-20 21:35:16,035 INFO L132 PluginConnector]: ------------------------ END Boogie Procedure Inliner---------------------------- [2022-02-20 21:35:16,036 INFO L113 PluginConnector]: ------------------------Boogie Preprocessor---------------------------- [2022-02-20 21:35:16,036 INFO L271 PluginConnector]: Initializing Boogie Preprocessor... [2022-02-20 21:35:16,036 INFO L275 PluginConnector]: Boogie Preprocessor initialized [2022-02-20 21:35:16,044 INFO L185 PluginConnector]: Executing the observer EnsureBoogieModelObserver from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 09:35:15" (1/1) ... [2022-02-20 21:35:16,044 INFO L185 PluginConnector]: Executing the observer TypeChecker from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 09:35:15" (1/1) ... [2022-02-20 21:35:16,057 INFO L185 PluginConnector]: Executing the observer ConstExpander from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 09:35:15" (1/1) ... [2022-02-20 21:35:16,058 INFO L185 PluginConnector]: Executing the observer StructExpander from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 09:35:15" (1/1) ... [2022-02-20 21:35:16,112 INFO L185 PluginConnector]: Executing the observer UnstructureCode from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 09:35:15" (1/1) ... [2022-02-20 21:35:16,128 INFO L185 PluginConnector]: Executing the observer FunctionInliner from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 09:35:15" (1/1) ... [2022-02-20 21:35:16,138 INFO L185 PluginConnector]: Executing the observer BoogieSymbolTableConstructor from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 09:35:15" (1/1) ... [2022-02-20 21:35:16,150 INFO L132 PluginConnector]: ------------------------ END Boogie Preprocessor---------------------------- [2022-02-20 21:35:16,155 INFO L113 PluginConnector]: ------------------------RCFGBuilder---------------------------- [2022-02-20 21:35:16,155 INFO L271 PluginConnector]: Initializing RCFGBuilder... [2022-02-20 21:35:16,155 INFO L275 PluginConnector]: RCFGBuilder initialized [2022-02-20 21:35:16,156 INFO L185 PluginConnector]: Executing the observer RCFGBuilderObserver from plugin RCFGBuilder for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 09:35:15" (1/1) ... [2022-02-20 21:35:16,165 INFO L173 SolverBuilder]: Constructing external solver with command: z3 SMTLIB2_COMPLIANT=true -memory:2024 -smt2 -in -t:2000 [2022-02-20 21:35:16,175 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-02-20 21:35:16,188 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:35:16,203 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:35:16,227 INFO L130 BoogieDeclarations]: Found specification of procedure write~unchecked~int [2022-02-20 21:35:16,227 INFO L130 BoogieDeclarations]: Found specification of procedure read~unchecked~$Pointer$ [2022-02-20 21:35:16,227 INFO L130 BoogieDeclarations]: Found specification of procedure write~unchecked~$Pointer$ [2022-02-20 21:35:16,227 INFO L130 BoogieDeclarations]: Found specification of procedure read~int [2022-02-20 21:35:16,228 INFO L130 BoogieDeclarations]: Found specification of procedure ldv_malloc [2022-02-20 21:35:16,228 INFO L138 BoogieDeclarations]: Found implementation of procedure ldv_malloc [2022-02-20 21:35:16,228 INFO L130 BoogieDeclarations]: Found specification of procedure kfree [2022-02-20 21:35:16,228 INFO L138 BoogieDeclarations]: Found implementation of procedure kfree [2022-02-20 21:35:16,228 INFO L130 BoogieDeclarations]: Found specification of procedure write~int [2022-02-20 21:35:16,228 INFO L130 BoogieDeclarations]: Found specification of procedure ldv_error [2022-02-20 21:35:16,228 INFO L138 BoogieDeclarations]: Found implementation of procedure ldv_error [2022-02-20 21:35:16,228 INFO L130 BoogieDeclarations]: Found specification of procedure extract_value [2022-02-20 21:35:16,228 INFO L138 BoogieDeclarations]: Found implementation of procedure extract_value [2022-02-20 21:35:16,229 INFO L130 BoogieDeclarations]: Found specification of procedure #Ultimate.allocOnHeap [2022-02-20 21:35:16,229 INFO L130 BoogieDeclarations]: Found specification of procedure #Ultimate.allocInit [2022-02-20 21:35:16,229 INFO L130 BoogieDeclarations]: Found specification of procedure ipmi_destroy_user [2022-02-20 21:35:16,229 INFO L138 BoogieDeclarations]: Found implementation of procedure ipmi_destroy_user [2022-02-20 21:35:16,229 INFO L130 BoogieDeclarations]: Found specification of procedure write~$Pointer$ [2022-02-20 21:35:16,229 INFO L130 BoogieDeclarations]: Found specification of procedure wait_for_completion [2022-02-20 21:35:16,229 INFO L138 BoogieDeclarations]: Found implementation of procedure wait_for_completion [2022-02-20 21:35:16,230 INFO L130 BoogieDeclarations]: Found specification of procedure #Ultimate.allocOnStack [2022-02-20 21:35:16,230 INFO L130 BoogieDeclarations]: Found specification of procedure memcmp [2022-02-20 21:35:16,230 INFO L130 BoogieDeclarations]: Found specification of procedure ibmpex_bmc_delete [2022-02-20 21:35:16,230 INFO L138 BoogieDeclarations]: Found implementation of procedure ibmpex_bmc_delete [2022-02-20 21:35:16,230 INFO L130 BoogieDeclarations]: Found specification of procedure read~$Pointer$ [2022-02-20 21:35:16,230 INFO L130 BoogieDeclarations]: Found specification of procedure ldv_is_err [2022-02-20 21:35:16,230 INFO L138 BoogieDeclarations]: Found implementation of procedure ldv_is_err [2022-02-20 21:35:16,231 INFO L130 BoogieDeclarations]: Found specification of procedure ibmpex_send_message [2022-02-20 21:35:16,231 INFO L138 BoogieDeclarations]: Found implementation of procedure ibmpex_send_message [2022-02-20 21:35:16,231 INFO L130 BoogieDeclarations]: Found specification of procedure dev_set_drvdata [2022-02-20 21:35:16,231 INFO L138 BoogieDeclarations]: Found implementation of procedure dev_set_drvdata [2022-02-20 21:35:16,231 INFO L130 BoogieDeclarations]: Found specification of procedure ULTIMATE.dealloc [2022-02-20 21:35:16,231 INFO L130 BoogieDeclarations]: Found specification of procedure write~init~$Pointer$ [2022-02-20 21:35:16,231 INFO L130 BoogieDeclarations]: Found specification of procedure ldv_device_create_file_dev_attr_of_sensor_device_attribute [2022-02-20 21:35:16,232 INFO L138 BoogieDeclarations]: Found implementation of procedure ldv_device_create_file_dev_attr_of_sensor_device_attribute [2022-02-20 21:35:16,232 INFO L130 BoogieDeclarations]: Found specification of procedure hwmon_device_unregister [2022-02-20 21:35:16,232 INFO L138 BoogieDeclarations]: Found implementation of procedure hwmon_device_unregister [2022-02-20 21:35:16,232 INFO L130 BoogieDeclarations]: Found specification of procedure kzalloc [2022-02-20 21:35:16,232 INFO L138 BoogieDeclarations]: Found implementation of procedure kzalloc [2022-02-20 21:35:16,232 INFO L130 BoogieDeclarations]: Found specification of procedure kmalloc [2022-02-20 21:35:16,232 INFO L138 BoogieDeclarations]: Found implementation of procedure kmalloc [2022-02-20 21:35:16,232 INFO L130 BoogieDeclarations]: Found specification of procedure write~init~int [2022-02-20 21:35:16,232 INFO L130 BoogieDeclarations]: Found specification of procedure ldv_handler_precall [2022-02-20 21:35:16,232 INFO L138 BoogieDeclarations]: Found implementation of procedure ldv_handler_precall [2022-02-20 21:35:16,233 INFO L130 BoogieDeclarations]: Found specification of procedure ipmi_free_recv_msg [2022-02-20 21:35:16,233 INFO L138 BoogieDeclarations]: Found implementation of procedure ipmi_free_recv_msg [2022-02-20 21:35:16,233 INFO L130 BoogieDeclarations]: Found specification of procedure read~unchecked~int [2022-02-20 21:35:16,233 INFO L130 BoogieDeclarations]: Found specification of procedure device_remove_file [2022-02-20 21:35:16,233 INFO L138 BoogieDeclarations]: Found implementation of procedure device_remove_file [2022-02-20 21:35:16,233 INFO L130 BoogieDeclarations]: Found specification of procedure ULTIMATE.start [2022-02-20 21:35:16,233 INFO L138 BoogieDeclarations]: Found implementation of procedure ULTIMATE.start [2022-02-20 21:35:16,499 INFO L234 CfgBuilder]: Building ICFG [2022-02-20 21:35:16,501 INFO L260 CfgBuilder]: Building CFG for each procedure with an implementation [2022-02-20 21:35:17,554 INFO L275 CfgBuilder]: Performing block encoding [2022-02-20 21:35:17,564 INFO L294 CfgBuilder]: Using the 1 location(s) as analysis (start of procedure ULTIMATE.start) [2022-02-20 21:35:17,564 INFO L299 CfgBuilder]: Removed 0 assume(true) statements. [2022-02-20 21:35:17,566 INFO L202 PluginConnector]: Adding new model de.uni_freiburg.informatik.ultimate.plugins.generator.rcfgbuilder CFG 20.02 09:35:17 BoogieIcfgContainer [2022-02-20 21:35:17,566 INFO L132 PluginConnector]: ------------------------ END RCFGBuilder---------------------------- [2022-02-20 21:35:17,567 INFO L113 PluginConnector]: ------------------------TraceAbstraction---------------------------- [2022-02-20 21:35:17,568 INFO L271 PluginConnector]: Initializing TraceAbstraction... [2022-02-20 21:35:17,570 INFO L275 PluginConnector]: TraceAbstraction initialized [2022-02-20 21:35:17,570 INFO L185 PluginConnector]: Executing the observer TraceAbstractionObserver from plugin TraceAbstraction for "CDTParser AST 20.02 09:35:15" (1/3) ... [2022-02-20 21:35:17,571 INFO L205 PluginConnector]: Invalid model from TraceAbstraction for observer de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction.TraceAbstractionObserver@1575e0f and model type de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction AST 20.02 09:35:17, skipping insertion in model container [2022-02-20 21:35:17,571 INFO L185 PluginConnector]: Executing the observer TraceAbstractionObserver from plugin TraceAbstraction for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 09:35:15" (2/3) ... [2022-02-20 21:35:17,571 INFO L205 PluginConnector]: Invalid model from TraceAbstraction for observer de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction.TraceAbstractionObserver@1575e0f and model type de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction AST 20.02 09:35:17, skipping insertion in model container [2022-02-20 21:35:17,572 INFO L185 PluginConnector]: Executing the observer TraceAbstractionObserver from plugin TraceAbstraction for "de.uni_freiburg.informatik.ultimate.plugins.generator.rcfgbuilder CFG 20.02 09:35:17" (3/3) ... [2022-02-20 21:35:17,573 INFO L111 eAbstractionObserver]: Analyzing ICFG m0_drivers-hwmon-ibmpex-ko--130_7a--d631323.i [2022-02-20 21:35:17,577 INFO L205 ceAbstractionStarter]: Automizer settings: Hoare:true NWA Interpolation:FPandBP Determinization: PREDICATE_ABSTRACTION [2022-02-20 21:35:17,577 INFO L164 ceAbstractionStarter]: Applying trace abstraction to program that has 1 error locations. [2022-02-20 21:35:17,628 INFO L338 AbstractCegarLoop]: ======== Iteration 0 == of CEGAR loop == AllErrorsAtOnce ======== [2022-02-20 21:35:17,636 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:35:17,636 INFO L340 AbstractCegarLoop]: Starting to check reachability of 1 error locations. [2022-02-20 21:35:17,675 INFO L276 IsEmpty]: Start isEmpty. Operand has 275 states, 209 states have (on average 1.2966507177033493) internal successors, (271), 214 states have internal predecessors, (271), 47 states have call successors, (47), 17 states have call predecessors, (47), 17 states have return successors, (47), 47 states have call predecessors, (47), 47 states have call successors, (47) [2022-02-20 21:35:17,696 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 123 [2022-02-20 21:35:17,696 INFO L506 BasicCegarLoop]: Found error trace [2022-02-20 21:35:17,697 INFO L514 BasicCegarLoop]: trace histogram [3, 3, 3, 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, 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:35:17,698 INFO L402 AbstractCegarLoop]: === Iteration 1 === Targeting ldv_errorErr0ASSERT_VIOLATIONERROR_FUNCTION === [ldv_errorErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-02-20 21:35:17,705 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-02-20 21:35:17,705 INFO L85 PathProgramCache]: Analyzing trace with hash -1527877958, now seen corresponding path program 1 times [2022-02-20 21:35:17,718 INFO L126 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-02-20 21:35:17,718 INFO L338 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [588113376] [2022-02-20 21:35:17,718 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 21:35:17,719 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-02-20 21:35:18,055 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:18,246 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 3 [2022-02-20 21:35:18,251 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:18,276 INFO L290 TraceCheckUtils]: 0: Hoare triple {278#true} assume true; {278#true} is VALID [2022-02-20 21:35:18,276 INFO L284 TraceCheckUtils]: 1: Hoare quadruple {278#true} {278#true} #612#return; {278#true} is VALID [2022-02-20 21:35:18,277 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 14 [2022-02-20 21:35:18,282 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:18,292 INFO L290 TraceCheckUtils]: 0: Hoare triple {278#true} assume true; {278#true} is VALID [2022-02-20 21:35:18,293 INFO L284 TraceCheckUtils]: 1: Hoare quadruple {278#true} {278#true} #614#return; {278#true} is VALID [2022-02-20 21:35:18,299 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 18 [2022-02-20 21:35:18,305 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:18,315 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:35:18,326 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:18,334 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:35:18,336 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:18,340 INFO L290 TraceCheckUtils]: 0: Hoare triple {344#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {278#true} is VALID [2022-02-20 21:35:18,341 INFO L290 TraceCheckUtils]: 1: Hoare triple {278#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {278#true} is VALID [2022-02-20 21:35:18,341 INFO L290 TraceCheckUtils]: 2: Hoare triple {278#true} assume true; {278#true} is VALID [2022-02-20 21:35:18,341 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {278#true} {278#true} #590#return; {278#true} is VALID [2022-02-20 21:35:18,342 INFO L290 TraceCheckUtils]: 0: Hoare triple {344#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {278#true} is VALID [2022-02-20 21:35:18,343 INFO L272 TraceCheckUtils]: 1: Hoare triple {278#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {344#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:18,343 INFO L290 TraceCheckUtils]: 2: Hoare triple {344#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {278#true} is VALID [2022-02-20 21:35:18,344 INFO L290 TraceCheckUtils]: 3: Hoare triple {278#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {278#true} is VALID [2022-02-20 21:35:18,344 INFO L290 TraceCheckUtils]: 4: Hoare triple {278#true} assume true; {278#true} is VALID [2022-02-20 21:35:18,345 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {278#true} {278#true} #590#return; {278#true} is VALID [2022-02-20 21:35:18,345 INFO L290 TraceCheckUtils]: 6: Hoare triple {278#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {278#true} is VALID [2022-02-20 21:35:18,345 INFO L290 TraceCheckUtils]: 7: Hoare triple {278#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {278#true} is VALID [2022-02-20 21:35:18,346 INFO L290 TraceCheckUtils]: 8: Hoare triple {278#true} assume true; {278#true} is VALID [2022-02-20 21:35:18,347 INFO L284 TraceCheckUtils]: 9: Hoare quadruple {278#true} {278#true} #588#return; {278#true} is VALID [2022-02-20 21:35:18,348 INFO L290 TraceCheckUtils]: 0: Hoare triple {344#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size;~flags := #in~flags;havoc ~tmp~2.base, ~tmp~2.offset; {278#true} is VALID [2022-02-20 21:35:18,349 INFO L272 TraceCheckUtils]: 1: Hoare triple {278#true} call #t~ret40.base, #t~ret40.offset := kmalloc(~size, ~bitwiseOr(~flags, 32768)); {344#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:18,349 INFO L290 TraceCheckUtils]: 2: Hoare triple {344#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {278#true} is VALID [2022-02-20 21:35:18,350 INFO L272 TraceCheckUtils]: 3: Hoare triple {278#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {344#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:18,350 INFO L290 TraceCheckUtils]: 4: Hoare triple {344#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {278#true} is VALID [2022-02-20 21:35:18,351 INFO L290 TraceCheckUtils]: 5: Hoare triple {278#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {278#true} is VALID [2022-02-20 21:35:18,351 INFO L290 TraceCheckUtils]: 6: Hoare triple {278#true} assume true; {278#true} is VALID [2022-02-20 21:35:18,352 INFO L284 TraceCheckUtils]: 7: Hoare quadruple {278#true} {278#true} #590#return; {278#true} is VALID [2022-02-20 21:35:18,354 INFO L290 TraceCheckUtils]: 8: Hoare triple {278#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {278#true} is VALID [2022-02-20 21:35:18,355 INFO L290 TraceCheckUtils]: 9: Hoare triple {278#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {278#true} is VALID [2022-02-20 21:35:18,355 INFO L290 TraceCheckUtils]: 10: Hoare triple {278#true} assume true; {278#true} is VALID [2022-02-20 21:35:18,355 INFO L284 TraceCheckUtils]: 11: Hoare quadruple {278#true} {278#true} #588#return; {278#true} is VALID [2022-02-20 21:35:18,356 INFO L290 TraceCheckUtils]: 12: Hoare triple {278#true} ~tmp~2.base, ~tmp~2.offset := #t~ret40.base, #t~ret40.offset;havoc #t~ret40.base, #t~ret40.offset;#res.base, #res.offset := ~tmp~2.base, ~tmp~2.offset; {278#true} is VALID [2022-02-20 21:35:18,356 INFO L290 TraceCheckUtils]: 13: Hoare triple {278#true} assume true; {278#true} is VALID [2022-02-20 21:35:18,357 INFO L284 TraceCheckUtils]: 14: Hoare quadruple {278#true} {278#true} #616#return; {278#true} is VALID [2022-02-20 21:35:18,365 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 41 [2022-02-20 21:35:18,369 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:18,386 INFO L290 TraceCheckUtils]: 0: Hoare triple {359#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;havoc ~err~0#1;assume { :begin_inline_ipmi_validate_addr } true;ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset, ipmi_validate_addr_#in~arg1#1 := ~data#1.base, 193 + ~data#1.offset, 40;havoc ipmi_validate_addr_#res#1;havoc ipmi_validate_addr_#t~nondet254#1, ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset, ipmi_validate_addr_~arg1#1;ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset := ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset;ipmi_validate_addr_~arg1#1 := ipmi_validate_addr_#in~arg1#1;assume -2147483648 <= ipmi_validate_addr_#t~nondet254#1 && ipmi_validate_addr_#t~nondet254#1 <= 2147483647;ipmi_validate_addr_#res#1 := ipmi_validate_addr_#t~nondet254#1;havoc ipmi_validate_addr_#t~nondet254#1; {278#true} is VALID [2022-02-20 21:35:18,386 INFO L290 TraceCheckUtils]: 1: Hoare triple {278#true} #t~ret62#1 := ipmi_validate_addr_#res#1;assume { :end_inline_ipmi_validate_addr } true;assume -2147483648 <= #t~ret62#1 && #t~ret62#1 <= 2147483647;~err~0#1 := #t~ret62#1;havoc #t~ret62#1; {278#true} is VALID [2022-02-20 21:35:18,386 INFO L290 TraceCheckUtils]: 2: Hoare triple {278#true} assume 0 != ~err~0#1; {278#true} is VALID [2022-02-20 21:35:18,387 INFO L290 TraceCheckUtils]: 3: Hoare triple {278#true} havoc #t~nondet69#1;call #t~mem70#1.base, #t~mem70#1.offset := read~$Pointer$(~data#1.base, 24 + ~data#1.offset, 8);havoc #t~mem70#1.base, #t~mem70#1.offset;#res#1 := ~err~0#1; {278#true} is VALID [2022-02-20 21:35:18,387 INFO L290 TraceCheckUtils]: 4: Hoare triple {278#true} assume true; {278#true} is VALID [2022-02-20 21:35:18,387 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {278#true} {278#true} #618#return; {278#true} is VALID [2022-02-20 21:35:18,387 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 49 [2022-02-20 21:35:18,389 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:18,396 INFO L290 TraceCheckUtils]: 0: Hoare triple {278#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset; {278#true} is VALID [2022-02-20 21:35:18,397 INFO L290 TraceCheckUtils]: 1: Hoare triple {278#true} assume true; {278#true} is VALID [2022-02-20 21:35:18,397 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {278#true} {278#true} #620#return; {278#true} is VALID [2022-02-20 21:35:18,397 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 58 [2022-02-20 21:35:18,401 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:18,408 INFO L290 TraceCheckUtils]: 0: Hoare triple {344#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {278#true} is VALID [2022-02-20 21:35:18,408 INFO L290 TraceCheckUtils]: 1: Hoare triple {278#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {278#true} is VALID [2022-02-20 21:35:18,409 INFO L290 TraceCheckUtils]: 2: Hoare triple {278#true} assume true; {278#true} is VALID [2022-02-20 21:35:18,409 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {278#true} {279#false} #624#return; {279#false} is VALID [2022-02-20 21:35:18,409 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 65 [2022-02-20 21:35:18,418 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:18,424 INFO L290 TraceCheckUtils]: 0: Hoare triple {278#true} ~ptr.base, ~ptr.offset := #in~ptr.base, #in~ptr.offset;#res := (if (~ptr.base + ~ptr.offset) % 18446744073709551616 > 2012 then 1 else 0); {278#true} is VALID [2022-02-20 21:35:18,427 INFO L290 TraceCheckUtils]: 1: Hoare triple {278#true} assume true; {278#true} is VALID [2022-02-20 21:35:18,427 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {278#true} {279#false} #626#return; {279#false} is VALID [2022-02-20 21:35:18,427 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 72 [2022-02-20 21:35:18,430 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:18,437 INFO L290 TraceCheckUtils]: 0: Hoare triple {278#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset;~arg1.base, ~arg1.offset := #in~arg1.base, #in~arg1.offset; {278#true} is VALID [2022-02-20 21:35:18,437 INFO L290 TraceCheckUtils]: 1: Hoare triple {278#true} assume true; {278#true} is VALID [2022-02-20 21:35:18,437 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {278#true} {279#false} #628#return; {279#false} is VALID [2022-02-20 21:35:18,438 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 79 [2022-02-20 21:35:18,441 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:18,452 INFO L290 TraceCheckUtils]: 0: Hoare triple {359#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;havoc ~err~0#1;assume { :begin_inline_ipmi_validate_addr } true;ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset, ipmi_validate_addr_#in~arg1#1 := ~data#1.base, 193 + ~data#1.offset, 40;havoc ipmi_validate_addr_#res#1;havoc ipmi_validate_addr_#t~nondet254#1, ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset, ipmi_validate_addr_~arg1#1;ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset := ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset;ipmi_validate_addr_~arg1#1 := ipmi_validate_addr_#in~arg1#1;assume -2147483648 <= ipmi_validate_addr_#t~nondet254#1 && ipmi_validate_addr_#t~nondet254#1 <= 2147483647;ipmi_validate_addr_#res#1 := ipmi_validate_addr_#t~nondet254#1;havoc ipmi_validate_addr_#t~nondet254#1; {278#true} is VALID [2022-02-20 21:35:18,452 INFO L290 TraceCheckUtils]: 1: Hoare triple {278#true} #t~ret62#1 := ipmi_validate_addr_#res#1;assume { :end_inline_ipmi_validate_addr } true;assume -2147483648 <= #t~ret62#1 && #t~ret62#1 <= 2147483647;~err~0#1 := #t~ret62#1;havoc #t~ret62#1; {278#true} is VALID [2022-02-20 21:35:18,452 INFO L290 TraceCheckUtils]: 2: Hoare triple {278#true} assume 0 != ~err~0#1; {278#true} is VALID [2022-02-20 21:35:18,453 INFO L290 TraceCheckUtils]: 3: Hoare triple {278#true} havoc #t~nondet69#1;call #t~mem70#1.base, #t~mem70#1.offset := read~$Pointer$(~data#1.base, 24 + ~data#1.offset, 8);havoc #t~mem70#1.base, #t~mem70#1.offset;#res#1 := ~err~0#1; {278#true} is VALID [2022-02-20 21:35:18,453 INFO L290 TraceCheckUtils]: 4: Hoare triple {278#true} assume true; {278#true} is VALID [2022-02-20 21:35:18,453 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {278#true} {279#false} #630#return; {279#false} is VALID [2022-02-20 21:35:18,453 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 87 [2022-02-20 21:35:18,455 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:18,459 INFO L290 TraceCheckUtils]: 0: Hoare triple {278#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset; {278#true} is VALID [2022-02-20 21:35:18,459 INFO L290 TraceCheckUtils]: 1: Hoare triple {278#true} assume true; {278#true} is VALID [2022-02-20 21:35:18,460 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {278#true} {279#false} #632#return; {279#false} is VALID [2022-02-20 21:35:18,460 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 96 [2022-02-20 21:35:18,489 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:18,495 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:35:18,500 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:18,506 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:35:18,509 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:18,513 INFO L290 TraceCheckUtils]: 0: Hoare triple {344#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {278#true} is VALID [2022-02-20 21:35:18,513 INFO L290 TraceCheckUtils]: 1: Hoare triple {278#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {278#true} is VALID [2022-02-20 21:35:18,514 INFO L290 TraceCheckUtils]: 2: Hoare triple {278#true} assume true; {278#true} is VALID [2022-02-20 21:35:18,514 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {278#true} {278#true} #590#return; {278#true} is VALID [2022-02-20 21:35:18,514 INFO L290 TraceCheckUtils]: 0: Hoare triple {344#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {278#true} is VALID [2022-02-20 21:35:18,515 INFO L272 TraceCheckUtils]: 1: Hoare triple {278#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {344#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:18,515 INFO L290 TraceCheckUtils]: 2: Hoare triple {344#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {278#true} is VALID [2022-02-20 21:35:18,516 INFO L290 TraceCheckUtils]: 3: Hoare triple {278#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {278#true} is VALID [2022-02-20 21:35:18,516 INFO L290 TraceCheckUtils]: 4: Hoare triple {278#true} assume true; {278#true} is VALID [2022-02-20 21:35:18,516 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {278#true} {278#true} #590#return; {278#true} is VALID [2022-02-20 21:35:18,516 INFO L290 TraceCheckUtils]: 6: Hoare triple {278#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {278#true} is VALID [2022-02-20 21:35:18,516 INFO L290 TraceCheckUtils]: 7: Hoare triple {278#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {278#true} is VALID [2022-02-20 21:35:18,517 INFO L290 TraceCheckUtils]: 8: Hoare triple {278#true} assume true; {278#true} is VALID [2022-02-20 21:35:18,517 INFO L284 TraceCheckUtils]: 9: Hoare quadruple {278#true} {278#true} #588#return; {278#true} is VALID [2022-02-20 21:35:18,517 INFO L290 TraceCheckUtils]: 0: Hoare triple {344#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size;~flags := #in~flags;havoc ~tmp~2.base, ~tmp~2.offset; {278#true} is VALID [2022-02-20 21:35:18,518 INFO L272 TraceCheckUtils]: 1: Hoare triple {278#true} call #t~ret40.base, #t~ret40.offset := kmalloc(~size, ~bitwiseOr(~flags, 32768)); {344#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:18,518 INFO L290 TraceCheckUtils]: 2: Hoare triple {344#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {278#true} is VALID [2022-02-20 21:35:18,519 INFO L272 TraceCheckUtils]: 3: Hoare triple {278#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {344#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:18,520 INFO L290 TraceCheckUtils]: 4: Hoare triple {344#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {278#true} is VALID [2022-02-20 21:35:18,520 INFO L290 TraceCheckUtils]: 5: Hoare triple {278#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {278#true} is VALID [2022-02-20 21:35:18,521 INFO L290 TraceCheckUtils]: 6: Hoare triple {278#true} assume true; {278#true} is VALID [2022-02-20 21:35:18,521 INFO L284 TraceCheckUtils]: 7: Hoare quadruple {278#true} {278#true} #590#return; {278#true} is VALID [2022-02-20 21:35:18,521 INFO L290 TraceCheckUtils]: 8: Hoare triple {278#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {278#true} is VALID [2022-02-20 21:35:18,521 INFO L290 TraceCheckUtils]: 9: Hoare triple {278#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {278#true} is VALID [2022-02-20 21:35:18,522 INFO L290 TraceCheckUtils]: 10: Hoare triple {278#true} assume true; {278#true} is VALID [2022-02-20 21:35:18,522 INFO L284 TraceCheckUtils]: 11: Hoare quadruple {278#true} {278#true} #588#return; {278#true} is VALID [2022-02-20 21:35:18,522 INFO L290 TraceCheckUtils]: 12: Hoare triple {278#true} ~tmp~2.base, ~tmp~2.offset := #t~ret40.base, #t~ret40.offset;havoc #t~ret40.base, #t~ret40.offset;#res.base, #res.offset := ~tmp~2.base, ~tmp~2.offset; {278#true} is VALID [2022-02-20 21:35:18,522 INFO L290 TraceCheckUtils]: 13: Hoare triple {278#true} assume true; {278#true} is VALID [2022-02-20 21:35:18,522 INFO L284 TraceCheckUtils]: 14: Hoare quadruple {278#true} {279#false} #634#return; {279#false} is VALID [2022-02-20 21:35:18,527 INFO L290 TraceCheckUtils]: 0: Hoare triple {278#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(46, 2);call #Ultimate.allocInit(13, 3);call #Ultimate.allocInit(20, 4);call #Ultimate.allocInit(21, 5);call #Ultimate.allocInit(11, 6);call #Ultimate.allocInit(18, 7);call #Ultimate.allocInit(19, 8);call #Ultimate.allocInit(20, 9);call #Ultimate.allocInit(18, 10);call #Ultimate.allocInit(69, 11);call #Ultimate.allocInit(26, 12);call #Ultimate.allocInit(4, 13);call write~init~int(37, 13, 0, 1);call write~init~int(115, 13, 1, 1);call write~init~int(10, 13, 2, 1);call write~init~int(0, 13, 3, 1);call #Ultimate.allocInit(7, 14);call write~init~int(105, 14, 0, 1);call write~init~int(98, 14, 1, 1);call write~init~int(109, 14, 2, 1);call write~init~int(112, 14, 3, 1);call write~init~int(101, 14, 4, 1);call write~init~int(120, 14, 5, 1);call write~init~int(0, 14, 6, 1);call #Ultimate.allocInit(5, 15);call write~init~int(110, 15, 0, 1);call write~init~int(97, 15, 1, 1);call write~init~int(109, 15, 2, 1);call write~init~int(101, 15, 3, 1);call write~init~int(0, 15, 4, 1);call #Ultimate.allocInit(4, 16);call write~init~int(37, 16, 0, 1);call write~init~int(100, 16, 1, 1);call write~init~int(10, 16, 2, 1);call write~init~int(0, 16, 3, 1);call #Ultimate.allocInit(15, 17);call #Ultimate.allocInit(5, 18);call write~init~int(116, 18, 0, 1);call write~init~int(101, 18, 1, 1);call write~init~int(109, 18, 2, 1);call write~init~int(112, 18, 3, 1);call write~init~int(0, 18, 4, 1);call #Ultimate.allocInit(6, 19);call write~init~int(112, 19, 0, 1);call write~init~int(111, 19, 1, 1);call write~init~int(119, 19, 2, 1);call write~init~int(101, 19, 3, 1);call write~init~int(114, 19, 4, 1);call write~init~int(0, 19, 5, 1);call #Ultimate.allocInit(40, 20);call #Ultimate.allocInit(48, 21);call #Ultimate.allocInit(12, 22);call #Ultimate.allocInit(55, 23);call #Ultimate.allocInit(26, 24);call #Ultimate.allocInit(70, 25);~#power_sensor_sig~0.base, ~#power_sensor_sig~0.offset := 26, 0;call #Ultimate.allocInit(3, 26);call write~init~int(112, ~#power_sensor_sig~0.base, ~#power_sensor_sig~0.offset, 1);call write~init~int(119, ~#power_sensor_sig~0.base, 1 + ~#power_sensor_sig~0.offset, 1);call write~init~int(114, ~#power_sensor_sig~0.base, 2 + ~#power_sensor_sig~0.offset, 1);~#temp_sensor_sig~0.base, ~#temp_sensor_sig~0.offset := 27, 0;call #Ultimate.allocInit(3, 27);call write~init~int(116, ~#temp_sensor_sig~0.base, ~#temp_sensor_sig~0.offset, 1);call write~init~int(101, ~#temp_sensor_sig~0.base, 1 + ~#temp_sensor_sig~0.offset, 1);call write~init~int(109, ~#temp_sensor_sig~0.base, 2 + ~#temp_sensor_sig~0.offset, 1);~#watt_sensor_sig~0.base, ~#watt_sensor_sig~0.offset := 28, 0;call #Ultimate.allocInit(2, 28);call write~init~int(65, ~#watt_sensor_sig~0.base, ~#watt_sensor_sig~0.offset, 1);call write~init~int(67, ~#watt_sensor_sig~0.base, 1 + ~#watt_sensor_sig~0.offset, 1);~#power_sensor_name_templates~0.base, ~#power_sensor_name_templates~0.offset := 29, 0;call #Ultimate.allocInit(24, 29);call write~init~$Pointer$(3, 0, ~#power_sensor_name_templates~0.base, ~#power_sensor_name_templates~0.offset, 8);call write~init~$Pointer$(4, 0, ~#power_sensor_name_templates~0.base, 8 + ~#power_sensor_name_templates~0.offset, 8);call write~init~$Pointer$(5, 0, ~#power_sensor_name_templates~0.base, 16 + ~#power_sensor_name_templates~0.offset, 8);~#temp_sensor_name_templates~0.base, ~#temp_sensor_name_templates~0.offset := 30, 0;call #Ultimate.allocInit(24, 30);call write~init~$Pointer$(6, 0, ~#temp_sensor_name_templates~0.base, ~#temp_sensor_name_templates~0.offset, 8);call write~init~$Pointer$(7, 0, ~#temp_sensor_name_templates~0.base, 8 + ~#temp_sensor_name_templates~0.offset, 8);call write~init~$Pointer$(8, 0, ~#temp_sensor_name_templates~0.base, 16 + ~#temp_sensor_name_templates~0.offset, 8);~#driver_data~0.base, ~#driver_data~0.offset := 31, 0;call #Ultimate.allocInit(72, 31);call write~init~$Pointer$(~#driver_data~0.base, ~#driver_data~0.offset, ~#driver_data~0.base, ~#driver_data~0.offset, 8);call write~init~$Pointer$(~#driver_data~0.base, ~#driver_data~0.offset, ~#driver_data~0.base, 8 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(0, 0, ~#driver_data~0.base, 16 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(0, 0, ~#driver_data~0.base, 24 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(~#__this_module~0.base, ~#__this_module~0.offset, ~#driver_data~0.base, 32 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(#funAddr~ibmpex_register_bmc.base, #funAddr~ibmpex_register_bmc.offset, ~#driver_data~0.base, 40 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(#funAddr~ibmpex_bmc_gone.base, #funAddr~ibmpex_bmc_gone.offset, ~#driver_data~0.base, 48 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(#funAddr~ibmpex_msg_handler.base, #funAddr~ibmpex_msg_handler.offset, ~#driver_data~0.base, 56 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(0, 0, ~#driver_data~0.base, 64 + ~#driver_data~0.offset, 8);~#sensor_dev_attr_name~0.base, ~#sensor_dev_attr_name~0.offset := 32, 0;call #Ultimate.allocInit(48, 32);call write~init~$Pointer$(15, 0, ~#sensor_dev_attr_name~0.base, ~#sensor_dev_attr_name~0.offset, 8);call write~init~int(292, ~#sensor_dev_attr_name~0.base, 8 + ~#sensor_dev_attr_name~0.offset, 4);call write~init~$Pointer$(0, 0, ~#sensor_dev_attr_name~0.base, 12 + ~#sensor_dev_attr_name~0.offset, 8);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 20 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 21 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 22 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 23 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 24 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 25 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 26 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 27 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~$Pointer$(#funAddr~show_name.base, #funAddr~show_name.offset, ~#sensor_dev_attr_name~0.base, 28 + ~#sensor_dev_attr_name~0.offset, 8);call write~init~$Pointer$(0, 0, ~#sensor_dev_attr_name~0.base, 36 + ~#sensor_dev_attr_name~0.offset, 8);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 44 + ~#sensor_dev_attr_name~0.offset, 4);~#sensor_dev_attr_reset_high_low~0.base, ~#sensor_dev_attr_reset_high_low~0.offset := 33, 0;call #Ultimate.allocInit(48, 33);call write~init~$Pointer$(17, 0, ~#sensor_dev_attr_reset_high_low~0.base, ~#sensor_dev_attr_reset_high_low~0.offset, 8);call write~init~int(128, ~#sensor_dev_attr_reset_high_low~0.base, 8 + ~#sensor_dev_attr_reset_high_low~0.offset, 4);call write~init~$Pointer$(0, 0, ~#sensor_dev_attr_reset_high_low~0.base, 12 + ~#sensor_dev_attr_reset_high_low~0.offset, 8);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 20 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 21 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 22 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 23 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 24 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 25 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 26 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 27 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~$Pointer$(0, 0, ~#sensor_dev_attr_reset_high_low~0.base, 28 + ~#sensor_dev_attr_reset_high_low~0.offset, 8);call write~init~$Pointer$(#funAddr~ibmpex_reset_high_low.base, #funAddr~ibmpex_reset_high_low.offset, ~#sensor_dev_attr_reset_high_low~0.base, 36 + ~#sensor_dev_attr_reset_high_low~0.offset, 8);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 44 + ~#sensor_dev_attr_reset_high_low~0.offset, 4);~LDV_IN_INTERRUPT~0 := 0;~ldv_count_1~0 := 0;~ldv_count_2~0 := 0;~ldv_call_dev_attr_of_sensor_device_attribute~0 := 0;~ldv_call_dev_attr_of_sensor_device_attribute_2~0 := 0; {278#true} is VALID [2022-02-20 21:35:18,528 INFO L290 TraceCheckUtils]: 1: Hoare triple {278#true} assume { :end_inline_ULTIMATE.init } true;assume { :begin_inline_main } true;havoc main_#res#1;havoc main_#t~ret236#1, main_#t~nondet237#1, main_#t~switch238#1, main_#t~nondet239#1, main_~var_ibmpex_register_bmc_17_p0~0#1, main_~var_group1~0#1.base, main_~var_group1~0#1.offset, main_~var_ibmpex_bmc_gone_19_p0~0#1, main_~#var_group2~0#1.base, main_~#var_group2~0#1.offset, main_~#var_ibmpex_msg_handler_20_p1~0#1.base, main_~#var_ibmpex_msg_handler_20_p1~0#1.offset, main_~tmp~17#1, main_~tmp___0~4#1, main_~tmp___1~2#1;havoc main_~var_ibmpex_register_bmc_17_p0~0#1;havoc main_~var_group1~0#1.base, main_~var_group1~0#1.offset;havoc main_~var_ibmpex_bmc_gone_19_p0~0#1;call main_~#var_group2~0#1.base, main_~#var_group2~0#1.offset := #Ultimate.allocOnStack(374);call main_~#var_ibmpex_msg_handler_20_p1~0#1.base, main_~#var_ibmpex_msg_handler_20_p1~0#1.offset := #Ultimate.allocOnStack(915);havoc main_~tmp~17#1;havoc main_~tmp___0~4#1;havoc main_~tmp___1~2#1;~LDV_IN_INTERRUPT~0 := 1;assume { :begin_inline_ldv_initialize } true;~ldv_count_1~0 := 1 + ~ldv_count_1~0;~ldv_count_1~0 := 1 + ~ldv_count_1~0;~ldv_count_1~0 := 1 + ~ldv_count_1~0;~ldv_count_1~0 := 1 + ~ldv_count_1~0;~ldv_count_1~0 := 1 + ~ldv_count_1~0;~ldv_count_1~0 := 1 + ~ldv_count_1~0; {278#true} is VALID [2022-02-20 21:35:18,528 INFO L290 TraceCheckUtils]: 2: Hoare triple {278#true} assume { :end_inline_ldv_initialize } true; {278#true} is VALID [2022-02-20 21:35:18,528 INFO L272 TraceCheckUtils]: 3: Hoare triple {278#true} call ldv_handler_precall(); {278#true} is VALID [2022-02-20 21:35:18,529 INFO L290 TraceCheckUtils]: 4: Hoare triple {278#true} assume true; {278#true} is VALID [2022-02-20 21:35:18,529 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {278#true} {278#true} #612#return; {278#true} is VALID [2022-02-20 21:35:18,529 INFO L290 TraceCheckUtils]: 6: Hoare triple {278#true} assume { :begin_inline_ibmpex_init } true;havoc ibmpex_init_#res#1;havoc ibmpex_init_#t~ret231#1, ibmpex_init_~tmp~16#1;havoc ibmpex_init_~tmp~16#1;assume { :begin_inline_ipmi_smi_watcher_register } true;ipmi_smi_watcher_register_#in~arg0#1.base, ipmi_smi_watcher_register_#in~arg0#1.offset := ~#driver_data~0.base, 16 + ~#driver_data~0.offset;havoc ipmi_smi_watcher_register_#res#1;havoc ipmi_smi_watcher_register_#t~nondet252#1, ipmi_smi_watcher_register_~arg0#1.base, ipmi_smi_watcher_register_~arg0#1.offset;ipmi_smi_watcher_register_~arg0#1.base, ipmi_smi_watcher_register_~arg0#1.offset := ipmi_smi_watcher_register_#in~arg0#1.base, ipmi_smi_watcher_register_#in~arg0#1.offset;assume -2147483648 <= ipmi_smi_watcher_register_#t~nondet252#1 && ipmi_smi_watcher_register_#t~nondet252#1 <= 2147483647;ipmi_smi_watcher_register_#res#1 := ipmi_smi_watcher_register_#t~nondet252#1;havoc ipmi_smi_watcher_register_#t~nondet252#1; {278#true} is VALID [2022-02-20 21:35:18,529 INFO L290 TraceCheckUtils]: 7: Hoare triple {278#true} ibmpex_init_#t~ret231#1 := ipmi_smi_watcher_register_#res#1;assume { :end_inline_ipmi_smi_watcher_register } true;assume -2147483648 <= ibmpex_init_#t~ret231#1 && ibmpex_init_#t~ret231#1 <= 2147483647;ibmpex_init_~tmp~16#1 := ibmpex_init_#t~ret231#1;havoc ibmpex_init_#t~ret231#1;ibmpex_init_#res#1 := ibmpex_init_~tmp~16#1; {278#true} is VALID [2022-02-20 21:35:18,531 INFO L290 TraceCheckUtils]: 8: Hoare triple {278#true} main_#t~ret236#1 := ibmpex_init_#res#1;assume { :end_inline_ibmpex_init } true;assume -2147483648 <= main_#t~ret236#1 && main_#t~ret236#1 <= 2147483647;main_~tmp~17#1 := main_#t~ret236#1;havoc main_#t~ret236#1; {278#true} is VALID [2022-02-20 21:35:18,532 INFO L290 TraceCheckUtils]: 9: Hoare triple {278#true} assume !(0 != main_~tmp~17#1); {278#true} is VALID [2022-02-20 21:35:18,532 INFO L290 TraceCheckUtils]: 10: Hoare triple {278#true} assume -2147483648 <= main_#t~nondet239#1 && main_#t~nondet239#1 <= 2147483647;main_~tmp___1~2#1 := main_#t~nondet239#1;havoc main_#t~nondet239#1; {278#true} is VALID [2022-02-20 21:35:18,532 INFO L290 TraceCheckUtils]: 11: Hoare triple {278#true} assume 0 != main_~tmp___1~2#1; {278#true} is VALID [2022-02-20 21:35:18,532 INFO L290 TraceCheckUtils]: 12: Hoare triple {278#true} assume -2147483648 <= main_#t~nondet237#1 && main_#t~nondet237#1 <= 2147483647;main_~tmp___0~4#1 := main_#t~nondet237#1;havoc main_#t~nondet237#1;main_#t~switch238#1 := 0 == main_~tmp___0~4#1; {278#true} is VALID [2022-02-20 21:35:18,533 INFO L290 TraceCheckUtils]: 13: Hoare triple {278#true} assume main_#t~switch238#1; {278#true} is VALID [2022-02-20 21:35:18,533 INFO L272 TraceCheckUtils]: 14: Hoare triple {278#true} call ldv_handler_precall(); {278#true} is VALID [2022-02-20 21:35:18,533 INFO L290 TraceCheckUtils]: 15: Hoare triple {278#true} assume true; {278#true} is VALID [2022-02-20 21:35:18,533 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {278#true} {278#true} #614#return; {278#true} is VALID [2022-02-20 21:35:18,534 INFO L290 TraceCheckUtils]: 17: Hoare triple {278#true} assume { :begin_inline_ibmpex_register_bmc } true;ibmpex_register_bmc_#in~iface#1, ibmpex_register_bmc_#in~dev#1.base, ibmpex_register_bmc_#in~dev#1.offset := main_~var_ibmpex_register_bmc_17_p0~0#1, main_~var_group1~0#1.base, main_~var_group1~0#1.offset;havoc ibmpex_register_bmc_#t~ret178#1.base, ibmpex_register_bmc_#t~ret178#1.offset, ibmpex_register_bmc_#t~nondet179#1, ibmpex_register_bmc_#t~mem180#1, ibmpex_register_bmc_#t~ret181#1, ibmpex_register_bmc_#t~nondet182#1, ibmpex_register_bmc_#t~mem183#1, ibmpex_register_bmc_#t~ret184#1, ibmpex_register_bmc_#t~mem185#1.base, ibmpex_register_bmc_#t~mem185#1.offset, ibmpex_register_bmc_#t~ret186#1.base, ibmpex_register_bmc_#t~ret186#1.offset, ibmpex_register_bmc_#t~mem187#1.base, ibmpex_register_bmc_#t~mem187#1.offset, ibmpex_register_bmc_#t~ret188#1, ibmpex_register_bmc_#t~nondet189#1, ibmpex_register_bmc_#t~mem190#1.base, ibmpex_register_bmc_#t~mem190#1.offset, ibmpex_register_bmc_#t~mem191#1, ibmpex_register_bmc_#t~ret192#1, ibmpex_register_bmc_#t~nondet193#1, ibmpex_register_bmc_#t~mem194#1.base, ibmpex_register_bmc_#t~mem194#1.offset, ibmpex_register_bmc_#t~mem195#1.base, ibmpex_register_bmc_#t~mem195#1.offset, ibmpex_register_bmc_#t~mem196#1.base, ibmpex_register_bmc_#t~mem196#1.offset, ibmpex_register_bmc_#t~ret197#1, ibmpex_register_bmc_~iface#1, ibmpex_register_bmc_~dev#1.base, ibmpex_register_bmc_~dev#1.offset, ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset, ibmpex_register_bmc_~err~4#1, ibmpex_register_bmc_~tmp~14#1.base, ibmpex_register_bmc_~tmp~14#1.offset, ibmpex_register_bmc_~#__key~1#1.base, ibmpex_register_bmc_~#__key~1#1.offset, ibmpex_register_bmc_~tmp___0~3#1;ibmpex_register_bmc_~iface#1 := ibmpex_register_bmc_#in~iface#1;ibmpex_register_bmc_~dev#1.base, ibmpex_register_bmc_~dev#1.offset := ibmpex_register_bmc_#in~dev#1.base, ibmpex_register_bmc_#in~dev#1.offset;havoc ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset;havoc ibmpex_register_bmc_~err~4#1;havoc ibmpex_register_bmc_~tmp~14#1.base, ibmpex_register_bmc_~tmp~14#1.offset;call ibmpex_register_bmc_~#__key~1#1.base, ibmpex_register_bmc_~#__key~1#1.offset := #Ultimate.allocOnStack(8);havoc ibmpex_register_bmc_~tmp___0~3#1; {278#true} is VALID [2022-02-20 21:35:18,536 INFO L272 TraceCheckUtils]: 18: Hoare triple {278#true} call ibmpex_register_bmc_#t~ret178#1.base, ibmpex_register_bmc_#t~ret178#1.offset := kzalloc(968, 208); {344#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:18,537 INFO L290 TraceCheckUtils]: 19: Hoare triple {344#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size;~flags := #in~flags;havoc ~tmp~2.base, ~tmp~2.offset; {278#true} is VALID [2022-02-20 21:35:18,540 INFO L272 TraceCheckUtils]: 20: Hoare triple {278#true} call #t~ret40.base, #t~ret40.offset := kmalloc(~size, ~bitwiseOr(~flags, 32768)); {344#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:18,541 INFO L290 TraceCheckUtils]: 21: Hoare triple {344#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {278#true} is VALID [2022-02-20 21:35:18,542 INFO L272 TraceCheckUtils]: 22: Hoare triple {278#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {344#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:18,550 INFO L290 TraceCheckUtils]: 23: Hoare triple {344#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {278#true} is VALID [2022-02-20 21:35:18,550 INFO L290 TraceCheckUtils]: 24: Hoare triple {278#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {278#true} is VALID [2022-02-20 21:35:18,550 INFO L290 TraceCheckUtils]: 25: Hoare triple {278#true} assume true; {278#true} is VALID [2022-02-20 21:35:18,550 INFO L284 TraceCheckUtils]: 26: Hoare quadruple {278#true} {278#true} #590#return; {278#true} is VALID [2022-02-20 21:35:18,551 INFO L290 TraceCheckUtils]: 27: Hoare triple {278#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {278#true} is VALID [2022-02-20 21:35:18,551 INFO L290 TraceCheckUtils]: 28: Hoare triple {278#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {278#true} is VALID [2022-02-20 21:35:18,551 INFO L290 TraceCheckUtils]: 29: Hoare triple {278#true} assume true; {278#true} is VALID [2022-02-20 21:35:18,551 INFO L284 TraceCheckUtils]: 30: Hoare quadruple {278#true} {278#true} #588#return; {278#true} is VALID [2022-02-20 21:35:18,552 INFO L290 TraceCheckUtils]: 31: Hoare triple {278#true} ~tmp~2.base, ~tmp~2.offset := #t~ret40.base, #t~ret40.offset;havoc #t~ret40.base, #t~ret40.offset;#res.base, #res.offset := ~tmp~2.base, ~tmp~2.offset; {278#true} is VALID [2022-02-20 21:35:18,552 INFO L290 TraceCheckUtils]: 32: Hoare triple {278#true} assume true; {278#true} is VALID [2022-02-20 21:35:18,552 INFO L284 TraceCheckUtils]: 33: Hoare quadruple {278#true} {278#true} #616#return; {278#true} is VALID [2022-02-20 21:35:18,552 INFO L290 TraceCheckUtils]: 34: Hoare triple {278#true} ibmpex_register_bmc_~tmp~14#1.base, ibmpex_register_bmc_~tmp~14#1.offset := ibmpex_register_bmc_#t~ret178#1.base, ibmpex_register_bmc_#t~ret178#1.offset;havoc ibmpex_register_bmc_#t~ret178#1.base, ibmpex_register_bmc_#t~ret178#1.offset;ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset := ibmpex_register_bmc_~tmp~14#1.base, ibmpex_register_bmc_~tmp~14#1.offset; {278#true} is VALID [2022-02-20 21:35:18,553 INFO L290 TraceCheckUtils]: 35: Hoare triple {278#true} assume !(0 == (ibmpex_register_bmc_~data~2#1.base + ibmpex_register_bmc_~data~2#1.offset) % 18446744073709551616);call write~int(12, ibmpex_register_bmc_~data~2#1.base, 193 + ibmpex_register_bmc_~data~2#1.offset, 4);call write~int(15, ibmpex_register_bmc_~data~2#1.base, 197 + ibmpex_register_bmc_~data~2#1.offset, 2);call write~int(0, ibmpex_register_bmc_~data~2#1.base, 199 + ibmpex_register_bmc_~data~2#1.offset, 1);call write~int(ibmpex_register_bmc_~iface#1, ibmpex_register_bmc_~data~2#1.base, 323 + ibmpex_register_bmc_~data~2#1.offset, 4);call write~$Pointer$(ibmpex_register_bmc_~dev#1.base, ibmpex_register_bmc_~dev#1.offset, ibmpex_register_bmc_~data~2#1.base, 24 + ibmpex_register_bmc_~data~2#1.offset, 8);call ibmpex_register_bmc_#t~mem180#1 := read~int(ibmpex_register_bmc_~data~2#1.base, 323 + ibmpex_register_bmc_~data~2#1.offset, 4);assume { :begin_inline_ipmi_create_user } true;ipmi_create_user_#in~arg0#1, ipmi_create_user_#in~arg1#1.base, ipmi_create_user_#in~arg1#1.offset, ipmi_create_user_#in~arg2#1.base, ipmi_create_user_#in~arg2#1.offset, ipmi_create_user_#in~arg3#1.base, ipmi_create_user_#in~arg3#1.offset := ibmpex_register_bmc_#t~mem180#1, ~#driver_data~0.base, 56 + ~#driver_data~0.offset, ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset, ibmpex_register_bmc_~data~2#1.base, 315 + ibmpex_register_bmc_~data~2#1.offset;havoc ipmi_create_user_#res#1;havoc ipmi_create_user_#t~nondet249#1, ipmi_create_user_~arg0#1, ipmi_create_user_~arg1#1.base, ipmi_create_user_~arg1#1.offset, ipmi_create_user_~arg2#1.base, ipmi_create_user_~arg2#1.offset, ipmi_create_user_~arg3#1.base, ipmi_create_user_~arg3#1.offset;ipmi_create_user_~arg0#1 := ipmi_create_user_#in~arg0#1;ipmi_create_user_~arg1#1.base, ipmi_create_user_~arg1#1.offset := ipmi_create_user_#in~arg1#1.base, ipmi_create_user_#in~arg1#1.offset;ipmi_create_user_~arg2#1.base, ipmi_create_user_~arg2#1.offset := ipmi_create_user_#in~arg2#1.base, ipmi_create_user_#in~arg2#1.offset;ipmi_create_user_~arg3#1.base, ipmi_create_user_~arg3#1.offset := ipmi_create_user_#in~arg3#1.base, ipmi_create_user_#in~arg3#1.offset;assume -2147483648 <= ipmi_create_user_#t~nondet249#1 && ipmi_create_user_#t~nondet249#1 <= 2147483647;ipmi_create_user_#res#1 := ipmi_create_user_#t~nondet249#1;havoc ipmi_create_user_#t~nondet249#1; {278#true} is VALID [2022-02-20 21:35:18,553 INFO L290 TraceCheckUtils]: 36: Hoare triple {278#true} ibmpex_register_bmc_#t~ret181#1 := ipmi_create_user_#res#1;assume { :end_inline_ipmi_create_user } true;assume -2147483648 <= ibmpex_register_bmc_#t~ret181#1 && ibmpex_register_bmc_#t~ret181#1 <= 2147483647;ibmpex_register_bmc_~err~4#1 := ibmpex_register_bmc_#t~ret181#1;havoc ibmpex_register_bmc_#t~mem180#1;havoc ibmpex_register_bmc_#t~ret181#1; {278#true} is VALID [2022-02-20 21:35:18,553 INFO L290 TraceCheckUtils]: 37: Hoare triple {278#true} assume !(ibmpex_register_bmc_~err~4#1 < 0);assume { :begin_inline___mutex_init } true;__mutex_init_#in~arg0#1.base, __mutex_init_#in~arg0#1.offset, __mutex_init_#in~arg1#1.base, __mutex_init_#in~arg1#1.offset, __mutex_init_#in~arg2#1.base, __mutex_init_#in~arg2#1.offset := ibmpex_register_bmc_~data~2#1.base, 32 + ibmpex_register_bmc_~data~2#1.offset, 22, 0, ibmpex_register_bmc_~#__key~1#1.base, ibmpex_register_bmc_~#__key~1#1.offset;havoc __mutex_init_~arg0#1.base, __mutex_init_~arg0#1.offset, __mutex_init_~arg1#1.base, __mutex_init_~arg1#1.offset, __mutex_init_~arg2#1.base, __mutex_init_~arg2#1.offset;__mutex_init_~arg0#1.base, __mutex_init_~arg0#1.offset := __mutex_init_#in~arg0#1.base, __mutex_init_#in~arg0#1.offset;__mutex_init_~arg1#1.base, __mutex_init_~arg1#1.offset := __mutex_init_#in~arg1#1.base, __mutex_init_#in~arg1#1.offset;__mutex_init_~arg2#1.base, __mutex_init_~arg2#1.offset := __mutex_init_#in~arg2#1.base, __mutex_init_#in~arg2#1.offset; {278#true} is VALID [2022-02-20 21:35:18,554 INFO L290 TraceCheckUtils]: 38: Hoare triple {278#true} assume { :end_inline___mutex_init } true;call write~int(0, ibmpex_register_bmc_~data~2#1.base, 611 + ibmpex_register_bmc_~data~2#1.offset, 8);assume { :begin_inline_init_completion } true;init_completion_#in~x#1.base, init_completion_#in~x#1.offset := ibmpex_register_bmc_~data~2#1.base, 231 + ibmpex_register_bmc_~data~2#1.offset;havoc init_completion_~x#1.base, init_completion_~x#1.offset, init_completion_~#__key~0#1.base, init_completion_~#__key~0#1.offset;init_completion_~x#1.base, init_completion_~x#1.offset := init_completion_#in~x#1.base, init_completion_#in~x#1.offset;call init_completion_~#__key~0#1.base, init_completion_~#__key~0#1.offset := #Ultimate.allocOnStack(8);call write~int(0, init_completion_~x#1.base, init_completion_~x#1.offset, 4);assume { :begin_inline___init_waitqueue_head } true;__init_waitqueue_head_#in~arg0#1.base, __init_waitqueue_head_#in~arg0#1.offset, __init_waitqueue_head_#in~arg1#1.base, __init_waitqueue_head_#in~arg1#1.offset := init_completion_~x#1.base, 4 + init_completion_~x#1.offset, init_completion_~#__key~0#1.base, init_completion_~#__key~0#1.offset;havoc __init_waitqueue_head_~arg0#1.base, __init_waitqueue_head_~arg0#1.offset, __init_waitqueue_head_~arg1#1.base, __init_waitqueue_head_~arg1#1.offset;__init_waitqueue_head_~arg0#1.base, __init_waitqueue_head_~arg0#1.offset := __init_waitqueue_head_#in~arg0#1.base, __init_waitqueue_head_#in~arg0#1.offset;__init_waitqueue_head_~arg1#1.base, __init_waitqueue_head_~arg1#1.offset := __init_waitqueue_head_#in~arg1#1.base, __init_waitqueue_head_#in~arg1#1.offset; {278#true} is VALID [2022-02-20 21:35:18,554 INFO L290 TraceCheckUtils]: 39: Hoare triple {278#true} assume { :end_inline___init_waitqueue_head } true;call ULTIMATE.dealloc(init_completion_~#__key~0#1.base, init_completion_~#__key~0#1.offset);havoc init_completion_~#__key~0#1.base, init_completion_~#__key~0#1.offset; {278#true} is VALID [2022-02-20 21:35:18,554 INFO L290 TraceCheckUtils]: 40: Hoare triple {278#true} assume { :end_inline_init_completion } true;call write~int(58, ibmpex_register_bmc_~data~2#1.base, 327 + ibmpex_register_bmc_~data~2#1.offset, 1);call write~int(60, ibmpex_register_bmc_~data~2#1.base, 328 + ibmpex_register_bmc_~data~2#1.offset, 1);call write~$Pointer$(ibmpex_register_bmc_~data~2#1.base, 339 + ibmpex_register_bmc_~data~2#1.offset, ibmpex_register_bmc_~data~2#1.base, 331 + ibmpex_register_bmc_~data~2#1.offset, 8);assume { :begin_inline_ibmpex_ver_check } true;ibmpex_ver_check_#in~data#1.base, ibmpex_ver_check_#in~data#1.offset := ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset;havoc ibmpex_ver_check_#res#1;havoc ibmpex_ver_check_#t~ret71#1, ibmpex_ver_check_#t~mem72#1, ibmpex_ver_check_#t~mem73#1, ibmpex_ver_check_#t~short74#1, ibmpex_ver_check_#t~mem75#1, ibmpex_ver_check_#t~mem76#1, ibmpex_ver_check_#t~ret77#1, ibmpex_ver_check_#t~nondet78#1, ibmpex_ver_check_#t~mem79#1.base, ibmpex_ver_check_#t~mem79#1.offset, ibmpex_ver_check_#t~mem80#1, ibmpex_ver_check_#t~mem81#1, ibmpex_ver_check_#t~mem82#1, ibmpex_ver_check_#t~mem83#1, ibmpex_ver_check_#t~mem84#1, ibmpex_ver_check_~data#1.base, ibmpex_ver_check_~data#1.offset, ibmpex_ver_check_~tmp~4#1;ibmpex_ver_check_~data#1.base, ibmpex_ver_check_~data#1.offset := ibmpex_ver_check_#in~data#1.base, ibmpex_ver_check_#in~data#1.offset;havoc ibmpex_ver_check_~tmp~4#1;call write~int(1, ibmpex_ver_check_~data#1.base, 339 + ibmpex_ver_check_~data#1.offset, 1);call write~int(1, ibmpex_ver_check_~data#1.base, 329 + ibmpex_ver_check_~data#1.offset, 2); {278#true} is VALID [2022-02-20 21:35:18,556 INFO L272 TraceCheckUtils]: 41: Hoare triple {278#true} call ibmpex_ver_check_#t~ret71#1 := ibmpex_send_message(ibmpex_ver_check_~data#1.base, ibmpex_ver_check_~data#1.offset); {359#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} is VALID [2022-02-20 21:35:18,556 INFO L290 TraceCheckUtils]: 42: Hoare triple {359#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;havoc ~err~0#1;assume { :begin_inline_ipmi_validate_addr } true;ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset, ipmi_validate_addr_#in~arg1#1 := ~data#1.base, 193 + ~data#1.offset, 40;havoc ipmi_validate_addr_#res#1;havoc ipmi_validate_addr_#t~nondet254#1, ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset, ipmi_validate_addr_~arg1#1;ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset := ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset;ipmi_validate_addr_~arg1#1 := ipmi_validate_addr_#in~arg1#1;assume -2147483648 <= ipmi_validate_addr_#t~nondet254#1 && ipmi_validate_addr_#t~nondet254#1 <= 2147483647;ipmi_validate_addr_#res#1 := ipmi_validate_addr_#t~nondet254#1;havoc ipmi_validate_addr_#t~nondet254#1; {278#true} is VALID [2022-02-20 21:35:18,556 INFO L290 TraceCheckUtils]: 43: Hoare triple {278#true} #t~ret62#1 := ipmi_validate_addr_#res#1;assume { :end_inline_ipmi_validate_addr } true;assume -2147483648 <= #t~ret62#1 && #t~ret62#1 <= 2147483647;~err~0#1 := #t~ret62#1;havoc #t~ret62#1; {278#true} is VALID [2022-02-20 21:35:18,556 INFO L290 TraceCheckUtils]: 44: Hoare triple {278#true} assume 0 != ~err~0#1; {278#true} is VALID [2022-02-20 21:35:18,557 INFO L290 TraceCheckUtils]: 45: Hoare triple {278#true} havoc #t~nondet69#1;call #t~mem70#1.base, #t~mem70#1.offset := read~$Pointer$(~data#1.base, 24 + ~data#1.offset, 8);havoc #t~mem70#1.base, #t~mem70#1.offset;#res#1 := ~err~0#1; {278#true} is VALID [2022-02-20 21:35:18,557 INFO L290 TraceCheckUtils]: 46: Hoare triple {278#true} assume true; {278#true} is VALID [2022-02-20 21:35:18,557 INFO L284 TraceCheckUtils]: 47: Hoare quadruple {278#true} {278#true} #618#return; {278#true} is VALID [2022-02-20 21:35:18,557 INFO L290 TraceCheckUtils]: 48: Hoare triple {278#true} assume -2147483648 <= ibmpex_ver_check_#t~ret71#1 && ibmpex_ver_check_#t~ret71#1 <= 2147483647;havoc ibmpex_ver_check_#t~ret71#1; {278#true} is VALID [2022-02-20 21:35:18,558 INFO L272 TraceCheckUtils]: 49: Hoare triple {278#true} call wait_for_completion(ibmpex_ver_check_~data#1.base, 231 + ibmpex_ver_check_~data#1.offset); {278#true} is VALID [2022-02-20 21:35:18,558 INFO L290 TraceCheckUtils]: 50: Hoare triple {278#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset; {278#true} is VALID [2022-02-20 21:35:18,558 INFO L290 TraceCheckUtils]: 51: Hoare triple {278#true} assume true; {278#true} is VALID [2022-02-20 21:35:18,558 INFO L284 TraceCheckUtils]: 52: Hoare quadruple {278#true} {278#true} #620#return; {278#true} is VALID [2022-02-20 21:35:18,558 INFO L290 TraceCheckUtils]: 53: Hoare triple {278#true} call ibmpex_ver_check_#t~mem72#1 := read~int(ibmpex_ver_check_~data#1.base, 899 + ibmpex_ver_check_~data#1.offset, 1);ibmpex_ver_check_#t~short74#1 := 0 != ibmpex_ver_check_#t~mem72#1 % 256 % 4294967296; {278#true} is VALID [2022-02-20 21:35:18,559 INFO L290 TraceCheckUtils]: 54: Hoare triple {278#true} assume ibmpex_ver_check_#t~short74#1; {278#true} is VALID [2022-02-20 21:35:18,559 INFO L290 TraceCheckUtils]: 55: Hoare triple {278#true} assume ibmpex_ver_check_#t~short74#1;havoc ibmpex_ver_check_#t~mem72#1;havoc ibmpex_ver_check_#t~mem73#1;havoc ibmpex_ver_check_#t~short74#1;ibmpex_ver_check_#res#1 := -2; {308#(<= (+ |ULTIMATE.start_ibmpex_ver_check_#res#1| 2) 0)} is VALID [2022-02-20 21:35:18,560 INFO L290 TraceCheckUtils]: 56: Hoare triple {308#(<= (+ |ULTIMATE.start_ibmpex_ver_check_#res#1| 2) 0)} ibmpex_register_bmc_#t~ret184#1 := ibmpex_ver_check_#res#1;assume { :end_inline_ibmpex_ver_check } true;assume -2147483648 <= ibmpex_register_bmc_#t~ret184#1 && ibmpex_register_bmc_#t~ret184#1 <= 2147483647;ibmpex_register_bmc_~err~4#1 := ibmpex_register_bmc_#t~ret184#1;havoc ibmpex_register_bmc_#t~ret184#1; {309#(<= (+ 2 |ULTIMATE.start_ibmpex_register_bmc_~err~4#1|) 0)} is VALID [2022-02-20 21:35:18,561 INFO L290 TraceCheckUtils]: 57: Hoare triple {309#(<= (+ 2 |ULTIMATE.start_ibmpex_register_bmc_~err~4#1|) 0)} assume !(0 != ibmpex_register_bmc_~err~4#1);call ibmpex_register_bmc_#t~mem185#1.base, ibmpex_register_bmc_#t~mem185#1.offset := read~$Pointer$(ibmpex_register_bmc_~data~2#1.base, 24 + ibmpex_register_bmc_~data~2#1.offset, 8);assume { :begin_inline_hwmon_device_register } true;hwmon_device_register_#in~arg0#1.base, hwmon_device_register_#in~arg0#1.offset := ibmpex_register_bmc_#t~mem185#1.base, ibmpex_register_bmc_#t~mem185#1.offset;havoc hwmon_device_register_#res#1.base, hwmon_device_register_#res#1.offset;havoc hwmon_device_register_#t~ret248#1.base, hwmon_device_register_#t~ret248#1.offset, hwmon_device_register_~arg0#1.base, hwmon_device_register_~arg0#1.offset;hwmon_device_register_~arg0#1.base, hwmon_device_register_~arg0#1.offset := hwmon_device_register_#in~arg0#1.base, hwmon_device_register_#in~arg0#1.offset; {279#false} is VALID [2022-02-20 21:35:18,561 INFO L272 TraceCheckUtils]: 58: Hoare triple {279#false} call hwmon_device_register_#t~ret248#1.base, hwmon_device_register_#t~ret248#1.offset := ldv_malloc(1035); {344#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:18,561 INFO L290 TraceCheckUtils]: 59: Hoare triple {344#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {278#true} is VALID [2022-02-20 21:35:18,561 INFO L290 TraceCheckUtils]: 60: Hoare triple {278#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {278#true} is VALID [2022-02-20 21:35:18,562 INFO L290 TraceCheckUtils]: 61: Hoare triple {278#true} assume true; {278#true} is VALID [2022-02-20 21:35:18,562 INFO L284 TraceCheckUtils]: 62: Hoare quadruple {278#true} {279#false} #624#return; {279#false} is VALID [2022-02-20 21:35:18,562 INFO L290 TraceCheckUtils]: 63: Hoare triple {279#false} hwmon_device_register_#res#1.base, hwmon_device_register_#res#1.offset := hwmon_device_register_#t~ret248#1.base, hwmon_device_register_#t~ret248#1.offset;havoc hwmon_device_register_#t~ret248#1.base, hwmon_device_register_#t~ret248#1.offset; {279#false} is VALID [2022-02-20 21:35:18,562 INFO L290 TraceCheckUtils]: 64: Hoare triple {279#false} ibmpex_register_bmc_#t~ret186#1.base, ibmpex_register_bmc_#t~ret186#1.offset := hwmon_device_register_#res#1.base, hwmon_device_register_#res#1.offset;assume { :end_inline_hwmon_device_register } true;call write~$Pointer$(ibmpex_register_bmc_#t~ret186#1.base, ibmpex_register_bmc_#t~ret186#1.offset, ibmpex_register_bmc_~data~2#1.base, 16 + ibmpex_register_bmc_~data~2#1.offset, 8);havoc ibmpex_register_bmc_#t~mem185#1.base, ibmpex_register_bmc_#t~mem185#1.offset;havoc ibmpex_register_bmc_#t~ret186#1.base, ibmpex_register_bmc_#t~ret186#1.offset;call ibmpex_register_bmc_#t~mem187#1.base, ibmpex_register_bmc_#t~mem187#1.offset := read~$Pointer$(ibmpex_register_bmc_~data~2#1.base, 16 + ibmpex_register_bmc_~data~2#1.offset, 8);assume { :begin_inline_IS_ERR } true;IS_ERR_#in~ptr#1.base, IS_ERR_#in~ptr#1.offset := ibmpex_register_bmc_#t~mem187#1.base, ibmpex_register_bmc_#t~mem187#1.offset;havoc IS_ERR_#res#1;havoc IS_ERR_#t~ret240#1, IS_ERR_~ptr#1.base, IS_ERR_~ptr#1.offset, IS_ERR_~tmp~18#1;IS_ERR_~ptr#1.base, IS_ERR_~ptr#1.offset := IS_ERR_#in~ptr#1.base, IS_ERR_#in~ptr#1.offset;havoc IS_ERR_~tmp~18#1; {279#false} is VALID [2022-02-20 21:35:18,563 INFO L272 TraceCheckUtils]: 65: Hoare triple {279#false} call IS_ERR_#t~ret240#1 := ldv_is_err(IS_ERR_~ptr#1.base, IS_ERR_~ptr#1.offset); {278#true} is VALID [2022-02-20 21:35:18,563 INFO L290 TraceCheckUtils]: 66: Hoare triple {278#true} ~ptr.base, ~ptr.offset := #in~ptr.base, #in~ptr.offset;#res := (if (~ptr.base + ~ptr.offset) % 18446744073709551616 > 2012 then 1 else 0); {278#true} is VALID [2022-02-20 21:35:18,563 INFO L290 TraceCheckUtils]: 67: Hoare triple {278#true} assume true; {278#true} is VALID [2022-02-20 21:35:18,563 INFO L284 TraceCheckUtils]: 68: Hoare quadruple {278#true} {279#false} #626#return; {279#false} is VALID [2022-02-20 21:35:18,564 INFO L290 TraceCheckUtils]: 69: Hoare triple {279#false} assume -9223372036854775808 <= IS_ERR_#t~ret240#1 && IS_ERR_#t~ret240#1 <= 9223372036854775807;IS_ERR_~tmp~18#1 := IS_ERR_#t~ret240#1;havoc IS_ERR_#t~ret240#1;IS_ERR_#res#1 := IS_ERR_~tmp~18#1; {279#false} is VALID [2022-02-20 21:35:18,564 INFO L290 TraceCheckUtils]: 70: Hoare triple {279#false} ibmpex_register_bmc_#t~ret188#1 := IS_ERR_#res#1;assume { :end_inline_IS_ERR } true;assume -9223372036854775808 <= ibmpex_register_bmc_#t~ret188#1 && ibmpex_register_bmc_#t~ret188#1 <= 9223372036854775807;ibmpex_register_bmc_~tmp___0~3#1 := ibmpex_register_bmc_#t~ret188#1;havoc ibmpex_register_bmc_#t~mem187#1.base, ibmpex_register_bmc_#t~mem187#1.offset;havoc ibmpex_register_bmc_#t~ret188#1; {279#false} is VALID [2022-02-20 21:35:18,564 INFO L290 TraceCheckUtils]: 71: Hoare triple {279#false} assume !(0 != ibmpex_register_bmc_~tmp___0~3#1); {279#false} is VALID [2022-02-20 21:35:18,564 INFO L272 TraceCheckUtils]: 72: Hoare triple {279#false} call dev_set_drvdata(ibmpex_register_bmc_~dev#1.base, ibmpex_register_bmc_~dev#1.offset, ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset); {278#true} is VALID [2022-02-20 21:35:18,565 INFO L290 TraceCheckUtils]: 73: Hoare triple {278#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset;~arg1.base, ~arg1.offset := #in~arg1.base, #in~arg1.offset; {278#true} is VALID [2022-02-20 21:35:18,565 INFO L290 TraceCheckUtils]: 74: Hoare triple {278#true} assume true; {278#true} is VALID [2022-02-20 21:35:18,565 INFO L284 TraceCheckUtils]: 75: Hoare quadruple {278#true} {279#false} #628#return; {279#false} is VALID [2022-02-20 21:35:18,565 INFO L290 TraceCheckUtils]: 76: Hoare triple {279#false} assume { :begin_inline_list_add_tail } true;list_add_tail_#in~new#1.base, list_add_tail_#in~new#1.offset, list_add_tail_#in~head#1.base, list_add_tail_#in~head#1.offset := ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset, ~#driver_data~0.base, ~#driver_data~0.offset;havoc list_add_tail_#t~mem12#1.base, list_add_tail_#t~mem12#1.offset, list_add_tail_~new#1.base, list_add_tail_~new#1.offset, list_add_tail_~head#1.base, list_add_tail_~head#1.offset;list_add_tail_~new#1.base, list_add_tail_~new#1.offset := list_add_tail_#in~new#1.base, list_add_tail_#in~new#1.offset;list_add_tail_~head#1.base, list_add_tail_~head#1.offset := list_add_tail_#in~head#1.base, list_add_tail_#in~head#1.offset;call list_add_tail_#t~mem12#1.base, list_add_tail_#t~mem12#1.offset := read~$Pointer$(list_add_tail_~head#1.base, 8 + list_add_tail_~head#1.offset, 8);assume { :begin_inline___list_add } true;__list_add_#in~arg0#1.base, __list_add_#in~arg0#1.offset, __list_add_#in~arg1#1.base, __list_add_#in~arg1#1.offset, __list_add_#in~arg2#1.base, __list_add_#in~arg2#1.offset := list_add_tail_~new#1.base, list_add_tail_~new#1.offset, list_add_tail_#t~mem12#1.base, list_add_tail_#t~mem12#1.offset, list_add_tail_~head#1.base, list_add_tail_~head#1.offset;havoc __list_add_~arg0#1.base, __list_add_~arg0#1.offset, __list_add_~arg1#1.base, __list_add_~arg1#1.offset, __list_add_~arg2#1.base, __list_add_~arg2#1.offset;__list_add_~arg0#1.base, __list_add_~arg0#1.offset := __list_add_#in~arg0#1.base, __list_add_#in~arg0#1.offset;__list_add_~arg1#1.base, __list_add_~arg1#1.offset := __list_add_#in~arg1#1.base, __list_add_#in~arg1#1.offset;__list_add_~arg2#1.base, __list_add_~arg2#1.offset := __list_add_#in~arg2#1.base, __list_add_#in~arg2#1.offset; {279#false} is VALID [2022-02-20 21:35:18,566 INFO L290 TraceCheckUtils]: 77: Hoare triple {279#false} assume { :end_inline___list_add } true;havoc list_add_tail_#t~mem12#1.base, list_add_tail_#t~mem12#1.offset; {279#false} is VALID [2022-02-20 21:35:18,566 INFO L290 TraceCheckUtils]: 78: Hoare triple {279#false} assume { :end_inline_list_add_tail } true;assume { :begin_inline_ibmpex_find_sensors } true;ibmpex_find_sensors_#in~data#1.base, ibmpex_find_sensors_#in~data#1.offset := ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset;havoc ibmpex_find_sensors_#res#1;havoc ibmpex_find_sensors_#t~ret148#1, ibmpex_find_sensors_#t~mem149#1, ibmpex_find_sensors_#t~ret150#1.base, ibmpex_find_sensors_#t~ret150#1.offset, ibmpex_find_sensors_#t~mem151#1.base, ibmpex_find_sensors_#t~mem151#1.offset, ibmpex_find_sensors_#t~ret152#1, ibmpex_find_sensors_#t~mem153#1, ibmpex_find_sensors_#t~ret154#1, ibmpex_find_sensors_#t~mem155#1.base, ibmpex_find_sensors_#t~mem155#1.offset, ibmpex_find_sensors_#t~mem156#1, ibmpex_find_sensors_#t~ret157#1, ibmpex_find_sensors_#t~mem158#1, ibmpex_find_sensors_#t~ret159#1, ibmpex_find_sensors_#t~mem160#1.base, ibmpex_find_sensors_#t~mem160#1.offset, ibmpex_find_sensors_#t~mem161#1.base, ibmpex_find_sensors_#t~mem161#1.offset, ibmpex_find_sensors_#t~ret162#1, ibmpex_find_sensors_#t~mem163#1, ibmpex_find_sensors_#t~mem164#1.base, ibmpex_find_sensors_#t~mem164#1.offset, ibmpex_find_sensors_#t~ret165#1, ibmpex_find_sensors_#t~mem166#1.base, ibmpex_find_sensors_#t~mem166#1.offset, ibmpex_find_sensors_#t~ret167#1, ibmpex_find_sensors_#t~mem168#1.base, ibmpex_find_sensors_#t~mem168#1.offset, ibmpex_find_sensors_#t~mem169#1.base, ibmpex_find_sensors_#t~mem169#1.offset, ibmpex_find_sensors_#t~mem170#1.base, ibmpex_find_sensors_#t~mem170#1.offset, ibmpex_find_sensors_#t~mem171#1.base, ibmpex_find_sensors_#t~mem171#1.offset, ibmpex_find_sensors_#t~mem172#1.base, ibmpex_find_sensors_#t~mem172#1.offset, ibmpex_find_sensors_#t~mem173#1.base, ibmpex_find_sensors_#t~mem173#1.offset, ibmpex_find_sensors_#t~mem174#1.base, ibmpex_find_sensors_#t~mem174#1.offset, ibmpex_find_sensors_#t~mem175#1.base, ibmpex_find_sensors_#t~mem175#1.offset, ibmpex_find_sensors_#t~mem176#1, ibmpex_find_sensors_#t~mem177#1.base, ibmpex_find_sensors_#t~mem177#1.offset, ibmpex_find_sensors_~data#1.base, ibmpex_find_sensors_~data#1.offset, ibmpex_find_sensors_~i~2#1, ibmpex_find_sensors_~j~0#1, ibmpex_find_sensors_~err~3#1, ibmpex_find_sensors_~sensor_type~0#1, ibmpex_find_sensors_~sensor_counter~0#1, ibmpex_find_sensors_~num_power~0#1, ibmpex_find_sensors_~num_temp~0#1, ibmpex_find_sensors_~tmp~13#1.base, ibmpex_find_sensors_~tmp~13#1.offset, ibmpex_find_sensors_~tmp___0~2#1, ibmpex_find_sensors_~tmp___1~1#1;ibmpex_find_sensors_~data#1.base, ibmpex_find_sensors_~data#1.offset := ibmpex_find_sensors_#in~data#1.base, ibmpex_find_sensors_#in~data#1.offset;havoc ibmpex_find_sensors_~i~2#1;havoc ibmpex_find_sensors_~j~0#1;havoc ibmpex_find_sensors_~err~3#1;havoc ibmpex_find_sensors_~sensor_type~0#1;havoc ibmpex_find_sensors_~sensor_counter~0#1;havoc ibmpex_find_sensors_~num_power~0#1;havoc ibmpex_find_sensors_~num_temp~0#1;havoc ibmpex_find_sensors_~tmp~13#1.base, ibmpex_find_sensors_~tmp~13#1.offset;havoc ibmpex_find_sensors_~tmp___0~2#1;havoc ibmpex_find_sensors_~tmp___1~1#1;ibmpex_find_sensors_~num_power~0#1 := 0;ibmpex_find_sensors_~num_temp~0#1 := 0;assume { :begin_inline_ibmpex_query_sensor_count } true;ibmpex_query_sensor_count_#in~data#1.base, ibmpex_query_sensor_count_#in~data#1.offset := ibmpex_find_sensors_~data#1.base, ibmpex_find_sensors_~data#1.offset;havoc ibmpex_query_sensor_count_#res#1;havoc ibmpex_query_sensor_count_#t~ret85#1, ibmpex_query_sensor_count_#t~mem86#1, ibmpex_query_sensor_count_#t~mem87#1, ibmpex_query_sensor_count_#t~short88#1, ibmpex_query_sensor_count_#t~mem89#1, ibmpex_query_sensor_count_~data#1.base, ibmpex_query_sensor_count_~data#1.offset;ibmpex_query_sensor_count_~data#1.base, ibmpex_query_sensor_count_~data#1.offset := ibmpex_query_sensor_count_#in~data#1.base, ibmpex_query_sensor_count_#in~data#1.offset;call write~int(2, ibmpex_query_sensor_count_~data#1.base, 339 + ibmpex_query_sensor_count_~data#1.offset, 1);call write~int(1, ibmpex_query_sensor_count_~data#1.base, 329 + ibmpex_query_sensor_count_~data#1.offset, 2); {279#false} is VALID [2022-02-20 21:35:18,566 INFO L272 TraceCheckUtils]: 79: Hoare triple {279#false} call ibmpex_query_sensor_count_#t~ret85#1 := ibmpex_send_message(ibmpex_query_sensor_count_~data#1.base, ibmpex_query_sensor_count_~data#1.offset); {359#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} is VALID [2022-02-20 21:35:18,566 INFO L290 TraceCheckUtils]: 80: Hoare triple {359#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;havoc ~err~0#1;assume { :begin_inline_ipmi_validate_addr } true;ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset, ipmi_validate_addr_#in~arg1#1 := ~data#1.base, 193 + ~data#1.offset, 40;havoc ipmi_validate_addr_#res#1;havoc ipmi_validate_addr_#t~nondet254#1, ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset, ipmi_validate_addr_~arg1#1;ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset := ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset;ipmi_validate_addr_~arg1#1 := ipmi_validate_addr_#in~arg1#1;assume -2147483648 <= ipmi_validate_addr_#t~nondet254#1 && ipmi_validate_addr_#t~nondet254#1 <= 2147483647;ipmi_validate_addr_#res#1 := ipmi_validate_addr_#t~nondet254#1;havoc ipmi_validate_addr_#t~nondet254#1; {278#true} is VALID [2022-02-20 21:35:18,567 INFO L290 TraceCheckUtils]: 81: Hoare triple {278#true} #t~ret62#1 := ipmi_validate_addr_#res#1;assume { :end_inline_ipmi_validate_addr } true;assume -2147483648 <= #t~ret62#1 && #t~ret62#1 <= 2147483647;~err~0#1 := #t~ret62#1;havoc #t~ret62#1; {278#true} is VALID [2022-02-20 21:35:18,567 INFO L290 TraceCheckUtils]: 82: Hoare triple {278#true} assume 0 != ~err~0#1; {278#true} is VALID [2022-02-20 21:35:18,567 INFO L290 TraceCheckUtils]: 83: Hoare triple {278#true} havoc #t~nondet69#1;call #t~mem70#1.base, #t~mem70#1.offset := read~$Pointer$(~data#1.base, 24 + ~data#1.offset, 8);havoc #t~mem70#1.base, #t~mem70#1.offset;#res#1 := ~err~0#1; {278#true} is VALID [2022-02-20 21:35:18,567 INFO L290 TraceCheckUtils]: 84: Hoare triple {278#true} assume true; {278#true} is VALID [2022-02-20 21:35:18,568 INFO L284 TraceCheckUtils]: 85: Hoare quadruple {278#true} {279#false} #630#return; {279#false} is VALID [2022-02-20 21:35:18,568 INFO L290 TraceCheckUtils]: 86: Hoare triple {279#false} assume -2147483648 <= ibmpex_query_sensor_count_#t~ret85#1 && ibmpex_query_sensor_count_#t~ret85#1 <= 2147483647;havoc ibmpex_query_sensor_count_#t~ret85#1; {279#false} is VALID [2022-02-20 21:35:18,568 INFO L272 TraceCheckUtils]: 87: Hoare triple {279#false} call wait_for_completion(ibmpex_query_sensor_count_~data#1.base, 231 + ibmpex_query_sensor_count_~data#1.offset); {278#true} is VALID [2022-02-20 21:35:18,568 INFO L290 TraceCheckUtils]: 88: Hoare triple {278#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset; {278#true} is VALID [2022-02-20 21:35:18,569 INFO L290 TraceCheckUtils]: 89: Hoare triple {278#true} assume true; {278#true} is VALID [2022-02-20 21:35:18,569 INFO L284 TraceCheckUtils]: 90: Hoare quadruple {278#true} {279#false} #632#return; {279#false} is VALID [2022-02-20 21:35:18,569 INFO L290 TraceCheckUtils]: 91: Hoare triple {279#false} call ibmpex_query_sensor_count_#t~mem86#1 := read~int(ibmpex_query_sensor_count_~data#1.base, 899 + ibmpex_query_sensor_count_~data#1.offset, 1);ibmpex_query_sensor_count_#t~short88#1 := 0 != ibmpex_query_sensor_count_#t~mem86#1 % 256 % 4294967296; {279#false} is VALID [2022-02-20 21:35:18,569 INFO L290 TraceCheckUtils]: 92: Hoare triple {279#false} assume !ibmpex_query_sensor_count_#t~short88#1;call ibmpex_query_sensor_count_#t~mem87#1 := read~int(ibmpex_query_sensor_count_~data#1.base, 891 + ibmpex_query_sensor_count_~data#1.offset, 8);ibmpex_query_sensor_count_#t~short88#1 := 1 != ibmpex_query_sensor_count_#t~mem87#1 % 18446744073709551616; {279#false} is VALID [2022-02-20 21:35:18,570 INFO L290 TraceCheckUtils]: 93: Hoare triple {279#false} assume ibmpex_query_sensor_count_#t~short88#1;havoc ibmpex_query_sensor_count_#t~mem86#1;havoc ibmpex_query_sensor_count_#t~mem87#1;havoc ibmpex_query_sensor_count_#t~short88#1;ibmpex_query_sensor_count_#res#1 := -2; {279#false} is VALID [2022-02-20 21:35:18,570 INFO L290 TraceCheckUtils]: 94: Hoare triple {279#false} ibmpex_find_sensors_#t~ret148#1 := ibmpex_query_sensor_count_#res#1;assume { :end_inline_ibmpex_query_sensor_count } true;assume -2147483648 <= ibmpex_find_sensors_#t~ret148#1 && ibmpex_find_sensors_#t~ret148#1 <= 2147483647;ibmpex_find_sensors_~err~3#1 := ibmpex_find_sensors_#t~ret148#1;havoc ibmpex_find_sensors_#t~ret148#1; {279#false} is VALID [2022-02-20 21:35:18,570 INFO L290 TraceCheckUtils]: 95: Hoare triple {279#false} assume !(ibmpex_find_sensors_~err~3#1 <= 0);call write~int(ibmpex_find_sensors_~err~3#1, ibmpex_find_sensors_~data#1.base, 906 + ibmpex_find_sensors_~data#1.offset, 1);call ibmpex_find_sensors_#t~mem149#1 := read~int(ibmpex_find_sensors_~data#1.base, 906 + ibmpex_find_sensors_~data#1.offset, 1); {279#false} is VALID [2022-02-20 21:35:18,570 INFO L272 TraceCheckUtils]: 96: Hoare triple {279#false} call ibmpex_find_sensors_#t~ret150#1.base, ibmpex_find_sensors_#t~ret150#1.offset := kzalloc(184 * (ibmpex_find_sensors_#t~mem149#1 % 256), 208); {344#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:18,571 INFO L290 TraceCheckUtils]: 97: Hoare triple {344#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size;~flags := #in~flags;havoc ~tmp~2.base, ~tmp~2.offset; {278#true} is VALID [2022-02-20 21:35:18,571 INFO L272 TraceCheckUtils]: 98: Hoare triple {278#true} call #t~ret40.base, #t~ret40.offset := kmalloc(~size, ~bitwiseOr(~flags, 32768)); {344#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:18,572 INFO L290 TraceCheckUtils]: 99: Hoare triple {344#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {278#true} is VALID [2022-02-20 21:35:18,573 INFO L272 TraceCheckUtils]: 100: Hoare triple {278#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {344#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:18,574 INFO L290 TraceCheckUtils]: 101: Hoare triple {344#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {278#true} is VALID [2022-02-20 21:35:18,574 INFO L290 TraceCheckUtils]: 102: Hoare triple {278#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {278#true} is VALID [2022-02-20 21:35:18,575 INFO L290 TraceCheckUtils]: 103: Hoare triple {278#true} assume true; {278#true} is VALID [2022-02-20 21:35:18,575 INFO L284 TraceCheckUtils]: 104: Hoare quadruple {278#true} {278#true} #590#return; {278#true} is VALID [2022-02-20 21:35:18,575 INFO L290 TraceCheckUtils]: 105: Hoare triple {278#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {278#true} is VALID [2022-02-20 21:35:18,579 INFO L290 TraceCheckUtils]: 106: Hoare triple {278#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {278#true} is VALID [2022-02-20 21:35:18,579 INFO L290 TraceCheckUtils]: 107: Hoare triple {278#true} assume true; {278#true} is VALID [2022-02-20 21:35:18,579 INFO L284 TraceCheckUtils]: 108: Hoare quadruple {278#true} {278#true} #588#return; {278#true} is VALID [2022-02-20 21:35:18,580 INFO L290 TraceCheckUtils]: 109: Hoare triple {278#true} ~tmp~2.base, ~tmp~2.offset := #t~ret40.base, #t~ret40.offset;havoc #t~ret40.base, #t~ret40.offset;#res.base, #res.offset := ~tmp~2.base, ~tmp~2.offset; {278#true} is VALID [2022-02-20 21:35:18,580 INFO L290 TraceCheckUtils]: 110: Hoare triple {278#true} assume true; {278#true} is VALID [2022-02-20 21:35:18,580 INFO L284 TraceCheckUtils]: 111: Hoare quadruple {278#true} {279#false} #634#return; {279#false} is VALID [2022-02-20 21:35:18,580 INFO L290 TraceCheckUtils]: 112: Hoare triple {279#false} ibmpex_find_sensors_~tmp~13#1.base, ibmpex_find_sensors_~tmp~13#1.offset := ibmpex_find_sensors_#t~ret150#1.base, ibmpex_find_sensors_#t~ret150#1.offset;havoc ibmpex_find_sensors_#t~mem149#1;havoc ibmpex_find_sensors_#t~ret150#1.base, ibmpex_find_sensors_#t~ret150#1.offset;call write~$Pointer$(ibmpex_find_sensors_~tmp~13#1.base, ibmpex_find_sensors_~tmp~13#1.offset, ibmpex_find_sensors_~data#1.base, 907 + ibmpex_find_sensors_~data#1.offset, 8);call ibmpex_find_sensors_#t~mem151#1.base, ibmpex_find_sensors_#t~mem151#1.offset := read~$Pointer$(ibmpex_find_sensors_~data#1.base, 907 + ibmpex_find_sensors_~data#1.offset, 8); {279#false} is VALID [2022-02-20 21:35:18,581 INFO L290 TraceCheckUtils]: 113: Hoare triple {279#false} assume !(0 == (ibmpex_find_sensors_#t~mem151#1.base + ibmpex_find_sensors_#t~mem151#1.offset) % 18446744073709551616);havoc ibmpex_find_sensors_#t~mem151#1.base, ibmpex_find_sensors_#t~mem151#1.offset;ibmpex_find_sensors_~i~2#1 := 0; {279#false} is VALID [2022-02-20 21:35:18,581 INFO L290 TraceCheckUtils]: 114: Hoare triple {279#false} call ibmpex_find_sensors_#t~mem163#1 := read~int(ibmpex_find_sensors_~data#1.base, 906 + ibmpex_find_sensors_~data#1.offset, 1); {279#false} is VALID [2022-02-20 21:35:18,581 INFO L290 TraceCheckUtils]: 115: Hoare triple {279#false} assume !(ibmpex_find_sensors_#t~mem163#1 % 256 > ibmpex_find_sensors_~i~2#1);havoc ibmpex_find_sensors_#t~mem163#1;call ibmpex_find_sensors_#t~mem164#1.base, ibmpex_find_sensors_#t~mem164#1.offset := read~$Pointer$(ibmpex_find_sensors_~data#1.base, 24 + ibmpex_find_sensors_~data#1.offset, 8);assume { :begin_inline_ldv_device_create_file_6 } true;ldv_device_create_file_6_#in~ldv_func_arg1#1.base, ldv_device_create_file_6_#in~ldv_func_arg1#1.offset, ldv_device_create_file_6_#in~ldv_func_arg2#1.base, ldv_device_create_file_6_#in~ldv_func_arg2#1.offset := ibmpex_find_sensors_#t~mem164#1.base, ibmpex_find_sensors_#t~mem164#1.offset, ~#sensor_dev_attr_reset_high_low~0.base, ~#sensor_dev_attr_reset_high_low~0.offset;havoc ldv_device_create_file_6_#res#1;havoc ldv_device_create_file_6_#t~ret242#1, ldv_device_create_file_6_~ldv_func_arg1#1.base, ldv_device_create_file_6_~ldv_func_arg1#1.offset, ldv_device_create_file_6_~ldv_func_arg2#1.base, ldv_device_create_file_6_~ldv_func_arg2#1.offset, ldv_device_create_file_6_~tmp~20#1;ldv_device_create_file_6_~ldv_func_arg1#1.base, ldv_device_create_file_6_~ldv_func_arg1#1.offset := ldv_device_create_file_6_#in~ldv_func_arg1#1.base, ldv_device_create_file_6_#in~ldv_func_arg1#1.offset;ldv_device_create_file_6_~ldv_func_arg2#1.base, ldv_device_create_file_6_~ldv_func_arg2#1.offset := ldv_device_create_file_6_#in~ldv_func_arg2#1.base, ldv_device_create_file_6_#in~ldv_func_arg2#1.offset;havoc ldv_device_create_file_6_~tmp~20#1; {279#false} is VALID [2022-02-20 21:35:18,581 INFO L272 TraceCheckUtils]: 116: Hoare triple {279#false} call ldv_device_create_file_6_#t~ret242#1 := ldv_device_create_file_dev_attr_of_sensor_device_attribute(ldv_device_create_file_6_~ldv_func_arg2#1.base, ldv_device_create_file_6_~ldv_func_arg2#1.offset); {279#false} is VALID [2022-02-20 21:35:18,581 INFO L290 TraceCheckUtils]: 117: Hoare triple {279#false} ~attr.base, ~attr.offset := #in~attr.base, #in~attr.offset; {279#false} is VALID [2022-02-20 21:35:18,582 INFO L290 TraceCheckUtils]: 118: Hoare triple {279#false} assume 0 == ~ldv_call_dev_attr_of_sensor_device_attribute~0;~ldv_count_2~0 := 1 + ~ldv_count_2~0;~ldv_call_dev_attr_of_sensor_device_attribute~0 := 1; {279#false} is VALID [2022-02-20 21:35:18,582 INFO L290 TraceCheckUtils]: 119: Hoare triple {279#false} assume !(~ldv_count_1~0 >= ~ldv_count_2~0); {279#false} is VALID [2022-02-20 21:35:18,582 INFO L272 TraceCheckUtils]: 120: Hoare triple {279#false} call ldv_error(); {279#false} is VALID [2022-02-20 21:35:18,582 INFO L290 TraceCheckUtils]: 121: Hoare triple {279#false} assume !false; {279#false} is VALID [2022-02-20 21:35:18,585 INFO L134 CoverageAnalysis]: Checked inductivity of 34 backedges. 0 proven. 0 refuted. 0 times theorem prover too weak. 34 trivial. 0 not checked. [2022-02-20 21:35:18,586 INFO L144 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-02-20 21:35:18,586 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [588113376] [2022-02-20 21:35:18,586 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleSmtInterpolCraig [588113376] provided 1 perfect and 0 imperfect interpolant sequences [2022-02-20 21:35:18,587 INFO L191 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-02-20 21:35:18,587 INFO L204 FreeRefinementEngine]: Number of different interpolants: perfect sequences [6] imperfect sequences [] total 6 [2022-02-20 21:35:18,591 INFO L118 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [924303220] [2022-02-20 21:35:18,592 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-02-20 21:35:18,597 INFO L78 Accepts]: Start accepts. Automaton has has 6 states, 6 states have (on average 11.5) internal successors, (69), 4 states have internal predecessors, (69), 2 states have call successors, (15), 4 states have call predecessors, (15), 1 states have return successors, (13), 2 states have call predecessors, (13), 2 states have call successors, (13) Word has length 122 [2022-02-20 21:35:18,599 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-02-20 21:35:18,602 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with has 6 states, 6 states have (on average 11.5) internal successors, (69), 4 states have internal predecessors, (69), 2 states have call successors, (15), 4 states have call predecessors, (15), 1 states have return successors, (13), 2 states have call predecessors, (13), 2 states have call successors, (13) [2022-02-20 21:35:18,714 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 97 edges. 97 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 21:35:18,715 INFO L546 AbstractCegarLoop]: INTERPOLANT automaton has 6 states [2022-02-20 21:35:18,715 INFO L108 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2022-02-20 21:35:18,741 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 6 interpolants. [2022-02-20 21:35:18,742 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=9, Invalid=21, Unknown=0, NotChecked=0, Total=30 [2022-02-20 21:35:18,748 INFO L87 Difference]: Start difference. First operand has 275 states, 209 states have (on average 1.2966507177033493) internal successors, (271), 214 states have internal predecessors, (271), 47 states have call successors, (47), 17 states have call predecessors, (47), 17 states have return successors, (47), 47 states have call predecessors, (47), 47 states have call successors, (47) Second operand has 6 states, 6 states have (on average 11.5) internal successors, (69), 4 states have internal predecessors, (69), 2 states have call successors, (15), 4 states have call predecessors, (15), 1 states have return successors, (13), 2 states have call predecessors, (13), 2 states have call successors, (13) [2022-02-20 21:35:22,442 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 21:35:22,443 INFO L93 Difference]: Finished difference Result 678 states and 930 transitions. [2022-02-20 21:35:22,443 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 7 states. [2022-02-20 21:35:22,444 INFO L78 Accepts]: Start accepts. Automaton has has 6 states, 6 states have (on average 11.5) internal successors, (69), 4 states have internal predecessors, (69), 2 states have call successors, (15), 4 states have call predecessors, (15), 1 states have return successors, (13), 2 states have call predecessors, (13), 2 states have call successors, (13) Word has length 122 [2022-02-20 21:35:22,444 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-02-20 21:35:22,445 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 6 states, 6 states have (on average 11.5) internal successors, (69), 4 states have internal predecessors, (69), 2 states have call successors, (15), 4 states have call predecessors, (15), 1 states have return successors, (13), 2 states have call predecessors, (13), 2 states have call successors, (13) [2022-02-20 21:35:22,474 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 7 states to 7 states and 930 transitions. [2022-02-20 21:35:22,475 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 6 states, 6 states have (on average 11.5) internal successors, (69), 4 states have internal predecessors, (69), 2 states have call successors, (15), 4 states have call predecessors, (15), 1 states have return successors, (13), 2 states have call predecessors, (13), 2 states have call successors, (13) [2022-02-20 21:35:22,505 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 7 states to 7 states and 930 transitions. [2022-02-20 21:35:22,506 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with 7 states and 930 transitions. [2022-02-20 21:35:23,236 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 930 edges. 930 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 21:35:23,272 INFO L225 Difference]: With dead ends: 678 [2022-02-20 21:35:23,273 INFO L226 Difference]: Without dead ends: 375 [2022-02-20 21:35:23,277 INFO L932 BasicCegarLoop]: 0 DeclaredPredicates, 38 GetRequests, 32 SyntacticMatches, 0 SemanticMatches, 6 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 1 ImplicationChecksByTransitivity, 0.0s TimeCoverageRelationStatistics Valid=17, Invalid=39, Unknown=0, NotChecked=0, Total=56 [2022-02-20 21:35:23,280 INFO L933 BasicCegarLoop]: 425 mSDtfsCounter, 325 mSDsluCounter, 936 mSDsCounter, 0 mSdLazyCounter, 590 mSolverCounterSat, 147 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 1.1s Time, 0 mProtectedPredicate, 0 mProtectedAction, 343 SdHoareTripleChecker+Valid, 1361 SdHoareTripleChecker+Invalid, 737 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 147 IncrementalHoareTripleChecker+Valid, 590 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 1.1s IncrementalHoareTripleChecker+Time [2022-02-20 21:35:23,281 INFO L934 BasicCegarLoop]: SdHoareTripleChecker [343 Valid, 1361 Invalid, 737 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [147 Valid, 590 Invalid, 0 Unknown, 0 Unchecked, 1.1s Time] [2022-02-20 21:35:23,295 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 375 states. [2022-02-20 21:35:23,324 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 375 to 263. [2022-02-20 21:35:23,324 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-02-20 21:35:23,326 INFO L82 GeneralOperation]: Start isEquivalent. First operand 375 states. Second operand has 263 states, 201 states have (on average 1.2835820895522387) internal successors, (258), 204 states have internal predecessors, (258), 45 states have call successors, (45), 17 states have call predecessors, (45), 16 states have return successors, (43), 43 states have call predecessors, (43), 43 states have call successors, (43) [2022-02-20 21:35:23,327 INFO L74 IsIncluded]: Start isIncluded. First operand 375 states. Second operand has 263 states, 201 states have (on average 1.2835820895522387) internal successors, (258), 204 states have internal predecessors, (258), 45 states have call successors, (45), 17 states have call predecessors, (45), 16 states have return successors, (43), 43 states have call predecessors, (43), 43 states have call successors, (43) [2022-02-20 21:35:23,329 INFO L87 Difference]: Start difference. First operand 375 states. Second operand has 263 states, 201 states have (on average 1.2835820895522387) internal successors, (258), 204 states have internal predecessors, (258), 45 states have call successors, (45), 17 states have call predecessors, (45), 16 states have return successors, (43), 43 states have call predecessors, (43), 43 states have call successors, (43) [2022-02-20 21:35:23,352 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 21:35:23,353 INFO L93 Difference]: Finished difference Result 375 states and 515 transitions. [2022-02-20 21:35:23,353 INFO L276 IsEmpty]: Start isEmpty. Operand 375 states and 515 transitions. [2022-02-20 21:35:23,355 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 21:35:23,355 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 21:35:23,356 INFO L74 IsIncluded]: Start isIncluded. First operand has 263 states, 201 states have (on average 1.2835820895522387) internal successors, (258), 204 states have internal predecessors, (258), 45 states have call successors, (45), 17 states have call predecessors, (45), 16 states have return successors, (43), 43 states have call predecessors, (43), 43 states have call successors, (43) Second operand 375 states. [2022-02-20 21:35:23,358 INFO L87 Difference]: Start difference. First operand has 263 states, 201 states have (on average 1.2835820895522387) internal successors, (258), 204 states have internal predecessors, (258), 45 states have call successors, (45), 17 states have call predecessors, (45), 16 states have return successors, (43), 43 states have call predecessors, (43), 43 states have call successors, (43) Second operand 375 states. [2022-02-20 21:35:23,378 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 21:35:23,378 INFO L93 Difference]: Finished difference Result 375 states and 515 transitions. [2022-02-20 21:35:23,378 INFO L276 IsEmpty]: Start isEmpty. Operand 375 states and 515 transitions. [2022-02-20 21:35:23,380 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 21:35:23,380 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 21:35:23,380 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-02-20 21:35:23,380 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-02-20 21:35:23,381 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 263 states, 201 states have (on average 1.2835820895522387) internal successors, (258), 204 states have internal predecessors, (258), 45 states have call successors, (45), 17 states have call predecessors, (45), 16 states have return successors, (43), 43 states have call predecessors, (43), 43 states have call successors, (43) [2022-02-20 21:35:23,405 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 263 states to 263 states and 346 transitions. [2022-02-20 21:35:23,407 INFO L78 Accepts]: Start accepts. Automaton has 263 states and 346 transitions. Word has length 122 [2022-02-20 21:35:23,407 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-02-20 21:35:23,408 INFO L470 AbstractCegarLoop]: Abstraction has 263 states and 346 transitions. [2022-02-20 21:35:23,408 INFO L471 AbstractCegarLoop]: INTERPOLANT automaton has has 6 states, 6 states have (on average 11.5) internal successors, (69), 4 states have internal predecessors, (69), 2 states have call successors, (15), 4 states have call predecessors, (15), 1 states have return successors, (13), 2 states have call predecessors, (13), 2 states have call successors, (13) [2022-02-20 21:35:23,408 INFO L276 IsEmpty]: Start isEmpty. Operand 263 states and 346 transitions. [2022-02-20 21:35:23,410 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 131 [2022-02-20 21:35:23,410 INFO L506 BasicCegarLoop]: Found error trace [2022-02-20 21:35:23,410 INFO L514 BasicCegarLoop]: trace histogram [3, 3, 3, 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, 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:35:23,411 WARN L452 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable0 [2022-02-20 21:35:23,411 INFO L402 AbstractCegarLoop]: === Iteration 2 === Targeting ldv_errorErr0ASSERT_VIOLATIONERROR_FUNCTION === [ldv_errorErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-02-20 21:35:23,412 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-02-20 21:35:23,412 INFO L85 PathProgramCache]: Analyzing trace with hash 1747602214, now seen corresponding path program 1 times [2022-02-20 21:35:23,412 INFO L126 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-02-20 21:35:23,412 INFO L338 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [1186958518] [2022-02-20 21:35:23,412 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 21:35:23,413 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-02-20 21:35:23,490 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:23,533 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 3 [2022-02-20 21:35:23,534 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:23,537 INFO L290 TraceCheckUtils]: 0: Hoare triple {2537#true} assume true; {2537#true} is VALID [2022-02-20 21:35:23,537 INFO L284 TraceCheckUtils]: 1: Hoare quadruple {2537#true} {2537#true} #612#return; {2537#true} is VALID [2022-02-20 21:35:23,538 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 14 [2022-02-20 21:35:23,538 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:23,541 INFO L290 TraceCheckUtils]: 0: Hoare triple {2537#true} assume true; {2537#true} is VALID [2022-02-20 21:35:23,541 INFO L284 TraceCheckUtils]: 1: Hoare quadruple {2537#true} {2537#true} #614#return; {2537#true} is VALID [2022-02-20 21:35:23,545 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 18 [2022-02-20 21:35:23,547 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:23,551 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:35:23,553 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:23,556 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:35:23,558 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:23,561 INFO L290 TraceCheckUtils]: 0: Hoare triple {2608#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {2537#true} is VALID [2022-02-20 21:35:23,561 INFO L290 TraceCheckUtils]: 1: Hoare triple {2537#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {2537#true} is VALID [2022-02-20 21:35:23,561 INFO L290 TraceCheckUtils]: 2: Hoare triple {2537#true} assume true; {2537#true} is VALID [2022-02-20 21:35:23,561 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {2537#true} {2537#true} #590#return; {2537#true} is VALID [2022-02-20 21:35:23,562 INFO L290 TraceCheckUtils]: 0: Hoare triple {2608#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {2537#true} is VALID [2022-02-20 21:35:23,562 INFO L272 TraceCheckUtils]: 1: Hoare triple {2537#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {2608#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:23,563 INFO L290 TraceCheckUtils]: 2: Hoare triple {2608#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {2537#true} is VALID [2022-02-20 21:35:23,563 INFO L290 TraceCheckUtils]: 3: Hoare triple {2537#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {2537#true} is VALID [2022-02-20 21:35:23,563 INFO L290 TraceCheckUtils]: 4: Hoare triple {2537#true} assume true; {2537#true} is VALID [2022-02-20 21:35:23,563 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {2537#true} {2537#true} #590#return; {2537#true} is VALID [2022-02-20 21:35:23,563 INFO L290 TraceCheckUtils]: 6: Hoare triple {2537#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {2537#true} is VALID [2022-02-20 21:35:23,564 INFO L290 TraceCheckUtils]: 7: Hoare triple {2537#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {2537#true} is VALID [2022-02-20 21:35:23,564 INFO L290 TraceCheckUtils]: 8: Hoare triple {2537#true} assume true; {2537#true} is VALID [2022-02-20 21:35:23,564 INFO L284 TraceCheckUtils]: 9: Hoare quadruple {2537#true} {2537#true} #588#return; {2537#true} is VALID [2022-02-20 21:35:23,564 INFO L290 TraceCheckUtils]: 0: Hoare triple {2608#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size;~flags := #in~flags;havoc ~tmp~2.base, ~tmp~2.offset; {2537#true} is VALID [2022-02-20 21:35:23,565 INFO L272 TraceCheckUtils]: 1: Hoare triple {2537#true} call #t~ret40.base, #t~ret40.offset := kmalloc(~size, ~bitwiseOr(~flags, 32768)); {2608#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:23,565 INFO L290 TraceCheckUtils]: 2: Hoare triple {2608#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {2537#true} is VALID [2022-02-20 21:35:23,566 INFO L272 TraceCheckUtils]: 3: Hoare triple {2537#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {2608#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:23,566 INFO L290 TraceCheckUtils]: 4: Hoare triple {2608#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {2537#true} is VALID [2022-02-20 21:35:23,566 INFO L290 TraceCheckUtils]: 5: Hoare triple {2537#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {2537#true} is VALID [2022-02-20 21:35:23,566 INFO L290 TraceCheckUtils]: 6: Hoare triple {2537#true} assume true; {2537#true} is VALID [2022-02-20 21:35:23,567 INFO L284 TraceCheckUtils]: 7: Hoare quadruple {2537#true} {2537#true} #590#return; {2537#true} is VALID [2022-02-20 21:35:23,567 INFO L290 TraceCheckUtils]: 8: Hoare triple {2537#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {2537#true} is VALID [2022-02-20 21:35:23,567 INFO L290 TraceCheckUtils]: 9: Hoare triple {2537#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {2537#true} is VALID [2022-02-20 21:35:23,567 INFO L290 TraceCheckUtils]: 10: Hoare triple {2537#true} assume true; {2537#true} is VALID [2022-02-20 21:35:23,567 INFO L284 TraceCheckUtils]: 11: Hoare quadruple {2537#true} {2537#true} #588#return; {2537#true} is VALID [2022-02-20 21:35:23,568 INFO L290 TraceCheckUtils]: 12: Hoare triple {2537#true} ~tmp~2.base, ~tmp~2.offset := #t~ret40.base, #t~ret40.offset;havoc #t~ret40.base, #t~ret40.offset;#res.base, #res.offset := ~tmp~2.base, ~tmp~2.offset; {2537#true} is VALID [2022-02-20 21:35:23,568 INFO L290 TraceCheckUtils]: 13: Hoare triple {2537#true} assume true; {2537#true} is VALID [2022-02-20 21:35:23,568 INFO L284 TraceCheckUtils]: 14: Hoare quadruple {2537#true} {2537#true} #616#return; {2537#true} is VALID [2022-02-20 21:35:23,577 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 41 [2022-02-20 21:35:23,579 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:23,583 INFO L290 TraceCheckUtils]: 0: Hoare triple {2623#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;havoc ~err~0#1;assume { :begin_inline_ipmi_validate_addr } true;ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset, ipmi_validate_addr_#in~arg1#1 := ~data#1.base, 193 + ~data#1.offset, 40;havoc ipmi_validate_addr_#res#1;havoc ipmi_validate_addr_#t~nondet254#1, ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset, ipmi_validate_addr_~arg1#1;ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset := ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset;ipmi_validate_addr_~arg1#1 := ipmi_validate_addr_#in~arg1#1;assume -2147483648 <= ipmi_validate_addr_#t~nondet254#1 && ipmi_validate_addr_#t~nondet254#1 <= 2147483647;ipmi_validate_addr_#res#1 := ipmi_validate_addr_#t~nondet254#1;havoc ipmi_validate_addr_#t~nondet254#1; {2537#true} is VALID [2022-02-20 21:35:23,583 INFO L290 TraceCheckUtils]: 1: Hoare triple {2537#true} #t~ret62#1 := ipmi_validate_addr_#res#1;assume { :end_inline_ipmi_validate_addr } true;assume -2147483648 <= #t~ret62#1 && #t~ret62#1 <= 2147483647;~err~0#1 := #t~ret62#1;havoc #t~ret62#1; {2537#true} is VALID [2022-02-20 21:35:23,583 INFO L290 TraceCheckUtils]: 2: Hoare triple {2537#true} assume 0 != ~err~0#1; {2537#true} is VALID [2022-02-20 21:35:23,583 INFO L290 TraceCheckUtils]: 3: Hoare triple {2537#true} havoc #t~nondet69#1;call #t~mem70#1.base, #t~mem70#1.offset := read~$Pointer$(~data#1.base, 24 + ~data#1.offset, 8);havoc #t~mem70#1.base, #t~mem70#1.offset;#res#1 := ~err~0#1; {2537#true} is VALID [2022-02-20 21:35:23,584 INFO L290 TraceCheckUtils]: 4: Hoare triple {2537#true} assume true; {2537#true} is VALID [2022-02-20 21:35:23,584 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {2537#true} {2537#true} #618#return; {2537#true} is VALID [2022-02-20 21:35:23,584 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 49 [2022-02-20 21:35:23,585 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:23,592 INFO L290 TraceCheckUtils]: 0: Hoare triple {2537#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset; {2537#true} is VALID [2022-02-20 21:35:23,592 INFO L290 TraceCheckUtils]: 1: Hoare triple {2537#true} assume true; {2537#true} is VALID [2022-02-20 21:35:23,593 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {2537#true} {2537#true} #620#return; {2537#true} is VALID [2022-02-20 21:35:23,593 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 56 [2022-02-20 21:35:23,601 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:23,615 INFO L290 TraceCheckUtils]: 0: Hoare triple {2537#true} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;~offset#1 := #in~offset#1;havoc ~tmp~3#1;assume { :begin_inline___be16_to_cpup } true;__be16_to_cpup_#in~p#1.base, __be16_to_cpup_#in~p#1.offset := ~data#1.base, ~data#1.offset + 2 * (if ~offset#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then ~offset#1 % 18446744073709551616 % 18446744073709551616 else ~offset#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616);havoc __be16_to_cpup_#res#1;havoc __be16_to_cpup_#t~ret3#1, __be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset, __be16_to_cpup_~tmp~1#1;__be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset := __be16_to_cpup_#in~p#1.base, __be16_to_cpup_#in~p#1.offset;havoc __be16_to_cpup_~tmp~1#1;assume { :begin_inline___swab16p } true;__swab16p_#in~p#1.base, __swab16p_#in~p#1.offset := __be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset;havoc __swab16p_#res#1;havoc __swab16p_#t~mem1#1, __swab16p_#t~ret2#1, __swab16p_~p#1.base, __swab16p_~p#1.offset, __swab16p_~tmp~0#1;__swab16p_~p#1.base, __swab16p_~p#1.offset := __swab16p_#in~p#1.base, __swab16p_#in~p#1.offset;havoc __swab16p_~tmp~0#1;call __swab16p_#t~mem1#1 := read~int(__swab16p_~p#1.base, __swab16p_~p#1.offset, 2);assume { :begin_inline___fswab16 } true;__fswab16_#in~val#1 := __swab16p_#t~mem1#1 % 65536;havoc __fswab16_#res#1;havoc __fswab16_~val#1;__fswab16_~val#1 := __fswab16_#in~val#1;__fswab16_#res#1 := (if (1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) || 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536)) && 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) then (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) else (if 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) && (1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) || 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536)) then (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) else (if (1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) && (1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) || 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536))) || ((1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) || 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536)) && 1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536)) then 1 else ~bitwiseOr((if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536), (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536))))); {2537#true} is VALID [2022-02-20 21:35:23,617 INFO L290 TraceCheckUtils]: 1: Hoare triple {2537#true} __swab16p_#t~ret2#1 := __fswab16_#res#1;assume { :end_inline___fswab16 } true;__swab16p_~tmp~0#1 := __swab16p_#t~ret2#1;havoc __swab16p_#t~mem1#1;havoc __swab16p_#t~ret2#1;__swab16p_#res#1 := __swab16p_~tmp~0#1; {2537#true} is VALID [2022-02-20 21:35:23,618 INFO L290 TraceCheckUtils]: 2: Hoare triple {2537#true} __be16_to_cpup_#t~ret3#1 := __swab16p_#res#1;assume { :end_inline___swab16p } true;__be16_to_cpup_~tmp~1#1 := __be16_to_cpup_#t~ret3#1;havoc __be16_to_cpup_#t~ret3#1;__be16_to_cpup_#res#1 := __be16_to_cpup_~tmp~1#1; {2537#true} is VALID [2022-02-20 21:35:23,618 INFO L290 TraceCheckUtils]: 3: Hoare triple {2537#true} #t~ret61#1 := __be16_to_cpup_#res#1;assume { :end_inline___be16_to_cpup } true;~tmp~3#1 := #t~ret61#1;havoc #t~ret61#1;#res#1 := ~tmp~3#1; {2537#true} is VALID [2022-02-20 21:35:23,618 INFO L290 TraceCheckUtils]: 4: Hoare triple {2537#true} assume true; {2537#true} is VALID [2022-02-20 21:35:23,618 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {2537#true} {2538#false} #622#return; {2538#false} is VALID [2022-02-20 21:35:23,619 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 66 [2022-02-20 21:35:23,622 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:23,631 INFO L290 TraceCheckUtils]: 0: Hoare triple {2608#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {2537#true} is VALID [2022-02-20 21:35:23,631 INFO L290 TraceCheckUtils]: 1: Hoare triple {2537#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {2537#true} is VALID [2022-02-20 21:35:23,631 INFO L290 TraceCheckUtils]: 2: Hoare triple {2537#true} assume true; {2537#true} is VALID [2022-02-20 21:35:23,632 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {2537#true} {2538#false} #624#return; {2538#false} is VALID [2022-02-20 21:35:23,632 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 73 [2022-02-20 21:35:23,634 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:23,640 INFO L290 TraceCheckUtils]: 0: Hoare triple {2537#true} ~ptr.base, ~ptr.offset := #in~ptr.base, #in~ptr.offset;#res := (if (~ptr.base + ~ptr.offset) % 18446744073709551616 > 2012 then 1 else 0); {2537#true} is VALID [2022-02-20 21:35:23,640 INFO L290 TraceCheckUtils]: 1: Hoare triple {2537#true} assume true; {2537#true} is VALID [2022-02-20 21:35:23,640 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {2537#true} {2538#false} #626#return; {2538#false} is VALID [2022-02-20 21:35:23,640 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 80 [2022-02-20 21:35:23,643 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:23,652 INFO L290 TraceCheckUtils]: 0: Hoare triple {2537#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset;~arg1.base, ~arg1.offset := #in~arg1.base, #in~arg1.offset; {2537#true} is VALID [2022-02-20 21:35:23,652 INFO L290 TraceCheckUtils]: 1: Hoare triple {2537#true} assume true; {2537#true} is VALID [2022-02-20 21:35:23,652 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {2537#true} {2538#false} #628#return; {2538#false} is VALID [2022-02-20 21:35:23,653 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 87 [2022-02-20 21:35:23,657 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:23,661 INFO L290 TraceCheckUtils]: 0: Hoare triple {2623#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;havoc ~err~0#1;assume { :begin_inline_ipmi_validate_addr } true;ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset, ipmi_validate_addr_#in~arg1#1 := ~data#1.base, 193 + ~data#1.offset, 40;havoc ipmi_validate_addr_#res#1;havoc ipmi_validate_addr_#t~nondet254#1, ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset, ipmi_validate_addr_~arg1#1;ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset := ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset;ipmi_validate_addr_~arg1#1 := ipmi_validate_addr_#in~arg1#1;assume -2147483648 <= ipmi_validate_addr_#t~nondet254#1 && ipmi_validate_addr_#t~nondet254#1 <= 2147483647;ipmi_validate_addr_#res#1 := ipmi_validate_addr_#t~nondet254#1;havoc ipmi_validate_addr_#t~nondet254#1; {2537#true} is VALID [2022-02-20 21:35:23,662 INFO L290 TraceCheckUtils]: 1: Hoare triple {2537#true} #t~ret62#1 := ipmi_validate_addr_#res#1;assume { :end_inline_ipmi_validate_addr } true;assume -2147483648 <= #t~ret62#1 && #t~ret62#1 <= 2147483647;~err~0#1 := #t~ret62#1;havoc #t~ret62#1; {2537#true} is VALID [2022-02-20 21:35:23,662 INFO L290 TraceCheckUtils]: 2: Hoare triple {2537#true} assume 0 != ~err~0#1; {2537#true} is VALID [2022-02-20 21:35:23,663 INFO L290 TraceCheckUtils]: 3: Hoare triple {2537#true} havoc #t~nondet69#1;call #t~mem70#1.base, #t~mem70#1.offset := read~$Pointer$(~data#1.base, 24 + ~data#1.offset, 8);havoc #t~mem70#1.base, #t~mem70#1.offset;#res#1 := ~err~0#1; {2537#true} is VALID [2022-02-20 21:35:23,663 INFO L290 TraceCheckUtils]: 4: Hoare triple {2537#true} assume true; {2537#true} is VALID [2022-02-20 21:35:23,663 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {2537#true} {2538#false} #630#return; {2538#false} is VALID [2022-02-20 21:35:23,664 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 95 [2022-02-20 21:35:23,665 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:23,668 INFO L290 TraceCheckUtils]: 0: Hoare triple {2537#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset; {2537#true} is VALID [2022-02-20 21:35:23,668 INFO L290 TraceCheckUtils]: 1: Hoare triple {2537#true} assume true; {2537#true} is VALID [2022-02-20 21:35:23,668 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {2537#true} {2538#false} #632#return; {2538#false} is VALID [2022-02-20 21:35:23,668 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 104 [2022-02-20 21:35:23,672 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:23,676 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:35:23,678 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:23,682 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:35:23,683 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:23,686 INFO L290 TraceCheckUtils]: 0: Hoare triple {2608#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {2537#true} is VALID [2022-02-20 21:35:23,686 INFO L290 TraceCheckUtils]: 1: Hoare triple {2537#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {2537#true} is VALID [2022-02-20 21:35:23,686 INFO L290 TraceCheckUtils]: 2: Hoare triple {2537#true} assume true; {2537#true} is VALID [2022-02-20 21:35:23,686 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {2537#true} {2537#true} #590#return; {2537#true} is VALID [2022-02-20 21:35:23,687 INFO L290 TraceCheckUtils]: 0: Hoare triple {2608#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {2537#true} is VALID [2022-02-20 21:35:23,687 INFO L272 TraceCheckUtils]: 1: Hoare triple {2537#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {2608#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:23,687 INFO L290 TraceCheckUtils]: 2: Hoare triple {2608#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {2537#true} is VALID [2022-02-20 21:35:23,688 INFO L290 TraceCheckUtils]: 3: Hoare triple {2537#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {2537#true} is VALID [2022-02-20 21:35:23,688 INFO L290 TraceCheckUtils]: 4: Hoare triple {2537#true} assume true; {2537#true} is VALID [2022-02-20 21:35:23,688 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {2537#true} {2537#true} #590#return; {2537#true} is VALID [2022-02-20 21:35:23,688 INFO L290 TraceCheckUtils]: 6: Hoare triple {2537#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {2537#true} is VALID [2022-02-20 21:35:23,688 INFO L290 TraceCheckUtils]: 7: Hoare triple {2537#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {2537#true} is VALID [2022-02-20 21:35:23,689 INFO L290 TraceCheckUtils]: 8: Hoare triple {2537#true} assume true; {2537#true} is VALID [2022-02-20 21:35:23,689 INFO L284 TraceCheckUtils]: 9: Hoare quadruple {2537#true} {2537#true} #588#return; {2537#true} is VALID [2022-02-20 21:35:23,690 INFO L290 TraceCheckUtils]: 0: Hoare triple {2608#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size;~flags := #in~flags;havoc ~tmp~2.base, ~tmp~2.offset; {2537#true} is VALID [2022-02-20 21:35:23,691 INFO L272 TraceCheckUtils]: 1: Hoare triple {2537#true} call #t~ret40.base, #t~ret40.offset := kmalloc(~size, ~bitwiseOr(~flags, 32768)); {2608#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:23,691 INFO L290 TraceCheckUtils]: 2: Hoare triple {2608#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {2537#true} is VALID [2022-02-20 21:35:23,692 INFO L272 TraceCheckUtils]: 3: Hoare triple {2537#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {2608#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:23,692 INFO L290 TraceCheckUtils]: 4: Hoare triple {2608#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {2537#true} is VALID [2022-02-20 21:35:23,692 INFO L290 TraceCheckUtils]: 5: Hoare triple {2537#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {2537#true} is VALID [2022-02-20 21:35:23,692 INFO L290 TraceCheckUtils]: 6: Hoare triple {2537#true} assume true; {2537#true} is VALID [2022-02-20 21:35:23,693 INFO L284 TraceCheckUtils]: 7: Hoare quadruple {2537#true} {2537#true} #590#return; {2537#true} is VALID [2022-02-20 21:35:23,693 INFO L290 TraceCheckUtils]: 8: Hoare triple {2537#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {2537#true} is VALID [2022-02-20 21:35:23,694 INFO L290 TraceCheckUtils]: 9: Hoare triple {2537#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {2537#true} is VALID [2022-02-20 21:35:23,694 INFO L290 TraceCheckUtils]: 10: Hoare triple {2537#true} assume true; {2537#true} is VALID [2022-02-20 21:35:23,694 INFO L284 TraceCheckUtils]: 11: Hoare quadruple {2537#true} {2537#true} #588#return; {2537#true} is VALID [2022-02-20 21:35:23,694 INFO L290 TraceCheckUtils]: 12: Hoare triple {2537#true} ~tmp~2.base, ~tmp~2.offset := #t~ret40.base, #t~ret40.offset;havoc #t~ret40.base, #t~ret40.offset;#res.base, #res.offset := ~tmp~2.base, ~tmp~2.offset; {2537#true} is VALID [2022-02-20 21:35:23,695 INFO L290 TraceCheckUtils]: 13: Hoare triple {2537#true} assume true; {2537#true} is VALID [2022-02-20 21:35:23,695 INFO L284 TraceCheckUtils]: 14: Hoare quadruple {2537#true} {2538#false} #634#return; {2538#false} is VALID [2022-02-20 21:35:23,695 INFO L290 TraceCheckUtils]: 0: Hoare triple {2537#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(46, 2);call #Ultimate.allocInit(13, 3);call #Ultimate.allocInit(20, 4);call #Ultimate.allocInit(21, 5);call #Ultimate.allocInit(11, 6);call #Ultimate.allocInit(18, 7);call #Ultimate.allocInit(19, 8);call #Ultimate.allocInit(20, 9);call #Ultimate.allocInit(18, 10);call #Ultimate.allocInit(69, 11);call #Ultimate.allocInit(26, 12);call #Ultimate.allocInit(4, 13);call write~init~int(37, 13, 0, 1);call write~init~int(115, 13, 1, 1);call write~init~int(10, 13, 2, 1);call write~init~int(0, 13, 3, 1);call #Ultimate.allocInit(7, 14);call write~init~int(105, 14, 0, 1);call write~init~int(98, 14, 1, 1);call write~init~int(109, 14, 2, 1);call write~init~int(112, 14, 3, 1);call write~init~int(101, 14, 4, 1);call write~init~int(120, 14, 5, 1);call write~init~int(0, 14, 6, 1);call #Ultimate.allocInit(5, 15);call write~init~int(110, 15, 0, 1);call write~init~int(97, 15, 1, 1);call write~init~int(109, 15, 2, 1);call write~init~int(101, 15, 3, 1);call write~init~int(0, 15, 4, 1);call #Ultimate.allocInit(4, 16);call write~init~int(37, 16, 0, 1);call write~init~int(100, 16, 1, 1);call write~init~int(10, 16, 2, 1);call write~init~int(0, 16, 3, 1);call #Ultimate.allocInit(15, 17);call #Ultimate.allocInit(5, 18);call write~init~int(116, 18, 0, 1);call write~init~int(101, 18, 1, 1);call write~init~int(109, 18, 2, 1);call write~init~int(112, 18, 3, 1);call write~init~int(0, 18, 4, 1);call #Ultimate.allocInit(6, 19);call write~init~int(112, 19, 0, 1);call write~init~int(111, 19, 1, 1);call write~init~int(119, 19, 2, 1);call write~init~int(101, 19, 3, 1);call write~init~int(114, 19, 4, 1);call write~init~int(0, 19, 5, 1);call #Ultimate.allocInit(40, 20);call #Ultimate.allocInit(48, 21);call #Ultimate.allocInit(12, 22);call #Ultimate.allocInit(55, 23);call #Ultimate.allocInit(26, 24);call #Ultimate.allocInit(70, 25);~#power_sensor_sig~0.base, ~#power_sensor_sig~0.offset := 26, 0;call #Ultimate.allocInit(3, 26);call write~init~int(112, ~#power_sensor_sig~0.base, ~#power_sensor_sig~0.offset, 1);call write~init~int(119, ~#power_sensor_sig~0.base, 1 + ~#power_sensor_sig~0.offset, 1);call write~init~int(114, ~#power_sensor_sig~0.base, 2 + ~#power_sensor_sig~0.offset, 1);~#temp_sensor_sig~0.base, ~#temp_sensor_sig~0.offset := 27, 0;call #Ultimate.allocInit(3, 27);call write~init~int(116, ~#temp_sensor_sig~0.base, ~#temp_sensor_sig~0.offset, 1);call write~init~int(101, ~#temp_sensor_sig~0.base, 1 + ~#temp_sensor_sig~0.offset, 1);call write~init~int(109, ~#temp_sensor_sig~0.base, 2 + ~#temp_sensor_sig~0.offset, 1);~#watt_sensor_sig~0.base, ~#watt_sensor_sig~0.offset := 28, 0;call #Ultimate.allocInit(2, 28);call write~init~int(65, ~#watt_sensor_sig~0.base, ~#watt_sensor_sig~0.offset, 1);call write~init~int(67, ~#watt_sensor_sig~0.base, 1 + ~#watt_sensor_sig~0.offset, 1);~#power_sensor_name_templates~0.base, ~#power_sensor_name_templates~0.offset := 29, 0;call #Ultimate.allocInit(24, 29);call write~init~$Pointer$(3, 0, ~#power_sensor_name_templates~0.base, ~#power_sensor_name_templates~0.offset, 8);call write~init~$Pointer$(4, 0, ~#power_sensor_name_templates~0.base, 8 + ~#power_sensor_name_templates~0.offset, 8);call write~init~$Pointer$(5, 0, ~#power_sensor_name_templates~0.base, 16 + ~#power_sensor_name_templates~0.offset, 8);~#temp_sensor_name_templates~0.base, ~#temp_sensor_name_templates~0.offset := 30, 0;call #Ultimate.allocInit(24, 30);call write~init~$Pointer$(6, 0, ~#temp_sensor_name_templates~0.base, ~#temp_sensor_name_templates~0.offset, 8);call write~init~$Pointer$(7, 0, ~#temp_sensor_name_templates~0.base, 8 + ~#temp_sensor_name_templates~0.offset, 8);call write~init~$Pointer$(8, 0, ~#temp_sensor_name_templates~0.base, 16 + ~#temp_sensor_name_templates~0.offset, 8);~#driver_data~0.base, ~#driver_data~0.offset := 31, 0;call #Ultimate.allocInit(72, 31);call write~init~$Pointer$(~#driver_data~0.base, ~#driver_data~0.offset, ~#driver_data~0.base, ~#driver_data~0.offset, 8);call write~init~$Pointer$(~#driver_data~0.base, ~#driver_data~0.offset, ~#driver_data~0.base, 8 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(0, 0, ~#driver_data~0.base, 16 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(0, 0, ~#driver_data~0.base, 24 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(~#__this_module~0.base, ~#__this_module~0.offset, ~#driver_data~0.base, 32 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(#funAddr~ibmpex_register_bmc.base, #funAddr~ibmpex_register_bmc.offset, ~#driver_data~0.base, 40 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(#funAddr~ibmpex_bmc_gone.base, #funAddr~ibmpex_bmc_gone.offset, ~#driver_data~0.base, 48 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(#funAddr~ibmpex_msg_handler.base, #funAddr~ibmpex_msg_handler.offset, ~#driver_data~0.base, 56 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(0, 0, ~#driver_data~0.base, 64 + ~#driver_data~0.offset, 8);~#sensor_dev_attr_name~0.base, ~#sensor_dev_attr_name~0.offset := 32, 0;call #Ultimate.allocInit(48, 32);call write~init~$Pointer$(15, 0, ~#sensor_dev_attr_name~0.base, ~#sensor_dev_attr_name~0.offset, 8);call write~init~int(292, ~#sensor_dev_attr_name~0.base, 8 + ~#sensor_dev_attr_name~0.offset, 4);call write~init~$Pointer$(0, 0, ~#sensor_dev_attr_name~0.base, 12 + ~#sensor_dev_attr_name~0.offset, 8);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 20 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 21 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 22 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 23 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 24 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 25 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 26 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 27 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~$Pointer$(#funAddr~show_name.base, #funAddr~show_name.offset, ~#sensor_dev_attr_name~0.base, 28 + ~#sensor_dev_attr_name~0.offset, 8);call write~init~$Pointer$(0, 0, ~#sensor_dev_attr_name~0.base, 36 + ~#sensor_dev_attr_name~0.offset, 8);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 44 + ~#sensor_dev_attr_name~0.offset, 4);~#sensor_dev_attr_reset_high_low~0.base, ~#sensor_dev_attr_reset_high_low~0.offset := 33, 0;call #Ultimate.allocInit(48, 33);call write~init~$Pointer$(17, 0, ~#sensor_dev_attr_reset_high_low~0.base, ~#sensor_dev_attr_reset_high_low~0.offset, 8);call write~init~int(128, ~#sensor_dev_attr_reset_high_low~0.base, 8 + ~#sensor_dev_attr_reset_high_low~0.offset, 4);call write~init~$Pointer$(0, 0, ~#sensor_dev_attr_reset_high_low~0.base, 12 + ~#sensor_dev_attr_reset_high_low~0.offset, 8);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 20 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 21 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 22 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 23 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 24 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 25 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 26 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 27 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~$Pointer$(0, 0, ~#sensor_dev_attr_reset_high_low~0.base, 28 + ~#sensor_dev_attr_reset_high_low~0.offset, 8);call write~init~$Pointer$(#funAddr~ibmpex_reset_high_low.base, #funAddr~ibmpex_reset_high_low.offset, ~#sensor_dev_attr_reset_high_low~0.base, 36 + ~#sensor_dev_attr_reset_high_low~0.offset, 8);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 44 + ~#sensor_dev_attr_reset_high_low~0.offset, 4);~LDV_IN_INTERRUPT~0 := 0;~ldv_count_1~0 := 0;~ldv_count_2~0 := 0;~ldv_call_dev_attr_of_sensor_device_attribute~0 := 0;~ldv_call_dev_attr_of_sensor_device_attribute_2~0 := 0; {2537#true} is VALID [2022-02-20 21:35:23,695 INFO L290 TraceCheckUtils]: 1: Hoare triple {2537#true} assume { :end_inline_ULTIMATE.init } true;assume { :begin_inline_main } true;havoc main_#res#1;havoc main_#t~ret236#1, main_#t~nondet237#1, main_#t~switch238#1, main_#t~nondet239#1, main_~var_ibmpex_register_bmc_17_p0~0#1, main_~var_group1~0#1.base, main_~var_group1~0#1.offset, main_~var_ibmpex_bmc_gone_19_p0~0#1, main_~#var_group2~0#1.base, main_~#var_group2~0#1.offset, main_~#var_ibmpex_msg_handler_20_p1~0#1.base, main_~#var_ibmpex_msg_handler_20_p1~0#1.offset, main_~tmp~17#1, main_~tmp___0~4#1, main_~tmp___1~2#1;havoc main_~var_ibmpex_register_bmc_17_p0~0#1;havoc main_~var_group1~0#1.base, main_~var_group1~0#1.offset;havoc main_~var_ibmpex_bmc_gone_19_p0~0#1;call main_~#var_group2~0#1.base, main_~#var_group2~0#1.offset := #Ultimate.allocOnStack(374);call main_~#var_ibmpex_msg_handler_20_p1~0#1.base, main_~#var_ibmpex_msg_handler_20_p1~0#1.offset := #Ultimate.allocOnStack(915);havoc main_~tmp~17#1;havoc main_~tmp___0~4#1;havoc main_~tmp___1~2#1;~LDV_IN_INTERRUPT~0 := 1;assume { :begin_inline_ldv_initialize } true;~ldv_count_1~0 := 1 + ~ldv_count_1~0;~ldv_count_1~0 := 1 + ~ldv_count_1~0;~ldv_count_1~0 := 1 + ~ldv_count_1~0;~ldv_count_1~0 := 1 + ~ldv_count_1~0;~ldv_count_1~0 := 1 + ~ldv_count_1~0;~ldv_count_1~0 := 1 + ~ldv_count_1~0; {2537#true} is VALID [2022-02-20 21:35:23,696 INFO L290 TraceCheckUtils]: 2: Hoare triple {2537#true} assume { :end_inline_ldv_initialize } true; {2537#true} is VALID [2022-02-20 21:35:23,696 INFO L272 TraceCheckUtils]: 3: Hoare triple {2537#true} call ldv_handler_precall(); {2537#true} is VALID [2022-02-20 21:35:23,696 INFO L290 TraceCheckUtils]: 4: Hoare triple {2537#true} assume true; {2537#true} is VALID [2022-02-20 21:35:23,696 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {2537#true} {2537#true} #612#return; {2537#true} is VALID [2022-02-20 21:35:23,696 INFO L290 TraceCheckUtils]: 6: Hoare triple {2537#true} assume { :begin_inline_ibmpex_init } true;havoc ibmpex_init_#res#1;havoc ibmpex_init_#t~ret231#1, ibmpex_init_~tmp~16#1;havoc ibmpex_init_~tmp~16#1;assume { :begin_inline_ipmi_smi_watcher_register } true;ipmi_smi_watcher_register_#in~arg0#1.base, ipmi_smi_watcher_register_#in~arg0#1.offset := ~#driver_data~0.base, 16 + ~#driver_data~0.offset;havoc ipmi_smi_watcher_register_#res#1;havoc ipmi_smi_watcher_register_#t~nondet252#1, ipmi_smi_watcher_register_~arg0#1.base, ipmi_smi_watcher_register_~arg0#1.offset;ipmi_smi_watcher_register_~arg0#1.base, ipmi_smi_watcher_register_~arg0#1.offset := ipmi_smi_watcher_register_#in~arg0#1.base, ipmi_smi_watcher_register_#in~arg0#1.offset;assume -2147483648 <= ipmi_smi_watcher_register_#t~nondet252#1 && ipmi_smi_watcher_register_#t~nondet252#1 <= 2147483647;ipmi_smi_watcher_register_#res#1 := ipmi_smi_watcher_register_#t~nondet252#1;havoc ipmi_smi_watcher_register_#t~nondet252#1; {2537#true} is VALID [2022-02-20 21:35:23,697 INFO L290 TraceCheckUtils]: 7: Hoare triple {2537#true} ibmpex_init_#t~ret231#1 := ipmi_smi_watcher_register_#res#1;assume { :end_inline_ipmi_smi_watcher_register } true;assume -2147483648 <= ibmpex_init_#t~ret231#1 && ibmpex_init_#t~ret231#1 <= 2147483647;ibmpex_init_~tmp~16#1 := ibmpex_init_#t~ret231#1;havoc ibmpex_init_#t~ret231#1;ibmpex_init_#res#1 := ibmpex_init_~tmp~16#1; {2537#true} is VALID [2022-02-20 21:35:23,697 INFO L290 TraceCheckUtils]: 8: Hoare triple {2537#true} main_#t~ret236#1 := ibmpex_init_#res#1;assume { :end_inline_ibmpex_init } true;assume -2147483648 <= main_#t~ret236#1 && main_#t~ret236#1 <= 2147483647;main_~tmp~17#1 := main_#t~ret236#1;havoc main_#t~ret236#1; {2537#true} is VALID [2022-02-20 21:35:23,697 INFO L290 TraceCheckUtils]: 9: Hoare triple {2537#true} assume !(0 != main_~tmp~17#1); {2537#true} is VALID [2022-02-20 21:35:23,697 INFO L290 TraceCheckUtils]: 10: Hoare triple {2537#true} assume -2147483648 <= main_#t~nondet239#1 && main_#t~nondet239#1 <= 2147483647;main_~tmp___1~2#1 := main_#t~nondet239#1;havoc main_#t~nondet239#1; {2537#true} is VALID [2022-02-20 21:35:23,697 INFO L290 TraceCheckUtils]: 11: Hoare triple {2537#true} assume 0 != main_~tmp___1~2#1; {2537#true} is VALID [2022-02-20 21:35:23,697 INFO L290 TraceCheckUtils]: 12: Hoare triple {2537#true} assume -2147483648 <= main_#t~nondet237#1 && main_#t~nondet237#1 <= 2147483647;main_~tmp___0~4#1 := main_#t~nondet237#1;havoc main_#t~nondet237#1;main_#t~switch238#1 := 0 == main_~tmp___0~4#1; {2537#true} is VALID [2022-02-20 21:35:23,698 INFO L290 TraceCheckUtils]: 13: Hoare triple {2537#true} assume main_#t~switch238#1; {2537#true} is VALID [2022-02-20 21:35:23,698 INFO L272 TraceCheckUtils]: 14: Hoare triple {2537#true} call ldv_handler_precall(); {2537#true} is VALID [2022-02-20 21:35:23,703 INFO L290 TraceCheckUtils]: 15: Hoare triple {2537#true} assume true; {2537#true} is VALID [2022-02-20 21:35:23,703 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {2537#true} {2537#true} #614#return; {2537#true} is VALID [2022-02-20 21:35:23,703 INFO L290 TraceCheckUtils]: 17: Hoare triple {2537#true} assume { :begin_inline_ibmpex_register_bmc } true;ibmpex_register_bmc_#in~iface#1, ibmpex_register_bmc_#in~dev#1.base, ibmpex_register_bmc_#in~dev#1.offset := main_~var_ibmpex_register_bmc_17_p0~0#1, main_~var_group1~0#1.base, main_~var_group1~0#1.offset;havoc ibmpex_register_bmc_#t~ret178#1.base, ibmpex_register_bmc_#t~ret178#1.offset, ibmpex_register_bmc_#t~nondet179#1, ibmpex_register_bmc_#t~mem180#1, ibmpex_register_bmc_#t~ret181#1, ibmpex_register_bmc_#t~nondet182#1, ibmpex_register_bmc_#t~mem183#1, ibmpex_register_bmc_#t~ret184#1, ibmpex_register_bmc_#t~mem185#1.base, ibmpex_register_bmc_#t~mem185#1.offset, ibmpex_register_bmc_#t~ret186#1.base, ibmpex_register_bmc_#t~ret186#1.offset, ibmpex_register_bmc_#t~mem187#1.base, ibmpex_register_bmc_#t~mem187#1.offset, ibmpex_register_bmc_#t~ret188#1, ibmpex_register_bmc_#t~nondet189#1, ibmpex_register_bmc_#t~mem190#1.base, ibmpex_register_bmc_#t~mem190#1.offset, ibmpex_register_bmc_#t~mem191#1, ibmpex_register_bmc_#t~ret192#1, ibmpex_register_bmc_#t~nondet193#1, ibmpex_register_bmc_#t~mem194#1.base, ibmpex_register_bmc_#t~mem194#1.offset, ibmpex_register_bmc_#t~mem195#1.base, ibmpex_register_bmc_#t~mem195#1.offset, ibmpex_register_bmc_#t~mem196#1.base, ibmpex_register_bmc_#t~mem196#1.offset, ibmpex_register_bmc_#t~ret197#1, ibmpex_register_bmc_~iface#1, ibmpex_register_bmc_~dev#1.base, ibmpex_register_bmc_~dev#1.offset, ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset, ibmpex_register_bmc_~err~4#1, ibmpex_register_bmc_~tmp~14#1.base, ibmpex_register_bmc_~tmp~14#1.offset, ibmpex_register_bmc_~#__key~1#1.base, ibmpex_register_bmc_~#__key~1#1.offset, ibmpex_register_bmc_~tmp___0~3#1;ibmpex_register_bmc_~iface#1 := ibmpex_register_bmc_#in~iface#1;ibmpex_register_bmc_~dev#1.base, ibmpex_register_bmc_~dev#1.offset := ibmpex_register_bmc_#in~dev#1.base, ibmpex_register_bmc_#in~dev#1.offset;havoc ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset;havoc ibmpex_register_bmc_~err~4#1;havoc ibmpex_register_bmc_~tmp~14#1.base, ibmpex_register_bmc_~tmp~14#1.offset;call ibmpex_register_bmc_~#__key~1#1.base, ibmpex_register_bmc_~#__key~1#1.offset := #Ultimate.allocOnStack(8);havoc ibmpex_register_bmc_~tmp___0~3#1; {2537#true} is VALID [2022-02-20 21:35:23,704 INFO L272 TraceCheckUtils]: 18: Hoare triple {2537#true} call ibmpex_register_bmc_#t~ret178#1.base, ibmpex_register_bmc_#t~ret178#1.offset := kzalloc(968, 208); {2608#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:23,704 INFO L290 TraceCheckUtils]: 19: Hoare triple {2608#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size;~flags := #in~flags;havoc ~tmp~2.base, ~tmp~2.offset; {2537#true} is VALID [2022-02-20 21:35:23,705 INFO L272 TraceCheckUtils]: 20: Hoare triple {2537#true} call #t~ret40.base, #t~ret40.offset := kmalloc(~size, ~bitwiseOr(~flags, 32768)); {2608#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:23,705 INFO L290 TraceCheckUtils]: 21: Hoare triple {2608#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {2537#true} is VALID [2022-02-20 21:35:23,706 INFO L272 TraceCheckUtils]: 22: Hoare triple {2537#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {2608#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:23,706 INFO L290 TraceCheckUtils]: 23: Hoare triple {2608#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {2537#true} is VALID [2022-02-20 21:35:23,706 INFO L290 TraceCheckUtils]: 24: Hoare triple {2537#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {2537#true} is VALID [2022-02-20 21:35:23,706 INFO L290 TraceCheckUtils]: 25: Hoare triple {2537#true} assume true; {2537#true} is VALID [2022-02-20 21:35:23,706 INFO L284 TraceCheckUtils]: 26: Hoare quadruple {2537#true} {2537#true} #590#return; {2537#true} is VALID [2022-02-20 21:35:23,706 INFO L290 TraceCheckUtils]: 27: Hoare triple {2537#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {2537#true} is VALID [2022-02-20 21:35:23,707 INFO L290 TraceCheckUtils]: 28: Hoare triple {2537#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {2537#true} is VALID [2022-02-20 21:35:23,707 INFO L290 TraceCheckUtils]: 29: Hoare triple {2537#true} assume true; {2537#true} is VALID [2022-02-20 21:35:23,707 INFO L284 TraceCheckUtils]: 30: Hoare quadruple {2537#true} {2537#true} #588#return; {2537#true} is VALID [2022-02-20 21:35:23,707 INFO L290 TraceCheckUtils]: 31: Hoare triple {2537#true} ~tmp~2.base, ~tmp~2.offset := #t~ret40.base, #t~ret40.offset;havoc #t~ret40.base, #t~ret40.offset;#res.base, #res.offset := ~tmp~2.base, ~tmp~2.offset; {2537#true} is VALID [2022-02-20 21:35:23,707 INFO L290 TraceCheckUtils]: 32: Hoare triple {2537#true} assume true; {2537#true} is VALID [2022-02-20 21:35:23,708 INFO L284 TraceCheckUtils]: 33: Hoare quadruple {2537#true} {2537#true} #616#return; {2537#true} is VALID [2022-02-20 21:35:23,708 INFO L290 TraceCheckUtils]: 34: Hoare triple {2537#true} ibmpex_register_bmc_~tmp~14#1.base, ibmpex_register_bmc_~tmp~14#1.offset := ibmpex_register_bmc_#t~ret178#1.base, ibmpex_register_bmc_#t~ret178#1.offset;havoc ibmpex_register_bmc_#t~ret178#1.base, ibmpex_register_bmc_#t~ret178#1.offset;ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset := ibmpex_register_bmc_~tmp~14#1.base, ibmpex_register_bmc_~tmp~14#1.offset; {2537#true} is VALID [2022-02-20 21:35:23,708 INFO L290 TraceCheckUtils]: 35: Hoare triple {2537#true} assume !(0 == (ibmpex_register_bmc_~data~2#1.base + ibmpex_register_bmc_~data~2#1.offset) % 18446744073709551616);call write~int(12, ibmpex_register_bmc_~data~2#1.base, 193 + ibmpex_register_bmc_~data~2#1.offset, 4);call write~int(15, ibmpex_register_bmc_~data~2#1.base, 197 + ibmpex_register_bmc_~data~2#1.offset, 2);call write~int(0, ibmpex_register_bmc_~data~2#1.base, 199 + ibmpex_register_bmc_~data~2#1.offset, 1);call write~int(ibmpex_register_bmc_~iface#1, ibmpex_register_bmc_~data~2#1.base, 323 + ibmpex_register_bmc_~data~2#1.offset, 4);call write~$Pointer$(ibmpex_register_bmc_~dev#1.base, ibmpex_register_bmc_~dev#1.offset, ibmpex_register_bmc_~data~2#1.base, 24 + ibmpex_register_bmc_~data~2#1.offset, 8);call ibmpex_register_bmc_#t~mem180#1 := read~int(ibmpex_register_bmc_~data~2#1.base, 323 + ibmpex_register_bmc_~data~2#1.offset, 4);assume { :begin_inline_ipmi_create_user } true;ipmi_create_user_#in~arg0#1, ipmi_create_user_#in~arg1#1.base, ipmi_create_user_#in~arg1#1.offset, ipmi_create_user_#in~arg2#1.base, ipmi_create_user_#in~arg2#1.offset, ipmi_create_user_#in~arg3#1.base, ipmi_create_user_#in~arg3#1.offset := ibmpex_register_bmc_#t~mem180#1, ~#driver_data~0.base, 56 + ~#driver_data~0.offset, ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset, ibmpex_register_bmc_~data~2#1.base, 315 + ibmpex_register_bmc_~data~2#1.offset;havoc ipmi_create_user_#res#1;havoc ipmi_create_user_#t~nondet249#1, ipmi_create_user_~arg0#1, ipmi_create_user_~arg1#1.base, ipmi_create_user_~arg1#1.offset, ipmi_create_user_~arg2#1.base, ipmi_create_user_~arg2#1.offset, ipmi_create_user_~arg3#1.base, ipmi_create_user_~arg3#1.offset;ipmi_create_user_~arg0#1 := ipmi_create_user_#in~arg0#1;ipmi_create_user_~arg1#1.base, ipmi_create_user_~arg1#1.offset := ipmi_create_user_#in~arg1#1.base, ipmi_create_user_#in~arg1#1.offset;ipmi_create_user_~arg2#1.base, ipmi_create_user_~arg2#1.offset := ipmi_create_user_#in~arg2#1.base, ipmi_create_user_#in~arg2#1.offset;ipmi_create_user_~arg3#1.base, ipmi_create_user_~arg3#1.offset := ipmi_create_user_#in~arg3#1.base, ipmi_create_user_#in~arg3#1.offset;assume -2147483648 <= ipmi_create_user_#t~nondet249#1 && ipmi_create_user_#t~nondet249#1 <= 2147483647;ipmi_create_user_#res#1 := ipmi_create_user_#t~nondet249#1;havoc ipmi_create_user_#t~nondet249#1; {2537#true} is VALID [2022-02-20 21:35:23,708 INFO L290 TraceCheckUtils]: 36: Hoare triple {2537#true} ibmpex_register_bmc_#t~ret181#1 := ipmi_create_user_#res#1;assume { :end_inline_ipmi_create_user } true;assume -2147483648 <= ibmpex_register_bmc_#t~ret181#1 && ibmpex_register_bmc_#t~ret181#1 <= 2147483647;ibmpex_register_bmc_~err~4#1 := ibmpex_register_bmc_#t~ret181#1;havoc ibmpex_register_bmc_#t~mem180#1;havoc ibmpex_register_bmc_#t~ret181#1; {2537#true} is VALID [2022-02-20 21:35:23,708 INFO L290 TraceCheckUtils]: 37: Hoare triple {2537#true} assume !(ibmpex_register_bmc_~err~4#1 < 0);assume { :begin_inline___mutex_init } true;__mutex_init_#in~arg0#1.base, __mutex_init_#in~arg0#1.offset, __mutex_init_#in~arg1#1.base, __mutex_init_#in~arg1#1.offset, __mutex_init_#in~arg2#1.base, __mutex_init_#in~arg2#1.offset := ibmpex_register_bmc_~data~2#1.base, 32 + ibmpex_register_bmc_~data~2#1.offset, 22, 0, ibmpex_register_bmc_~#__key~1#1.base, ibmpex_register_bmc_~#__key~1#1.offset;havoc __mutex_init_~arg0#1.base, __mutex_init_~arg0#1.offset, __mutex_init_~arg1#1.base, __mutex_init_~arg1#1.offset, __mutex_init_~arg2#1.base, __mutex_init_~arg2#1.offset;__mutex_init_~arg0#1.base, __mutex_init_~arg0#1.offset := __mutex_init_#in~arg0#1.base, __mutex_init_#in~arg0#1.offset;__mutex_init_~arg1#1.base, __mutex_init_~arg1#1.offset := __mutex_init_#in~arg1#1.base, __mutex_init_#in~arg1#1.offset;__mutex_init_~arg2#1.base, __mutex_init_~arg2#1.offset := __mutex_init_#in~arg2#1.base, __mutex_init_#in~arg2#1.offset; {2537#true} is VALID [2022-02-20 21:35:23,709 INFO L290 TraceCheckUtils]: 38: Hoare triple {2537#true} assume { :end_inline___mutex_init } true;call write~int(0, ibmpex_register_bmc_~data~2#1.base, 611 + ibmpex_register_bmc_~data~2#1.offset, 8);assume { :begin_inline_init_completion } true;init_completion_#in~x#1.base, init_completion_#in~x#1.offset := ibmpex_register_bmc_~data~2#1.base, 231 + ibmpex_register_bmc_~data~2#1.offset;havoc init_completion_~x#1.base, init_completion_~x#1.offset, init_completion_~#__key~0#1.base, init_completion_~#__key~0#1.offset;init_completion_~x#1.base, init_completion_~x#1.offset := init_completion_#in~x#1.base, init_completion_#in~x#1.offset;call init_completion_~#__key~0#1.base, init_completion_~#__key~0#1.offset := #Ultimate.allocOnStack(8);call write~int(0, init_completion_~x#1.base, init_completion_~x#1.offset, 4);assume { :begin_inline___init_waitqueue_head } true;__init_waitqueue_head_#in~arg0#1.base, __init_waitqueue_head_#in~arg0#1.offset, __init_waitqueue_head_#in~arg1#1.base, __init_waitqueue_head_#in~arg1#1.offset := init_completion_~x#1.base, 4 + init_completion_~x#1.offset, init_completion_~#__key~0#1.base, init_completion_~#__key~0#1.offset;havoc __init_waitqueue_head_~arg0#1.base, __init_waitqueue_head_~arg0#1.offset, __init_waitqueue_head_~arg1#1.base, __init_waitqueue_head_~arg1#1.offset;__init_waitqueue_head_~arg0#1.base, __init_waitqueue_head_~arg0#1.offset := __init_waitqueue_head_#in~arg0#1.base, __init_waitqueue_head_#in~arg0#1.offset;__init_waitqueue_head_~arg1#1.base, __init_waitqueue_head_~arg1#1.offset := __init_waitqueue_head_#in~arg1#1.base, __init_waitqueue_head_#in~arg1#1.offset; {2537#true} is VALID [2022-02-20 21:35:23,709 INFO L290 TraceCheckUtils]: 39: Hoare triple {2537#true} assume { :end_inline___init_waitqueue_head } true;call ULTIMATE.dealloc(init_completion_~#__key~0#1.base, init_completion_~#__key~0#1.offset);havoc init_completion_~#__key~0#1.base, init_completion_~#__key~0#1.offset; {2537#true} is VALID [2022-02-20 21:35:23,709 INFO L290 TraceCheckUtils]: 40: Hoare triple {2537#true} assume { :end_inline_init_completion } true;call write~int(58, ibmpex_register_bmc_~data~2#1.base, 327 + ibmpex_register_bmc_~data~2#1.offset, 1);call write~int(60, ibmpex_register_bmc_~data~2#1.base, 328 + ibmpex_register_bmc_~data~2#1.offset, 1);call write~$Pointer$(ibmpex_register_bmc_~data~2#1.base, 339 + ibmpex_register_bmc_~data~2#1.offset, ibmpex_register_bmc_~data~2#1.base, 331 + ibmpex_register_bmc_~data~2#1.offset, 8);assume { :begin_inline_ibmpex_ver_check } true;ibmpex_ver_check_#in~data#1.base, ibmpex_ver_check_#in~data#1.offset := ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset;havoc ibmpex_ver_check_#res#1;havoc ibmpex_ver_check_#t~ret71#1, ibmpex_ver_check_#t~mem72#1, ibmpex_ver_check_#t~mem73#1, ibmpex_ver_check_#t~short74#1, ibmpex_ver_check_#t~mem75#1, ibmpex_ver_check_#t~mem76#1, ibmpex_ver_check_#t~ret77#1, ibmpex_ver_check_#t~nondet78#1, ibmpex_ver_check_#t~mem79#1.base, ibmpex_ver_check_#t~mem79#1.offset, ibmpex_ver_check_#t~mem80#1, ibmpex_ver_check_#t~mem81#1, ibmpex_ver_check_#t~mem82#1, ibmpex_ver_check_#t~mem83#1, ibmpex_ver_check_#t~mem84#1, ibmpex_ver_check_~data#1.base, ibmpex_ver_check_~data#1.offset, ibmpex_ver_check_~tmp~4#1;ibmpex_ver_check_~data#1.base, ibmpex_ver_check_~data#1.offset := ibmpex_ver_check_#in~data#1.base, ibmpex_ver_check_#in~data#1.offset;havoc ibmpex_ver_check_~tmp~4#1;call write~int(1, ibmpex_ver_check_~data#1.base, 339 + ibmpex_ver_check_~data#1.offset, 1);call write~int(1, ibmpex_ver_check_~data#1.base, 329 + ibmpex_ver_check_~data#1.offset, 2); {2537#true} is VALID [2022-02-20 21:35:23,710 INFO L272 TraceCheckUtils]: 41: Hoare triple {2537#true} call ibmpex_ver_check_#t~ret71#1 := ibmpex_send_message(ibmpex_ver_check_~data#1.base, ibmpex_ver_check_~data#1.offset); {2623#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} is VALID [2022-02-20 21:35:23,710 INFO L290 TraceCheckUtils]: 42: Hoare triple {2623#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;havoc ~err~0#1;assume { :begin_inline_ipmi_validate_addr } true;ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset, ipmi_validate_addr_#in~arg1#1 := ~data#1.base, 193 + ~data#1.offset, 40;havoc ipmi_validate_addr_#res#1;havoc ipmi_validate_addr_#t~nondet254#1, ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset, ipmi_validate_addr_~arg1#1;ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset := ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset;ipmi_validate_addr_~arg1#1 := ipmi_validate_addr_#in~arg1#1;assume -2147483648 <= ipmi_validate_addr_#t~nondet254#1 && ipmi_validate_addr_#t~nondet254#1 <= 2147483647;ipmi_validate_addr_#res#1 := ipmi_validate_addr_#t~nondet254#1;havoc ipmi_validate_addr_#t~nondet254#1; {2537#true} is VALID [2022-02-20 21:35:23,710 INFO L290 TraceCheckUtils]: 43: Hoare triple {2537#true} #t~ret62#1 := ipmi_validate_addr_#res#1;assume { :end_inline_ipmi_validate_addr } true;assume -2147483648 <= #t~ret62#1 && #t~ret62#1 <= 2147483647;~err~0#1 := #t~ret62#1;havoc #t~ret62#1; {2537#true} is VALID [2022-02-20 21:35:23,710 INFO L290 TraceCheckUtils]: 44: Hoare triple {2537#true} assume 0 != ~err~0#1; {2537#true} is VALID [2022-02-20 21:35:23,711 INFO L290 TraceCheckUtils]: 45: Hoare triple {2537#true} havoc #t~nondet69#1;call #t~mem70#1.base, #t~mem70#1.offset := read~$Pointer$(~data#1.base, 24 + ~data#1.offset, 8);havoc #t~mem70#1.base, #t~mem70#1.offset;#res#1 := ~err~0#1; {2537#true} is VALID [2022-02-20 21:35:23,711 INFO L290 TraceCheckUtils]: 46: Hoare triple {2537#true} assume true; {2537#true} is VALID [2022-02-20 21:35:23,711 INFO L284 TraceCheckUtils]: 47: Hoare quadruple {2537#true} {2537#true} #618#return; {2537#true} is VALID [2022-02-20 21:35:23,711 INFO L290 TraceCheckUtils]: 48: Hoare triple {2537#true} assume -2147483648 <= ibmpex_ver_check_#t~ret71#1 && ibmpex_ver_check_#t~ret71#1 <= 2147483647;havoc ibmpex_ver_check_#t~ret71#1; {2537#true} is VALID [2022-02-20 21:35:23,712 INFO L272 TraceCheckUtils]: 49: Hoare triple {2537#true} call wait_for_completion(ibmpex_ver_check_~data#1.base, 231 + ibmpex_ver_check_~data#1.offset); {2537#true} is VALID [2022-02-20 21:35:23,712 INFO L290 TraceCheckUtils]: 50: Hoare triple {2537#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset; {2537#true} is VALID [2022-02-20 21:35:23,712 INFO L290 TraceCheckUtils]: 51: Hoare triple {2537#true} assume true; {2537#true} is VALID [2022-02-20 21:35:23,712 INFO L284 TraceCheckUtils]: 52: Hoare quadruple {2537#true} {2537#true} #620#return; {2537#true} is VALID [2022-02-20 21:35:23,712 INFO L290 TraceCheckUtils]: 53: Hoare triple {2537#true} call ibmpex_ver_check_#t~mem72#1 := read~int(ibmpex_ver_check_~data#1.base, 899 + ibmpex_ver_check_~data#1.offset, 1);ibmpex_ver_check_#t~short74#1 := 0 != ibmpex_ver_check_#t~mem72#1 % 256 % 4294967296; {2537#true} is VALID [2022-02-20 21:35:23,713 INFO L290 TraceCheckUtils]: 54: Hoare triple {2537#true} assume ibmpex_ver_check_#t~short74#1; {2567#|ULTIMATE.start_ibmpex_ver_check_#t~short74#1|} is VALID [2022-02-20 21:35:23,718 INFO L290 TraceCheckUtils]: 55: Hoare triple {2567#|ULTIMATE.start_ibmpex_ver_check_#t~short74#1|} assume !ibmpex_ver_check_#t~short74#1;havoc ibmpex_ver_check_#t~mem72#1;havoc ibmpex_ver_check_#t~mem73#1;havoc ibmpex_ver_check_#t~short74#1;call ibmpex_ver_check_#t~mem75#1 := read~int(ibmpex_ver_check_~data#1.base, 619 + ibmpex_ver_check_~data#1.offset, 1);call write~int(ibmpex_ver_check_#t~mem75#1, ibmpex_ver_check_~data#1.base, 904 + ibmpex_ver_check_~data#1.offset, 1);havoc ibmpex_ver_check_#t~mem75#1;call ibmpex_ver_check_#t~mem76#1 := read~int(ibmpex_ver_check_~data#1.base, 620 + ibmpex_ver_check_~data#1.offset, 1);call write~int(ibmpex_ver_check_#t~mem76#1, ibmpex_ver_check_~data#1.base, 905 + ibmpex_ver_check_~data#1.offset, 1);havoc ibmpex_ver_check_#t~mem76#1; {2538#false} is VALID [2022-02-20 21:35:23,719 INFO L272 TraceCheckUtils]: 56: Hoare triple {2538#false} call ibmpex_ver_check_#t~ret77#1 := extract_value(ibmpex_ver_check_~data#1.base, 619 + ibmpex_ver_check_~data#1.offset, 2); {2537#true} is VALID [2022-02-20 21:35:23,719 INFO L290 TraceCheckUtils]: 57: Hoare triple {2537#true} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;~offset#1 := #in~offset#1;havoc ~tmp~3#1;assume { :begin_inline___be16_to_cpup } true;__be16_to_cpup_#in~p#1.base, __be16_to_cpup_#in~p#1.offset := ~data#1.base, ~data#1.offset + 2 * (if ~offset#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then ~offset#1 % 18446744073709551616 % 18446744073709551616 else ~offset#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616);havoc __be16_to_cpup_#res#1;havoc __be16_to_cpup_#t~ret3#1, __be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset, __be16_to_cpup_~tmp~1#1;__be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset := __be16_to_cpup_#in~p#1.base, __be16_to_cpup_#in~p#1.offset;havoc __be16_to_cpup_~tmp~1#1;assume { :begin_inline___swab16p } true;__swab16p_#in~p#1.base, __swab16p_#in~p#1.offset := __be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset;havoc __swab16p_#res#1;havoc __swab16p_#t~mem1#1, __swab16p_#t~ret2#1, __swab16p_~p#1.base, __swab16p_~p#1.offset, __swab16p_~tmp~0#1;__swab16p_~p#1.base, __swab16p_~p#1.offset := __swab16p_#in~p#1.base, __swab16p_#in~p#1.offset;havoc __swab16p_~tmp~0#1;call __swab16p_#t~mem1#1 := read~int(__swab16p_~p#1.base, __swab16p_~p#1.offset, 2);assume { :begin_inline___fswab16 } true;__fswab16_#in~val#1 := __swab16p_#t~mem1#1 % 65536;havoc __fswab16_#res#1;havoc __fswab16_~val#1;__fswab16_~val#1 := __fswab16_#in~val#1;__fswab16_#res#1 := (if (1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) || 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536)) && 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) then (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) else (if 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) && (1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) || 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536)) then (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) else (if (1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) && (1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) || 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536))) || ((1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) || 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536)) && 1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536)) then 1 else ~bitwiseOr((if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536), (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536))))); {2537#true} is VALID [2022-02-20 21:35:23,719 INFO L290 TraceCheckUtils]: 58: Hoare triple {2537#true} __swab16p_#t~ret2#1 := __fswab16_#res#1;assume { :end_inline___fswab16 } true;__swab16p_~tmp~0#1 := __swab16p_#t~ret2#1;havoc __swab16p_#t~mem1#1;havoc __swab16p_#t~ret2#1;__swab16p_#res#1 := __swab16p_~tmp~0#1; {2537#true} is VALID [2022-02-20 21:35:23,721 INFO L290 TraceCheckUtils]: 59: Hoare triple {2537#true} __be16_to_cpup_#t~ret3#1 := __swab16p_#res#1;assume { :end_inline___swab16p } true;__be16_to_cpup_~tmp~1#1 := __be16_to_cpup_#t~ret3#1;havoc __be16_to_cpup_#t~ret3#1;__be16_to_cpup_#res#1 := __be16_to_cpup_~tmp~1#1; {2537#true} is VALID [2022-02-20 21:35:23,724 INFO L290 TraceCheckUtils]: 60: Hoare triple {2537#true} #t~ret61#1 := __be16_to_cpup_#res#1;assume { :end_inline___be16_to_cpup } true;~tmp~3#1 := #t~ret61#1;havoc #t~ret61#1;#res#1 := ~tmp~3#1; {2537#true} is VALID [2022-02-20 21:35:23,724 INFO L290 TraceCheckUtils]: 61: Hoare triple {2537#true} assume true; {2537#true} is VALID [2022-02-20 21:35:23,726 INFO L284 TraceCheckUtils]: 62: Hoare quadruple {2537#true} {2538#false} #622#return; {2538#false} is VALID [2022-02-20 21:35:23,726 INFO L290 TraceCheckUtils]: 63: Hoare triple {2538#false} ibmpex_ver_check_~tmp~4#1 := ibmpex_ver_check_#t~ret77#1;havoc ibmpex_ver_check_#t~ret77#1;havoc ibmpex_ver_check_#t~nondet78#1;call ibmpex_ver_check_#t~mem79#1.base, ibmpex_ver_check_#t~mem79#1.offset := read~$Pointer$(ibmpex_ver_check_~data#1.base, 24 + ibmpex_ver_check_~data#1.offset, 8);call ibmpex_ver_check_#t~mem80#1 := read~int(ibmpex_ver_check_~data#1.base, 904 + ibmpex_ver_check_~data#1.offset, 1);call ibmpex_ver_check_#t~mem81#1 := read~int(ibmpex_ver_check_~data#1.base, 905 + ibmpex_ver_check_~data#1.offset, 1);call ibmpex_ver_check_#t~mem82#1 := read~int(ibmpex_ver_check_~data#1.base, 623 + ibmpex_ver_check_~data#1.offset, 1);call ibmpex_ver_check_#t~mem83#1 := read~int(ibmpex_ver_check_~data#1.base, 624 + ibmpex_ver_check_~data#1.offset, 1);call ibmpex_ver_check_#t~mem84#1 := read~int(ibmpex_ver_check_~data#1.base, 323 + ibmpex_ver_check_~data#1.offset, 4);havoc ibmpex_ver_check_#t~mem79#1.base, ibmpex_ver_check_#t~mem79#1.offset;havoc ibmpex_ver_check_#t~mem80#1;havoc ibmpex_ver_check_#t~mem81#1;havoc ibmpex_ver_check_#t~mem82#1;havoc ibmpex_ver_check_#t~mem83#1;havoc ibmpex_ver_check_#t~mem84#1;ibmpex_ver_check_#res#1 := 0; {2538#false} is VALID [2022-02-20 21:35:23,726 INFO L290 TraceCheckUtils]: 64: Hoare triple {2538#false} ibmpex_register_bmc_#t~ret184#1 := ibmpex_ver_check_#res#1;assume { :end_inline_ibmpex_ver_check } true;assume -2147483648 <= ibmpex_register_bmc_#t~ret184#1 && ibmpex_register_bmc_#t~ret184#1 <= 2147483647;ibmpex_register_bmc_~err~4#1 := ibmpex_register_bmc_#t~ret184#1;havoc ibmpex_register_bmc_#t~ret184#1; {2538#false} is VALID [2022-02-20 21:35:23,726 INFO L290 TraceCheckUtils]: 65: Hoare triple {2538#false} assume !(0 != ibmpex_register_bmc_~err~4#1);call ibmpex_register_bmc_#t~mem185#1.base, ibmpex_register_bmc_#t~mem185#1.offset := read~$Pointer$(ibmpex_register_bmc_~data~2#1.base, 24 + ibmpex_register_bmc_~data~2#1.offset, 8);assume { :begin_inline_hwmon_device_register } true;hwmon_device_register_#in~arg0#1.base, hwmon_device_register_#in~arg0#1.offset := ibmpex_register_bmc_#t~mem185#1.base, ibmpex_register_bmc_#t~mem185#1.offset;havoc hwmon_device_register_#res#1.base, hwmon_device_register_#res#1.offset;havoc hwmon_device_register_#t~ret248#1.base, hwmon_device_register_#t~ret248#1.offset, hwmon_device_register_~arg0#1.base, hwmon_device_register_~arg0#1.offset;hwmon_device_register_~arg0#1.base, hwmon_device_register_~arg0#1.offset := hwmon_device_register_#in~arg0#1.base, hwmon_device_register_#in~arg0#1.offset; {2538#false} is VALID [2022-02-20 21:35:23,727 INFO L272 TraceCheckUtils]: 66: Hoare triple {2538#false} call hwmon_device_register_#t~ret248#1.base, hwmon_device_register_#t~ret248#1.offset := ldv_malloc(1035); {2608#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:23,727 INFO L290 TraceCheckUtils]: 67: Hoare triple {2608#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {2537#true} is VALID [2022-02-20 21:35:23,728 INFO L290 TraceCheckUtils]: 68: Hoare triple {2537#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {2537#true} is VALID [2022-02-20 21:35:23,728 INFO L290 TraceCheckUtils]: 69: Hoare triple {2537#true} assume true; {2537#true} is VALID [2022-02-20 21:35:23,728 INFO L284 TraceCheckUtils]: 70: Hoare quadruple {2537#true} {2538#false} #624#return; {2538#false} is VALID [2022-02-20 21:35:23,728 INFO L290 TraceCheckUtils]: 71: Hoare triple {2538#false} hwmon_device_register_#res#1.base, hwmon_device_register_#res#1.offset := hwmon_device_register_#t~ret248#1.base, hwmon_device_register_#t~ret248#1.offset;havoc hwmon_device_register_#t~ret248#1.base, hwmon_device_register_#t~ret248#1.offset; {2538#false} is VALID [2022-02-20 21:35:23,729 INFO L290 TraceCheckUtils]: 72: Hoare triple {2538#false} ibmpex_register_bmc_#t~ret186#1.base, ibmpex_register_bmc_#t~ret186#1.offset := hwmon_device_register_#res#1.base, hwmon_device_register_#res#1.offset;assume { :end_inline_hwmon_device_register } true;call write~$Pointer$(ibmpex_register_bmc_#t~ret186#1.base, ibmpex_register_bmc_#t~ret186#1.offset, ibmpex_register_bmc_~data~2#1.base, 16 + ibmpex_register_bmc_~data~2#1.offset, 8);havoc ibmpex_register_bmc_#t~mem185#1.base, ibmpex_register_bmc_#t~mem185#1.offset;havoc ibmpex_register_bmc_#t~ret186#1.base, ibmpex_register_bmc_#t~ret186#1.offset;call ibmpex_register_bmc_#t~mem187#1.base, ibmpex_register_bmc_#t~mem187#1.offset := read~$Pointer$(ibmpex_register_bmc_~data~2#1.base, 16 + ibmpex_register_bmc_~data~2#1.offset, 8);assume { :begin_inline_IS_ERR } true;IS_ERR_#in~ptr#1.base, IS_ERR_#in~ptr#1.offset := ibmpex_register_bmc_#t~mem187#1.base, ibmpex_register_bmc_#t~mem187#1.offset;havoc IS_ERR_#res#1;havoc IS_ERR_#t~ret240#1, IS_ERR_~ptr#1.base, IS_ERR_~ptr#1.offset, IS_ERR_~tmp~18#1;IS_ERR_~ptr#1.base, IS_ERR_~ptr#1.offset := IS_ERR_#in~ptr#1.base, IS_ERR_#in~ptr#1.offset;havoc IS_ERR_~tmp~18#1; {2538#false} is VALID [2022-02-20 21:35:23,729 INFO L272 TraceCheckUtils]: 73: Hoare triple {2538#false} call IS_ERR_#t~ret240#1 := ldv_is_err(IS_ERR_~ptr#1.base, IS_ERR_~ptr#1.offset); {2537#true} is VALID [2022-02-20 21:35:23,729 INFO L290 TraceCheckUtils]: 74: Hoare triple {2537#true} ~ptr.base, ~ptr.offset := #in~ptr.base, #in~ptr.offset;#res := (if (~ptr.base + ~ptr.offset) % 18446744073709551616 > 2012 then 1 else 0); {2537#true} is VALID [2022-02-20 21:35:23,729 INFO L290 TraceCheckUtils]: 75: Hoare triple {2537#true} assume true; {2537#true} is VALID [2022-02-20 21:35:23,729 INFO L284 TraceCheckUtils]: 76: Hoare quadruple {2537#true} {2538#false} #626#return; {2538#false} is VALID [2022-02-20 21:35:23,730 INFO L290 TraceCheckUtils]: 77: Hoare triple {2538#false} assume -9223372036854775808 <= IS_ERR_#t~ret240#1 && IS_ERR_#t~ret240#1 <= 9223372036854775807;IS_ERR_~tmp~18#1 := IS_ERR_#t~ret240#1;havoc IS_ERR_#t~ret240#1;IS_ERR_#res#1 := IS_ERR_~tmp~18#1; {2538#false} is VALID [2022-02-20 21:35:23,730 INFO L290 TraceCheckUtils]: 78: Hoare triple {2538#false} ibmpex_register_bmc_#t~ret188#1 := IS_ERR_#res#1;assume { :end_inline_IS_ERR } true;assume -9223372036854775808 <= ibmpex_register_bmc_#t~ret188#1 && ibmpex_register_bmc_#t~ret188#1 <= 9223372036854775807;ibmpex_register_bmc_~tmp___0~3#1 := ibmpex_register_bmc_#t~ret188#1;havoc ibmpex_register_bmc_#t~mem187#1.base, ibmpex_register_bmc_#t~mem187#1.offset;havoc ibmpex_register_bmc_#t~ret188#1; {2538#false} is VALID [2022-02-20 21:35:23,730 INFO L290 TraceCheckUtils]: 79: Hoare triple {2538#false} assume !(0 != ibmpex_register_bmc_~tmp___0~3#1); {2538#false} is VALID [2022-02-20 21:35:23,730 INFO L272 TraceCheckUtils]: 80: Hoare triple {2538#false} call dev_set_drvdata(ibmpex_register_bmc_~dev#1.base, ibmpex_register_bmc_~dev#1.offset, ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset); {2537#true} is VALID [2022-02-20 21:35:23,730 INFO L290 TraceCheckUtils]: 81: Hoare triple {2537#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset;~arg1.base, ~arg1.offset := #in~arg1.base, #in~arg1.offset; {2537#true} is VALID [2022-02-20 21:35:23,730 INFO L290 TraceCheckUtils]: 82: Hoare triple {2537#true} assume true; {2537#true} is VALID [2022-02-20 21:35:23,731 INFO L284 TraceCheckUtils]: 83: Hoare quadruple {2537#true} {2538#false} #628#return; {2538#false} is VALID [2022-02-20 21:35:23,731 INFO L290 TraceCheckUtils]: 84: Hoare triple {2538#false} assume { :begin_inline_list_add_tail } true;list_add_tail_#in~new#1.base, list_add_tail_#in~new#1.offset, list_add_tail_#in~head#1.base, list_add_tail_#in~head#1.offset := ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset, ~#driver_data~0.base, ~#driver_data~0.offset;havoc list_add_tail_#t~mem12#1.base, list_add_tail_#t~mem12#1.offset, list_add_tail_~new#1.base, list_add_tail_~new#1.offset, list_add_tail_~head#1.base, list_add_tail_~head#1.offset;list_add_tail_~new#1.base, list_add_tail_~new#1.offset := list_add_tail_#in~new#1.base, list_add_tail_#in~new#1.offset;list_add_tail_~head#1.base, list_add_tail_~head#1.offset := list_add_tail_#in~head#1.base, list_add_tail_#in~head#1.offset;call list_add_tail_#t~mem12#1.base, list_add_tail_#t~mem12#1.offset := read~$Pointer$(list_add_tail_~head#1.base, 8 + list_add_tail_~head#1.offset, 8);assume { :begin_inline___list_add } true;__list_add_#in~arg0#1.base, __list_add_#in~arg0#1.offset, __list_add_#in~arg1#1.base, __list_add_#in~arg1#1.offset, __list_add_#in~arg2#1.base, __list_add_#in~arg2#1.offset := list_add_tail_~new#1.base, list_add_tail_~new#1.offset, list_add_tail_#t~mem12#1.base, list_add_tail_#t~mem12#1.offset, list_add_tail_~head#1.base, list_add_tail_~head#1.offset;havoc __list_add_~arg0#1.base, __list_add_~arg0#1.offset, __list_add_~arg1#1.base, __list_add_~arg1#1.offset, __list_add_~arg2#1.base, __list_add_~arg2#1.offset;__list_add_~arg0#1.base, __list_add_~arg0#1.offset := __list_add_#in~arg0#1.base, __list_add_#in~arg0#1.offset;__list_add_~arg1#1.base, __list_add_~arg1#1.offset := __list_add_#in~arg1#1.base, __list_add_#in~arg1#1.offset;__list_add_~arg2#1.base, __list_add_~arg2#1.offset := __list_add_#in~arg2#1.base, __list_add_#in~arg2#1.offset; {2538#false} is VALID [2022-02-20 21:35:23,731 INFO L290 TraceCheckUtils]: 85: Hoare triple {2538#false} assume { :end_inline___list_add } true;havoc list_add_tail_#t~mem12#1.base, list_add_tail_#t~mem12#1.offset; {2538#false} is VALID [2022-02-20 21:35:23,731 INFO L290 TraceCheckUtils]: 86: Hoare triple {2538#false} assume { :end_inline_list_add_tail } true;assume { :begin_inline_ibmpex_find_sensors } true;ibmpex_find_sensors_#in~data#1.base, ibmpex_find_sensors_#in~data#1.offset := ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset;havoc ibmpex_find_sensors_#res#1;havoc ibmpex_find_sensors_#t~ret148#1, ibmpex_find_sensors_#t~mem149#1, ibmpex_find_sensors_#t~ret150#1.base, ibmpex_find_sensors_#t~ret150#1.offset, ibmpex_find_sensors_#t~mem151#1.base, ibmpex_find_sensors_#t~mem151#1.offset, ibmpex_find_sensors_#t~ret152#1, ibmpex_find_sensors_#t~mem153#1, ibmpex_find_sensors_#t~ret154#1, ibmpex_find_sensors_#t~mem155#1.base, ibmpex_find_sensors_#t~mem155#1.offset, ibmpex_find_sensors_#t~mem156#1, ibmpex_find_sensors_#t~ret157#1, ibmpex_find_sensors_#t~mem158#1, ibmpex_find_sensors_#t~ret159#1, ibmpex_find_sensors_#t~mem160#1.base, ibmpex_find_sensors_#t~mem160#1.offset, ibmpex_find_sensors_#t~mem161#1.base, ibmpex_find_sensors_#t~mem161#1.offset, ibmpex_find_sensors_#t~ret162#1, ibmpex_find_sensors_#t~mem163#1, ibmpex_find_sensors_#t~mem164#1.base, ibmpex_find_sensors_#t~mem164#1.offset, ibmpex_find_sensors_#t~ret165#1, ibmpex_find_sensors_#t~mem166#1.base, ibmpex_find_sensors_#t~mem166#1.offset, ibmpex_find_sensors_#t~ret167#1, ibmpex_find_sensors_#t~mem168#1.base, ibmpex_find_sensors_#t~mem168#1.offset, ibmpex_find_sensors_#t~mem169#1.base, ibmpex_find_sensors_#t~mem169#1.offset, ibmpex_find_sensors_#t~mem170#1.base, ibmpex_find_sensors_#t~mem170#1.offset, ibmpex_find_sensors_#t~mem171#1.base, ibmpex_find_sensors_#t~mem171#1.offset, ibmpex_find_sensors_#t~mem172#1.base, ibmpex_find_sensors_#t~mem172#1.offset, ibmpex_find_sensors_#t~mem173#1.base, ibmpex_find_sensors_#t~mem173#1.offset, ibmpex_find_sensors_#t~mem174#1.base, ibmpex_find_sensors_#t~mem174#1.offset, ibmpex_find_sensors_#t~mem175#1.base, ibmpex_find_sensors_#t~mem175#1.offset, ibmpex_find_sensors_#t~mem176#1, ibmpex_find_sensors_#t~mem177#1.base, ibmpex_find_sensors_#t~mem177#1.offset, ibmpex_find_sensors_~data#1.base, ibmpex_find_sensors_~data#1.offset, ibmpex_find_sensors_~i~2#1, ibmpex_find_sensors_~j~0#1, ibmpex_find_sensors_~err~3#1, ibmpex_find_sensors_~sensor_type~0#1, ibmpex_find_sensors_~sensor_counter~0#1, ibmpex_find_sensors_~num_power~0#1, ibmpex_find_sensors_~num_temp~0#1, ibmpex_find_sensors_~tmp~13#1.base, ibmpex_find_sensors_~tmp~13#1.offset, ibmpex_find_sensors_~tmp___0~2#1, ibmpex_find_sensors_~tmp___1~1#1;ibmpex_find_sensors_~data#1.base, ibmpex_find_sensors_~data#1.offset := ibmpex_find_sensors_#in~data#1.base, ibmpex_find_sensors_#in~data#1.offset;havoc ibmpex_find_sensors_~i~2#1;havoc ibmpex_find_sensors_~j~0#1;havoc ibmpex_find_sensors_~err~3#1;havoc ibmpex_find_sensors_~sensor_type~0#1;havoc ibmpex_find_sensors_~sensor_counter~0#1;havoc ibmpex_find_sensors_~num_power~0#1;havoc ibmpex_find_sensors_~num_temp~0#1;havoc ibmpex_find_sensors_~tmp~13#1.base, ibmpex_find_sensors_~tmp~13#1.offset;havoc ibmpex_find_sensors_~tmp___0~2#1;havoc ibmpex_find_sensors_~tmp___1~1#1;ibmpex_find_sensors_~num_power~0#1 := 0;ibmpex_find_sensors_~num_temp~0#1 := 0;assume { :begin_inline_ibmpex_query_sensor_count } true;ibmpex_query_sensor_count_#in~data#1.base, ibmpex_query_sensor_count_#in~data#1.offset := ibmpex_find_sensors_~data#1.base, ibmpex_find_sensors_~data#1.offset;havoc ibmpex_query_sensor_count_#res#1;havoc ibmpex_query_sensor_count_#t~ret85#1, ibmpex_query_sensor_count_#t~mem86#1, ibmpex_query_sensor_count_#t~mem87#1, ibmpex_query_sensor_count_#t~short88#1, ibmpex_query_sensor_count_#t~mem89#1, ibmpex_query_sensor_count_~data#1.base, ibmpex_query_sensor_count_~data#1.offset;ibmpex_query_sensor_count_~data#1.base, ibmpex_query_sensor_count_~data#1.offset := ibmpex_query_sensor_count_#in~data#1.base, ibmpex_query_sensor_count_#in~data#1.offset;call write~int(2, ibmpex_query_sensor_count_~data#1.base, 339 + ibmpex_query_sensor_count_~data#1.offset, 1);call write~int(1, ibmpex_query_sensor_count_~data#1.base, 329 + ibmpex_query_sensor_count_~data#1.offset, 2); {2538#false} is VALID [2022-02-20 21:35:23,731 INFO L272 TraceCheckUtils]: 87: Hoare triple {2538#false} call ibmpex_query_sensor_count_#t~ret85#1 := ibmpex_send_message(ibmpex_query_sensor_count_~data#1.base, ibmpex_query_sensor_count_~data#1.offset); {2623#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} is VALID [2022-02-20 21:35:23,732 INFO L290 TraceCheckUtils]: 88: Hoare triple {2623#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;havoc ~err~0#1;assume { :begin_inline_ipmi_validate_addr } true;ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset, ipmi_validate_addr_#in~arg1#1 := ~data#1.base, 193 + ~data#1.offset, 40;havoc ipmi_validate_addr_#res#1;havoc ipmi_validate_addr_#t~nondet254#1, ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset, ipmi_validate_addr_~arg1#1;ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset := ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset;ipmi_validate_addr_~arg1#1 := ipmi_validate_addr_#in~arg1#1;assume -2147483648 <= ipmi_validate_addr_#t~nondet254#1 && ipmi_validate_addr_#t~nondet254#1 <= 2147483647;ipmi_validate_addr_#res#1 := ipmi_validate_addr_#t~nondet254#1;havoc ipmi_validate_addr_#t~nondet254#1; {2537#true} is VALID [2022-02-20 21:35:23,732 INFO L290 TraceCheckUtils]: 89: Hoare triple {2537#true} #t~ret62#1 := ipmi_validate_addr_#res#1;assume { :end_inline_ipmi_validate_addr } true;assume -2147483648 <= #t~ret62#1 && #t~ret62#1 <= 2147483647;~err~0#1 := #t~ret62#1;havoc #t~ret62#1; {2537#true} is VALID [2022-02-20 21:35:23,732 INFO L290 TraceCheckUtils]: 90: Hoare triple {2537#true} assume 0 != ~err~0#1; {2537#true} is VALID [2022-02-20 21:35:23,732 INFO L290 TraceCheckUtils]: 91: Hoare triple {2537#true} havoc #t~nondet69#1;call #t~mem70#1.base, #t~mem70#1.offset := read~$Pointer$(~data#1.base, 24 + ~data#1.offset, 8);havoc #t~mem70#1.base, #t~mem70#1.offset;#res#1 := ~err~0#1; {2537#true} is VALID [2022-02-20 21:35:23,732 INFO L290 TraceCheckUtils]: 92: Hoare triple {2537#true} assume true; {2537#true} is VALID [2022-02-20 21:35:23,732 INFO L284 TraceCheckUtils]: 93: Hoare quadruple {2537#true} {2538#false} #630#return; {2538#false} is VALID [2022-02-20 21:35:23,733 INFO L290 TraceCheckUtils]: 94: Hoare triple {2538#false} assume -2147483648 <= ibmpex_query_sensor_count_#t~ret85#1 && ibmpex_query_sensor_count_#t~ret85#1 <= 2147483647;havoc ibmpex_query_sensor_count_#t~ret85#1; {2538#false} is VALID [2022-02-20 21:35:23,733 INFO L272 TraceCheckUtils]: 95: Hoare triple {2538#false} call wait_for_completion(ibmpex_query_sensor_count_~data#1.base, 231 + ibmpex_query_sensor_count_~data#1.offset); {2537#true} is VALID [2022-02-20 21:35:23,733 INFO L290 TraceCheckUtils]: 96: Hoare triple {2537#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset; {2537#true} is VALID [2022-02-20 21:35:23,733 INFO L290 TraceCheckUtils]: 97: Hoare triple {2537#true} assume true; {2537#true} is VALID [2022-02-20 21:35:23,733 INFO L284 TraceCheckUtils]: 98: Hoare quadruple {2537#true} {2538#false} #632#return; {2538#false} is VALID [2022-02-20 21:35:23,734 INFO L290 TraceCheckUtils]: 99: Hoare triple {2538#false} call ibmpex_query_sensor_count_#t~mem86#1 := read~int(ibmpex_query_sensor_count_~data#1.base, 899 + ibmpex_query_sensor_count_~data#1.offset, 1);ibmpex_query_sensor_count_#t~short88#1 := 0 != ibmpex_query_sensor_count_#t~mem86#1 % 256 % 4294967296; {2538#false} is VALID [2022-02-20 21:35:23,734 INFO L290 TraceCheckUtils]: 100: Hoare triple {2538#false} assume !ibmpex_query_sensor_count_#t~short88#1;call ibmpex_query_sensor_count_#t~mem87#1 := read~int(ibmpex_query_sensor_count_~data#1.base, 891 + ibmpex_query_sensor_count_~data#1.offset, 8);ibmpex_query_sensor_count_#t~short88#1 := 1 != ibmpex_query_sensor_count_#t~mem87#1 % 18446744073709551616; {2538#false} is VALID [2022-02-20 21:35:23,734 INFO L290 TraceCheckUtils]: 101: Hoare triple {2538#false} assume ibmpex_query_sensor_count_#t~short88#1;havoc ibmpex_query_sensor_count_#t~mem86#1;havoc ibmpex_query_sensor_count_#t~mem87#1;havoc ibmpex_query_sensor_count_#t~short88#1;ibmpex_query_sensor_count_#res#1 := -2; {2538#false} is VALID [2022-02-20 21:35:23,734 INFO L290 TraceCheckUtils]: 102: Hoare triple {2538#false} ibmpex_find_sensors_#t~ret148#1 := ibmpex_query_sensor_count_#res#1;assume { :end_inline_ibmpex_query_sensor_count } true;assume -2147483648 <= ibmpex_find_sensors_#t~ret148#1 && ibmpex_find_sensors_#t~ret148#1 <= 2147483647;ibmpex_find_sensors_~err~3#1 := ibmpex_find_sensors_#t~ret148#1;havoc ibmpex_find_sensors_#t~ret148#1; {2538#false} is VALID [2022-02-20 21:35:23,734 INFO L290 TraceCheckUtils]: 103: Hoare triple {2538#false} assume !(ibmpex_find_sensors_~err~3#1 <= 0);call write~int(ibmpex_find_sensors_~err~3#1, ibmpex_find_sensors_~data#1.base, 906 + ibmpex_find_sensors_~data#1.offset, 1);call ibmpex_find_sensors_#t~mem149#1 := read~int(ibmpex_find_sensors_~data#1.base, 906 + ibmpex_find_sensors_~data#1.offset, 1); {2538#false} is VALID [2022-02-20 21:35:23,734 INFO L272 TraceCheckUtils]: 104: Hoare triple {2538#false} call ibmpex_find_sensors_#t~ret150#1.base, ibmpex_find_sensors_#t~ret150#1.offset := kzalloc(184 * (ibmpex_find_sensors_#t~mem149#1 % 256), 208); {2608#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:23,735 INFO L290 TraceCheckUtils]: 105: Hoare triple {2608#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size;~flags := #in~flags;havoc ~tmp~2.base, ~tmp~2.offset; {2537#true} is VALID [2022-02-20 21:35:23,735 INFO L272 TraceCheckUtils]: 106: Hoare triple {2537#true} call #t~ret40.base, #t~ret40.offset := kmalloc(~size, ~bitwiseOr(~flags, 32768)); {2608#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:23,736 INFO L290 TraceCheckUtils]: 107: Hoare triple {2608#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {2537#true} is VALID [2022-02-20 21:35:23,736 INFO L272 TraceCheckUtils]: 108: Hoare triple {2537#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {2608#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:23,736 INFO L290 TraceCheckUtils]: 109: Hoare triple {2608#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {2537#true} is VALID [2022-02-20 21:35:23,736 INFO L290 TraceCheckUtils]: 110: Hoare triple {2537#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {2537#true} is VALID [2022-02-20 21:35:23,737 INFO L290 TraceCheckUtils]: 111: Hoare triple {2537#true} assume true; {2537#true} is VALID [2022-02-20 21:35:23,737 INFO L284 TraceCheckUtils]: 112: Hoare quadruple {2537#true} {2537#true} #590#return; {2537#true} is VALID [2022-02-20 21:35:23,737 INFO L290 TraceCheckUtils]: 113: Hoare triple {2537#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {2537#true} is VALID [2022-02-20 21:35:23,737 INFO L290 TraceCheckUtils]: 114: Hoare triple {2537#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {2537#true} is VALID [2022-02-20 21:35:23,737 INFO L290 TraceCheckUtils]: 115: Hoare triple {2537#true} assume true; {2537#true} is VALID [2022-02-20 21:35:23,738 INFO L284 TraceCheckUtils]: 116: Hoare quadruple {2537#true} {2537#true} #588#return; {2537#true} is VALID [2022-02-20 21:35:23,738 INFO L290 TraceCheckUtils]: 117: Hoare triple {2537#true} ~tmp~2.base, ~tmp~2.offset := #t~ret40.base, #t~ret40.offset;havoc #t~ret40.base, #t~ret40.offset;#res.base, #res.offset := ~tmp~2.base, ~tmp~2.offset; {2537#true} is VALID [2022-02-20 21:35:23,738 INFO L290 TraceCheckUtils]: 118: Hoare triple {2537#true} assume true; {2537#true} is VALID [2022-02-20 21:35:23,738 INFO L284 TraceCheckUtils]: 119: Hoare quadruple {2537#true} {2538#false} #634#return; {2538#false} is VALID [2022-02-20 21:35:23,738 INFO L290 TraceCheckUtils]: 120: Hoare triple {2538#false} ibmpex_find_sensors_~tmp~13#1.base, ibmpex_find_sensors_~tmp~13#1.offset := ibmpex_find_sensors_#t~ret150#1.base, ibmpex_find_sensors_#t~ret150#1.offset;havoc ibmpex_find_sensors_#t~mem149#1;havoc ibmpex_find_sensors_#t~ret150#1.base, ibmpex_find_sensors_#t~ret150#1.offset;call write~$Pointer$(ibmpex_find_sensors_~tmp~13#1.base, ibmpex_find_sensors_~tmp~13#1.offset, ibmpex_find_sensors_~data#1.base, 907 + ibmpex_find_sensors_~data#1.offset, 8);call ibmpex_find_sensors_#t~mem151#1.base, ibmpex_find_sensors_#t~mem151#1.offset := read~$Pointer$(ibmpex_find_sensors_~data#1.base, 907 + ibmpex_find_sensors_~data#1.offset, 8); {2538#false} is VALID [2022-02-20 21:35:23,738 INFO L290 TraceCheckUtils]: 121: Hoare triple {2538#false} assume !(0 == (ibmpex_find_sensors_#t~mem151#1.base + ibmpex_find_sensors_#t~mem151#1.offset) % 18446744073709551616);havoc ibmpex_find_sensors_#t~mem151#1.base, ibmpex_find_sensors_#t~mem151#1.offset;ibmpex_find_sensors_~i~2#1 := 0; {2538#false} is VALID [2022-02-20 21:35:23,739 INFO L290 TraceCheckUtils]: 122: Hoare triple {2538#false} call ibmpex_find_sensors_#t~mem163#1 := read~int(ibmpex_find_sensors_~data#1.base, 906 + ibmpex_find_sensors_~data#1.offset, 1); {2538#false} is VALID [2022-02-20 21:35:23,739 INFO L290 TraceCheckUtils]: 123: Hoare triple {2538#false} assume !(ibmpex_find_sensors_#t~mem163#1 % 256 > ibmpex_find_sensors_~i~2#1);havoc ibmpex_find_sensors_#t~mem163#1;call ibmpex_find_sensors_#t~mem164#1.base, ibmpex_find_sensors_#t~mem164#1.offset := read~$Pointer$(ibmpex_find_sensors_~data#1.base, 24 + ibmpex_find_sensors_~data#1.offset, 8);assume { :begin_inline_ldv_device_create_file_6 } true;ldv_device_create_file_6_#in~ldv_func_arg1#1.base, ldv_device_create_file_6_#in~ldv_func_arg1#1.offset, ldv_device_create_file_6_#in~ldv_func_arg2#1.base, ldv_device_create_file_6_#in~ldv_func_arg2#1.offset := ibmpex_find_sensors_#t~mem164#1.base, ibmpex_find_sensors_#t~mem164#1.offset, ~#sensor_dev_attr_reset_high_low~0.base, ~#sensor_dev_attr_reset_high_low~0.offset;havoc ldv_device_create_file_6_#res#1;havoc ldv_device_create_file_6_#t~ret242#1, ldv_device_create_file_6_~ldv_func_arg1#1.base, ldv_device_create_file_6_~ldv_func_arg1#1.offset, ldv_device_create_file_6_~ldv_func_arg2#1.base, ldv_device_create_file_6_~ldv_func_arg2#1.offset, ldv_device_create_file_6_~tmp~20#1;ldv_device_create_file_6_~ldv_func_arg1#1.base, ldv_device_create_file_6_~ldv_func_arg1#1.offset := ldv_device_create_file_6_#in~ldv_func_arg1#1.base, ldv_device_create_file_6_#in~ldv_func_arg1#1.offset;ldv_device_create_file_6_~ldv_func_arg2#1.base, ldv_device_create_file_6_~ldv_func_arg2#1.offset := ldv_device_create_file_6_#in~ldv_func_arg2#1.base, ldv_device_create_file_6_#in~ldv_func_arg2#1.offset;havoc ldv_device_create_file_6_~tmp~20#1; {2538#false} is VALID [2022-02-20 21:35:23,739 INFO L272 TraceCheckUtils]: 124: Hoare triple {2538#false} call ldv_device_create_file_6_#t~ret242#1 := ldv_device_create_file_dev_attr_of_sensor_device_attribute(ldv_device_create_file_6_~ldv_func_arg2#1.base, ldv_device_create_file_6_~ldv_func_arg2#1.offset); {2538#false} is VALID [2022-02-20 21:35:23,739 INFO L290 TraceCheckUtils]: 125: Hoare triple {2538#false} ~attr.base, ~attr.offset := #in~attr.base, #in~attr.offset; {2538#false} is VALID [2022-02-20 21:35:23,739 INFO L290 TraceCheckUtils]: 126: Hoare triple {2538#false} assume 0 == ~ldv_call_dev_attr_of_sensor_device_attribute~0;~ldv_count_2~0 := 1 + ~ldv_count_2~0;~ldv_call_dev_attr_of_sensor_device_attribute~0 := 1; {2538#false} is VALID [2022-02-20 21:35:23,740 INFO L290 TraceCheckUtils]: 127: Hoare triple {2538#false} assume !(~ldv_count_1~0 >= ~ldv_count_2~0); {2538#false} is VALID [2022-02-20 21:35:23,740 INFO L272 TraceCheckUtils]: 128: Hoare triple {2538#false} call ldv_error(); {2538#false} is VALID [2022-02-20 21:35:23,740 INFO L290 TraceCheckUtils]: 129: Hoare triple {2538#false} assume !false; {2538#false} is VALID [2022-02-20 21:35:23,740 INFO L134 CoverageAnalysis]: Checked inductivity of 34 backedges. 0 proven. 0 refuted. 0 times theorem prover too weak. 34 trivial. 0 not checked. [2022-02-20 21:35:23,741 INFO L144 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-02-20 21:35:23,741 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [1186958518] [2022-02-20 21:35:23,741 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleSmtInterpolCraig [1186958518] provided 1 perfect and 0 imperfect interpolant sequences [2022-02-20 21:35:23,741 INFO L191 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-02-20 21:35:23,741 INFO L204 FreeRefinementEngine]: Number of different interpolants: perfect sequences [5] imperfect sequences [] total 5 [2022-02-20 21:35:23,742 INFO L118 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [1549413954] [2022-02-20 21:35:23,742 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-02-20 21:35:23,744 INFO L78 Accepts]: Start accepts. Automaton has has 5 states, 5 states have (on average 15.0) internal successors, (75), 3 states have internal predecessors, (75), 2 states have call successors, (16), 4 states have call predecessors, (16), 1 states have return successors, (14), 2 states have call predecessors, (14), 2 states have call successors, (14) Word has length 130 [2022-02-20 21:35:23,744 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-02-20 21:35:23,745 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with has 5 states, 5 states have (on average 15.0) internal successors, (75), 3 states have internal predecessors, (75), 2 states have call successors, (16), 4 states have call predecessors, (16), 1 states have return successors, (14), 2 states have call predecessors, (14), 2 states have call successors, (14) [2022-02-20 21:35:23,826 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 105 edges. 105 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 21:35:23,826 INFO L546 AbstractCegarLoop]: INTERPOLANT automaton has 5 states [2022-02-20 21:35:23,826 INFO L108 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2022-02-20 21:35:23,827 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 5 interpolants. [2022-02-20 21:35:23,827 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=7, Invalid=13, Unknown=0, NotChecked=0, Total=20 [2022-02-20 21:35:23,827 INFO L87 Difference]: Start difference. First operand 263 states and 346 transitions. Second operand has 5 states, 5 states have (on average 15.0) internal successors, (75), 3 states have internal predecessors, (75), 2 states have call successors, (16), 4 states have call predecessors, (16), 1 states have return successors, (14), 2 states have call predecessors, (14), 2 states have call successors, (14) [2022-02-20 21:35:25,538 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 21:35:25,539 INFO L93 Difference]: Finished difference Result 548 states and 728 transitions. [2022-02-20 21:35:25,539 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 6 states. [2022-02-20 21:35:25,539 INFO L78 Accepts]: Start accepts. Automaton has has 5 states, 5 states have (on average 15.0) internal successors, (75), 3 states have internal predecessors, (75), 2 states have call successors, (16), 4 states have call predecessors, (16), 1 states have return successors, (14), 2 states have call predecessors, (14), 2 states have call successors, (14) Word has length 130 [2022-02-20 21:35:25,540 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-02-20 21:35:25,540 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 5 states, 5 states have (on average 15.0) internal successors, (75), 3 states have internal predecessors, (75), 2 states have call successors, (16), 4 states have call predecessors, (16), 1 states have return successors, (14), 2 states have call predecessors, (14), 2 states have call successors, (14) [2022-02-20 21:35:25,552 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 6 states to 6 states and 724 transitions. [2022-02-20 21:35:25,553 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 5 states, 5 states have (on average 15.0) internal successors, (75), 3 states have internal predecessors, (75), 2 states have call successors, (16), 4 states have call predecessors, (16), 1 states have return successors, (14), 2 states have call predecessors, (14), 2 states have call successors, (14) [2022-02-20 21:35:25,564 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 6 states to 6 states and 724 transitions. [2022-02-20 21:35:25,565 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with 6 states and 724 transitions. [2022-02-20 21:35:26,127 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 724 edges. 724 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 21:35:26,136 INFO L225 Difference]: With dead ends: 548 [2022-02-20 21:35:26,136 INFO L226 Difference]: Without dead ends: 293 [2022-02-20 21:35:26,137 INFO L932 BasicCegarLoop]: 0 DeclaredPredicates, 37 GetRequests, 33 SyntacticMatches, 0 SemanticMatches, 4 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 0 ImplicationChecksByTransitivity, 0.0s TimeCoverageRelationStatistics Valid=11, Invalid=19, Unknown=0, NotChecked=0, Total=30 [2022-02-20 21:35:26,138 INFO L933 BasicCegarLoop]: 319 mSDtfsCounter, 155 mSDsluCounter, 508 mSDsCounter, 0 mSdLazyCounter, 352 mSolverCounterSat, 121 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.6s Time, 0 mProtectedPredicate, 0 mProtectedAction, 163 SdHoareTripleChecker+Valid, 827 SdHoareTripleChecker+Invalid, 473 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 121 IncrementalHoareTripleChecker+Valid, 352 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.6s IncrementalHoareTripleChecker+Time [2022-02-20 21:35:26,139 INFO L934 BasicCegarLoop]: SdHoareTripleChecker [163 Valid, 827 Invalid, 473 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [121 Valid, 352 Invalid, 0 Unknown, 0 Unchecked, 0.6s Time] [2022-02-20 21:35:26,139 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 293 states. [2022-02-20 21:35:26,162 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 293 to 264. [2022-02-20 21:35:26,162 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-02-20 21:35:26,163 INFO L82 GeneralOperation]: Start isEquivalent. First operand 293 states. Second operand has 264 states, 202 states have (on average 1.2821782178217822) internal successors, (259), 205 states have internal predecessors, (259), 45 states have call successors, (45), 17 states have call predecessors, (45), 16 states have return successors, (43), 43 states have call predecessors, (43), 43 states have call successors, (43) [2022-02-20 21:35:26,164 INFO L74 IsIncluded]: Start isIncluded. First operand 293 states. Second operand has 264 states, 202 states have (on average 1.2821782178217822) internal successors, (259), 205 states have internal predecessors, (259), 45 states have call successors, (45), 17 states have call predecessors, (45), 16 states have return successors, (43), 43 states have call predecessors, (43), 43 states have call successors, (43) [2022-02-20 21:35:26,166 INFO L87 Difference]: Start difference. First operand 293 states. Second operand has 264 states, 202 states have (on average 1.2821782178217822) internal successors, (259), 205 states have internal predecessors, (259), 45 states have call successors, (45), 17 states have call predecessors, (45), 16 states have return successors, (43), 43 states have call predecessors, (43), 43 states have call successors, (43) [2022-02-20 21:35:26,177 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 21:35:26,177 INFO L93 Difference]: Finished difference Result 293 states and 390 transitions. [2022-02-20 21:35:26,178 INFO L276 IsEmpty]: Start isEmpty. Operand 293 states and 390 transitions. [2022-02-20 21:35:26,179 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 21:35:26,179 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 21:35:26,180 INFO L74 IsIncluded]: Start isIncluded. First operand has 264 states, 202 states have (on average 1.2821782178217822) internal successors, (259), 205 states have internal predecessors, (259), 45 states have call successors, (45), 17 states have call predecessors, (45), 16 states have return successors, (43), 43 states have call predecessors, (43), 43 states have call successors, (43) Second operand 293 states. [2022-02-20 21:35:26,181 INFO L87 Difference]: Start difference. First operand has 264 states, 202 states have (on average 1.2821782178217822) internal successors, (259), 205 states have internal predecessors, (259), 45 states have call successors, (45), 17 states have call predecessors, (45), 16 states have return successors, (43), 43 states have call predecessors, (43), 43 states have call successors, (43) Second operand 293 states. [2022-02-20 21:35:26,192 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 21:35:26,192 INFO L93 Difference]: Finished difference Result 293 states and 390 transitions. [2022-02-20 21:35:26,192 INFO L276 IsEmpty]: Start isEmpty. Operand 293 states and 390 transitions. [2022-02-20 21:35:26,193 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 21:35:26,193 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 21:35:26,194 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-02-20 21:35:26,194 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-02-20 21:35:26,195 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 264 states, 202 states have (on average 1.2821782178217822) internal successors, (259), 205 states have internal predecessors, (259), 45 states have call successors, (45), 17 states have call predecessors, (45), 16 states have return successors, (43), 43 states have call predecessors, (43), 43 states have call successors, (43) [2022-02-20 21:35:26,216 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 264 states to 264 states and 347 transitions. [2022-02-20 21:35:26,216 INFO L78 Accepts]: Start accepts. Automaton has 264 states and 347 transitions. Word has length 130 [2022-02-20 21:35:26,217 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-02-20 21:35:26,217 INFO L470 AbstractCegarLoop]: Abstraction has 264 states and 347 transitions. [2022-02-20 21:35:26,218 INFO L471 AbstractCegarLoop]: INTERPOLANT automaton has has 5 states, 5 states have (on average 15.0) internal successors, (75), 3 states have internal predecessors, (75), 2 states have call successors, (16), 4 states have call predecessors, (16), 1 states have return successors, (14), 2 states have call predecessors, (14), 2 states have call successors, (14) [2022-02-20 21:35:26,218 INFO L276 IsEmpty]: Start isEmpty. Operand 264 states and 347 transitions. [2022-02-20 21:35:26,220 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 131 [2022-02-20 21:35:26,222 INFO L506 BasicCegarLoop]: Found error trace [2022-02-20 21:35:26,222 INFO L514 BasicCegarLoop]: trace histogram [3, 3, 3, 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, 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:35:26,223 WARN L452 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable1 [2022-02-20 21:35:26,223 INFO L402 AbstractCegarLoop]: === Iteration 3 === Targeting ldv_errorErr0ASSERT_VIOLATIONERROR_FUNCTION === [ldv_errorErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-02-20 21:35:26,223 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-02-20 21:35:26,224 INFO L85 PathProgramCache]: Analyzing trace with hash -329734684, now seen corresponding path program 1 times [2022-02-20 21:35:26,224 INFO L126 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-02-20 21:35:26,224 INFO L338 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [851792029] [2022-02-20 21:35:26,224 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 21:35:26,224 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-02-20 21:35:26,340 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:26,408 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 3 [2022-02-20 21:35:26,409 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:26,412 INFO L290 TraceCheckUtils]: 0: Hoare triple {4431#true} assume true; {4431#true} is VALID [2022-02-20 21:35:26,412 INFO L284 TraceCheckUtils]: 1: Hoare quadruple {4431#true} {4431#true} #612#return; {4431#true} is VALID [2022-02-20 21:35:26,412 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 14 [2022-02-20 21:35:26,413 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:26,416 INFO L290 TraceCheckUtils]: 0: Hoare triple {4431#true} assume true; {4431#true} is VALID [2022-02-20 21:35:26,416 INFO L284 TraceCheckUtils]: 1: Hoare quadruple {4431#true} {4431#true} #614#return; {4431#true} is VALID [2022-02-20 21:35:26,421 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 18 [2022-02-20 21:35:26,423 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:26,427 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:35:26,428 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:26,432 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:35:26,433 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:26,435 INFO L290 TraceCheckUtils]: 0: Hoare triple {4503#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {4431#true} is VALID [2022-02-20 21:35:26,436 INFO L290 TraceCheckUtils]: 1: Hoare triple {4431#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {4431#true} is VALID [2022-02-20 21:35:26,436 INFO L290 TraceCheckUtils]: 2: Hoare triple {4431#true} assume true; {4431#true} is VALID [2022-02-20 21:35:26,436 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {4431#true} {4431#true} #590#return; {4431#true} is VALID [2022-02-20 21:35:26,436 INFO L290 TraceCheckUtils]: 0: Hoare triple {4503#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {4431#true} is VALID [2022-02-20 21:35:26,437 INFO L272 TraceCheckUtils]: 1: Hoare triple {4431#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {4503#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:26,437 INFO L290 TraceCheckUtils]: 2: Hoare triple {4503#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {4431#true} is VALID [2022-02-20 21:35:26,437 INFO L290 TraceCheckUtils]: 3: Hoare triple {4431#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {4431#true} is VALID [2022-02-20 21:35:26,438 INFO L290 TraceCheckUtils]: 4: Hoare triple {4431#true} assume true; {4431#true} is VALID [2022-02-20 21:35:26,438 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {4431#true} {4431#true} #590#return; {4431#true} is VALID [2022-02-20 21:35:26,438 INFO L290 TraceCheckUtils]: 6: Hoare triple {4431#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {4431#true} is VALID [2022-02-20 21:35:26,438 INFO L290 TraceCheckUtils]: 7: Hoare triple {4431#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {4431#true} is VALID [2022-02-20 21:35:26,438 INFO L290 TraceCheckUtils]: 8: Hoare triple {4431#true} assume true; {4431#true} is VALID [2022-02-20 21:35:26,438 INFO L284 TraceCheckUtils]: 9: Hoare quadruple {4431#true} {4431#true} #588#return; {4431#true} is VALID [2022-02-20 21:35:26,439 INFO L290 TraceCheckUtils]: 0: Hoare triple {4503#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size;~flags := #in~flags;havoc ~tmp~2.base, ~tmp~2.offset; {4431#true} is VALID [2022-02-20 21:35:26,439 INFO L272 TraceCheckUtils]: 1: Hoare triple {4431#true} call #t~ret40.base, #t~ret40.offset := kmalloc(~size, ~bitwiseOr(~flags, 32768)); {4503#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:26,440 INFO L290 TraceCheckUtils]: 2: Hoare triple {4503#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {4431#true} is VALID [2022-02-20 21:35:26,440 INFO L272 TraceCheckUtils]: 3: Hoare triple {4431#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {4503#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:26,440 INFO L290 TraceCheckUtils]: 4: Hoare triple {4503#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {4431#true} is VALID [2022-02-20 21:35:26,440 INFO L290 TraceCheckUtils]: 5: Hoare triple {4431#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {4431#true} is VALID [2022-02-20 21:35:26,441 INFO L290 TraceCheckUtils]: 6: Hoare triple {4431#true} assume true; {4431#true} is VALID [2022-02-20 21:35:26,441 INFO L284 TraceCheckUtils]: 7: Hoare quadruple {4431#true} {4431#true} #590#return; {4431#true} is VALID [2022-02-20 21:35:26,441 INFO L290 TraceCheckUtils]: 8: Hoare triple {4431#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {4431#true} is VALID [2022-02-20 21:35:26,441 INFO L290 TraceCheckUtils]: 9: Hoare triple {4431#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {4431#true} is VALID [2022-02-20 21:35:26,441 INFO L290 TraceCheckUtils]: 10: Hoare triple {4431#true} assume true; {4431#true} is VALID [2022-02-20 21:35:26,442 INFO L284 TraceCheckUtils]: 11: Hoare quadruple {4431#true} {4431#true} #588#return; {4431#true} is VALID [2022-02-20 21:35:26,442 INFO L290 TraceCheckUtils]: 12: Hoare triple {4431#true} ~tmp~2.base, ~tmp~2.offset := #t~ret40.base, #t~ret40.offset;havoc #t~ret40.base, #t~ret40.offset;#res.base, #res.offset := ~tmp~2.base, ~tmp~2.offset; {4431#true} is VALID [2022-02-20 21:35:26,442 INFO L290 TraceCheckUtils]: 13: Hoare triple {4431#true} assume true; {4431#true} is VALID [2022-02-20 21:35:26,442 INFO L284 TraceCheckUtils]: 14: Hoare quadruple {4431#true} {4431#true} #616#return; {4431#true} is VALID [2022-02-20 21:35:26,449 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 41 [2022-02-20 21:35:26,451 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:26,455 INFO L290 TraceCheckUtils]: 0: Hoare triple {4518#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;havoc ~err~0#1;assume { :begin_inline_ipmi_validate_addr } true;ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset, ipmi_validate_addr_#in~arg1#1 := ~data#1.base, 193 + ~data#1.offset, 40;havoc ipmi_validate_addr_#res#1;havoc ipmi_validate_addr_#t~nondet254#1, ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset, ipmi_validate_addr_~arg1#1;ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset := ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset;ipmi_validate_addr_~arg1#1 := ipmi_validate_addr_#in~arg1#1;assume -2147483648 <= ipmi_validate_addr_#t~nondet254#1 && ipmi_validate_addr_#t~nondet254#1 <= 2147483647;ipmi_validate_addr_#res#1 := ipmi_validate_addr_#t~nondet254#1;havoc ipmi_validate_addr_#t~nondet254#1; {4431#true} is VALID [2022-02-20 21:35:26,455 INFO L290 TraceCheckUtils]: 1: Hoare triple {4431#true} #t~ret62#1 := ipmi_validate_addr_#res#1;assume { :end_inline_ipmi_validate_addr } true;assume -2147483648 <= #t~ret62#1 && #t~ret62#1 <= 2147483647;~err~0#1 := #t~ret62#1;havoc #t~ret62#1; {4431#true} is VALID [2022-02-20 21:35:26,455 INFO L290 TraceCheckUtils]: 2: Hoare triple {4431#true} assume 0 != ~err~0#1; {4431#true} is VALID [2022-02-20 21:35:26,455 INFO L290 TraceCheckUtils]: 3: Hoare triple {4431#true} havoc #t~nondet69#1;call #t~mem70#1.base, #t~mem70#1.offset := read~$Pointer$(~data#1.base, 24 + ~data#1.offset, 8);havoc #t~mem70#1.base, #t~mem70#1.offset;#res#1 := ~err~0#1; {4431#true} is VALID [2022-02-20 21:35:26,456 INFO L290 TraceCheckUtils]: 4: Hoare triple {4431#true} assume true; {4431#true} is VALID [2022-02-20 21:35:26,456 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {4431#true} {4431#true} #618#return; {4431#true} is VALID [2022-02-20 21:35:26,456 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 49 [2022-02-20 21:35:26,457 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:26,468 INFO L290 TraceCheckUtils]: 0: Hoare triple {4431#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset; {4431#true} is VALID [2022-02-20 21:35:26,468 INFO L290 TraceCheckUtils]: 1: Hoare triple {4431#true} assume true; {4431#true} is VALID [2022-02-20 21:35:26,468 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {4431#true} {4431#true} #620#return; {4431#true} is VALID [2022-02-20 21:35:26,469 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 56 [2022-02-20 21:35:26,471 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:26,478 INFO L290 TraceCheckUtils]: 0: Hoare triple {4431#true} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;~offset#1 := #in~offset#1;havoc ~tmp~3#1;assume { :begin_inline___be16_to_cpup } true;__be16_to_cpup_#in~p#1.base, __be16_to_cpup_#in~p#1.offset := ~data#1.base, ~data#1.offset + 2 * (if ~offset#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then ~offset#1 % 18446744073709551616 % 18446744073709551616 else ~offset#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616);havoc __be16_to_cpup_#res#1;havoc __be16_to_cpup_#t~ret3#1, __be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset, __be16_to_cpup_~tmp~1#1;__be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset := __be16_to_cpup_#in~p#1.base, __be16_to_cpup_#in~p#1.offset;havoc __be16_to_cpup_~tmp~1#1;assume { :begin_inline___swab16p } true;__swab16p_#in~p#1.base, __swab16p_#in~p#1.offset := __be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset;havoc __swab16p_#res#1;havoc __swab16p_#t~mem1#1, __swab16p_#t~ret2#1, __swab16p_~p#1.base, __swab16p_~p#1.offset, __swab16p_~tmp~0#1;__swab16p_~p#1.base, __swab16p_~p#1.offset := __swab16p_#in~p#1.base, __swab16p_#in~p#1.offset;havoc __swab16p_~tmp~0#1;call __swab16p_#t~mem1#1 := read~int(__swab16p_~p#1.base, __swab16p_~p#1.offset, 2);assume { :begin_inline___fswab16 } true;__fswab16_#in~val#1 := __swab16p_#t~mem1#1 % 65536;havoc __fswab16_#res#1;havoc __fswab16_~val#1;__fswab16_~val#1 := __fswab16_#in~val#1;__fswab16_#res#1 := (if (1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) || 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536)) && 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) then (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) else (if 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) && (1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) || 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536)) then (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) else (if (1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) && (1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) || 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536))) || ((1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) || 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536)) && 1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536)) then 1 else ~bitwiseOr((if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536), (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536))))); {4431#true} is VALID [2022-02-20 21:35:26,479 INFO L290 TraceCheckUtils]: 1: Hoare triple {4431#true} __swab16p_#t~ret2#1 := __fswab16_#res#1;assume { :end_inline___fswab16 } true;__swab16p_~tmp~0#1 := __swab16p_#t~ret2#1;havoc __swab16p_#t~mem1#1;havoc __swab16p_#t~ret2#1;__swab16p_#res#1 := __swab16p_~tmp~0#1; {4431#true} is VALID [2022-02-20 21:35:26,479 INFO L290 TraceCheckUtils]: 2: Hoare triple {4431#true} __be16_to_cpup_#t~ret3#1 := __swab16p_#res#1;assume { :end_inline___swab16p } true;__be16_to_cpup_~tmp~1#1 := __be16_to_cpup_#t~ret3#1;havoc __be16_to_cpup_#t~ret3#1;__be16_to_cpup_#res#1 := __be16_to_cpup_~tmp~1#1; {4431#true} is VALID [2022-02-20 21:35:26,479 INFO L290 TraceCheckUtils]: 3: Hoare triple {4431#true} #t~ret61#1 := __be16_to_cpup_#res#1;assume { :end_inline___be16_to_cpup } true;~tmp~3#1 := #t~ret61#1;havoc #t~ret61#1;#res#1 := ~tmp~3#1; {4431#true} is VALID [2022-02-20 21:35:26,479 INFO L290 TraceCheckUtils]: 4: Hoare triple {4431#true} assume true; {4431#true} is VALID [2022-02-20 21:35:26,479 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {4431#true} {4431#true} #622#return; {4431#true} is VALID [2022-02-20 21:35:26,480 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 66 [2022-02-20 21:35:26,481 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:26,484 INFO L290 TraceCheckUtils]: 0: Hoare triple {4503#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {4431#true} is VALID [2022-02-20 21:35:26,484 INFO L290 TraceCheckUtils]: 1: Hoare triple {4431#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {4431#true} is VALID [2022-02-20 21:35:26,484 INFO L290 TraceCheckUtils]: 2: Hoare triple {4431#true} assume true; {4431#true} is VALID [2022-02-20 21:35:26,485 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {4431#true} {4431#true} #624#return; {4431#true} is VALID [2022-02-20 21:35:26,485 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 73 [2022-02-20 21:35:26,486 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:26,489 INFO L290 TraceCheckUtils]: 0: Hoare triple {4431#true} ~ptr.base, ~ptr.offset := #in~ptr.base, #in~ptr.offset;#res := (if (~ptr.base + ~ptr.offset) % 18446744073709551616 > 2012 then 1 else 0); {4431#true} is VALID [2022-02-20 21:35:26,489 INFO L290 TraceCheckUtils]: 1: Hoare triple {4431#true} assume true; {4431#true} is VALID [2022-02-20 21:35:26,489 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {4431#true} {4431#true} #626#return; {4431#true} is VALID [2022-02-20 21:35:26,489 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 80 [2022-02-20 21:35:26,490 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:26,493 INFO L290 TraceCheckUtils]: 0: Hoare triple {4431#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset;~arg1.base, ~arg1.offset := #in~arg1.base, #in~arg1.offset; {4431#true} is VALID [2022-02-20 21:35:26,493 INFO L290 TraceCheckUtils]: 1: Hoare triple {4431#true} assume true; {4431#true} is VALID [2022-02-20 21:35:26,495 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {4431#true} {4431#true} #628#return; {4431#true} is VALID [2022-02-20 21:35:26,495 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 87 [2022-02-20 21:35:26,497 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:26,500 INFO L290 TraceCheckUtils]: 0: Hoare triple {4518#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;havoc ~err~0#1;assume { :begin_inline_ipmi_validate_addr } true;ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset, ipmi_validate_addr_#in~arg1#1 := ~data#1.base, 193 + ~data#1.offset, 40;havoc ipmi_validate_addr_#res#1;havoc ipmi_validate_addr_#t~nondet254#1, ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset, ipmi_validate_addr_~arg1#1;ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset := ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset;ipmi_validate_addr_~arg1#1 := ipmi_validate_addr_#in~arg1#1;assume -2147483648 <= ipmi_validate_addr_#t~nondet254#1 && ipmi_validate_addr_#t~nondet254#1 <= 2147483647;ipmi_validate_addr_#res#1 := ipmi_validate_addr_#t~nondet254#1;havoc ipmi_validate_addr_#t~nondet254#1; {4431#true} is VALID [2022-02-20 21:35:26,501 INFO L290 TraceCheckUtils]: 1: Hoare triple {4431#true} #t~ret62#1 := ipmi_validate_addr_#res#1;assume { :end_inline_ipmi_validate_addr } true;assume -2147483648 <= #t~ret62#1 && #t~ret62#1 <= 2147483647;~err~0#1 := #t~ret62#1;havoc #t~ret62#1; {4431#true} is VALID [2022-02-20 21:35:26,501 INFO L290 TraceCheckUtils]: 2: Hoare triple {4431#true} assume 0 != ~err~0#1; {4431#true} is VALID [2022-02-20 21:35:26,501 INFO L290 TraceCheckUtils]: 3: Hoare triple {4431#true} havoc #t~nondet69#1;call #t~mem70#1.base, #t~mem70#1.offset := read~$Pointer$(~data#1.base, 24 + ~data#1.offset, 8);havoc #t~mem70#1.base, #t~mem70#1.offset;#res#1 := ~err~0#1; {4431#true} is VALID [2022-02-20 21:35:26,501 INFO L290 TraceCheckUtils]: 4: Hoare triple {4431#true} assume true; {4431#true} is VALID [2022-02-20 21:35:26,501 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {4431#true} {4431#true} #630#return; {4431#true} is VALID [2022-02-20 21:35:26,502 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 95 [2022-02-20 21:35:26,503 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:26,506 INFO L290 TraceCheckUtils]: 0: Hoare triple {4431#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset; {4431#true} is VALID [2022-02-20 21:35:26,506 INFO L290 TraceCheckUtils]: 1: Hoare triple {4431#true} assume true; {4431#true} is VALID [2022-02-20 21:35:26,506 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {4431#true} {4431#true} #632#return; {4431#true} is VALID [2022-02-20 21:35:26,507 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 104 [2022-02-20 21:35:26,513 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:26,518 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:35:26,519 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:26,523 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:35:26,524 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:26,527 INFO L290 TraceCheckUtils]: 0: Hoare triple {4503#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {4431#true} is VALID [2022-02-20 21:35:26,527 INFO L290 TraceCheckUtils]: 1: Hoare triple {4431#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {4431#true} is VALID [2022-02-20 21:35:26,527 INFO L290 TraceCheckUtils]: 2: Hoare triple {4431#true} assume true; {4431#true} is VALID [2022-02-20 21:35:26,527 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {4431#true} {4431#true} #590#return; {4431#true} is VALID [2022-02-20 21:35:26,528 INFO L290 TraceCheckUtils]: 0: Hoare triple {4503#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {4431#true} is VALID [2022-02-20 21:35:26,528 INFO L272 TraceCheckUtils]: 1: Hoare triple {4431#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {4503#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:26,529 INFO L290 TraceCheckUtils]: 2: Hoare triple {4503#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {4431#true} is VALID [2022-02-20 21:35:26,529 INFO L290 TraceCheckUtils]: 3: Hoare triple {4431#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {4431#true} is VALID [2022-02-20 21:35:26,529 INFO L290 TraceCheckUtils]: 4: Hoare triple {4431#true} assume true; {4431#true} is VALID [2022-02-20 21:35:26,529 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {4431#true} {4431#true} #590#return; {4431#true} is VALID [2022-02-20 21:35:26,529 INFO L290 TraceCheckUtils]: 6: Hoare triple {4431#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {4431#true} is VALID [2022-02-20 21:35:26,530 INFO L290 TraceCheckUtils]: 7: Hoare triple {4431#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {4431#true} is VALID [2022-02-20 21:35:26,530 INFO L290 TraceCheckUtils]: 8: Hoare triple {4431#true} assume true; {4431#true} is VALID [2022-02-20 21:35:26,530 INFO L284 TraceCheckUtils]: 9: Hoare quadruple {4431#true} {4431#true} #588#return; {4431#true} is VALID [2022-02-20 21:35:26,530 INFO L290 TraceCheckUtils]: 0: Hoare triple {4503#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size;~flags := #in~flags;havoc ~tmp~2.base, ~tmp~2.offset; {4431#true} is VALID [2022-02-20 21:35:26,531 INFO L272 TraceCheckUtils]: 1: Hoare triple {4431#true} call #t~ret40.base, #t~ret40.offset := kmalloc(~size, ~bitwiseOr(~flags, 32768)); {4503#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:26,531 INFO L290 TraceCheckUtils]: 2: Hoare triple {4503#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {4431#true} is VALID [2022-02-20 21:35:26,531 INFO L272 TraceCheckUtils]: 3: Hoare triple {4431#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {4503#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:26,532 INFO L290 TraceCheckUtils]: 4: Hoare triple {4503#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {4431#true} is VALID [2022-02-20 21:35:26,532 INFO L290 TraceCheckUtils]: 5: Hoare triple {4431#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {4431#true} is VALID [2022-02-20 21:35:26,532 INFO L290 TraceCheckUtils]: 6: Hoare triple {4431#true} assume true; {4431#true} is VALID [2022-02-20 21:35:26,532 INFO L284 TraceCheckUtils]: 7: Hoare quadruple {4431#true} {4431#true} #590#return; {4431#true} is VALID [2022-02-20 21:35:26,532 INFO L290 TraceCheckUtils]: 8: Hoare triple {4431#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {4431#true} is VALID [2022-02-20 21:35:26,533 INFO L290 TraceCheckUtils]: 9: Hoare triple {4431#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {4431#true} is VALID [2022-02-20 21:35:26,533 INFO L290 TraceCheckUtils]: 10: Hoare triple {4431#true} assume true; {4431#true} is VALID [2022-02-20 21:35:26,534 INFO L284 TraceCheckUtils]: 11: Hoare quadruple {4431#true} {4431#true} #588#return; {4431#true} is VALID [2022-02-20 21:35:26,534 INFO L290 TraceCheckUtils]: 12: Hoare triple {4431#true} ~tmp~2.base, ~tmp~2.offset := #t~ret40.base, #t~ret40.offset;havoc #t~ret40.base, #t~ret40.offset;#res.base, #res.offset := ~tmp~2.base, ~tmp~2.offset; {4431#true} is VALID [2022-02-20 21:35:26,534 INFO L290 TraceCheckUtils]: 13: Hoare triple {4431#true} assume true; {4431#true} is VALID [2022-02-20 21:35:26,534 INFO L284 TraceCheckUtils]: 14: Hoare quadruple {4431#true} {4432#false} #634#return; {4432#false} is VALID [2022-02-20 21:35:26,534 INFO L290 TraceCheckUtils]: 0: Hoare triple {4431#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(46, 2);call #Ultimate.allocInit(13, 3);call #Ultimate.allocInit(20, 4);call #Ultimate.allocInit(21, 5);call #Ultimate.allocInit(11, 6);call #Ultimate.allocInit(18, 7);call #Ultimate.allocInit(19, 8);call #Ultimate.allocInit(20, 9);call #Ultimate.allocInit(18, 10);call #Ultimate.allocInit(69, 11);call #Ultimate.allocInit(26, 12);call #Ultimate.allocInit(4, 13);call write~init~int(37, 13, 0, 1);call write~init~int(115, 13, 1, 1);call write~init~int(10, 13, 2, 1);call write~init~int(0, 13, 3, 1);call #Ultimate.allocInit(7, 14);call write~init~int(105, 14, 0, 1);call write~init~int(98, 14, 1, 1);call write~init~int(109, 14, 2, 1);call write~init~int(112, 14, 3, 1);call write~init~int(101, 14, 4, 1);call write~init~int(120, 14, 5, 1);call write~init~int(0, 14, 6, 1);call #Ultimate.allocInit(5, 15);call write~init~int(110, 15, 0, 1);call write~init~int(97, 15, 1, 1);call write~init~int(109, 15, 2, 1);call write~init~int(101, 15, 3, 1);call write~init~int(0, 15, 4, 1);call #Ultimate.allocInit(4, 16);call write~init~int(37, 16, 0, 1);call write~init~int(100, 16, 1, 1);call write~init~int(10, 16, 2, 1);call write~init~int(0, 16, 3, 1);call #Ultimate.allocInit(15, 17);call #Ultimate.allocInit(5, 18);call write~init~int(116, 18, 0, 1);call write~init~int(101, 18, 1, 1);call write~init~int(109, 18, 2, 1);call write~init~int(112, 18, 3, 1);call write~init~int(0, 18, 4, 1);call #Ultimate.allocInit(6, 19);call write~init~int(112, 19, 0, 1);call write~init~int(111, 19, 1, 1);call write~init~int(119, 19, 2, 1);call write~init~int(101, 19, 3, 1);call write~init~int(114, 19, 4, 1);call write~init~int(0, 19, 5, 1);call #Ultimate.allocInit(40, 20);call #Ultimate.allocInit(48, 21);call #Ultimate.allocInit(12, 22);call #Ultimate.allocInit(55, 23);call #Ultimate.allocInit(26, 24);call #Ultimate.allocInit(70, 25);~#power_sensor_sig~0.base, ~#power_sensor_sig~0.offset := 26, 0;call #Ultimate.allocInit(3, 26);call write~init~int(112, ~#power_sensor_sig~0.base, ~#power_sensor_sig~0.offset, 1);call write~init~int(119, ~#power_sensor_sig~0.base, 1 + ~#power_sensor_sig~0.offset, 1);call write~init~int(114, ~#power_sensor_sig~0.base, 2 + ~#power_sensor_sig~0.offset, 1);~#temp_sensor_sig~0.base, ~#temp_sensor_sig~0.offset := 27, 0;call #Ultimate.allocInit(3, 27);call write~init~int(116, ~#temp_sensor_sig~0.base, ~#temp_sensor_sig~0.offset, 1);call write~init~int(101, ~#temp_sensor_sig~0.base, 1 + ~#temp_sensor_sig~0.offset, 1);call write~init~int(109, ~#temp_sensor_sig~0.base, 2 + ~#temp_sensor_sig~0.offset, 1);~#watt_sensor_sig~0.base, ~#watt_sensor_sig~0.offset := 28, 0;call #Ultimate.allocInit(2, 28);call write~init~int(65, ~#watt_sensor_sig~0.base, ~#watt_sensor_sig~0.offset, 1);call write~init~int(67, ~#watt_sensor_sig~0.base, 1 + ~#watt_sensor_sig~0.offset, 1);~#power_sensor_name_templates~0.base, ~#power_sensor_name_templates~0.offset := 29, 0;call #Ultimate.allocInit(24, 29);call write~init~$Pointer$(3, 0, ~#power_sensor_name_templates~0.base, ~#power_sensor_name_templates~0.offset, 8);call write~init~$Pointer$(4, 0, ~#power_sensor_name_templates~0.base, 8 + ~#power_sensor_name_templates~0.offset, 8);call write~init~$Pointer$(5, 0, ~#power_sensor_name_templates~0.base, 16 + ~#power_sensor_name_templates~0.offset, 8);~#temp_sensor_name_templates~0.base, ~#temp_sensor_name_templates~0.offset := 30, 0;call #Ultimate.allocInit(24, 30);call write~init~$Pointer$(6, 0, ~#temp_sensor_name_templates~0.base, ~#temp_sensor_name_templates~0.offset, 8);call write~init~$Pointer$(7, 0, ~#temp_sensor_name_templates~0.base, 8 + ~#temp_sensor_name_templates~0.offset, 8);call write~init~$Pointer$(8, 0, ~#temp_sensor_name_templates~0.base, 16 + ~#temp_sensor_name_templates~0.offset, 8);~#driver_data~0.base, ~#driver_data~0.offset := 31, 0;call #Ultimate.allocInit(72, 31);call write~init~$Pointer$(~#driver_data~0.base, ~#driver_data~0.offset, ~#driver_data~0.base, ~#driver_data~0.offset, 8);call write~init~$Pointer$(~#driver_data~0.base, ~#driver_data~0.offset, ~#driver_data~0.base, 8 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(0, 0, ~#driver_data~0.base, 16 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(0, 0, ~#driver_data~0.base, 24 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(~#__this_module~0.base, ~#__this_module~0.offset, ~#driver_data~0.base, 32 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(#funAddr~ibmpex_register_bmc.base, #funAddr~ibmpex_register_bmc.offset, ~#driver_data~0.base, 40 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(#funAddr~ibmpex_bmc_gone.base, #funAddr~ibmpex_bmc_gone.offset, ~#driver_data~0.base, 48 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(#funAddr~ibmpex_msg_handler.base, #funAddr~ibmpex_msg_handler.offset, ~#driver_data~0.base, 56 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(0, 0, ~#driver_data~0.base, 64 + ~#driver_data~0.offset, 8);~#sensor_dev_attr_name~0.base, ~#sensor_dev_attr_name~0.offset := 32, 0;call #Ultimate.allocInit(48, 32);call write~init~$Pointer$(15, 0, ~#sensor_dev_attr_name~0.base, ~#sensor_dev_attr_name~0.offset, 8);call write~init~int(292, ~#sensor_dev_attr_name~0.base, 8 + ~#sensor_dev_attr_name~0.offset, 4);call write~init~$Pointer$(0, 0, ~#sensor_dev_attr_name~0.base, 12 + ~#sensor_dev_attr_name~0.offset, 8);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 20 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 21 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 22 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 23 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 24 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 25 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 26 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 27 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~$Pointer$(#funAddr~show_name.base, #funAddr~show_name.offset, ~#sensor_dev_attr_name~0.base, 28 + ~#sensor_dev_attr_name~0.offset, 8);call write~init~$Pointer$(0, 0, ~#sensor_dev_attr_name~0.base, 36 + ~#sensor_dev_attr_name~0.offset, 8);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 44 + ~#sensor_dev_attr_name~0.offset, 4);~#sensor_dev_attr_reset_high_low~0.base, ~#sensor_dev_attr_reset_high_low~0.offset := 33, 0;call #Ultimate.allocInit(48, 33);call write~init~$Pointer$(17, 0, ~#sensor_dev_attr_reset_high_low~0.base, ~#sensor_dev_attr_reset_high_low~0.offset, 8);call write~init~int(128, ~#sensor_dev_attr_reset_high_low~0.base, 8 + ~#sensor_dev_attr_reset_high_low~0.offset, 4);call write~init~$Pointer$(0, 0, ~#sensor_dev_attr_reset_high_low~0.base, 12 + ~#sensor_dev_attr_reset_high_low~0.offset, 8);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 20 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 21 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 22 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 23 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 24 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 25 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 26 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 27 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~$Pointer$(0, 0, ~#sensor_dev_attr_reset_high_low~0.base, 28 + ~#sensor_dev_attr_reset_high_low~0.offset, 8);call write~init~$Pointer$(#funAddr~ibmpex_reset_high_low.base, #funAddr~ibmpex_reset_high_low.offset, ~#sensor_dev_attr_reset_high_low~0.base, 36 + ~#sensor_dev_attr_reset_high_low~0.offset, 8);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 44 + ~#sensor_dev_attr_reset_high_low~0.offset, 4);~LDV_IN_INTERRUPT~0 := 0;~ldv_count_1~0 := 0;~ldv_count_2~0 := 0;~ldv_call_dev_attr_of_sensor_device_attribute~0 := 0;~ldv_call_dev_attr_of_sensor_device_attribute_2~0 := 0; {4431#true} is VALID [2022-02-20 21:35:26,535 INFO L290 TraceCheckUtils]: 1: Hoare triple {4431#true} assume { :end_inline_ULTIMATE.init } true;assume { :begin_inline_main } true;havoc main_#res#1;havoc main_#t~ret236#1, main_#t~nondet237#1, main_#t~switch238#1, main_#t~nondet239#1, main_~var_ibmpex_register_bmc_17_p0~0#1, main_~var_group1~0#1.base, main_~var_group1~0#1.offset, main_~var_ibmpex_bmc_gone_19_p0~0#1, main_~#var_group2~0#1.base, main_~#var_group2~0#1.offset, main_~#var_ibmpex_msg_handler_20_p1~0#1.base, main_~#var_ibmpex_msg_handler_20_p1~0#1.offset, main_~tmp~17#1, main_~tmp___0~4#1, main_~tmp___1~2#1;havoc main_~var_ibmpex_register_bmc_17_p0~0#1;havoc main_~var_group1~0#1.base, main_~var_group1~0#1.offset;havoc main_~var_ibmpex_bmc_gone_19_p0~0#1;call main_~#var_group2~0#1.base, main_~#var_group2~0#1.offset := #Ultimate.allocOnStack(374);call main_~#var_ibmpex_msg_handler_20_p1~0#1.base, main_~#var_ibmpex_msg_handler_20_p1~0#1.offset := #Ultimate.allocOnStack(915);havoc main_~tmp~17#1;havoc main_~tmp___0~4#1;havoc main_~tmp___1~2#1;~LDV_IN_INTERRUPT~0 := 1;assume { :begin_inline_ldv_initialize } true;~ldv_count_1~0 := 1 + ~ldv_count_1~0;~ldv_count_1~0 := 1 + ~ldv_count_1~0;~ldv_count_1~0 := 1 + ~ldv_count_1~0;~ldv_count_1~0 := 1 + ~ldv_count_1~0;~ldv_count_1~0 := 1 + ~ldv_count_1~0;~ldv_count_1~0 := 1 + ~ldv_count_1~0; {4431#true} is VALID [2022-02-20 21:35:26,535 INFO L290 TraceCheckUtils]: 2: Hoare triple {4431#true} assume { :end_inline_ldv_initialize } true; {4431#true} is VALID [2022-02-20 21:35:26,535 INFO L272 TraceCheckUtils]: 3: Hoare triple {4431#true} call ldv_handler_precall(); {4431#true} is VALID [2022-02-20 21:35:26,535 INFO L290 TraceCheckUtils]: 4: Hoare triple {4431#true} assume true; {4431#true} is VALID [2022-02-20 21:35:26,535 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {4431#true} {4431#true} #612#return; {4431#true} is VALID [2022-02-20 21:35:26,536 INFO L290 TraceCheckUtils]: 6: Hoare triple {4431#true} assume { :begin_inline_ibmpex_init } true;havoc ibmpex_init_#res#1;havoc ibmpex_init_#t~ret231#1, ibmpex_init_~tmp~16#1;havoc ibmpex_init_~tmp~16#1;assume { :begin_inline_ipmi_smi_watcher_register } true;ipmi_smi_watcher_register_#in~arg0#1.base, ipmi_smi_watcher_register_#in~arg0#1.offset := ~#driver_data~0.base, 16 + ~#driver_data~0.offset;havoc ipmi_smi_watcher_register_#res#1;havoc ipmi_smi_watcher_register_#t~nondet252#1, ipmi_smi_watcher_register_~arg0#1.base, ipmi_smi_watcher_register_~arg0#1.offset;ipmi_smi_watcher_register_~arg0#1.base, ipmi_smi_watcher_register_~arg0#1.offset := ipmi_smi_watcher_register_#in~arg0#1.base, ipmi_smi_watcher_register_#in~arg0#1.offset;assume -2147483648 <= ipmi_smi_watcher_register_#t~nondet252#1 && ipmi_smi_watcher_register_#t~nondet252#1 <= 2147483647;ipmi_smi_watcher_register_#res#1 := ipmi_smi_watcher_register_#t~nondet252#1;havoc ipmi_smi_watcher_register_#t~nondet252#1; {4431#true} is VALID [2022-02-20 21:35:26,536 INFO L290 TraceCheckUtils]: 7: Hoare triple {4431#true} ibmpex_init_#t~ret231#1 := ipmi_smi_watcher_register_#res#1;assume { :end_inline_ipmi_smi_watcher_register } true;assume -2147483648 <= ibmpex_init_#t~ret231#1 && ibmpex_init_#t~ret231#1 <= 2147483647;ibmpex_init_~tmp~16#1 := ibmpex_init_#t~ret231#1;havoc ibmpex_init_#t~ret231#1;ibmpex_init_#res#1 := ibmpex_init_~tmp~16#1; {4431#true} is VALID [2022-02-20 21:35:26,536 INFO L290 TraceCheckUtils]: 8: Hoare triple {4431#true} main_#t~ret236#1 := ibmpex_init_#res#1;assume { :end_inline_ibmpex_init } true;assume -2147483648 <= main_#t~ret236#1 && main_#t~ret236#1 <= 2147483647;main_~tmp~17#1 := main_#t~ret236#1;havoc main_#t~ret236#1; {4431#true} is VALID [2022-02-20 21:35:26,536 INFO L290 TraceCheckUtils]: 9: Hoare triple {4431#true} assume !(0 != main_~tmp~17#1); {4431#true} is VALID [2022-02-20 21:35:26,536 INFO L290 TraceCheckUtils]: 10: Hoare triple {4431#true} assume -2147483648 <= main_#t~nondet239#1 && main_#t~nondet239#1 <= 2147483647;main_~tmp___1~2#1 := main_#t~nondet239#1;havoc main_#t~nondet239#1; {4431#true} is VALID [2022-02-20 21:35:26,536 INFO L290 TraceCheckUtils]: 11: Hoare triple {4431#true} assume 0 != main_~tmp___1~2#1; {4431#true} is VALID [2022-02-20 21:35:26,537 INFO L290 TraceCheckUtils]: 12: Hoare triple {4431#true} assume -2147483648 <= main_#t~nondet237#1 && main_#t~nondet237#1 <= 2147483647;main_~tmp___0~4#1 := main_#t~nondet237#1;havoc main_#t~nondet237#1;main_#t~switch238#1 := 0 == main_~tmp___0~4#1; {4431#true} is VALID [2022-02-20 21:35:26,537 INFO L290 TraceCheckUtils]: 13: Hoare triple {4431#true} assume main_#t~switch238#1; {4431#true} is VALID [2022-02-20 21:35:26,537 INFO L272 TraceCheckUtils]: 14: Hoare triple {4431#true} call ldv_handler_precall(); {4431#true} is VALID [2022-02-20 21:35:26,537 INFO L290 TraceCheckUtils]: 15: Hoare triple {4431#true} assume true; {4431#true} is VALID [2022-02-20 21:35:26,537 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {4431#true} {4431#true} #614#return; {4431#true} is VALID [2022-02-20 21:35:26,537 INFO L290 TraceCheckUtils]: 17: Hoare triple {4431#true} assume { :begin_inline_ibmpex_register_bmc } true;ibmpex_register_bmc_#in~iface#1, ibmpex_register_bmc_#in~dev#1.base, ibmpex_register_bmc_#in~dev#1.offset := main_~var_ibmpex_register_bmc_17_p0~0#1, main_~var_group1~0#1.base, main_~var_group1~0#1.offset;havoc ibmpex_register_bmc_#t~ret178#1.base, ibmpex_register_bmc_#t~ret178#1.offset, ibmpex_register_bmc_#t~nondet179#1, ibmpex_register_bmc_#t~mem180#1, ibmpex_register_bmc_#t~ret181#1, ibmpex_register_bmc_#t~nondet182#1, ibmpex_register_bmc_#t~mem183#1, ibmpex_register_bmc_#t~ret184#1, ibmpex_register_bmc_#t~mem185#1.base, ibmpex_register_bmc_#t~mem185#1.offset, ibmpex_register_bmc_#t~ret186#1.base, ibmpex_register_bmc_#t~ret186#1.offset, ibmpex_register_bmc_#t~mem187#1.base, ibmpex_register_bmc_#t~mem187#1.offset, ibmpex_register_bmc_#t~ret188#1, ibmpex_register_bmc_#t~nondet189#1, ibmpex_register_bmc_#t~mem190#1.base, ibmpex_register_bmc_#t~mem190#1.offset, ibmpex_register_bmc_#t~mem191#1, ibmpex_register_bmc_#t~ret192#1, ibmpex_register_bmc_#t~nondet193#1, ibmpex_register_bmc_#t~mem194#1.base, ibmpex_register_bmc_#t~mem194#1.offset, ibmpex_register_bmc_#t~mem195#1.base, ibmpex_register_bmc_#t~mem195#1.offset, ibmpex_register_bmc_#t~mem196#1.base, ibmpex_register_bmc_#t~mem196#1.offset, ibmpex_register_bmc_#t~ret197#1, ibmpex_register_bmc_~iface#1, ibmpex_register_bmc_~dev#1.base, ibmpex_register_bmc_~dev#1.offset, ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset, ibmpex_register_bmc_~err~4#1, ibmpex_register_bmc_~tmp~14#1.base, ibmpex_register_bmc_~tmp~14#1.offset, ibmpex_register_bmc_~#__key~1#1.base, ibmpex_register_bmc_~#__key~1#1.offset, ibmpex_register_bmc_~tmp___0~3#1;ibmpex_register_bmc_~iface#1 := ibmpex_register_bmc_#in~iface#1;ibmpex_register_bmc_~dev#1.base, ibmpex_register_bmc_~dev#1.offset := ibmpex_register_bmc_#in~dev#1.base, ibmpex_register_bmc_#in~dev#1.offset;havoc ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset;havoc ibmpex_register_bmc_~err~4#1;havoc ibmpex_register_bmc_~tmp~14#1.base, ibmpex_register_bmc_~tmp~14#1.offset;call ibmpex_register_bmc_~#__key~1#1.base, ibmpex_register_bmc_~#__key~1#1.offset := #Ultimate.allocOnStack(8);havoc ibmpex_register_bmc_~tmp___0~3#1; {4431#true} is VALID [2022-02-20 21:35:26,538 INFO L272 TraceCheckUtils]: 18: Hoare triple {4431#true} call ibmpex_register_bmc_#t~ret178#1.base, ibmpex_register_bmc_#t~ret178#1.offset := kzalloc(968, 208); {4503#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:26,538 INFO L290 TraceCheckUtils]: 19: Hoare triple {4503#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size;~flags := #in~flags;havoc ~tmp~2.base, ~tmp~2.offset; {4431#true} is VALID [2022-02-20 21:35:26,539 INFO L272 TraceCheckUtils]: 20: Hoare triple {4431#true} call #t~ret40.base, #t~ret40.offset := kmalloc(~size, ~bitwiseOr(~flags, 32768)); {4503#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:26,539 INFO L290 TraceCheckUtils]: 21: Hoare triple {4503#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {4431#true} is VALID [2022-02-20 21:35:26,540 INFO L272 TraceCheckUtils]: 22: Hoare triple {4431#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {4503#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:26,540 INFO L290 TraceCheckUtils]: 23: Hoare triple {4503#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {4431#true} is VALID [2022-02-20 21:35:26,540 INFO L290 TraceCheckUtils]: 24: Hoare triple {4431#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {4431#true} is VALID [2022-02-20 21:35:26,540 INFO L290 TraceCheckUtils]: 25: Hoare triple {4431#true} assume true; {4431#true} is VALID [2022-02-20 21:35:26,540 INFO L284 TraceCheckUtils]: 26: Hoare quadruple {4431#true} {4431#true} #590#return; {4431#true} is VALID [2022-02-20 21:35:26,540 INFO L290 TraceCheckUtils]: 27: Hoare triple {4431#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {4431#true} is VALID [2022-02-20 21:35:26,541 INFO L290 TraceCheckUtils]: 28: Hoare triple {4431#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {4431#true} is VALID [2022-02-20 21:35:26,541 INFO L290 TraceCheckUtils]: 29: Hoare triple {4431#true} assume true; {4431#true} is VALID [2022-02-20 21:35:26,541 INFO L284 TraceCheckUtils]: 30: Hoare quadruple {4431#true} {4431#true} #588#return; {4431#true} is VALID [2022-02-20 21:35:26,541 INFO L290 TraceCheckUtils]: 31: Hoare triple {4431#true} ~tmp~2.base, ~tmp~2.offset := #t~ret40.base, #t~ret40.offset;havoc #t~ret40.base, #t~ret40.offset;#res.base, #res.offset := ~tmp~2.base, ~tmp~2.offset; {4431#true} is VALID [2022-02-20 21:35:26,541 INFO L290 TraceCheckUtils]: 32: Hoare triple {4431#true} assume true; {4431#true} is VALID [2022-02-20 21:35:26,542 INFO L284 TraceCheckUtils]: 33: Hoare quadruple {4431#true} {4431#true} #616#return; {4431#true} is VALID [2022-02-20 21:35:26,542 INFO L290 TraceCheckUtils]: 34: Hoare triple {4431#true} ibmpex_register_bmc_~tmp~14#1.base, ibmpex_register_bmc_~tmp~14#1.offset := ibmpex_register_bmc_#t~ret178#1.base, ibmpex_register_bmc_#t~ret178#1.offset;havoc ibmpex_register_bmc_#t~ret178#1.base, ibmpex_register_bmc_#t~ret178#1.offset;ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset := ibmpex_register_bmc_~tmp~14#1.base, ibmpex_register_bmc_~tmp~14#1.offset; {4431#true} is VALID [2022-02-20 21:35:26,542 INFO L290 TraceCheckUtils]: 35: Hoare triple {4431#true} assume !(0 == (ibmpex_register_bmc_~data~2#1.base + ibmpex_register_bmc_~data~2#1.offset) % 18446744073709551616);call write~int(12, ibmpex_register_bmc_~data~2#1.base, 193 + ibmpex_register_bmc_~data~2#1.offset, 4);call write~int(15, ibmpex_register_bmc_~data~2#1.base, 197 + ibmpex_register_bmc_~data~2#1.offset, 2);call write~int(0, ibmpex_register_bmc_~data~2#1.base, 199 + ibmpex_register_bmc_~data~2#1.offset, 1);call write~int(ibmpex_register_bmc_~iface#1, ibmpex_register_bmc_~data~2#1.base, 323 + ibmpex_register_bmc_~data~2#1.offset, 4);call write~$Pointer$(ibmpex_register_bmc_~dev#1.base, ibmpex_register_bmc_~dev#1.offset, ibmpex_register_bmc_~data~2#1.base, 24 + ibmpex_register_bmc_~data~2#1.offset, 8);call ibmpex_register_bmc_#t~mem180#1 := read~int(ibmpex_register_bmc_~data~2#1.base, 323 + ibmpex_register_bmc_~data~2#1.offset, 4);assume { :begin_inline_ipmi_create_user } true;ipmi_create_user_#in~arg0#1, ipmi_create_user_#in~arg1#1.base, ipmi_create_user_#in~arg1#1.offset, ipmi_create_user_#in~arg2#1.base, ipmi_create_user_#in~arg2#1.offset, ipmi_create_user_#in~arg3#1.base, ipmi_create_user_#in~arg3#1.offset := ibmpex_register_bmc_#t~mem180#1, ~#driver_data~0.base, 56 + ~#driver_data~0.offset, ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset, ibmpex_register_bmc_~data~2#1.base, 315 + ibmpex_register_bmc_~data~2#1.offset;havoc ipmi_create_user_#res#1;havoc ipmi_create_user_#t~nondet249#1, ipmi_create_user_~arg0#1, ipmi_create_user_~arg1#1.base, ipmi_create_user_~arg1#1.offset, ipmi_create_user_~arg2#1.base, ipmi_create_user_~arg2#1.offset, ipmi_create_user_~arg3#1.base, ipmi_create_user_~arg3#1.offset;ipmi_create_user_~arg0#1 := ipmi_create_user_#in~arg0#1;ipmi_create_user_~arg1#1.base, ipmi_create_user_~arg1#1.offset := ipmi_create_user_#in~arg1#1.base, ipmi_create_user_#in~arg1#1.offset;ipmi_create_user_~arg2#1.base, ipmi_create_user_~arg2#1.offset := ipmi_create_user_#in~arg2#1.base, ipmi_create_user_#in~arg2#1.offset;ipmi_create_user_~arg3#1.base, ipmi_create_user_~arg3#1.offset := ipmi_create_user_#in~arg3#1.base, ipmi_create_user_#in~arg3#1.offset;assume -2147483648 <= ipmi_create_user_#t~nondet249#1 && ipmi_create_user_#t~nondet249#1 <= 2147483647;ipmi_create_user_#res#1 := ipmi_create_user_#t~nondet249#1;havoc ipmi_create_user_#t~nondet249#1; {4431#true} is VALID [2022-02-20 21:35:26,542 INFO L290 TraceCheckUtils]: 36: Hoare triple {4431#true} ibmpex_register_bmc_#t~ret181#1 := ipmi_create_user_#res#1;assume { :end_inline_ipmi_create_user } true;assume -2147483648 <= ibmpex_register_bmc_#t~ret181#1 && ibmpex_register_bmc_#t~ret181#1 <= 2147483647;ibmpex_register_bmc_~err~4#1 := ibmpex_register_bmc_#t~ret181#1;havoc ibmpex_register_bmc_#t~mem180#1;havoc ibmpex_register_bmc_#t~ret181#1; {4431#true} is VALID [2022-02-20 21:35:26,542 INFO L290 TraceCheckUtils]: 37: Hoare triple {4431#true} assume !(ibmpex_register_bmc_~err~4#1 < 0);assume { :begin_inline___mutex_init } true;__mutex_init_#in~arg0#1.base, __mutex_init_#in~arg0#1.offset, __mutex_init_#in~arg1#1.base, __mutex_init_#in~arg1#1.offset, __mutex_init_#in~arg2#1.base, __mutex_init_#in~arg2#1.offset := ibmpex_register_bmc_~data~2#1.base, 32 + ibmpex_register_bmc_~data~2#1.offset, 22, 0, ibmpex_register_bmc_~#__key~1#1.base, ibmpex_register_bmc_~#__key~1#1.offset;havoc __mutex_init_~arg0#1.base, __mutex_init_~arg0#1.offset, __mutex_init_~arg1#1.base, __mutex_init_~arg1#1.offset, __mutex_init_~arg2#1.base, __mutex_init_~arg2#1.offset;__mutex_init_~arg0#1.base, __mutex_init_~arg0#1.offset := __mutex_init_#in~arg0#1.base, __mutex_init_#in~arg0#1.offset;__mutex_init_~arg1#1.base, __mutex_init_~arg1#1.offset := __mutex_init_#in~arg1#1.base, __mutex_init_#in~arg1#1.offset;__mutex_init_~arg2#1.base, __mutex_init_~arg2#1.offset := __mutex_init_#in~arg2#1.base, __mutex_init_#in~arg2#1.offset; {4431#true} is VALID [2022-02-20 21:35:26,542 INFO L290 TraceCheckUtils]: 38: Hoare triple {4431#true} assume { :end_inline___mutex_init } true;call write~int(0, ibmpex_register_bmc_~data~2#1.base, 611 + ibmpex_register_bmc_~data~2#1.offset, 8);assume { :begin_inline_init_completion } true;init_completion_#in~x#1.base, init_completion_#in~x#1.offset := ibmpex_register_bmc_~data~2#1.base, 231 + ibmpex_register_bmc_~data~2#1.offset;havoc init_completion_~x#1.base, init_completion_~x#1.offset, init_completion_~#__key~0#1.base, init_completion_~#__key~0#1.offset;init_completion_~x#1.base, init_completion_~x#1.offset := init_completion_#in~x#1.base, init_completion_#in~x#1.offset;call init_completion_~#__key~0#1.base, init_completion_~#__key~0#1.offset := #Ultimate.allocOnStack(8);call write~int(0, init_completion_~x#1.base, init_completion_~x#1.offset, 4);assume { :begin_inline___init_waitqueue_head } true;__init_waitqueue_head_#in~arg0#1.base, __init_waitqueue_head_#in~arg0#1.offset, __init_waitqueue_head_#in~arg1#1.base, __init_waitqueue_head_#in~arg1#1.offset := init_completion_~x#1.base, 4 + init_completion_~x#1.offset, init_completion_~#__key~0#1.base, init_completion_~#__key~0#1.offset;havoc __init_waitqueue_head_~arg0#1.base, __init_waitqueue_head_~arg0#1.offset, __init_waitqueue_head_~arg1#1.base, __init_waitqueue_head_~arg1#1.offset;__init_waitqueue_head_~arg0#1.base, __init_waitqueue_head_~arg0#1.offset := __init_waitqueue_head_#in~arg0#1.base, __init_waitqueue_head_#in~arg0#1.offset;__init_waitqueue_head_~arg1#1.base, __init_waitqueue_head_~arg1#1.offset := __init_waitqueue_head_#in~arg1#1.base, __init_waitqueue_head_#in~arg1#1.offset; {4431#true} is VALID [2022-02-20 21:35:26,543 INFO L290 TraceCheckUtils]: 39: Hoare triple {4431#true} assume { :end_inline___init_waitqueue_head } true;call ULTIMATE.dealloc(init_completion_~#__key~0#1.base, init_completion_~#__key~0#1.offset);havoc init_completion_~#__key~0#1.base, init_completion_~#__key~0#1.offset; {4431#true} is VALID [2022-02-20 21:35:26,543 INFO L290 TraceCheckUtils]: 40: Hoare triple {4431#true} assume { :end_inline_init_completion } true;call write~int(58, ibmpex_register_bmc_~data~2#1.base, 327 + ibmpex_register_bmc_~data~2#1.offset, 1);call write~int(60, ibmpex_register_bmc_~data~2#1.base, 328 + ibmpex_register_bmc_~data~2#1.offset, 1);call write~$Pointer$(ibmpex_register_bmc_~data~2#1.base, 339 + ibmpex_register_bmc_~data~2#1.offset, ibmpex_register_bmc_~data~2#1.base, 331 + ibmpex_register_bmc_~data~2#1.offset, 8);assume { :begin_inline_ibmpex_ver_check } true;ibmpex_ver_check_#in~data#1.base, ibmpex_ver_check_#in~data#1.offset := ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset;havoc ibmpex_ver_check_#res#1;havoc ibmpex_ver_check_#t~ret71#1, ibmpex_ver_check_#t~mem72#1, ibmpex_ver_check_#t~mem73#1, ibmpex_ver_check_#t~short74#1, ibmpex_ver_check_#t~mem75#1, ibmpex_ver_check_#t~mem76#1, ibmpex_ver_check_#t~ret77#1, ibmpex_ver_check_#t~nondet78#1, ibmpex_ver_check_#t~mem79#1.base, ibmpex_ver_check_#t~mem79#1.offset, ibmpex_ver_check_#t~mem80#1, ibmpex_ver_check_#t~mem81#1, ibmpex_ver_check_#t~mem82#1, ibmpex_ver_check_#t~mem83#1, ibmpex_ver_check_#t~mem84#1, ibmpex_ver_check_~data#1.base, ibmpex_ver_check_~data#1.offset, ibmpex_ver_check_~tmp~4#1;ibmpex_ver_check_~data#1.base, ibmpex_ver_check_~data#1.offset := ibmpex_ver_check_#in~data#1.base, ibmpex_ver_check_#in~data#1.offset;havoc ibmpex_ver_check_~tmp~4#1;call write~int(1, ibmpex_ver_check_~data#1.base, 339 + ibmpex_ver_check_~data#1.offset, 1);call write~int(1, ibmpex_ver_check_~data#1.base, 329 + ibmpex_ver_check_~data#1.offset, 2); {4431#true} is VALID [2022-02-20 21:35:26,544 INFO L272 TraceCheckUtils]: 41: Hoare triple {4431#true} call ibmpex_ver_check_#t~ret71#1 := ibmpex_send_message(ibmpex_ver_check_~data#1.base, ibmpex_ver_check_~data#1.offset); {4518#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} is VALID [2022-02-20 21:35:26,544 INFO L290 TraceCheckUtils]: 42: Hoare triple {4518#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;havoc ~err~0#1;assume { :begin_inline_ipmi_validate_addr } true;ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset, ipmi_validate_addr_#in~arg1#1 := ~data#1.base, 193 + ~data#1.offset, 40;havoc ipmi_validate_addr_#res#1;havoc ipmi_validate_addr_#t~nondet254#1, ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset, ipmi_validate_addr_~arg1#1;ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset := ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset;ipmi_validate_addr_~arg1#1 := ipmi_validate_addr_#in~arg1#1;assume -2147483648 <= ipmi_validate_addr_#t~nondet254#1 && ipmi_validate_addr_#t~nondet254#1 <= 2147483647;ipmi_validate_addr_#res#1 := ipmi_validate_addr_#t~nondet254#1;havoc ipmi_validate_addr_#t~nondet254#1; {4431#true} is VALID [2022-02-20 21:35:26,544 INFO L290 TraceCheckUtils]: 43: Hoare triple {4431#true} #t~ret62#1 := ipmi_validate_addr_#res#1;assume { :end_inline_ipmi_validate_addr } true;assume -2147483648 <= #t~ret62#1 && #t~ret62#1 <= 2147483647;~err~0#1 := #t~ret62#1;havoc #t~ret62#1; {4431#true} is VALID [2022-02-20 21:35:26,544 INFO L290 TraceCheckUtils]: 44: Hoare triple {4431#true} assume 0 != ~err~0#1; {4431#true} is VALID [2022-02-20 21:35:26,544 INFO L290 TraceCheckUtils]: 45: Hoare triple {4431#true} havoc #t~nondet69#1;call #t~mem70#1.base, #t~mem70#1.offset := read~$Pointer$(~data#1.base, 24 + ~data#1.offset, 8);havoc #t~mem70#1.base, #t~mem70#1.offset;#res#1 := ~err~0#1; {4431#true} is VALID [2022-02-20 21:35:26,544 INFO L290 TraceCheckUtils]: 46: Hoare triple {4431#true} assume true; {4431#true} is VALID [2022-02-20 21:35:26,545 INFO L284 TraceCheckUtils]: 47: Hoare quadruple {4431#true} {4431#true} #618#return; {4431#true} is VALID [2022-02-20 21:35:26,545 INFO L290 TraceCheckUtils]: 48: Hoare triple {4431#true} assume -2147483648 <= ibmpex_ver_check_#t~ret71#1 && ibmpex_ver_check_#t~ret71#1 <= 2147483647;havoc ibmpex_ver_check_#t~ret71#1; {4431#true} is VALID [2022-02-20 21:35:26,545 INFO L272 TraceCheckUtils]: 49: Hoare triple {4431#true} call wait_for_completion(ibmpex_ver_check_~data#1.base, 231 + ibmpex_ver_check_~data#1.offset); {4431#true} is VALID [2022-02-20 21:35:26,545 INFO L290 TraceCheckUtils]: 50: Hoare triple {4431#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset; {4431#true} is VALID [2022-02-20 21:35:26,545 INFO L290 TraceCheckUtils]: 51: Hoare triple {4431#true} assume true; {4431#true} is VALID [2022-02-20 21:35:26,546 INFO L284 TraceCheckUtils]: 52: Hoare quadruple {4431#true} {4431#true} #620#return; {4431#true} is VALID [2022-02-20 21:35:26,546 INFO L290 TraceCheckUtils]: 53: Hoare triple {4431#true} call ibmpex_ver_check_#t~mem72#1 := read~int(ibmpex_ver_check_~data#1.base, 899 + ibmpex_ver_check_~data#1.offset, 1);ibmpex_ver_check_#t~short74#1 := 0 != ibmpex_ver_check_#t~mem72#1 % 256 % 4294967296; {4431#true} is VALID [2022-02-20 21:35:26,546 INFO L290 TraceCheckUtils]: 54: Hoare triple {4431#true} assume !ibmpex_ver_check_#t~short74#1;call ibmpex_ver_check_#t~mem73#1 := read~int(ibmpex_ver_check_~data#1.base, 891 + ibmpex_ver_check_~data#1.offset, 8);ibmpex_ver_check_#t~short74#1 := 6 != ibmpex_ver_check_#t~mem73#1 % 18446744073709551616; {4431#true} is VALID [2022-02-20 21:35:26,546 INFO L290 TraceCheckUtils]: 55: Hoare triple {4431#true} assume !ibmpex_ver_check_#t~short74#1;havoc ibmpex_ver_check_#t~mem72#1;havoc ibmpex_ver_check_#t~mem73#1;havoc ibmpex_ver_check_#t~short74#1;call ibmpex_ver_check_#t~mem75#1 := read~int(ibmpex_ver_check_~data#1.base, 619 + ibmpex_ver_check_~data#1.offset, 1);call write~int(ibmpex_ver_check_#t~mem75#1, ibmpex_ver_check_~data#1.base, 904 + ibmpex_ver_check_~data#1.offset, 1);havoc ibmpex_ver_check_#t~mem75#1;call ibmpex_ver_check_#t~mem76#1 := read~int(ibmpex_ver_check_~data#1.base, 620 + ibmpex_ver_check_~data#1.offset, 1);call write~int(ibmpex_ver_check_#t~mem76#1, ibmpex_ver_check_~data#1.base, 905 + ibmpex_ver_check_~data#1.offset, 1);havoc ibmpex_ver_check_#t~mem76#1; {4431#true} is VALID [2022-02-20 21:35:26,546 INFO L272 TraceCheckUtils]: 56: Hoare triple {4431#true} call ibmpex_ver_check_#t~ret77#1 := extract_value(ibmpex_ver_check_~data#1.base, 619 + ibmpex_ver_check_~data#1.offset, 2); {4431#true} is VALID [2022-02-20 21:35:26,546 INFO L290 TraceCheckUtils]: 57: Hoare triple {4431#true} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;~offset#1 := #in~offset#1;havoc ~tmp~3#1;assume { :begin_inline___be16_to_cpup } true;__be16_to_cpup_#in~p#1.base, __be16_to_cpup_#in~p#1.offset := ~data#1.base, ~data#1.offset + 2 * (if ~offset#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then ~offset#1 % 18446744073709551616 % 18446744073709551616 else ~offset#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616);havoc __be16_to_cpup_#res#1;havoc __be16_to_cpup_#t~ret3#1, __be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset, __be16_to_cpup_~tmp~1#1;__be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset := __be16_to_cpup_#in~p#1.base, __be16_to_cpup_#in~p#1.offset;havoc __be16_to_cpup_~tmp~1#1;assume { :begin_inline___swab16p } true;__swab16p_#in~p#1.base, __swab16p_#in~p#1.offset := __be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset;havoc __swab16p_#res#1;havoc __swab16p_#t~mem1#1, __swab16p_#t~ret2#1, __swab16p_~p#1.base, __swab16p_~p#1.offset, __swab16p_~tmp~0#1;__swab16p_~p#1.base, __swab16p_~p#1.offset := __swab16p_#in~p#1.base, __swab16p_#in~p#1.offset;havoc __swab16p_~tmp~0#1;call __swab16p_#t~mem1#1 := read~int(__swab16p_~p#1.base, __swab16p_~p#1.offset, 2);assume { :begin_inline___fswab16 } true;__fswab16_#in~val#1 := __swab16p_#t~mem1#1 % 65536;havoc __fswab16_#res#1;havoc __fswab16_~val#1;__fswab16_~val#1 := __fswab16_#in~val#1;__fswab16_#res#1 := (if (1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) || 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536)) && 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) then (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) else (if 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) && (1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) || 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536)) then (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) else (if (1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) && (1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) || 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536))) || ((1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) || 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536)) && 1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536)) then 1 else ~bitwiseOr((if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536), (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536))))); {4431#true} is VALID [2022-02-20 21:35:26,547 INFO L290 TraceCheckUtils]: 58: Hoare triple {4431#true} __swab16p_#t~ret2#1 := __fswab16_#res#1;assume { :end_inline___fswab16 } true;__swab16p_~tmp~0#1 := __swab16p_#t~ret2#1;havoc __swab16p_#t~mem1#1;havoc __swab16p_#t~ret2#1;__swab16p_#res#1 := __swab16p_~tmp~0#1; {4431#true} is VALID [2022-02-20 21:35:26,547 INFO L290 TraceCheckUtils]: 59: Hoare triple {4431#true} __be16_to_cpup_#t~ret3#1 := __swab16p_#res#1;assume { :end_inline___swab16p } true;__be16_to_cpup_~tmp~1#1 := __be16_to_cpup_#t~ret3#1;havoc __be16_to_cpup_#t~ret3#1;__be16_to_cpup_#res#1 := __be16_to_cpup_~tmp~1#1; {4431#true} is VALID [2022-02-20 21:35:26,547 INFO L290 TraceCheckUtils]: 60: Hoare triple {4431#true} #t~ret61#1 := __be16_to_cpup_#res#1;assume { :end_inline___be16_to_cpup } true;~tmp~3#1 := #t~ret61#1;havoc #t~ret61#1;#res#1 := ~tmp~3#1; {4431#true} is VALID [2022-02-20 21:35:26,547 INFO L290 TraceCheckUtils]: 61: Hoare triple {4431#true} assume true; {4431#true} is VALID [2022-02-20 21:35:26,547 INFO L284 TraceCheckUtils]: 62: Hoare quadruple {4431#true} {4431#true} #622#return; {4431#true} is VALID [2022-02-20 21:35:26,548 INFO L290 TraceCheckUtils]: 63: Hoare triple {4431#true} ibmpex_ver_check_~tmp~4#1 := ibmpex_ver_check_#t~ret77#1;havoc ibmpex_ver_check_#t~ret77#1;havoc ibmpex_ver_check_#t~nondet78#1;call ibmpex_ver_check_#t~mem79#1.base, ibmpex_ver_check_#t~mem79#1.offset := read~$Pointer$(ibmpex_ver_check_~data#1.base, 24 + ibmpex_ver_check_~data#1.offset, 8);call ibmpex_ver_check_#t~mem80#1 := read~int(ibmpex_ver_check_~data#1.base, 904 + ibmpex_ver_check_~data#1.offset, 1);call ibmpex_ver_check_#t~mem81#1 := read~int(ibmpex_ver_check_~data#1.base, 905 + ibmpex_ver_check_~data#1.offset, 1);call ibmpex_ver_check_#t~mem82#1 := read~int(ibmpex_ver_check_~data#1.base, 623 + ibmpex_ver_check_~data#1.offset, 1);call ibmpex_ver_check_#t~mem83#1 := read~int(ibmpex_ver_check_~data#1.base, 624 + ibmpex_ver_check_~data#1.offset, 1);call ibmpex_ver_check_#t~mem84#1 := read~int(ibmpex_ver_check_~data#1.base, 323 + ibmpex_ver_check_~data#1.offset, 4);havoc ibmpex_ver_check_#t~mem79#1.base, ibmpex_ver_check_#t~mem79#1.offset;havoc ibmpex_ver_check_#t~mem80#1;havoc ibmpex_ver_check_#t~mem81#1;havoc ibmpex_ver_check_#t~mem82#1;havoc ibmpex_ver_check_#t~mem83#1;havoc ibmpex_ver_check_#t~mem84#1;ibmpex_ver_check_#res#1 := 0; {4431#true} is VALID [2022-02-20 21:35:26,548 INFO L290 TraceCheckUtils]: 64: Hoare triple {4431#true} ibmpex_register_bmc_#t~ret184#1 := ibmpex_ver_check_#res#1;assume { :end_inline_ibmpex_ver_check } true;assume -2147483648 <= ibmpex_register_bmc_#t~ret184#1 && ibmpex_register_bmc_#t~ret184#1 <= 2147483647;ibmpex_register_bmc_~err~4#1 := ibmpex_register_bmc_#t~ret184#1;havoc ibmpex_register_bmc_#t~ret184#1; {4431#true} is VALID [2022-02-20 21:35:26,548 INFO L290 TraceCheckUtils]: 65: Hoare triple {4431#true} assume !(0 != ibmpex_register_bmc_~err~4#1);call ibmpex_register_bmc_#t~mem185#1.base, ibmpex_register_bmc_#t~mem185#1.offset := read~$Pointer$(ibmpex_register_bmc_~data~2#1.base, 24 + ibmpex_register_bmc_~data~2#1.offset, 8);assume { :begin_inline_hwmon_device_register } true;hwmon_device_register_#in~arg0#1.base, hwmon_device_register_#in~arg0#1.offset := ibmpex_register_bmc_#t~mem185#1.base, ibmpex_register_bmc_#t~mem185#1.offset;havoc hwmon_device_register_#res#1.base, hwmon_device_register_#res#1.offset;havoc hwmon_device_register_#t~ret248#1.base, hwmon_device_register_#t~ret248#1.offset, hwmon_device_register_~arg0#1.base, hwmon_device_register_~arg0#1.offset;hwmon_device_register_~arg0#1.base, hwmon_device_register_~arg0#1.offset := hwmon_device_register_#in~arg0#1.base, hwmon_device_register_#in~arg0#1.offset; {4431#true} is VALID [2022-02-20 21:35:26,548 INFO L272 TraceCheckUtils]: 66: Hoare triple {4431#true} call hwmon_device_register_#t~ret248#1.base, hwmon_device_register_#t~ret248#1.offset := ldv_malloc(1035); {4503#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:26,549 INFO L290 TraceCheckUtils]: 67: Hoare triple {4503#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {4431#true} is VALID [2022-02-20 21:35:26,549 INFO L290 TraceCheckUtils]: 68: Hoare triple {4431#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {4431#true} is VALID [2022-02-20 21:35:26,549 INFO L290 TraceCheckUtils]: 69: Hoare triple {4431#true} assume true; {4431#true} is VALID [2022-02-20 21:35:26,549 INFO L284 TraceCheckUtils]: 70: Hoare quadruple {4431#true} {4431#true} #624#return; {4431#true} is VALID [2022-02-20 21:35:26,549 INFO L290 TraceCheckUtils]: 71: Hoare triple {4431#true} hwmon_device_register_#res#1.base, hwmon_device_register_#res#1.offset := hwmon_device_register_#t~ret248#1.base, hwmon_device_register_#t~ret248#1.offset;havoc hwmon_device_register_#t~ret248#1.base, hwmon_device_register_#t~ret248#1.offset; {4431#true} is VALID [2022-02-20 21:35:26,550 INFO L290 TraceCheckUtils]: 72: Hoare triple {4431#true} ibmpex_register_bmc_#t~ret186#1.base, ibmpex_register_bmc_#t~ret186#1.offset := hwmon_device_register_#res#1.base, hwmon_device_register_#res#1.offset;assume { :end_inline_hwmon_device_register } true;call write~$Pointer$(ibmpex_register_bmc_#t~ret186#1.base, ibmpex_register_bmc_#t~ret186#1.offset, ibmpex_register_bmc_~data~2#1.base, 16 + ibmpex_register_bmc_~data~2#1.offset, 8);havoc ibmpex_register_bmc_#t~mem185#1.base, ibmpex_register_bmc_#t~mem185#1.offset;havoc ibmpex_register_bmc_#t~ret186#1.base, ibmpex_register_bmc_#t~ret186#1.offset;call ibmpex_register_bmc_#t~mem187#1.base, ibmpex_register_bmc_#t~mem187#1.offset := read~$Pointer$(ibmpex_register_bmc_~data~2#1.base, 16 + ibmpex_register_bmc_~data~2#1.offset, 8);assume { :begin_inline_IS_ERR } true;IS_ERR_#in~ptr#1.base, IS_ERR_#in~ptr#1.offset := ibmpex_register_bmc_#t~mem187#1.base, ibmpex_register_bmc_#t~mem187#1.offset;havoc IS_ERR_#res#1;havoc IS_ERR_#t~ret240#1, IS_ERR_~ptr#1.base, IS_ERR_~ptr#1.offset, IS_ERR_~tmp~18#1;IS_ERR_~ptr#1.base, IS_ERR_~ptr#1.offset := IS_ERR_#in~ptr#1.base, IS_ERR_#in~ptr#1.offset;havoc IS_ERR_~tmp~18#1; {4431#true} is VALID [2022-02-20 21:35:26,550 INFO L272 TraceCheckUtils]: 73: Hoare triple {4431#true} call IS_ERR_#t~ret240#1 := ldv_is_err(IS_ERR_~ptr#1.base, IS_ERR_~ptr#1.offset); {4431#true} is VALID [2022-02-20 21:35:26,550 INFO L290 TraceCheckUtils]: 74: Hoare triple {4431#true} ~ptr.base, ~ptr.offset := #in~ptr.base, #in~ptr.offset;#res := (if (~ptr.base + ~ptr.offset) % 18446744073709551616 > 2012 then 1 else 0); {4431#true} is VALID [2022-02-20 21:35:26,550 INFO L290 TraceCheckUtils]: 75: Hoare triple {4431#true} assume true; {4431#true} is VALID [2022-02-20 21:35:26,550 INFO L284 TraceCheckUtils]: 76: Hoare quadruple {4431#true} {4431#true} #626#return; {4431#true} is VALID [2022-02-20 21:35:26,550 INFO L290 TraceCheckUtils]: 77: Hoare triple {4431#true} assume -9223372036854775808 <= IS_ERR_#t~ret240#1 && IS_ERR_#t~ret240#1 <= 9223372036854775807;IS_ERR_~tmp~18#1 := IS_ERR_#t~ret240#1;havoc IS_ERR_#t~ret240#1;IS_ERR_#res#1 := IS_ERR_~tmp~18#1; {4431#true} is VALID [2022-02-20 21:35:26,551 INFO L290 TraceCheckUtils]: 78: Hoare triple {4431#true} ibmpex_register_bmc_#t~ret188#1 := IS_ERR_#res#1;assume { :end_inline_IS_ERR } true;assume -9223372036854775808 <= ibmpex_register_bmc_#t~ret188#1 && ibmpex_register_bmc_#t~ret188#1 <= 9223372036854775807;ibmpex_register_bmc_~tmp___0~3#1 := ibmpex_register_bmc_#t~ret188#1;havoc ibmpex_register_bmc_#t~mem187#1.base, ibmpex_register_bmc_#t~mem187#1.offset;havoc ibmpex_register_bmc_#t~ret188#1; {4431#true} is VALID [2022-02-20 21:35:26,551 INFO L290 TraceCheckUtils]: 79: Hoare triple {4431#true} assume !(0 != ibmpex_register_bmc_~tmp___0~3#1); {4431#true} is VALID [2022-02-20 21:35:26,551 INFO L272 TraceCheckUtils]: 80: Hoare triple {4431#true} call dev_set_drvdata(ibmpex_register_bmc_~dev#1.base, ibmpex_register_bmc_~dev#1.offset, ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset); {4431#true} is VALID [2022-02-20 21:35:26,551 INFO L290 TraceCheckUtils]: 81: Hoare triple {4431#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset;~arg1.base, ~arg1.offset := #in~arg1.base, #in~arg1.offset; {4431#true} is VALID [2022-02-20 21:35:26,551 INFO L290 TraceCheckUtils]: 82: Hoare triple {4431#true} assume true; {4431#true} is VALID [2022-02-20 21:35:26,551 INFO L284 TraceCheckUtils]: 83: Hoare quadruple {4431#true} {4431#true} #628#return; {4431#true} is VALID [2022-02-20 21:35:26,552 INFO L290 TraceCheckUtils]: 84: Hoare triple {4431#true} assume { :begin_inline_list_add_tail } true;list_add_tail_#in~new#1.base, list_add_tail_#in~new#1.offset, list_add_tail_#in~head#1.base, list_add_tail_#in~head#1.offset := ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset, ~#driver_data~0.base, ~#driver_data~0.offset;havoc list_add_tail_#t~mem12#1.base, list_add_tail_#t~mem12#1.offset, list_add_tail_~new#1.base, list_add_tail_~new#1.offset, list_add_tail_~head#1.base, list_add_tail_~head#1.offset;list_add_tail_~new#1.base, list_add_tail_~new#1.offset := list_add_tail_#in~new#1.base, list_add_tail_#in~new#1.offset;list_add_tail_~head#1.base, list_add_tail_~head#1.offset := list_add_tail_#in~head#1.base, list_add_tail_#in~head#1.offset;call list_add_tail_#t~mem12#1.base, list_add_tail_#t~mem12#1.offset := read~$Pointer$(list_add_tail_~head#1.base, 8 + list_add_tail_~head#1.offset, 8);assume { :begin_inline___list_add } true;__list_add_#in~arg0#1.base, __list_add_#in~arg0#1.offset, __list_add_#in~arg1#1.base, __list_add_#in~arg1#1.offset, __list_add_#in~arg2#1.base, __list_add_#in~arg2#1.offset := list_add_tail_~new#1.base, list_add_tail_~new#1.offset, list_add_tail_#t~mem12#1.base, list_add_tail_#t~mem12#1.offset, list_add_tail_~head#1.base, list_add_tail_~head#1.offset;havoc __list_add_~arg0#1.base, __list_add_~arg0#1.offset, __list_add_~arg1#1.base, __list_add_~arg1#1.offset, __list_add_~arg2#1.base, __list_add_~arg2#1.offset;__list_add_~arg0#1.base, __list_add_~arg0#1.offset := __list_add_#in~arg0#1.base, __list_add_#in~arg0#1.offset;__list_add_~arg1#1.base, __list_add_~arg1#1.offset := __list_add_#in~arg1#1.base, __list_add_#in~arg1#1.offset;__list_add_~arg2#1.base, __list_add_~arg2#1.offset := __list_add_#in~arg2#1.base, __list_add_#in~arg2#1.offset; {4431#true} is VALID [2022-02-20 21:35:26,552 INFO L290 TraceCheckUtils]: 85: Hoare triple {4431#true} assume { :end_inline___list_add } true;havoc list_add_tail_#t~mem12#1.base, list_add_tail_#t~mem12#1.offset; {4431#true} is VALID [2022-02-20 21:35:26,552 INFO L290 TraceCheckUtils]: 86: Hoare triple {4431#true} assume { :end_inline_list_add_tail } true;assume { :begin_inline_ibmpex_find_sensors } true;ibmpex_find_sensors_#in~data#1.base, ibmpex_find_sensors_#in~data#1.offset := ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset;havoc ibmpex_find_sensors_#res#1;havoc ibmpex_find_sensors_#t~ret148#1, ibmpex_find_sensors_#t~mem149#1, ibmpex_find_sensors_#t~ret150#1.base, ibmpex_find_sensors_#t~ret150#1.offset, ibmpex_find_sensors_#t~mem151#1.base, ibmpex_find_sensors_#t~mem151#1.offset, ibmpex_find_sensors_#t~ret152#1, ibmpex_find_sensors_#t~mem153#1, ibmpex_find_sensors_#t~ret154#1, ibmpex_find_sensors_#t~mem155#1.base, ibmpex_find_sensors_#t~mem155#1.offset, ibmpex_find_sensors_#t~mem156#1, ibmpex_find_sensors_#t~ret157#1, ibmpex_find_sensors_#t~mem158#1, ibmpex_find_sensors_#t~ret159#1, ibmpex_find_sensors_#t~mem160#1.base, ibmpex_find_sensors_#t~mem160#1.offset, ibmpex_find_sensors_#t~mem161#1.base, ibmpex_find_sensors_#t~mem161#1.offset, ibmpex_find_sensors_#t~ret162#1, ibmpex_find_sensors_#t~mem163#1, ibmpex_find_sensors_#t~mem164#1.base, ibmpex_find_sensors_#t~mem164#1.offset, ibmpex_find_sensors_#t~ret165#1, ibmpex_find_sensors_#t~mem166#1.base, ibmpex_find_sensors_#t~mem166#1.offset, ibmpex_find_sensors_#t~ret167#1, ibmpex_find_sensors_#t~mem168#1.base, ibmpex_find_sensors_#t~mem168#1.offset, ibmpex_find_sensors_#t~mem169#1.base, ibmpex_find_sensors_#t~mem169#1.offset, ibmpex_find_sensors_#t~mem170#1.base, ibmpex_find_sensors_#t~mem170#1.offset, ibmpex_find_sensors_#t~mem171#1.base, ibmpex_find_sensors_#t~mem171#1.offset, ibmpex_find_sensors_#t~mem172#1.base, ibmpex_find_sensors_#t~mem172#1.offset, ibmpex_find_sensors_#t~mem173#1.base, ibmpex_find_sensors_#t~mem173#1.offset, ibmpex_find_sensors_#t~mem174#1.base, ibmpex_find_sensors_#t~mem174#1.offset, ibmpex_find_sensors_#t~mem175#1.base, ibmpex_find_sensors_#t~mem175#1.offset, ibmpex_find_sensors_#t~mem176#1, ibmpex_find_sensors_#t~mem177#1.base, ibmpex_find_sensors_#t~mem177#1.offset, ibmpex_find_sensors_~data#1.base, ibmpex_find_sensors_~data#1.offset, ibmpex_find_sensors_~i~2#1, ibmpex_find_sensors_~j~0#1, ibmpex_find_sensors_~err~3#1, ibmpex_find_sensors_~sensor_type~0#1, ibmpex_find_sensors_~sensor_counter~0#1, ibmpex_find_sensors_~num_power~0#1, ibmpex_find_sensors_~num_temp~0#1, ibmpex_find_sensors_~tmp~13#1.base, ibmpex_find_sensors_~tmp~13#1.offset, ibmpex_find_sensors_~tmp___0~2#1, ibmpex_find_sensors_~tmp___1~1#1;ibmpex_find_sensors_~data#1.base, ibmpex_find_sensors_~data#1.offset := ibmpex_find_sensors_#in~data#1.base, ibmpex_find_sensors_#in~data#1.offset;havoc ibmpex_find_sensors_~i~2#1;havoc ibmpex_find_sensors_~j~0#1;havoc ibmpex_find_sensors_~err~3#1;havoc ibmpex_find_sensors_~sensor_type~0#1;havoc ibmpex_find_sensors_~sensor_counter~0#1;havoc ibmpex_find_sensors_~num_power~0#1;havoc ibmpex_find_sensors_~num_temp~0#1;havoc ibmpex_find_sensors_~tmp~13#1.base, ibmpex_find_sensors_~tmp~13#1.offset;havoc ibmpex_find_sensors_~tmp___0~2#1;havoc ibmpex_find_sensors_~tmp___1~1#1;ibmpex_find_sensors_~num_power~0#1 := 0;ibmpex_find_sensors_~num_temp~0#1 := 0;assume { :begin_inline_ibmpex_query_sensor_count } true;ibmpex_query_sensor_count_#in~data#1.base, ibmpex_query_sensor_count_#in~data#1.offset := ibmpex_find_sensors_~data#1.base, ibmpex_find_sensors_~data#1.offset;havoc ibmpex_query_sensor_count_#res#1;havoc ibmpex_query_sensor_count_#t~ret85#1, ibmpex_query_sensor_count_#t~mem86#1, ibmpex_query_sensor_count_#t~mem87#1, ibmpex_query_sensor_count_#t~short88#1, ibmpex_query_sensor_count_#t~mem89#1, ibmpex_query_sensor_count_~data#1.base, ibmpex_query_sensor_count_~data#1.offset;ibmpex_query_sensor_count_~data#1.base, ibmpex_query_sensor_count_~data#1.offset := ibmpex_query_sensor_count_#in~data#1.base, ibmpex_query_sensor_count_#in~data#1.offset;call write~int(2, ibmpex_query_sensor_count_~data#1.base, 339 + ibmpex_query_sensor_count_~data#1.offset, 1);call write~int(1, ibmpex_query_sensor_count_~data#1.base, 329 + ibmpex_query_sensor_count_~data#1.offset, 2); {4431#true} is VALID [2022-02-20 21:35:26,553 INFO L272 TraceCheckUtils]: 87: Hoare triple {4431#true} call ibmpex_query_sensor_count_#t~ret85#1 := ibmpex_send_message(ibmpex_query_sensor_count_~data#1.base, ibmpex_query_sensor_count_~data#1.offset); {4518#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} is VALID [2022-02-20 21:35:26,553 INFO L290 TraceCheckUtils]: 88: Hoare triple {4518#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;havoc ~err~0#1;assume { :begin_inline_ipmi_validate_addr } true;ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset, ipmi_validate_addr_#in~arg1#1 := ~data#1.base, 193 + ~data#1.offset, 40;havoc ipmi_validate_addr_#res#1;havoc ipmi_validate_addr_#t~nondet254#1, ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset, ipmi_validate_addr_~arg1#1;ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset := ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset;ipmi_validate_addr_~arg1#1 := ipmi_validate_addr_#in~arg1#1;assume -2147483648 <= ipmi_validate_addr_#t~nondet254#1 && ipmi_validate_addr_#t~nondet254#1 <= 2147483647;ipmi_validate_addr_#res#1 := ipmi_validate_addr_#t~nondet254#1;havoc ipmi_validate_addr_#t~nondet254#1; {4431#true} is VALID [2022-02-20 21:35:26,553 INFO L290 TraceCheckUtils]: 89: Hoare triple {4431#true} #t~ret62#1 := ipmi_validate_addr_#res#1;assume { :end_inline_ipmi_validate_addr } true;assume -2147483648 <= #t~ret62#1 && #t~ret62#1 <= 2147483647;~err~0#1 := #t~ret62#1;havoc #t~ret62#1; {4431#true} is VALID [2022-02-20 21:35:26,553 INFO L290 TraceCheckUtils]: 90: Hoare triple {4431#true} assume 0 != ~err~0#1; {4431#true} is VALID [2022-02-20 21:35:26,554 INFO L290 TraceCheckUtils]: 91: Hoare triple {4431#true} havoc #t~nondet69#1;call #t~mem70#1.base, #t~mem70#1.offset := read~$Pointer$(~data#1.base, 24 + ~data#1.offset, 8);havoc #t~mem70#1.base, #t~mem70#1.offset;#res#1 := ~err~0#1; {4431#true} is VALID [2022-02-20 21:35:26,554 INFO L290 TraceCheckUtils]: 92: Hoare triple {4431#true} assume true; {4431#true} is VALID [2022-02-20 21:35:26,554 INFO L284 TraceCheckUtils]: 93: Hoare quadruple {4431#true} {4431#true} #630#return; {4431#true} is VALID [2022-02-20 21:35:26,554 INFO L290 TraceCheckUtils]: 94: Hoare triple {4431#true} assume -2147483648 <= ibmpex_query_sensor_count_#t~ret85#1 && ibmpex_query_sensor_count_#t~ret85#1 <= 2147483647;havoc ibmpex_query_sensor_count_#t~ret85#1; {4431#true} is VALID [2022-02-20 21:35:26,554 INFO L272 TraceCheckUtils]: 95: Hoare triple {4431#true} call wait_for_completion(ibmpex_query_sensor_count_~data#1.base, 231 + ibmpex_query_sensor_count_~data#1.offset); {4431#true} is VALID [2022-02-20 21:35:26,554 INFO L290 TraceCheckUtils]: 96: Hoare triple {4431#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset; {4431#true} is VALID [2022-02-20 21:35:26,555 INFO L290 TraceCheckUtils]: 97: Hoare triple {4431#true} assume true; {4431#true} is VALID [2022-02-20 21:35:26,555 INFO L284 TraceCheckUtils]: 98: Hoare quadruple {4431#true} {4431#true} #632#return; {4431#true} is VALID [2022-02-20 21:35:26,555 INFO L290 TraceCheckUtils]: 99: Hoare triple {4431#true} call ibmpex_query_sensor_count_#t~mem86#1 := read~int(ibmpex_query_sensor_count_~data#1.base, 899 + ibmpex_query_sensor_count_~data#1.offset, 1);ibmpex_query_sensor_count_#t~short88#1 := 0 != ibmpex_query_sensor_count_#t~mem86#1 % 256 % 4294967296; {4431#true} is VALID [2022-02-20 21:35:26,555 INFO L290 TraceCheckUtils]: 100: Hoare triple {4431#true} assume !ibmpex_query_sensor_count_#t~short88#1;call ibmpex_query_sensor_count_#t~mem87#1 := read~int(ibmpex_query_sensor_count_~data#1.base, 891 + ibmpex_query_sensor_count_~data#1.offset, 8);ibmpex_query_sensor_count_#t~short88#1 := 1 != ibmpex_query_sensor_count_#t~mem87#1 % 18446744073709551616; {4431#true} is VALID [2022-02-20 21:35:26,556 INFO L290 TraceCheckUtils]: 101: Hoare triple {4431#true} assume ibmpex_query_sensor_count_#t~short88#1;havoc ibmpex_query_sensor_count_#t~mem86#1;havoc ibmpex_query_sensor_count_#t~mem87#1;havoc ibmpex_query_sensor_count_#t~short88#1;ibmpex_query_sensor_count_#res#1 := -2; {4486#(<= (+ 2 |ULTIMATE.start_ibmpex_query_sensor_count_#res#1|) 0)} is VALID [2022-02-20 21:35:26,556 INFO L290 TraceCheckUtils]: 102: Hoare triple {4486#(<= (+ 2 |ULTIMATE.start_ibmpex_query_sensor_count_#res#1|) 0)} ibmpex_find_sensors_#t~ret148#1 := ibmpex_query_sensor_count_#res#1;assume { :end_inline_ibmpex_query_sensor_count } true;assume -2147483648 <= ibmpex_find_sensors_#t~ret148#1 && ibmpex_find_sensors_#t~ret148#1 <= 2147483647;ibmpex_find_sensors_~err~3#1 := ibmpex_find_sensors_#t~ret148#1;havoc ibmpex_find_sensors_#t~ret148#1; {4487#(<= (+ 2 |ULTIMATE.start_ibmpex_find_sensors_~err~3#1|) 0)} is VALID [2022-02-20 21:35:26,557 INFO L290 TraceCheckUtils]: 103: Hoare triple {4487#(<= (+ 2 |ULTIMATE.start_ibmpex_find_sensors_~err~3#1|) 0)} assume !(ibmpex_find_sensors_~err~3#1 <= 0);call write~int(ibmpex_find_sensors_~err~3#1, ibmpex_find_sensors_~data#1.base, 906 + ibmpex_find_sensors_~data#1.offset, 1);call ibmpex_find_sensors_#t~mem149#1 := read~int(ibmpex_find_sensors_~data#1.base, 906 + ibmpex_find_sensors_~data#1.offset, 1); {4432#false} is VALID [2022-02-20 21:35:26,557 INFO L272 TraceCheckUtils]: 104: Hoare triple {4432#false} call ibmpex_find_sensors_#t~ret150#1.base, ibmpex_find_sensors_#t~ret150#1.offset := kzalloc(184 * (ibmpex_find_sensors_#t~mem149#1 % 256), 208); {4503#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:26,557 INFO L290 TraceCheckUtils]: 105: Hoare triple {4503#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size;~flags := #in~flags;havoc ~tmp~2.base, ~tmp~2.offset; {4431#true} is VALID [2022-02-20 21:35:26,558 INFO L272 TraceCheckUtils]: 106: Hoare triple {4431#true} call #t~ret40.base, #t~ret40.offset := kmalloc(~size, ~bitwiseOr(~flags, 32768)); {4503#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:26,558 INFO L290 TraceCheckUtils]: 107: Hoare triple {4503#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {4431#true} is VALID [2022-02-20 21:35:26,559 INFO L272 TraceCheckUtils]: 108: Hoare triple {4431#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {4503#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:26,559 INFO L290 TraceCheckUtils]: 109: Hoare triple {4503#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {4431#true} is VALID [2022-02-20 21:35:26,559 INFO L290 TraceCheckUtils]: 110: Hoare triple {4431#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {4431#true} is VALID [2022-02-20 21:35:26,559 INFO L290 TraceCheckUtils]: 111: Hoare triple {4431#true} assume true; {4431#true} is VALID [2022-02-20 21:35:26,559 INFO L284 TraceCheckUtils]: 112: Hoare quadruple {4431#true} {4431#true} #590#return; {4431#true} is VALID [2022-02-20 21:35:26,560 INFO L290 TraceCheckUtils]: 113: Hoare triple {4431#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {4431#true} is VALID [2022-02-20 21:35:26,560 INFO L290 TraceCheckUtils]: 114: Hoare triple {4431#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {4431#true} is VALID [2022-02-20 21:35:26,560 INFO L290 TraceCheckUtils]: 115: Hoare triple {4431#true} assume true; {4431#true} is VALID [2022-02-20 21:35:26,560 INFO L284 TraceCheckUtils]: 116: Hoare quadruple {4431#true} {4431#true} #588#return; {4431#true} is VALID [2022-02-20 21:35:26,560 INFO L290 TraceCheckUtils]: 117: Hoare triple {4431#true} ~tmp~2.base, ~tmp~2.offset := #t~ret40.base, #t~ret40.offset;havoc #t~ret40.base, #t~ret40.offset;#res.base, #res.offset := ~tmp~2.base, ~tmp~2.offset; {4431#true} is VALID [2022-02-20 21:35:26,561 INFO L290 TraceCheckUtils]: 118: Hoare triple {4431#true} assume true; {4431#true} is VALID [2022-02-20 21:35:26,561 INFO L284 TraceCheckUtils]: 119: Hoare quadruple {4431#true} {4432#false} #634#return; {4432#false} is VALID [2022-02-20 21:35:26,561 INFO L290 TraceCheckUtils]: 120: Hoare triple {4432#false} ibmpex_find_sensors_~tmp~13#1.base, ibmpex_find_sensors_~tmp~13#1.offset := ibmpex_find_sensors_#t~ret150#1.base, ibmpex_find_sensors_#t~ret150#1.offset;havoc ibmpex_find_sensors_#t~mem149#1;havoc ibmpex_find_sensors_#t~ret150#1.base, ibmpex_find_sensors_#t~ret150#1.offset;call write~$Pointer$(ibmpex_find_sensors_~tmp~13#1.base, ibmpex_find_sensors_~tmp~13#1.offset, ibmpex_find_sensors_~data#1.base, 907 + ibmpex_find_sensors_~data#1.offset, 8);call ibmpex_find_sensors_#t~mem151#1.base, ibmpex_find_sensors_#t~mem151#1.offset := read~$Pointer$(ibmpex_find_sensors_~data#1.base, 907 + ibmpex_find_sensors_~data#1.offset, 8); {4432#false} is VALID [2022-02-20 21:35:26,561 INFO L290 TraceCheckUtils]: 121: Hoare triple {4432#false} assume !(0 == (ibmpex_find_sensors_#t~mem151#1.base + ibmpex_find_sensors_#t~mem151#1.offset) % 18446744073709551616);havoc ibmpex_find_sensors_#t~mem151#1.base, ibmpex_find_sensors_#t~mem151#1.offset;ibmpex_find_sensors_~i~2#1 := 0; {4432#false} is VALID [2022-02-20 21:35:26,561 INFO L290 TraceCheckUtils]: 122: Hoare triple {4432#false} call ibmpex_find_sensors_#t~mem163#1 := read~int(ibmpex_find_sensors_~data#1.base, 906 + ibmpex_find_sensors_~data#1.offset, 1); {4432#false} is VALID [2022-02-20 21:35:26,561 INFO L290 TraceCheckUtils]: 123: Hoare triple {4432#false} assume !(ibmpex_find_sensors_#t~mem163#1 % 256 > ibmpex_find_sensors_~i~2#1);havoc ibmpex_find_sensors_#t~mem163#1;call ibmpex_find_sensors_#t~mem164#1.base, ibmpex_find_sensors_#t~mem164#1.offset := read~$Pointer$(ibmpex_find_sensors_~data#1.base, 24 + ibmpex_find_sensors_~data#1.offset, 8);assume { :begin_inline_ldv_device_create_file_6 } true;ldv_device_create_file_6_#in~ldv_func_arg1#1.base, ldv_device_create_file_6_#in~ldv_func_arg1#1.offset, ldv_device_create_file_6_#in~ldv_func_arg2#1.base, ldv_device_create_file_6_#in~ldv_func_arg2#1.offset := ibmpex_find_sensors_#t~mem164#1.base, ibmpex_find_sensors_#t~mem164#1.offset, ~#sensor_dev_attr_reset_high_low~0.base, ~#sensor_dev_attr_reset_high_low~0.offset;havoc ldv_device_create_file_6_#res#1;havoc ldv_device_create_file_6_#t~ret242#1, ldv_device_create_file_6_~ldv_func_arg1#1.base, ldv_device_create_file_6_~ldv_func_arg1#1.offset, ldv_device_create_file_6_~ldv_func_arg2#1.base, ldv_device_create_file_6_~ldv_func_arg2#1.offset, ldv_device_create_file_6_~tmp~20#1;ldv_device_create_file_6_~ldv_func_arg1#1.base, ldv_device_create_file_6_~ldv_func_arg1#1.offset := ldv_device_create_file_6_#in~ldv_func_arg1#1.base, ldv_device_create_file_6_#in~ldv_func_arg1#1.offset;ldv_device_create_file_6_~ldv_func_arg2#1.base, ldv_device_create_file_6_~ldv_func_arg2#1.offset := ldv_device_create_file_6_#in~ldv_func_arg2#1.base, ldv_device_create_file_6_#in~ldv_func_arg2#1.offset;havoc ldv_device_create_file_6_~tmp~20#1; {4432#false} is VALID [2022-02-20 21:35:26,562 INFO L272 TraceCheckUtils]: 124: Hoare triple {4432#false} call ldv_device_create_file_6_#t~ret242#1 := ldv_device_create_file_dev_attr_of_sensor_device_attribute(ldv_device_create_file_6_~ldv_func_arg2#1.base, ldv_device_create_file_6_~ldv_func_arg2#1.offset); {4432#false} is VALID [2022-02-20 21:35:26,562 INFO L290 TraceCheckUtils]: 125: Hoare triple {4432#false} ~attr.base, ~attr.offset := #in~attr.base, #in~attr.offset; {4432#false} is VALID [2022-02-20 21:35:26,562 INFO L290 TraceCheckUtils]: 126: Hoare triple {4432#false} assume 0 == ~ldv_call_dev_attr_of_sensor_device_attribute~0;~ldv_count_2~0 := 1 + ~ldv_count_2~0;~ldv_call_dev_attr_of_sensor_device_attribute~0 := 1; {4432#false} is VALID [2022-02-20 21:35:26,562 INFO L290 TraceCheckUtils]: 127: Hoare triple {4432#false} assume !(~ldv_count_1~0 >= ~ldv_count_2~0); {4432#false} is VALID [2022-02-20 21:35:26,562 INFO L272 TraceCheckUtils]: 128: Hoare triple {4432#false} call ldv_error(); {4432#false} is VALID [2022-02-20 21:35:26,562 INFO L290 TraceCheckUtils]: 129: Hoare triple {4432#false} assume !false; {4432#false} is VALID [2022-02-20 21:35:26,563 INFO L134 CoverageAnalysis]: Checked inductivity of 34 backedges. 0 proven. 0 refuted. 0 times theorem prover too weak. 34 trivial. 0 not checked. [2022-02-20 21:35:26,564 INFO L144 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-02-20 21:35:26,564 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [851792029] [2022-02-20 21:35:26,564 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleSmtInterpolCraig [851792029] provided 1 perfect and 0 imperfect interpolant sequences [2022-02-20 21:35:26,565 INFO L191 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-02-20 21:35:26,565 INFO L204 FreeRefinementEngine]: Number of different interpolants: perfect sequences [6] imperfect sequences [] total 6 [2022-02-20 21:35:26,565 INFO L118 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [1212766432] [2022-02-20 21:35:26,565 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-02-20 21:35:26,567 INFO L78 Accepts]: Start accepts. Automaton has has 6 states, 6 states have (on average 12.5) internal successors, (75), 4 states have internal predecessors, (75), 2 states have call successors, (16), 4 states have call predecessors, (16), 1 states have return successors, (14), 2 states have call predecessors, (14), 2 states have call successors, (14) Word has length 130 [2022-02-20 21:35:26,567 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-02-20 21:35:26,567 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with has 6 states, 6 states have (on average 12.5) internal successors, (75), 4 states have internal predecessors, (75), 2 states have call successors, (16), 4 states have call predecessors, (16), 1 states have return successors, (14), 2 states have call predecessors, (14), 2 states have call successors, (14) [2022-02-20 21:35:26,657 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 105 edges. 105 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 21:35:26,658 INFO L546 AbstractCegarLoop]: INTERPOLANT automaton has 6 states [2022-02-20 21:35:26,658 INFO L108 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2022-02-20 21:35:26,658 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 6 interpolants. [2022-02-20 21:35:26,659 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=9, Invalid=21, Unknown=0, NotChecked=0, Total=30 [2022-02-20 21:35:26,659 INFO L87 Difference]: Start difference. First operand 264 states and 347 transitions. Second operand has 6 states, 6 states have (on average 12.5) internal successors, (75), 4 states have internal predecessors, (75), 2 states have call successors, (16), 4 states have call predecessors, (16), 1 states have return successors, (14), 2 states have call predecessors, (14), 2 states have call successors, (14) [2022-02-20 21:35:29,627 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 21:35:29,627 INFO L93 Difference]: Finished difference Result 627 states and 845 transitions. [2022-02-20 21:35:29,628 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 7 states. [2022-02-20 21:35:29,628 INFO L78 Accepts]: Start accepts. Automaton has has 6 states, 6 states have (on average 12.5) internal successors, (75), 4 states have internal predecessors, (75), 2 states have call successors, (16), 4 states have call predecessors, (16), 1 states have return successors, (14), 2 states have call predecessors, (14), 2 states have call successors, (14) Word has length 130 [2022-02-20 21:35:29,628 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-02-20 21:35:29,629 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 6 states, 6 states have (on average 12.5) internal successors, (75), 4 states have internal predecessors, (75), 2 states have call successors, (16), 4 states have call predecessors, (16), 1 states have return successors, (14), 2 states have call predecessors, (14), 2 states have call successors, (14) [2022-02-20 21:35:29,638 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 7 states to 7 states and 836 transitions. [2022-02-20 21:35:29,638 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 6 states, 6 states have (on average 12.5) internal successors, (75), 4 states have internal predecessors, (75), 2 states have call successors, (16), 4 states have call predecessors, (16), 1 states have return successors, (14), 2 states have call predecessors, (14), 2 states have call successors, (14) [2022-02-20 21:35:29,647 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 7 states to 7 states and 836 transitions. [2022-02-20 21:35:29,647 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with 7 states and 836 transitions. [2022-02-20 21:35:30,363 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 836 edges. 836 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 21:35:30,375 INFO L225 Difference]: With dead ends: 627 [2022-02-20 21:35:30,375 INFO L226 Difference]: Without dead ends: 371 [2022-02-20 21:35:30,375 INFO L932 BasicCegarLoop]: 0 DeclaredPredicates, 40 GetRequests, 34 SyntacticMatches, 0 SemanticMatches, 6 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 1 ImplicationChecksByTransitivity, 0.0s TimeCoverageRelationStatistics Valid=17, Invalid=39, Unknown=0, NotChecked=0, Total=56 [2022-02-20 21:35:30,376 INFO L933 BasicCegarLoop]: 421 mSDtfsCounter, 308 mSDsluCounter, 848 mSDsCounter, 0 mSdLazyCounter, 573 mSolverCounterSat, 157 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.9s Time, 0 mProtectedPredicate, 0 mProtectedAction, 316 SdHoareTripleChecker+Valid, 1269 SdHoareTripleChecker+Invalid, 730 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 157 IncrementalHoareTripleChecker+Valid, 573 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.9s IncrementalHoareTripleChecker+Time [2022-02-20 21:35:30,377 INFO L934 BasicCegarLoop]: SdHoareTripleChecker [316 Valid, 1269 Invalid, 730 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [157 Valid, 573 Invalid, 0 Unknown, 0 Unchecked, 0.9s Time] [2022-02-20 21:35:30,378 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 371 states. [2022-02-20 21:35:30,395 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 371 to 266. [2022-02-20 21:35:30,395 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-02-20 21:35:30,396 INFO L82 GeneralOperation]: Start isEquivalent. First operand 371 states. Second operand has 266 states, 204 states have (on average 1.2794117647058822) internal successors, (261), 207 states have internal predecessors, (261), 45 states have call successors, (45), 17 states have call predecessors, (45), 16 states have return successors, (43), 43 states have call predecessors, (43), 43 states have call successors, (43) [2022-02-20 21:35:30,396 INFO L74 IsIncluded]: Start isIncluded. First operand 371 states. Second operand has 266 states, 204 states have (on average 1.2794117647058822) internal successors, (261), 207 states have internal predecessors, (261), 45 states have call successors, (45), 17 states have call predecessors, (45), 16 states have return successors, (43), 43 states have call predecessors, (43), 43 states have call successors, (43) [2022-02-20 21:35:30,397 INFO L87 Difference]: Start difference. First operand 371 states. Second operand has 266 states, 204 states have (on average 1.2794117647058822) internal successors, (261), 207 states have internal predecessors, (261), 45 states have call successors, (45), 17 states have call predecessors, (45), 16 states have return successors, (43), 43 states have call predecessors, (43), 43 states have call successors, (43) [2022-02-20 21:35:30,419 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 21:35:30,419 INFO L93 Difference]: Finished difference Result 371 states and 506 transitions. [2022-02-20 21:35:30,419 INFO L276 IsEmpty]: Start isEmpty. Operand 371 states and 506 transitions. [2022-02-20 21:35:30,421 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 21:35:30,421 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 21:35:30,423 INFO L74 IsIncluded]: Start isIncluded. First operand has 266 states, 204 states have (on average 1.2794117647058822) internal successors, (261), 207 states have internal predecessors, (261), 45 states have call successors, (45), 17 states have call predecessors, (45), 16 states have return successors, (43), 43 states have call predecessors, (43), 43 states have call successors, (43) Second operand 371 states. [2022-02-20 21:35:30,423 INFO L87 Difference]: Start difference. First operand has 266 states, 204 states have (on average 1.2794117647058822) internal successors, (261), 207 states have internal predecessors, (261), 45 states have call successors, (45), 17 states have call predecessors, (45), 16 states have return successors, (43), 43 states have call predecessors, (43), 43 states have call successors, (43) Second operand 371 states. [2022-02-20 21:35:30,437 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 21:35:30,437 INFO L93 Difference]: Finished difference Result 371 states and 506 transitions. [2022-02-20 21:35:30,437 INFO L276 IsEmpty]: Start isEmpty. Operand 371 states and 506 transitions. [2022-02-20 21:35:30,438 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 21:35:30,438 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 21:35:30,439 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-02-20 21:35:30,439 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-02-20 21:35:30,440 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 266 states, 204 states have (on average 1.2794117647058822) internal successors, (261), 207 states have internal predecessors, (261), 45 states have call successors, (45), 17 states have call predecessors, (45), 16 states have return successors, (43), 43 states have call predecessors, (43), 43 states have call successors, (43) [2022-02-20 21:35:30,447 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 266 states to 266 states and 349 transitions. [2022-02-20 21:35:30,447 INFO L78 Accepts]: Start accepts. Automaton has 266 states and 349 transitions. Word has length 130 [2022-02-20 21:35:30,448 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-02-20 21:35:30,449 INFO L470 AbstractCegarLoop]: Abstraction has 266 states and 349 transitions. [2022-02-20 21:35:30,449 INFO L471 AbstractCegarLoop]: INTERPOLANT automaton has has 6 states, 6 states have (on average 12.5) internal successors, (75), 4 states have internal predecessors, (75), 2 states have call successors, (16), 4 states have call predecessors, (16), 1 states have return successors, (14), 2 states have call predecessors, (14), 2 states have call successors, (14) [2022-02-20 21:35:30,449 INFO L276 IsEmpty]: Start isEmpty. Operand 266 states and 349 transitions. [2022-02-20 21:35:30,450 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 131 [2022-02-20 21:35:30,450 INFO L506 BasicCegarLoop]: Found error trace [2022-02-20 21:35:30,451 INFO L514 BasicCegarLoop]: trace histogram [3, 3, 3, 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, 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:35:30,451 WARN L452 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable2 [2022-02-20 21:35:30,451 INFO L402 AbstractCegarLoop]: === Iteration 4 === Targeting ldv_errorErr0ASSERT_VIOLATIONERROR_FUNCTION === [ldv_errorErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-02-20 21:35:30,452 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-02-20 21:35:30,452 INFO L85 PathProgramCache]: Analyzing trace with hash 1056468710, now seen corresponding path program 1 times [2022-02-20 21:35:30,452 INFO L126 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-02-20 21:35:30,452 INFO L338 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [840559958] [2022-02-20 21:35:30,452 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 21:35:30,453 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-02-20 21:35:30,560 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:30,664 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 3 [2022-02-20 21:35:30,669 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:30,672 INFO L290 TraceCheckUtils]: 0: Hoare triple {6608#true} assume true; {6608#true} is VALID [2022-02-20 21:35:30,672 INFO L284 TraceCheckUtils]: 1: Hoare quadruple {6608#true} {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} #612#return; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,672 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 14 [2022-02-20 21:35:30,673 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:30,676 INFO L290 TraceCheckUtils]: 0: Hoare triple {6608#true} assume true; {6608#true} is VALID [2022-02-20 21:35:30,676 INFO L284 TraceCheckUtils]: 1: Hoare quadruple {6608#true} {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} #614#return; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,681 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 18 [2022-02-20 21:35:30,685 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:30,689 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:35:30,692 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:30,695 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:35:30,696 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:30,699 INFO L290 TraceCheckUtils]: 0: Hoare triple {6681#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {6608#true} is VALID [2022-02-20 21:35:30,699 INFO L290 TraceCheckUtils]: 1: Hoare triple {6608#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {6608#true} is VALID [2022-02-20 21:35:30,700 INFO L290 TraceCheckUtils]: 2: Hoare triple {6608#true} assume true; {6608#true} is VALID [2022-02-20 21:35:30,700 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {6608#true} {6608#true} #590#return; {6608#true} is VALID [2022-02-20 21:35:30,700 INFO L290 TraceCheckUtils]: 0: Hoare triple {6681#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {6608#true} is VALID [2022-02-20 21:35:30,701 INFO L272 TraceCheckUtils]: 1: Hoare triple {6608#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {6681#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:30,701 INFO L290 TraceCheckUtils]: 2: Hoare triple {6681#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {6608#true} is VALID [2022-02-20 21:35:30,701 INFO L290 TraceCheckUtils]: 3: Hoare triple {6608#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {6608#true} is VALID [2022-02-20 21:35:30,701 INFO L290 TraceCheckUtils]: 4: Hoare triple {6608#true} assume true; {6608#true} is VALID [2022-02-20 21:35:30,701 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {6608#true} {6608#true} #590#return; {6608#true} is VALID [2022-02-20 21:35:30,702 INFO L290 TraceCheckUtils]: 6: Hoare triple {6608#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {6608#true} is VALID [2022-02-20 21:35:30,702 INFO L290 TraceCheckUtils]: 7: Hoare triple {6608#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {6608#true} is VALID [2022-02-20 21:35:30,702 INFO L290 TraceCheckUtils]: 8: Hoare triple {6608#true} assume true; {6608#true} is VALID [2022-02-20 21:35:30,702 INFO L284 TraceCheckUtils]: 9: Hoare quadruple {6608#true} {6608#true} #588#return; {6608#true} is VALID [2022-02-20 21:35:30,702 INFO L290 TraceCheckUtils]: 0: Hoare triple {6681#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size;~flags := #in~flags;havoc ~tmp~2.base, ~tmp~2.offset; {6608#true} is VALID [2022-02-20 21:35:30,703 INFO L272 TraceCheckUtils]: 1: Hoare triple {6608#true} call #t~ret40.base, #t~ret40.offset := kmalloc(~size, ~bitwiseOr(~flags, 32768)); {6681#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:30,703 INFO L290 TraceCheckUtils]: 2: Hoare triple {6681#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {6608#true} is VALID [2022-02-20 21:35:30,704 INFO L272 TraceCheckUtils]: 3: Hoare triple {6608#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {6681#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:30,704 INFO L290 TraceCheckUtils]: 4: Hoare triple {6681#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {6608#true} is VALID [2022-02-20 21:35:30,704 INFO L290 TraceCheckUtils]: 5: Hoare triple {6608#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {6608#true} is VALID [2022-02-20 21:35:30,704 INFO L290 TraceCheckUtils]: 6: Hoare triple {6608#true} assume true; {6608#true} is VALID [2022-02-20 21:35:30,704 INFO L284 TraceCheckUtils]: 7: Hoare quadruple {6608#true} {6608#true} #590#return; {6608#true} is VALID [2022-02-20 21:35:30,705 INFO L290 TraceCheckUtils]: 8: Hoare triple {6608#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {6608#true} is VALID [2022-02-20 21:35:30,705 INFO L290 TraceCheckUtils]: 9: Hoare triple {6608#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {6608#true} is VALID [2022-02-20 21:35:30,705 INFO L290 TraceCheckUtils]: 10: Hoare triple {6608#true} assume true; {6608#true} is VALID [2022-02-20 21:35:30,705 INFO L284 TraceCheckUtils]: 11: Hoare quadruple {6608#true} {6608#true} #588#return; {6608#true} is VALID [2022-02-20 21:35:30,705 INFO L290 TraceCheckUtils]: 12: Hoare triple {6608#true} ~tmp~2.base, ~tmp~2.offset := #t~ret40.base, #t~ret40.offset;havoc #t~ret40.base, #t~ret40.offset;#res.base, #res.offset := ~tmp~2.base, ~tmp~2.offset; {6608#true} is VALID [2022-02-20 21:35:30,705 INFO L290 TraceCheckUtils]: 13: Hoare triple {6608#true} assume true; {6608#true} is VALID [2022-02-20 21:35:30,706 INFO L284 TraceCheckUtils]: 14: Hoare quadruple {6608#true} {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} #616#return; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,713 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 41 [2022-02-20 21:35:30,718 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:30,724 INFO L290 TraceCheckUtils]: 0: Hoare triple {6696#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;havoc ~err~0#1;assume { :begin_inline_ipmi_validate_addr } true;ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset, ipmi_validate_addr_#in~arg1#1 := ~data#1.base, 193 + ~data#1.offset, 40;havoc ipmi_validate_addr_#res#1;havoc ipmi_validate_addr_#t~nondet254#1, ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset, ipmi_validate_addr_~arg1#1;ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset := ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset;ipmi_validate_addr_~arg1#1 := ipmi_validate_addr_#in~arg1#1;assume -2147483648 <= ipmi_validate_addr_#t~nondet254#1 && ipmi_validate_addr_#t~nondet254#1 <= 2147483647;ipmi_validate_addr_#res#1 := ipmi_validate_addr_#t~nondet254#1;havoc ipmi_validate_addr_#t~nondet254#1; {6608#true} is VALID [2022-02-20 21:35:30,724 INFO L290 TraceCheckUtils]: 1: Hoare triple {6608#true} #t~ret62#1 := ipmi_validate_addr_#res#1;assume { :end_inline_ipmi_validate_addr } true;assume -2147483648 <= #t~ret62#1 && #t~ret62#1 <= 2147483647;~err~0#1 := #t~ret62#1;havoc #t~ret62#1; {6608#true} is VALID [2022-02-20 21:35:30,739 INFO L290 TraceCheckUtils]: 2: Hoare triple {6608#true} assume 0 != ~err~0#1; {6608#true} is VALID [2022-02-20 21:35:30,739 INFO L290 TraceCheckUtils]: 3: Hoare triple {6608#true} havoc #t~nondet69#1;call #t~mem70#1.base, #t~mem70#1.offset := read~$Pointer$(~data#1.base, 24 + ~data#1.offset, 8);havoc #t~mem70#1.base, #t~mem70#1.offset;#res#1 := ~err~0#1; {6608#true} is VALID [2022-02-20 21:35:30,739 INFO L290 TraceCheckUtils]: 4: Hoare triple {6608#true} assume true; {6608#true} is VALID [2022-02-20 21:35:30,740 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {6608#true} {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} #618#return; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,740 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 49 [2022-02-20 21:35:30,743 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:30,746 INFO L290 TraceCheckUtils]: 0: Hoare triple {6608#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset; {6608#true} is VALID [2022-02-20 21:35:30,746 INFO L290 TraceCheckUtils]: 1: Hoare triple {6608#true} assume true; {6608#true} is VALID [2022-02-20 21:35:30,747 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {6608#true} {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} #620#return; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,747 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 56 [2022-02-20 21:35:30,751 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:30,756 INFO L290 TraceCheckUtils]: 0: Hoare triple {6608#true} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;~offset#1 := #in~offset#1;havoc ~tmp~3#1;assume { :begin_inline___be16_to_cpup } true;__be16_to_cpup_#in~p#1.base, __be16_to_cpup_#in~p#1.offset := ~data#1.base, ~data#1.offset + 2 * (if ~offset#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then ~offset#1 % 18446744073709551616 % 18446744073709551616 else ~offset#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616);havoc __be16_to_cpup_#res#1;havoc __be16_to_cpup_#t~ret3#1, __be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset, __be16_to_cpup_~tmp~1#1;__be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset := __be16_to_cpup_#in~p#1.base, __be16_to_cpup_#in~p#1.offset;havoc __be16_to_cpup_~tmp~1#1;assume { :begin_inline___swab16p } true;__swab16p_#in~p#1.base, __swab16p_#in~p#1.offset := __be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset;havoc __swab16p_#res#1;havoc __swab16p_#t~mem1#1, __swab16p_#t~ret2#1, __swab16p_~p#1.base, __swab16p_~p#1.offset, __swab16p_~tmp~0#1;__swab16p_~p#1.base, __swab16p_~p#1.offset := __swab16p_#in~p#1.base, __swab16p_#in~p#1.offset;havoc __swab16p_~tmp~0#1;call __swab16p_#t~mem1#1 := read~int(__swab16p_~p#1.base, __swab16p_~p#1.offset, 2);assume { :begin_inline___fswab16 } true;__fswab16_#in~val#1 := __swab16p_#t~mem1#1 % 65536;havoc __fswab16_#res#1;havoc __fswab16_~val#1;__fswab16_~val#1 := __fswab16_#in~val#1;__fswab16_#res#1 := (if (1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) || 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536)) && 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) then (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) else (if 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) && (1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) || 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536)) then (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) else (if (1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) && (1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) || 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536))) || ((1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) || 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536)) && 1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536)) then 1 else ~bitwiseOr((if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536), (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536))))); {6608#true} is VALID [2022-02-20 21:35:30,756 INFO L290 TraceCheckUtils]: 1: Hoare triple {6608#true} __swab16p_#t~ret2#1 := __fswab16_#res#1;assume { :end_inline___fswab16 } true;__swab16p_~tmp~0#1 := __swab16p_#t~ret2#1;havoc __swab16p_#t~mem1#1;havoc __swab16p_#t~ret2#1;__swab16p_#res#1 := __swab16p_~tmp~0#1; {6608#true} is VALID [2022-02-20 21:35:30,757 INFO L290 TraceCheckUtils]: 2: Hoare triple {6608#true} __be16_to_cpup_#t~ret3#1 := __swab16p_#res#1;assume { :end_inline___swab16p } true;__be16_to_cpup_~tmp~1#1 := __be16_to_cpup_#t~ret3#1;havoc __be16_to_cpup_#t~ret3#1;__be16_to_cpup_#res#1 := __be16_to_cpup_~tmp~1#1; {6608#true} is VALID [2022-02-20 21:35:30,757 INFO L290 TraceCheckUtils]: 3: Hoare triple {6608#true} #t~ret61#1 := __be16_to_cpup_#res#1;assume { :end_inline___be16_to_cpup } true;~tmp~3#1 := #t~ret61#1;havoc #t~ret61#1;#res#1 := ~tmp~3#1; {6608#true} is VALID [2022-02-20 21:35:30,757 INFO L290 TraceCheckUtils]: 4: Hoare triple {6608#true} assume true; {6608#true} is VALID [2022-02-20 21:35:30,758 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {6608#true} {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} #622#return; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,758 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 66 [2022-02-20 21:35:30,760 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:30,763 INFO L290 TraceCheckUtils]: 0: Hoare triple {6681#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {6608#true} is VALID [2022-02-20 21:35:30,763 INFO L290 TraceCheckUtils]: 1: Hoare triple {6608#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {6608#true} is VALID [2022-02-20 21:35:30,763 INFO L290 TraceCheckUtils]: 2: Hoare triple {6608#true} assume true; {6608#true} is VALID [2022-02-20 21:35:30,764 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {6608#true} {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} #624#return; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,764 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 73 [2022-02-20 21:35:30,766 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:30,769 INFO L290 TraceCheckUtils]: 0: Hoare triple {6608#true} ~ptr.base, ~ptr.offset := #in~ptr.base, #in~ptr.offset;#res := (if (~ptr.base + ~ptr.offset) % 18446744073709551616 > 2012 then 1 else 0); {6608#true} is VALID [2022-02-20 21:35:30,769 INFO L290 TraceCheckUtils]: 1: Hoare triple {6608#true} assume true; {6608#true} is VALID [2022-02-20 21:35:30,769 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {6608#true} {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} #626#return; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,770 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 80 [2022-02-20 21:35:30,771 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:30,773 INFO L290 TraceCheckUtils]: 0: Hoare triple {6608#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset;~arg1.base, ~arg1.offset := #in~arg1.base, #in~arg1.offset; {6608#true} is VALID [2022-02-20 21:35:30,773 INFO L290 TraceCheckUtils]: 1: Hoare triple {6608#true} assume true; {6608#true} is VALID [2022-02-20 21:35:30,774 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {6608#true} {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} #628#return; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,774 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 87 [2022-02-20 21:35:30,785 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:30,788 INFO L290 TraceCheckUtils]: 0: Hoare triple {6696#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;havoc ~err~0#1;assume { :begin_inline_ipmi_validate_addr } true;ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset, ipmi_validate_addr_#in~arg1#1 := ~data#1.base, 193 + ~data#1.offset, 40;havoc ipmi_validate_addr_#res#1;havoc ipmi_validate_addr_#t~nondet254#1, ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset, ipmi_validate_addr_~arg1#1;ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset := ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset;ipmi_validate_addr_~arg1#1 := ipmi_validate_addr_#in~arg1#1;assume -2147483648 <= ipmi_validate_addr_#t~nondet254#1 && ipmi_validate_addr_#t~nondet254#1 <= 2147483647;ipmi_validate_addr_#res#1 := ipmi_validate_addr_#t~nondet254#1;havoc ipmi_validate_addr_#t~nondet254#1; {6608#true} is VALID [2022-02-20 21:35:30,789 INFO L290 TraceCheckUtils]: 1: Hoare triple {6608#true} #t~ret62#1 := ipmi_validate_addr_#res#1;assume { :end_inline_ipmi_validate_addr } true;assume -2147483648 <= #t~ret62#1 && #t~ret62#1 <= 2147483647;~err~0#1 := #t~ret62#1;havoc #t~ret62#1; {6608#true} is VALID [2022-02-20 21:35:30,789 INFO L290 TraceCheckUtils]: 2: Hoare triple {6608#true} assume 0 != ~err~0#1; {6608#true} is VALID [2022-02-20 21:35:30,789 INFO L290 TraceCheckUtils]: 3: Hoare triple {6608#true} havoc #t~nondet69#1;call #t~mem70#1.base, #t~mem70#1.offset := read~$Pointer$(~data#1.base, 24 + ~data#1.offset, 8);havoc #t~mem70#1.base, #t~mem70#1.offset;#res#1 := ~err~0#1; {6608#true} is VALID [2022-02-20 21:35:30,789 INFO L290 TraceCheckUtils]: 4: Hoare triple {6608#true} assume true; {6608#true} is VALID [2022-02-20 21:35:30,790 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {6608#true} {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} #630#return; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,790 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 95 [2022-02-20 21:35:30,791 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:30,795 INFO L290 TraceCheckUtils]: 0: Hoare triple {6608#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset; {6608#true} is VALID [2022-02-20 21:35:30,795 INFO L290 TraceCheckUtils]: 1: Hoare triple {6608#true} assume true; {6608#true} is VALID [2022-02-20 21:35:30,796 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {6608#true} {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} #632#return; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,796 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 104 [2022-02-20 21:35:30,800 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:30,804 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:35:30,806 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:30,809 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:35:30,811 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:30,814 INFO L290 TraceCheckUtils]: 0: Hoare triple {6681#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {6608#true} is VALID [2022-02-20 21:35:30,814 INFO L290 TraceCheckUtils]: 1: Hoare triple {6608#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {6608#true} is VALID [2022-02-20 21:35:30,814 INFO L290 TraceCheckUtils]: 2: Hoare triple {6608#true} assume true; {6608#true} is VALID [2022-02-20 21:35:30,814 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {6608#true} {6608#true} #590#return; {6608#true} is VALID [2022-02-20 21:35:30,814 INFO L290 TraceCheckUtils]: 0: Hoare triple {6681#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {6608#true} is VALID [2022-02-20 21:35:30,815 INFO L272 TraceCheckUtils]: 1: Hoare triple {6608#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {6681#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:30,815 INFO L290 TraceCheckUtils]: 2: Hoare triple {6681#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {6608#true} is VALID [2022-02-20 21:35:30,815 INFO L290 TraceCheckUtils]: 3: Hoare triple {6608#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {6608#true} is VALID [2022-02-20 21:35:30,816 INFO L290 TraceCheckUtils]: 4: Hoare triple {6608#true} assume true; {6608#true} is VALID [2022-02-20 21:35:30,816 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {6608#true} {6608#true} #590#return; {6608#true} is VALID [2022-02-20 21:35:30,816 INFO L290 TraceCheckUtils]: 6: Hoare triple {6608#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {6608#true} is VALID [2022-02-20 21:35:30,816 INFO L290 TraceCheckUtils]: 7: Hoare triple {6608#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {6608#true} is VALID [2022-02-20 21:35:30,816 INFO L290 TraceCheckUtils]: 8: Hoare triple {6608#true} assume true; {6608#true} is VALID [2022-02-20 21:35:30,816 INFO L284 TraceCheckUtils]: 9: Hoare quadruple {6608#true} {6608#true} #588#return; {6608#true} is VALID [2022-02-20 21:35:30,817 INFO L290 TraceCheckUtils]: 0: Hoare triple {6681#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size;~flags := #in~flags;havoc ~tmp~2.base, ~tmp~2.offset; {6608#true} is VALID [2022-02-20 21:35:30,817 INFO L272 TraceCheckUtils]: 1: Hoare triple {6608#true} call #t~ret40.base, #t~ret40.offset := kmalloc(~size, ~bitwiseOr(~flags, 32768)); {6681#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:30,817 INFO L290 TraceCheckUtils]: 2: Hoare triple {6681#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {6608#true} is VALID [2022-02-20 21:35:30,818 INFO L272 TraceCheckUtils]: 3: Hoare triple {6608#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {6681#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:30,818 INFO L290 TraceCheckUtils]: 4: Hoare triple {6681#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {6608#true} is VALID [2022-02-20 21:35:30,818 INFO L290 TraceCheckUtils]: 5: Hoare triple {6608#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {6608#true} is VALID [2022-02-20 21:35:30,819 INFO L290 TraceCheckUtils]: 6: Hoare triple {6608#true} assume true; {6608#true} is VALID [2022-02-20 21:35:30,819 INFO L284 TraceCheckUtils]: 7: Hoare quadruple {6608#true} {6608#true} #590#return; {6608#true} is VALID [2022-02-20 21:35:30,819 INFO L290 TraceCheckUtils]: 8: Hoare triple {6608#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {6608#true} is VALID [2022-02-20 21:35:30,819 INFO L290 TraceCheckUtils]: 9: Hoare triple {6608#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {6608#true} is VALID [2022-02-20 21:35:30,819 INFO L290 TraceCheckUtils]: 10: Hoare triple {6608#true} assume true; {6608#true} is VALID [2022-02-20 21:35:30,819 INFO L284 TraceCheckUtils]: 11: Hoare quadruple {6608#true} {6608#true} #588#return; {6608#true} is VALID [2022-02-20 21:35:30,820 INFO L290 TraceCheckUtils]: 12: Hoare triple {6608#true} ~tmp~2.base, ~tmp~2.offset := #t~ret40.base, #t~ret40.offset;havoc #t~ret40.base, #t~ret40.offset;#res.base, #res.offset := ~tmp~2.base, ~tmp~2.offset; {6608#true} is VALID [2022-02-20 21:35:30,820 INFO L290 TraceCheckUtils]: 13: Hoare triple {6608#true} assume true; {6608#true} is VALID [2022-02-20 21:35:30,821 INFO L284 TraceCheckUtils]: 14: Hoare quadruple {6608#true} {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} #634#return; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,825 INFO L290 TraceCheckUtils]: 0: Hoare triple {6608#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(46, 2);call #Ultimate.allocInit(13, 3);call #Ultimate.allocInit(20, 4);call #Ultimate.allocInit(21, 5);call #Ultimate.allocInit(11, 6);call #Ultimate.allocInit(18, 7);call #Ultimate.allocInit(19, 8);call #Ultimate.allocInit(20, 9);call #Ultimate.allocInit(18, 10);call #Ultimate.allocInit(69, 11);call #Ultimate.allocInit(26, 12);call #Ultimate.allocInit(4, 13);call write~init~int(37, 13, 0, 1);call write~init~int(115, 13, 1, 1);call write~init~int(10, 13, 2, 1);call write~init~int(0, 13, 3, 1);call #Ultimate.allocInit(7, 14);call write~init~int(105, 14, 0, 1);call write~init~int(98, 14, 1, 1);call write~init~int(109, 14, 2, 1);call write~init~int(112, 14, 3, 1);call write~init~int(101, 14, 4, 1);call write~init~int(120, 14, 5, 1);call write~init~int(0, 14, 6, 1);call #Ultimate.allocInit(5, 15);call write~init~int(110, 15, 0, 1);call write~init~int(97, 15, 1, 1);call write~init~int(109, 15, 2, 1);call write~init~int(101, 15, 3, 1);call write~init~int(0, 15, 4, 1);call #Ultimate.allocInit(4, 16);call write~init~int(37, 16, 0, 1);call write~init~int(100, 16, 1, 1);call write~init~int(10, 16, 2, 1);call write~init~int(0, 16, 3, 1);call #Ultimate.allocInit(15, 17);call #Ultimate.allocInit(5, 18);call write~init~int(116, 18, 0, 1);call write~init~int(101, 18, 1, 1);call write~init~int(109, 18, 2, 1);call write~init~int(112, 18, 3, 1);call write~init~int(0, 18, 4, 1);call #Ultimate.allocInit(6, 19);call write~init~int(112, 19, 0, 1);call write~init~int(111, 19, 1, 1);call write~init~int(119, 19, 2, 1);call write~init~int(101, 19, 3, 1);call write~init~int(114, 19, 4, 1);call write~init~int(0, 19, 5, 1);call #Ultimate.allocInit(40, 20);call #Ultimate.allocInit(48, 21);call #Ultimate.allocInit(12, 22);call #Ultimate.allocInit(55, 23);call #Ultimate.allocInit(26, 24);call #Ultimate.allocInit(70, 25);~#power_sensor_sig~0.base, ~#power_sensor_sig~0.offset := 26, 0;call #Ultimate.allocInit(3, 26);call write~init~int(112, ~#power_sensor_sig~0.base, ~#power_sensor_sig~0.offset, 1);call write~init~int(119, ~#power_sensor_sig~0.base, 1 + ~#power_sensor_sig~0.offset, 1);call write~init~int(114, ~#power_sensor_sig~0.base, 2 + ~#power_sensor_sig~0.offset, 1);~#temp_sensor_sig~0.base, ~#temp_sensor_sig~0.offset := 27, 0;call #Ultimate.allocInit(3, 27);call write~init~int(116, ~#temp_sensor_sig~0.base, ~#temp_sensor_sig~0.offset, 1);call write~init~int(101, ~#temp_sensor_sig~0.base, 1 + ~#temp_sensor_sig~0.offset, 1);call write~init~int(109, ~#temp_sensor_sig~0.base, 2 + ~#temp_sensor_sig~0.offset, 1);~#watt_sensor_sig~0.base, ~#watt_sensor_sig~0.offset := 28, 0;call #Ultimate.allocInit(2, 28);call write~init~int(65, ~#watt_sensor_sig~0.base, ~#watt_sensor_sig~0.offset, 1);call write~init~int(67, ~#watt_sensor_sig~0.base, 1 + ~#watt_sensor_sig~0.offset, 1);~#power_sensor_name_templates~0.base, ~#power_sensor_name_templates~0.offset := 29, 0;call #Ultimate.allocInit(24, 29);call write~init~$Pointer$(3, 0, ~#power_sensor_name_templates~0.base, ~#power_sensor_name_templates~0.offset, 8);call write~init~$Pointer$(4, 0, ~#power_sensor_name_templates~0.base, 8 + ~#power_sensor_name_templates~0.offset, 8);call write~init~$Pointer$(5, 0, ~#power_sensor_name_templates~0.base, 16 + ~#power_sensor_name_templates~0.offset, 8);~#temp_sensor_name_templates~0.base, ~#temp_sensor_name_templates~0.offset := 30, 0;call #Ultimate.allocInit(24, 30);call write~init~$Pointer$(6, 0, ~#temp_sensor_name_templates~0.base, ~#temp_sensor_name_templates~0.offset, 8);call write~init~$Pointer$(7, 0, ~#temp_sensor_name_templates~0.base, 8 + ~#temp_sensor_name_templates~0.offset, 8);call write~init~$Pointer$(8, 0, ~#temp_sensor_name_templates~0.base, 16 + ~#temp_sensor_name_templates~0.offset, 8);~#driver_data~0.base, ~#driver_data~0.offset := 31, 0;call #Ultimate.allocInit(72, 31);call write~init~$Pointer$(~#driver_data~0.base, ~#driver_data~0.offset, ~#driver_data~0.base, ~#driver_data~0.offset, 8);call write~init~$Pointer$(~#driver_data~0.base, ~#driver_data~0.offset, ~#driver_data~0.base, 8 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(0, 0, ~#driver_data~0.base, 16 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(0, 0, ~#driver_data~0.base, 24 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(~#__this_module~0.base, ~#__this_module~0.offset, ~#driver_data~0.base, 32 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(#funAddr~ibmpex_register_bmc.base, #funAddr~ibmpex_register_bmc.offset, ~#driver_data~0.base, 40 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(#funAddr~ibmpex_bmc_gone.base, #funAddr~ibmpex_bmc_gone.offset, ~#driver_data~0.base, 48 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(#funAddr~ibmpex_msg_handler.base, #funAddr~ibmpex_msg_handler.offset, ~#driver_data~0.base, 56 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(0, 0, ~#driver_data~0.base, 64 + ~#driver_data~0.offset, 8);~#sensor_dev_attr_name~0.base, ~#sensor_dev_attr_name~0.offset := 32, 0;call #Ultimate.allocInit(48, 32);call write~init~$Pointer$(15, 0, ~#sensor_dev_attr_name~0.base, ~#sensor_dev_attr_name~0.offset, 8);call write~init~int(292, ~#sensor_dev_attr_name~0.base, 8 + ~#sensor_dev_attr_name~0.offset, 4);call write~init~$Pointer$(0, 0, ~#sensor_dev_attr_name~0.base, 12 + ~#sensor_dev_attr_name~0.offset, 8);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 20 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 21 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 22 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 23 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 24 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 25 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 26 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 27 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~$Pointer$(#funAddr~show_name.base, #funAddr~show_name.offset, ~#sensor_dev_attr_name~0.base, 28 + ~#sensor_dev_attr_name~0.offset, 8);call write~init~$Pointer$(0, 0, ~#sensor_dev_attr_name~0.base, 36 + ~#sensor_dev_attr_name~0.offset, 8);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 44 + ~#sensor_dev_attr_name~0.offset, 4);~#sensor_dev_attr_reset_high_low~0.base, ~#sensor_dev_attr_reset_high_low~0.offset := 33, 0;call #Ultimate.allocInit(48, 33);call write~init~$Pointer$(17, 0, ~#sensor_dev_attr_reset_high_low~0.base, ~#sensor_dev_attr_reset_high_low~0.offset, 8);call write~init~int(128, ~#sensor_dev_attr_reset_high_low~0.base, 8 + ~#sensor_dev_attr_reset_high_low~0.offset, 4);call write~init~$Pointer$(0, 0, ~#sensor_dev_attr_reset_high_low~0.base, 12 + ~#sensor_dev_attr_reset_high_low~0.offset, 8);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 20 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 21 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 22 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 23 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 24 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 25 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 26 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 27 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~$Pointer$(0, 0, ~#sensor_dev_attr_reset_high_low~0.base, 28 + ~#sensor_dev_attr_reset_high_low~0.offset, 8);call write~init~$Pointer$(#funAddr~ibmpex_reset_high_low.base, #funAddr~ibmpex_reset_high_low.offset, ~#sensor_dev_attr_reset_high_low~0.base, 36 + ~#sensor_dev_attr_reset_high_low~0.offset, 8);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 44 + ~#sensor_dev_attr_reset_high_low~0.offset, 4);~LDV_IN_INTERRUPT~0 := 0;~ldv_count_1~0 := 0;~ldv_count_2~0 := 0;~ldv_call_dev_attr_of_sensor_device_attribute~0 := 0;~ldv_call_dev_attr_of_sensor_device_attribute_2~0 := 0; {6610#(and (= ~ldv_count_1~0 0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,826 INFO L290 TraceCheckUtils]: 1: Hoare triple {6610#(and (= ~ldv_count_1~0 0) (= ~ldv_count_2~0 0))} assume { :end_inline_ULTIMATE.init } true;assume { :begin_inline_main } true;havoc main_#res#1;havoc main_#t~ret236#1, main_#t~nondet237#1, main_#t~switch238#1, main_#t~nondet239#1, main_~var_ibmpex_register_bmc_17_p0~0#1, main_~var_group1~0#1.base, main_~var_group1~0#1.offset, main_~var_ibmpex_bmc_gone_19_p0~0#1, main_~#var_group2~0#1.base, main_~#var_group2~0#1.offset, main_~#var_ibmpex_msg_handler_20_p1~0#1.base, main_~#var_ibmpex_msg_handler_20_p1~0#1.offset, main_~tmp~17#1, main_~tmp___0~4#1, main_~tmp___1~2#1;havoc main_~var_ibmpex_register_bmc_17_p0~0#1;havoc main_~var_group1~0#1.base, main_~var_group1~0#1.offset;havoc main_~var_ibmpex_bmc_gone_19_p0~0#1;call main_~#var_group2~0#1.base, main_~#var_group2~0#1.offset := #Ultimate.allocOnStack(374);call main_~#var_ibmpex_msg_handler_20_p1~0#1.base, main_~#var_ibmpex_msg_handler_20_p1~0#1.offset := #Ultimate.allocOnStack(915);havoc main_~tmp~17#1;havoc main_~tmp___0~4#1;havoc main_~tmp___1~2#1;~LDV_IN_INTERRUPT~0 := 1;assume { :begin_inline_ldv_initialize } true;~ldv_count_1~0 := 1 + ~ldv_count_1~0;~ldv_count_1~0 := 1 + ~ldv_count_1~0;~ldv_count_1~0 := 1 + ~ldv_count_1~0;~ldv_count_1~0 := 1 + ~ldv_count_1~0;~ldv_count_1~0 := 1 + ~ldv_count_1~0;~ldv_count_1~0 := 1 + ~ldv_count_1~0; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,826 INFO L290 TraceCheckUtils]: 2: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} assume { :end_inline_ldv_initialize } true; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,826 INFO L272 TraceCheckUtils]: 3: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} call ldv_handler_precall(); {6608#true} is VALID [2022-02-20 21:35:30,826 INFO L290 TraceCheckUtils]: 4: Hoare triple {6608#true} assume true; {6608#true} is VALID [2022-02-20 21:35:30,827 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {6608#true} {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} #612#return; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,827 INFO L290 TraceCheckUtils]: 6: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} assume { :begin_inline_ibmpex_init } true;havoc ibmpex_init_#res#1;havoc ibmpex_init_#t~ret231#1, ibmpex_init_~tmp~16#1;havoc ibmpex_init_~tmp~16#1;assume { :begin_inline_ipmi_smi_watcher_register } true;ipmi_smi_watcher_register_#in~arg0#1.base, ipmi_smi_watcher_register_#in~arg0#1.offset := ~#driver_data~0.base, 16 + ~#driver_data~0.offset;havoc ipmi_smi_watcher_register_#res#1;havoc ipmi_smi_watcher_register_#t~nondet252#1, ipmi_smi_watcher_register_~arg0#1.base, ipmi_smi_watcher_register_~arg0#1.offset;ipmi_smi_watcher_register_~arg0#1.base, ipmi_smi_watcher_register_~arg0#1.offset := ipmi_smi_watcher_register_#in~arg0#1.base, ipmi_smi_watcher_register_#in~arg0#1.offset;assume -2147483648 <= ipmi_smi_watcher_register_#t~nondet252#1 && ipmi_smi_watcher_register_#t~nondet252#1 <= 2147483647;ipmi_smi_watcher_register_#res#1 := ipmi_smi_watcher_register_#t~nondet252#1;havoc ipmi_smi_watcher_register_#t~nondet252#1; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,828 INFO L290 TraceCheckUtils]: 7: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} ibmpex_init_#t~ret231#1 := ipmi_smi_watcher_register_#res#1;assume { :end_inline_ipmi_smi_watcher_register } true;assume -2147483648 <= ibmpex_init_#t~ret231#1 && ibmpex_init_#t~ret231#1 <= 2147483647;ibmpex_init_~tmp~16#1 := ibmpex_init_#t~ret231#1;havoc ibmpex_init_#t~ret231#1;ibmpex_init_#res#1 := ibmpex_init_~tmp~16#1; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,828 INFO L290 TraceCheckUtils]: 8: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} main_#t~ret236#1 := ibmpex_init_#res#1;assume { :end_inline_ibmpex_init } true;assume -2147483648 <= main_#t~ret236#1 && main_#t~ret236#1 <= 2147483647;main_~tmp~17#1 := main_#t~ret236#1;havoc main_#t~ret236#1; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,829 INFO L290 TraceCheckUtils]: 9: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} assume !(0 != main_~tmp~17#1); {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,829 INFO L290 TraceCheckUtils]: 10: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} assume -2147483648 <= main_#t~nondet239#1 && main_#t~nondet239#1 <= 2147483647;main_~tmp___1~2#1 := main_#t~nondet239#1;havoc main_#t~nondet239#1; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,830 INFO L290 TraceCheckUtils]: 11: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} assume 0 != main_~tmp___1~2#1; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,830 INFO L290 TraceCheckUtils]: 12: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} assume -2147483648 <= main_#t~nondet237#1 && main_#t~nondet237#1 <= 2147483647;main_~tmp___0~4#1 := main_#t~nondet237#1;havoc main_#t~nondet237#1;main_#t~switch238#1 := 0 == main_~tmp___0~4#1; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,831 INFO L290 TraceCheckUtils]: 13: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} assume main_#t~switch238#1; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,831 INFO L272 TraceCheckUtils]: 14: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} call ldv_handler_precall(); {6608#true} is VALID [2022-02-20 21:35:30,831 INFO L290 TraceCheckUtils]: 15: Hoare triple {6608#true} assume true; {6608#true} is VALID [2022-02-20 21:35:30,831 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {6608#true} {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} #614#return; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,832 INFO L290 TraceCheckUtils]: 17: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} assume { :begin_inline_ibmpex_register_bmc } true;ibmpex_register_bmc_#in~iface#1, ibmpex_register_bmc_#in~dev#1.base, ibmpex_register_bmc_#in~dev#1.offset := main_~var_ibmpex_register_bmc_17_p0~0#1, main_~var_group1~0#1.base, main_~var_group1~0#1.offset;havoc ibmpex_register_bmc_#t~ret178#1.base, ibmpex_register_bmc_#t~ret178#1.offset, ibmpex_register_bmc_#t~nondet179#1, ibmpex_register_bmc_#t~mem180#1, ibmpex_register_bmc_#t~ret181#1, ibmpex_register_bmc_#t~nondet182#1, ibmpex_register_bmc_#t~mem183#1, ibmpex_register_bmc_#t~ret184#1, ibmpex_register_bmc_#t~mem185#1.base, ibmpex_register_bmc_#t~mem185#1.offset, ibmpex_register_bmc_#t~ret186#1.base, ibmpex_register_bmc_#t~ret186#1.offset, ibmpex_register_bmc_#t~mem187#1.base, ibmpex_register_bmc_#t~mem187#1.offset, ibmpex_register_bmc_#t~ret188#1, ibmpex_register_bmc_#t~nondet189#1, ibmpex_register_bmc_#t~mem190#1.base, ibmpex_register_bmc_#t~mem190#1.offset, ibmpex_register_bmc_#t~mem191#1, ibmpex_register_bmc_#t~ret192#1, ibmpex_register_bmc_#t~nondet193#1, ibmpex_register_bmc_#t~mem194#1.base, ibmpex_register_bmc_#t~mem194#1.offset, ibmpex_register_bmc_#t~mem195#1.base, ibmpex_register_bmc_#t~mem195#1.offset, ibmpex_register_bmc_#t~mem196#1.base, ibmpex_register_bmc_#t~mem196#1.offset, ibmpex_register_bmc_#t~ret197#1, ibmpex_register_bmc_~iface#1, ibmpex_register_bmc_~dev#1.base, ibmpex_register_bmc_~dev#1.offset, ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset, ibmpex_register_bmc_~err~4#1, ibmpex_register_bmc_~tmp~14#1.base, ibmpex_register_bmc_~tmp~14#1.offset, ibmpex_register_bmc_~#__key~1#1.base, ibmpex_register_bmc_~#__key~1#1.offset, ibmpex_register_bmc_~tmp___0~3#1;ibmpex_register_bmc_~iface#1 := ibmpex_register_bmc_#in~iface#1;ibmpex_register_bmc_~dev#1.base, ibmpex_register_bmc_~dev#1.offset := ibmpex_register_bmc_#in~dev#1.base, ibmpex_register_bmc_#in~dev#1.offset;havoc ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset;havoc ibmpex_register_bmc_~err~4#1;havoc ibmpex_register_bmc_~tmp~14#1.base, ibmpex_register_bmc_~tmp~14#1.offset;call ibmpex_register_bmc_~#__key~1#1.base, ibmpex_register_bmc_~#__key~1#1.offset := #Ultimate.allocOnStack(8);havoc ibmpex_register_bmc_~tmp___0~3#1; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,833 INFO L272 TraceCheckUtils]: 18: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} call ibmpex_register_bmc_#t~ret178#1.base, ibmpex_register_bmc_#t~ret178#1.offset := kzalloc(968, 208); {6681#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:30,833 INFO L290 TraceCheckUtils]: 19: Hoare triple {6681#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size;~flags := #in~flags;havoc ~tmp~2.base, ~tmp~2.offset; {6608#true} is VALID [2022-02-20 21:35:30,833 INFO L272 TraceCheckUtils]: 20: Hoare triple {6608#true} call #t~ret40.base, #t~ret40.offset := kmalloc(~size, ~bitwiseOr(~flags, 32768)); {6681#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:30,834 INFO L290 TraceCheckUtils]: 21: Hoare triple {6681#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {6608#true} is VALID [2022-02-20 21:35:30,834 INFO L272 TraceCheckUtils]: 22: Hoare triple {6608#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {6681#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:30,834 INFO L290 TraceCheckUtils]: 23: Hoare triple {6681#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {6608#true} is VALID [2022-02-20 21:35:30,834 INFO L290 TraceCheckUtils]: 24: Hoare triple {6608#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {6608#true} is VALID [2022-02-20 21:35:30,835 INFO L290 TraceCheckUtils]: 25: Hoare triple {6608#true} assume true; {6608#true} is VALID [2022-02-20 21:35:30,835 INFO L284 TraceCheckUtils]: 26: Hoare quadruple {6608#true} {6608#true} #590#return; {6608#true} is VALID [2022-02-20 21:35:30,835 INFO L290 TraceCheckUtils]: 27: Hoare triple {6608#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {6608#true} is VALID [2022-02-20 21:35:30,835 INFO L290 TraceCheckUtils]: 28: Hoare triple {6608#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {6608#true} is VALID [2022-02-20 21:35:30,835 INFO L290 TraceCheckUtils]: 29: Hoare triple {6608#true} assume true; {6608#true} is VALID [2022-02-20 21:35:30,842 INFO L284 TraceCheckUtils]: 30: Hoare quadruple {6608#true} {6608#true} #588#return; {6608#true} is VALID [2022-02-20 21:35:30,843 INFO L290 TraceCheckUtils]: 31: Hoare triple {6608#true} ~tmp~2.base, ~tmp~2.offset := #t~ret40.base, #t~ret40.offset;havoc #t~ret40.base, #t~ret40.offset;#res.base, #res.offset := ~tmp~2.base, ~tmp~2.offset; {6608#true} is VALID [2022-02-20 21:35:30,843 INFO L290 TraceCheckUtils]: 32: Hoare triple {6608#true} assume true; {6608#true} is VALID [2022-02-20 21:35:30,844 INFO L284 TraceCheckUtils]: 33: Hoare quadruple {6608#true} {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} #616#return; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,844 INFO L290 TraceCheckUtils]: 34: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} ibmpex_register_bmc_~tmp~14#1.base, ibmpex_register_bmc_~tmp~14#1.offset := ibmpex_register_bmc_#t~ret178#1.base, ibmpex_register_bmc_#t~ret178#1.offset;havoc ibmpex_register_bmc_#t~ret178#1.base, ibmpex_register_bmc_#t~ret178#1.offset;ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset := ibmpex_register_bmc_~tmp~14#1.base, ibmpex_register_bmc_~tmp~14#1.offset; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,846 INFO L290 TraceCheckUtils]: 35: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} assume !(0 == (ibmpex_register_bmc_~data~2#1.base + ibmpex_register_bmc_~data~2#1.offset) % 18446744073709551616);call write~int(12, ibmpex_register_bmc_~data~2#1.base, 193 + ibmpex_register_bmc_~data~2#1.offset, 4);call write~int(15, ibmpex_register_bmc_~data~2#1.base, 197 + ibmpex_register_bmc_~data~2#1.offset, 2);call write~int(0, ibmpex_register_bmc_~data~2#1.base, 199 + ibmpex_register_bmc_~data~2#1.offset, 1);call write~int(ibmpex_register_bmc_~iface#1, ibmpex_register_bmc_~data~2#1.base, 323 + ibmpex_register_bmc_~data~2#1.offset, 4);call write~$Pointer$(ibmpex_register_bmc_~dev#1.base, ibmpex_register_bmc_~dev#1.offset, ibmpex_register_bmc_~data~2#1.base, 24 + ibmpex_register_bmc_~data~2#1.offset, 8);call ibmpex_register_bmc_#t~mem180#1 := read~int(ibmpex_register_bmc_~data~2#1.base, 323 + ibmpex_register_bmc_~data~2#1.offset, 4);assume { :begin_inline_ipmi_create_user } true;ipmi_create_user_#in~arg0#1, ipmi_create_user_#in~arg1#1.base, ipmi_create_user_#in~arg1#1.offset, ipmi_create_user_#in~arg2#1.base, ipmi_create_user_#in~arg2#1.offset, ipmi_create_user_#in~arg3#1.base, ipmi_create_user_#in~arg3#1.offset := ibmpex_register_bmc_#t~mem180#1, ~#driver_data~0.base, 56 + ~#driver_data~0.offset, ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset, ibmpex_register_bmc_~data~2#1.base, 315 + ibmpex_register_bmc_~data~2#1.offset;havoc ipmi_create_user_#res#1;havoc ipmi_create_user_#t~nondet249#1, ipmi_create_user_~arg0#1, ipmi_create_user_~arg1#1.base, ipmi_create_user_~arg1#1.offset, ipmi_create_user_~arg2#1.base, ipmi_create_user_~arg2#1.offset, ipmi_create_user_~arg3#1.base, ipmi_create_user_~arg3#1.offset;ipmi_create_user_~arg0#1 := ipmi_create_user_#in~arg0#1;ipmi_create_user_~arg1#1.base, ipmi_create_user_~arg1#1.offset := ipmi_create_user_#in~arg1#1.base, ipmi_create_user_#in~arg1#1.offset;ipmi_create_user_~arg2#1.base, ipmi_create_user_~arg2#1.offset := ipmi_create_user_#in~arg2#1.base, ipmi_create_user_#in~arg2#1.offset;ipmi_create_user_~arg3#1.base, ipmi_create_user_~arg3#1.offset := ipmi_create_user_#in~arg3#1.base, ipmi_create_user_#in~arg3#1.offset;assume -2147483648 <= ipmi_create_user_#t~nondet249#1 && ipmi_create_user_#t~nondet249#1 <= 2147483647;ipmi_create_user_#res#1 := ipmi_create_user_#t~nondet249#1;havoc ipmi_create_user_#t~nondet249#1; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,846 INFO L290 TraceCheckUtils]: 36: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} ibmpex_register_bmc_#t~ret181#1 := ipmi_create_user_#res#1;assume { :end_inline_ipmi_create_user } true;assume -2147483648 <= ibmpex_register_bmc_#t~ret181#1 && ibmpex_register_bmc_#t~ret181#1 <= 2147483647;ibmpex_register_bmc_~err~4#1 := ibmpex_register_bmc_#t~ret181#1;havoc ibmpex_register_bmc_#t~mem180#1;havoc ibmpex_register_bmc_#t~ret181#1; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,847 INFO L290 TraceCheckUtils]: 37: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} assume !(ibmpex_register_bmc_~err~4#1 < 0);assume { :begin_inline___mutex_init } true;__mutex_init_#in~arg0#1.base, __mutex_init_#in~arg0#1.offset, __mutex_init_#in~arg1#1.base, __mutex_init_#in~arg1#1.offset, __mutex_init_#in~arg2#1.base, __mutex_init_#in~arg2#1.offset := ibmpex_register_bmc_~data~2#1.base, 32 + ibmpex_register_bmc_~data~2#1.offset, 22, 0, ibmpex_register_bmc_~#__key~1#1.base, ibmpex_register_bmc_~#__key~1#1.offset;havoc __mutex_init_~arg0#1.base, __mutex_init_~arg0#1.offset, __mutex_init_~arg1#1.base, __mutex_init_~arg1#1.offset, __mutex_init_~arg2#1.base, __mutex_init_~arg2#1.offset;__mutex_init_~arg0#1.base, __mutex_init_~arg0#1.offset := __mutex_init_#in~arg0#1.base, __mutex_init_#in~arg0#1.offset;__mutex_init_~arg1#1.base, __mutex_init_~arg1#1.offset := __mutex_init_#in~arg1#1.base, __mutex_init_#in~arg1#1.offset;__mutex_init_~arg2#1.base, __mutex_init_~arg2#1.offset := __mutex_init_#in~arg2#1.base, __mutex_init_#in~arg2#1.offset; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,848 INFO L290 TraceCheckUtils]: 38: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} assume { :end_inline___mutex_init } true;call write~int(0, ibmpex_register_bmc_~data~2#1.base, 611 + ibmpex_register_bmc_~data~2#1.offset, 8);assume { :begin_inline_init_completion } true;init_completion_#in~x#1.base, init_completion_#in~x#1.offset := ibmpex_register_bmc_~data~2#1.base, 231 + ibmpex_register_bmc_~data~2#1.offset;havoc init_completion_~x#1.base, init_completion_~x#1.offset, init_completion_~#__key~0#1.base, init_completion_~#__key~0#1.offset;init_completion_~x#1.base, init_completion_~x#1.offset := init_completion_#in~x#1.base, init_completion_#in~x#1.offset;call init_completion_~#__key~0#1.base, init_completion_~#__key~0#1.offset := #Ultimate.allocOnStack(8);call write~int(0, init_completion_~x#1.base, init_completion_~x#1.offset, 4);assume { :begin_inline___init_waitqueue_head } true;__init_waitqueue_head_#in~arg0#1.base, __init_waitqueue_head_#in~arg0#1.offset, __init_waitqueue_head_#in~arg1#1.base, __init_waitqueue_head_#in~arg1#1.offset := init_completion_~x#1.base, 4 + init_completion_~x#1.offset, init_completion_~#__key~0#1.base, init_completion_~#__key~0#1.offset;havoc __init_waitqueue_head_~arg0#1.base, __init_waitqueue_head_~arg0#1.offset, __init_waitqueue_head_~arg1#1.base, __init_waitqueue_head_~arg1#1.offset;__init_waitqueue_head_~arg0#1.base, __init_waitqueue_head_~arg0#1.offset := __init_waitqueue_head_#in~arg0#1.base, __init_waitqueue_head_#in~arg0#1.offset;__init_waitqueue_head_~arg1#1.base, __init_waitqueue_head_~arg1#1.offset := __init_waitqueue_head_#in~arg1#1.base, __init_waitqueue_head_#in~arg1#1.offset; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,848 INFO L290 TraceCheckUtils]: 39: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} assume { :end_inline___init_waitqueue_head } true;call ULTIMATE.dealloc(init_completion_~#__key~0#1.base, init_completion_~#__key~0#1.offset);havoc init_completion_~#__key~0#1.base, init_completion_~#__key~0#1.offset; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,850 INFO L290 TraceCheckUtils]: 40: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} assume { :end_inline_init_completion } true;call write~int(58, ibmpex_register_bmc_~data~2#1.base, 327 + ibmpex_register_bmc_~data~2#1.offset, 1);call write~int(60, ibmpex_register_bmc_~data~2#1.base, 328 + ibmpex_register_bmc_~data~2#1.offset, 1);call write~$Pointer$(ibmpex_register_bmc_~data~2#1.base, 339 + ibmpex_register_bmc_~data~2#1.offset, ibmpex_register_bmc_~data~2#1.base, 331 + ibmpex_register_bmc_~data~2#1.offset, 8);assume { :begin_inline_ibmpex_ver_check } true;ibmpex_ver_check_#in~data#1.base, ibmpex_ver_check_#in~data#1.offset := ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset;havoc ibmpex_ver_check_#res#1;havoc ibmpex_ver_check_#t~ret71#1, ibmpex_ver_check_#t~mem72#1, ibmpex_ver_check_#t~mem73#1, ibmpex_ver_check_#t~short74#1, ibmpex_ver_check_#t~mem75#1, ibmpex_ver_check_#t~mem76#1, ibmpex_ver_check_#t~ret77#1, ibmpex_ver_check_#t~nondet78#1, ibmpex_ver_check_#t~mem79#1.base, ibmpex_ver_check_#t~mem79#1.offset, ibmpex_ver_check_#t~mem80#1, ibmpex_ver_check_#t~mem81#1, ibmpex_ver_check_#t~mem82#1, ibmpex_ver_check_#t~mem83#1, ibmpex_ver_check_#t~mem84#1, ibmpex_ver_check_~data#1.base, ibmpex_ver_check_~data#1.offset, ibmpex_ver_check_~tmp~4#1;ibmpex_ver_check_~data#1.base, ibmpex_ver_check_~data#1.offset := ibmpex_ver_check_#in~data#1.base, ibmpex_ver_check_#in~data#1.offset;havoc ibmpex_ver_check_~tmp~4#1;call write~int(1, ibmpex_ver_check_~data#1.base, 339 + ibmpex_ver_check_~data#1.offset, 1);call write~int(1, ibmpex_ver_check_~data#1.base, 329 + ibmpex_ver_check_~data#1.offset, 2); {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,851 INFO L272 TraceCheckUtils]: 41: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} call ibmpex_ver_check_#t~ret71#1 := ibmpex_send_message(ibmpex_ver_check_~data#1.base, ibmpex_ver_check_~data#1.offset); {6696#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} is VALID [2022-02-20 21:35:30,851 INFO L290 TraceCheckUtils]: 42: Hoare triple {6696#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;havoc ~err~0#1;assume { :begin_inline_ipmi_validate_addr } true;ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset, ipmi_validate_addr_#in~arg1#1 := ~data#1.base, 193 + ~data#1.offset, 40;havoc ipmi_validate_addr_#res#1;havoc ipmi_validate_addr_#t~nondet254#1, ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset, ipmi_validate_addr_~arg1#1;ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset := ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset;ipmi_validate_addr_~arg1#1 := ipmi_validate_addr_#in~arg1#1;assume -2147483648 <= ipmi_validate_addr_#t~nondet254#1 && ipmi_validate_addr_#t~nondet254#1 <= 2147483647;ipmi_validate_addr_#res#1 := ipmi_validate_addr_#t~nondet254#1;havoc ipmi_validate_addr_#t~nondet254#1; {6608#true} is VALID [2022-02-20 21:35:30,851 INFO L290 TraceCheckUtils]: 43: Hoare triple {6608#true} #t~ret62#1 := ipmi_validate_addr_#res#1;assume { :end_inline_ipmi_validate_addr } true;assume -2147483648 <= #t~ret62#1 && #t~ret62#1 <= 2147483647;~err~0#1 := #t~ret62#1;havoc #t~ret62#1; {6608#true} is VALID [2022-02-20 21:35:30,851 INFO L290 TraceCheckUtils]: 44: Hoare triple {6608#true} assume 0 != ~err~0#1; {6608#true} is VALID [2022-02-20 21:35:30,851 INFO L290 TraceCheckUtils]: 45: Hoare triple {6608#true} havoc #t~nondet69#1;call #t~mem70#1.base, #t~mem70#1.offset := read~$Pointer$(~data#1.base, 24 + ~data#1.offset, 8);havoc #t~mem70#1.base, #t~mem70#1.offset;#res#1 := ~err~0#1; {6608#true} is VALID [2022-02-20 21:35:30,851 INFO L290 TraceCheckUtils]: 46: Hoare triple {6608#true} assume true; {6608#true} is VALID [2022-02-20 21:35:30,852 INFO L284 TraceCheckUtils]: 47: Hoare quadruple {6608#true} {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} #618#return; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,852 INFO L290 TraceCheckUtils]: 48: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} assume -2147483648 <= ibmpex_ver_check_#t~ret71#1 && ibmpex_ver_check_#t~ret71#1 <= 2147483647;havoc ibmpex_ver_check_#t~ret71#1; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,853 INFO L272 TraceCheckUtils]: 49: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} call wait_for_completion(ibmpex_ver_check_~data#1.base, 231 + ibmpex_ver_check_~data#1.offset); {6608#true} is VALID [2022-02-20 21:35:30,853 INFO L290 TraceCheckUtils]: 50: Hoare triple {6608#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset; {6608#true} is VALID [2022-02-20 21:35:30,853 INFO L290 TraceCheckUtils]: 51: Hoare triple {6608#true} assume true; {6608#true} is VALID [2022-02-20 21:35:30,854 INFO L284 TraceCheckUtils]: 52: Hoare quadruple {6608#true} {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} #620#return; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,854 INFO L290 TraceCheckUtils]: 53: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} call ibmpex_ver_check_#t~mem72#1 := read~int(ibmpex_ver_check_~data#1.base, 899 + ibmpex_ver_check_~data#1.offset, 1);ibmpex_ver_check_#t~short74#1 := 0 != ibmpex_ver_check_#t~mem72#1 % 256 % 4294967296; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,855 INFO L290 TraceCheckUtils]: 54: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} assume !ibmpex_ver_check_#t~short74#1;call ibmpex_ver_check_#t~mem73#1 := read~int(ibmpex_ver_check_~data#1.base, 891 + ibmpex_ver_check_~data#1.offset, 8);ibmpex_ver_check_#t~short74#1 := 6 != ibmpex_ver_check_#t~mem73#1 % 18446744073709551616; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,855 INFO L290 TraceCheckUtils]: 55: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} assume !ibmpex_ver_check_#t~short74#1;havoc ibmpex_ver_check_#t~mem72#1;havoc ibmpex_ver_check_#t~mem73#1;havoc ibmpex_ver_check_#t~short74#1;call ibmpex_ver_check_#t~mem75#1 := read~int(ibmpex_ver_check_~data#1.base, 619 + ibmpex_ver_check_~data#1.offset, 1);call write~int(ibmpex_ver_check_#t~mem75#1, ibmpex_ver_check_~data#1.base, 904 + ibmpex_ver_check_~data#1.offset, 1);havoc ibmpex_ver_check_#t~mem75#1;call ibmpex_ver_check_#t~mem76#1 := read~int(ibmpex_ver_check_~data#1.base, 620 + ibmpex_ver_check_~data#1.offset, 1);call write~int(ibmpex_ver_check_#t~mem76#1, ibmpex_ver_check_~data#1.base, 905 + ibmpex_ver_check_~data#1.offset, 1);havoc ibmpex_ver_check_#t~mem76#1; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,856 INFO L272 TraceCheckUtils]: 56: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} call ibmpex_ver_check_#t~ret77#1 := extract_value(ibmpex_ver_check_~data#1.base, 619 + ibmpex_ver_check_~data#1.offset, 2); {6608#true} is VALID [2022-02-20 21:35:30,856 INFO L290 TraceCheckUtils]: 57: Hoare triple {6608#true} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;~offset#1 := #in~offset#1;havoc ~tmp~3#1;assume { :begin_inline___be16_to_cpup } true;__be16_to_cpup_#in~p#1.base, __be16_to_cpup_#in~p#1.offset := ~data#1.base, ~data#1.offset + 2 * (if ~offset#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then ~offset#1 % 18446744073709551616 % 18446744073709551616 else ~offset#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616);havoc __be16_to_cpup_#res#1;havoc __be16_to_cpup_#t~ret3#1, __be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset, __be16_to_cpup_~tmp~1#1;__be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset := __be16_to_cpup_#in~p#1.base, __be16_to_cpup_#in~p#1.offset;havoc __be16_to_cpup_~tmp~1#1;assume { :begin_inline___swab16p } true;__swab16p_#in~p#1.base, __swab16p_#in~p#1.offset := __be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset;havoc __swab16p_#res#1;havoc __swab16p_#t~mem1#1, __swab16p_#t~ret2#1, __swab16p_~p#1.base, __swab16p_~p#1.offset, __swab16p_~tmp~0#1;__swab16p_~p#1.base, __swab16p_~p#1.offset := __swab16p_#in~p#1.base, __swab16p_#in~p#1.offset;havoc __swab16p_~tmp~0#1;call __swab16p_#t~mem1#1 := read~int(__swab16p_~p#1.base, __swab16p_~p#1.offset, 2);assume { :begin_inline___fswab16 } true;__fswab16_#in~val#1 := __swab16p_#t~mem1#1 % 65536;havoc __fswab16_#res#1;havoc __fswab16_~val#1;__fswab16_~val#1 := __fswab16_#in~val#1;__fswab16_#res#1 := (if (1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) || 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536)) && 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) then (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) else (if 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) && (1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) || 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536)) then (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) else (if (1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) && (1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) || 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536))) || ((1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) || 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536)) && 1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536)) then 1 else ~bitwiseOr((if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536), (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536))))); {6608#true} is VALID [2022-02-20 21:35:30,856 INFO L290 TraceCheckUtils]: 58: Hoare triple {6608#true} __swab16p_#t~ret2#1 := __fswab16_#res#1;assume { :end_inline___fswab16 } true;__swab16p_~tmp~0#1 := __swab16p_#t~ret2#1;havoc __swab16p_#t~mem1#1;havoc __swab16p_#t~ret2#1;__swab16p_#res#1 := __swab16p_~tmp~0#1; {6608#true} is VALID [2022-02-20 21:35:30,856 INFO L290 TraceCheckUtils]: 59: Hoare triple {6608#true} __be16_to_cpup_#t~ret3#1 := __swab16p_#res#1;assume { :end_inline___swab16p } true;__be16_to_cpup_~tmp~1#1 := __be16_to_cpup_#t~ret3#1;havoc __be16_to_cpup_#t~ret3#1;__be16_to_cpup_#res#1 := __be16_to_cpup_~tmp~1#1; {6608#true} is VALID [2022-02-20 21:35:30,856 INFO L290 TraceCheckUtils]: 60: Hoare triple {6608#true} #t~ret61#1 := __be16_to_cpup_#res#1;assume { :end_inline___be16_to_cpup } true;~tmp~3#1 := #t~ret61#1;havoc #t~ret61#1;#res#1 := ~tmp~3#1; {6608#true} is VALID [2022-02-20 21:35:30,856 INFO L290 TraceCheckUtils]: 61: Hoare triple {6608#true} assume true; {6608#true} is VALID [2022-02-20 21:35:30,857 INFO L284 TraceCheckUtils]: 62: Hoare quadruple {6608#true} {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} #622#return; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,858 INFO L290 TraceCheckUtils]: 63: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} ibmpex_ver_check_~tmp~4#1 := ibmpex_ver_check_#t~ret77#1;havoc ibmpex_ver_check_#t~ret77#1;havoc ibmpex_ver_check_#t~nondet78#1;call ibmpex_ver_check_#t~mem79#1.base, ibmpex_ver_check_#t~mem79#1.offset := read~$Pointer$(ibmpex_ver_check_~data#1.base, 24 + ibmpex_ver_check_~data#1.offset, 8);call ibmpex_ver_check_#t~mem80#1 := read~int(ibmpex_ver_check_~data#1.base, 904 + ibmpex_ver_check_~data#1.offset, 1);call ibmpex_ver_check_#t~mem81#1 := read~int(ibmpex_ver_check_~data#1.base, 905 + ibmpex_ver_check_~data#1.offset, 1);call ibmpex_ver_check_#t~mem82#1 := read~int(ibmpex_ver_check_~data#1.base, 623 + ibmpex_ver_check_~data#1.offset, 1);call ibmpex_ver_check_#t~mem83#1 := read~int(ibmpex_ver_check_~data#1.base, 624 + ibmpex_ver_check_~data#1.offset, 1);call ibmpex_ver_check_#t~mem84#1 := read~int(ibmpex_ver_check_~data#1.base, 323 + ibmpex_ver_check_~data#1.offset, 4);havoc ibmpex_ver_check_#t~mem79#1.base, ibmpex_ver_check_#t~mem79#1.offset;havoc ibmpex_ver_check_#t~mem80#1;havoc ibmpex_ver_check_#t~mem81#1;havoc ibmpex_ver_check_#t~mem82#1;havoc ibmpex_ver_check_#t~mem83#1;havoc ibmpex_ver_check_#t~mem84#1;ibmpex_ver_check_#res#1 := 0; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,858 INFO L290 TraceCheckUtils]: 64: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} ibmpex_register_bmc_#t~ret184#1 := ibmpex_ver_check_#res#1;assume { :end_inline_ibmpex_ver_check } true;assume -2147483648 <= ibmpex_register_bmc_#t~ret184#1 && ibmpex_register_bmc_#t~ret184#1 <= 2147483647;ibmpex_register_bmc_~err~4#1 := ibmpex_register_bmc_#t~ret184#1;havoc ibmpex_register_bmc_#t~ret184#1; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,859 INFO L290 TraceCheckUtils]: 65: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} assume !(0 != ibmpex_register_bmc_~err~4#1);call ibmpex_register_bmc_#t~mem185#1.base, ibmpex_register_bmc_#t~mem185#1.offset := read~$Pointer$(ibmpex_register_bmc_~data~2#1.base, 24 + ibmpex_register_bmc_~data~2#1.offset, 8);assume { :begin_inline_hwmon_device_register } true;hwmon_device_register_#in~arg0#1.base, hwmon_device_register_#in~arg0#1.offset := ibmpex_register_bmc_#t~mem185#1.base, ibmpex_register_bmc_#t~mem185#1.offset;havoc hwmon_device_register_#res#1.base, hwmon_device_register_#res#1.offset;havoc hwmon_device_register_#t~ret248#1.base, hwmon_device_register_#t~ret248#1.offset, hwmon_device_register_~arg0#1.base, hwmon_device_register_~arg0#1.offset;hwmon_device_register_~arg0#1.base, hwmon_device_register_~arg0#1.offset := hwmon_device_register_#in~arg0#1.base, hwmon_device_register_#in~arg0#1.offset; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,859 INFO L272 TraceCheckUtils]: 66: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} call hwmon_device_register_#t~ret248#1.base, hwmon_device_register_#t~ret248#1.offset := ldv_malloc(1035); {6681#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:30,860 INFO L290 TraceCheckUtils]: 67: Hoare triple {6681#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {6608#true} is VALID [2022-02-20 21:35:30,860 INFO L290 TraceCheckUtils]: 68: Hoare triple {6608#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {6608#true} is VALID [2022-02-20 21:35:30,860 INFO L290 TraceCheckUtils]: 69: Hoare triple {6608#true} assume true; {6608#true} is VALID [2022-02-20 21:35:30,861 INFO L284 TraceCheckUtils]: 70: Hoare quadruple {6608#true} {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} #624#return; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,861 INFO L290 TraceCheckUtils]: 71: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} hwmon_device_register_#res#1.base, hwmon_device_register_#res#1.offset := hwmon_device_register_#t~ret248#1.base, hwmon_device_register_#t~ret248#1.offset;havoc hwmon_device_register_#t~ret248#1.base, hwmon_device_register_#t~ret248#1.offset; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,862 INFO L290 TraceCheckUtils]: 72: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} ibmpex_register_bmc_#t~ret186#1.base, ibmpex_register_bmc_#t~ret186#1.offset := hwmon_device_register_#res#1.base, hwmon_device_register_#res#1.offset;assume { :end_inline_hwmon_device_register } true;call write~$Pointer$(ibmpex_register_bmc_#t~ret186#1.base, ibmpex_register_bmc_#t~ret186#1.offset, ibmpex_register_bmc_~data~2#1.base, 16 + ibmpex_register_bmc_~data~2#1.offset, 8);havoc ibmpex_register_bmc_#t~mem185#1.base, ibmpex_register_bmc_#t~mem185#1.offset;havoc ibmpex_register_bmc_#t~ret186#1.base, ibmpex_register_bmc_#t~ret186#1.offset;call ibmpex_register_bmc_#t~mem187#1.base, ibmpex_register_bmc_#t~mem187#1.offset := read~$Pointer$(ibmpex_register_bmc_~data~2#1.base, 16 + ibmpex_register_bmc_~data~2#1.offset, 8);assume { :begin_inline_IS_ERR } true;IS_ERR_#in~ptr#1.base, IS_ERR_#in~ptr#1.offset := ibmpex_register_bmc_#t~mem187#1.base, ibmpex_register_bmc_#t~mem187#1.offset;havoc IS_ERR_#res#1;havoc IS_ERR_#t~ret240#1, IS_ERR_~ptr#1.base, IS_ERR_~ptr#1.offset, IS_ERR_~tmp~18#1;IS_ERR_~ptr#1.base, IS_ERR_~ptr#1.offset := IS_ERR_#in~ptr#1.base, IS_ERR_#in~ptr#1.offset;havoc IS_ERR_~tmp~18#1; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,862 INFO L272 TraceCheckUtils]: 73: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} call IS_ERR_#t~ret240#1 := ldv_is_err(IS_ERR_~ptr#1.base, IS_ERR_~ptr#1.offset); {6608#true} is VALID [2022-02-20 21:35:30,862 INFO L290 TraceCheckUtils]: 74: Hoare triple {6608#true} ~ptr.base, ~ptr.offset := #in~ptr.base, #in~ptr.offset;#res := (if (~ptr.base + ~ptr.offset) % 18446744073709551616 > 2012 then 1 else 0); {6608#true} is VALID [2022-02-20 21:35:30,862 INFO L290 TraceCheckUtils]: 75: Hoare triple {6608#true} assume true; {6608#true} is VALID [2022-02-20 21:35:30,863 INFO L284 TraceCheckUtils]: 76: Hoare quadruple {6608#true} {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} #626#return; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,863 INFO L290 TraceCheckUtils]: 77: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} assume -9223372036854775808 <= IS_ERR_#t~ret240#1 && IS_ERR_#t~ret240#1 <= 9223372036854775807;IS_ERR_~tmp~18#1 := IS_ERR_#t~ret240#1;havoc IS_ERR_#t~ret240#1;IS_ERR_#res#1 := IS_ERR_~tmp~18#1; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,864 INFO L290 TraceCheckUtils]: 78: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} ibmpex_register_bmc_#t~ret188#1 := IS_ERR_#res#1;assume { :end_inline_IS_ERR } true;assume -9223372036854775808 <= ibmpex_register_bmc_#t~ret188#1 && ibmpex_register_bmc_#t~ret188#1 <= 9223372036854775807;ibmpex_register_bmc_~tmp___0~3#1 := ibmpex_register_bmc_#t~ret188#1;havoc ibmpex_register_bmc_#t~mem187#1.base, ibmpex_register_bmc_#t~mem187#1.offset;havoc ibmpex_register_bmc_#t~ret188#1; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,864 INFO L290 TraceCheckUtils]: 79: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} assume !(0 != ibmpex_register_bmc_~tmp___0~3#1); {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,864 INFO L272 TraceCheckUtils]: 80: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} call dev_set_drvdata(ibmpex_register_bmc_~dev#1.base, ibmpex_register_bmc_~dev#1.offset, ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset); {6608#true} is VALID [2022-02-20 21:35:30,865 INFO L290 TraceCheckUtils]: 81: Hoare triple {6608#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset;~arg1.base, ~arg1.offset := #in~arg1.base, #in~arg1.offset; {6608#true} is VALID [2022-02-20 21:35:30,865 INFO L290 TraceCheckUtils]: 82: Hoare triple {6608#true} assume true; {6608#true} is VALID [2022-02-20 21:35:30,866 INFO L284 TraceCheckUtils]: 83: Hoare quadruple {6608#true} {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} #628#return; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,866 INFO L290 TraceCheckUtils]: 84: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} assume { :begin_inline_list_add_tail } true;list_add_tail_#in~new#1.base, list_add_tail_#in~new#1.offset, list_add_tail_#in~head#1.base, list_add_tail_#in~head#1.offset := ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset, ~#driver_data~0.base, ~#driver_data~0.offset;havoc list_add_tail_#t~mem12#1.base, list_add_tail_#t~mem12#1.offset, list_add_tail_~new#1.base, list_add_tail_~new#1.offset, list_add_tail_~head#1.base, list_add_tail_~head#1.offset;list_add_tail_~new#1.base, list_add_tail_~new#1.offset := list_add_tail_#in~new#1.base, list_add_tail_#in~new#1.offset;list_add_tail_~head#1.base, list_add_tail_~head#1.offset := list_add_tail_#in~head#1.base, list_add_tail_#in~head#1.offset;call list_add_tail_#t~mem12#1.base, list_add_tail_#t~mem12#1.offset := read~$Pointer$(list_add_tail_~head#1.base, 8 + list_add_tail_~head#1.offset, 8);assume { :begin_inline___list_add } true;__list_add_#in~arg0#1.base, __list_add_#in~arg0#1.offset, __list_add_#in~arg1#1.base, __list_add_#in~arg1#1.offset, __list_add_#in~arg2#1.base, __list_add_#in~arg2#1.offset := list_add_tail_~new#1.base, list_add_tail_~new#1.offset, list_add_tail_#t~mem12#1.base, list_add_tail_#t~mem12#1.offset, list_add_tail_~head#1.base, list_add_tail_~head#1.offset;havoc __list_add_~arg0#1.base, __list_add_~arg0#1.offset, __list_add_~arg1#1.base, __list_add_~arg1#1.offset, __list_add_~arg2#1.base, __list_add_~arg2#1.offset;__list_add_~arg0#1.base, __list_add_~arg0#1.offset := __list_add_#in~arg0#1.base, __list_add_#in~arg0#1.offset;__list_add_~arg1#1.base, __list_add_~arg1#1.offset := __list_add_#in~arg1#1.base, __list_add_#in~arg1#1.offset;__list_add_~arg2#1.base, __list_add_~arg2#1.offset := __list_add_#in~arg2#1.base, __list_add_#in~arg2#1.offset; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,867 INFO L290 TraceCheckUtils]: 85: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} assume { :end_inline___list_add } true;havoc list_add_tail_#t~mem12#1.base, list_add_tail_#t~mem12#1.offset; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,868 INFO L290 TraceCheckUtils]: 86: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} assume { :end_inline_list_add_tail } true;assume { :begin_inline_ibmpex_find_sensors } true;ibmpex_find_sensors_#in~data#1.base, ibmpex_find_sensors_#in~data#1.offset := ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset;havoc ibmpex_find_sensors_#res#1;havoc ibmpex_find_sensors_#t~ret148#1, ibmpex_find_sensors_#t~mem149#1, ibmpex_find_sensors_#t~ret150#1.base, ibmpex_find_sensors_#t~ret150#1.offset, ibmpex_find_sensors_#t~mem151#1.base, ibmpex_find_sensors_#t~mem151#1.offset, ibmpex_find_sensors_#t~ret152#1, ibmpex_find_sensors_#t~mem153#1, ibmpex_find_sensors_#t~ret154#1, ibmpex_find_sensors_#t~mem155#1.base, ibmpex_find_sensors_#t~mem155#1.offset, ibmpex_find_sensors_#t~mem156#1, ibmpex_find_sensors_#t~ret157#1, ibmpex_find_sensors_#t~mem158#1, ibmpex_find_sensors_#t~ret159#1, ibmpex_find_sensors_#t~mem160#1.base, ibmpex_find_sensors_#t~mem160#1.offset, ibmpex_find_sensors_#t~mem161#1.base, ibmpex_find_sensors_#t~mem161#1.offset, ibmpex_find_sensors_#t~ret162#1, ibmpex_find_sensors_#t~mem163#1, ibmpex_find_sensors_#t~mem164#1.base, ibmpex_find_sensors_#t~mem164#1.offset, ibmpex_find_sensors_#t~ret165#1, ibmpex_find_sensors_#t~mem166#1.base, ibmpex_find_sensors_#t~mem166#1.offset, ibmpex_find_sensors_#t~ret167#1, ibmpex_find_sensors_#t~mem168#1.base, ibmpex_find_sensors_#t~mem168#1.offset, ibmpex_find_sensors_#t~mem169#1.base, ibmpex_find_sensors_#t~mem169#1.offset, ibmpex_find_sensors_#t~mem170#1.base, ibmpex_find_sensors_#t~mem170#1.offset, ibmpex_find_sensors_#t~mem171#1.base, ibmpex_find_sensors_#t~mem171#1.offset, ibmpex_find_sensors_#t~mem172#1.base, ibmpex_find_sensors_#t~mem172#1.offset, ibmpex_find_sensors_#t~mem173#1.base, ibmpex_find_sensors_#t~mem173#1.offset, ibmpex_find_sensors_#t~mem174#1.base, ibmpex_find_sensors_#t~mem174#1.offset, ibmpex_find_sensors_#t~mem175#1.base, ibmpex_find_sensors_#t~mem175#1.offset, ibmpex_find_sensors_#t~mem176#1, ibmpex_find_sensors_#t~mem177#1.base, ibmpex_find_sensors_#t~mem177#1.offset, ibmpex_find_sensors_~data#1.base, ibmpex_find_sensors_~data#1.offset, ibmpex_find_sensors_~i~2#1, ibmpex_find_sensors_~j~0#1, ibmpex_find_sensors_~err~3#1, ibmpex_find_sensors_~sensor_type~0#1, ibmpex_find_sensors_~sensor_counter~0#1, ibmpex_find_sensors_~num_power~0#1, ibmpex_find_sensors_~num_temp~0#1, ibmpex_find_sensors_~tmp~13#1.base, ibmpex_find_sensors_~tmp~13#1.offset, ibmpex_find_sensors_~tmp___0~2#1, ibmpex_find_sensors_~tmp___1~1#1;ibmpex_find_sensors_~data#1.base, ibmpex_find_sensors_~data#1.offset := ibmpex_find_sensors_#in~data#1.base, ibmpex_find_sensors_#in~data#1.offset;havoc ibmpex_find_sensors_~i~2#1;havoc ibmpex_find_sensors_~j~0#1;havoc ibmpex_find_sensors_~err~3#1;havoc ibmpex_find_sensors_~sensor_type~0#1;havoc ibmpex_find_sensors_~sensor_counter~0#1;havoc ibmpex_find_sensors_~num_power~0#1;havoc ibmpex_find_sensors_~num_temp~0#1;havoc ibmpex_find_sensors_~tmp~13#1.base, ibmpex_find_sensors_~tmp~13#1.offset;havoc ibmpex_find_sensors_~tmp___0~2#1;havoc ibmpex_find_sensors_~tmp___1~1#1;ibmpex_find_sensors_~num_power~0#1 := 0;ibmpex_find_sensors_~num_temp~0#1 := 0;assume { :begin_inline_ibmpex_query_sensor_count } true;ibmpex_query_sensor_count_#in~data#1.base, ibmpex_query_sensor_count_#in~data#1.offset := ibmpex_find_sensors_~data#1.base, ibmpex_find_sensors_~data#1.offset;havoc ibmpex_query_sensor_count_#res#1;havoc ibmpex_query_sensor_count_#t~ret85#1, ibmpex_query_sensor_count_#t~mem86#1, ibmpex_query_sensor_count_#t~mem87#1, ibmpex_query_sensor_count_#t~short88#1, ibmpex_query_sensor_count_#t~mem89#1, ibmpex_query_sensor_count_~data#1.base, ibmpex_query_sensor_count_~data#1.offset;ibmpex_query_sensor_count_~data#1.base, ibmpex_query_sensor_count_~data#1.offset := ibmpex_query_sensor_count_#in~data#1.base, ibmpex_query_sensor_count_#in~data#1.offset;call write~int(2, ibmpex_query_sensor_count_~data#1.base, 339 + ibmpex_query_sensor_count_~data#1.offset, 1);call write~int(1, ibmpex_query_sensor_count_~data#1.base, 329 + ibmpex_query_sensor_count_~data#1.offset, 2); {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,869 INFO L272 TraceCheckUtils]: 87: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} call ibmpex_query_sensor_count_#t~ret85#1 := ibmpex_send_message(ibmpex_query_sensor_count_~data#1.base, ibmpex_query_sensor_count_~data#1.offset); {6696#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} is VALID [2022-02-20 21:35:30,869 INFO L290 TraceCheckUtils]: 88: Hoare triple {6696#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;havoc ~err~0#1;assume { :begin_inline_ipmi_validate_addr } true;ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset, ipmi_validate_addr_#in~arg1#1 := ~data#1.base, 193 + ~data#1.offset, 40;havoc ipmi_validate_addr_#res#1;havoc ipmi_validate_addr_#t~nondet254#1, ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset, ipmi_validate_addr_~arg1#1;ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset := ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset;ipmi_validate_addr_~arg1#1 := ipmi_validate_addr_#in~arg1#1;assume -2147483648 <= ipmi_validate_addr_#t~nondet254#1 && ipmi_validate_addr_#t~nondet254#1 <= 2147483647;ipmi_validate_addr_#res#1 := ipmi_validate_addr_#t~nondet254#1;havoc ipmi_validate_addr_#t~nondet254#1; {6608#true} is VALID [2022-02-20 21:35:30,869 INFO L290 TraceCheckUtils]: 89: Hoare triple {6608#true} #t~ret62#1 := ipmi_validate_addr_#res#1;assume { :end_inline_ipmi_validate_addr } true;assume -2147483648 <= #t~ret62#1 && #t~ret62#1 <= 2147483647;~err~0#1 := #t~ret62#1;havoc #t~ret62#1; {6608#true} is VALID [2022-02-20 21:35:30,869 INFO L290 TraceCheckUtils]: 90: Hoare triple {6608#true} assume 0 != ~err~0#1; {6608#true} is VALID [2022-02-20 21:35:30,869 INFO L290 TraceCheckUtils]: 91: Hoare triple {6608#true} havoc #t~nondet69#1;call #t~mem70#1.base, #t~mem70#1.offset := read~$Pointer$(~data#1.base, 24 + ~data#1.offset, 8);havoc #t~mem70#1.base, #t~mem70#1.offset;#res#1 := ~err~0#1; {6608#true} is VALID [2022-02-20 21:35:30,869 INFO L290 TraceCheckUtils]: 92: Hoare triple {6608#true} assume true; {6608#true} is VALID [2022-02-20 21:35:30,870 INFO L284 TraceCheckUtils]: 93: Hoare quadruple {6608#true} {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} #630#return; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,871 INFO L290 TraceCheckUtils]: 94: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} assume -2147483648 <= ibmpex_query_sensor_count_#t~ret85#1 && ibmpex_query_sensor_count_#t~ret85#1 <= 2147483647;havoc ibmpex_query_sensor_count_#t~ret85#1; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,871 INFO L272 TraceCheckUtils]: 95: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} call wait_for_completion(ibmpex_query_sensor_count_~data#1.base, 231 + ibmpex_query_sensor_count_~data#1.offset); {6608#true} is VALID [2022-02-20 21:35:30,871 INFO L290 TraceCheckUtils]: 96: Hoare triple {6608#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset; {6608#true} is VALID [2022-02-20 21:35:30,871 INFO L290 TraceCheckUtils]: 97: Hoare triple {6608#true} assume true; {6608#true} is VALID [2022-02-20 21:35:30,872 INFO L284 TraceCheckUtils]: 98: Hoare quadruple {6608#true} {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} #632#return; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,872 INFO L290 TraceCheckUtils]: 99: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} call ibmpex_query_sensor_count_#t~mem86#1 := read~int(ibmpex_query_sensor_count_~data#1.base, 899 + ibmpex_query_sensor_count_~data#1.offset, 1);ibmpex_query_sensor_count_#t~short88#1 := 0 != ibmpex_query_sensor_count_#t~mem86#1 % 256 % 4294967296; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,873 INFO L290 TraceCheckUtils]: 100: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} assume !ibmpex_query_sensor_count_#t~short88#1;call ibmpex_query_sensor_count_#t~mem87#1 := read~int(ibmpex_query_sensor_count_~data#1.base, 891 + ibmpex_query_sensor_count_~data#1.offset, 8);ibmpex_query_sensor_count_#t~short88#1 := 1 != ibmpex_query_sensor_count_#t~mem87#1 % 18446744073709551616; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,873 INFO L290 TraceCheckUtils]: 101: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} assume !ibmpex_query_sensor_count_#t~short88#1;havoc ibmpex_query_sensor_count_#t~mem86#1;havoc ibmpex_query_sensor_count_#t~mem87#1;havoc ibmpex_query_sensor_count_#t~short88#1;call ibmpex_query_sensor_count_#t~mem89#1 := read~int(ibmpex_query_sensor_count_~data#1.base, 619 + ibmpex_query_sensor_count_~data#1.offset, 1);ibmpex_query_sensor_count_#res#1 := ibmpex_query_sensor_count_#t~mem89#1 % 256;havoc ibmpex_query_sensor_count_#t~mem89#1; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,874 INFO L290 TraceCheckUtils]: 102: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} ibmpex_find_sensors_#t~ret148#1 := ibmpex_query_sensor_count_#res#1;assume { :end_inline_ibmpex_query_sensor_count } true;assume -2147483648 <= ibmpex_find_sensors_#t~ret148#1 && ibmpex_find_sensors_#t~ret148#1 <= 2147483647;ibmpex_find_sensors_~err~3#1 := ibmpex_find_sensors_#t~ret148#1;havoc ibmpex_find_sensors_#t~ret148#1; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,874 INFO L290 TraceCheckUtils]: 103: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} assume !(ibmpex_find_sensors_~err~3#1 <= 0);call write~int(ibmpex_find_sensors_~err~3#1, ibmpex_find_sensors_~data#1.base, 906 + ibmpex_find_sensors_~data#1.offset, 1);call ibmpex_find_sensors_#t~mem149#1 := read~int(ibmpex_find_sensors_~data#1.base, 906 + ibmpex_find_sensors_~data#1.offset, 1); {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,875 INFO L272 TraceCheckUtils]: 104: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} call ibmpex_find_sensors_#t~ret150#1.base, ibmpex_find_sensors_#t~ret150#1.offset := kzalloc(184 * (ibmpex_find_sensors_#t~mem149#1 % 256), 208); {6681#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:30,875 INFO L290 TraceCheckUtils]: 105: Hoare triple {6681#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size;~flags := #in~flags;havoc ~tmp~2.base, ~tmp~2.offset; {6608#true} is VALID [2022-02-20 21:35:30,876 INFO L272 TraceCheckUtils]: 106: Hoare triple {6608#true} call #t~ret40.base, #t~ret40.offset := kmalloc(~size, ~bitwiseOr(~flags, 32768)); {6681#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:30,876 INFO L290 TraceCheckUtils]: 107: Hoare triple {6681#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {6608#true} is VALID [2022-02-20 21:35:30,877 INFO L272 TraceCheckUtils]: 108: Hoare triple {6608#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {6681#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:30,877 INFO L290 TraceCheckUtils]: 109: Hoare triple {6681#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {6608#true} is VALID [2022-02-20 21:35:30,877 INFO L290 TraceCheckUtils]: 110: Hoare triple {6608#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {6608#true} is VALID [2022-02-20 21:35:30,877 INFO L290 TraceCheckUtils]: 111: Hoare triple {6608#true} assume true; {6608#true} is VALID [2022-02-20 21:35:30,877 INFO L284 TraceCheckUtils]: 112: Hoare quadruple {6608#true} {6608#true} #590#return; {6608#true} is VALID [2022-02-20 21:35:30,877 INFO L290 TraceCheckUtils]: 113: Hoare triple {6608#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {6608#true} is VALID [2022-02-20 21:35:30,878 INFO L290 TraceCheckUtils]: 114: Hoare triple {6608#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {6608#true} is VALID [2022-02-20 21:35:30,878 INFO L290 TraceCheckUtils]: 115: Hoare triple {6608#true} assume true; {6608#true} is VALID [2022-02-20 21:35:30,878 INFO L284 TraceCheckUtils]: 116: Hoare quadruple {6608#true} {6608#true} #588#return; {6608#true} is VALID [2022-02-20 21:35:30,878 INFO L290 TraceCheckUtils]: 117: Hoare triple {6608#true} ~tmp~2.base, ~tmp~2.offset := #t~ret40.base, #t~ret40.offset;havoc #t~ret40.base, #t~ret40.offset;#res.base, #res.offset := ~tmp~2.base, ~tmp~2.offset; {6608#true} is VALID [2022-02-20 21:35:30,878 INFO L290 TraceCheckUtils]: 118: Hoare triple {6608#true} assume true; {6608#true} is VALID [2022-02-20 21:35:30,879 INFO L284 TraceCheckUtils]: 119: Hoare quadruple {6608#true} {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} #634#return; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,880 INFO L290 TraceCheckUtils]: 120: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} ibmpex_find_sensors_~tmp~13#1.base, ibmpex_find_sensors_~tmp~13#1.offset := ibmpex_find_sensors_#t~ret150#1.base, ibmpex_find_sensors_#t~ret150#1.offset;havoc ibmpex_find_sensors_#t~mem149#1;havoc ibmpex_find_sensors_#t~ret150#1.base, ibmpex_find_sensors_#t~ret150#1.offset;call write~$Pointer$(ibmpex_find_sensors_~tmp~13#1.base, ibmpex_find_sensors_~tmp~13#1.offset, ibmpex_find_sensors_~data#1.base, 907 + ibmpex_find_sensors_~data#1.offset, 8);call ibmpex_find_sensors_#t~mem151#1.base, ibmpex_find_sensors_#t~mem151#1.offset := read~$Pointer$(ibmpex_find_sensors_~data#1.base, 907 + ibmpex_find_sensors_~data#1.offset, 8); {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,880 INFO L290 TraceCheckUtils]: 121: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} assume !(0 == (ibmpex_find_sensors_#t~mem151#1.base + ibmpex_find_sensors_#t~mem151#1.offset) % 18446744073709551616);havoc ibmpex_find_sensors_#t~mem151#1.base, ibmpex_find_sensors_#t~mem151#1.offset;ibmpex_find_sensors_~i~2#1 := 0; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,881 INFO L290 TraceCheckUtils]: 122: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} call ibmpex_find_sensors_#t~mem163#1 := read~int(ibmpex_find_sensors_~data#1.base, 906 + ibmpex_find_sensors_~data#1.offset, 1); {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,881 INFO L290 TraceCheckUtils]: 123: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} assume !(ibmpex_find_sensors_#t~mem163#1 % 256 > ibmpex_find_sensors_~i~2#1);havoc ibmpex_find_sensors_#t~mem163#1;call ibmpex_find_sensors_#t~mem164#1.base, ibmpex_find_sensors_#t~mem164#1.offset := read~$Pointer$(ibmpex_find_sensors_~data#1.base, 24 + ibmpex_find_sensors_~data#1.offset, 8);assume { :begin_inline_ldv_device_create_file_6 } true;ldv_device_create_file_6_#in~ldv_func_arg1#1.base, ldv_device_create_file_6_#in~ldv_func_arg1#1.offset, ldv_device_create_file_6_#in~ldv_func_arg2#1.base, ldv_device_create_file_6_#in~ldv_func_arg2#1.offset := ibmpex_find_sensors_#t~mem164#1.base, ibmpex_find_sensors_#t~mem164#1.offset, ~#sensor_dev_attr_reset_high_low~0.base, ~#sensor_dev_attr_reset_high_low~0.offset;havoc ldv_device_create_file_6_#res#1;havoc ldv_device_create_file_6_#t~ret242#1, ldv_device_create_file_6_~ldv_func_arg1#1.base, ldv_device_create_file_6_~ldv_func_arg1#1.offset, ldv_device_create_file_6_~ldv_func_arg2#1.base, ldv_device_create_file_6_~ldv_func_arg2#1.offset, ldv_device_create_file_6_~tmp~20#1;ldv_device_create_file_6_~ldv_func_arg1#1.base, ldv_device_create_file_6_~ldv_func_arg1#1.offset := ldv_device_create_file_6_#in~ldv_func_arg1#1.base, ldv_device_create_file_6_#in~ldv_func_arg1#1.offset;ldv_device_create_file_6_~ldv_func_arg2#1.base, ldv_device_create_file_6_~ldv_func_arg2#1.offset := ldv_device_create_file_6_#in~ldv_func_arg2#1.base, ldv_device_create_file_6_#in~ldv_func_arg2#1.offset;havoc ldv_device_create_file_6_~tmp~20#1; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,882 INFO L272 TraceCheckUtils]: 124: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} call ldv_device_create_file_6_#t~ret242#1 := ldv_device_create_file_dev_attr_of_sensor_device_attribute(ldv_device_create_file_6_~ldv_func_arg2#1.base, ldv_device_create_file_6_~ldv_func_arg2#1.offset); {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,882 INFO L290 TraceCheckUtils]: 125: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} ~attr.base, ~attr.offset := #in~attr.base, #in~attr.offset; {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} is VALID [2022-02-20 21:35:30,883 INFO L290 TraceCheckUtils]: 126: Hoare triple {6611#(and (<= 6 ~ldv_count_1~0) (= ~ldv_count_2~0 0))} assume 0 == ~ldv_call_dev_attr_of_sensor_device_attribute~0;~ldv_count_2~0 := 1 + ~ldv_count_2~0;~ldv_call_dev_attr_of_sensor_device_attribute~0 := 1; {6680#(<= (+ 5 ~ldv_count_2~0) ~ldv_count_1~0)} is VALID [2022-02-20 21:35:30,883 INFO L290 TraceCheckUtils]: 127: Hoare triple {6680#(<= (+ 5 ~ldv_count_2~0) ~ldv_count_1~0)} assume !(~ldv_count_1~0 >= ~ldv_count_2~0); {6609#false} is VALID [2022-02-20 21:35:30,884 INFO L272 TraceCheckUtils]: 128: Hoare triple {6609#false} call ldv_error(); {6609#false} is VALID [2022-02-20 21:35:30,884 INFO L290 TraceCheckUtils]: 129: Hoare triple {6609#false} assume !false; {6609#false} is VALID [2022-02-20 21:35:30,884 INFO L134 CoverageAnalysis]: Checked inductivity of 34 backedges. 0 proven. 0 refuted. 0 times theorem prover too weak. 34 trivial. 0 not checked. [2022-02-20 21:35:30,885 INFO L144 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-02-20 21:35:30,885 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [840559958] [2022-02-20 21:35:30,885 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleSmtInterpolCraig [840559958] provided 1 perfect and 0 imperfect interpolant sequences [2022-02-20 21:35:30,885 INFO L191 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-02-20 21:35:30,885 INFO L204 FreeRefinementEngine]: Number of different interpolants: perfect sequences [7] imperfect sequences [] total 7 [2022-02-20 21:35:30,886 INFO L118 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [2014697283] [2022-02-20 21:35:30,886 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-02-20 21:35:30,887 INFO L78 Accepts]: Start accepts. Automaton has has 7 states, 7 states have (on average 10.714285714285714) internal successors, (75), 5 states have internal predecessors, (75), 3 states have call successors, (16), 5 states have call predecessors, (16), 1 states have return successors, (14), 2 states have call predecessors, (14), 2 states have call successors, (14) Word has length 130 [2022-02-20 21:35:30,887 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-02-20 21:35:30,888 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with has 7 states, 7 states have (on average 10.714285714285714) internal successors, (75), 5 states have internal predecessors, (75), 3 states have call successors, (16), 5 states have call predecessors, (16), 1 states have return successors, (14), 2 states have call predecessors, (14), 2 states have call successors, (14) [2022-02-20 21:35:31,001 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 105 edges. 105 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 21:35:31,001 INFO L546 AbstractCegarLoop]: INTERPOLANT automaton has 7 states [2022-02-20 21:35:31,002 INFO L108 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2022-02-20 21:35:31,002 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 7 interpolants. [2022-02-20 21:35:31,002 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=12, Invalid=30, Unknown=0, NotChecked=0, Total=42 [2022-02-20 21:35:31,003 INFO L87 Difference]: Start difference. First operand 266 states and 349 transitions. Second operand has 7 states, 7 states have (on average 10.714285714285714) internal successors, (75), 5 states have internal predecessors, (75), 3 states have call successors, (16), 5 states have call predecessors, (16), 1 states have return successors, (14), 2 states have call predecessors, (14), 2 states have call successors, (14) [2022-02-20 21:35:36,321 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 21:35:36,322 INFO L93 Difference]: Finished difference Result 863 states and 1155 transitions. [2022-02-20 21:35:36,322 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 14 states. [2022-02-20 21:35:36,323 INFO L78 Accepts]: Start accepts. Automaton has has 7 states, 7 states have (on average 10.714285714285714) internal successors, (75), 5 states have internal predecessors, (75), 3 states have call successors, (16), 5 states have call predecessors, (16), 1 states have return successors, (14), 2 states have call predecessors, (14), 2 states have call successors, (14) Word has length 130 [2022-02-20 21:35:36,323 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-02-20 21:35:36,323 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 7 states, 7 states have (on average 10.714285714285714) internal successors, (75), 5 states have internal predecessors, (75), 3 states have call successors, (16), 5 states have call predecessors, (16), 1 states have return successors, (14), 2 states have call predecessors, (14), 2 states have call successors, (14) [2022-02-20 21:35:36,337 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 14 states to 14 states and 1140 transitions. [2022-02-20 21:35:36,337 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 7 states, 7 states have (on average 10.714285714285714) internal successors, (75), 5 states have internal predecessors, (75), 3 states have call successors, (16), 5 states have call predecessors, (16), 1 states have return successors, (14), 2 states have call predecessors, (14), 2 states have call successors, (14) [2022-02-20 21:35:36,349 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 14 states to 14 states and 1140 transitions. [2022-02-20 21:35:36,350 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with 14 states and 1140 transitions. [2022-02-20 21:35:37,421 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 1140 edges. 1140 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 21:35:37,473 INFO L225 Difference]: With dead ends: 863 [2022-02-20 21:35:37,474 INFO L226 Difference]: Without dead ends: 859 [2022-02-20 21:35:37,474 INFO L932 BasicCegarLoop]: 0 DeclaredPredicates, 51 GetRequests, 39 SyntacticMatches, 0 SemanticMatches, 12 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 23 ImplicationChecksByTransitivity, 0.1s TimeCoverageRelationStatistics Valid=56, Invalid=126, Unknown=0, NotChecked=0, Total=182 [2022-02-20 21:35:37,475 INFO L933 BasicCegarLoop]: 406 mSDtfsCounter, 1105 mSDsluCounter, 915 mSDsCounter, 0 mSdLazyCounter, 996 mSolverCounterSat, 487 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 1.8s Time, 0 mProtectedPredicate, 0 mProtectedAction, 1166 SdHoareTripleChecker+Valid, 1321 SdHoareTripleChecker+Invalid, 1483 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 487 IncrementalHoareTripleChecker+Valid, 996 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 1.8s IncrementalHoareTripleChecker+Time [2022-02-20 21:35:37,476 INFO L934 BasicCegarLoop]: SdHoareTripleChecker [1166 Valid, 1321 Invalid, 1483 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [487 Valid, 996 Invalid, 0 Unknown, 0 Unchecked, 1.8s Time] [2022-02-20 21:35:37,477 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 859 states. [2022-02-20 21:35:37,626 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 859 to 772. [2022-02-20 21:35:37,626 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-02-20 21:35:37,628 INFO L82 GeneralOperation]: Start isEquivalent. First operand 859 states. Second operand has 772 states, 594 states have (on average 1.2811447811447811) internal successors, (761), 601 states have internal predecessors, (761), 129 states have call successors, (129), 49 states have call predecessors, (129), 48 states have return successors, (131), 127 states have call predecessors, (131), 127 states have call successors, (131) [2022-02-20 21:35:37,630 INFO L74 IsIncluded]: Start isIncluded. First operand 859 states. Second operand has 772 states, 594 states have (on average 1.2811447811447811) internal successors, (761), 601 states have internal predecessors, (761), 129 states have call successors, (129), 49 states have call predecessors, (129), 48 states have return successors, (131), 127 states have call predecessors, (131), 127 states have call successors, (131) [2022-02-20 21:35:37,632 INFO L87 Difference]: Start difference. First operand 859 states. Second operand has 772 states, 594 states have (on average 1.2811447811447811) internal successors, (761), 601 states have internal predecessors, (761), 129 states have call successors, (129), 49 states have call predecessors, (129), 48 states have return successors, (131), 127 states have call predecessors, (131), 127 states have call successors, (131) [2022-02-20 21:35:37,675 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 21:35:37,675 INFO L93 Difference]: Finished difference Result 859 states and 1150 transitions. [2022-02-20 21:35:37,675 INFO L276 IsEmpty]: Start isEmpty. Operand 859 states and 1150 transitions. [2022-02-20 21:35:37,677 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 21:35:37,678 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 21:35:37,680 INFO L74 IsIncluded]: Start isIncluded. First operand has 772 states, 594 states have (on average 1.2811447811447811) internal successors, (761), 601 states have internal predecessors, (761), 129 states have call successors, (129), 49 states have call predecessors, (129), 48 states have return successors, (131), 127 states have call predecessors, (131), 127 states have call successors, (131) Second operand 859 states. [2022-02-20 21:35:37,682 INFO L87 Difference]: Start difference. First operand has 772 states, 594 states have (on average 1.2811447811447811) internal successors, (761), 601 states have internal predecessors, (761), 129 states have call successors, (129), 49 states have call predecessors, (129), 48 states have return successors, (131), 127 states have call predecessors, (131), 127 states have call successors, (131) Second operand 859 states. [2022-02-20 21:35:37,726 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 21:35:37,726 INFO L93 Difference]: Finished difference Result 859 states and 1150 transitions. [2022-02-20 21:35:37,726 INFO L276 IsEmpty]: Start isEmpty. Operand 859 states and 1150 transitions. [2022-02-20 21:35:37,729 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 21:35:37,729 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 21:35:37,729 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-02-20 21:35:37,729 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-02-20 21:35:37,732 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 772 states, 594 states have (on average 1.2811447811447811) internal successors, (761), 601 states have internal predecessors, (761), 129 states have call successors, (129), 49 states have call predecessors, (129), 48 states have return successors, (131), 127 states have call predecessors, (131), 127 states have call successors, (131) [2022-02-20 21:35:37,777 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 772 states to 772 states and 1021 transitions. [2022-02-20 21:35:37,777 INFO L78 Accepts]: Start accepts. Automaton has 772 states and 1021 transitions. Word has length 130 [2022-02-20 21:35:37,778 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-02-20 21:35:37,778 INFO L470 AbstractCegarLoop]: Abstraction has 772 states and 1021 transitions. [2022-02-20 21:35:37,778 INFO L471 AbstractCegarLoop]: INTERPOLANT automaton has has 7 states, 7 states have (on average 10.714285714285714) internal successors, (75), 5 states have internal predecessors, (75), 3 states have call successors, (16), 5 states have call predecessors, (16), 1 states have return successors, (14), 2 states have call predecessors, (14), 2 states have call successors, (14) [2022-02-20 21:35:37,779 INFO L276 IsEmpty]: Start isEmpty. Operand 772 states and 1021 transitions. [2022-02-20 21:35:37,782 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 141 [2022-02-20 21:35:37,782 INFO L506 BasicCegarLoop]: Found error trace [2022-02-20 21:35:37,783 INFO L514 BasicCegarLoop]: trace histogram [3, 3, 3, 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, 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:35:37,783 WARN L452 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable3 [2022-02-20 21:35:37,783 INFO L402 AbstractCegarLoop]: === Iteration 5 === Targeting ldv_errorErr0ASSERT_VIOLATIONERROR_FUNCTION === [ldv_errorErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-02-20 21:35:37,784 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-02-20 21:35:37,784 INFO L85 PathProgramCache]: Analyzing trace with hash 88761714, now seen corresponding path program 1 times [2022-02-20 21:35:37,784 INFO L126 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-02-20 21:35:37,784 INFO L338 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [1197118447] [2022-02-20 21:35:37,785 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 21:35:37,785 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-02-20 21:35:37,878 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:37,939 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 3 [2022-02-20 21:35:37,940 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:37,944 INFO L290 TraceCheckUtils]: 0: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:37,944 INFO L284 TraceCheckUtils]: 1: Hoare quadruple {10869#true} {10869#true} #612#return; {10869#true} is VALID [2022-02-20 21:35:37,944 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 14 [2022-02-20 21:35:37,945 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:37,947 INFO L290 TraceCheckUtils]: 0: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:37,947 INFO L284 TraceCheckUtils]: 1: Hoare quadruple {10869#true} {10869#true} #614#return; {10869#true} is VALID [2022-02-20 21:35:37,954 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 18 [2022-02-20 21:35:37,957 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:37,960 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:35:37,961 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:37,964 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:35:37,965 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:37,969 INFO L290 TraceCheckUtils]: 0: Hoare triple {10946#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {10869#true} is VALID [2022-02-20 21:35:37,969 INFO L290 TraceCheckUtils]: 1: Hoare triple {10869#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {10869#true} is VALID [2022-02-20 21:35:37,969 INFO L290 TraceCheckUtils]: 2: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:37,970 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {10869#true} {10869#true} #590#return; {10869#true} is VALID [2022-02-20 21:35:37,970 INFO L290 TraceCheckUtils]: 0: Hoare triple {10946#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {10869#true} is VALID [2022-02-20 21:35:37,970 INFO L272 TraceCheckUtils]: 1: Hoare triple {10869#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {10946#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:37,971 INFO L290 TraceCheckUtils]: 2: Hoare triple {10946#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {10869#true} is VALID [2022-02-20 21:35:37,971 INFO L290 TraceCheckUtils]: 3: Hoare triple {10869#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {10869#true} is VALID [2022-02-20 21:35:37,971 INFO L290 TraceCheckUtils]: 4: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:37,971 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {10869#true} {10869#true} #590#return; {10869#true} is VALID [2022-02-20 21:35:37,971 INFO L290 TraceCheckUtils]: 6: Hoare triple {10869#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {10869#true} is VALID [2022-02-20 21:35:37,972 INFO L290 TraceCheckUtils]: 7: Hoare triple {10869#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {10869#true} is VALID [2022-02-20 21:35:37,972 INFO L290 TraceCheckUtils]: 8: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:37,972 INFO L284 TraceCheckUtils]: 9: Hoare quadruple {10869#true} {10869#true} #588#return; {10869#true} is VALID [2022-02-20 21:35:37,972 INFO L290 TraceCheckUtils]: 0: Hoare triple {10946#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size;~flags := #in~flags;havoc ~tmp~2.base, ~tmp~2.offset; {10869#true} is VALID [2022-02-20 21:35:37,973 INFO L272 TraceCheckUtils]: 1: Hoare triple {10869#true} call #t~ret40.base, #t~ret40.offset := kmalloc(~size, ~bitwiseOr(~flags, 32768)); {10946#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:37,973 INFO L290 TraceCheckUtils]: 2: Hoare triple {10946#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {10869#true} is VALID [2022-02-20 21:35:37,974 INFO L272 TraceCheckUtils]: 3: Hoare triple {10869#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {10946#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:37,974 INFO L290 TraceCheckUtils]: 4: Hoare triple {10946#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {10869#true} is VALID [2022-02-20 21:35:37,974 INFO L290 TraceCheckUtils]: 5: Hoare triple {10869#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {10869#true} is VALID [2022-02-20 21:35:37,974 INFO L290 TraceCheckUtils]: 6: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:37,974 INFO L284 TraceCheckUtils]: 7: Hoare quadruple {10869#true} {10869#true} #590#return; {10869#true} is VALID [2022-02-20 21:35:37,974 INFO L290 TraceCheckUtils]: 8: Hoare triple {10869#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {10869#true} is VALID [2022-02-20 21:35:37,975 INFO L290 TraceCheckUtils]: 9: Hoare triple {10869#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {10869#true} is VALID [2022-02-20 21:35:37,975 INFO L290 TraceCheckUtils]: 10: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:37,975 INFO L284 TraceCheckUtils]: 11: Hoare quadruple {10869#true} {10869#true} #588#return; {10869#true} is VALID [2022-02-20 21:35:37,975 INFO L290 TraceCheckUtils]: 12: Hoare triple {10869#true} ~tmp~2.base, ~tmp~2.offset := #t~ret40.base, #t~ret40.offset;havoc #t~ret40.base, #t~ret40.offset;#res.base, #res.offset := ~tmp~2.base, ~tmp~2.offset; {10869#true} is VALID [2022-02-20 21:35:37,975 INFO L290 TraceCheckUtils]: 13: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:37,976 INFO L284 TraceCheckUtils]: 14: Hoare quadruple {10869#true} {10869#true} #616#return; {10869#true} is VALID [2022-02-20 21:35:37,981 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 41 [2022-02-20 21:35:37,984 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:37,988 INFO L290 TraceCheckUtils]: 0: Hoare triple {10961#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;havoc ~err~0#1;assume { :begin_inline_ipmi_validate_addr } true;ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset, ipmi_validate_addr_#in~arg1#1 := ~data#1.base, 193 + ~data#1.offset, 40;havoc ipmi_validate_addr_#res#1;havoc ipmi_validate_addr_#t~nondet254#1, ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset, ipmi_validate_addr_~arg1#1;ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset := ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset;ipmi_validate_addr_~arg1#1 := ipmi_validate_addr_#in~arg1#1;assume -2147483648 <= ipmi_validate_addr_#t~nondet254#1 && ipmi_validate_addr_#t~nondet254#1 <= 2147483647;ipmi_validate_addr_#res#1 := ipmi_validate_addr_#t~nondet254#1;havoc ipmi_validate_addr_#t~nondet254#1; {10869#true} is VALID [2022-02-20 21:35:37,989 INFO L290 TraceCheckUtils]: 1: Hoare triple {10869#true} #t~ret62#1 := ipmi_validate_addr_#res#1;assume { :end_inline_ipmi_validate_addr } true;assume -2147483648 <= #t~ret62#1 && #t~ret62#1 <= 2147483647;~err~0#1 := #t~ret62#1;havoc #t~ret62#1; {10869#true} is VALID [2022-02-20 21:35:37,989 INFO L290 TraceCheckUtils]: 2: Hoare triple {10869#true} assume 0 != ~err~0#1; {10869#true} is VALID [2022-02-20 21:35:37,989 INFO L290 TraceCheckUtils]: 3: Hoare triple {10869#true} havoc #t~nondet69#1;call #t~mem70#1.base, #t~mem70#1.offset := read~$Pointer$(~data#1.base, 24 + ~data#1.offset, 8);havoc #t~mem70#1.base, #t~mem70#1.offset;#res#1 := ~err~0#1; {10869#true} is VALID [2022-02-20 21:35:37,989 INFO L290 TraceCheckUtils]: 4: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:37,989 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {10869#true} {10869#true} #618#return; {10869#true} is VALID [2022-02-20 21:35:37,990 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 49 [2022-02-20 21:35:37,992 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:37,994 INFO L290 TraceCheckUtils]: 0: Hoare triple {10869#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset; {10869#true} is VALID [2022-02-20 21:35:37,995 INFO L290 TraceCheckUtils]: 1: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:37,995 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {10869#true} {10869#true} #620#return; {10869#true} is VALID [2022-02-20 21:35:37,995 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 56 [2022-02-20 21:35:37,997 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:38,003 INFO L290 TraceCheckUtils]: 0: Hoare triple {10869#true} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;~offset#1 := #in~offset#1;havoc ~tmp~3#1;assume { :begin_inline___be16_to_cpup } true;__be16_to_cpup_#in~p#1.base, __be16_to_cpup_#in~p#1.offset := ~data#1.base, ~data#1.offset + 2 * (if ~offset#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then ~offset#1 % 18446744073709551616 % 18446744073709551616 else ~offset#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616);havoc __be16_to_cpup_#res#1;havoc __be16_to_cpup_#t~ret3#1, __be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset, __be16_to_cpup_~tmp~1#1;__be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset := __be16_to_cpup_#in~p#1.base, __be16_to_cpup_#in~p#1.offset;havoc __be16_to_cpup_~tmp~1#1;assume { :begin_inline___swab16p } true;__swab16p_#in~p#1.base, __swab16p_#in~p#1.offset := __be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset;havoc __swab16p_#res#1;havoc __swab16p_#t~mem1#1, __swab16p_#t~ret2#1, __swab16p_~p#1.base, __swab16p_~p#1.offset, __swab16p_~tmp~0#1;__swab16p_~p#1.base, __swab16p_~p#1.offset := __swab16p_#in~p#1.base, __swab16p_#in~p#1.offset;havoc __swab16p_~tmp~0#1;call __swab16p_#t~mem1#1 := read~int(__swab16p_~p#1.base, __swab16p_~p#1.offset, 2);assume { :begin_inline___fswab16 } true;__fswab16_#in~val#1 := __swab16p_#t~mem1#1 % 65536;havoc __fswab16_#res#1;havoc __fswab16_~val#1;__fswab16_~val#1 := __fswab16_#in~val#1;__fswab16_#res#1 := (if (1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) || 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536)) && 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) then (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) else (if 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) && (1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) || 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536)) then (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) else (if (1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) && (1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) || 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536))) || ((1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) || 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536)) && 1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536)) then 1 else ~bitwiseOr((if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536), (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536))))); {10869#true} is VALID [2022-02-20 21:35:38,003 INFO L290 TraceCheckUtils]: 1: Hoare triple {10869#true} __swab16p_#t~ret2#1 := __fswab16_#res#1;assume { :end_inline___fswab16 } true;__swab16p_~tmp~0#1 := __swab16p_#t~ret2#1;havoc __swab16p_#t~mem1#1;havoc __swab16p_#t~ret2#1;__swab16p_#res#1 := __swab16p_~tmp~0#1; {10869#true} is VALID [2022-02-20 21:35:38,003 INFO L290 TraceCheckUtils]: 2: Hoare triple {10869#true} __be16_to_cpup_#t~ret3#1 := __swab16p_#res#1;assume { :end_inline___swab16p } true;__be16_to_cpup_~tmp~1#1 := __be16_to_cpup_#t~ret3#1;havoc __be16_to_cpup_#t~ret3#1;__be16_to_cpup_#res#1 := __be16_to_cpup_~tmp~1#1; {10869#true} is VALID [2022-02-20 21:35:38,004 INFO L290 TraceCheckUtils]: 3: Hoare triple {10869#true} #t~ret61#1 := __be16_to_cpup_#res#1;assume { :end_inline___be16_to_cpup } true;~tmp~3#1 := #t~ret61#1;havoc #t~ret61#1;#res#1 := ~tmp~3#1; {10869#true} is VALID [2022-02-20 21:35:38,004 INFO L290 TraceCheckUtils]: 4: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:38,004 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {10869#true} {10869#true} #622#return; {10869#true} is VALID [2022-02-20 21:35:38,004 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 66 [2022-02-20 21:35:38,006 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:38,009 INFO L290 TraceCheckUtils]: 0: Hoare triple {10946#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {10869#true} is VALID [2022-02-20 21:35:38,009 INFO L290 TraceCheckUtils]: 1: Hoare triple {10869#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {10869#true} is VALID [2022-02-20 21:35:38,009 INFO L290 TraceCheckUtils]: 2: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:38,009 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {10869#true} {10869#true} #624#return; {10869#true} is VALID [2022-02-20 21:35:38,010 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 73 [2022-02-20 21:35:38,011 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:38,018 INFO L290 TraceCheckUtils]: 0: Hoare triple {10869#true} ~ptr.base, ~ptr.offset := #in~ptr.base, #in~ptr.offset;#res := (if (~ptr.base + ~ptr.offset) % 18446744073709551616 > 2012 then 1 else 0); {10869#true} is VALID [2022-02-20 21:35:38,018 INFO L290 TraceCheckUtils]: 1: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:38,018 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {10869#true} {10869#true} #626#return; {10869#true} is VALID [2022-02-20 21:35:38,018 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 80 [2022-02-20 21:35:38,019 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:38,022 INFO L290 TraceCheckUtils]: 0: Hoare triple {10869#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset;~arg1.base, ~arg1.offset := #in~arg1.base, #in~arg1.offset; {10869#true} is VALID [2022-02-20 21:35:38,022 INFO L290 TraceCheckUtils]: 1: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:38,022 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {10869#true} {10869#true} #628#return; {10869#true} is VALID [2022-02-20 21:35:38,023 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 87 [2022-02-20 21:35:38,025 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:38,028 INFO L290 TraceCheckUtils]: 0: Hoare triple {10961#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;havoc ~err~0#1;assume { :begin_inline_ipmi_validate_addr } true;ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset, ipmi_validate_addr_#in~arg1#1 := ~data#1.base, 193 + ~data#1.offset, 40;havoc ipmi_validate_addr_#res#1;havoc ipmi_validate_addr_#t~nondet254#1, ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset, ipmi_validate_addr_~arg1#1;ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset := ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset;ipmi_validate_addr_~arg1#1 := ipmi_validate_addr_#in~arg1#1;assume -2147483648 <= ipmi_validate_addr_#t~nondet254#1 && ipmi_validate_addr_#t~nondet254#1 <= 2147483647;ipmi_validate_addr_#res#1 := ipmi_validate_addr_#t~nondet254#1;havoc ipmi_validate_addr_#t~nondet254#1; {10869#true} is VALID [2022-02-20 21:35:38,028 INFO L290 TraceCheckUtils]: 1: Hoare triple {10869#true} #t~ret62#1 := ipmi_validate_addr_#res#1;assume { :end_inline_ipmi_validate_addr } true;assume -2147483648 <= #t~ret62#1 && #t~ret62#1 <= 2147483647;~err~0#1 := #t~ret62#1;havoc #t~ret62#1; {10869#true} is VALID [2022-02-20 21:35:38,029 INFO L290 TraceCheckUtils]: 2: Hoare triple {10869#true} assume 0 != ~err~0#1; {10869#true} is VALID [2022-02-20 21:35:38,029 INFO L290 TraceCheckUtils]: 3: Hoare triple {10869#true} havoc #t~nondet69#1;call #t~mem70#1.base, #t~mem70#1.offset := read~$Pointer$(~data#1.base, 24 + ~data#1.offset, 8);havoc #t~mem70#1.base, #t~mem70#1.offset;#res#1 := ~err~0#1; {10869#true} is VALID [2022-02-20 21:35:38,029 INFO L290 TraceCheckUtils]: 4: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:38,029 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {10869#true} {10869#true} #630#return; {10869#true} is VALID [2022-02-20 21:35:38,029 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 95 [2022-02-20 21:35:38,030 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:38,033 INFO L290 TraceCheckUtils]: 0: Hoare triple {10869#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset; {10869#true} is VALID [2022-02-20 21:35:38,033 INFO L290 TraceCheckUtils]: 1: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:38,033 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {10869#true} {10869#true} #632#return; {10869#true} is VALID [2022-02-20 21:35:38,034 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 104 [2022-02-20 21:35:38,036 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:38,040 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:35:38,041 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:38,045 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:35:38,046 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:38,048 INFO L290 TraceCheckUtils]: 0: Hoare triple {10946#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {10869#true} is VALID [2022-02-20 21:35:38,048 INFO L290 TraceCheckUtils]: 1: Hoare triple {10869#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {10869#true} is VALID [2022-02-20 21:35:38,049 INFO L290 TraceCheckUtils]: 2: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:38,049 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {10869#true} {10869#true} #590#return; {10869#true} is VALID [2022-02-20 21:35:38,049 INFO L290 TraceCheckUtils]: 0: Hoare triple {10946#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {10869#true} is VALID [2022-02-20 21:35:38,050 INFO L272 TraceCheckUtils]: 1: Hoare triple {10869#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {10946#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:38,050 INFO L290 TraceCheckUtils]: 2: Hoare triple {10946#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {10869#true} is VALID [2022-02-20 21:35:38,050 INFO L290 TraceCheckUtils]: 3: Hoare triple {10869#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {10869#true} is VALID [2022-02-20 21:35:38,050 INFO L290 TraceCheckUtils]: 4: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:38,050 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {10869#true} {10869#true} #590#return; {10869#true} is VALID [2022-02-20 21:35:38,051 INFO L290 TraceCheckUtils]: 6: Hoare triple {10869#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {10869#true} is VALID [2022-02-20 21:35:38,051 INFO L290 TraceCheckUtils]: 7: Hoare triple {10869#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {10869#true} is VALID [2022-02-20 21:35:38,051 INFO L290 TraceCheckUtils]: 8: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:38,051 INFO L284 TraceCheckUtils]: 9: Hoare quadruple {10869#true} {10869#true} #588#return; {10869#true} is VALID [2022-02-20 21:35:38,051 INFO L290 TraceCheckUtils]: 0: Hoare triple {10946#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size;~flags := #in~flags;havoc ~tmp~2.base, ~tmp~2.offset; {10869#true} is VALID [2022-02-20 21:35:38,052 INFO L272 TraceCheckUtils]: 1: Hoare triple {10869#true} call #t~ret40.base, #t~ret40.offset := kmalloc(~size, ~bitwiseOr(~flags, 32768)); {10946#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:38,052 INFO L290 TraceCheckUtils]: 2: Hoare triple {10946#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {10869#true} is VALID [2022-02-20 21:35:38,053 INFO L272 TraceCheckUtils]: 3: Hoare triple {10869#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {10946#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:38,053 INFO L290 TraceCheckUtils]: 4: Hoare triple {10946#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {10869#true} is VALID [2022-02-20 21:35:38,053 INFO L290 TraceCheckUtils]: 5: Hoare triple {10869#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {10869#true} is VALID [2022-02-20 21:35:38,053 INFO L290 TraceCheckUtils]: 6: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:38,053 INFO L284 TraceCheckUtils]: 7: Hoare quadruple {10869#true} {10869#true} #590#return; {10869#true} is VALID [2022-02-20 21:35:38,054 INFO L290 TraceCheckUtils]: 8: Hoare triple {10869#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {10869#true} is VALID [2022-02-20 21:35:38,054 INFO L290 TraceCheckUtils]: 9: Hoare triple {10869#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {10869#true} is VALID [2022-02-20 21:35:38,054 INFO L290 TraceCheckUtils]: 10: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:38,054 INFO L284 TraceCheckUtils]: 11: Hoare quadruple {10869#true} {10869#true} #588#return; {10869#true} is VALID [2022-02-20 21:35:38,054 INFO L290 TraceCheckUtils]: 12: Hoare triple {10869#true} ~tmp~2.base, ~tmp~2.offset := #t~ret40.base, #t~ret40.offset;havoc #t~ret40.base, #t~ret40.offset;#res.base, #res.offset := ~tmp~2.base, ~tmp~2.offset; {10869#true} is VALID [2022-02-20 21:35:38,055 INFO L290 TraceCheckUtils]: 13: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:38,055 INFO L284 TraceCheckUtils]: 14: Hoare quadruple {10869#true} {10869#true} #634#return; {10869#true} is VALID [2022-02-20 21:35:38,060 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 124 [2022-02-20 21:35:38,062 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:38,068 INFO L290 TraceCheckUtils]: 0: Hoare triple {10976#(and (= ~ldv_call_dev_attr_of_sensor_device_attribute~0 |old(~ldv_call_dev_attr_of_sensor_device_attribute~0)|) (= |old(~ldv_count_2~0)| ~ldv_count_2~0))} ~attr.base, ~attr.offset := #in~attr.base, #in~attr.offset; {10869#true} is VALID [2022-02-20 21:35:38,068 INFO L290 TraceCheckUtils]: 1: Hoare triple {10869#true} assume 0 == ~ldv_call_dev_attr_of_sensor_device_attribute~0;~ldv_count_2~0 := 1 + ~ldv_count_2~0;~ldv_call_dev_attr_of_sensor_device_attribute~0 := 1; {10945#(= ~ldv_call_dev_attr_of_sensor_device_attribute~0 1)} is VALID [2022-02-20 21:35:38,069 INFO L290 TraceCheckUtils]: 2: Hoare triple {10945#(= ~ldv_call_dev_attr_of_sensor_device_attribute~0 1)} assume ~ldv_count_1~0 >= ~ldv_count_2~0; {10945#(= ~ldv_call_dev_attr_of_sensor_device_attribute~0 1)} is VALID [2022-02-20 21:35:38,069 INFO L290 TraceCheckUtils]: 3: Hoare triple {10945#(= ~ldv_call_dev_attr_of_sensor_device_attribute~0 1)} #res := 0; {10945#(= ~ldv_call_dev_attr_of_sensor_device_attribute~0 1)} is VALID [2022-02-20 21:35:38,070 INFO L290 TraceCheckUtils]: 4: Hoare triple {10945#(= ~ldv_call_dev_attr_of_sensor_device_attribute~0 1)} assume true; {10945#(= ~ldv_call_dev_attr_of_sensor_device_attribute~0 1)} is VALID [2022-02-20 21:35:38,070 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {10945#(= ~ldv_call_dev_attr_of_sensor_device_attribute~0 1)} {10869#true} #646#return; {10945#(= ~ldv_call_dev_attr_of_sensor_device_attribute~0 1)} is VALID [2022-02-20 21:35:38,071 INFO L290 TraceCheckUtils]: 0: Hoare triple {10869#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(46, 2);call #Ultimate.allocInit(13, 3);call #Ultimate.allocInit(20, 4);call #Ultimate.allocInit(21, 5);call #Ultimate.allocInit(11, 6);call #Ultimate.allocInit(18, 7);call #Ultimate.allocInit(19, 8);call #Ultimate.allocInit(20, 9);call #Ultimate.allocInit(18, 10);call #Ultimate.allocInit(69, 11);call #Ultimate.allocInit(26, 12);call #Ultimate.allocInit(4, 13);call write~init~int(37, 13, 0, 1);call write~init~int(115, 13, 1, 1);call write~init~int(10, 13, 2, 1);call write~init~int(0, 13, 3, 1);call #Ultimate.allocInit(7, 14);call write~init~int(105, 14, 0, 1);call write~init~int(98, 14, 1, 1);call write~init~int(109, 14, 2, 1);call write~init~int(112, 14, 3, 1);call write~init~int(101, 14, 4, 1);call write~init~int(120, 14, 5, 1);call write~init~int(0, 14, 6, 1);call #Ultimate.allocInit(5, 15);call write~init~int(110, 15, 0, 1);call write~init~int(97, 15, 1, 1);call write~init~int(109, 15, 2, 1);call write~init~int(101, 15, 3, 1);call write~init~int(0, 15, 4, 1);call #Ultimate.allocInit(4, 16);call write~init~int(37, 16, 0, 1);call write~init~int(100, 16, 1, 1);call write~init~int(10, 16, 2, 1);call write~init~int(0, 16, 3, 1);call #Ultimate.allocInit(15, 17);call #Ultimate.allocInit(5, 18);call write~init~int(116, 18, 0, 1);call write~init~int(101, 18, 1, 1);call write~init~int(109, 18, 2, 1);call write~init~int(112, 18, 3, 1);call write~init~int(0, 18, 4, 1);call #Ultimate.allocInit(6, 19);call write~init~int(112, 19, 0, 1);call write~init~int(111, 19, 1, 1);call write~init~int(119, 19, 2, 1);call write~init~int(101, 19, 3, 1);call write~init~int(114, 19, 4, 1);call write~init~int(0, 19, 5, 1);call #Ultimate.allocInit(40, 20);call #Ultimate.allocInit(48, 21);call #Ultimate.allocInit(12, 22);call #Ultimate.allocInit(55, 23);call #Ultimate.allocInit(26, 24);call #Ultimate.allocInit(70, 25);~#power_sensor_sig~0.base, ~#power_sensor_sig~0.offset := 26, 0;call #Ultimate.allocInit(3, 26);call write~init~int(112, ~#power_sensor_sig~0.base, ~#power_sensor_sig~0.offset, 1);call write~init~int(119, ~#power_sensor_sig~0.base, 1 + ~#power_sensor_sig~0.offset, 1);call write~init~int(114, ~#power_sensor_sig~0.base, 2 + ~#power_sensor_sig~0.offset, 1);~#temp_sensor_sig~0.base, ~#temp_sensor_sig~0.offset := 27, 0;call #Ultimate.allocInit(3, 27);call write~init~int(116, ~#temp_sensor_sig~0.base, ~#temp_sensor_sig~0.offset, 1);call write~init~int(101, ~#temp_sensor_sig~0.base, 1 + ~#temp_sensor_sig~0.offset, 1);call write~init~int(109, ~#temp_sensor_sig~0.base, 2 + ~#temp_sensor_sig~0.offset, 1);~#watt_sensor_sig~0.base, ~#watt_sensor_sig~0.offset := 28, 0;call #Ultimate.allocInit(2, 28);call write~init~int(65, ~#watt_sensor_sig~0.base, ~#watt_sensor_sig~0.offset, 1);call write~init~int(67, ~#watt_sensor_sig~0.base, 1 + ~#watt_sensor_sig~0.offset, 1);~#power_sensor_name_templates~0.base, ~#power_sensor_name_templates~0.offset := 29, 0;call #Ultimate.allocInit(24, 29);call write~init~$Pointer$(3, 0, ~#power_sensor_name_templates~0.base, ~#power_sensor_name_templates~0.offset, 8);call write~init~$Pointer$(4, 0, ~#power_sensor_name_templates~0.base, 8 + ~#power_sensor_name_templates~0.offset, 8);call write~init~$Pointer$(5, 0, ~#power_sensor_name_templates~0.base, 16 + ~#power_sensor_name_templates~0.offset, 8);~#temp_sensor_name_templates~0.base, ~#temp_sensor_name_templates~0.offset := 30, 0;call #Ultimate.allocInit(24, 30);call write~init~$Pointer$(6, 0, ~#temp_sensor_name_templates~0.base, ~#temp_sensor_name_templates~0.offset, 8);call write~init~$Pointer$(7, 0, ~#temp_sensor_name_templates~0.base, 8 + ~#temp_sensor_name_templates~0.offset, 8);call write~init~$Pointer$(8, 0, ~#temp_sensor_name_templates~0.base, 16 + ~#temp_sensor_name_templates~0.offset, 8);~#driver_data~0.base, ~#driver_data~0.offset := 31, 0;call #Ultimate.allocInit(72, 31);call write~init~$Pointer$(~#driver_data~0.base, ~#driver_data~0.offset, ~#driver_data~0.base, ~#driver_data~0.offset, 8);call write~init~$Pointer$(~#driver_data~0.base, ~#driver_data~0.offset, ~#driver_data~0.base, 8 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(0, 0, ~#driver_data~0.base, 16 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(0, 0, ~#driver_data~0.base, 24 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(~#__this_module~0.base, ~#__this_module~0.offset, ~#driver_data~0.base, 32 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(#funAddr~ibmpex_register_bmc.base, #funAddr~ibmpex_register_bmc.offset, ~#driver_data~0.base, 40 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(#funAddr~ibmpex_bmc_gone.base, #funAddr~ibmpex_bmc_gone.offset, ~#driver_data~0.base, 48 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(#funAddr~ibmpex_msg_handler.base, #funAddr~ibmpex_msg_handler.offset, ~#driver_data~0.base, 56 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(0, 0, ~#driver_data~0.base, 64 + ~#driver_data~0.offset, 8);~#sensor_dev_attr_name~0.base, ~#sensor_dev_attr_name~0.offset := 32, 0;call #Ultimate.allocInit(48, 32);call write~init~$Pointer$(15, 0, ~#sensor_dev_attr_name~0.base, ~#sensor_dev_attr_name~0.offset, 8);call write~init~int(292, ~#sensor_dev_attr_name~0.base, 8 + ~#sensor_dev_attr_name~0.offset, 4);call write~init~$Pointer$(0, 0, ~#sensor_dev_attr_name~0.base, 12 + ~#sensor_dev_attr_name~0.offset, 8);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 20 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 21 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 22 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 23 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 24 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 25 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 26 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 27 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~$Pointer$(#funAddr~show_name.base, #funAddr~show_name.offset, ~#sensor_dev_attr_name~0.base, 28 + ~#sensor_dev_attr_name~0.offset, 8);call write~init~$Pointer$(0, 0, ~#sensor_dev_attr_name~0.base, 36 + ~#sensor_dev_attr_name~0.offset, 8);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 44 + ~#sensor_dev_attr_name~0.offset, 4);~#sensor_dev_attr_reset_high_low~0.base, ~#sensor_dev_attr_reset_high_low~0.offset := 33, 0;call #Ultimate.allocInit(48, 33);call write~init~$Pointer$(17, 0, ~#sensor_dev_attr_reset_high_low~0.base, ~#sensor_dev_attr_reset_high_low~0.offset, 8);call write~init~int(128, ~#sensor_dev_attr_reset_high_low~0.base, 8 + ~#sensor_dev_attr_reset_high_low~0.offset, 4);call write~init~$Pointer$(0, 0, ~#sensor_dev_attr_reset_high_low~0.base, 12 + ~#sensor_dev_attr_reset_high_low~0.offset, 8);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 20 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 21 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 22 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 23 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 24 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 25 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 26 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 27 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~$Pointer$(0, 0, ~#sensor_dev_attr_reset_high_low~0.base, 28 + ~#sensor_dev_attr_reset_high_low~0.offset, 8);call write~init~$Pointer$(#funAddr~ibmpex_reset_high_low.base, #funAddr~ibmpex_reset_high_low.offset, ~#sensor_dev_attr_reset_high_low~0.base, 36 + ~#sensor_dev_attr_reset_high_low~0.offset, 8);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 44 + ~#sensor_dev_attr_reset_high_low~0.offset, 4);~LDV_IN_INTERRUPT~0 := 0;~ldv_count_1~0 := 0;~ldv_count_2~0 := 0;~ldv_call_dev_attr_of_sensor_device_attribute~0 := 0;~ldv_call_dev_attr_of_sensor_device_attribute_2~0 := 0; {10869#true} is VALID [2022-02-20 21:35:38,071 INFO L290 TraceCheckUtils]: 1: Hoare triple {10869#true} assume { :end_inline_ULTIMATE.init } true;assume { :begin_inline_main } true;havoc main_#res#1;havoc main_#t~ret236#1, main_#t~nondet237#1, main_#t~switch238#1, main_#t~nondet239#1, main_~var_ibmpex_register_bmc_17_p0~0#1, main_~var_group1~0#1.base, main_~var_group1~0#1.offset, main_~var_ibmpex_bmc_gone_19_p0~0#1, main_~#var_group2~0#1.base, main_~#var_group2~0#1.offset, main_~#var_ibmpex_msg_handler_20_p1~0#1.base, main_~#var_ibmpex_msg_handler_20_p1~0#1.offset, main_~tmp~17#1, main_~tmp___0~4#1, main_~tmp___1~2#1;havoc main_~var_ibmpex_register_bmc_17_p0~0#1;havoc main_~var_group1~0#1.base, main_~var_group1~0#1.offset;havoc main_~var_ibmpex_bmc_gone_19_p0~0#1;call main_~#var_group2~0#1.base, main_~#var_group2~0#1.offset := #Ultimate.allocOnStack(374);call main_~#var_ibmpex_msg_handler_20_p1~0#1.base, main_~#var_ibmpex_msg_handler_20_p1~0#1.offset := #Ultimate.allocOnStack(915);havoc main_~tmp~17#1;havoc main_~tmp___0~4#1;havoc main_~tmp___1~2#1;~LDV_IN_INTERRUPT~0 := 1;assume { :begin_inline_ldv_initialize } true;~ldv_count_1~0 := 1 + ~ldv_count_1~0;~ldv_count_1~0 := 1 + ~ldv_count_1~0;~ldv_count_1~0 := 1 + ~ldv_count_1~0;~ldv_count_1~0 := 1 + ~ldv_count_1~0;~ldv_count_1~0 := 1 + ~ldv_count_1~0;~ldv_count_1~0 := 1 + ~ldv_count_1~0; {10869#true} is VALID [2022-02-20 21:35:38,071 INFO L290 TraceCheckUtils]: 2: Hoare triple {10869#true} assume { :end_inline_ldv_initialize } true; {10869#true} is VALID [2022-02-20 21:35:38,071 INFO L272 TraceCheckUtils]: 3: Hoare triple {10869#true} call ldv_handler_precall(); {10869#true} is VALID [2022-02-20 21:35:38,072 INFO L290 TraceCheckUtils]: 4: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:38,072 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {10869#true} {10869#true} #612#return; {10869#true} is VALID [2022-02-20 21:35:38,072 INFO L290 TraceCheckUtils]: 6: Hoare triple {10869#true} assume { :begin_inline_ibmpex_init } true;havoc ibmpex_init_#res#1;havoc ibmpex_init_#t~ret231#1, ibmpex_init_~tmp~16#1;havoc ibmpex_init_~tmp~16#1;assume { :begin_inline_ipmi_smi_watcher_register } true;ipmi_smi_watcher_register_#in~arg0#1.base, ipmi_smi_watcher_register_#in~arg0#1.offset := ~#driver_data~0.base, 16 + ~#driver_data~0.offset;havoc ipmi_smi_watcher_register_#res#1;havoc ipmi_smi_watcher_register_#t~nondet252#1, ipmi_smi_watcher_register_~arg0#1.base, ipmi_smi_watcher_register_~arg0#1.offset;ipmi_smi_watcher_register_~arg0#1.base, ipmi_smi_watcher_register_~arg0#1.offset := ipmi_smi_watcher_register_#in~arg0#1.base, ipmi_smi_watcher_register_#in~arg0#1.offset;assume -2147483648 <= ipmi_smi_watcher_register_#t~nondet252#1 && ipmi_smi_watcher_register_#t~nondet252#1 <= 2147483647;ipmi_smi_watcher_register_#res#1 := ipmi_smi_watcher_register_#t~nondet252#1;havoc ipmi_smi_watcher_register_#t~nondet252#1; {10869#true} is VALID [2022-02-20 21:35:38,072 INFO L290 TraceCheckUtils]: 7: Hoare triple {10869#true} ibmpex_init_#t~ret231#1 := ipmi_smi_watcher_register_#res#1;assume { :end_inline_ipmi_smi_watcher_register } true;assume -2147483648 <= ibmpex_init_#t~ret231#1 && ibmpex_init_#t~ret231#1 <= 2147483647;ibmpex_init_~tmp~16#1 := ibmpex_init_#t~ret231#1;havoc ibmpex_init_#t~ret231#1;ibmpex_init_#res#1 := ibmpex_init_~tmp~16#1; {10869#true} is VALID [2022-02-20 21:35:38,072 INFO L290 TraceCheckUtils]: 8: Hoare triple {10869#true} main_#t~ret236#1 := ibmpex_init_#res#1;assume { :end_inline_ibmpex_init } true;assume -2147483648 <= main_#t~ret236#1 && main_#t~ret236#1 <= 2147483647;main_~tmp~17#1 := main_#t~ret236#1;havoc main_#t~ret236#1; {10869#true} is VALID [2022-02-20 21:35:38,072 INFO L290 TraceCheckUtils]: 9: Hoare triple {10869#true} assume !(0 != main_~tmp~17#1); {10869#true} is VALID [2022-02-20 21:35:38,073 INFO L290 TraceCheckUtils]: 10: Hoare triple {10869#true} assume -2147483648 <= main_#t~nondet239#1 && main_#t~nondet239#1 <= 2147483647;main_~tmp___1~2#1 := main_#t~nondet239#1;havoc main_#t~nondet239#1; {10869#true} is VALID [2022-02-20 21:35:38,073 INFO L290 TraceCheckUtils]: 11: Hoare triple {10869#true} assume 0 != main_~tmp___1~2#1; {10869#true} is VALID [2022-02-20 21:35:38,073 INFO L290 TraceCheckUtils]: 12: Hoare triple {10869#true} assume -2147483648 <= main_#t~nondet237#1 && main_#t~nondet237#1 <= 2147483647;main_~tmp___0~4#1 := main_#t~nondet237#1;havoc main_#t~nondet237#1;main_#t~switch238#1 := 0 == main_~tmp___0~4#1; {10869#true} is VALID [2022-02-20 21:35:38,073 INFO L290 TraceCheckUtils]: 13: Hoare triple {10869#true} assume main_#t~switch238#1; {10869#true} is VALID [2022-02-20 21:35:38,073 INFO L272 TraceCheckUtils]: 14: Hoare triple {10869#true} call ldv_handler_precall(); {10869#true} is VALID [2022-02-20 21:35:38,074 INFO L290 TraceCheckUtils]: 15: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:38,074 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {10869#true} {10869#true} #614#return; {10869#true} is VALID [2022-02-20 21:35:38,074 INFO L290 TraceCheckUtils]: 17: Hoare triple {10869#true} assume { :begin_inline_ibmpex_register_bmc } true;ibmpex_register_bmc_#in~iface#1, ibmpex_register_bmc_#in~dev#1.base, ibmpex_register_bmc_#in~dev#1.offset := main_~var_ibmpex_register_bmc_17_p0~0#1, main_~var_group1~0#1.base, main_~var_group1~0#1.offset;havoc ibmpex_register_bmc_#t~ret178#1.base, ibmpex_register_bmc_#t~ret178#1.offset, ibmpex_register_bmc_#t~nondet179#1, ibmpex_register_bmc_#t~mem180#1, ibmpex_register_bmc_#t~ret181#1, ibmpex_register_bmc_#t~nondet182#1, ibmpex_register_bmc_#t~mem183#1, ibmpex_register_bmc_#t~ret184#1, ibmpex_register_bmc_#t~mem185#1.base, ibmpex_register_bmc_#t~mem185#1.offset, ibmpex_register_bmc_#t~ret186#1.base, ibmpex_register_bmc_#t~ret186#1.offset, ibmpex_register_bmc_#t~mem187#1.base, ibmpex_register_bmc_#t~mem187#1.offset, ibmpex_register_bmc_#t~ret188#1, ibmpex_register_bmc_#t~nondet189#1, ibmpex_register_bmc_#t~mem190#1.base, ibmpex_register_bmc_#t~mem190#1.offset, ibmpex_register_bmc_#t~mem191#1, ibmpex_register_bmc_#t~ret192#1, ibmpex_register_bmc_#t~nondet193#1, ibmpex_register_bmc_#t~mem194#1.base, ibmpex_register_bmc_#t~mem194#1.offset, ibmpex_register_bmc_#t~mem195#1.base, ibmpex_register_bmc_#t~mem195#1.offset, ibmpex_register_bmc_#t~mem196#1.base, ibmpex_register_bmc_#t~mem196#1.offset, ibmpex_register_bmc_#t~ret197#1, ibmpex_register_bmc_~iface#1, ibmpex_register_bmc_~dev#1.base, ibmpex_register_bmc_~dev#1.offset, ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset, ibmpex_register_bmc_~err~4#1, ibmpex_register_bmc_~tmp~14#1.base, ibmpex_register_bmc_~tmp~14#1.offset, ibmpex_register_bmc_~#__key~1#1.base, ibmpex_register_bmc_~#__key~1#1.offset, ibmpex_register_bmc_~tmp___0~3#1;ibmpex_register_bmc_~iface#1 := ibmpex_register_bmc_#in~iface#1;ibmpex_register_bmc_~dev#1.base, ibmpex_register_bmc_~dev#1.offset := ibmpex_register_bmc_#in~dev#1.base, ibmpex_register_bmc_#in~dev#1.offset;havoc ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset;havoc ibmpex_register_bmc_~err~4#1;havoc ibmpex_register_bmc_~tmp~14#1.base, ibmpex_register_bmc_~tmp~14#1.offset;call ibmpex_register_bmc_~#__key~1#1.base, ibmpex_register_bmc_~#__key~1#1.offset := #Ultimate.allocOnStack(8);havoc ibmpex_register_bmc_~tmp___0~3#1; {10869#true} is VALID [2022-02-20 21:35:38,075 INFO L272 TraceCheckUtils]: 18: Hoare triple {10869#true} call ibmpex_register_bmc_#t~ret178#1.base, ibmpex_register_bmc_#t~ret178#1.offset := kzalloc(968, 208); {10946#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:38,075 INFO L290 TraceCheckUtils]: 19: Hoare triple {10946#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size;~flags := #in~flags;havoc ~tmp~2.base, ~tmp~2.offset; {10869#true} is VALID [2022-02-20 21:35:38,075 INFO L272 TraceCheckUtils]: 20: Hoare triple {10869#true} call #t~ret40.base, #t~ret40.offset := kmalloc(~size, ~bitwiseOr(~flags, 32768)); {10946#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:38,075 INFO L290 TraceCheckUtils]: 21: Hoare triple {10946#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {10869#true} is VALID [2022-02-20 21:35:38,076 INFO L272 TraceCheckUtils]: 22: Hoare triple {10869#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {10946#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:38,076 INFO L290 TraceCheckUtils]: 23: Hoare triple {10946#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {10869#true} is VALID [2022-02-20 21:35:38,076 INFO L290 TraceCheckUtils]: 24: Hoare triple {10869#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {10869#true} is VALID [2022-02-20 21:35:38,077 INFO L290 TraceCheckUtils]: 25: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:38,077 INFO L284 TraceCheckUtils]: 26: Hoare quadruple {10869#true} {10869#true} #590#return; {10869#true} is VALID [2022-02-20 21:35:38,077 INFO L290 TraceCheckUtils]: 27: Hoare triple {10869#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {10869#true} is VALID [2022-02-20 21:35:38,077 INFO L290 TraceCheckUtils]: 28: Hoare triple {10869#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {10869#true} is VALID [2022-02-20 21:35:38,077 INFO L290 TraceCheckUtils]: 29: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:38,077 INFO L284 TraceCheckUtils]: 30: Hoare quadruple {10869#true} {10869#true} #588#return; {10869#true} is VALID [2022-02-20 21:35:38,078 INFO L290 TraceCheckUtils]: 31: Hoare triple {10869#true} ~tmp~2.base, ~tmp~2.offset := #t~ret40.base, #t~ret40.offset;havoc #t~ret40.base, #t~ret40.offset;#res.base, #res.offset := ~tmp~2.base, ~tmp~2.offset; {10869#true} is VALID [2022-02-20 21:35:38,078 INFO L290 TraceCheckUtils]: 32: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:38,078 INFO L284 TraceCheckUtils]: 33: Hoare quadruple {10869#true} {10869#true} #616#return; {10869#true} is VALID [2022-02-20 21:35:38,078 INFO L290 TraceCheckUtils]: 34: Hoare triple {10869#true} ibmpex_register_bmc_~tmp~14#1.base, ibmpex_register_bmc_~tmp~14#1.offset := ibmpex_register_bmc_#t~ret178#1.base, ibmpex_register_bmc_#t~ret178#1.offset;havoc ibmpex_register_bmc_#t~ret178#1.base, ibmpex_register_bmc_#t~ret178#1.offset;ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset := ibmpex_register_bmc_~tmp~14#1.base, ibmpex_register_bmc_~tmp~14#1.offset; {10869#true} is VALID [2022-02-20 21:35:38,078 INFO L290 TraceCheckUtils]: 35: Hoare triple {10869#true} assume !(0 == (ibmpex_register_bmc_~data~2#1.base + ibmpex_register_bmc_~data~2#1.offset) % 18446744073709551616);call write~int(12, ibmpex_register_bmc_~data~2#1.base, 193 + ibmpex_register_bmc_~data~2#1.offset, 4);call write~int(15, ibmpex_register_bmc_~data~2#1.base, 197 + ibmpex_register_bmc_~data~2#1.offset, 2);call write~int(0, ibmpex_register_bmc_~data~2#1.base, 199 + ibmpex_register_bmc_~data~2#1.offset, 1);call write~int(ibmpex_register_bmc_~iface#1, ibmpex_register_bmc_~data~2#1.base, 323 + ibmpex_register_bmc_~data~2#1.offset, 4);call write~$Pointer$(ibmpex_register_bmc_~dev#1.base, ibmpex_register_bmc_~dev#1.offset, ibmpex_register_bmc_~data~2#1.base, 24 + ibmpex_register_bmc_~data~2#1.offset, 8);call ibmpex_register_bmc_#t~mem180#1 := read~int(ibmpex_register_bmc_~data~2#1.base, 323 + ibmpex_register_bmc_~data~2#1.offset, 4);assume { :begin_inline_ipmi_create_user } true;ipmi_create_user_#in~arg0#1, ipmi_create_user_#in~arg1#1.base, ipmi_create_user_#in~arg1#1.offset, ipmi_create_user_#in~arg2#1.base, ipmi_create_user_#in~arg2#1.offset, ipmi_create_user_#in~arg3#1.base, ipmi_create_user_#in~arg3#1.offset := ibmpex_register_bmc_#t~mem180#1, ~#driver_data~0.base, 56 + ~#driver_data~0.offset, ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset, ibmpex_register_bmc_~data~2#1.base, 315 + ibmpex_register_bmc_~data~2#1.offset;havoc ipmi_create_user_#res#1;havoc ipmi_create_user_#t~nondet249#1, ipmi_create_user_~arg0#1, ipmi_create_user_~arg1#1.base, ipmi_create_user_~arg1#1.offset, ipmi_create_user_~arg2#1.base, ipmi_create_user_~arg2#1.offset, ipmi_create_user_~arg3#1.base, ipmi_create_user_~arg3#1.offset;ipmi_create_user_~arg0#1 := ipmi_create_user_#in~arg0#1;ipmi_create_user_~arg1#1.base, ipmi_create_user_~arg1#1.offset := ipmi_create_user_#in~arg1#1.base, ipmi_create_user_#in~arg1#1.offset;ipmi_create_user_~arg2#1.base, ipmi_create_user_~arg2#1.offset := ipmi_create_user_#in~arg2#1.base, ipmi_create_user_#in~arg2#1.offset;ipmi_create_user_~arg3#1.base, ipmi_create_user_~arg3#1.offset := ipmi_create_user_#in~arg3#1.base, ipmi_create_user_#in~arg3#1.offset;assume -2147483648 <= ipmi_create_user_#t~nondet249#1 && ipmi_create_user_#t~nondet249#1 <= 2147483647;ipmi_create_user_#res#1 := ipmi_create_user_#t~nondet249#1;havoc ipmi_create_user_#t~nondet249#1; {10869#true} is VALID [2022-02-20 21:35:38,079 INFO L290 TraceCheckUtils]: 36: Hoare triple {10869#true} ibmpex_register_bmc_#t~ret181#1 := ipmi_create_user_#res#1;assume { :end_inline_ipmi_create_user } true;assume -2147483648 <= ibmpex_register_bmc_#t~ret181#1 && ibmpex_register_bmc_#t~ret181#1 <= 2147483647;ibmpex_register_bmc_~err~4#1 := ibmpex_register_bmc_#t~ret181#1;havoc ibmpex_register_bmc_#t~mem180#1;havoc ibmpex_register_bmc_#t~ret181#1; {10869#true} is VALID [2022-02-20 21:35:38,079 INFO L290 TraceCheckUtils]: 37: Hoare triple {10869#true} assume !(ibmpex_register_bmc_~err~4#1 < 0);assume { :begin_inline___mutex_init } true;__mutex_init_#in~arg0#1.base, __mutex_init_#in~arg0#1.offset, __mutex_init_#in~arg1#1.base, __mutex_init_#in~arg1#1.offset, __mutex_init_#in~arg2#1.base, __mutex_init_#in~arg2#1.offset := ibmpex_register_bmc_~data~2#1.base, 32 + ibmpex_register_bmc_~data~2#1.offset, 22, 0, ibmpex_register_bmc_~#__key~1#1.base, ibmpex_register_bmc_~#__key~1#1.offset;havoc __mutex_init_~arg0#1.base, __mutex_init_~arg0#1.offset, __mutex_init_~arg1#1.base, __mutex_init_~arg1#1.offset, __mutex_init_~arg2#1.base, __mutex_init_~arg2#1.offset;__mutex_init_~arg0#1.base, __mutex_init_~arg0#1.offset := __mutex_init_#in~arg0#1.base, __mutex_init_#in~arg0#1.offset;__mutex_init_~arg1#1.base, __mutex_init_~arg1#1.offset := __mutex_init_#in~arg1#1.base, __mutex_init_#in~arg1#1.offset;__mutex_init_~arg2#1.base, __mutex_init_~arg2#1.offset := __mutex_init_#in~arg2#1.base, __mutex_init_#in~arg2#1.offset; {10869#true} is VALID [2022-02-20 21:35:38,079 INFO L290 TraceCheckUtils]: 38: Hoare triple {10869#true} assume { :end_inline___mutex_init } true;call write~int(0, ibmpex_register_bmc_~data~2#1.base, 611 + ibmpex_register_bmc_~data~2#1.offset, 8);assume { :begin_inline_init_completion } true;init_completion_#in~x#1.base, init_completion_#in~x#1.offset := ibmpex_register_bmc_~data~2#1.base, 231 + ibmpex_register_bmc_~data~2#1.offset;havoc init_completion_~x#1.base, init_completion_~x#1.offset, init_completion_~#__key~0#1.base, init_completion_~#__key~0#1.offset;init_completion_~x#1.base, init_completion_~x#1.offset := init_completion_#in~x#1.base, init_completion_#in~x#1.offset;call init_completion_~#__key~0#1.base, init_completion_~#__key~0#1.offset := #Ultimate.allocOnStack(8);call write~int(0, init_completion_~x#1.base, init_completion_~x#1.offset, 4);assume { :begin_inline___init_waitqueue_head } true;__init_waitqueue_head_#in~arg0#1.base, __init_waitqueue_head_#in~arg0#1.offset, __init_waitqueue_head_#in~arg1#1.base, __init_waitqueue_head_#in~arg1#1.offset := init_completion_~x#1.base, 4 + init_completion_~x#1.offset, init_completion_~#__key~0#1.base, init_completion_~#__key~0#1.offset;havoc __init_waitqueue_head_~arg0#1.base, __init_waitqueue_head_~arg0#1.offset, __init_waitqueue_head_~arg1#1.base, __init_waitqueue_head_~arg1#1.offset;__init_waitqueue_head_~arg0#1.base, __init_waitqueue_head_~arg0#1.offset := __init_waitqueue_head_#in~arg0#1.base, __init_waitqueue_head_#in~arg0#1.offset;__init_waitqueue_head_~arg1#1.base, __init_waitqueue_head_~arg1#1.offset := __init_waitqueue_head_#in~arg1#1.base, __init_waitqueue_head_#in~arg1#1.offset; {10869#true} is VALID [2022-02-20 21:35:38,079 INFO L290 TraceCheckUtils]: 39: Hoare triple {10869#true} assume { :end_inline___init_waitqueue_head } true;call ULTIMATE.dealloc(init_completion_~#__key~0#1.base, init_completion_~#__key~0#1.offset);havoc init_completion_~#__key~0#1.base, init_completion_~#__key~0#1.offset; {10869#true} is VALID [2022-02-20 21:35:38,079 INFO L290 TraceCheckUtils]: 40: Hoare triple {10869#true} assume { :end_inline_init_completion } true;call write~int(58, ibmpex_register_bmc_~data~2#1.base, 327 + ibmpex_register_bmc_~data~2#1.offset, 1);call write~int(60, ibmpex_register_bmc_~data~2#1.base, 328 + ibmpex_register_bmc_~data~2#1.offset, 1);call write~$Pointer$(ibmpex_register_bmc_~data~2#1.base, 339 + ibmpex_register_bmc_~data~2#1.offset, ibmpex_register_bmc_~data~2#1.base, 331 + ibmpex_register_bmc_~data~2#1.offset, 8);assume { :begin_inline_ibmpex_ver_check } true;ibmpex_ver_check_#in~data#1.base, ibmpex_ver_check_#in~data#1.offset := ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset;havoc ibmpex_ver_check_#res#1;havoc ibmpex_ver_check_#t~ret71#1, ibmpex_ver_check_#t~mem72#1, ibmpex_ver_check_#t~mem73#1, ibmpex_ver_check_#t~short74#1, ibmpex_ver_check_#t~mem75#1, ibmpex_ver_check_#t~mem76#1, ibmpex_ver_check_#t~ret77#1, ibmpex_ver_check_#t~nondet78#1, ibmpex_ver_check_#t~mem79#1.base, ibmpex_ver_check_#t~mem79#1.offset, ibmpex_ver_check_#t~mem80#1, ibmpex_ver_check_#t~mem81#1, ibmpex_ver_check_#t~mem82#1, ibmpex_ver_check_#t~mem83#1, ibmpex_ver_check_#t~mem84#1, ibmpex_ver_check_~data#1.base, ibmpex_ver_check_~data#1.offset, ibmpex_ver_check_~tmp~4#1;ibmpex_ver_check_~data#1.base, ibmpex_ver_check_~data#1.offset := ibmpex_ver_check_#in~data#1.base, ibmpex_ver_check_#in~data#1.offset;havoc ibmpex_ver_check_~tmp~4#1;call write~int(1, ibmpex_ver_check_~data#1.base, 339 + ibmpex_ver_check_~data#1.offset, 1);call write~int(1, ibmpex_ver_check_~data#1.base, 329 + ibmpex_ver_check_~data#1.offset, 2); {10869#true} is VALID [2022-02-20 21:35:38,080 INFO L272 TraceCheckUtils]: 41: Hoare triple {10869#true} call ibmpex_ver_check_#t~ret71#1 := ibmpex_send_message(ibmpex_ver_check_~data#1.base, ibmpex_ver_check_~data#1.offset); {10961#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} is VALID [2022-02-20 21:35:38,080 INFO L290 TraceCheckUtils]: 42: Hoare triple {10961#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;havoc ~err~0#1;assume { :begin_inline_ipmi_validate_addr } true;ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset, ipmi_validate_addr_#in~arg1#1 := ~data#1.base, 193 + ~data#1.offset, 40;havoc ipmi_validate_addr_#res#1;havoc ipmi_validate_addr_#t~nondet254#1, ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset, ipmi_validate_addr_~arg1#1;ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset := ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset;ipmi_validate_addr_~arg1#1 := ipmi_validate_addr_#in~arg1#1;assume -2147483648 <= ipmi_validate_addr_#t~nondet254#1 && ipmi_validate_addr_#t~nondet254#1 <= 2147483647;ipmi_validate_addr_#res#1 := ipmi_validate_addr_#t~nondet254#1;havoc ipmi_validate_addr_#t~nondet254#1; {10869#true} is VALID [2022-02-20 21:35:38,080 INFO L290 TraceCheckUtils]: 43: Hoare triple {10869#true} #t~ret62#1 := ipmi_validate_addr_#res#1;assume { :end_inline_ipmi_validate_addr } true;assume -2147483648 <= #t~ret62#1 && #t~ret62#1 <= 2147483647;~err~0#1 := #t~ret62#1;havoc #t~ret62#1; {10869#true} is VALID [2022-02-20 21:35:38,081 INFO L290 TraceCheckUtils]: 44: Hoare triple {10869#true} assume 0 != ~err~0#1; {10869#true} is VALID [2022-02-20 21:35:38,081 INFO L290 TraceCheckUtils]: 45: Hoare triple {10869#true} havoc #t~nondet69#1;call #t~mem70#1.base, #t~mem70#1.offset := read~$Pointer$(~data#1.base, 24 + ~data#1.offset, 8);havoc #t~mem70#1.base, #t~mem70#1.offset;#res#1 := ~err~0#1; {10869#true} is VALID [2022-02-20 21:35:38,081 INFO L290 TraceCheckUtils]: 46: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:38,081 INFO L284 TraceCheckUtils]: 47: Hoare quadruple {10869#true} {10869#true} #618#return; {10869#true} is VALID [2022-02-20 21:35:38,081 INFO L290 TraceCheckUtils]: 48: Hoare triple {10869#true} assume -2147483648 <= ibmpex_ver_check_#t~ret71#1 && ibmpex_ver_check_#t~ret71#1 <= 2147483647;havoc ibmpex_ver_check_#t~ret71#1; {10869#true} is VALID [2022-02-20 21:35:38,082 INFO L272 TraceCheckUtils]: 49: Hoare triple {10869#true} call wait_for_completion(ibmpex_ver_check_~data#1.base, 231 + ibmpex_ver_check_~data#1.offset); {10869#true} is VALID [2022-02-20 21:35:38,082 INFO L290 TraceCheckUtils]: 50: Hoare triple {10869#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset; {10869#true} is VALID [2022-02-20 21:35:38,082 INFO L290 TraceCheckUtils]: 51: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:38,082 INFO L284 TraceCheckUtils]: 52: Hoare quadruple {10869#true} {10869#true} #620#return; {10869#true} is VALID [2022-02-20 21:35:38,082 INFO L290 TraceCheckUtils]: 53: Hoare triple {10869#true} call ibmpex_ver_check_#t~mem72#1 := read~int(ibmpex_ver_check_~data#1.base, 899 + ibmpex_ver_check_~data#1.offset, 1);ibmpex_ver_check_#t~short74#1 := 0 != ibmpex_ver_check_#t~mem72#1 % 256 % 4294967296; {10869#true} is VALID [2022-02-20 21:35:38,082 INFO L290 TraceCheckUtils]: 54: Hoare triple {10869#true} assume !ibmpex_ver_check_#t~short74#1;call ibmpex_ver_check_#t~mem73#1 := read~int(ibmpex_ver_check_~data#1.base, 891 + ibmpex_ver_check_~data#1.offset, 8);ibmpex_ver_check_#t~short74#1 := 6 != ibmpex_ver_check_#t~mem73#1 % 18446744073709551616; {10869#true} is VALID [2022-02-20 21:35:38,083 INFO L290 TraceCheckUtils]: 55: Hoare triple {10869#true} assume !ibmpex_ver_check_#t~short74#1;havoc ibmpex_ver_check_#t~mem72#1;havoc ibmpex_ver_check_#t~mem73#1;havoc ibmpex_ver_check_#t~short74#1;call ibmpex_ver_check_#t~mem75#1 := read~int(ibmpex_ver_check_~data#1.base, 619 + ibmpex_ver_check_~data#1.offset, 1);call write~int(ibmpex_ver_check_#t~mem75#1, ibmpex_ver_check_~data#1.base, 904 + ibmpex_ver_check_~data#1.offset, 1);havoc ibmpex_ver_check_#t~mem75#1;call ibmpex_ver_check_#t~mem76#1 := read~int(ibmpex_ver_check_~data#1.base, 620 + ibmpex_ver_check_~data#1.offset, 1);call write~int(ibmpex_ver_check_#t~mem76#1, ibmpex_ver_check_~data#1.base, 905 + ibmpex_ver_check_~data#1.offset, 1);havoc ibmpex_ver_check_#t~mem76#1; {10869#true} is VALID [2022-02-20 21:35:38,083 INFO L272 TraceCheckUtils]: 56: Hoare triple {10869#true} call ibmpex_ver_check_#t~ret77#1 := extract_value(ibmpex_ver_check_~data#1.base, 619 + ibmpex_ver_check_~data#1.offset, 2); {10869#true} is VALID [2022-02-20 21:35:38,083 INFO L290 TraceCheckUtils]: 57: Hoare triple {10869#true} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;~offset#1 := #in~offset#1;havoc ~tmp~3#1;assume { :begin_inline___be16_to_cpup } true;__be16_to_cpup_#in~p#1.base, __be16_to_cpup_#in~p#1.offset := ~data#1.base, ~data#1.offset + 2 * (if ~offset#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then ~offset#1 % 18446744073709551616 % 18446744073709551616 else ~offset#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616);havoc __be16_to_cpup_#res#1;havoc __be16_to_cpup_#t~ret3#1, __be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset, __be16_to_cpup_~tmp~1#1;__be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset := __be16_to_cpup_#in~p#1.base, __be16_to_cpup_#in~p#1.offset;havoc __be16_to_cpup_~tmp~1#1;assume { :begin_inline___swab16p } true;__swab16p_#in~p#1.base, __swab16p_#in~p#1.offset := __be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset;havoc __swab16p_#res#1;havoc __swab16p_#t~mem1#1, __swab16p_#t~ret2#1, __swab16p_~p#1.base, __swab16p_~p#1.offset, __swab16p_~tmp~0#1;__swab16p_~p#1.base, __swab16p_~p#1.offset := __swab16p_#in~p#1.base, __swab16p_#in~p#1.offset;havoc __swab16p_~tmp~0#1;call __swab16p_#t~mem1#1 := read~int(__swab16p_~p#1.base, __swab16p_~p#1.offset, 2);assume { :begin_inline___fswab16 } true;__fswab16_#in~val#1 := __swab16p_#t~mem1#1 % 65536;havoc __fswab16_#res#1;havoc __fswab16_~val#1;__fswab16_~val#1 := __fswab16_#in~val#1;__fswab16_#res#1 := (if (1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) || 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536)) && 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) then (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) else (if 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) && (1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) || 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536)) then (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) else (if (1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) && (1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) || 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536))) || ((1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) || 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536)) && 1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536)) then 1 else ~bitwiseOr((if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536), (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536))))); {10869#true} is VALID [2022-02-20 21:35:38,083 INFO L290 TraceCheckUtils]: 58: Hoare triple {10869#true} __swab16p_#t~ret2#1 := __fswab16_#res#1;assume { :end_inline___fswab16 } true;__swab16p_~tmp~0#1 := __swab16p_#t~ret2#1;havoc __swab16p_#t~mem1#1;havoc __swab16p_#t~ret2#1;__swab16p_#res#1 := __swab16p_~tmp~0#1; {10869#true} is VALID [2022-02-20 21:35:38,083 INFO L290 TraceCheckUtils]: 59: Hoare triple {10869#true} __be16_to_cpup_#t~ret3#1 := __swab16p_#res#1;assume { :end_inline___swab16p } true;__be16_to_cpup_~tmp~1#1 := __be16_to_cpup_#t~ret3#1;havoc __be16_to_cpup_#t~ret3#1;__be16_to_cpup_#res#1 := __be16_to_cpup_~tmp~1#1; {10869#true} is VALID [2022-02-20 21:35:38,084 INFO L290 TraceCheckUtils]: 60: Hoare triple {10869#true} #t~ret61#1 := __be16_to_cpup_#res#1;assume { :end_inline___be16_to_cpup } true;~tmp~3#1 := #t~ret61#1;havoc #t~ret61#1;#res#1 := ~tmp~3#1; {10869#true} is VALID [2022-02-20 21:35:38,084 INFO L290 TraceCheckUtils]: 61: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:38,084 INFO L284 TraceCheckUtils]: 62: Hoare quadruple {10869#true} {10869#true} #622#return; {10869#true} is VALID [2022-02-20 21:35:38,084 INFO L290 TraceCheckUtils]: 63: Hoare triple {10869#true} ibmpex_ver_check_~tmp~4#1 := ibmpex_ver_check_#t~ret77#1;havoc ibmpex_ver_check_#t~ret77#1;havoc ibmpex_ver_check_#t~nondet78#1;call ibmpex_ver_check_#t~mem79#1.base, ibmpex_ver_check_#t~mem79#1.offset := read~$Pointer$(ibmpex_ver_check_~data#1.base, 24 + ibmpex_ver_check_~data#1.offset, 8);call ibmpex_ver_check_#t~mem80#1 := read~int(ibmpex_ver_check_~data#1.base, 904 + ibmpex_ver_check_~data#1.offset, 1);call ibmpex_ver_check_#t~mem81#1 := read~int(ibmpex_ver_check_~data#1.base, 905 + ibmpex_ver_check_~data#1.offset, 1);call ibmpex_ver_check_#t~mem82#1 := read~int(ibmpex_ver_check_~data#1.base, 623 + ibmpex_ver_check_~data#1.offset, 1);call ibmpex_ver_check_#t~mem83#1 := read~int(ibmpex_ver_check_~data#1.base, 624 + ibmpex_ver_check_~data#1.offset, 1);call ibmpex_ver_check_#t~mem84#1 := read~int(ibmpex_ver_check_~data#1.base, 323 + ibmpex_ver_check_~data#1.offset, 4);havoc ibmpex_ver_check_#t~mem79#1.base, ibmpex_ver_check_#t~mem79#1.offset;havoc ibmpex_ver_check_#t~mem80#1;havoc ibmpex_ver_check_#t~mem81#1;havoc ibmpex_ver_check_#t~mem82#1;havoc ibmpex_ver_check_#t~mem83#1;havoc ibmpex_ver_check_#t~mem84#1;ibmpex_ver_check_#res#1 := 0; {10869#true} is VALID [2022-02-20 21:35:38,084 INFO L290 TraceCheckUtils]: 64: Hoare triple {10869#true} ibmpex_register_bmc_#t~ret184#1 := ibmpex_ver_check_#res#1;assume { :end_inline_ibmpex_ver_check } true;assume -2147483648 <= ibmpex_register_bmc_#t~ret184#1 && ibmpex_register_bmc_#t~ret184#1 <= 2147483647;ibmpex_register_bmc_~err~4#1 := ibmpex_register_bmc_#t~ret184#1;havoc ibmpex_register_bmc_#t~ret184#1; {10869#true} is VALID [2022-02-20 21:35:38,084 INFO L290 TraceCheckUtils]: 65: Hoare triple {10869#true} assume !(0 != ibmpex_register_bmc_~err~4#1);call ibmpex_register_bmc_#t~mem185#1.base, ibmpex_register_bmc_#t~mem185#1.offset := read~$Pointer$(ibmpex_register_bmc_~data~2#1.base, 24 + ibmpex_register_bmc_~data~2#1.offset, 8);assume { :begin_inline_hwmon_device_register } true;hwmon_device_register_#in~arg0#1.base, hwmon_device_register_#in~arg0#1.offset := ibmpex_register_bmc_#t~mem185#1.base, ibmpex_register_bmc_#t~mem185#1.offset;havoc hwmon_device_register_#res#1.base, hwmon_device_register_#res#1.offset;havoc hwmon_device_register_#t~ret248#1.base, hwmon_device_register_#t~ret248#1.offset, hwmon_device_register_~arg0#1.base, hwmon_device_register_~arg0#1.offset;hwmon_device_register_~arg0#1.base, hwmon_device_register_~arg0#1.offset := hwmon_device_register_#in~arg0#1.base, hwmon_device_register_#in~arg0#1.offset; {10869#true} is VALID [2022-02-20 21:35:38,085 INFO L272 TraceCheckUtils]: 66: Hoare triple {10869#true} call hwmon_device_register_#t~ret248#1.base, hwmon_device_register_#t~ret248#1.offset := ldv_malloc(1035); {10946#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:38,085 INFO L290 TraceCheckUtils]: 67: Hoare triple {10946#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {10869#true} is VALID [2022-02-20 21:35:38,085 INFO L290 TraceCheckUtils]: 68: Hoare triple {10869#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {10869#true} is VALID [2022-02-20 21:35:38,085 INFO L290 TraceCheckUtils]: 69: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:38,086 INFO L284 TraceCheckUtils]: 70: Hoare quadruple {10869#true} {10869#true} #624#return; {10869#true} is VALID [2022-02-20 21:35:38,086 INFO L290 TraceCheckUtils]: 71: Hoare triple {10869#true} hwmon_device_register_#res#1.base, hwmon_device_register_#res#1.offset := hwmon_device_register_#t~ret248#1.base, hwmon_device_register_#t~ret248#1.offset;havoc hwmon_device_register_#t~ret248#1.base, hwmon_device_register_#t~ret248#1.offset; {10869#true} is VALID [2022-02-20 21:35:38,086 INFO L290 TraceCheckUtils]: 72: Hoare triple {10869#true} ibmpex_register_bmc_#t~ret186#1.base, ibmpex_register_bmc_#t~ret186#1.offset := hwmon_device_register_#res#1.base, hwmon_device_register_#res#1.offset;assume { :end_inline_hwmon_device_register } true;call write~$Pointer$(ibmpex_register_bmc_#t~ret186#1.base, ibmpex_register_bmc_#t~ret186#1.offset, ibmpex_register_bmc_~data~2#1.base, 16 + ibmpex_register_bmc_~data~2#1.offset, 8);havoc ibmpex_register_bmc_#t~mem185#1.base, ibmpex_register_bmc_#t~mem185#1.offset;havoc ibmpex_register_bmc_#t~ret186#1.base, ibmpex_register_bmc_#t~ret186#1.offset;call ibmpex_register_bmc_#t~mem187#1.base, ibmpex_register_bmc_#t~mem187#1.offset := read~$Pointer$(ibmpex_register_bmc_~data~2#1.base, 16 + ibmpex_register_bmc_~data~2#1.offset, 8);assume { :begin_inline_IS_ERR } true;IS_ERR_#in~ptr#1.base, IS_ERR_#in~ptr#1.offset := ibmpex_register_bmc_#t~mem187#1.base, ibmpex_register_bmc_#t~mem187#1.offset;havoc IS_ERR_#res#1;havoc IS_ERR_#t~ret240#1, IS_ERR_~ptr#1.base, IS_ERR_~ptr#1.offset, IS_ERR_~tmp~18#1;IS_ERR_~ptr#1.base, IS_ERR_~ptr#1.offset := IS_ERR_#in~ptr#1.base, IS_ERR_#in~ptr#1.offset;havoc IS_ERR_~tmp~18#1; {10869#true} is VALID [2022-02-20 21:35:38,086 INFO L272 TraceCheckUtils]: 73: Hoare triple {10869#true} call IS_ERR_#t~ret240#1 := ldv_is_err(IS_ERR_~ptr#1.base, IS_ERR_~ptr#1.offset); {10869#true} is VALID [2022-02-20 21:35:38,086 INFO L290 TraceCheckUtils]: 74: Hoare triple {10869#true} ~ptr.base, ~ptr.offset := #in~ptr.base, #in~ptr.offset;#res := (if (~ptr.base + ~ptr.offset) % 18446744073709551616 > 2012 then 1 else 0); {10869#true} is VALID [2022-02-20 21:35:38,087 INFO L290 TraceCheckUtils]: 75: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:38,087 INFO L284 TraceCheckUtils]: 76: Hoare quadruple {10869#true} {10869#true} #626#return; {10869#true} is VALID [2022-02-20 21:35:38,087 INFO L290 TraceCheckUtils]: 77: Hoare triple {10869#true} assume -9223372036854775808 <= IS_ERR_#t~ret240#1 && IS_ERR_#t~ret240#1 <= 9223372036854775807;IS_ERR_~tmp~18#1 := IS_ERR_#t~ret240#1;havoc IS_ERR_#t~ret240#1;IS_ERR_#res#1 := IS_ERR_~tmp~18#1; {10869#true} is VALID [2022-02-20 21:35:38,087 INFO L290 TraceCheckUtils]: 78: Hoare triple {10869#true} ibmpex_register_bmc_#t~ret188#1 := IS_ERR_#res#1;assume { :end_inline_IS_ERR } true;assume -9223372036854775808 <= ibmpex_register_bmc_#t~ret188#1 && ibmpex_register_bmc_#t~ret188#1 <= 9223372036854775807;ibmpex_register_bmc_~tmp___0~3#1 := ibmpex_register_bmc_#t~ret188#1;havoc ibmpex_register_bmc_#t~mem187#1.base, ibmpex_register_bmc_#t~mem187#1.offset;havoc ibmpex_register_bmc_#t~ret188#1; {10869#true} is VALID [2022-02-20 21:35:38,087 INFO L290 TraceCheckUtils]: 79: Hoare triple {10869#true} assume !(0 != ibmpex_register_bmc_~tmp___0~3#1); {10869#true} is VALID [2022-02-20 21:35:38,087 INFO L272 TraceCheckUtils]: 80: Hoare triple {10869#true} call dev_set_drvdata(ibmpex_register_bmc_~dev#1.base, ibmpex_register_bmc_~dev#1.offset, ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset); {10869#true} is VALID [2022-02-20 21:35:38,088 INFO L290 TraceCheckUtils]: 81: Hoare triple {10869#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset;~arg1.base, ~arg1.offset := #in~arg1.base, #in~arg1.offset; {10869#true} is VALID [2022-02-20 21:35:38,088 INFO L290 TraceCheckUtils]: 82: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:38,088 INFO L284 TraceCheckUtils]: 83: Hoare quadruple {10869#true} {10869#true} #628#return; {10869#true} is VALID [2022-02-20 21:35:38,088 INFO L290 TraceCheckUtils]: 84: Hoare triple {10869#true} assume { :begin_inline_list_add_tail } true;list_add_tail_#in~new#1.base, list_add_tail_#in~new#1.offset, list_add_tail_#in~head#1.base, list_add_tail_#in~head#1.offset := ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset, ~#driver_data~0.base, ~#driver_data~0.offset;havoc list_add_tail_#t~mem12#1.base, list_add_tail_#t~mem12#1.offset, list_add_tail_~new#1.base, list_add_tail_~new#1.offset, list_add_tail_~head#1.base, list_add_tail_~head#1.offset;list_add_tail_~new#1.base, list_add_tail_~new#1.offset := list_add_tail_#in~new#1.base, list_add_tail_#in~new#1.offset;list_add_tail_~head#1.base, list_add_tail_~head#1.offset := list_add_tail_#in~head#1.base, list_add_tail_#in~head#1.offset;call list_add_tail_#t~mem12#1.base, list_add_tail_#t~mem12#1.offset := read~$Pointer$(list_add_tail_~head#1.base, 8 + list_add_tail_~head#1.offset, 8);assume { :begin_inline___list_add } true;__list_add_#in~arg0#1.base, __list_add_#in~arg0#1.offset, __list_add_#in~arg1#1.base, __list_add_#in~arg1#1.offset, __list_add_#in~arg2#1.base, __list_add_#in~arg2#1.offset := list_add_tail_~new#1.base, list_add_tail_~new#1.offset, list_add_tail_#t~mem12#1.base, list_add_tail_#t~mem12#1.offset, list_add_tail_~head#1.base, list_add_tail_~head#1.offset;havoc __list_add_~arg0#1.base, __list_add_~arg0#1.offset, __list_add_~arg1#1.base, __list_add_~arg1#1.offset, __list_add_~arg2#1.base, __list_add_~arg2#1.offset;__list_add_~arg0#1.base, __list_add_~arg0#1.offset := __list_add_#in~arg0#1.base, __list_add_#in~arg0#1.offset;__list_add_~arg1#1.base, __list_add_~arg1#1.offset := __list_add_#in~arg1#1.base, __list_add_#in~arg1#1.offset;__list_add_~arg2#1.base, __list_add_~arg2#1.offset := __list_add_#in~arg2#1.base, __list_add_#in~arg2#1.offset; {10869#true} is VALID [2022-02-20 21:35:38,088 INFO L290 TraceCheckUtils]: 85: Hoare triple {10869#true} assume { :end_inline___list_add } true;havoc list_add_tail_#t~mem12#1.base, list_add_tail_#t~mem12#1.offset; {10869#true} is VALID [2022-02-20 21:35:38,089 INFO L290 TraceCheckUtils]: 86: Hoare triple {10869#true} assume { :end_inline_list_add_tail } true;assume { :begin_inline_ibmpex_find_sensors } true;ibmpex_find_sensors_#in~data#1.base, ibmpex_find_sensors_#in~data#1.offset := ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset;havoc ibmpex_find_sensors_#res#1;havoc ibmpex_find_sensors_#t~ret148#1, ibmpex_find_sensors_#t~mem149#1, ibmpex_find_sensors_#t~ret150#1.base, ibmpex_find_sensors_#t~ret150#1.offset, ibmpex_find_sensors_#t~mem151#1.base, ibmpex_find_sensors_#t~mem151#1.offset, ibmpex_find_sensors_#t~ret152#1, ibmpex_find_sensors_#t~mem153#1, ibmpex_find_sensors_#t~ret154#1, ibmpex_find_sensors_#t~mem155#1.base, ibmpex_find_sensors_#t~mem155#1.offset, ibmpex_find_sensors_#t~mem156#1, ibmpex_find_sensors_#t~ret157#1, ibmpex_find_sensors_#t~mem158#1, ibmpex_find_sensors_#t~ret159#1, ibmpex_find_sensors_#t~mem160#1.base, ibmpex_find_sensors_#t~mem160#1.offset, ibmpex_find_sensors_#t~mem161#1.base, ibmpex_find_sensors_#t~mem161#1.offset, ibmpex_find_sensors_#t~ret162#1, ibmpex_find_sensors_#t~mem163#1, ibmpex_find_sensors_#t~mem164#1.base, ibmpex_find_sensors_#t~mem164#1.offset, ibmpex_find_sensors_#t~ret165#1, ibmpex_find_sensors_#t~mem166#1.base, ibmpex_find_sensors_#t~mem166#1.offset, ibmpex_find_sensors_#t~ret167#1, ibmpex_find_sensors_#t~mem168#1.base, ibmpex_find_sensors_#t~mem168#1.offset, ibmpex_find_sensors_#t~mem169#1.base, ibmpex_find_sensors_#t~mem169#1.offset, ibmpex_find_sensors_#t~mem170#1.base, ibmpex_find_sensors_#t~mem170#1.offset, ibmpex_find_sensors_#t~mem171#1.base, ibmpex_find_sensors_#t~mem171#1.offset, ibmpex_find_sensors_#t~mem172#1.base, ibmpex_find_sensors_#t~mem172#1.offset, ibmpex_find_sensors_#t~mem173#1.base, ibmpex_find_sensors_#t~mem173#1.offset, ibmpex_find_sensors_#t~mem174#1.base, ibmpex_find_sensors_#t~mem174#1.offset, ibmpex_find_sensors_#t~mem175#1.base, ibmpex_find_sensors_#t~mem175#1.offset, ibmpex_find_sensors_#t~mem176#1, ibmpex_find_sensors_#t~mem177#1.base, ibmpex_find_sensors_#t~mem177#1.offset, ibmpex_find_sensors_~data#1.base, ibmpex_find_sensors_~data#1.offset, ibmpex_find_sensors_~i~2#1, ibmpex_find_sensors_~j~0#1, ibmpex_find_sensors_~err~3#1, ibmpex_find_sensors_~sensor_type~0#1, ibmpex_find_sensors_~sensor_counter~0#1, ibmpex_find_sensors_~num_power~0#1, ibmpex_find_sensors_~num_temp~0#1, ibmpex_find_sensors_~tmp~13#1.base, ibmpex_find_sensors_~tmp~13#1.offset, ibmpex_find_sensors_~tmp___0~2#1, ibmpex_find_sensors_~tmp___1~1#1;ibmpex_find_sensors_~data#1.base, ibmpex_find_sensors_~data#1.offset := ibmpex_find_sensors_#in~data#1.base, ibmpex_find_sensors_#in~data#1.offset;havoc ibmpex_find_sensors_~i~2#1;havoc ibmpex_find_sensors_~j~0#1;havoc ibmpex_find_sensors_~err~3#1;havoc ibmpex_find_sensors_~sensor_type~0#1;havoc ibmpex_find_sensors_~sensor_counter~0#1;havoc ibmpex_find_sensors_~num_power~0#1;havoc ibmpex_find_sensors_~num_temp~0#1;havoc ibmpex_find_sensors_~tmp~13#1.base, ibmpex_find_sensors_~tmp~13#1.offset;havoc ibmpex_find_sensors_~tmp___0~2#1;havoc ibmpex_find_sensors_~tmp___1~1#1;ibmpex_find_sensors_~num_power~0#1 := 0;ibmpex_find_sensors_~num_temp~0#1 := 0;assume { :begin_inline_ibmpex_query_sensor_count } true;ibmpex_query_sensor_count_#in~data#1.base, ibmpex_query_sensor_count_#in~data#1.offset := ibmpex_find_sensors_~data#1.base, ibmpex_find_sensors_~data#1.offset;havoc ibmpex_query_sensor_count_#res#1;havoc ibmpex_query_sensor_count_#t~ret85#1, ibmpex_query_sensor_count_#t~mem86#1, ibmpex_query_sensor_count_#t~mem87#1, ibmpex_query_sensor_count_#t~short88#1, ibmpex_query_sensor_count_#t~mem89#1, ibmpex_query_sensor_count_~data#1.base, ibmpex_query_sensor_count_~data#1.offset;ibmpex_query_sensor_count_~data#1.base, ibmpex_query_sensor_count_~data#1.offset := ibmpex_query_sensor_count_#in~data#1.base, ibmpex_query_sensor_count_#in~data#1.offset;call write~int(2, ibmpex_query_sensor_count_~data#1.base, 339 + ibmpex_query_sensor_count_~data#1.offset, 1);call write~int(1, ibmpex_query_sensor_count_~data#1.base, 329 + ibmpex_query_sensor_count_~data#1.offset, 2); {10869#true} is VALID [2022-02-20 21:35:38,089 INFO L272 TraceCheckUtils]: 87: Hoare triple {10869#true} call ibmpex_query_sensor_count_#t~ret85#1 := ibmpex_send_message(ibmpex_query_sensor_count_~data#1.base, ibmpex_query_sensor_count_~data#1.offset); {10961#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} is VALID [2022-02-20 21:35:38,089 INFO L290 TraceCheckUtils]: 88: Hoare triple {10961#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;havoc ~err~0#1;assume { :begin_inline_ipmi_validate_addr } true;ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset, ipmi_validate_addr_#in~arg1#1 := ~data#1.base, 193 + ~data#1.offset, 40;havoc ipmi_validate_addr_#res#1;havoc ipmi_validate_addr_#t~nondet254#1, ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset, ipmi_validate_addr_~arg1#1;ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset := ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset;ipmi_validate_addr_~arg1#1 := ipmi_validate_addr_#in~arg1#1;assume -2147483648 <= ipmi_validate_addr_#t~nondet254#1 && ipmi_validate_addr_#t~nondet254#1 <= 2147483647;ipmi_validate_addr_#res#1 := ipmi_validate_addr_#t~nondet254#1;havoc ipmi_validate_addr_#t~nondet254#1; {10869#true} is VALID [2022-02-20 21:35:38,090 INFO L290 TraceCheckUtils]: 89: Hoare triple {10869#true} #t~ret62#1 := ipmi_validate_addr_#res#1;assume { :end_inline_ipmi_validate_addr } true;assume -2147483648 <= #t~ret62#1 && #t~ret62#1 <= 2147483647;~err~0#1 := #t~ret62#1;havoc #t~ret62#1; {10869#true} is VALID [2022-02-20 21:35:38,090 INFO L290 TraceCheckUtils]: 90: Hoare triple {10869#true} assume 0 != ~err~0#1; {10869#true} is VALID [2022-02-20 21:35:38,090 INFO L290 TraceCheckUtils]: 91: Hoare triple {10869#true} havoc #t~nondet69#1;call #t~mem70#1.base, #t~mem70#1.offset := read~$Pointer$(~data#1.base, 24 + ~data#1.offset, 8);havoc #t~mem70#1.base, #t~mem70#1.offset;#res#1 := ~err~0#1; {10869#true} is VALID [2022-02-20 21:35:38,090 INFO L290 TraceCheckUtils]: 92: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:38,090 INFO L284 TraceCheckUtils]: 93: Hoare quadruple {10869#true} {10869#true} #630#return; {10869#true} is VALID [2022-02-20 21:35:38,091 INFO L290 TraceCheckUtils]: 94: Hoare triple {10869#true} assume -2147483648 <= ibmpex_query_sensor_count_#t~ret85#1 && ibmpex_query_sensor_count_#t~ret85#1 <= 2147483647;havoc ibmpex_query_sensor_count_#t~ret85#1; {10869#true} is VALID [2022-02-20 21:35:38,091 INFO L272 TraceCheckUtils]: 95: Hoare triple {10869#true} call wait_for_completion(ibmpex_query_sensor_count_~data#1.base, 231 + ibmpex_query_sensor_count_~data#1.offset); {10869#true} is VALID [2022-02-20 21:35:38,091 INFO L290 TraceCheckUtils]: 96: Hoare triple {10869#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset; {10869#true} is VALID [2022-02-20 21:35:38,091 INFO L290 TraceCheckUtils]: 97: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:38,091 INFO L284 TraceCheckUtils]: 98: Hoare quadruple {10869#true} {10869#true} #632#return; {10869#true} is VALID [2022-02-20 21:35:38,091 INFO L290 TraceCheckUtils]: 99: Hoare triple {10869#true} call ibmpex_query_sensor_count_#t~mem86#1 := read~int(ibmpex_query_sensor_count_~data#1.base, 899 + ibmpex_query_sensor_count_~data#1.offset, 1);ibmpex_query_sensor_count_#t~short88#1 := 0 != ibmpex_query_sensor_count_#t~mem86#1 % 256 % 4294967296; {10869#true} is VALID [2022-02-20 21:35:38,092 INFO L290 TraceCheckUtils]: 100: Hoare triple {10869#true} assume !ibmpex_query_sensor_count_#t~short88#1;call ibmpex_query_sensor_count_#t~mem87#1 := read~int(ibmpex_query_sensor_count_~data#1.base, 891 + ibmpex_query_sensor_count_~data#1.offset, 8);ibmpex_query_sensor_count_#t~short88#1 := 1 != ibmpex_query_sensor_count_#t~mem87#1 % 18446744073709551616; {10869#true} is VALID [2022-02-20 21:35:38,092 INFO L290 TraceCheckUtils]: 101: Hoare triple {10869#true} assume !ibmpex_query_sensor_count_#t~short88#1;havoc ibmpex_query_sensor_count_#t~mem86#1;havoc ibmpex_query_sensor_count_#t~mem87#1;havoc ibmpex_query_sensor_count_#t~short88#1;call ibmpex_query_sensor_count_#t~mem89#1 := read~int(ibmpex_query_sensor_count_~data#1.base, 619 + ibmpex_query_sensor_count_~data#1.offset, 1);ibmpex_query_sensor_count_#res#1 := ibmpex_query_sensor_count_#t~mem89#1 % 256;havoc ibmpex_query_sensor_count_#t~mem89#1; {10869#true} is VALID [2022-02-20 21:35:38,092 INFO L290 TraceCheckUtils]: 102: Hoare triple {10869#true} ibmpex_find_sensors_#t~ret148#1 := ibmpex_query_sensor_count_#res#1;assume { :end_inline_ibmpex_query_sensor_count } true;assume -2147483648 <= ibmpex_find_sensors_#t~ret148#1 && ibmpex_find_sensors_#t~ret148#1 <= 2147483647;ibmpex_find_sensors_~err~3#1 := ibmpex_find_sensors_#t~ret148#1;havoc ibmpex_find_sensors_#t~ret148#1; {10869#true} is VALID [2022-02-20 21:35:38,092 INFO L290 TraceCheckUtils]: 103: Hoare triple {10869#true} assume !(ibmpex_find_sensors_~err~3#1 <= 0);call write~int(ibmpex_find_sensors_~err~3#1, ibmpex_find_sensors_~data#1.base, 906 + ibmpex_find_sensors_~data#1.offset, 1);call ibmpex_find_sensors_#t~mem149#1 := read~int(ibmpex_find_sensors_~data#1.base, 906 + ibmpex_find_sensors_~data#1.offset, 1); {10869#true} is VALID [2022-02-20 21:35:38,093 INFO L272 TraceCheckUtils]: 104: Hoare triple {10869#true} call ibmpex_find_sensors_#t~ret150#1.base, ibmpex_find_sensors_#t~ret150#1.offset := kzalloc(184 * (ibmpex_find_sensors_#t~mem149#1 % 256), 208); {10946#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:38,093 INFO L290 TraceCheckUtils]: 105: Hoare triple {10946#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size;~flags := #in~flags;havoc ~tmp~2.base, ~tmp~2.offset; {10869#true} is VALID [2022-02-20 21:35:38,094 INFO L272 TraceCheckUtils]: 106: Hoare triple {10869#true} call #t~ret40.base, #t~ret40.offset := kmalloc(~size, ~bitwiseOr(~flags, 32768)); {10946#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:38,094 INFO L290 TraceCheckUtils]: 107: Hoare triple {10946#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {10869#true} is VALID [2022-02-20 21:35:38,094 INFO L272 TraceCheckUtils]: 108: Hoare triple {10869#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {10946#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:38,094 INFO L290 TraceCheckUtils]: 109: Hoare triple {10946#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {10869#true} is VALID [2022-02-20 21:35:38,095 INFO L290 TraceCheckUtils]: 110: Hoare triple {10869#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {10869#true} is VALID [2022-02-20 21:35:38,095 INFO L290 TraceCheckUtils]: 111: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:38,095 INFO L284 TraceCheckUtils]: 112: Hoare quadruple {10869#true} {10869#true} #590#return; {10869#true} is VALID [2022-02-20 21:35:38,095 INFO L290 TraceCheckUtils]: 113: Hoare triple {10869#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {10869#true} is VALID [2022-02-20 21:35:38,095 INFO L290 TraceCheckUtils]: 114: Hoare triple {10869#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {10869#true} is VALID [2022-02-20 21:35:38,096 INFO L290 TraceCheckUtils]: 115: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:38,096 INFO L284 TraceCheckUtils]: 116: Hoare quadruple {10869#true} {10869#true} #588#return; {10869#true} is VALID [2022-02-20 21:35:38,096 INFO L290 TraceCheckUtils]: 117: Hoare triple {10869#true} ~tmp~2.base, ~tmp~2.offset := #t~ret40.base, #t~ret40.offset;havoc #t~ret40.base, #t~ret40.offset;#res.base, #res.offset := ~tmp~2.base, ~tmp~2.offset; {10869#true} is VALID [2022-02-20 21:35:38,096 INFO L290 TraceCheckUtils]: 118: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:38,096 INFO L284 TraceCheckUtils]: 119: Hoare quadruple {10869#true} {10869#true} #634#return; {10869#true} is VALID [2022-02-20 21:35:38,096 INFO L290 TraceCheckUtils]: 120: Hoare triple {10869#true} ibmpex_find_sensors_~tmp~13#1.base, ibmpex_find_sensors_~tmp~13#1.offset := ibmpex_find_sensors_#t~ret150#1.base, ibmpex_find_sensors_#t~ret150#1.offset;havoc ibmpex_find_sensors_#t~mem149#1;havoc ibmpex_find_sensors_#t~ret150#1.base, ibmpex_find_sensors_#t~ret150#1.offset;call write~$Pointer$(ibmpex_find_sensors_~tmp~13#1.base, ibmpex_find_sensors_~tmp~13#1.offset, ibmpex_find_sensors_~data#1.base, 907 + ibmpex_find_sensors_~data#1.offset, 8);call ibmpex_find_sensors_#t~mem151#1.base, ibmpex_find_sensors_#t~mem151#1.offset := read~$Pointer$(ibmpex_find_sensors_~data#1.base, 907 + ibmpex_find_sensors_~data#1.offset, 8); {10869#true} is VALID [2022-02-20 21:35:38,097 INFO L290 TraceCheckUtils]: 121: Hoare triple {10869#true} assume !(0 == (ibmpex_find_sensors_#t~mem151#1.base + ibmpex_find_sensors_#t~mem151#1.offset) % 18446744073709551616);havoc ibmpex_find_sensors_#t~mem151#1.base, ibmpex_find_sensors_#t~mem151#1.offset;ibmpex_find_sensors_~i~2#1 := 0; {10869#true} is VALID [2022-02-20 21:35:38,097 INFO L290 TraceCheckUtils]: 122: Hoare triple {10869#true} call ibmpex_find_sensors_#t~mem163#1 := read~int(ibmpex_find_sensors_~data#1.base, 906 + ibmpex_find_sensors_~data#1.offset, 1); {10869#true} is VALID [2022-02-20 21:35:38,097 INFO L290 TraceCheckUtils]: 123: Hoare triple {10869#true} assume !(ibmpex_find_sensors_#t~mem163#1 % 256 > ibmpex_find_sensors_~i~2#1);havoc ibmpex_find_sensors_#t~mem163#1;call ibmpex_find_sensors_#t~mem164#1.base, ibmpex_find_sensors_#t~mem164#1.offset := read~$Pointer$(ibmpex_find_sensors_~data#1.base, 24 + ibmpex_find_sensors_~data#1.offset, 8);assume { :begin_inline_ldv_device_create_file_6 } true;ldv_device_create_file_6_#in~ldv_func_arg1#1.base, ldv_device_create_file_6_#in~ldv_func_arg1#1.offset, ldv_device_create_file_6_#in~ldv_func_arg2#1.base, ldv_device_create_file_6_#in~ldv_func_arg2#1.offset := ibmpex_find_sensors_#t~mem164#1.base, ibmpex_find_sensors_#t~mem164#1.offset, ~#sensor_dev_attr_reset_high_low~0.base, ~#sensor_dev_attr_reset_high_low~0.offset;havoc ldv_device_create_file_6_#res#1;havoc ldv_device_create_file_6_#t~ret242#1, ldv_device_create_file_6_~ldv_func_arg1#1.base, ldv_device_create_file_6_~ldv_func_arg1#1.offset, ldv_device_create_file_6_~ldv_func_arg2#1.base, ldv_device_create_file_6_~ldv_func_arg2#1.offset, ldv_device_create_file_6_~tmp~20#1;ldv_device_create_file_6_~ldv_func_arg1#1.base, ldv_device_create_file_6_~ldv_func_arg1#1.offset := ldv_device_create_file_6_#in~ldv_func_arg1#1.base, ldv_device_create_file_6_#in~ldv_func_arg1#1.offset;ldv_device_create_file_6_~ldv_func_arg2#1.base, ldv_device_create_file_6_~ldv_func_arg2#1.offset := ldv_device_create_file_6_#in~ldv_func_arg2#1.base, ldv_device_create_file_6_#in~ldv_func_arg2#1.offset;havoc ldv_device_create_file_6_~tmp~20#1; {10869#true} is VALID [2022-02-20 21:35:38,098 INFO L272 TraceCheckUtils]: 124: Hoare triple {10869#true} call ldv_device_create_file_6_#t~ret242#1 := ldv_device_create_file_dev_attr_of_sensor_device_attribute(ldv_device_create_file_6_~ldv_func_arg2#1.base, ldv_device_create_file_6_~ldv_func_arg2#1.offset); {10976#(and (= ~ldv_call_dev_attr_of_sensor_device_attribute~0 |old(~ldv_call_dev_attr_of_sensor_device_attribute~0)|) (= |old(~ldv_count_2~0)| ~ldv_count_2~0))} is VALID [2022-02-20 21:35:38,098 INFO L290 TraceCheckUtils]: 125: Hoare triple {10976#(and (= ~ldv_call_dev_attr_of_sensor_device_attribute~0 |old(~ldv_call_dev_attr_of_sensor_device_attribute~0)|) (= |old(~ldv_count_2~0)| ~ldv_count_2~0))} ~attr.base, ~attr.offset := #in~attr.base, #in~attr.offset; {10869#true} is VALID [2022-02-20 21:35:38,098 INFO L290 TraceCheckUtils]: 126: Hoare triple {10869#true} assume 0 == ~ldv_call_dev_attr_of_sensor_device_attribute~0;~ldv_count_2~0 := 1 + ~ldv_count_2~0;~ldv_call_dev_attr_of_sensor_device_attribute~0 := 1; {10945#(= ~ldv_call_dev_attr_of_sensor_device_attribute~0 1)} is VALID [2022-02-20 21:35:38,099 INFO L290 TraceCheckUtils]: 127: Hoare triple {10945#(= ~ldv_call_dev_attr_of_sensor_device_attribute~0 1)} assume ~ldv_count_1~0 >= ~ldv_count_2~0; {10945#(= ~ldv_call_dev_attr_of_sensor_device_attribute~0 1)} is VALID [2022-02-20 21:35:38,099 INFO L290 TraceCheckUtils]: 128: Hoare triple {10945#(= ~ldv_call_dev_attr_of_sensor_device_attribute~0 1)} #res := 0; {10945#(= ~ldv_call_dev_attr_of_sensor_device_attribute~0 1)} is VALID [2022-02-20 21:35:38,099 INFO L290 TraceCheckUtils]: 129: Hoare triple {10945#(= ~ldv_call_dev_attr_of_sensor_device_attribute~0 1)} assume true; {10945#(= ~ldv_call_dev_attr_of_sensor_device_attribute~0 1)} is VALID [2022-02-20 21:35:38,100 INFO L284 TraceCheckUtils]: 130: Hoare quadruple {10945#(= ~ldv_call_dev_attr_of_sensor_device_attribute~0 1)} {10869#true} #646#return; {10945#(= ~ldv_call_dev_attr_of_sensor_device_attribute~0 1)} is VALID [2022-02-20 21:35:38,100 INFO L290 TraceCheckUtils]: 131: Hoare triple {10945#(= ~ldv_call_dev_attr_of_sensor_device_attribute~0 1)} assume -2147483648 <= ldv_device_create_file_6_#t~ret242#1 && ldv_device_create_file_6_#t~ret242#1 <= 2147483647;ldv_device_create_file_6_~tmp~20#1 := ldv_device_create_file_6_#t~ret242#1;havoc ldv_device_create_file_6_#t~ret242#1;ldv_device_create_file_6_#res#1 := ldv_device_create_file_6_~tmp~20#1; {10945#(= ~ldv_call_dev_attr_of_sensor_device_attribute~0 1)} is VALID [2022-02-20 21:35:38,101 INFO L290 TraceCheckUtils]: 132: Hoare triple {10945#(= ~ldv_call_dev_attr_of_sensor_device_attribute~0 1)} ibmpex_find_sensors_#t~ret165#1 := ldv_device_create_file_6_#res#1;assume { :end_inline_ldv_device_create_file_6 } true;assume -2147483648 <= ibmpex_find_sensors_#t~ret165#1 && ibmpex_find_sensors_#t~ret165#1 <= 2147483647;ibmpex_find_sensors_~err~3#1 := ibmpex_find_sensors_#t~ret165#1;havoc ibmpex_find_sensors_#t~mem164#1.base, ibmpex_find_sensors_#t~mem164#1.offset;havoc ibmpex_find_sensors_#t~ret165#1; {10945#(= ~ldv_call_dev_attr_of_sensor_device_attribute~0 1)} is VALID [2022-02-20 21:35:38,101 INFO L290 TraceCheckUtils]: 133: Hoare triple {10945#(= ~ldv_call_dev_attr_of_sensor_device_attribute~0 1)} assume !(0 != ibmpex_find_sensors_~err~3#1);call ibmpex_find_sensors_#t~mem166#1.base, ibmpex_find_sensors_#t~mem166#1.offset := read~$Pointer$(ibmpex_find_sensors_~data#1.base, 24 + ibmpex_find_sensors_~data#1.offset, 8);assume { :begin_inline_ldv_device_create_file_7 } true;ldv_device_create_file_7_#in~ldv_func_arg1#1.base, ldv_device_create_file_7_#in~ldv_func_arg1#1.offset, ldv_device_create_file_7_#in~ldv_func_arg2#1.base, ldv_device_create_file_7_#in~ldv_func_arg2#1.offset := ibmpex_find_sensors_#t~mem166#1.base, ibmpex_find_sensors_#t~mem166#1.offset, ~#sensor_dev_attr_name~0.base, ~#sensor_dev_attr_name~0.offset;havoc ldv_device_create_file_7_#res#1;havoc ldv_device_create_file_7_#t~ret243#1, ldv_device_create_file_7_~ldv_func_arg1#1.base, ldv_device_create_file_7_~ldv_func_arg1#1.offset, ldv_device_create_file_7_~ldv_func_arg2#1.base, ldv_device_create_file_7_~ldv_func_arg2#1.offset, ldv_device_create_file_7_~tmp~21#1;ldv_device_create_file_7_~ldv_func_arg1#1.base, ldv_device_create_file_7_~ldv_func_arg1#1.offset := ldv_device_create_file_7_#in~ldv_func_arg1#1.base, ldv_device_create_file_7_#in~ldv_func_arg1#1.offset;ldv_device_create_file_7_~ldv_func_arg2#1.base, ldv_device_create_file_7_~ldv_func_arg2#1.offset := ldv_device_create_file_7_#in~ldv_func_arg2#1.base, ldv_device_create_file_7_#in~ldv_func_arg2#1.offset;havoc ldv_device_create_file_7_~tmp~21#1; {10945#(= ~ldv_call_dev_attr_of_sensor_device_attribute~0 1)} is VALID [2022-02-20 21:35:38,101 INFO L272 TraceCheckUtils]: 134: Hoare triple {10945#(= ~ldv_call_dev_attr_of_sensor_device_attribute~0 1)} call ldv_device_create_file_7_#t~ret243#1 := ldv_device_create_file_dev_attr_of_sensor_device_attribute(ldv_device_create_file_7_~ldv_func_arg2#1.base, ldv_device_create_file_7_~ldv_func_arg2#1.offset); {10945#(= ~ldv_call_dev_attr_of_sensor_device_attribute~0 1)} is VALID [2022-02-20 21:35:38,102 INFO L290 TraceCheckUtils]: 135: Hoare triple {10945#(= ~ldv_call_dev_attr_of_sensor_device_attribute~0 1)} ~attr.base, ~attr.offset := #in~attr.base, #in~attr.offset; {10945#(= ~ldv_call_dev_attr_of_sensor_device_attribute~0 1)} is VALID [2022-02-20 21:35:38,102 INFO L290 TraceCheckUtils]: 136: Hoare triple {10945#(= ~ldv_call_dev_attr_of_sensor_device_attribute~0 1)} assume 0 == ~ldv_call_dev_attr_of_sensor_device_attribute~0;~ldv_count_2~0 := 1 + ~ldv_count_2~0;~ldv_call_dev_attr_of_sensor_device_attribute~0 := 1; {10870#false} is VALID [2022-02-20 21:35:38,102 INFO L290 TraceCheckUtils]: 137: Hoare triple {10870#false} assume !(~ldv_count_1~0 >= ~ldv_count_2~0); {10870#false} is VALID [2022-02-20 21:35:38,102 INFO L272 TraceCheckUtils]: 138: Hoare triple {10870#false} call ldv_error(); {10870#false} is VALID [2022-02-20 21:35:38,102 INFO L290 TraceCheckUtils]: 139: Hoare triple {10870#false} assume !false; {10870#false} is VALID [2022-02-20 21:35:38,103 INFO L134 CoverageAnalysis]: Checked inductivity of 37 backedges. 2 proven. 1 refuted. 0 times theorem prover too weak. 34 trivial. 0 not checked. [2022-02-20 21:35:38,103 INFO L144 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-02-20 21:35:38,103 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [1197118447] [2022-02-20 21:35:38,103 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleSmtInterpolCraig [1197118447] provided 0 perfect and 1 imperfect interpolant sequences [2022-02-20 21:35:38,103 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [1173207069] [2022-02-20 21:35:38,104 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 21:35:38,105 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-02-20 21:35:38,105 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-02-20 21:35:38,107 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:35:38,116 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:35:38,477 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:38,485 INFO L263 TraceCheckSpWp]: Trace formula consists of 1464 conjuncts, 4 conjunts are in the unsatisfiable core [2022-02-20 21:35:38,565 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:38,572 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-02-20 21:35:39,003 INFO L290 TraceCheckUtils]: 0: Hoare triple {10869#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(46, 2);call #Ultimate.allocInit(13, 3);call #Ultimate.allocInit(20, 4);call #Ultimate.allocInit(21, 5);call #Ultimate.allocInit(11, 6);call #Ultimate.allocInit(18, 7);call #Ultimate.allocInit(19, 8);call #Ultimate.allocInit(20, 9);call #Ultimate.allocInit(18, 10);call #Ultimate.allocInit(69, 11);call #Ultimate.allocInit(26, 12);call #Ultimate.allocInit(4, 13);call write~init~int(37, 13, 0, 1);call write~init~int(115, 13, 1, 1);call write~init~int(10, 13, 2, 1);call write~init~int(0, 13, 3, 1);call #Ultimate.allocInit(7, 14);call write~init~int(105, 14, 0, 1);call write~init~int(98, 14, 1, 1);call write~init~int(109, 14, 2, 1);call write~init~int(112, 14, 3, 1);call write~init~int(101, 14, 4, 1);call write~init~int(120, 14, 5, 1);call write~init~int(0, 14, 6, 1);call #Ultimate.allocInit(5, 15);call write~init~int(110, 15, 0, 1);call write~init~int(97, 15, 1, 1);call write~init~int(109, 15, 2, 1);call write~init~int(101, 15, 3, 1);call write~init~int(0, 15, 4, 1);call #Ultimate.allocInit(4, 16);call write~init~int(37, 16, 0, 1);call write~init~int(100, 16, 1, 1);call write~init~int(10, 16, 2, 1);call write~init~int(0, 16, 3, 1);call #Ultimate.allocInit(15, 17);call #Ultimate.allocInit(5, 18);call write~init~int(116, 18, 0, 1);call write~init~int(101, 18, 1, 1);call write~init~int(109, 18, 2, 1);call write~init~int(112, 18, 3, 1);call write~init~int(0, 18, 4, 1);call #Ultimate.allocInit(6, 19);call write~init~int(112, 19, 0, 1);call write~init~int(111, 19, 1, 1);call write~init~int(119, 19, 2, 1);call write~init~int(101, 19, 3, 1);call write~init~int(114, 19, 4, 1);call write~init~int(0, 19, 5, 1);call #Ultimate.allocInit(40, 20);call #Ultimate.allocInit(48, 21);call #Ultimate.allocInit(12, 22);call #Ultimate.allocInit(55, 23);call #Ultimate.allocInit(26, 24);call #Ultimate.allocInit(70, 25);~#power_sensor_sig~0.base, ~#power_sensor_sig~0.offset := 26, 0;call #Ultimate.allocInit(3, 26);call write~init~int(112, ~#power_sensor_sig~0.base, ~#power_sensor_sig~0.offset, 1);call write~init~int(119, ~#power_sensor_sig~0.base, 1 + ~#power_sensor_sig~0.offset, 1);call write~init~int(114, ~#power_sensor_sig~0.base, 2 + ~#power_sensor_sig~0.offset, 1);~#temp_sensor_sig~0.base, ~#temp_sensor_sig~0.offset := 27, 0;call #Ultimate.allocInit(3, 27);call write~init~int(116, ~#temp_sensor_sig~0.base, ~#temp_sensor_sig~0.offset, 1);call write~init~int(101, ~#temp_sensor_sig~0.base, 1 + ~#temp_sensor_sig~0.offset, 1);call write~init~int(109, ~#temp_sensor_sig~0.base, 2 + ~#temp_sensor_sig~0.offset, 1);~#watt_sensor_sig~0.base, ~#watt_sensor_sig~0.offset := 28, 0;call #Ultimate.allocInit(2, 28);call write~init~int(65, ~#watt_sensor_sig~0.base, ~#watt_sensor_sig~0.offset, 1);call write~init~int(67, ~#watt_sensor_sig~0.base, 1 + ~#watt_sensor_sig~0.offset, 1);~#power_sensor_name_templates~0.base, ~#power_sensor_name_templates~0.offset := 29, 0;call #Ultimate.allocInit(24, 29);call write~init~$Pointer$(3, 0, ~#power_sensor_name_templates~0.base, ~#power_sensor_name_templates~0.offset, 8);call write~init~$Pointer$(4, 0, ~#power_sensor_name_templates~0.base, 8 + ~#power_sensor_name_templates~0.offset, 8);call write~init~$Pointer$(5, 0, ~#power_sensor_name_templates~0.base, 16 + ~#power_sensor_name_templates~0.offset, 8);~#temp_sensor_name_templates~0.base, ~#temp_sensor_name_templates~0.offset := 30, 0;call #Ultimate.allocInit(24, 30);call write~init~$Pointer$(6, 0, ~#temp_sensor_name_templates~0.base, ~#temp_sensor_name_templates~0.offset, 8);call write~init~$Pointer$(7, 0, ~#temp_sensor_name_templates~0.base, 8 + ~#temp_sensor_name_templates~0.offset, 8);call write~init~$Pointer$(8, 0, ~#temp_sensor_name_templates~0.base, 16 + ~#temp_sensor_name_templates~0.offset, 8);~#driver_data~0.base, ~#driver_data~0.offset := 31, 0;call #Ultimate.allocInit(72, 31);call write~init~$Pointer$(~#driver_data~0.base, ~#driver_data~0.offset, ~#driver_data~0.base, ~#driver_data~0.offset, 8);call write~init~$Pointer$(~#driver_data~0.base, ~#driver_data~0.offset, ~#driver_data~0.base, 8 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(0, 0, ~#driver_data~0.base, 16 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(0, 0, ~#driver_data~0.base, 24 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(~#__this_module~0.base, ~#__this_module~0.offset, ~#driver_data~0.base, 32 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(#funAddr~ibmpex_register_bmc.base, #funAddr~ibmpex_register_bmc.offset, ~#driver_data~0.base, 40 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(#funAddr~ibmpex_bmc_gone.base, #funAddr~ibmpex_bmc_gone.offset, ~#driver_data~0.base, 48 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(#funAddr~ibmpex_msg_handler.base, #funAddr~ibmpex_msg_handler.offset, ~#driver_data~0.base, 56 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(0, 0, ~#driver_data~0.base, 64 + ~#driver_data~0.offset, 8);~#sensor_dev_attr_name~0.base, ~#sensor_dev_attr_name~0.offset := 32, 0;call #Ultimate.allocInit(48, 32);call write~init~$Pointer$(15, 0, ~#sensor_dev_attr_name~0.base, ~#sensor_dev_attr_name~0.offset, 8);call write~init~int(292, ~#sensor_dev_attr_name~0.base, 8 + ~#sensor_dev_attr_name~0.offset, 4);call write~init~$Pointer$(0, 0, ~#sensor_dev_attr_name~0.base, 12 + ~#sensor_dev_attr_name~0.offset, 8);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 20 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 21 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 22 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 23 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 24 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 25 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 26 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 27 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~$Pointer$(#funAddr~show_name.base, #funAddr~show_name.offset, ~#sensor_dev_attr_name~0.base, 28 + ~#sensor_dev_attr_name~0.offset, 8);call write~init~$Pointer$(0, 0, ~#sensor_dev_attr_name~0.base, 36 + ~#sensor_dev_attr_name~0.offset, 8);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 44 + ~#sensor_dev_attr_name~0.offset, 4);~#sensor_dev_attr_reset_high_low~0.base, ~#sensor_dev_attr_reset_high_low~0.offset := 33, 0;call #Ultimate.allocInit(48, 33);call write~init~$Pointer$(17, 0, ~#sensor_dev_attr_reset_high_low~0.base, ~#sensor_dev_attr_reset_high_low~0.offset, 8);call write~init~int(128, ~#sensor_dev_attr_reset_high_low~0.base, 8 + ~#sensor_dev_attr_reset_high_low~0.offset, 4);call write~init~$Pointer$(0, 0, ~#sensor_dev_attr_reset_high_low~0.base, 12 + ~#sensor_dev_attr_reset_high_low~0.offset, 8);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 20 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 21 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 22 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 23 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 24 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 25 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 26 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 27 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~$Pointer$(0, 0, ~#sensor_dev_attr_reset_high_low~0.base, 28 + ~#sensor_dev_attr_reset_high_low~0.offset, 8);call write~init~$Pointer$(#funAddr~ibmpex_reset_high_low.base, #funAddr~ibmpex_reset_high_low.offset, ~#sensor_dev_attr_reset_high_low~0.base, 36 + ~#sensor_dev_attr_reset_high_low~0.offset, 8);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 44 + ~#sensor_dev_attr_reset_high_low~0.offset, 4);~LDV_IN_INTERRUPT~0 := 0;~ldv_count_1~0 := 0;~ldv_count_2~0 := 0;~ldv_call_dev_attr_of_sensor_device_attribute~0 := 0;~ldv_call_dev_attr_of_sensor_device_attribute_2~0 := 0; {10869#true} is VALID [2022-02-20 21:35:39,003 INFO L290 TraceCheckUtils]: 1: Hoare triple {10869#true} assume { :end_inline_ULTIMATE.init } true;assume { :begin_inline_main } true;havoc main_#res#1;havoc main_#t~ret236#1, main_#t~nondet237#1, main_#t~switch238#1, main_#t~nondet239#1, main_~var_ibmpex_register_bmc_17_p0~0#1, main_~var_group1~0#1.base, main_~var_group1~0#1.offset, main_~var_ibmpex_bmc_gone_19_p0~0#1, main_~#var_group2~0#1.base, main_~#var_group2~0#1.offset, main_~#var_ibmpex_msg_handler_20_p1~0#1.base, main_~#var_ibmpex_msg_handler_20_p1~0#1.offset, main_~tmp~17#1, main_~tmp___0~4#1, main_~tmp___1~2#1;havoc main_~var_ibmpex_register_bmc_17_p0~0#1;havoc main_~var_group1~0#1.base, main_~var_group1~0#1.offset;havoc main_~var_ibmpex_bmc_gone_19_p0~0#1;call main_~#var_group2~0#1.base, main_~#var_group2~0#1.offset := #Ultimate.allocOnStack(374);call main_~#var_ibmpex_msg_handler_20_p1~0#1.base, main_~#var_ibmpex_msg_handler_20_p1~0#1.offset := #Ultimate.allocOnStack(915);havoc main_~tmp~17#1;havoc main_~tmp___0~4#1;havoc main_~tmp___1~2#1;~LDV_IN_INTERRUPT~0 := 1;assume { :begin_inline_ldv_initialize } true;~ldv_count_1~0 := 1 + ~ldv_count_1~0;~ldv_count_1~0 := 1 + ~ldv_count_1~0;~ldv_count_1~0 := 1 + ~ldv_count_1~0;~ldv_count_1~0 := 1 + ~ldv_count_1~0;~ldv_count_1~0 := 1 + ~ldv_count_1~0;~ldv_count_1~0 := 1 + ~ldv_count_1~0; {10869#true} is VALID [2022-02-20 21:35:39,003 INFO L290 TraceCheckUtils]: 2: Hoare triple {10869#true} assume { :end_inline_ldv_initialize } true; {10869#true} is VALID [2022-02-20 21:35:39,003 INFO L272 TraceCheckUtils]: 3: Hoare triple {10869#true} call ldv_handler_precall(); {10869#true} is VALID [2022-02-20 21:35:39,004 INFO L290 TraceCheckUtils]: 4: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:39,004 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {10869#true} {10869#true} #612#return; {10869#true} is VALID [2022-02-20 21:35:39,004 INFO L290 TraceCheckUtils]: 6: Hoare triple {10869#true} assume { :begin_inline_ibmpex_init } true;havoc ibmpex_init_#res#1;havoc ibmpex_init_#t~ret231#1, ibmpex_init_~tmp~16#1;havoc ibmpex_init_~tmp~16#1;assume { :begin_inline_ipmi_smi_watcher_register } true;ipmi_smi_watcher_register_#in~arg0#1.base, ipmi_smi_watcher_register_#in~arg0#1.offset := ~#driver_data~0.base, 16 + ~#driver_data~0.offset;havoc ipmi_smi_watcher_register_#res#1;havoc ipmi_smi_watcher_register_#t~nondet252#1, ipmi_smi_watcher_register_~arg0#1.base, ipmi_smi_watcher_register_~arg0#1.offset;ipmi_smi_watcher_register_~arg0#1.base, ipmi_smi_watcher_register_~arg0#1.offset := ipmi_smi_watcher_register_#in~arg0#1.base, ipmi_smi_watcher_register_#in~arg0#1.offset;assume -2147483648 <= ipmi_smi_watcher_register_#t~nondet252#1 && ipmi_smi_watcher_register_#t~nondet252#1 <= 2147483647;ipmi_smi_watcher_register_#res#1 := ipmi_smi_watcher_register_#t~nondet252#1;havoc ipmi_smi_watcher_register_#t~nondet252#1; {10869#true} is VALID [2022-02-20 21:35:39,004 INFO L290 TraceCheckUtils]: 7: Hoare triple {10869#true} ibmpex_init_#t~ret231#1 := ipmi_smi_watcher_register_#res#1;assume { :end_inline_ipmi_smi_watcher_register } true;assume -2147483648 <= ibmpex_init_#t~ret231#1 && ibmpex_init_#t~ret231#1 <= 2147483647;ibmpex_init_~tmp~16#1 := ibmpex_init_#t~ret231#1;havoc ibmpex_init_#t~ret231#1;ibmpex_init_#res#1 := ibmpex_init_~tmp~16#1; {10869#true} is VALID [2022-02-20 21:35:39,004 INFO L290 TraceCheckUtils]: 8: Hoare triple {10869#true} main_#t~ret236#1 := ibmpex_init_#res#1;assume { :end_inline_ibmpex_init } true;assume -2147483648 <= main_#t~ret236#1 && main_#t~ret236#1 <= 2147483647;main_~tmp~17#1 := main_#t~ret236#1;havoc main_#t~ret236#1; {10869#true} is VALID [2022-02-20 21:35:39,005 INFO L290 TraceCheckUtils]: 9: Hoare triple {10869#true} assume !(0 != main_~tmp~17#1); {10869#true} is VALID [2022-02-20 21:35:39,005 INFO L290 TraceCheckUtils]: 10: Hoare triple {10869#true} assume -2147483648 <= main_#t~nondet239#1 && main_#t~nondet239#1 <= 2147483647;main_~tmp___1~2#1 := main_#t~nondet239#1;havoc main_#t~nondet239#1; {10869#true} is VALID [2022-02-20 21:35:39,005 INFO L290 TraceCheckUtils]: 11: Hoare triple {10869#true} assume 0 != main_~tmp___1~2#1; {10869#true} is VALID [2022-02-20 21:35:39,005 INFO L290 TraceCheckUtils]: 12: Hoare triple {10869#true} assume -2147483648 <= main_#t~nondet237#1 && main_#t~nondet237#1 <= 2147483647;main_~tmp___0~4#1 := main_#t~nondet237#1;havoc main_#t~nondet237#1;main_#t~switch238#1 := 0 == main_~tmp___0~4#1; {10869#true} is VALID [2022-02-20 21:35:39,005 INFO L290 TraceCheckUtils]: 13: Hoare triple {10869#true} assume main_#t~switch238#1; {10869#true} is VALID [2022-02-20 21:35:39,005 INFO L272 TraceCheckUtils]: 14: Hoare triple {10869#true} call ldv_handler_precall(); {10869#true} is VALID [2022-02-20 21:35:39,006 INFO L290 TraceCheckUtils]: 15: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:39,006 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {10869#true} {10869#true} #614#return; {10869#true} is VALID [2022-02-20 21:35:39,006 INFO L290 TraceCheckUtils]: 17: Hoare triple {10869#true} assume { :begin_inline_ibmpex_register_bmc } true;ibmpex_register_bmc_#in~iface#1, ibmpex_register_bmc_#in~dev#1.base, ibmpex_register_bmc_#in~dev#1.offset := main_~var_ibmpex_register_bmc_17_p0~0#1, main_~var_group1~0#1.base, main_~var_group1~0#1.offset;havoc ibmpex_register_bmc_#t~ret178#1.base, ibmpex_register_bmc_#t~ret178#1.offset, ibmpex_register_bmc_#t~nondet179#1, ibmpex_register_bmc_#t~mem180#1, ibmpex_register_bmc_#t~ret181#1, ibmpex_register_bmc_#t~nondet182#1, ibmpex_register_bmc_#t~mem183#1, ibmpex_register_bmc_#t~ret184#1, ibmpex_register_bmc_#t~mem185#1.base, ibmpex_register_bmc_#t~mem185#1.offset, ibmpex_register_bmc_#t~ret186#1.base, ibmpex_register_bmc_#t~ret186#1.offset, ibmpex_register_bmc_#t~mem187#1.base, ibmpex_register_bmc_#t~mem187#1.offset, ibmpex_register_bmc_#t~ret188#1, ibmpex_register_bmc_#t~nondet189#1, ibmpex_register_bmc_#t~mem190#1.base, ibmpex_register_bmc_#t~mem190#1.offset, ibmpex_register_bmc_#t~mem191#1, ibmpex_register_bmc_#t~ret192#1, ibmpex_register_bmc_#t~nondet193#1, ibmpex_register_bmc_#t~mem194#1.base, ibmpex_register_bmc_#t~mem194#1.offset, ibmpex_register_bmc_#t~mem195#1.base, ibmpex_register_bmc_#t~mem195#1.offset, ibmpex_register_bmc_#t~mem196#1.base, ibmpex_register_bmc_#t~mem196#1.offset, ibmpex_register_bmc_#t~ret197#1, ibmpex_register_bmc_~iface#1, ibmpex_register_bmc_~dev#1.base, ibmpex_register_bmc_~dev#1.offset, ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset, ibmpex_register_bmc_~err~4#1, ibmpex_register_bmc_~tmp~14#1.base, ibmpex_register_bmc_~tmp~14#1.offset, ibmpex_register_bmc_~#__key~1#1.base, ibmpex_register_bmc_~#__key~1#1.offset, ibmpex_register_bmc_~tmp___0~3#1;ibmpex_register_bmc_~iface#1 := ibmpex_register_bmc_#in~iface#1;ibmpex_register_bmc_~dev#1.base, ibmpex_register_bmc_~dev#1.offset := ibmpex_register_bmc_#in~dev#1.base, ibmpex_register_bmc_#in~dev#1.offset;havoc ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset;havoc ibmpex_register_bmc_~err~4#1;havoc ibmpex_register_bmc_~tmp~14#1.base, ibmpex_register_bmc_~tmp~14#1.offset;call ibmpex_register_bmc_~#__key~1#1.base, ibmpex_register_bmc_~#__key~1#1.offset := #Ultimate.allocOnStack(8);havoc ibmpex_register_bmc_~tmp___0~3#1; {10869#true} is VALID [2022-02-20 21:35:39,006 INFO L272 TraceCheckUtils]: 18: Hoare triple {10869#true} call ibmpex_register_bmc_#t~ret178#1.base, ibmpex_register_bmc_#t~ret178#1.offset := kzalloc(968, 208); {10869#true} is VALID [2022-02-20 21:35:39,006 INFO L290 TraceCheckUtils]: 19: Hoare triple {10869#true} ~size := #in~size;~flags := #in~flags;havoc ~tmp~2.base, ~tmp~2.offset; {10869#true} is VALID [2022-02-20 21:35:39,006 INFO L272 TraceCheckUtils]: 20: Hoare triple {10869#true} call #t~ret40.base, #t~ret40.offset := kmalloc(~size, ~bitwiseOr(~flags, 32768)); {10869#true} is VALID [2022-02-20 21:35:39,007 INFO L290 TraceCheckUtils]: 21: Hoare triple {10869#true} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {10869#true} is VALID [2022-02-20 21:35:39,007 INFO L272 TraceCheckUtils]: 22: Hoare triple {10869#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {10869#true} is VALID [2022-02-20 21:35:39,007 INFO L290 TraceCheckUtils]: 23: Hoare triple {10869#true} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {10869#true} is VALID [2022-02-20 21:35:39,007 INFO L290 TraceCheckUtils]: 24: Hoare triple {10869#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {10869#true} is VALID [2022-02-20 21:35:39,007 INFO L290 TraceCheckUtils]: 25: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:39,008 INFO L284 TraceCheckUtils]: 26: Hoare quadruple {10869#true} {10869#true} #590#return; {10869#true} is VALID [2022-02-20 21:35:39,008 INFO L290 TraceCheckUtils]: 27: Hoare triple {10869#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {10869#true} is VALID [2022-02-20 21:35:39,008 INFO L290 TraceCheckUtils]: 28: Hoare triple {10869#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {10869#true} is VALID [2022-02-20 21:35:39,008 INFO L290 TraceCheckUtils]: 29: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:39,008 INFO L284 TraceCheckUtils]: 30: Hoare quadruple {10869#true} {10869#true} #588#return; {10869#true} is VALID [2022-02-20 21:35:39,008 INFO L290 TraceCheckUtils]: 31: Hoare triple {10869#true} ~tmp~2.base, ~tmp~2.offset := #t~ret40.base, #t~ret40.offset;havoc #t~ret40.base, #t~ret40.offset;#res.base, #res.offset := ~tmp~2.base, ~tmp~2.offset; {10869#true} is VALID [2022-02-20 21:35:39,009 INFO L290 TraceCheckUtils]: 32: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:39,009 INFO L284 TraceCheckUtils]: 33: Hoare quadruple {10869#true} {10869#true} #616#return; {10869#true} is VALID [2022-02-20 21:35:39,009 INFO L290 TraceCheckUtils]: 34: Hoare triple {10869#true} ibmpex_register_bmc_~tmp~14#1.base, ibmpex_register_bmc_~tmp~14#1.offset := ibmpex_register_bmc_#t~ret178#1.base, ibmpex_register_bmc_#t~ret178#1.offset;havoc ibmpex_register_bmc_#t~ret178#1.base, ibmpex_register_bmc_#t~ret178#1.offset;ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset := ibmpex_register_bmc_~tmp~14#1.base, ibmpex_register_bmc_~tmp~14#1.offset; {10869#true} is VALID [2022-02-20 21:35:39,009 INFO L290 TraceCheckUtils]: 35: Hoare triple {10869#true} assume !(0 == (ibmpex_register_bmc_~data~2#1.base + ibmpex_register_bmc_~data~2#1.offset) % 18446744073709551616);call write~int(12, ibmpex_register_bmc_~data~2#1.base, 193 + ibmpex_register_bmc_~data~2#1.offset, 4);call write~int(15, ibmpex_register_bmc_~data~2#1.base, 197 + ibmpex_register_bmc_~data~2#1.offset, 2);call write~int(0, ibmpex_register_bmc_~data~2#1.base, 199 + ibmpex_register_bmc_~data~2#1.offset, 1);call write~int(ibmpex_register_bmc_~iface#1, ibmpex_register_bmc_~data~2#1.base, 323 + ibmpex_register_bmc_~data~2#1.offset, 4);call write~$Pointer$(ibmpex_register_bmc_~dev#1.base, ibmpex_register_bmc_~dev#1.offset, ibmpex_register_bmc_~data~2#1.base, 24 + ibmpex_register_bmc_~data~2#1.offset, 8);call ibmpex_register_bmc_#t~mem180#1 := read~int(ibmpex_register_bmc_~data~2#1.base, 323 + ibmpex_register_bmc_~data~2#1.offset, 4);assume { :begin_inline_ipmi_create_user } true;ipmi_create_user_#in~arg0#1, ipmi_create_user_#in~arg1#1.base, ipmi_create_user_#in~arg1#1.offset, ipmi_create_user_#in~arg2#1.base, ipmi_create_user_#in~arg2#1.offset, ipmi_create_user_#in~arg3#1.base, ipmi_create_user_#in~arg3#1.offset := ibmpex_register_bmc_#t~mem180#1, ~#driver_data~0.base, 56 + ~#driver_data~0.offset, ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset, ibmpex_register_bmc_~data~2#1.base, 315 + ibmpex_register_bmc_~data~2#1.offset;havoc ipmi_create_user_#res#1;havoc ipmi_create_user_#t~nondet249#1, ipmi_create_user_~arg0#1, ipmi_create_user_~arg1#1.base, ipmi_create_user_~arg1#1.offset, ipmi_create_user_~arg2#1.base, ipmi_create_user_~arg2#1.offset, ipmi_create_user_~arg3#1.base, ipmi_create_user_~arg3#1.offset;ipmi_create_user_~arg0#1 := ipmi_create_user_#in~arg0#1;ipmi_create_user_~arg1#1.base, ipmi_create_user_~arg1#1.offset := ipmi_create_user_#in~arg1#1.base, ipmi_create_user_#in~arg1#1.offset;ipmi_create_user_~arg2#1.base, ipmi_create_user_~arg2#1.offset := ipmi_create_user_#in~arg2#1.base, ipmi_create_user_#in~arg2#1.offset;ipmi_create_user_~arg3#1.base, ipmi_create_user_~arg3#1.offset := ipmi_create_user_#in~arg3#1.base, ipmi_create_user_#in~arg3#1.offset;assume -2147483648 <= ipmi_create_user_#t~nondet249#1 && ipmi_create_user_#t~nondet249#1 <= 2147483647;ipmi_create_user_#res#1 := ipmi_create_user_#t~nondet249#1;havoc ipmi_create_user_#t~nondet249#1; {10869#true} is VALID [2022-02-20 21:35:39,009 INFO L290 TraceCheckUtils]: 36: Hoare triple {10869#true} ibmpex_register_bmc_#t~ret181#1 := ipmi_create_user_#res#1;assume { :end_inline_ipmi_create_user } true;assume -2147483648 <= ibmpex_register_bmc_#t~ret181#1 && ibmpex_register_bmc_#t~ret181#1 <= 2147483647;ibmpex_register_bmc_~err~4#1 := ibmpex_register_bmc_#t~ret181#1;havoc ibmpex_register_bmc_#t~mem180#1;havoc ibmpex_register_bmc_#t~ret181#1; {10869#true} is VALID [2022-02-20 21:35:39,009 INFO L290 TraceCheckUtils]: 37: Hoare triple {10869#true} assume !(ibmpex_register_bmc_~err~4#1 < 0);assume { :begin_inline___mutex_init } true;__mutex_init_#in~arg0#1.base, __mutex_init_#in~arg0#1.offset, __mutex_init_#in~arg1#1.base, __mutex_init_#in~arg1#1.offset, __mutex_init_#in~arg2#1.base, __mutex_init_#in~arg2#1.offset := ibmpex_register_bmc_~data~2#1.base, 32 + ibmpex_register_bmc_~data~2#1.offset, 22, 0, ibmpex_register_bmc_~#__key~1#1.base, ibmpex_register_bmc_~#__key~1#1.offset;havoc __mutex_init_~arg0#1.base, __mutex_init_~arg0#1.offset, __mutex_init_~arg1#1.base, __mutex_init_~arg1#1.offset, __mutex_init_~arg2#1.base, __mutex_init_~arg2#1.offset;__mutex_init_~arg0#1.base, __mutex_init_~arg0#1.offset := __mutex_init_#in~arg0#1.base, __mutex_init_#in~arg0#1.offset;__mutex_init_~arg1#1.base, __mutex_init_~arg1#1.offset := __mutex_init_#in~arg1#1.base, __mutex_init_#in~arg1#1.offset;__mutex_init_~arg2#1.base, __mutex_init_~arg2#1.offset := __mutex_init_#in~arg2#1.base, __mutex_init_#in~arg2#1.offset; {10869#true} is VALID [2022-02-20 21:35:39,010 INFO L290 TraceCheckUtils]: 38: Hoare triple {10869#true} assume { :end_inline___mutex_init } true;call write~int(0, ibmpex_register_bmc_~data~2#1.base, 611 + ibmpex_register_bmc_~data~2#1.offset, 8);assume { :begin_inline_init_completion } true;init_completion_#in~x#1.base, init_completion_#in~x#1.offset := ibmpex_register_bmc_~data~2#1.base, 231 + ibmpex_register_bmc_~data~2#1.offset;havoc init_completion_~x#1.base, init_completion_~x#1.offset, init_completion_~#__key~0#1.base, init_completion_~#__key~0#1.offset;init_completion_~x#1.base, init_completion_~x#1.offset := init_completion_#in~x#1.base, init_completion_#in~x#1.offset;call init_completion_~#__key~0#1.base, init_completion_~#__key~0#1.offset := #Ultimate.allocOnStack(8);call write~int(0, init_completion_~x#1.base, init_completion_~x#1.offset, 4);assume { :begin_inline___init_waitqueue_head } true;__init_waitqueue_head_#in~arg0#1.base, __init_waitqueue_head_#in~arg0#1.offset, __init_waitqueue_head_#in~arg1#1.base, __init_waitqueue_head_#in~arg1#1.offset := init_completion_~x#1.base, 4 + init_completion_~x#1.offset, init_completion_~#__key~0#1.base, init_completion_~#__key~0#1.offset;havoc __init_waitqueue_head_~arg0#1.base, __init_waitqueue_head_~arg0#1.offset, __init_waitqueue_head_~arg1#1.base, __init_waitqueue_head_~arg1#1.offset;__init_waitqueue_head_~arg0#1.base, __init_waitqueue_head_~arg0#1.offset := __init_waitqueue_head_#in~arg0#1.base, __init_waitqueue_head_#in~arg0#1.offset;__init_waitqueue_head_~arg1#1.base, __init_waitqueue_head_~arg1#1.offset := __init_waitqueue_head_#in~arg1#1.base, __init_waitqueue_head_#in~arg1#1.offset; {10869#true} is VALID [2022-02-20 21:35:39,010 INFO L290 TraceCheckUtils]: 39: Hoare triple {10869#true} assume { :end_inline___init_waitqueue_head } true;call ULTIMATE.dealloc(init_completion_~#__key~0#1.base, init_completion_~#__key~0#1.offset);havoc init_completion_~#__key~0#1.base, init_completion_~#__key~0#1.offset; {10869#true} is VALID [2022-02-20 21:35:39,010 INFO L290 TraceCheckUtils]: 40: Hoare triple {10869#true} assume { :end_inline_init_completion } true;call write~int(58, ibmpex_register_bmc_~data~2#1.base, 327 + ibmpex_register_bmc_~data~2#1.offset, 1);call write~int(60, ibmpex_register_bmc_~data~2#1.base, 328 + ibmpex_register_bmc_~data~2#1.offset, 1);call write~$Pointer$(ibmpex_register_bmc_~data~2#1.base, 339 + ibmpex_register_bmc_~data~2#1.offset, ibmpex_register_bmc_~data~2#1.base, 331 + ibmpex_register_bmc_~data~2#1.offset, 8);assume { :begin_inline_ibmpex_ver_check } true;ibmpex_ver_check_#in~data#1.base, ibmpex_ver_check_#in~data#1.offset := ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset;havoc ibmpex_ver_check_#res#1;havoc ibmpex_ver_check_#t~ret71#1, ibmpex_ver_check_#t~mem72#1, ibmpex_ver_check_#t~mem73#1, ibmpex_ver_check_#t~short74#1, ibmpex_ver_check_#t~mem75#1, ibmpex_ver_check_#t~mem76#1, ibmpex_ver_check_#t~ret77#1, ibmpex_ver_check_#t~nondet78#1, ibmpex_ver_check_#t~mem79#1.base, ibmpex_ver_check_#t~mem79#1.offset, ibmpex_ver_check_#t~mem80#1, ibmpex_ver_check_#t~mem81#1, ibmpex_ver_check_#t~mem82#1, ibmpex_ver_check_#t~mem83#1, ibmpex_ver_check_#t~mem84#1, ibmpex_ver_check_~data#1.base, ibmpex_ver_check_~data#1.offset, ibmpex_ver_check_~tmp~4#1;ibmpex_ver_check_~data#1.base, ibmpex_ver_check_~data#1.offset := ibmpex_ver_check_#in~data#1.base, ibmpex_ver_check_#in~data#1.offset;havoc ibmpex_ver_check_~tmp~4#1;call write~int(1, ibmpex_ver_check_~data#1.base, 339 + ibmpex_ver_check_~data#1.offset, 1);call write~int(1, ibmpex_ver_check_~data#1.base, 329 + ibmpex_ver_check_~data#1.offset, 2); {10869#true} is VALID [2022-02-20 21:35:39,010 INFO L272 TraceCheckUtils]: 41: Hoare triple {10869#true} call ibmpex_ver_check_#t~ret71#1 := ibmpex_send_message(ibmpex_ver_check_~data#1.base, ibmpex_ver_check_~data#1.offset); {10869#true} is VALID [2022-02-20 21:35:39,010 INFO L290 TraceCheckUtils]: 42: Hoare triple {10869#true} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;havoc ~err~0#1;assume { :begin_inline_ipmi_validate_addr } true;ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset, ipmi_validate_addr_#in~arg1#1 := ~data#1.base, 193 + ~data#1.offset, 40;havoc ipmi_validate_addr_#res#1;havoc ipmi_validate_addr_#t~nondet254#1, ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset, ipmi_validate_addr_~arg1#1;ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset := ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset;ipmi_validate_addr_~arg1#1 := ipmi_validate_addr_#in~arg1#1;assume -2147483648 <= ipmi_validate_addr_#t~nondet254#1 && ipmi_validate_addr_#t~nondet254#1 <= 2147483647;ipmi_validate_addr_#res#1 := ipmi_validate_addr_#t~nondet254#1;havoc ipmi_validate_addr_#t~nondet254#1; {10869#true} is VALID [2022-02-20 21:35:39,011 INFO L290 TraceCheckUtils]: 43: Hoare triple {10869#true} #t~ret62#1 := ipmi_validate_addr_#res#1;assume { :end_inline_ipmi_validate_addr } true;assume -2147483648 <= #t~ret62#1 && #t~ret62#1 <= 2147483647;~err~0#1 := #t~ret62#1;havoc #t~ret62#1; {10869#true} is VALID [2022-02-20 21:35:39,011 INFO L290 TraceCheckUtils]: 44: Hoare triple {10869#true} assume 0 != ~err~0#1; {10869#true} is VALID [2022-02-20 21:35:39,011 INFO L290 TraceCheckUtils]: 45: Hoare triple {10869#true} havoc #t~nondet69#1;call #t~mem70#1.base, #t~mem70#1.offset := read~$Pointer$(~data#1.base, 24 + ~data#1.offset, 8);havoc #t~mem70#1.base, #t~mem70#1.offset;#res#1 := ~err~0#1; {10869#true} is VALID [2022-02-20 21:35:39,011 INFO L290 TraceCheckUtils]: 46: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:39,011 INFO L284 TraceCheckUtils]: 47: Hoare quadruple {10869#true} {10869#true} #618#return; {10869#true} is VALID [2022-02-20 21:35:39,011 INFO L290 TraceCheckUtils]: 48: Hoare triple {10869#true} assume -2147483648 <= ibmpex_ver_check_#t~ret71#1 && ibmpex_ver_check_#t~ret71#1 <= 2147483647;havoc ibmpex_ver_check_#t~ret71#1; {10869#true} is VALID [2022-02-20 21:35:39,012 INFO L272 TraceCheckUtils]: 49: Hoare triple {10869#true} call wait_for_completion(ibmpex_ver_check_~data#1.base, 231 + ibmpex_ver_check_~data#1.offset); {10869#true} is VALID [2022-02-20 21:35:39,012 INFO L290 TraceCheckUtils]: 50: Hoare triple {10869#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset; {10869#true} is VALID [2022-02-20 21:35:39,012 INFO L290 TraceCheckUtils]: 51: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:39,012 INFO L284 TraceCheckUtils]: 52: Hoare quadruple {10869#true} {10869#true} #620#return; {10869#true} is VALID [2022-02-20 21:35:39,012 INFO L290 TraceCheckUtils]: 53: Hoare triple {10869#true} call ibmpex_ver_check_#t~mem72#1 := read~int(ibmpex_ver_check_~data#1.base, 899 + ibmpex_ver_check_~data#1.offset, 1);ibmpex_ver_check_#t~short74#1 := 0 != ibmpex_ver_check_#t~mem72#1 % 256 % 4294967296; {10869#true} is VALID [2022-02-20 21:35:39,012 INFO L290 TraceCheckUtils]: 54: Hoare triple {10869#true} assume !ibmpex_ver_check_#t~short74#1;call ibmpex_ver_check_#t~mem73#1 := read~int(ibmpex_ver_check_~data#1.base, 891 + ibmpex_ver_check_~data#1.offset, 8);ibmpex_ver_check_#t~short74#1 := 6 != ibmpex_ver_check_#t~mem73#1 % 18446744073709551616; {10869#true} is VALID [2022-02-20 21:35:39,013 INFO L290 TraceCheckUtils]: 55: Hoare triple {10869#true} assume !ibmpex_ver_check_#t~short74#1;havoc ibmpex_ver_check_#t~mem72#1;havoc ibmpex_ver_check_#t~mem73#1;havoc ibmpex_ver_check_#t~short74#1;call ibmpex_ver_check_#t~mem75#1 := read~int(ibmpex_ver_check_~data#1.base, 619 + ibmpex_ver_check_~data#1.offset, 1);call write~int(ibmpex_ver_check_#t~mem75#1, ibmpex_ver_check_~data#1.base, 904 + ibmpex_ver_check_~data#1.offset, 1);havoc ibmpex_ver_check_#t~mem75#1;call ibmpex_ver_check_#t~mem76#1 := read~int(ibmpex_ver_check_~data#1.base, 620 + ibmpex_ver_check_~data#1.offset, 1);call write~int(ibmpex_ver_check_#t~mem76#1, ibmpex_ver_check_~data#1.base, 905 + ibmpex_ver_check_~data#1.offset, 1);havoc ibmpex_ver_check_#t~mem76#1; {10869#true} is VALID [2022-02-20 21:35:39,013 INFO L272 TraceCheckUtils]: 56: Hoare triple {10869#true} call ibmpex_ver_check_#t~ret77#1 := extract_value(ibmpex_ver_check_~data#1.base, 619 + ibmpex_ver_check_~data#1.offset, 2); {10869#true} is VALID [2022-02-20 21:35:39,013 INFO L290 TraceCheckUtils]: 57: Hoare triple {10869#true} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;~offset#1 := #in~offset#1;havoc ~tmp~3#1;assume { :begin_inline___be16_to_cpup } true;__be16_to_cpup_#in~p#1.base, __be16_to_cpup_#in~p#1.offset := ~data#1.base, ~data#1.offset + 2 * (if ~offset#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then ~offset#1 % 18446744073709551616 % 18446744073709551616 else ~offset#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616);havoc __be16_to_cpup_#res#1;havoc __be16_to_cpup_#t~ret3#1, __be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset, __be16_to_cpup_~tmp~1#1;__be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset := __be16_to_cpup_#in~p#1.base, __be16_to_cpup_#in~p#1.offset;havoc __be16_to_cpup_~tmp~1#1;assume { :begin_inline___swab16p } true;__swab16p_#in~p#1.base, __swab16p_#in~p#1.offset := __be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset;havoc __swab16p_#res#1;havoc __swab16p_#t~mem1#1, __swab16p_#t~ret2#1, __swab16p_~p#1.base, __swab16p_~p#1.offset, __swab16p_~tmp~0#1;__swab16p_~p#1.base, __swab16p_~p#1.offset := __swab16p_#in~p#1.base, __swab16p_#in~p#1.offset;havoc __swab16p_~tmp~0#1;call __swab16p_#t~mem1#1 := read~int(__swab16p_~p#1.base, __swab16p_~p#1.offset, 2);assume { :begin_inline___fswab16 } true;__fswab16_#in~val#1 := __swab16p_#t~mem1#1 % 65536;havoc __fswab16_#res#1;havoc __fswab16_~val#1;__fswab16_~val#1 := __fswab16_#in~val#1;__fswab16_#res#1 := (if (1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) || 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536)) && 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) then (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) else (if 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) && (1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) || 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536)) then (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) else (if (1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) && (1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) || 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536))) || ((1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) || 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536)) && 1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536)) then 1 else ~bitwiseOr((if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536), (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536))))); {10869#true} is VALID [2022-02-20 21:35:39,013 INFO L290 TraceCheckUtils]: 58: Hoare triple {10869#true} __swab16p_#t~ret2#1 := __fswab16_#res#1;assume { :end_inline___fswab16 } true;__swab16p_~tmp~0#1 := __swab16p_#t~ret2#1;havoc __swab16p_#t~mem1#1;havoc __swab16p_#t~ret2#1;__swab16p_#res#1 := __swab16p_~tmp~0#1; {10869#true} is VALID [2022-02-20 21:35:39,013 INFO L290 TraceCheckUtils]: 59: Hoare triple {10869#true} __be16_to_cpup_#t~ret3#1 := __swab16p_#res#1;assume { :end_inline___swab16p } true;__be16_to_cpup_~tmp~1#1 := __be16_to_cpup_#t~ret3#1;havoc __be16_to_cpup_#t~ret3#1;__be16_to_cpup_#res#1 := __be16_to_cpup_~tmp~1#1; {10869#true} is VALID [2022-02-20 21:35:39,014 INFO L290 TraceCheckUtils]: 60: Hoare triple {10869#true} #t~ret61#1 := __be16_to_cpup_#res#1;assume { :end_inline___be16_to_cpup } true;~tmp~3#1 := #t~ret61#1;havoc #t~ret61#1;#res#1 := ~tmp~3#1; {10869#true} is VALID [2022-02-20 21:35:39,014 INFO L290 TraceCheckUtils]: 61: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:39,014 INFO L284 TraceCheckUtils]: 62: Hoare quadruple {10869#true} {10869#true} #622#return; {10869#true} is VALID [2022-02-20 21:35:39,014 INFO L290 TraceCheckUtils]: 63: Hoare triple {10869#true} ibmpex_ver_check_~tmp~4#1 := ibmpex_ver_check_#t~ret77#1;havoc ibmpex_ver_check_#t~ret77#1;havoc ibmpex_ver_check_#t~nondet78#1;call ibmpex_ver_check_#t~mem79#1.base, ibmpex_ver_check_#t~mem79#1.offset := read~$Pointer$(ibmpex_ver_check_~data#1.base, 24 + ibmpex_ver_check_~data#1.offset, 8);call ibmpex_ver_check_#t~mem80#1 := read~int(ibmpex_ver_check_~data#1.base, 904 + ibmpex_ver_check_~data#1.offset, 1);call ibmpex_ver_check_#t~mem81#1 := read~int(ibmpex_ver_check_~data#1.base, 905 + ibmpex_ver_check_~data#1.offset, 1);call ibmpex_ver_check_#t~mem82#1 := read~int(ibmpex_ver_check_~data#1.base, 623 + ibmpex_ver_check_~data#1.offset, 1);call ibmpex_ver_check_#t~mem83#1 := read~int(ibmpex_ver_check_~data#1.base, 624 + ibmpex_ver_check_~data#1.offset, 1);call ibmpex_ver_check_#t~mem84#1 := read~int(ibmpex_ver_check_~data#1.base, 323 + ibmpex_ver_check_~data#1.offset, 4);havoc ibmpex_ver_check_#t~mem79#1.base, ibmpex_ver_check_#t~mem79#1.offset;havoc ibmpex_ver_check_#t~mem80#1;havoc ibmpex_ver_check_#t~mem81#1;havoc ibmpex_ver_check_#t~mem82#1;havoc ibmpex_ver_check_#t~mem83#1;havoc ibmpex_ver_check_#t~mem84#1;ibmpex_ver_check_#res#1 := 0; {10869#true} is VALID [2022-02-20 21:35:39,014 INFO L290 TraceCheckUtils]: 64: Hoare triple {10869#true} ibmpex_register_bmc_#t~ret184#1 := ibmpex_ver_check_#res#1;assume { :end_inline_ibmpex_ver_check } true;assume -2147483648 <= ibmpex_register_bmc_#t~ret184#1 && ibmpex_register_bmc_#t~ret184#1 <= 2147483647;ibmpex_register_bmc_~err~4#1 := ibmpex_register_bmc_#t~ret184#1;havoc ibmpex_register_bmc_#t~ret184#1; {10869#true} is VALID [2022-02-20 21:35:39,014 INFO L290 TraceCheckUtils]: 65: Hoare triple {10869#true} assume !(0 != ibmpex_register_bmc_~err~4#1);call ibmpex_register_bmc_#t~mem185#1.base, ibmpex_register_bmc_#t~mem185#1.offset := read~$Pointer$(ibmpex_register_bmc_~data~2#1.base, 24 + ibmpex_register_bmc_~data~2#1.offset, 8);assume { :begin_inline_hwmon_device_register } true;hwmon_device_register_#in~arg0#1.base, hwmon_device_register_#in~arg0#1.offset := ibmpex_register_bmc_#t~mem185#1.base, ibmpex_register_bmc_#t~mem185#1.offset;havoc hwmon_device_register_#res#1.base, hwmon_device_register_#res#1.offset;havoc hwmon_device_register_#t~ret248#1.base, hwmon_device_register_#t~ret248#1.offset, hwmon_device_register_~arg0#1.base, hwmon_device_register_~arg0#1.offset;hwmon_device_register_~arg0#1.base, hwmon_device_register_~arg0#1.offset := hwmon_device_register_#in~arg0#1.base, hwmon_device_register_#in~arg0#1.offset; {10869#true} is VALID [2022-02-20 21:35:39,015 INFO L272 TraceCheckUtils]: 66: Hoare triple {10869#true} call hwmon_device_register_#t~ret248#1.base, hwmon_device_register_#t~ret248#1.offset := ldv_malloc(1035); {10869#true} is VALID [2022-02-20 21:35:39,015 INFO L290 TraceCheckUtils]: 67: Hoare triple {10869#true} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {10869#true} is VALID [2022-02-20 21:35:39,015 INFO L290 TraceCheckUtils]: 68: Hoare triple {10869#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {10869#true} is VALID [2022-02-20 21:35:39,015 INFO L290 TraceCheckUtils]: 69: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:39,015 INFO L284 TraceCheckUtils]: 70: Hoare quadruple {10869#true} {10869#true} #624#return; {10869#true} is VALID [2022-02-20 21:35:39,015 INFO L290 TraceCheckUtils]: 71: Hoare triple {10869#true} hwmon_device_register_#res#1.base, hwmon_device_register_#res#1.offset := hwmon_device_register_#t~ret248#1.base, hwmon_device_register_#t~ret248#1.offset;havoc hwmon_device_register_#t~ret248#1.base, hwmon_device_register_#t~ret248#1.offset; {10869#true} is VALID [2022-02-20 21:35:39,016 INFO L290 TraceCheckUtils]: 72: Hoare triple {10869#true} ibmpex_register_bmc_#t~ret186#1.base, ibmpex_register_bmc_#t~ret186#1.offset := hwmon_device_register_#res#1.base, hwmon_device_register_#res#1.offset;assume { :end_inline_hwmon_device_register } true;call write~$Pointer$(ibmpex_register_bmc_#t~ret186#1.base, ibmpex_register_bmc_#t~ret186#1.offset, ibmpex_register_bmc_~data~2#1.base, 16 + ibmpex_register_bmc_~data~2#1.offset, 8);havoc ibmpex_register_bmc_#t~mem185#1.base, ibmpex_register_bmc_#t~mem185#1.offset;havoc ibmpex_register_bmc_#t~ret186#1.base, ibmpex_register_bmc_#t~ret186#1.offset;call ibmpex_register_bmc_#t~mem187#1.base, ibmpex_register_bmc_#t~mem187#1.offset := read~$Pointer$(ibmpex_register_bmc_~data~2#1.base, 16 + ibmpex_register_bmc_~data~2#1.offset, 8);assume { :begin_inline_IS_ERR } true;IS_ERR_#in~ptr#1.base, IS_ERR_#in~ptr#1.offset := ibmpex_register_bmc_#t~mem187#1.base, ibmpex_register_bmc_#t~mem187#1.offset;havoc IS_ERR_#res#1;havoc IS_ERR_#t~ret240#1, IS_ERR_~ptr#1.base, IS_ERR_~ptr#1.offset, IS_ERR_~tmp~18#1;IS_ERR_~ptr#1.base, IS_ERR_~ptr#1.offset := IS_ERR_#in~ptr#1.base, IS_ERR_#in~ptr#1.offset;havoc IS_ERR_~tmp~18#1; {10869#true} is VALID [2022-02-20 21:35:39,016 INFO L272 TraceCheckUtils]: 73: Hoare triple {10869#true} call IS_ERR_#t~ret240#1 := ldv_is_err(IS_ERR_~ptr#1.base, IS_ERR_~ptr#1.offset); {10869#true} is VALID [2022-02-20 21:35:39,016 INFO L290 TraceCheckUtils]: 74: Hoare triple {10869#true} ~ptr.base, ~ptr.offset := #in~ptr.base, #in~ptr.offset;#res := (if (~ptr.base + ~ptr.offset) % 18446744073709551616 > 2012 then 1 else 0); {10869#true} is VALID [2022-02-20 21:35:39,016 INFO L290 TraceCheckUtils]: 75: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:39,016 INFO L284 TraceCheckUtils]: 76: Hoare quadruple {10869#true} {10869#true} #626#return; {10869#true} is VALID [2022-02-20 21:35:39,017 INFO L290 TraceCheckUtils]: 77: Hoare triple {10869#true} assume -9223372036854775808 <= IS_ERR_#t~ret240#1 && IS_ERR_#t~ret240#1 <= 9223372036854775807;IS_ERR_~tmp~18#1 := IS_ERR_#t~ret240#1;havoc IS_ERR_#t~ret240#1;IS_ERR_#res#1 := IS_ERR_~tmp~18#1; {10869#true} is VALID [2022-02-20 21:35:39,017 INFO L290 TraceCheckUtils]: 78: Hoare triple {10869#true} ibmpex_register_bmc_#t~ret188#1 := IS_ERR_#res#1;assume { :end_inline_IS_ERR } true;assume -9223372036854775808 <= ibmpex_register_bmc_#t~ret188#1 && ibmpex_register_bmc_#t~ret188#1 <= 9223372036854775807;ibmpex_register_bmc_~tmp___0~3#1 := ibmpex_register_bmc_#t~ret188#1;havoc ibmpex_register_bmc_#t~mem187#1.base, ibmpex_register_bmc_#t~mem187#1.offset;havoc ibmpex_register_bmc_#t~ret188#1; {10869#true} is VALID [2022-02-20 21:35:39,017 INFO L290 TraceCheckUtils]: 79: Hoare triple {10869#true} assume !(0 != ibmpex_register_bmc_~tmp___0~3#1); {10869#true} is VALID [2022-02-20 21:35:39,017 INFO L272 TraceCheckUtils]: 80: Hoare triple {10869#true} call dev_set_drvdata(ibmpex_register_bmc_~dev#1.base, ibmpex_register_bmc_~dev#1.offset, ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset); {10869#true} is VALID [2022-02-20 21:35:39,017 INFO L290 TraceCheckUtils]: 81: Hoare triple {10869#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset;~arg1.base, ~arg1.offset := #in~arg1.base, #in~arg1.offset; {10869#true} is VALID [2022-02-20 21:35:39,017 INFO L290 TraceCheckUtils]: 82: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:39,018 INFO L284 TraceCheckUtils]: 83: Hoare quadruple {10869#true} {10869#true} #628#return; {10869#true} is VALID [2022-02-20 21:35:39,018 INFO L290 TraceCheckUtils]: 84: Hoare triple {10869#true} assume { :begin_inline_list_add_tail } true;list_add_tail_#in~new#1.base, list_add_tail_#in~new#1.offset, list_add_tail_#in~head#1.base, list_add_tail_#in~head#1.offset := ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset, ~#driver_data~0.base, ~#driver_data~0.offset;havoc list_add_tail_#t~mem12#1.base, list_add_tail_#t~mem12#1.offset, list_add_tail_~new#1.base, list_add_tail_~new#1.offset, list_add_tail_~head#1.base, list_add_tail_~head#1.offset;list_add_tail_~new#1.base, list_add_tail_~new#1.offset := list_add_tail_#in~new#1.base, list_add_tail_#in~new#1.offset;list_add_tail_~head#1.base, list_add_tail_~head#1.offset := list_add_tail_#in~head#1.base, list_add_tail_#in~head#1.offset;call list_add_tail_#t~mem12#1.base, list_add_tail_#t~mem12#1.offset := read~$Pointer$(list_add_tail_~head#1.base, 8 + list_add_tail_~head#1.offset, 8);assume { :begin_inline___list_add } true;__list_add_#in~arg0#1.base, __list_add_#in~arg0#1.offset, __list_add_#in~arg1#1.base, __list_add_#in~arg1#1.offset, __list_add_#in~arg2#1.base, __list_add_#in~arg2#1.offset := list_add_tail_~new#1.base, list_add_tail_~new#1.offset, list_add_tail_#t~mem12#1.base, list_add_tail_#t~mem12#1.offset, list_add_tail_~head#1.base, list_add_tail_~head#1.offset;havoc __list_add_~arg0#1.base, __list_add_~arg0#1.offset, __list_add_~arg1#1.base, __list_add_~arg1#1.offset, __list_add_~arg2#1.base, __list_add_~arg2#1.offset;__list_add_~arg0#1.base, __list_add_~arg0#1.offset := __list_add_#in~arg0#1.base, __list_add_#in~arg0#1.offset;__list_add_~arg1#1.base, __list_add_~arg1#1.offset := __list_add_#in~arg1#1.base, __list_add_#in~arg1#1.offset;__list_add_~arg2#1.base, __list_add_~arg2#1.offset := __list_add_#in~arg2#1.base, __list_add_#in~arg2#1.offset; {10869#true} is VALID [2022-02-20 21:35:39,018 INFO L290 TraceCheckUtils]: 85: Hoare triple {10869#true} assume { :end_inline___list_add } true;havoc list_add_tail_#t~mem12#1.base, list_add_tail_#t~mem12#1.offset; {10869#true} is VALID [2022-02-20 21:35:39,018 INFO L290 TraceCheckUtils]: 86: Hoare triple {10869#true} assume { :end_inline_list_add_tail } true;assume { :begin_inline_ibmpex_find_sensors } true;ibmpex_find_sensors_#in~data#1.base, ibmpex_find_sensors_#in~data#1.offset := ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset;havoc ibmpex_find_sensors_#res#1;havoc ibmpex_find_sensors_#t~ret148#1, ibmpex_find_sensors_#t~mem149#1, ibmpex_find_sensors_#t~ret150#1.base, ibmpex_find_sensors_#t~ret150#1.offset, ibmpex_find_sensors_#t~mem151#1.base, ibmpex_find_sensors_#t~mem151#1.offset, ibmpex_find_sensors_#t~ret152#1, ibmpex_find_sensors_#t~mem153#1, ibmpex_find_sensors_#t~ret154#1, ibmpex_find_sensors_#t~mem155#1.base, ibmpex_find_sensors_#t~mem155#1.offset, ibmpex_find_sensors_#t~mem156#1, ibmpex_find_sensors_#t~ret157#1, ibmpex_find_sensors_#t~mem158#1, ibmpex_find_sensors_#t~ret159#1, ibmpex_find_sensors_#t~mem160#1.base, ibmpex_find_sensors_#t~mem160#1.offset, ibmpex_find_sensors_#t~mem161#1.base, ibmpex_find_sensors_#t~mem161#1.offset, ibmpex_find_sensors_#t~ret162#1, ibmpex_find_sensors_#t~mem163#1, ibmpex_find_sensors_#t~mem164#1.base, ibmpex_find_sensors_#t~mem164#1.offset, ibmpex_find_sensors_#t~ret165#1, ibmpex_find_sensors_#t~mem166#1.base, ibmpex_find_sensors_#t~mem166#1.offset, ibmpex_find_sensors_#t~ret167#1, ibmpex_find_sensors_#t~mem168#1.base, ibmpex_find_sensors_#t~mem168#1.offset, ibmpex_find_sensors_#t~mem169#1.base, ibmpex_find_sensors_#t~mem169#1.offset, ibmpex_find_sensors_#t~mem170#1.base, ibmpex_find_sensors_#t~mem170#1.offset, ibmpex_find_sensors_#t~mem171#1.base, ibmpex_find_sensors_#t~mem171#1.offset, ibmpex_find_sensors_#t~mem172#1.base, ibmpex_find_sensors_#t~mem172#1.offset, ibmpex_find_sensors_#t~mem173#1.base, ibmpex_find_sensors_#t~mem173#1.offset, ibmpex_find_sensors_#t~mem174#1.base, ibmpex_find_sensors_#t~mem174#1.offset, ibmpex_find_sensors_#t~mem175#1.base, ibmpex_find_sensors_#t~mem175#1.offset, ibmpex_find_sensors_#t~mem176#1, ibmpex_find_sensors_#t~mem177#1.base, ibmpex_find_sensors_#t~mem177#1.offset, ibmpex_find_sensors_~data#1.base, ibmpex_find_sensors_~data#1.offset, ibmpex_find_sensors_~i~2#1, ibmpex_find_sensors_~j~0#1, ibmpex_find_sensors_~err~3#1, ibmpex_find_sensors_~sensor_type~0#1, ibmpex_find_sensors_~sensor_counter~0#1, ibmpex_find_sensors_~num_power~0#1, ibmpex_find_sensors_~num_temp~0#1, ibmpex_find_sensors_~tmp~13#1.base, ibmpex_find_sensors_~tmp~13#1.offset, ibmpex_find_sensors_~tmp___0~2#1, ibmpex_find_sensors_~tmp___1~1#1;ibmpex_find_sensors_~data#1.base, ibmpex_find_sensors_~data#1.offset := ibmpex_find_sensors_#in~data#1.base, ibmpex_find_sensors_#in~data#1.offset;havoc ibmpex_find_sensors_~i~2#1;havoc ibmpex_find_sensors_~j~0#1;havoc ibmpex_find_sensors_~err~3#1;havoc ibmpex_find_sensors_~sensor_type~0#1;havoc ibmpex_find_sensors_~sensor_counter~0#1;havoc ibmpex_find_sensors_~num_power~0#1;havoc ibmpex_find_sensors_~num_temp~0#1;havoc ibmpex_find_sensors_~tmp~13#1.base, ibmpex_find_sensors_~tmp~13#1.offset;havoc ibmpex_find_sensors_~tmp___0~2#1;havoc ibmpex_find_sensors_~tmp___1~1#1;ibmpex_find_sensors_~num_power~0#1 := 0;ibmpex_find_sensors_~num_temp~0#1 := 0;assume { :begin_inline_ibmpex_query_sensor_count } true;ibmpex_query_sensor_count_#in~data#1.base, ibmpex_query_sensor_count_#in~data#1.offset := ibmpex_find_sensors_~data#1.base, ibmpex_find_sensors_~data#1.offset;havoc ibmpex_query_sensor_count_#res#1;havoc ibmpex_query_sensor_count_#t~ret85#1, ibmpex_query_sensor_count_#t~mem86#1, ibmpex_query_sensor_count_#t~mem87#1, ibmpex_query_sensor_count_#t~short88#1, ibmpex_query_sensor_count_#t~mem89#1, ibmpex_query_sensor_count_~data#1.base, ibmpex_query_sensor_count_~data#1.offset;ibmpex_query_sensor_count_~data#1.base, ibmpex_query_sensor_count_~data#1.offset := ibmpex_query_sensor_count_#in~data#1.base, ibmpex_query_sensor_count_#in~data#1.offset;call write~int(2, ibmpex_query_sensor_count_~data#1.base, 339 + ibmpex_query_sensor_count_~data#1.offset, 1);call write~int(1, ibmpex_query_sensor_count_~data#1.base, 329 + ibmpex_query_sensor_count_~data#1.offset, 2); {10869#true} is VALID [2022-02-20 21:35:39,018 INFO L272 TraceCheckUtils]: 87: Hoare triple {10869#true} call ibmpex_query_sensor_count_#t~ret85#1 := ibmpex_send_message(ibmpex_query_sensor_count_~data#1.base, ibmpex_query_sensor_count_~data#1.offset); {10869#true} is VALID [2022-02-20 21:35:39,019 INFO L290 TraceCheckUtils]: 88: Hoare triple {10869#true} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;havoc ~err~0#1;assume { :begin_inline_ipmi_validate_addr } true;ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset, ipmi_validate_addr_#in~arg1#1 := ~data#1.base, 193 + ~data#1.offset, 40;havoc ipmi_validate_addr_#res#1;havoc ipmi_validate_addr_#t~nondet254#1, ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset, ipmi_validate_addr_~arg1#1;ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset := ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset;ipmi_validate_addr_~arg1#1 := ipmi_validate_addr_#in~arg1#1;assume -2147483648 <= ipmi_validate_addr_#t~nondet254#1 && ipmi_validate_addr_#t~nondet254#1 <= 2147483647;ipmi_validate_addr_#res#1 := ipmi_validate_addr_#t~nondet254#1;havoc ipmi_validate_addr_#t~nondet254#1; {10869#true} is VALID [2022-02-20 21:35:39,019 INFO L290 TraceCheckUtils]: 89: Hoare triple {10869#true} #t~ret62#1 := ipmi_validate_addr_#res#1;assume { :end_inline_ipmi_validate_addr } true;assume -2147483648 <= #t~ret62#1 && #t~ret62#1 <= 2147483647;~err~0#1 := #t~ret62#1;havoc #t~ret62#1; {10869#true} is VALID [2022-02-20 21:35:39,019 INFO L290 TraceCheckUtils]: 90: Hoare triple {10869#true} assume 0 != ~err~0#1; {10869#true} is VALID [2022-02-20 21:35:39,019 INFO L290 TraceCheckUtils]: 91: Hoare triple {10869#true} havoc #t~nondet69#1;call #t~mem70#1.base, #t~mem70#1.offset := read~$Pointer$(~data#1.base, 24 + ~data#1.offset, 8);havoc #t~mem70#1.base, #t~mem70#1.offset;#res#1 := ~err~0#1; {10869#true} is VALID [2022-02-20 21:35:39,019 INFO L290 TraceCheckUtils]: 92: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:39,019 INFO L284 TraceCheckUtils]: 93: Hoare quadruple {10869#true} {10869#true} #630#return; {10869#true} is VALID [2022-02-20 21:35:39,020 INFO L290 TraceCheckUtils]: 94: Hoare triple {10869#true} assume -2147483648 <= ibmpex_query_sensor_count_#t~ret85#1 && ibmpex_query_sensor_count_#t~ret85#1 <= 2147483647;havoc ibmpex_query_sensor_count_#t~ret85#1; {10869#true} is VALID [2022-02-20 21:35:39,020 INFO L272 TraceCheckUtils]: 95: Hoare triple {10869#true} call wait_for_completion(ibmpex_query_sensor_count_~data#1.base, 231 + ibmpex_query_sensor_count_~data#1.offset); {10869#true} is VALID [2022-02-20 21:35:39,020 INFO L290 TraceCheckUtils]: 96: Hoare triple {10869#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset; {10869#true} is VALID [2022-02-20 21:35:39,020 INFO L290 TraceCheckUtils]: 97: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:39,020 INFO L284 TraceCheckUtils]: 98: Hoare quadruple {10869#true} {10869#true} #632#return; {10869#true} is VALID [2022-02-20 21:35:39,020 INFO L290 TraceCheckUtils]: 99: Hoare triple {10869#true} call ibmpex_query_sensor_count_#t~mem86#1 := read~int(ibmpex_query_sensor_count_~data#1.base, 899 + ibmpex_query_sensor_count_~data#1.offset, 1);ibmpex_query_sensor_count_#t~short88#1 := 0 != ibmpex_query_sensor_count_#t~mem86#1 % 256 % 4294967296; {10869#true} is VALID [2022-02-20 21:35:39,021 INFO L290 TraceCheckUtils]: 100: Hoare triple {10869#true} assume !ibmpex_query_sensor_count_#t~short88#1;call ibmpex_query_sensor_count_#t~mem87#1 := read~int(ibmpex_query_sensor_count_~data#1.base, 891 + ibmpex_query_sensor_count_~data#1.offset, 8);ibmpex_query_sensor_count_#t~short88#1 := 1 != ibmpex_query_sensor_count_#t~mem87#1 % 18446744073709551616; {10869#true} is VALID [2022-02-20 21:35:39,021 INFO L290 TraceCheckUtils]: 101: Hoare triple {10869#true} assume !ibmpex_query_sensor_count_#t~short88#1;havoc ibmpex_query_sensor_count_#t~mem86#1;havoc ibmpex_query_sensor_count_#t~mem87#1;havoc ibmpex_query_sensor_count_#t~short88#1;call ibmpex_query_sensor_count_#t~mem89#1 := read~int(ibmpex_query_sensor_count_~data#1.base, 619 + ibmpex_query_sensor_count_~data#1.offset, 1);ibmpex_query_sensor_count_#res#1 := ibmpex_query_sensor_count_#t~mem89#1 % 256;havoc ibmpex_query_sensor_count_#t~mem89#1; {10869#true} is VALID [2022-02-20 21:35:39,021 INFO L290 TraceCheckUtils]: 102: Hoare triple {10869#true} ibmpex_find_sensors_#t~ret148#1 := ibmpex_query_sensor_count_#res#1;assume { :end_inline_ibmpex_query_sensor_count } true;assume -2147483648 <= ibmpex_find_sensors_#t~ret148#1 && ibmpex_find_sensors_#t~ret148#1 <= 2147483647;ibmpex_find_sensors_~err~3#1 := ibmpex_find_sensors_#t~ret148#1;havoc ibmpex_find_sensors_#t~ret148#1; {10869#true} is VALID [2022-02-20 21:35:39,021 INFO L290 TraceCheckUtils]: 103: Hoare triple {10869#true} assume !(ibmpex_find_sensors_~err~3#1 <= 0);call write~int(ibmpex_find_sensors_~err~3#1, ibmpex_find_sensors_~data#1.base, 906 + ibmpex_find_sensors_~data#1.offset, 1);call ibmpex_find_sensors_#t~mem149#1 := read~int(ibmpex_find_sensors_~data#1.base, 906 + ibmpex_find_sensors_~data#1.offset, 1); {10869#true} is VALID [2022-02-20 21:35:39,021 INFO L272 TraceCheckUtils]: 104: Hoare triple {10869#true} call ibmpex_find_sensors_#t~ret150#1.base, ibmpex_find_sensors_#t~ret150#1.offset := kzalloc(184 * (ibmpex_find_sensors_#t~mem149#1 % 256), 208); {10869#true} is VALID [2022-02-20 21:35:39,021 INFO L290 TraceCheckUtils]: 105: Hoare triple {10869#true} ~size := #in~size;~flags := #in~flags;havoc ~tmp~2.base, ~tmp~2.offset; {10869#true} is VALID [2022-02-20 21:35:39,022 INFO L272 TraceCheckUtils]: 106: Hoare triple {10869#true} call #t~ret40.base, #t~ret40.offset := kmalloc(~size, ~bitwiseOr(~flags, 32768)); {10869#true} is VALID [2022-02-20 21:35:39,022 INFO L290 TraceCheckUtils]: 107: Hoare triple {10869#true} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {10869#true} is VALID [2022-02-20 21:35:39,022 INFO L272 TraceCheckUtils]: 108: Hoare triple {10869#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {10869#true} is VALID [2022-02-20 21:35:39,022 INFO L290 TraceCheckUtils]: 109: Hoare triple {10869#true} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {10869#true} is VALID [2022-02-20 21:35:39,022 INFO L290 TraceCheckUtils]: 110: Hoare triple {10869#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {10869#true} is VALID [2022-02-20 21:35:39,023 INFO L290 TraceCheckUtils]: 111: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:39,023 INFO L284 TraceCheckUtils]: 112: Hoare quadruple {10869#true} {10869#true} #590#return; {10869#true} is VALID [2022-02-20 21:35:39,023 INFO L290 TraceCheckUtils]: 113: Hoare triple {10869#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {10869#true} is VALID [2022-02-20 21:35:39,023 INFO L290 TraceCheckUtils]: 114: Hoare triple {10869#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {10869#true} is VALID [2022-02-20 21:35:39,023 INFO L290 TraceCheckUtils]: 115: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:39,023 INFO L284 TraceCheckUtils]: 116: Hoare quadruple {10869#true} {10869#true} #588#return; {10869#true} is VALID [2022-02-20 21:35:39,024 INFO L290 TraceCheckUtils]: 117: Hoare triple {10869#true} ~tmp~2.base, ~tmp~2.offset := #t~ret40.base, #t~ret40.offset;havoc #t~ret40.base, #t~ret40.offset;#res.base, #res.offset := ~tmp~2.base, ~tmp~2.offset; {10869#true} is VALID [2022-02-20 21:35:39,024 INFO L290 TraceCheckUtils]: 118: Hoare triple {10869#true} assume true; {10869#true} is VALID [2022-02-20 21:35:39,024 INFO L284 TraceCheckUtils]: 119: Hoare quadruple {10869#true} {10869#true} #634#return; {10869#true} is VALID [2022-02-20 21:35:39,024 INFO L290 TraceCheckUtils]: 120: Hoare triple {10869#true} ibmpex_find_sensors_~tmp~13#1.base, ibmpex_find_sensors_~tmp~13#1.offset := ibmpex_find_sensors_#t~ret150#1.base, ibmpex_find_sensors_#t~ret150#1.offset;havoc ibmpex_find_sensors_#t~mem149#1;havoc ibmpex_find_sensors_#t~ret150#1.base, ibmpex_find_sensors_#t~ret150#1.offset;call write~$Pointer$(ibmpex_find_sensors_~tmp~13#1.base, ibmpex_find_sensors_~tmp~13#1.offset, ibmpex_find_sensors_~data#1.base, 907 + ibmpex_find_sensors_~data#1.offset, 8);call ibmpex_find_sensors_#t~mem151#1.base, ibmpex_find_sensors_#t~mem151#1.offset := read~$Pointer$(ibmpex_find_sensors_~data#1.base, 907 + ibmpex_find_sensors_~data#1.offset, 8); {10869#true} is VALID [2022-02-20 21:35:39,024 INFO L290 TraceCheckUtils]: 121: Hoare triple {10869#true} assume !(0 == (ibmpex_find_sensors_#t~mem151#1.base + ibmpex_find_sensors_#t~mem151#1.offset) % 18446744073709551616);havoc ibmpex_find_sensors_#t~mem151#1.base, ibmpex_find_sensors_#t~mem151#1.offset;ibmpex_find_sensors_~i~2#1 := 0; {10869#true} is VALID [2022-02-20 21:35:39,025 INFO L290 TraceCheckUtils]: 122: Hoare triple {10869#true} call ibmpex_find_sensors_#t~mem163#1 := read~int(ibmpex_find_sensors_~data#1.base, 906 + ibmpex_find_sensors_~data#1.offset, 1); {10869#true} is VALID [2022-02-20 21:35:39,025 INFO L290 TraceCheckUtils]: 123: Hoare triple {10869#true} assume !(ibmpex_find_sensors_#t~mem163#1 % 256 > ibmpex_find_sensors_~i~2#1);havoc ibmpex_find_sensors_#t~mem163#1;call ibmpex_find_sensors_#t~mem164#1.base, ibmpex_find_sensors_#t~mem164#1.offset := read~$Pointer$(ibmpex_find_sensors_~data#1.base, 24 + ibmpex_find_sensors_~data#1.offset, 8);assume { :begin_inline_ldv_device_create_file_6 } true;ldv_device_create_file_6_#in~ldv_func_arg1#1.base, ldv_device_create_file_6_#in~ldv_func_arg1#1.offset, ldv_device_create_file_6_#in~ldv_func_arg2#1.base, ldv_device_create_file_6_#in~ldv_func_arg2#1.offset := ibmpex_find_sensors_#t~mem164#1.base, ibmpex_find_sensors_#t~mem164#1.offset, ~#sensor_dev_attr_reset_high_low~0.base, ~#sensor_dev_attr_reset_high_low~0.offset;havoc ldv_device_create_file_6_#res#1;havoc ldv_device_create_file_6_#t~ret242#1, ldv_device_create_file_6_~ldv_func_arg1#1.base, ldv_device_create_file_6_~ldv_func_arg1#1.offset, ldv_device_create_file_6_~ldv_func_arg2#1.base, ldv_device_create_file_6_~ldv_func_arg2#1.offset, ldv_device_create_file_6_~tmp~20#1;ldv_device_create_file_6_~ldv_func_arg1#1.base, ldv_device_create_file_6_~ldv_func_arg1#1.offset := ldv_device_create_file_6_#in~ldv_func_arg1#1.base, ldv_device_create_file_6_#in~ldv_func_arg1#1.offset;ldv_device_create_file_6_~ldv_func_arg2#1.base, ldv_device_create_file_6_~ldv_func_arg2#1.offset := ldv_device_create_file_6_#in~ldv_func_arg2#1.base, ldv_device_create_file_6_#in~ldv_func_arg2#1.offset;havoc ldv_device_create_file_6_~tmp~20#1; {10869#true} is VALID [2022-02-20 21:35:39,025 INFO L272 TraceCheckUtils]: 124: Hoare triple {10869#true} call ldv_device_create_file_6_#t~ret242#1 := ldv_device_create_file_dev_attr_of_sensor_device_attribute(ldv_device_create_file_6_~ldv_func_arg2#1.base, ldv_device_create_file_6_~ldv_func_arg2#1.offset); {10869#true} is VALID [2022-02-20 21:35:39,025 INFO L290 TraceCheckUtils]: 125: Hoare triple {10869#true} ~attr.base, ~attr.offset := #in~attr.base, #in~attr.offset; {10869#true} is VALID [2022-02-20 21:35:39,026 INFO L290 TraceCheckUtils]: 126: Hoare triple {10869#true} assume 0 == ~ldv_call_dev_attr_of_sensor_device_attribute~0;~ldv_count_2~0 := 1 + ~ldv_count_2~0;~ldv_call_dev_attr_of_sensor_device_attribute~0 := 1; {11358#(<= 1 ~ldv_call_dev_attr_of_sensor_device_attribute~0)} is VALID [2022-02-20 21:35:39,026 INFO L290 TraceCheckUtils]: 127: Hoare triple {11358#(<= 1 ~ldv_call_dev_attr_of_sensor_device_attribute~0)} assume ~ldv_count_1~0 >= ~ldv_count_2~0; {11358#(<= 1 ~ldv_call_dev_attr_of_sensor_device_attribute~0)} is VALID [2022-02-20 21:35:39,026 INFO L290 TraceCheckUtils]: 128: Hoare triple {11358#(<= 1 ~ldv_call_dev_attr_of_sensor_device_attribute~0)} #res := 0; {11358#(<= 1 ~ldv_call_dev_attr_of_sensor_device_attribute~0)} is VALID [2022-02-20 21:35:39,027 INFO L290 TraceCheckUtils]: 129: Hoare triple {11358#(<= 1 ~ldv_call_dev_attr_of_sensor_device_attribute~0)} assume true; {11358#(<= 1 ~ldv_call_dev_attr_of_sensor_device_attribute~0)} is VALID [2022-02-20 21:35:39,027 INFO L284 TraceCheckUtils]: 130: Hoare quadruple {11358#(<= 1 ~ldv_call_dev_attr_of_sensor_device_attribute~0)} {10869#true} #646#return; {11358#(<= 1 ~ldv_call_dev_attr_of_sensor_device_attribute~0)} is VALID [2022-02-20 21:35:39,028 INFO L290 TraceCheckUtils]: 131: Hoare triple {11358#(<= 1 ~ldv_call_dev_attr_of_sensor_device_attribute~0)} assume -2147483648 <= ldv_device_create_file_6_#t~ret242#1 && ldv_device_create_file_6_#t~ret242#1 <= 2147483647;ldv_device_create_file_6_~tmp~20#1 := ldv_device_create_file_6_#t~ret242#1;havoc ldv_device_create_file_6_#t~ret242#1;ldv_device_create_file_6_#res#1 := ldv_device_create_file_6_~tmp~20#1; {11358#(<= 1 ~ldv_call_dev_attr_of_sensor_device_attribute~0)} is VALID [2022-02-20 21:35:39,028 INFO L290 TraceCheckUtils]: 132: Hoare triple {11358#(<= 1 ~ldv_call_dev_attr_of_sensor_device_attribute~0)} ibmpex_find_sensors_#t~ret165#1 := ldv_device_create_file_6_#res#1;assume { :end_inline_ldv_device_create_file_6 } true;assume -2147483648 <= ibmpex_find_sensors_#t~ret165#1 && ibmpex_find_sensors_#t~ret165#1 <= 2147483647;ibmpex_find_sensors_~err~3#1 := ibmpex_find_sensors_#t~ret165#1;havoc ibmpex_find_sensors_#t~mem164#1.base, ibmpex_find_sensors_#t~mem164#1.offset;havoc ibmpex_find_sensors_#t~ret165#1; {11358#(<= 1 ~ldv_call_dev_attr_of_sensor_device_attribute~0)} is VALID [2022-02-20 21:35:39,029 INFO L290 TraceCheckUtils]: 133: Hoare triple {11358#(<= 1 ~ldv_call_dev_attr_of_sensor_device_attribute~0)} assume !(0 != ibmpex_find_sensors_~err~3#1);call ibmpex_find_sensors_#t~mem166#1.base, ibmpex_find_sensors_#t~mem166#1.offset := read~$Pointer$(ibmpex_find_sensors_~data#1.base, 24 + ibmpex_find_sensors_~data#1.offset, 8);assume { :begin_inline_ldv_device_create_file_7 } true;ldv_device_create_file_7_#in~ldv_func_arg1#1.base, ldv_device_create_file_7_#in~ldv_func_arg1#1.offset, ldv_device_create_file_7_#in~ldv_func_arg2#1.base, ldv_device_create_file_7_#in~ldv_func_arg2#1.offset := ibmpex_find_sensors_#t~mem166#1.base, ibmpex_find_sensors_#t~mem166#1.offset, ~#sensor_dev_attr_name~0.base, ~#sensor_dev_attr_name~0.offset;havoc ldv_device_create_file_7_#res#1;havoc ldv_device_create_file_7_#t~ret243#1, ldv_device_create_file_7_~ldv_func_arg1#1.base, ldv_device_create_file_7_~ldv_func_arg1#1.offset, ldv_device_create_file_7_~ldv_func_arg2#1.base, ldv_device_create_file_7_~ldv_func_arg2#1.offset, ldv_device_create_file_7_~tmp~21#1;ldv_device_create_file_7_~ldv_func_arg1#1.base, ldv_device_create_file_7_~ldv_func_arg1#1.offset := ldv_device_create_file_7_#in~ldv_func_arg1#1.base, ldv_device_create_file_7_#in~ldv_func_arg1#1.offset;ldv_device_create_file_7_~ldv_func_arg2#1.base, ldv_device_create_file_7_~ldv_func_arg2#1.offset := ldv_device_create_file_7_#in~ldv_func_arg2#1.base, ldv_device_create_file_7_#in~ldv_func_arg2#1.offset;havoc ldv_device_create_file_7_~tmp~21#1; {11358#(<= 1 ~ldv_call_dev_attr_of_sensor_device_attribute~0)} is VALID [2022-02-20 21:35:39,029 INFO L272 TraceCheckUtils]: 134: Hoare triple {11358#(<= 1 ~ldv_call_dev_attr_of_sensor_device_attribute~0)} call ldv_device_create_file_7_#t~ret243#1 := ldv_device_create_file_dev_attr_of_sensor_device_attribute(ldv_device_create_file_7_~ldv_func_arg2#1.base, ldv_device_create_file_7_~ldv_func_arg2#1.offset); {11358#(<= 1 ~ldv_call_dev_attr_of_sensor_device_attribute~0)} is VALID [2022-02-20 21:35:39,030 INFO L290 TraceCheckUtils]: 135: Hoare triple {11358#(<= 1 ~ldv_call_dev_attr_of_sensor_device_attribute~0)} ~attr.base, ~attr.offset := #in~attr.base, #in~attr.offset; {11358#(<= 1 ~ldv_call_dev_attr_of_sensor_device_attribute~0)} is VALID [2022-02-20 21:35:39,030 INFO L290 TraceCheckUtils]: 136: Hoare triple {11358#(<= 1 ~ldv_call_dev_attr_of_sensor_device_attribute~0)} assume 0 == ~ldv_call_dev_attr_of_sensor_device_attribute~0;~ldv_count_2~0 := 1 + ~ldv_count_2~0;~ldv_call_dev_attr_of_sensor_device_attribute~0 := 1; {10870#false} is VALID [2022-02-20 21:35:39,030 INFO L290 TraceCheckUtils]: 137: Hoare triple {10870#false} assume !(~ldv_count_1~0 >= ~ldv_count_2~0); {10870#false} is VALID [2022-02-20 21:35:39,030 INFO L272 TraceCheckUtils]: 138: Hoare triple {10870#false} call ldv_error(); {10870#false} is VALID [2022-02-20 21:35:39,031 INFO L290 TraceCheckUtils]: 139: Hoare triple {10870#false} assume !false; {10870#false} is VALID [2022-02-20 21:35:39,031 INFO L134 CoverageAnalysis]: Checked inductivity of 37 backedges. 3 proven. 0 refuted. 0 times theorem prover too weak. 34 trivial. 0 not checked. [2022-02-20 21:35:39,031 INFO L324 TraceCheckSpWp]: Omiting computation of backward sequence because forward sequence was already perfect [2022-02-20 21:35:39,031 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleZ3 [1173207069] provided 1 perfect and 0 imperfect interpolant sequences [2022-02-20 21:35:39,032 INFO L191 FreeRefinementEngine]: Found 1 perfect and 1 imperfect interpolant sequences. [2022-02-20 21:35:39,032 INFO L204 FreeRefinementEngine]: Number of different interpolants: perfect sequences [3] imperfect sequences [6] total 7 [2022-02-20 21:35:39,032 INFO L118 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [999548560] [2022-02-20 21:35:39,032 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-02-20 21:35:39,033 INFO L78 Accepts]: Start accepts. Automaton has has 3 states, 3 states have (on average 27.666666666666668) internal successors, (83), 3 states have internal predecessors, (83), 3 states have call successors, (17), 3 states have call predecessors, (17), 2 states have return successors, (15), 2 states have call predecessors, (15), 1 states have call successors, (15) Word has length 140 [2022-02-20 21:35:39,033 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-02-20 21:35:39,034 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with has 3 states, 3 states have (on average 27.666666666666668) internal successors, (83), 3 states have internal predecessors, (83), 3 states have call successors, (17), 3 states have call predecessors, (17), 2 states have return successors, (15), 2 states have call predecessors, (15), 1 states have call successors, (15) [2022-02-20 21:35:39,131 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 115 edges. 115 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 21:35:39,131 INFO L546 AbstractCegarLoop]: INTERPOLANT automaton has 3 states [2022-02-20 21:35:39,132 INFO L108 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2022-02-20 21:35:39,132 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 3 interpolants. [2022-02-20 21:35:39,132 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=12, Invalid=30, Unknown=0, NotChecked=0, Total=42 [2022-02-20 21:35:39,133 INFO L87 Difference]: Start difference. First operand 772 states and 1021 transitions. Second operand has 3 states, 3 states have (on average 27.666666666666668) internal successors, (83), 3 states have internal predecessors, (83), 3 states have call successors, (17), 3 states have call predecessors, (17), 2 states have return successors, (15), 2 states have call predecessors, (15), 1 states have call successors, (15) [2022-02-20 21:35:40,575 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 21:35:40,576 INFO L93 Difference]: Finished difference Result 1538 states and 2037 transitions. [2022-02-20 21:35:40,576 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 3 states. [2022-02-20 21:35:40,576 INFO L78 Accepts]: Start accepts. Automaton has has 3 states, 3 states have (on average 27.666666666666668) internal successors, (83), 3 states have internal predecessors, (83), 3 states have call successors, (17), 3 states have call predecessors, (17), 2 states have return successors, (15), 2 states have call predecessors, (15), 1 states have call successors, (15) Word has length 140 [2022-02-20 21:35:40,577 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-02-20 21:35:40,577 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 3 states, 3 states have (on average 27.666666666666668) internal successors, (83), 3 states have internal predecessors, (83), 3 states have call successors, (17), 3 states have call predecessors, (17), 2 states have return successors, (15), 2 states have call predecessors, (15), 1 states have call successors, (15) [2022-02-20 21:35:40,587 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 3 states to 3 states and 1015 transitions. [2022-02-20 21:35:40,587 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 3 states, 3 states have (on average 27.666666666666668) internal successors, (83), 3 states have internal predecessors, (83), 3 states have call successors, (17), 3 states have call predecessors, (17), 2 states have return successors, (15), 2 states have call predecessors, (15), 1 states have call successors, (15) [2022-02-20 21:35:40,597 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 3 states to 3 states and 1015 transitions. [2022-02-20 21:35:40,598 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with 3 states and 1015 transitions. [2022-02-20 21:35:41,385 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 1015 edges. 1015 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 21:35:41,498 INFO L225 Difference]: With dead ends: 1538 [2022-02-20 21:35:41,498 INFO L226 Difference]: Without dead ends: 1280 [2022-02-20 21:35:41,500 INFO L932 BasicCegarLoop]: 0 DeclaredPredicates, 178 GetRequests, 172 SyntacticMatches, 1 SemanticMatches, 5 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 0 ImplicationChecksByTransitivity, 0.0s TimeCoverageRelationStatistics Valid=12, Invalid=30, Unknown=0, NotChecked=0, Total=42 [2022-02-20 21:35:41,500 INFO L933 BasicCegarLoop]: 652 mSDtfsCounter, 326 mSDsluCounter, 338 mSDsCounter, 0 mSdLazyCounter, 3 mSolverCounterSat, 0 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.0s Time, 0 mProtectedPredicate, 0 mProtectedAction, 326 SdHoareTripleChecker+Valid, 990 SdHoareTripleChecker+Invalid, 3 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 0 IncrementalHoareTripleChecker+Valid, 3 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.0s IncrementalHoareTripleChecker+Time [2022-02-20 21:35:41,501 INFO L934 BasicCegarLoop]: SdHoareTripleChecker [326 Valid, 990 Invalid, 3 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [0 Valid, 3 Invalid, 0 Unknown, 0 Unchecked, 0.0s Time] [2022-02-20 21:35:41,502 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 1280 states. [2022-02-20 21:35:41,776 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 1280 to 1025. [2022-02-20 21:35:41,776 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-02-20 21:35:41,779 INFO L82 GeneralOperation]: Start isEquivalent. First operand 1280 states. Second operand has 1025 states, 789 states have (on average 1.2801013941698351) internal successors, (1010), 798 states have internal predecessors, (1010), 171 states have call successors, (171), 65 states have call predecessors, (171), 64 states have return successors, (173), 169 states have call predecessors, (173), 169 states have call successors, (173) [2022-02-20 21:35:41,781 INFO L74 IsIncluded]: Start isIncluded. First operand 1280 states. Second operand has 1025 states, 789 states have (on average 1.2801013941698351) internal successors, (1010), 798 states have internal predecessors, (1010), 171 states have call successors, (171), 65 states have call predecessors, (171), 64 states have return successors, (173), 169 states have call predecessors, (173), 169 states have call successors, (173) [2022-02-20 21:35:41,783 INFO L87 Difference]: Start difference. First operand 1280 states. Second operand has 1025 states, 789 states have (on average 1.2801013941698351) internal successors, (1010), 798 states have internal predecessors, (1010), 171 states have call successors, (171), 65 states have call predecessors, (171), 64 states have return successors, (173), 169 states have call predecessors, (173), 169 states have call successors, (173) [2022-02-20 21:35:41,856 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 21:35:41,856 INFO L93 Difference]: Finished difference Result 1280 states and 1691 transitions. [2022-02-20 21:35:41,856 INFO L276 IsEmpty]: Start isEmpty. Operand 1280 states and 1691 transitions. [2022-02-20 21:35:41,860 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 21:35:41,860 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 21:35:41,863 INFO L74 IsIncluded]: Start isIncluded. First operand has 1025 states, 789 states have (on average 1.2801013941698351) internal successors, (1010), 798 states have internal predecessors, (1010), 171 states have call successors, (171), 65 states have call predecessors, (171), 64 states have return successors, (173), 169 states have call predecessors, (173), 169 states have call successors, (173) Second operand 1280 states. [2022-02-20 21:35:41,865 INFO L87 Difference]: Start difference. First operand has 1025 states, 789 states have (on average 1.2801013941698351) internal successors, (1010), 798 states have internal predecessors, (1010), 171 states have call successors, (171), 65 states have call predecessors, (171), 64 states have return successors, (173), 169 states have call predecessors, (173), 169 states have call successors, (173) Second operand 1280 states. [2022-02-20 21:35:41,943 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 21:35:41,944 INFO L93 Difference]: Finished difference Result 1280 states and 1691 transitions. [2022-02-20 21:35:41,944 INFO L276 IsEmpty]: Start isEmpty. Operand 1280 states and 1691 transitions. [2022-02-20 21:35:41,954 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 21:35:41,954 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 21:35:41,954 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-02-20 21:35:41,955 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-02-20 21:35:41,964 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 1025 states, 789 states have (on average 1.2801013941698351) internal successors, (1010), 798 states have internal predecessors, (1010), 171 states have call successors, (171), 65 states have call predecessors, (171), 64 states have return successors, (173), 169 states have call predecessors, (173), 169 states have call successors, (173) [2022-02-20 21:35:42,050 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 1025 states to 1025 states and 1354 transitions. [2022-02-20 21:35:42,051 INFO L78 Accepts]: Start accepts. Automaton has 1025 states and 1354 transitions. Word has length 140 [2022-02-20 21:35:42,051 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-02-20 21:35:42,051 INFO L470 AbstractCegarLoop]: Abstraction has 1025 states and 1354 transitions. [2022-02-20 21:35:42,052 INFO L471 AbstractCegarLoop]: INTERPOLANT automaton has has 3 states, 3 states have (on average 27.666666666666668) internal successors, (83), 3 states have internal predecessors, (83), 3 states have call successors, (17), 3 states have call predecessors, (17), 2 states have return successors, (15), 2 states have call predecessors, (15), 1 states have call successors, (15) [2022-02-20 21:35:42,052 INFO L276 IsEmpty]: Start isEmpty. Operand 1025 states and 1354 transitions. [2022-02-20 21:35:42,054 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 185 [2022-02-20 21:35:42,054 INFO L506 BasicCegarLoop]: Found error trace [2022-02-20 21:35:42,055 INFO L514 BasicCegarLoop]: trace histogram [4, 4, 4, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 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, 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:35:42,084 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:35:42,278 WARN L452 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable4,2 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-02-20 21:35:42,279 INFO L402 AbstractCegarLoop]: === Iteration 6 === Targeting ldv_errorErr0ASSERT_VIOLATIONERROR_FUNCTION === [ldv_errorErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-02-20 21:35:42,279 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-02-20 21:35:42,279 INFO L85 PathProgramCache]: Analyzing trace with hash 1821132084, now seen corresponding path program 1 times [2022-02-20 21:35:42,279 INFO L126 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-02-20 21:35:42,279 INFO L338 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [1685417656] [2022-02-20 21:35:42,280 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 21:35:42,280 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-02-20 21:35:42,409 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:42,469 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 3 [2022-02-20 21:35:42,471 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:42,474 INFO L290 TraceCheckUtils]: 0: Hoare triple {17749#true} assume true; {17749#true} is VALID [2022-02-20 21:35:42,474 INFO L284 TraceCheckUtils]: 1: Hoare quadruple {17749#true} {17749#true} #612#return; {17749#true} is VALID [2022-02-20 21:35:42,474 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 14 [2022-02-20 21:35:42,475 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:42,477 INFO L290 TraceCheckUtils]: 0: Hoare triple {17749#true} assume true; {17749#true} is VALID [2022-02-20 21:35:42,477 INFO L284 TraceCheckUtils]: 1: Hoare quadruple {17749#true} {17749#true} #614#return; {17749#true} is VALID [2022-02-20 21:35:42,482 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 18 [2022-02-20 21:35:42,484 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:42,490 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:35:42,493 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:42,496 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:35:42,497 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:42,500 INFO L290 TraceCheckUtils]: 0: Hoare triple {17840#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {17749#true} is VALID [2022-02-20 21:35:42,501 INFO L290 TraceCheckUtils]: 1: Hoare triple {17749#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {17749#true} is VALID [2022-02-20 21:35:42,501 INFO L290 TraceCheckUtils]: 2: Hoare triple {17749#true} assume true; {17749#true} is VALID [2022-02-20 21:35:42,501 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {17749#true} {17749#true} #590#return; {17749#true} is VALID [2022-02-20 21:35:42,501 INFO L290 TraceCheckUtils]: 0: Hoare triple {17840#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {17749#true} is VALID [2022-02-20 21:35:42,502 INFO L272 TraceCheckUtils]: 1: Hoare triple {17749#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {17840#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:42,502 INFO L290 TraceCheckUtils]: 2: Hoare triple {17840#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {17749#true} is VALID [2022-02-20 21:35:42,502 INFO L290 TraceCheckUtils]: 3: Hoare triple {17749#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {17749#true} is VALID [2022-02-20 21:35:42,503 INFO L290 TraceCheckUtils]: 4: Hoare triple {17749#true} assume true; {17749#true} is VALID [2022-02-20 21:35:42,503 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {17749#true} {17749#true} #590#return; {17749#true} is VALID [2022-02-20 21:35:42,504 INFO L290 TraceCheckUtils]: 6: Hoare triple {17749#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {17749#true} is VALID [2022-02-20 21:35:42,504 INFO L290 TraceCheckUtils]: 7: Hoare triple {17749#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {17749#true} is VALID [2022-02-20 21:35:42,504 INFO L290 TraceCheckUtils]: 8: Hoare triple {17749#true} assume true; {17749#true} is VALID [2022-02-20 21:35:42,504 INFO L284 TraceCheckUtils]: 9: Hoare quadruple {17749#true} {17749#true} #588#return; {17749#true} is VALID [2022-02-20 21:35:42,504 INFO L290 TraceCheckUtils]: 0: Hoare triple {17840#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size;~flags := #in~flags;havoc ~tmp~2.base, ~tmp~2.offset; {17749#true} is VALID [2022-02-20 21:35:42,505 INFO L272 TraceCheckUtils]: 1: Hoare triple {17749#true} call #t~ret40.base, #t~ret40.offset := kmalloc(~size, ~bitwiseOr(~flags, 32768)); {17840#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:42,505 INFO L290 TraceCheckUtils]: 2: Hoare triple {17840#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {17749#true} is VALID [2022-02-20 21:35:42,506 INFO L272 TraceCheckUtils]: 3: Hoare triple {17749#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {17840#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:42,506 INFO L290 TraceCheckUtils]: 4: Hoare triple {17840#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {17749#true} is VALID [2022-02-20 21:35:42,506 INFO L290 TraceCheckUtils]: 5: Hoare triple {17749#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {17749#true} is VALID [2022-02-20 21:35:42,507 INFO L290 TraceCheckUtils]: 6: Hoare triple {17749#true} assume true; {17749#true} is VALID [2022-02-20 21:35:42,507 INFO L284 TraceCheckUtils]: 7: Hoare quadruple {17749#true} {17749#true} #590#return; {17749#true} is VALID [2022-02-20 21:35:42,507 INFO L290 TraceCheckUtils]: 8: Hoare triple {17749#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {17749#true} is VALID [2022-02-20 21:35:42,507 INFO L290 TraceCheckUtils]: 9: Hoare triple {17749#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {17749#true} is VALID [2022-02-20 21:35:42,507 INFO L290 TraceCheckUtils]: 10: Hoare triple {17749#true} assume true; {17749#true} is VALID [2022-02-20 21:35:42,507 INFO L284 TraceCheckUtils]: 11: Hoare quadruple {17749#true} {17749#true} #588#return; {17749#true} is VALID [2022-02-20 21:35:42,508 INFO L290 TraceCheckUtils]: 12: Hoare triple {17749#true} ~tmp~2.base, ~tmp~2.offset := #t~ret40.base, #t~ret40.offset;havoc #t~ret40.base, #t~ret40.offset;#res.base, #res.offset := ~tmp~2.base, ~tmp~2.offset; {17749#true} is VALID [2022-02-20 21:35:42,508 INFO L290 TraceCheckUtils]: 13: Hoare triple {17749#true} assume true; {17749#true} is VALID [2022-02-20 21:35:42,508 INFO L284 TraceCheckUtils]: 14: Hoare quadruple {17749#true} {17749#true} #616#return; {17749#true} is VALID [2022-02-20 21:35:42,515 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 41 [2022-02-20 21:35:42,517 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:42,520 INFO L290 TraceCheckUtils]: 0: Hoare triple {17855#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;havoc ~err~0#1;assume { :begin_inline_ipmi_validate_addr } true;ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset, ipmi_validate_addr_#in~arg1#1 := ~data#1.base, 193 + ~data#1.offset, 40;havoc ipmi_validate_addr_#res#1;havoc ipmi_validate_addr_#t~nondet254#1, ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset, ipmi_validate_addr_~arg1#1;ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset := ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset;ipmi_validate_addr_~arg1#1 := ipmi_validate_addr_#in~arg1#1;assume -2147483648 <= ipmi_validate_addr_#t~nondet254#1 && ipmi_validate_addr_#t~nondet254#1 <= 2147483647;ipmi_validate_addr_#res#1 := ipmi_validate_addr_#t~nondet254#1;havoc ipmi_validate_addr_#t~nondet254#1; {17749#true} is VALID [2022-02-20 21:35:42,521 INFO L290 TraceCheckUtils]: 1: Hoare triple {17749#true} #t~ret62#1 := ipmi_validate_addr_#res#1;assume { :end_inline_ipmi_validate_addr } true;assume -2147483648 <= #t~ret62#1 && #t~ret62#1 <= 2147483647;~err~0#1 := #t~ret62#1;havoc #t~ret62#1; {17749#true} is VALID [2022-02-20 21:35:42,521 INFO L290 TraceCheckUtils]: 2: Hoare triple {17749#true} assume 0 != ~err~0#1; {17749#true} is VALID [2022-02-20 21:35:42,521 INFO L290 TraceCheckUtils]: 3: Hoare triple {17749#true} havoc #t~nondet69#1;call #t~mem70#1.base, #t~mem70#1.offset := read~$Pointer$(~data#1.base, 24 + ~data#1.offset, 8);havoc #t~mem70#1.base, #t~mem70#1.offset;#res#1 := ~err~0#1; {17749#true} is VALID [2022-02-20 21:35:42,521 INFO L290 TraceCheckUtils]: 4: Hoare triple {17749#true} assume true; {17749#true} is VALID [2022-02-20 21:35:42,521 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {17749#true} {17749#true} #618#return; {17749#true} is VALID [2022-02-20 21:35:42,522 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 49 [2022-02-20 21:35:42,522 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:42,526 INFO L290 TraceCheckUtils]: 0: Hoare triple {17749#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset; {17749#true} is VALID [2022-02-20 21:35:42,526 INFO L290 TraceCheckUtils]: 1: Hoare triple {17749#true} assume true; {17749#true} is VALID [2022-02-20 21:35:42,526 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {17749#true} {17749#true} #620#return; {17749#true} is VALID [2022-02-20 21:35:42,526 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 56 [2022-02-20 21:35:42,529 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:42,534 INFO L290 TraceCheckUtils]: 0: Hoare triple {17749#true} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;~offset#1 := #in~offset#1;havoc ~tmp~3#1;assume { :begin_inline___be16_to_cpup } true;__be16_to_cpup_#in~p#1.base, __be16_to_cpup_#in~p#1.offset := ~data#1.base, ~data#1.offset + 2 * (if ~offset#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then ~offset#1 % 18446744073709551616 % 18446744073709551616 else ~offset#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616);havoc __be16_to_cpup_#res#1;havoc __be16_to_cpup_#t~ret3#1, __be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset, __be16_to_cpup_~tmp~1#1;__be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset := __be16_to_cpup_#in~p#1.base, __be16_to_cpup_#in~p#1.offset;havoc __be16_to_cpup_~tmp~1#1;assume { :begin_inline___swab16p } true;__swab16p_#in~p#1.base, __swab16p_#in~p#1.offset := __be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset;havoc __swab16p_#res#1;havoc __swab16p_#t~mem1#1, __swab16p_#t~ret2#1, __swab16p_~p#1.base, __swab16p_~p#1.offset, __swab16p_~tmp~0#1;__swab16p_~p#1.base, __swab16p_~p#1.offset := __swab16p_#in~p#1.base, __swab16p_#in~p#1.offset;havoc __swab16p_~tmp~0#1;call __swab16p_#t~mem1#1 := read~int(__swab16p_~p#1.base, __swab16p_~p#1.offset, 2);assume { :begin_inline___fswab16 } true;__fswab16_#in~val#1 := __swab16p_#t~mem1#1 % 65536;havoc __fswab16_#res#1;havoc __fswab16_~val#1;__fswab16_~val#1 := __fswab16_#in~val#1;__fswab16_#res#1 := (if (1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) || 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536)) && 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) then (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) else (if 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) && (1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) || 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536)) then (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) else (if (1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) && (1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) || 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536))) || ((1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) || 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536)) && 1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536)) then 1 else ~bitwiseOr((if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536), (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536))))); {17749#true} is VALID [2022-02-20 21:35:42,534 INFO L290 TraceCheckUtils]: 1: Hoare triple {17749#true} __swab16p_#t~ret2#1 := __fswab16_#res#1;assume { :end_inline___fswab16 } true;__swab16p_~tmp~0#1 := __swab16p_#t~ret2#1;havoc __swab16p_#t~mem1#1;havoc __swab16p_#t~ret2#1;__swab16p_#res#1 := __swab16p_~tmp~0#1; {17749#true} is VALID [2022-02-20 21:35:42,534 INFO L290 TraceCheckUtils]: 2: Hoare triple {17749#true} __be16_to_cpup_#t~ret3#1 := __swab16p_#res#1;assume { :end_inline___swab16p } true;__be16_to_cpup_~tmp~1#1 := __be16_to_cpup_#t~ret3#1;havoc __be16_to_cpup_#t~ret3#1;__be16_to_cpup_#res#1 := __be16_to_cpup_~tmp~1#1; {17749#true} is VALID [2022-02-20 21:35:42,534 INFO L290 TraceCheckUtils]: 3: Hoare triple {17749#true} #t~ret61#1 := __be16_to_cpup_#res#1;assume { :end_inline___be16_to_cpup } true;~tmp~3#1 := #t~ret61#1;havoc #t~ret61#1;#res#1 := ~tmp~3#1; {17749#true} is VALID [2022-02-20 21:35:42,535 INFO L290 TraceCheckUtils]: 4: Hoare triple {17749#true} assume true; {17749#true} is VALID [2022-02-20 21:35:42,535 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {17749#true} {17749#true} #622#return; {17749#true} is VALID [2022-02-20 21:35:42,535 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 66 [2022-02-20 21:35:42,537 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:42,539 INFO L290 TraceCheckUtils]: 0: Hoare triple {17840#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {17749#true} is VALID [2022-02-20 21:35:42,539 INFO L290 TraceCheckUtils]: 1: Hoare triple {17749#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {17749#true} is VALID [2022-02-20 21:35:42,539 INFO L290 TraceCheckUtils]: 2: Hoare triple {17749#true} assume true; {17749#true} is VALID [2022-02-20 21:35:42,540 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {17749#true} {17749#true} #624#return; {17749#true} is VALID [2022-02-20 21:35:42,540 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 73 [2022-02-20 21:35:42,541 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:42,543 INFO L290 TraceCheckUtils]: 0: Hoare triple {17749#true} ~ptr.base, ~ptr.offset := #in~ptr.base, #in~ptr.offset;#res := (if (~ptr.base + ~ptr.offset) % 18446744073709551616 > 2012 then 1 else 0); {17749#true} is VALID [2022-02-20 21:35:42,544 INFO L290 TraceCheckUtils]: 1: Hoare triple {17749#true} assume true; {17749#true} is VALID [2022-02-20 21:35:42,544 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {17749#true} {17749#true} #626#return; {17749#true} is VALID [2022-02-20 21:35:42,544 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 80 [2022-02-20 21:35:42,545 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:42,550 INFO L290 TraceCheckUtils]: 0: Hoare triple {17749#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset;~arg1.base, ~arg1.offset := #in~arg1.base, #in~arg1.offset; {17749#true} is VALID [2022-02-20 21:35:42,550 INFO L290 TraceCheckUtils]: 1: Hoare triple {17749#true} assume true; {17749#true} is VALID [2022-02-20 21:35:42,550 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {17749#true} {17749#true} #628#return; {17749#true} is VALID [2022-02-20 21:35:42,550 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 87 [2022-02-20 21:35:42,553 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:42,556 INFO L290 TraceCheckUtils]: 0: Hoare triple {17855#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;havoc ~err~0#1;assume { :begin_inline_ipmi_validate_addr } true;ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset, ipmi_validate_addr_#in~arg1#1 := ~data#1.base, 193 + ~data#1.offset, 40;havoc ipmi_validate_addr_#res#1;havoc ipmi_validate_addr_#t~nondet254#1, ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset, ipmi_validate_addr_~arg1#1;ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset := ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset;ipmi_validate_addr_~arg1#1 := ipmi_validate_addr_#in~arg1#1;assume -2147483648 <= ipmi_validate_addr_#t~nondet254#1 && ipmi_validate_addr_#t~nondet254#1 <= 2147483647;ipmi_validate_addr_#res#1 := ipmi_validate_addr_#t~nondet254#1;havoc ipmi_validate_addr_#t~nondet254#1; {17749#true} is VALID [2022-02-20 21:35:42,557 INFO L290 TraceCheckUtils]: 1: Hoare triple {17749#true} #t~ret62#1 := ipmi_validate_addr_#res#1;assume { :end_inline_ipmi_validate_addr } true;assume -2147483648 <= #t~ret62#1 && #t~ret62#1 <= 2147483647;~err~0#1 := #t~ret62#1;havoc #t~ret62#1; {17749#true} is VALID [2022-02-20 21:35:42,557 INFO L290 TraceCheckUtils]: 2: Hoare triple {17749#true} assume 0 != ~err~0#1; {17749#true} is VALID [2022-02-20 21:35:42,557 INFO L290 TraceCheckUtils]: 3: Hoare triple {17749#true} havoc #t~nondet69#1;call #t~mem70#1.base, #t~mem70#1.offset := read~$Pointer$(~data#1.base, 24 + ~data#1.offset, 8);havoc #t~mem70#1.base, #t~mem70#1.offset;#res#1 := ~err~0#1; {17749#true} is VALID [2022-02-20 21:35:42,557 INFO L290 TraceCheckUtils]: 4: Hoare triple {17749#true} assume true; {17749#true} is VALID [2022-02-20 21:35:42,557 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {17749#true} {17749#true} #630#return; {17749#true} is VALID [2022-02-20 21:35:42,558 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 95 [2022-02-20 21:35:42,558 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:42,561 INFO L290 TraceCheckUtils]: 0: Hoare triple {17749#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset; {17749#true} is VALID [2022-02-20 21:35:42,561 INFO L290 TraceCheckUtils]: 1: Hoare triple {17749#true} assume true; {17749#true} is VALID [2022-02-20 21:35:42,561 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {17749#true} {17749#true} #632#return; {17749#true} is VALID [2022-02-20 21:35:42,561 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 104 [2022-02-20 21:35:42,563 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:42,568 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:35:42,570 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:42,573 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:35:42,575 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:42,578 INFO L290 TraceCheckUtils]: 0: Hoare triple {17840#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {17749#true} is VALID [2022-02-20 21:35:42,578 INFO L290 TraceCheckUtils]: 1: Hoare triple {17749#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {17749#true} is VALID [2022-02-20 21:35:42,578 INFO L290 TraceCheckUtils]: 2: Hoare triple {17749#true} assume true; {17749#true} is VALID [2022-02-20 21:35:42,578 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {17749#true} {17749#true} #590#return; {17749#true} is VALID [2022-02-20 21:35:42,578 INFO L290 TraceCheckUtils]: 0: Hoare triple {17840#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {17749#true} is VALID [2022-02-20 21:35:42,579 INFO L272 TraceCheckUtils]: 1: Hoare triple {17749#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {17840#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:42,579 INFO L290 TraceCheckUtils]: 2: Hoare triple {17840#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {17749#true} is VALID [2022-02-20 21:35:42,579 INFO L290 TraceCheckUtils]: 3: Hoare triple {17749#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {17749#true} is VALID [2022-02-20 21:35:42,580 INFO L290 TraceCheckUtils]: 4: Hoare triple {17749#true} assume true; {17749#true} is VALID [2022-02-20 21:35:42,580 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {17749#true} {17749#true} #590#return; {17749#true} is VALID [2022-02-20 21:35:42,580 INFO L290 TraceCheckUtils]: 6: Hoare triple {17749#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {17749#true} is VALID [2022-02-20 21:35:42,580 INFO L290 TraceCheckUtils]: 7: Hoare triple {17749#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {17749#true} is VALID [2022-02-20 21:35:42,580 INFO L290 TraceCheckUtils]: 8: Hoare triple {17749#true} assume true; {17749#true} is VALID [2022-02-20 21:35:42,581 INFO L284 TraceCheckUtils]: 9: Hoare quadruple {17749#true} {17749#true} #588#return; {17749#true} is VALID [2022-02-20 21:35:42,581 INFO L290 TraceCheckUtils]: 0: Hoare triple {17840#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size;~flags := #in~flags;havoc ~tmp~2.base, ~tmp~2.offset; {17749#true} is VALID [2022-02-20 21:35:42,581 INFO L272 TraceCheckUtils]: 1: Hoare triple {17749#true} call #t~ret40.base, #t~ret40.offset := kmalloc(~size, ~bitwiseOr(~flags, 32768)); {17840#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:42,582 INFO L290 TraceCheckUtils]: 2: Hoare triple {17840#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {17749#true} is VALID [2022-02-20 21:35:42,582 INFO L272 TraceCheckUtils]: 3: Hoare triple {17749#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {17840#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:42,582 INFO L290 TraceCheckUtils]: 4: Hoare triple {17840#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {17749#true} is VALID [2022-02-20 21:35:42,583 INFO L290 TraceCheckUtils]: 5: Hoare triple {17749#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {17749#true} is VALID [2022-02-20 21:35:42,583 INFO L290 TraceCheckUtils]: 6: Hoare triple {17749#true} assume true; {17749#true} is VALID [2022-02-20 21:35:42,583 INFO L284 TraceCheckUtils]: 7: Hoare quadruple {17749#true} {17749#true} #590#return; {17749#true} is VALID [2022-02-20 21:35:42,583 INFO L290 TraceCheckUtils]: 8: Hoare triple {17749#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {17749#true} is VALID [2022-02-20 21:35:42,583 INFO L290 TraceCheckUtils]: 9: Hoare triple {17749#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {17749#true} is VALID [2022-02-20 21:35:42,584 INFO L290 TraceCheckUtils]: 10: Hoare triple {17749#true} assume true; {17749#true} is VALID [2022-02-20 21:35:42,584 INFO L284 TraceCheckUtils]: 11: Hoare quadruple {17749#true} {17749#true} #588#return; {17749#true} is VALID [2022-02-20 21:35:42,584 INFO L290 TraceCheckUtils]: 12: Hoare triple {17749#true} ~tmp~2.base, ~tmp~2.offset := #t~ret40.base, #t~ret40.offset;havoc #t~ret40.base, #t~ret40.offset;#res.base, #res.offset := ~tmp~2.base, ~tmp~2.offset; {17749#true} is VALID [2022-02-20 21:35:42,584 INFO L290 TraceCheckUtils]: 13: Hoare triple {17749#true} assume true; {17749#true} is VALID [2022-02-20 21:35:42,584 INFO L284 TraceCheckUtils]: 14: Hoare quadruple {17749#true} {17749#true} #634#return; {17749#true} is VALID [2022-02-20 21:35:42,585 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 125 [2022-02-20 21:35:42,587 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:42,590 INFO L290 TraceCheckUtils]: 0: Hoare triple {17855#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;havoc ~err~0#1;assume { :begin_inline_ipmi_validate_addr } true;ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset, ipmi_validate_addr_#in~arg1#1 := ~data#1.base, 193 + ~data#1.offset, 40;havoc ipmi_validate_addr_#res#1;havoc ipmi_validate_addr_#t~nondet254#1, ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset, ipmi_validate_addr_~arg1#1;ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset := ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset;ipmi_validate_addr_~arg1#1 := ipmi_validate_addr_#in~arg1#1;assume -2147483648 <= ipmi_validate_addr_#t~nondet254#1 && ipmi_validate_addr_#t~nondet254#1 <= 2147483647;ipmi_validate_addr_#res#1 := ipmi_validate_addr_#t~nondet254#1;havoc ipmi_validate_addr_#t~nondet254#1; {17749#true} is VALID [2022-02-20 21:35:42,591 INFO L290 TraceCheckUtils]: 1: Hoare triple {17749#true} #t~ret62#1 := ipmi_validate_addr_#res#1;assume { :end_inline_ipmi_validate_addr } true;assume -2147483648 <= #t~ret62#1 && #t~ret62#1 <= 2147483647;~err~0#1 := #t~ret62#1;havoc #t~ret62#1; {17749#true} is VALID [2022-02-20 21:35:42,591 INFO L290 TraceCheckUtils]: 2: Hoare triple {17749#true} assume 0 != ~err~0#1; {17749#true} is VALID [2022-02-20 21:35:42,591 INFO L290 TraceCheckUtils]: 3: Hoare triple {17749#true} havoc #t~nondet69#1;call #t~mem70#1.base, #t~mem70#1.offset := read~$Pointer$(~data#1.base, 24 + ~data#1.offset, 8);havoc #t~mem70#1.base, #t~mem70#1.offset;#res#1 := ~err~0#1; {17749#true} is VALID [2022-02-20 21:35:42,591 INFO L290 TraceCheckUtils]: 4: Hoare triple {17749#true} assume true; {17749#true} is VALID [2022-02-20 21:35:42,592 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {17749#true} {17749#true} #636#return; {17749#true} is VALID [2022-02-20 21:35:42,592 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 133 [2022-02-20 21:35:42,593 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:42,596 INFO L290 TraceCheckUtils]: 0: Hoare triple {17749#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset; {17749#true} is VALID [2022-02-20 21:35:42,597 INFO L290 TraceCheckUtils]: 1: Hoare triple {17749#true} assume true; {17749#true} is VALID [2022-02-20 21:35:42,597 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {17749#true} {17749#true} #638#return; {17749#true} is VALID [2022-02-20 21:35:42,597 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 150 [2022-02-20 21:35:42,601 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:42,604 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:35:42,605 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:42,609 INFO L290 TraceCheckUtils]: 0: Hoare triple {17840#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {17749#true} is VALID [2022-02-20 21:35:42,609 INFO L290 TraceCheckUtils]: 1: Hoare triple {17749#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {17749#true} is VALID [2022-02-20 21:35:42,609 INFO L290 TraceCheckUtils]: 2: Hoare triple {17749#true} assume true; {17749#true} is VALID [2022-02-20 21:35:42,610 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {17749#true} {17749#true} #590#return; {17749#true} is VALID [2022-02-20 21:35:42,610 INFO L290 TraceCheckUtils]: 0: Hoare triple {17840#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {17749#true} is VALID [2022-02-20 21:35:42,610 INFO L272 TraceCheckUtils]: 1: Hoare triple {17749#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {17840#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:42,611 INFO L290 TraceCheckUtils]: 2: Hoare triple {17840#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {17749#true} is VALID [2022-02-20 21:35:42,611 INFO L290 TraceCheckUtils]: 3: Hoare triple {17749#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {17749#true} is VALID [2022-02-20 21:35:42,611 INFO L290 TraceCheckUtils]: 4: Hoare triple {17749#true} assume true; {17749#true} is VALID [2022-02-20 21:35:42,611 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {17749#true} {17749#true} #590#return; {17749#true} is VALID [2022-02-20 21:35:42,611 INFO L290 TraceCheckUtils]: 6: Hoare triple {17749#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {17749#true} is VALID [2022-02-20 21:35:42,612 INFO L290 TraceCheckUtils]: 7: Hoare triple {17749#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {17749#true} is VALID [2022-02-20 21:35:42,612 INFO L290 TraceCheckUtils]: 8: Hoare triple {17749#true} assume true; {17749#true} is VALID [2022-02-20 21:35:42,612 INFO L284 TraceCheckUtils]: 9: Hoare quadruple {17749#true} {17750#false} #640#return; {17750#false} is VALID [2022-02-20 21:35:42,612 INFO L290 TraceCheckUtils]: 0: Hoare triple {17749#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(46, 2);call #Ultimate.allocInit(13, 3);call #Ultimate.allocInit(20, 4);call #Ultimate.allocInit(21, 5);call #Ultimate.allocInit(11, 6);call #Ultimate.allocInit(18, 7);call #Ultimate.allocInit(19, 8);call #Ultimate.allocInit(20, 9);call #Ultimate.allocInit(18, 10);call #Ultimate.allocInit(69, 11);call #Ultimate.allocInit(26, 12);call #Ultimate.allocInit(4, 13);call write~init~int(37, 13, 0, 1);call write~init~int(115, 13, 1, 1);call write~init~int(10, 13, 2, 1);call write~init~int(0, 13, 3, 1);call #Ultimate.allocInit(7, 14);call write~init~int(105, 14, 0, 1);call write~init~int(98, 14, 1, 1);call write~init~int(109, 14, 2, 1);call write~init~int(112, 14, 3, 1);call write~init~int(101, 14, 4, 1);call write~init~int(120, 14, 5, 1);call write~init~int(0, 14, 6, 1);call #Ultimate.allocInit(5, 15);call write~init~int(110, 15, 0, 1);call write~init~int(97, 15, 1, 1);call write~init~int(109, 15, 2, 1);call write~init~int(101, 15, 3, 1);call write~init~int(0, 15, 4, 1);call #Ultimate.allocInit(4, 16);call write~init~int(37, 16, 0, 1);call write~init~int(100, 16, 1, 1);call write~init~int(10, 16, 2, 1);call write~init~int(0, 16, 3, 1);call #Ultimate.allocInit(15, 17);call #Ultimate.allocInit(5, 18);call write~init~int(116, 18, 0, 1);call write~init~int(101, 18, 1, 1);call write~init~int(109, 18, 2, 1);call write~init~int(112, 18, 3, 1);call write~init~int(0, 18, 4, 1);call #Ultimate.allocInit(6, 19);call write~init~int(112, 19, 0, 1);call write~init~int(111, 19, 1, 1);call write~init~int(119, 19, 2, 1);call write~init~int(101, 19, 3, 1);call write~init~int(114, 19, 4, 1);call write~init~int(0, 19, 5, 1);call #Ultimate.allocInit(40, 20);call #Ultimate.allocInit(48, 21);call #Ultimate.allocInit(12, 22);call #Ultimate.allocInit(55, 23);call #Ultimate.allocInit(26, 24);call #Ultimate.allocInit(70, 25);~#power_sensor_sig~0.base, ~#power_sensor_sig~0.offset := 26, 0;call #Ultimate.allocInit(3, 26);call write~init~int(112, ~#power_sensor_sig~0.base, ~#power_sensor_sig~0.offset, 1);call write~init~int(119, ~#power_sensor_sig~0.base, 1 + ~#power_sensor_sig~0.offset, 1);call write~init~int(114, ~#power_sensor_sig~0.base, 2 + ~#power_sensor_sig~0.offset, 1);~#temp_sensor_sig~0.base, ~#temp_sensor_sig~0.offset := 27, 0;call #Ultimate.allocInit(3, 27);call write~init~int(116, ~#temp_sensor_sig~0.base, ~#temp_sensor_sig~0.offset, 1);call write~init~int(101, ~#temp_sensor_sig~0.base, 1 + ~#temp_sensor_sig~0.offset, 1);call write~init~int(109, ~#temp_sensor_sig~0.base, 2 + ~#temp_sensor_sig~0.offset, 1);~#watt_sensor_sig~0.base, ~#watt_sensor_sig~0.offset := 28, 0;call #Ultimate.allocInit(2, 28);call write~init~int(65, ~#watt_sensor_sig~0.base, ~#watt_sensor_sig~0.offset, 1);call write~init~int(67, ~#watt_sensor_sig~0.base, 1 + ~#watt_sensor_sig~0.offset, 1);~#power_sensor_name_templates~0.base, ~#power_sensor_name_templates~0.offset := 29, 0;call #Ultimate.allocInit(24, 29);call write~init~$Pointer$(3, 0, ~#power_sensor_name_templates~0.base, ~#power_sensor_name_templates~0.offset, 8);call write~init~$Pointer$(4, 0, ~#power_sensor_name_templates~0.base, 8 + ~#power_sensor_name_templates~0.offset, 8);call write~init~$Pointer$(5, 0, ~#power_sensor_name_templates~0.base, 16 + ~#power_sensor_name_templates~0.offset, 8);~#temp_sensor_name_templates~0.base, ~#temp_sensor_name_templates~0.offset := 30, 0;call #Ultimate.allocInit(24, 30);call write~init~$Pointer$(6, 0, ~#temp_sensor_name_templates~0.base, ~#temp_sensor_name_templates~0.offset, 8);call write~init~$Pointer$(7, 0, ~#temp_sensor_name_templates~0.base, 8 + ~#temp_sensor_name_templates~0.offset, 8);call write~init~$Pointer$(8, 0, ~#temp_sensor_name_templates~0.base, 16 + ~#temp_sensor_name_templates~0.offset, 8);~#driver_data~0.base, ~#driver_data~0.offset := 31, 0;call #Ultimate.allocInit(72, 31);call write~init~$Pointer$(~#driver_data~0.base, ~#driver_data~0.offset, ~#driver_data~0.base, ~#driver_data~0.offset, 8);call write~init~$Pointer$(~#driver_data~0.base, ~#driver_data~0.offset, ~#driver_data~0.base, 8 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(0, 0, ~#driver_data~0.base, 16 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(0, 0, ~#driver_data~0.base, 24 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(~#__this_module~0.base, ~#__this_module~0.offset, ~#driver_data~0.base, 32 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(#funAddr~ibmpex_register_bmc.base, #funAddr~ibmpex_register_bmc.offset, ~#driver_data~0.base, 40 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(#funAddr~ibmpex_bmc_gone.base, #funAddr~ibmpex_bmc_gone.offset, ~#driver_data~0.base, 48 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(#funAddr~ibmpex_msg_handler.base, #funAddr~ibmpex_msg_handler.offset, ~#driver_data~0.base, 56 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(0, 0, ~#driver_data~0.base, 64 + ~#driver_data~0.offset, 8);~#sensor_dev_attr_name~0.base, ~#sensor_dev_attr_name~0.offset := 32, 0;call #Ultimate.allocInit(48, 32);call write~init~$Pointer$(15, 0, ~#sensor_dev_attr_name~0.base, ~#sensor_dev_attr_name~0.offset, 8);call write~init~int(292, ~#sensor_dev_attr_name~0.base, 8 + ~#sensor_dev_attr_name~0.offset, 4);call write~init~$Pointer$(0, 0, ~#sensor_dev_attr_name~0.base, 12 + ~#sensor_dev_attr_name~0.offset, 8);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 20 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 21 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 22 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 23 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 24 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 25 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 26 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 27 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~$Pointer$(#funAddr~show_name.base, #funAddr~show_name.offset, ~#sensor_dev_attr_name~0.base, 28 + ~#sensor_dev_attr_name~0.offset, 8);call write~init~$Pointer$(0, 0, ~#sensor_dev_attr_name~0.base, 36 + ~#sensor_dev_attr_name~0.offset, 8);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 44 + ~#sensor_dev_attr_name~0.offset, 4);~#sensor_dev_attr_reset_high_low~0.base, ~#sensor_dev_attr_reset_high_low~0.offset := 33, 0;call #Ultimate.allocInit(48, 33);call write~init~$Pointer$(17, 0, ~#sensor_dev_attr_reset_high_low~0.base, ~#sensor_dev_attr_reset_high_low~0.offset, 8);call write~init~int(128, ~#sensor_dev_attr_reset_high_low~0.base, 8 + ~#sensor_dev_attr_reset_high_low~0.offset, 4);call write~init~$Pointer$(0, 0, ~#sensor_dev_attr_reset_high_low~0.base, 12 + ~#sensor_dev_attr_reset_high_low~0.offset, 8);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 20 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 21 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 22 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 23 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 24 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 25 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 26 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 27 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~$Pointer$(0, 0, ~#sensor_dev_attr_reset_high_low~0.base, 28 + ~#sensor_dev_attr_reset_high_low~0.offset, 8);call write~init~$Pointer$(#funAddr~ibmpex_reset_high_low.base, #funAddr~ibmpex_reset_high_low.offset, ~#sensor_dev_attr_reset_high_low~0.base, 36 + ~#sensor_dev_attr_reset_high_low~0.offset, 8);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 44 + ~#sensor_dev_attr_reset_high_low~0.offset, 4);~LDV_IN_INTERRUPT~0 := 0;~ldv_count_1~0 := 0;~ldv_count_2~0 := 0;~ldv_call_dev_attr_of_sensor_device_attribute~0 := 0;~ldv_call_dev_attr_of_sensor_device_attribute_2~0 := 0; {17749#true} is VALID [2022-02-20 21:35:42,613 INFO L290 TraceCheckUtils]: 1: Hoare triple {17749#true} assume { :end_inline_ULTIMATE.init } true;assume { :begin_inline_main } true;havoc main_#res#1;havoc main_#t~ret236#1, main_#t~nondet237#1, main_#t~switch238#1, main_#t~nondet239#1, main_~var_ibmpex_register_bmc_17_p0~0#1, main_~var_group1~0#1.base, main_~var_group1~0#1.offset, main_~var_ibmpex_bmc_gone_19_p0~0#1, main_~#var_group2~0#1.base, main_~#var_group2~0#1.offset, main_~#var_ibmpex_msg_handler_20_p1~0#1.base, main_~#var_ibmpex_msg_handler_20_p1~0#1.offset, main_~tmp~17#1, main_~tmp___0~4#1, main_~tmp___1~2#1;havoc main_~var_ibmpex_register_bmc_17_p0~0#1;havoc main_~var_group1~0#1.base, main_~var_group1~0#1.offset;havoc main_~var_ibmpex_bmc_gone_19_p0~0#1;call main_~#var_group2~0#1.base, main_~#var_group2~0#1.offset := #Ultimate.allocOnStack(374);call main_~#var_ibmpex_msg_handler_20_p1~0#1.base, main_~#var_ibmpex_msg_handler_20_p1~0#1.offset := #Ultimate.allocOnStack(915);havoc main_~tmp~17#1;havoc main_~tmp___0~4#1;havoc main_~tmp___1~2#1;~LDV_IN_INTERRUPT~0 := 1;assume { :begin_inline_ldv_initialize } true;~ldv_count_1~0 := 1 + ~ldv_count_1~0;~ldv_count_1~0 := 1 + ~ldv_count_1~0;~ldv_count_1~0 := 1 + ~ldv_count_1~0;~ldv_count_1~0 := 1 + ~ldv_count_1~0;~ldv_count_1~0 := 1 + ~ldv_count_1~0;~ldv_count_1~0 := 1 + ~ldv_count_1~0; {17749#true} is VALID [2022-02-20 21:35:42,613 INFO L290 TraceCheckUtils]: 2: Hoare triple {17749#true} assume { :end_inline_ldv_initialize } true; {17749#true} is VALID [2022-02-20 21:35:42,613 INFO L272 TraceCheckUtils]: 3: Hoare triple {17749#true} call ldv_handler_precall(); {17749#true} is VALID [2022-02-20 21:35:42,613 INFO L290 TraceCheckUtils]: 4: Hoare triple {17749#true} assume true; {17749#true} is VALID [2022-02-20 21:35:42,613 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {17749#true} {17749#true} #612#return; {17749#true} is VALID [2022-02-20 21:35:42,613 INFO L290 TraceCheckUtils]: 6: Hoare triple {17749#true} assume { :begin_inline_ibmpex_init } true;havoc ibmpex_init_#res#1;havoc ibmpex_init_#t~ret231#1, ibmpex_init_~tmp~16#1;havoc ibmpex_init_~tmp~16#1;assume { :begin_inline_ipmi_smi_watcher_register } true;ipmi_smi_watcher_register_#in~arg0#1.base, ipmi_smi_watcher_register_#in~arg0#1.offset := ~#driver_data~0.base, 16 + ~#driver_data~0.offset;havoc ipmi_smi_watcher_register_#res#1;havoc ipmi_smi_watcher_register_#t~nondet252#1, ipmi_smi_watcher_register_~arg0#1.base, ipmi_smi_watcher_register_~arg0#1.offset;ipmi_smi_watcher_register_~arg0#1.base, ipmi_smi_watcher_register_~arg0#1.offset := ipmi_smi_watcher_register_#in~arg0#1.base, ipmi_smi_watcher_register_#in~arg0#1.offset;assume -2147483648 <= ipmi_smi_watcher_register_#t~nondet252#1 && ipmi_smi_watcher_register_#t~nondet252#1 <= 2147483647;ipmi_smi_watcher_register_#res#1 := ipmi_smi_watcher_register_#t~nondet252#1;havoc ipmi_smi_watcher_register_#t~nondet252#1; {17749#true} is VALID [2022-02-20 21:35:42,614 INFO L290 TraceCheckUtils]: 7: Hoare triple {17749#true} ibmpex_init_#t~ret231#1 := ipmi_smi_watcher_register_#res#1;assume { :end_inline_ipmi_smi_watcher_register } true;assume -2147483648 <= ibmpex_init_#t~ret231#1 && ibmpex_init_#t~ret231#1 <= 2147483647;ibmpex_init_~tmp~16#1 := ibmpex_init_#t~ret231#1;havoc ibmpex_init_#t~ret231#1;ibmpex_init_#res#1 := ibmpex_init_~tmp~16#1; {17749#true} is VALID [2022-02-20 21:35:42,614 INFO L290 TraceCheckUtils]: 8: Hoare triple {17749#true} main_#t~ret236#1 := ibmpex_init_#res#1;assume { :end_inline_ibmpex_init } true;assume -2147483648 <= main_#t~ret236#1 && main_#t~ret236#1 <= 2147483647;main_~tmp~17#1 := main_#t~ret236#1;havoc main_#t~ret236#1; {17749#true} is VALID [2022-02-20 21:35:42,614 INFO L290 TraceCheckUtils]: 9: Hoare triple {17749#true} assume !(0 != main_~tmp~17#1); {17749#true} is VALID [2022-02-20 21:35:42,614 INFO L290 TraceCheckUtils]: 10: Hoare triple {17749#true} assume -2147483648 <= main_#t~nondet239#1 && main_#t~nondet239#1 <= 2147483647;main_~tmp___1~2#1 := main_#t~nondet239#1;havoc main_#t~nondet239#1; {17749#true} is VALID [2022-02-20 21:35:42,614 INFO L290 TraceCheckUtils]: 11: Hoare triple {17749#true} assume 0 != main_~tmp___1~2#1; {17749#true} is VALID [2022-02-20 21:35:42,615 INFO L290 TraceCheckUtils]: 12: Hoare triple {17749#true} assume -2147483648 <= main_#t~nondet237#1 && main_#t~nondet237#1 <= 2147483647;main_~tmp___0~4#1 := main_#t~nondet237#1;havoc main_#t~nondet237#1;main_#t~switch238#1 := 0 == main_~tmp___0~4#1; {17749#true} is VALID [2022-02-20 21:35:42,615 INFO L290 TraceCheckUtils]: 13: Hoare triple {17749#true} assume main_#t~switch238#1; {17749#true} is VALID [2022-02-20 21:35:42,615 INFO L272 TraceCheckUtils]: 14: Hoare triple {17749#true} call ldv_handler_precall(); {17749#true} is VALID [2022-02-20 21:35:42,615 INFO L290 TraceCheckUtils]: 15: Hoare triple {17749#true} assume true; {17749#true} is VALID [2022-02-20 21:35:42,615 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {17749#true} {17749#true} #614#return; {17749#true} is VALID [2022-02-20 21:35:42,615 INFO L290 TraceCheckUtils]: 17: Hoare triple {17749#true} assume { :begin_inline_ibmpex_register_bmc } true;ibmpex_register_bmc_#in~iface#1, ibmpex_register_bmc_#in~dev#1.base, ibmpex_register_bmc_#in~dev#1.offset := main_~var_ibmpex_register_bmc_17_p0~0#1, main_~var_group1~0#1.base, main_~var_group1~0#1.offset;havoc ibmpex_register_bmc_#t~ret178#1.base, ibmpex_register_bmc_#t~ret178#1.offset, ibmpex_register_bmc_#t~nondet179#1, ibmpex_register_bmc_#t~mem180#1, ibmpex_register_bmc_#t~ret181#1, ibmpex_register_bmc_#t~nondet182#1, ibmpex_register_bmc_#t~mem183#1, ibmpex_register_bmc_#t~ret184#1, ibmpex_register_bmc_#t~mem185#1.base, ibmpex_register_bmc_#t~mem185#1.offset, ibmpex_register_bmc_#t~ret186#1.base, ibmpex_register_bmc_#t~ret186#1.offset, ibmpex_register_bmc_#t~mem187#1.base, ibmpex_register_bmc_#t~mem187#1.offset, ibmpex_register_bmc_#t~ret188#1, ibmpex_register_bmc_#t~nondet189#1, ibmpex_register_bmc_#t~mem190#1.base, ibmpex_register_bmc_#t~mem190#1.offset, ibmpex_register_bmc_#t~mem191#1, ibmpex_register_bmc_#t~ret192#1, ibmpex_register_bmc_#t~nondet193#1, ibmpex_register_bmc_#t~mem194#1.base, ibmpex_register_bmc_#t~mem194#1.offset, ibmpex_register_bmc_#t~mem195#1.base, ibmpex_register_bmc_#t~mem195#1.offset, ibmpex_register_bmc_#t~mem196#1.base, ibmpex_register_bmc_#t~mem196#1.offset, ibmpex_register_bmc_#t~ret197#1, ibmpex_register_bmc_~iface#1, ibmpex_register_bmc_~dev#1.base, ibmpex_register_bmc_~dev#1.offset, ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset, ibmpex_register_bmc_~err~4#1, ibmpex_register_bmc_~tmp~14#1.base, ibmpex_register_bmc_~tmp~14#1.offset, ibmpex_register_bmc_~#__key~1#1.base, ibmpex_register_bmc_~#__key~1#1.offset, ibmpex_register_bmc_~tmp___0~3#1;ibmpex_register_bmc_~iface#1 := ibmpex_register_bmc_#in~iface#1;ibmpex_register_bmc_~dev#1.base, ibmpex_register_bmc_~dev#1.offset := ibmpex_register_bmc_#in~dev#1.base, ibmpex_register_bmc_#in~dev#1.offset;havoc ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset;havoc ibmpex_register_bmc_~err~4#1;havoc ibmpex_register_bmc_~tmp~14#1.base, ibmpex_register_bmc_~tmp~14#1.offset;call ibmpex_register_bmc_~#__key~1#1.base, ibmpex_register_bmc_~#__key~1#1.offset := #Ultimate.allocOnStack(8);havoc ibmpex_register_bmc_~tmp___0~3#1; {17749#true} is VALID [2022-02-20 21:35:42,616 INFO L272 TraceCheckUtils]: 18: Hoare triple {17749#true} call ibmpex_register_bmc_#t~ret178#1.base, ibmpex_register_bmc_#t~ret178#1.offset := kzalloc(968, 208); {17840#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:42,616 INFO L290 TraceCheckUtils]: 19: Hoare triple {17840#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size;~flags := #in~flags;havoc ~tmp~2.base, ~tmp~2.offset; {17749#true} is VALID [2022-02-20 21:35:42,617 INFO L272 TraceCheckUtils]: 20: Hoare triple {17749#true} call #t~ret40.base, #t~ret40.offset := kmalloc(~size, ~bitwiseOr(~flags, 32768)); {17840#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:42,617 INFO L290 TraceCheckUtils]: 21: Hoare triple {17840#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {17749#true} is VALID [2022-02-20 21:35:42,618 INFO L272 TraceCheckUtils]: 22: Hoare triple {17749#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {17840#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:42,618 INFO L290 TraceCheckUtils]: 23: Hoare triple {17840#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {17749#true} is VALID [2022-02-20 21:35:42,618 INFO L290 TraceCheckUtils]: 24: Hoare triple {17749#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {17749#true} is VALID [2022-02-20 21:35:42,618 INFO L290 TraceCheckUtils]: 25: Hoare triple {17749#true} assume true; {17749#true} is VALID [2022-02-20 21:35:42,618 INFO L284 TraceCheckUtils]: 26: Hoare quadruple {17749#true} {17749#true} #590#return; {17749#true} is VALID [2022-02-20 21:35:42,619 INFO L290 TraceCheckUtils]: 27: Hoare triple {17749#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {17749#true} is VALID [2022-02-20 21:35:42,619 INFO L290 TraceCheckUtils]: 28: Hoare triple {17749#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {17749#true} is VALID [2022-02-20 21:35:42,619 INFO L290 TraceCheckUtils]: 29: Hoare triple {17749#true} assume true; {17749#true} is VALID [2022-02-20 21:35:42,619 INFO L284 TraceCheckUtils]: 30: Hoare quadruple {17749#true} {17749#true} #588#return; {17749#true} is VALID [2022-02-20 21:35:42,619 INFO L290 TraceCheckUtils]: 31: Hoare triple {17749#true} ~tmp~2.base, ~tmp~2.offset := #t~ret40.base, #t~ret40.offset;havoc #t~ret40.base, #t~ret40.offset;#res.base, #res.offset := ~tmp~2.base, ~tmp~2.offset; {17749#true} is VALID [2022-02-20 21:35:42,620 INFO L290 TraceCheckUtils]: 32: Hoare triple {17749#true} assume true; {17749#true} is VALID [2022-02-20 21:35:42,620 INFO L284 TraceCheckUtils]: 33: Hoare quadruple {17749#true} {17749#true} #616#return; {17749#true} is VALID [2022-02-20 21:35:42,620 INFO L290 TraceCheckUtils]: 34: Hoare triple {17749#true} ibmpex_register_bmc_~tmp~14#1.base, ibmpex_register_bmc_~tmp~14#1.offset := ibmpex_register_bmc_#t~ret178#1.base, ibmpex_register_bmc_#t~ret178#1.offset;havoc ibmpex_register_bmc_#t~ret178#1.base, ibmpex_register_bmc_#t~ret178#1.offset;ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset := ibmpex_register_bmc_~tmp~14#1.base, ibmpex_register_bmc_~tmp~14#1.offset; {17749#true} is VALID [2022-02-20 21:35:42,620 INFO L290 TraceCheckUtils]: 35: Hoare triple {17749#true} assume !(0 == (ibmpex_register_bmc_~data~2#1.base + ibmpex_register_bmc_~data~2#1.offset) % 18446744073709551616);call write~int(12, ibmpex_register_bmc_~data~2#1.base, 193 + ibmpex_register_bmc_~data~2#1.offset, 4);call write~int(15, ibmpex_register_bmc_~data~2#1.base, 197 + ibmpex_register_bmc_~data~2#1.offset, 2);call write~int(0, ibmpex_register_bmc_~data~2#1.base, 199 + ibmpex_register_bmc_~data~2#1.offset, 1);call write~int(ibmpex_register_bmc_~iface#1, ibmpex_register_bmc_~data~2#1.base, 323 + ibmpex_register_bmc_~data~2#1.offset, 4);call write~$Pointer$(ibmpex_register_bmc_~dev#1.base, ibmpex_register_bmc_~dev#1.offset, ibmpex_register_bmc_~data~2#1.base, 24 + ibmpex_register_bmc_~data~2#1.offset, 8);call ibmpex_register_bmc_#t~mem180#1 := read~int(ibmpex_register_bmc_~data~2#1.base, 323 + ibmpex_register_bmc_~data~2#1.offset, 4);assume { :begin_inline_ipmi_create_user } true;ipmi_create_user_#in~arg0#1, ipmi_create_user_#in~arg1#1.base, ipmi_create_user_#in~arg1#1.offset, ipmi_create_user_#in~arg2#1.base, ipmi_create_user_#in~arg2#1.offset, ipmi_create_user_#in~arg3#1.base, ipmi_create_user_#in~arg3#1.offset := ibmpex_register_bmc_#t~mem180#1, ~#driver_data~0.base, 56 + ~#driver_data~0.offset, ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset, ibmpex_register_bmc_~data~2#1.base, 315 + ibmpex_register_bmc_~data~2#1.offset;havoc ipmi_create_user_#res#1;havoc ipmi_create_user_#t~nondet249#1, ipmi_create_user_~arg0#1, ipmi_create_user_~arg1#1.base, ipmi_create_user_~arg1#1.offset, ipmi_create_user_~arg2#1.base, ipmi_create_user_~arg2#1.offset, ipmi_create_user_~arg3#1.base, ipmi_create_user_~arg3#1.offset;ipmi_create_user_~arg0#1 := ipmi_create_user_#in~arg0#1;ipmi_create_user_~arg1#1.base, ipmi_create_user_~arg1#1.offset := ipmi_create_user_#in~arg1#1.base, ipmi_create_user_#in~arg1#1.offset;ipmi_create_user_~arg2#1.base, ipmi_create_user_~arg2#1.offset := ipmi_create_user_#in~arg2#1.base, ipmi_create_user_#in~arg2#1.offset;ipmi_create_user_~arg3#1.base, ipmi_create_user_~arg3#1.offset := ipmi_create_user_#in~arg3#1.base, ipmi_create_user_#in~arg3#1.offset;assume -2147483648 <= ipmi_create_user_#t~nondet249#1 && ipmi_create_user_#t~nondet249#1 <= 2147483647;ipmi_create_user_#res#1 := ipmi_create_user_#t~nondet249#1;havoc ipmi_create_user_#t~nondet249#1; {17749#true} is VALID [2022-02-20 21:35:42,620 INFO L290 TraceCheckUtils]: 36: Hoare triple {17749#true} ibmpex_register_bmc_#t~ret181#1 := ipmi_create_user_#res#1;assume { :end_inline_ipmi_create_user } true;assume -2147483648 <= ibmpex_register_bmc_#t~ret181#1 && ibmpex_register_bmc_#t~ret181#1 <= 2147483647;ibmpex_register_bmc_~err~4#1 := ibmpex_register_bmc_#t~ret181#1;havoc ibmpex_register_bmc_#t~mem180#1;havoc ibmpex_register_bmc_#t~ret181#1; {17749#true} is VALID [2022-02-20 21:35:42,620 INFO L290 TraceCheckUtils]: 37: Hoare triple {17749#true} assume !(ibmpex_register_bmc_~err~4#1 < 0);assume { :begin_inline___mutex_init } true;__mutex_init_#in~arg0#1.base, __mutex_init_#in~arg0#1.offset, __mutex_init_#in~arg1#1.base, __mutex_init_#in~arg1#1.offset, __mutex_init_#in~arg2#1.base, __mutex_init_#in~arg2#1.offset := ibmpex_register_bmc_~data~2#1.base, 32 + ibmpex_register_bmc_~data~2#1.offset, 22, 0, ibmpex_register_bmc_~#__key~1#1.base, ibmpex_register_bmc_~#__key~1#1.offset;havoc __mutex_init_~arg0#1.base, __mutex_init_~arg0#1.offset, __mutex_init_~arg1#1.base, __mutex_init_~arg1#1.offset, __mutex_init_~arg2#1.base, __mutex_init_~arg2#1.offset;__mutex_init_~arg0#1.base, __mutex_init_~arg0#1.offset := __mutex_init_#in~arg0#1.base, __mutex_init_#in~arg0#1.offset;__mutex_init_~arg1#1.base, __mutex_init_~arg1#1.offset := __mutex_init_#in~arg1#1.base, __mutex_init_#in~arg1#1.offset;__mutex_init_~arg2#1.base, __mutex_init_~arg2#1.offset := __mutex_init_#in~arg2#1.base, __mutex_init_#in~arg2#1.offset; {17749#true} is VALID [2022-02-20 21:35:42,621 INFO L290 TraceCheckUtils]: 38: Hoare triple {17749#true} assume { :end_inline___mutex_init } true;call write~int(0, ibmpex_register_bmc_~data~2#1.base, 611 + ibmpex_register_bmc_~data~2#1.offset, 8);assume { :begin_inline_init_completion } true;init_completion_#in~x#1.base, init_completion_#in~x#1.offset := ibmpex_register_bmc_~data~2#1.base, 231 + ibmpex_register_bmc_~data~2#1.offset;havoc init_completion_~x#1.base, init_completion_~x#1.offset, init_completion_~#__key~0#1.base, init_completion_~#__key~0#1.offset;init_completion_~x#1.base, init_completion_~x#1.offset := init_completion_#in~x#1.base, init_completion_#in~x#1.offset;call init_completion_~#__key~0#1.base, init_completion_~#__key~0#1.offset := #Ultimate.allocOnStack(8);call write~int(0, init_completion_~x#1.base, init_completion_~x#1.offset, 4);assume { :begin_inline___init_waitqueue_head } true;__init_waitqueue_head_#in~arg0#1.base, __init_waitqueue_head_#in~arg0#1.offset, __init_waitqueue_head_#in~arg1#1.base, __init_waitqueue_head_#in~arg1#1.offset := init_completion_~x#1.base, 4 + init_completion_~x#1.offset, init_completion_~#__key~0#1.base, init_completion_~#__key~0#1.offset;havoc __init_waitqueue_head_~arg0#1.base, __init_waitqueue_head_~arg0#1.offset, __init_waitqueue_head_~arg1#1.base, __init_waitqueue_head_~arg1#1.offset;__init_waitqueue_head_~arg0#1.base, __init_waitqueue_head_~arg0#1.offset := __init_waitqueue_head_#in~arg0#1.base, __init_waitqueue_head_#in~arg0#1.offset;__init_waitqueue_head_~arg1#1.base, __init_waitqueue_head_~arg1#1.offset := __init_waitqueue_head_#in~arg1#1.base, __init_waitqueue_head_#in~arg1#1.offset; {17749#true} is VALID [2022-02-20 21:35:42,621 INFO L290 TraceCheckUtils]: 39: Hoare triple {17749#true} assume { :end_inline___init_waitqueue_head } true;call ULTIMATE.dealloc(init_completion_~#__key~0#1.base, init_completion_~#__key~0#1.offset);havoc init_completion_~#__key~0#1.base, init_completion_~#__key~0#1.offset; {17749#true} is VALID [2022-02-20 21:35:42,621 INFO L290 TraceCheckUtils]: 40: Hoare triple {17749#true} assume { :end_inline_init_completion } true;call write~int(58, ibmpex_register_bmc_~data~2#1.base, 327 + ibmpex_register_bmc_~data~2#1.offset, 1);call write~int(60, ibmpex_register_bmc_~data~2#1.base, 328 + ibmpex_register_bmc_~data~2#1.offset, 1);call write~$Pointer$(ibmpex_register_bmc_~data~2#1.base, 339 + ibmpex_register_bmc_~data~2#1.offset, ibmpex_register_bmc_~data~2#1.base, 331 + ibmpex_register_bmc_~data~2#1.offset, 8);assume { :begin_inline_ibmpex_ver_check } true;ibmpex_ver_check_#in~data#1.base, ibmpex_ver_check_#in~data#1.offset := ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset;havoc ibmpex_ver_check_#res#1;havoc ibmpex_ver_check_#t~ret71#1, ibmpex_ver_check_#t~mem72#1, ibmpex_ver_check_#t~mem73#1, ibmpex_ver_check_#t~short74#1, ibmpex_ver_check_#t~mem75#1, ibmpex_ver_check_#t~mem76#1, ibmpex_ver_check_#t~ret77#1, ibmpex_ver_check_#t~nondet78#1, ibmpex_ver_check_#t~mem79#1.base, ibmpex_ver_check_#t~mem79#1.offset, ibmpex_ver_check_#t~mem80#1, ibmpex_ver_check_#t~mem81#1, ibmpex_ver_check_#t~mem82#1, ibmpex_ver_check_#t~mem83#1, ibmpex_ver_check_#t~mem84#1, ibmpex_ver_check_~data#1.base, ibmpex_ver_check_~data#1.offset, ibmpex_ver_check_~tmp~4#1;ibmpex_ver_check_~data#1.base, ibmpex_ver_check_~data#1.offset := ibmpex_ver_check_#in~data#1.base, ibmpex_ver_check_#in~data#1.offset;havoc ibmpex_ver_check_~tmp~4#1;call write~int(1, ibmpex_ver_check_~data#1.base, 339 + ibmpex_ver_check_~data#1.offset, 1);call write~int(1, ibmpex_ver_check_~data#1.base, 329 + ibmpex_ver_check_~data#1.offset, 2); {17749#true} is VALID [2022-02-20 21:35:42,622 INFO L272 TraceCheckUtils]: 41: Hoare triple {17749#true} call ibmpex_ver_check_#t~ret71#1 := ibmpex_send_message(ibmpex_ver_check_~data#1.base, ibmpex_ver_check_~data#1.offset); {17855#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} is VALID [2022-02-20 21:35:42,622 INFO L290 TraceCheckUtils]: 42: Hoare triple {17855#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;havoc ~err~0#1;assume { :begin_inline_ipmi_validate_addr } true;ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset, ipmi_validate_addr_#in~arg1#1 := ~data#1.base, 193 + ~data#1.offset, 40;havoc ipmi_validate_addr_#res#1;havoc ipmi_validate_addr_#t~nondet254#1, ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset, ipmi_validate_addr_~arg1#1;ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset := ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset;ipmi_validate_addr_~arg1#1 := ipmi_validate_addr_#in~arg1#1;assume -2147483648 <= ipmi_validate_addr_#t~nondet254#1 && ipmi_validate_addr_#t~nondet254#1 <= 2147483647;ipmi_validate_addr_#res#1 := ipmi_validate_addr_#t~nondet254#1;havoc ipmi_validate_addr_#t~nondet254#1; {17749#true} is VALID [2022-02-20 21:35:42,622 INFO L290 TraceCheckUtils]: 43: Hoare triple {17749#true} #t~ret62#1 := ipmi_validate_addr_#res#1;assume { :end_inline_ipmi_validate_addr } true;assume -2147483648 <= #t~ret62#1 && #t~ret62#1 <= 2147483647;~err~0#1 := #t~ret62#1;havoc #t~ret62#1; {17749#true} is VALID [2022-02-20 21:35:42,622 INFO L290 TraceCheckUtils]: 44: Hoare triple {17749#true} assume 0 != ~err~0#1; {17749#true} is VALID [2022-02-20 21:35:42,622 INFO L290 TraceCheckUtils]: 45: Hoare triple {17749#true} havoc #t~nondet69#1;call #t~mem70#1.base, #t~mem70#1.offset := read~$Pointer$(~data#1.base, 24 + ~data#1.offset, 8);havoc #t~mem70#1.base, #t~mem70#1.offset;#res#1 := ~err~0#1; {17749#true} is VALID [2022-02-20 21:35:42,623 INFO L290 TraceCheckUtils]: 46: Hoare triple {17749#true} assume true; {17749#true} is VALID [2022-02-20 21:35:42,623 INFO L284 TraceCheckUtils]: 47: Hoare quadruple {17749#true} {17749#true} #618#return; {17749#true} is VALID [2022-02-20 21:35:42,623 INFO L290 TraceCheckUtils]: 48: Hoare triple {17749#true} assume -2147483648 <= ibmpex_ver_check_#t~ret71#1 && ibmpex_ver_check_#t~ret71#1 <= 2147483647;havoc ibmpex_ver_check_#t~ret71#1; {17749#true} is VALID [2022-02-20 21:35:42,623 INFO L272 TraceCheckUtils]: 49: Hoare triple {17749#true} call wait_for_completion(ibmpex_ver_check_~data#1.base, 231 + ibmpex_ver_check_~data#1.offset); {17749#true} is VALID [2022-02-20 21:35:42,623 INFO L290 TraceCheckUtils]: 50: Hoare triple {17749#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset; {17749#true} is VALID [2022-02-20 21:35:42,624 INFO L290 TraceCheckUtils]: 51: Hoare triple {17749#true} assume true; {17749#true} is VALID [2022-02-20 21:35:42,624 INFO L284 TraceCheckUtils]: 52: Hoare quadruple {17749#true} {17749#true} #620#return; {17749#true} is VALID [2022-02-20 21:35:42,624 INFO L290 TraceCheckUtils]: 53: Hoare triple {17749#true} call ibmpex_ver_check_#t~mem72#1 := read~int(ibmpex_ver_check_~data#1.base, 899 + ibmpex_ver_check_~data#1.offset, 1);ibmpex_ver_check_#t~short74#1 := 0 != ibmpex_ver_check_#t~mem72#1 % 256 % 4294967296; {17749#true} is VALID [2022-02-20 21:35:42,624 INFO L290 TraceCheckUtils]: 54: Hoare triple {17749#true} assume !ibmpex_ver_check_#t~short74#1;call ibmpex_ver_check_#t~mem73#1 := read~int(ibmpex_ver_check_~data#1.base, 891 + ibmpex_ver_check_~data#1.offset, 8);ibmpex_ver_check_#t~short74#1 := 6 != ibmpex_ver_check_#t~mem73#1 % 18446744073709551616; {17749#true} is VALID [2022-02-20 21:35:42,624 INFO L290 TraceCheckUtils]: 55: Hoare triple {17749#true} assume !ibmpex_ver_check_#t~short74#1;havoc ibmpex_ver_check_#t~mem72#1;havoc ibmpex_ver_check_#t~mem73#1;havoc ibmpex_ver_check_#t~short74#1;call ibmpex_ver_check_#t~mem75#1 := read~int(ibmpex_ver_check_~data#1.base, 619 + ibmpex_ver_check_~data#1.offset, 1);call write~int(ibmpex_ver_check_#t~mem75#1, ibmpex_ver_check_~data#1.base, 904 + ibmpex_ver_check_~data#1.offset, 1);havoc ibmpex_ver_check_#t~mem75#1;call ibmpex_ver_check_#t~mem76#1 := read~int(ibmpex_ver_check_~data#1.base, 620 + ibmpex_ver_check_~data#1.offset, 1);call write~int(ibmpex_ver_check_#t~mem76#1, ibmpex_ver_check_~data#1.base, 905 + ibmpex_ver_check_~data#1.offset, 1);havoc ibmpex_ver_check_#t~mem76#1; {17749#true} is VALID [2022-02-20 21:35:42,624 INFO L272 TraceCheckUtils]: 56: Hoare triple {17749#true} call ibmpex_ver_check_#t~ret77#1 := extract_value(ibmpex_ver_check_~data#1.base, 619 + ibmpex_ver_check_~data#1.offset, 2); {17749#true} is VALID [2022-02-20 21:35:42,625 INFO L290 TraceCheckUtils]: 57: Hoare triple {17749#true} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;~offset#1 := #in~offset#1;havoc ~tmp~3#1;assume { :begin_inline___be16_to_cpup } true;__be16_to_cpup_#in~p#1.base, __be16_to_cpup_#in~p#1.offset := ~data#1.base, ~data#1.offset + 2 * (if ~offset#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then ~offset#1 % 18446744073709551616 % 18446744073709551616 else ~offset#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616);havoc __be16_to_cpup_#res#1;havoc __be16_to_cpup_#t~ret3#1, __be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset, __be16_to_cpup_~tmp~1#1;__be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset := __be16_to_cpup_#in~p#1.base, __be16_to_cpup_#in~p#1.offset;havoc __be16_to_cpup_~tmp~1#1;assume { :begin_inline___swab16p } true;__swab16p_#in~p#1.base, __swab16p_#in~p#1.offset := __be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset;havoc __swab16p_#res#1;havoc __swab16p_#t~mem1#1, __swab16p_#t~ret2#1, __swab16p_~p#1.base, __swab16p_~p#1.offset, __swab16p_~tmp~0#1;__swab16p_~p#1.base, __swab16p_~p#1.offset := __swab16p_#in~p#1.base, __swab16p_#in~p#1.offset;havoc __swab16p_~tmp~0#1;call __swab16p_#t~mem1#1 := read~int(__swab16p_~p#1.base, __swab16p_~p#1.offset, 2);assume { :begin_inline___fswab16 } true;__fswab16_#in~val#1 := __swab16p_#t~mem1#1 % 65536;havoc __fswab16_#res#1;havoc __fswab16_~val#1;__fswab16_~val#1 := __fswab16_#in~val#1;__fswab16_#res#1 := (if (1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) || 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536)) && 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) then (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) else (if 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) && (1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) || 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536)) then (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) else (if (1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) && (1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) || 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536))) || ((1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) || 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536)) && 1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536)) then 1 else ~bitwiseOr((if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536), (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536))))); {17749#true} is VALID [2022-02-20 21:35:42,625 INFO L290 TraceCheckUtils]: 58: Hoare triple {17749#true} __swab16p_#t~ret2#1 := __fswab16_#res#1;assume { :end_inline___fswab16 } true;__swab16p_~tmp~0#1 := __swab16p_#t~ret2#1;havoc __swab16p_#t~mem1#1;havoc __swab16p_#t~ret2#1;__swab16p_#res#1 := __swab16p_~tmp~0#1; {17749#true} is VALID [2022-02-20 21:35:42,625 INFO L290 TraceCheckUtils]: 59: Hoare triple {17749#true} __be16_to_cpup_#t~ret3#1 := __swab16p_#res#1;assume { :end_inline___swab16p } true;__be16_to_cpup_~tmp~1#1 := __be16_to_cpup_#t~ret3#1;havoc __be16_to_cpup_#t~ret3#1;__be16_to_cpup_#res#1 := __be16_to_cpup_~tmp~1#1; {17749#true} is VALID [2022-02-20 21:35:42,625 INFO L290 TraceCheckUtils]: 60: Hoare triple {17749#true} #t~ret61#1 := __be16_to_cpup_#res#1;assume { :end_inline___be16_to_cpup } true;~tmp~3#1 := #t~ret61#1;havoc #t~ret61#1;#res#1 := ~tmp~3#1; {17749#true} is VALID [2022-02-20 21:35:42,625 INFO L290 TraceCheckUtils]: 61: Hoare triple {17749#true} assume true; {17749#true} is VALID [2022-02-20 21:35:42,626 INFO L284 TraceCheckUtils]: 62: Hoare quadruple {17749#true} {17749#true} #622#return; {17749#true} is VALID [2022-02-20 21:35:42,626 INFO L290 TraceCheckUtils]: 63: Hoare triple {17749#true} ibmpex_ver_check_~tmp~4#1 := ibmpex_ver_check_#t~ret77#1;havoc ibmpex_ver_check_#t~ret77#1;havoc ibmpex_ver_check_#t~nondet78#1;call ibmpex_ver_check_#t~mem79#1.base, ibmpex_ver_check_#t~mem79#1.offset := read~$Pointer$(ibmpex_ver_check_~data#1.base, 24 + ibmpex_ver_check_~data#1.offset, 8);call ibmpex_ver_check_#t~mem80#1 := read~int(ibmpex_ver_check_~data#1.base, 904 + ibmpex_ver_check_~data#1.offset, 1);call ibmpex_ver_check_#t~mem81#1 := read~int(ibmpex_ver_check_~data#1.base, 905 + ibmpex_ver_check_~data#1.offset, 1);call ibmpex_ver_check_#t~mem82#1 := read~int(ibmpex_ver_check_~data#1.base, 623 + ibmpex_ver_check_~data#1.offset, 1);call ibmpex_ver_check_#t~mem83#1 := read~int(ibmpex_ver_check_~data#1.base, 624 + ibmpex_ver_check_~data#1.offset, 1);call ibmpex_ver_check_#t~mem84#1 := read~int(ibmpex_ver_check_~data#1.base, 323 + ibmpex_ver_check_~data#1.offset, 4);havoc ibmpex_ver_check_#t~mem79#1.base, ibmpex_ver_check_#t~mem79#1.offset;havoc ibmpex_ver_check_#t~mem80#1;havoc ibmpex_ver_check_#t~mem81#1;havoc ibmpex_ver_check_#t~mem82#1;havoc ibmpex_ver_check_#t~mem83#1;havoc ibmpex_ver_check_#t~mem84#1;ibmpex_ver_check_#res#1 := 0; {17749#true} is VALID [2022-02-20 21:35:42,626 INFO L290 TraceCheckUtils]: 64: Hoare triple {17749#true} ibmpex_register_bmc_#t~ret184#1 := ibmpex_ver_check_#res#1;assume { :end_inline_ibmpex_ver_check } true;assume -2147483648 <= ibmpex_register_bmc_#t~ret184#1 && ibmpex_register_bmc_#t~ret184#1 <= 2147483647;ibmpex_register_bmc_~err~4#1 := ibmpex_register_bmc_#t~ret184#1;havoc ibmpex_register_bmc_#t~ret184#1; {17749#true} is VALID [2022-02-20 21:35:42,626 INFO L290 TraceCheckUtils]: 65: Hoare triple {17749#true} assume !(0 != ibmpex_register_bmc_~err~4#1);call ibmpex_register_bmc_#t~mem185#1.base, ibmpex_register_bmc_#t~mem185#1.offset := read~$Pointer$(ibmpex_register_bmc_~data~2#1.base, 24 + ibmpex_register_bmc_~data~2#1.offset, 8);assume { :begin_inline_hwmon_device_register } true;hwmon_device_register_#in~arg0#1.base, hwmon_device_register_#in~arg0#1.offset := ibmpex_register_bmc_#t~mem185#1.base, ibmpex_register_bmc_#t~mem185#1.offset;havoc hwmon_device_register_#res#1.base, hwmon_device_register_#res#1.offset;havoc hwmon_device_register_#t~ret248#1.base, hwmon_device_register_#t~ret248#1.offset, hwmon_device_register_~arg0#1.base, hwmon_device_register_~arg0#1.offset;hwmon_device_register_~arg0#1.base, hwmon_device_register_~arg0#1.offset := hwmon_device_register_#in~arg0#1.base, hwmon_device_register_#in~arg0#1.offset; {17749#true} is VALID [2022-02-20 21:35:42,627 INFO L272 TraceCheckUtils]: 66: Hoare triple {17749#true} call hwmon_device_register_#t~ret248#1.base, hwmon_device_register_#t~ret248#1.offset := ldv_malloc(1035); {17840#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:42,627 INFO L290 TraceCheckUtils]: 67: Hoare triple {17840#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {17749#true} is VALID [2022-02-20 21:35:42,627 INFO L290 TraceCheckUtils]: 68: Hoare triple {17749#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {17749#true} is VALID [2022-02-20 21:35:42,627 INFO L290 TraceCheckUtils]: 69: Hoare triple {17749#true} assume true; {17749#true} is VALID [2022-02-20 21:35:42,627 INFO L284 TraceCheckUtils]: 70: Hoare quadruple {17749#true} {17749#true} #624#return; {17749#true} is VALID [2022-02-20 21:35:42,628 INFO L290 TraceCheckUtils]: 71: Hoare triple {17749#true} hwmon_device_register_#res#1.base, hwmon_device_register_#res#1.offset := hwmon_device_register_#t~ret248#1.base, hwmon_device_register_#t~ret248#1.offset;havoc hwmon_device_register_#t~ret248#1.base, hwmon_device_register_#t~ret248#1.offset; {17749#true} is VALID [2022-02-20 21:35:42,628 INFO L290 TraceCheckUtils]: 72: Hoare triple {17749#true} ibmpex_register_bmc_#t~ret186#1.base, ibmpex_register_bmc_#t~ret186#1.offset := hwmon_device_register_#res#1.base, hwmon_device_register_#res#1.offset;assume { :end_inline_hwmon_device_register } true;call write~$Pointer$(ibmpex_register_bmc_#t~ret186#1.base, ibmpex_register_bmc_#t~ret186#1.offset, ibmpex_register_bmc_~data~2#1.base, 16 + ibmpex_register_bmc_~data~2#1.offset, 8);havoc ibmpex_register_bmc_#t~mem185#1.base, ibmpex_register_bmc_#t~mem185#1.offset;havoc ibmpex_register_bmc_#t~ret186#1.base, ibmpex_register_bmc_#t~ret186#1.offset;call ibmpex_register_bmc_#t~mem187#1.base, ibmpex_register_bmc_#t~mem187#1.offset := read~$Pointer$(ibmpex_register_bmc_~data~2#1.base, 16 + ibmpex_register_bmc_~data~2#1.offset, 8);assume { :begin_inline_IS_ERR } true;IS_ERR_#in~ptr#1.base, IS_ERR_#in~ptr#1.offset := ibmpex_register_bmc_#t~mem187#1.base, ibmpex_register_bmc_#t~mem187#1.offset;havoc IS_ERR_#res#1;havoc IS_ERR_#t~ret240#1, IS_ERR_~ptr#1.base, IS_ERR_~ptr#1.offset, IS_ERR_~tmp~18#1;IS_ERR_~ptr#1.base, IS_ERR_~ptr#1.offset := IS_ERR_#in~ptr#1.base, IS_ERR_#in~ptr#1.offset;havoc IS_ERR_~tmp~18#1; {17749#true} is VALID [2022-02-20 21:35:42,628 INFO L272 TraceCheckUtils]: 73: Hoare triple {17749#true} call IS_ERR_#t~ret240#1 := ldv_is_err(IS_ERR_~ptr#1.base, IS_ERR_~ptr#1.offset); {17749#true} is VALID [2022-02-20 21:35:42,628 INFO L290 TraceCheckUtils]: 74: Hoare triple {17749#true} ~ptr.base, ~ptr.offset := #in~ptr.base, #in~ptr.offset;#res := (if (~ptr.base + ~ptr.offset) % 18446744073709551616 > 2012 then 1 else 0); {17749#true} is VALID [2022-02-20 21:35:42,628 INFO L290 TraceCheckUtils]: 75: Hoare triple {17749#true} assume true; {17749#true} is VALID [2022-02-20 21:35:42,628 INFO L284 TraceCheckUtils]: 76: Hoare quadruple {17749#true} {17749#true} #626#return; {17749#true} is VALID [2022-02-20 21:35:42,629 INFO L290 TraceCheckUtils]: 77: Hoare triple {17749#true} assume -9223372036854775808 <= IS_ERR_#t~ret240#1 && IS_ERR_#t~ret240#1 <= 9223372036854775807;IS_ERR_~tmp~18#1 := IS_ERR_#t~ret240#1;havoc IS_ERR_#t~ret240#1;IS_ERR_#res#1 := IS_ERR_~tmp~18#1; {17749#true} is VALID [2022-02-20 21:35:42,629 INFO L290 TraceCheckUtils]: 78: Hoare triple {17749#true} ibmpex_register_bmc_#t~ret188#1 := IS_ERR_#res#1;assume { :end_inline_IS_ERR } true;assume -9223372036854775808 <= ibmpex_register_bmc_#t~ret188#1 && ibmpex_register_bmc_#t~ret188#1 <= 9223372036854775807;ibmpex_register_bmc_~tmp___0~3#1 := ibmpex_register_bmc_#t~ret188#1;havoc ibmpex_register_bmc_#t~mem187#1.base, ibmpex_register_bmc_#t~mem187#1.offset;havoc ibmpex_register_bmc_#t~ret188#1; {17749#true} is VALID [2022-02-20 21:35:42,629 INFO L290 TraceCheckUtils]: 79: Hoare triple {17749#true} assume !(0 != ibmpex_register_bmc_~tmp___0~3#1); {17749#true} is VALID [2022-02-20 21:35:42,629 INFO L272 TraceCheckUtils]: 80: Hoare triple {17749#true} call dev_set_drvdata(ibmpex_register_bmc_~dev#1.base, ibmpex_register_bmc_~dev#1.offset, ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset); {17749#true} is VALID [2022-02-20 21:35:42,629 INFO L290 TraceCheckUtils]: 81: Hoare triple {17749#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset;~arg1.base, ~arg1.offset := #in~arg1.base, #in~arg1.offset; {17749#true} is VALID [2022-02-20 21:35:42,630 INFO L290 TraceCheckUtils]: 82: Hoare triple {17749#true} assume true; {17749#true} is VALID [2022-02-20 21:35:42,630 INFO L284 TraceCheckUtils]: 83: Hoare quadruple {17749#true} {17749#true} #628#return; {17749#true} is VALID [2022-02-20 21:35:42,630 INFO L290 TraceCheckUtils]: 84: Hoare triple {17749#true} assume { :begin_inline_list_add_tail } true;list_add_tail_#in~new#1.base, list_add_tail_#in~new#1.offset, list_add_tail_#in~head#1.base, list_add_tail_#in~head#1.offset := ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset, ~#driver_data~0.base, ~#driver_data~0.offset;havoc list_add_tail_#t~mem12#1.base, list_add_tail_#t~mem12#1.offset, list_add_tail_~new#1.base, list_add_tail_~new#1.offset, list_add_tail_~head#1.base, list_add_tail_~head#1.offset;list_add_tail_~new#1.base, list_add_tail_~new#1.offset := list_add_tail_#in~new#1.base, list_add_tail_#in~new#1.offset;list_add_tail_~head#1.base, list_add_tail_~head#1.offset := list_add_tail_#in~head#1.base, list_add_tail_#in~head#1.offset;call list_add_tail_#t~mem12#1.base, list_add_tail_#t~mem12#1.offset := read~$Pointer$(list_add_tail_~head#1.base, 8 + list_add_tail_~head#1.offset, 8);assume { :begin_inline___list_add } true;__list_add_#in~arg0#1.base, __list_add_#in~arg0#1.offset, __list_add_#in~arg1#1.base, __list_add_#in~arg1#1.offset, __list_add_#in~arg2#1.base, __list_add_#in~arg2#1.offset := list_add_tail_~new#1.base, list_add_tail_~new#1.offset, list_add_tail_#t~mem12#1.base, list_add_tail_#t~mem12#1.offset, list_add_tail_~head#1.base, list_add_tail_~head#1.offset;havoc __list_add_~arg0#1.base, __list_add_~arg0#1.offset, __list_add_~arg1#1.base, __list_add_~arg1#1.offset, __list_add_~arg2#1.base, __list_add_~arg2#1.offset;__list_add_~arg0#1.base, __list_add_~arg0#1.offset := __list_add_#in~arg0#1.base, __list_add_#in~arg0#1.offset;__list_add_~arg1#1.base, __list_add_~arg1#1.offset := __list_add_#in~arg1#1.base, __list_add_#in~arg1#1.offset;__list_add_~arg2#1.base, __list_add_~arg2#1.offset := __list_add_#in~arg2#1.base, __list_add_#in~arg2#1.offset; {17749#true} is VALID [2022-02-20 21:35:42,630 INFO L290 TraceCheckUtils]: 85: Hoare triple {17749#true} assume { :end_inline___list_add } true;havoc list_add_tail_#t~mem12#1.base, list_add_tail_#t~mem12#1.offset; {17749#true} is VALID [2022-02-20 21:35:42,630 INFO L290 TraceCheckUtils]: 86: Hoare triple {17749#true} assume { :end_inline_list_add_tail } true;assume { :begin_inline_ibmpex_find_sensors } true;ibmpex_find_sensors_#in~data#1.base, ibmpex_find_sensors_#in~data#1.offset := ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset;havoc ibmpex_find_sensors_#res#1;havoc ibmpex_find_sensors_#t~ret148#1, ibmpex_find_sensors_#t~mem149#1, ibmpex_find_sensors_#t~ret150#1.base, ibmpex_find_sensors_#t~ret150#1.offset, ibmpex_find_sensors_#t~mem151#1.base, ibmpex_find_sensors_#t~mem151#1.offset, ibmpex_find_sensors_#t~ret152#1, ibmpex_find_sensors_#t~mem153#1, ibmpex_find_sensors_#t~ret154#1, ibmpex_find_sensors_#t~mem155#1.base, ibmpex_find_sensors_#t~mem155#1.offset, ibmpex_find_sensors_#t~mem156#1, ibmpex_find_sensors_#t~ret157#1, ibmpex_find_sensors_#t~mem158#1, ibmpex_find_sensors_#t~ret159#1, ibmpex_find_sensors_#t~mem160#1.base, ibmpex_find_sensors_#t~mem160#1.offset, ibmpex_find_sensors_#t~mem161#1.base, ibmpex_find_sensors_#t~mem161#1.offset, ibmpex_find_sensors_#t~ret162#1, ibmpex_find_sensors_#t~mem163#1, ibmpex_find_sensors_#t~mem164#1.base, ibmpex_find_sensors_#t~mem164#1.offset, ibmpex_find_sensors_#t~ret165#1, ibmpex_find_sensors_#t~mem166#1.base, ibmpex_find_sensors_#t~mem166#1.offset, ibmpex_find_sensors_#t~ret167#1, ibmpex_find_sensors_#t~mem168#1.base, ibmpex_find_sensors_#t~mem168#1.offset, ibmpex_find_sensors_#t~mem169#1.base, ibmpex_find_sensors_#t~mem169#1.offset, ibmpex_find_sensors_#t~mem170#1.base, ibmpex_find_sensors_#t~mem170#1.offset, ibmpex_find_sensors_#t~mem171#1.base, ibmpex_find_sensors_#t~mem171#1.offset, ibmpex_find_sensors_#t~mem172#1.base, ibmpex_find_sensors_#t~mem172#1.offset, ibmpex_find_sensors_#t~mem173#1.base, ibmpex_find_sensors_#t~mem173#1.offset, ibmpex_find_sensors_#t~mem174#1.base, ibmpex_find_sensors_#t~mem174#1.offset, ibmpex_find_sensors_#t~mem175#1.base, ibmpex_find_sensors_#t~mem175#1.offset, ibmpex_find_sensors_#t~mem176#1, ibmpex_find_sensors_#t~mem177#1.base, ibmpex_find_sensors_#t~mem177#1.offset, ibmpex_find_sensors_~data#1.base, ibmpex_find_sensors_~data#1.offset, ibmpex_find_sensors_~i~2#1, ibmpex_find_sensors_~j~0#1, ibmpex_find_sensors_~err~3#1, ibmpex_find_sensors_~sensor_type~0#1, ibmpex_find_sensors_~sensor_counter~0#1, ibmpex_find_sensors_~num_power~0#1, ibmpex_find_sensors_~num_temp~0#1, ibmpex_find_sensors_~tmp~13#1.base, ibmpex_find_sensors_~tmp~13#1.offset, ibmpex_find_sensors_~tmp___0~2#1, ibmpex_find_sensors_~tmp___1~1#1;ibmpex_find_sensors_~data#1.base, ibmpex_find_sensors_~data#1.offset := ibmpex_find_sensors_#in~data#1.base, ibmpex_find_sensors_#in~data#1.offset;havoc ibmpex_find_sensors_~i~2#1;havoc ibmpex_find_sensors_~j~0#1;havoc ibmpex_find_sensors_~err~3#1;havoc ibmpex_find_sensors_~sensor_type~0#1;havoc ibmpex_find_sensors_~sensor_counter~0#1;havoc ibmpex_find_sensors_~num_power~0#1;havoc ibmpex_find_sensors_~num_temp~0#1;havoc ibmpex_find_sensors_~tmp~13#1.base, ibmpex_find_sensors_~tmp~13#1.offset;havoc ibmpex_find_sensors_~tmp___0~2#1;havoc ibmpex_find_sensors_~tmp___1~1#1;ibmpex_find_sensors_~num_power~0#1 := 0;ibmpex_find_sensors_~num_temp~0#1 := 0;assume { :begin_inline_ibmpex_query_sensor_count } true;ibmpex_query_sensor_count_#in~data#1.base, ibmpex_query_sensor_count_#in~data#1.offset := ibmpex_find_sensors_~data#1.base, ibmpex_find_sensors_~data#1.offset;havoc ibmpex_query_sensor_count_#res#1;havoc ibmpex_query_sensor_count_#t~ret85#1, ibmpex_query_sensor_count_#t~mem86#1, ibmpex_query_sensor_count_#t~mem87#1, ibmpex_query_sensor_count_#t~short88#1, ibmpex_query_sensor_count_#t~mem89#1, ibmpex_query_sensor_count_~data#1.base, ibmpex_query_sensor_count_~data#1.offset;ibmpex_query_sensor_count_~data#1.base, ibmpex_query_sensor_count_~data#1.offset := ibmpex_query_sensor_count_#in~data#1.base, ibmpex_query_sensor_count_#in~data#1.offset;call write~int(2, ibmpex_query_sensor_count_~data#1.base, 339 + ibmpex_query_sensor_count_~data#1.offset, 1);call write~int(1, ibmpex_query_sensor_count_~data#1.base, 329 + ibmpex_query_sensor_count_~data#1.offset, 2); {17749#true} is VALID [2022-02-20 21:35:42,631 INFO L272 TraceCheckUtils]: 87: Hoare triple {17749#true} call ibmpex_query_sensor_count_#t~ret85#1 := ibmpex_send_message(ibmpex_query_sensor_count_~data#1.base, ibmpex_query_sensor_count_~data#1.offset); {17855#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} is VALID [2022-02-20 21:35:42,631 INFO L290 TraceCheckUtils]: 88: Hoare triple {17855#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;havoc ~err~0#1;assume { :begin_inline_ipmi_validate_addr } true;ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset, ipmi_validate_addr_#in~arg1#1 := ~data#1.base, 193 + ~data#1.offset, 40;havoc ipmi_validate_addr_#res#1;havoc ipmi_validate_addr_#t~nondet254#1, ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset, ipmi_validate_addr_~arg1#1;ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset := ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset;ipmi_validate_addr_~arg1#1 := ipmi_validate_addr_#in~arg1#1;assume -2147483648 <= ipmi_validate_addr_#t~nondet254#1 && ipmi_validate_addr_#t~nondet254#1 <= 2147483647;ipmi_validate_addr_#res#1 := ipmi_validate_addr_#t~nondet254#1;havoc ipmi_validate_addr_#t~nondet254#1; {17749#true} is VALID [2022-02-20 21:35:42,631 INFO L290 TraceCheckUtils]: 89: Hoare triple {17749#true} #t~ret62#1 := ipmi_validate_addr_#res#1;assume { :end_inline_ipmi_validate_addr } true;assume -2147483648 <= #t~ret62#1 && #t~ret62#1 <= 2147483647;~err~0#1 := #t~ret62#1;havoc #t~ret62#1; {17749#true} is VALID [2022-02-20 21:35:42,632 INFO L290 TraceCheckUtils]: 90: Hoare triple {17749#true} assume 0 != ~err~0#1; {17749#true} is VALID [2022-02-20 21:35:42,632 INFO L290 TraceCheckUtils]: 91: Hoare triple {17749#true} havoc #t~nondet69#1;call #t~mem70#1.base, #t~mem70#1.offset := read~$Pointer$(~data#1.base, 24 + ~data#1.offset, 8);havoc #t~mem70#1.base, #t~mem70#1.offset;#res#1 := ~err~0#1; {17749#true} is VALID [2022-02-20 21:35:42,632 INFO L290 TraceCheckUtils]: 92: Hoare triple {17749#true} assume true; {17749#true} is VALID [2022-02-20 21:35:42,632 INFO L284 TraceCheckUtils]: 93: Hoare quadruple {17749#true} {17749#true} #630#return; {17749#true} is VALID [2022-02-20 21:35:42,632 INFO L290 TraceCheckUtils]: 94: Hoare triple {17749#true} assume -2147483648 <= ibmpex_query_sensor_count_#t~ret85#1 && ibmpex_query_sensor_count_#t~ret85#1 <= 2147483647;havoc ibmpex_query_sensor_count_#t~ret85#1; {17749#true} is VALID [2022-02-20 21:35:42,633 INFO L272 TraceCheckUtils]: 95: Hoare triple {17749#true} call wait_for_completion(ibmpex_query_sensor_count_~data#1.base, 231 + ibmpex_query_sensor_count_~data#1.offset); {17749#true} is VALID [2022-02-20 21:35:42,633 INFO L290 TraceCheckUtils]: 96: Hoare triple {17749#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset; {17749#true} is VALID [2022-02-20 21:35:42,633 INFO L290 TraceCheckUtils]: 97: Hoare triple {17749#true} assume true; {17749#true} is VALID [2022-02-20 21:35:42,633 INFO L284 TraceCheckUtils]: 98: Hoare quadruple {17749#true} {17749#true} #632#return; {17749#true} is VALID [2022-02-20 21:35:42,633 INFO L290 TraceCheckUtils]: 99: Hoare triple {17749#true} call ibmpex_query_sensor_count_#t~mem86#1 := read~int(ibmpex_query_sensor_count_~data#1.base, 899 + ibmpex_query_sensor_count_~data#1.offset, 1);ibmpex_query_sensor_count_#t~short88#1 := 0 != ibmpex_query_sensor_count_#t~mem86#1 % 256 % 4294967296; {17749#true} is VALID [2022-02-20 21:35:42,633 INFO L290 TraceCheckUtils]: 100: Hoare triple {17749#true} assume !ibmpex_query_sensor_count_#t~short88#1;call ibmpex_query_sensor_count_#t~mem87#1 := read~int(ibmpex_query_sensor_count_~data#1.base, 891 + ibmpex_query_sensor_count_~data#1.offset, 8);ibmpex_query_sensor_count_#t~short88#1 := 1 != ibmpex_query_sensor_count_#t~mem87#1 % 18446744073709551616; {17749#true} is VALID [2022-02-20 21:35:42,634 INFO L290 TraceCheckUtils]: 101: Hoare triple {17749#true} assume !ibmpex_query_sensor_count_#t~short88#1;havoc ibmpex_query_sensor_count_#t~mem86#1;havoc ibmpex_query_sensor_count_#t~mem87#1;havoc ibmpex_query_sensor_count_#t~short88#1;call ibmpex_query_sensor_count_#t~mem89#1 := read~int(ibmpex_query_sensor_count_~data#1.base, 619 + ibmpex_query_sensor_count_~data#1.offset, 1);ibmpex_query_sensor_count_#res#1 := ibmpex_query_sensor_count_#t~mem89#1 % 256;havoc ibmpex_query_sensor_count_#t~mem89#1; {17749#true} is VALID [2022-02-20 21:35:42,634 INFO L290 TraceCheckUtils]: 102: Hoare triple {17749#true} ibmpex_find_sensors_#t~ret148#1 := ibmpex_query_sensor_count_#res#1;assume { :end_inline_ibmpex_query_sensor_count } true;assume -2147483648 <= ibmpex_find_sensors_#t~ret148#1 && ibmpex_find_sensors_#t~ret148#1 <= 2147483647;ibmpex_find_sensors_~err~3#1 := ibmpex_find_sensors_#t~ret148#1;havoc ibmpex_find_sensors_#t~ret148#1; {17749#true} is VALID [2022-02-20 21:35:42,634 INFO L290 TraceCheckUtils]: 103: Hoare triple {17749#true} assume !(ibmpex_find_sensors_~err~3#1 <= 0);call write~int(ibmpex_find_sensors_~err~3#1, ibmpex_find_sensors_~data#1.base, 906 + ibmpex_find_sensors_~data#1.offset, 1);call ibmpex_find_sensors_#t~mem149#1 := read~int(ibmpex_find_sensors_~data#1.base, 906 + ibmpex_find_sensors_~data#1.offset, 1); {17749#true} is VALID [2022-02-20 21:35:42,635 INFO L272 TraceCheckUtils]: 104: Hoare triple {17749#true} call ibmpex_find_sensors_#t~ret150#1.base, ibmpex_find_sensors_#t~ret150#1.offset := kzalloc(184 * (ibmpex_find_sensors_#t~mem149#1 % 256), 208); {17840#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:42,635 INFO L290 TraceCheckUtils]: 105: Hoare triple {17840#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size;~flags := #in~flags;havoc ~tmp~2.base, ~tmp~2.offset; {17749#true} is VALID [2022-02-20 21:35:42,635 INFO L272 TraceCheckUtils]: 106: Hoare triple {17749#true} call #t~ret40.base, #t~ret40.offset := kmalloc(~size, ~bitwiseOr(~flags, 32768)); {17840#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:42,636 INFO L290 TraceCheckUtils]: 107: Hoare triple {17840#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {17749#true} is VALID [2022-02-20 21:35:42,636 INFO L272 TraceCheckUtils]: 108: Hoare triple {17749#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {17840#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:42,636 INFO L290 TraceCheckUtils]: 109: Hoare triple {17840#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {17749#true} is VALID [2022-02-20 21:35:42,636 INFO L290 TraceCheckUtils]: 110: Hoare triple {17749#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {17749#true} is VALID [2022-02-20 21:35:42,637 INFO L290 TraceCheckUtils]: 111: Hoare triple {17749#true} assume true; {17749#true} is VALID [2022-02-20 21:35:42,637 INFO L284 TraceCheckUtils]: 112: Hoare quadruple {17749#true} {17749#true} #590#return; {17749#true} is VALID [2022-02-20 21:35:42,637 INFO L290 TraceCheckUtils]: 113: Hoare triple {17749#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {17749#true} is VALID [2022-02-20 21:35:42,637 INFO L290 TraceCheckUtils]: 114: Hoare triple {17749#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {17749#true} is VALID [2022-02-20 21:35:42,637 INFO L290 TraceCheckUtils]: 115: Hoare triple {17749#true} assume true; {17749#true} is VALID [2022-02-20 21:35:42,638 INFO L284 TraceCheckUtils]: 116: Hoare quadruple {17749#true} {17749#true} #588#return; {17749#true} is VALID [2022-02-20 21:35:42,638 INFO L290 TraceCheckUtils]: 117: Hoare triple {17749#true} ~tmp~2.base, ~tmp~2.offset := #t~ret40.base, #t~ret40.offset;havoc #t~ret40.base, #t~ret40.offset;#res.base, #res.offset := ~tmp~2.base, ~tmp~2.offset; {17749#true} is VALID [2022-02-20 21:35:42,638 INFO L290 TraceCheckUtils]: 118: Hoare triple {17749#true} assume true; {17749#true} is VALID [2022-02-20 21:35:42,638 INFO L284 TraceCheckUtils]: 119: Hoare quadruple {17749#true} {17749#true} #634#return; {17749#true} is VALID [2022-02-20 21:35:42,638 INFO L290 TraceCheckUtils]: 120: Hoare triple {17749#true} ibmpex_find_sensors_~tmp~13#1.base, ibmpex_find_sensors_~tmp~13#1.offset := ibmpex_find_sensors_#t~ret150#1.base, ibmpex_find_sensors_#t~ret150#1.offset;havoc ibmpex_find_sensors_#t~mem149#1;havoc ibmpex_find_sensors_#t~ret150#1.base, ibmpex_find_sensors_#t~ret150#1.offset;call write~$Pointer$(ibmpex_find_sensors_~tmp~13#1.base, ibmpex_find_sensors_~tmp~13#1.offset, ibmpex_find_sensors_~data#1.base, 907 + ibmpex_find_sensors_~data#1.offset, 8);call ibmpex_find_sensors_#t~mem151#1.base, ibmpex_find_sensors_#t~mem151#1.offset := read~$Pointer$(ibmpex_find_sensors_~data#1.base, 907 + ibmpex_find_sensors_~data#1.offset, 8); {17749#true} is VALID [2022-02-20 21:35:42,638 INFO L290 TraceCheckUtils]: 121: Hoare triple {17749#true} assume !(0 == (ibmpex_find_sensors_#t~mem151#1.base + ibmpex_find_sensors_#t~mem151#1.offset) % 18446744073709551616);havoc ibmpex_find_sensors_#t~mem151#1.base, ibmpex_find_sensors_#t~mem151#1.offset;ibmpex_find_sensors_~i~2#1 := 0; {17749#true} is VALID [2022-02-20 21:35:42,639 INFO L290 TraceCheckUtils]: 122: Hoare triple {17749#true} call ibmpex_find_sensors_#t~mem163#1 := read~int(ibmpex_find_sensors_~data#1.base, 906 + ibmpex_find_sensors_~data#1.offset, 1); {17749#true} is VALID [2022-02-20 21:35:42,639 INFO L290 TraceCheckUtils]: 123: Hoare triple {17749#true} assume ibmpex_find_sensors_#t~mem163#1 % 256 > ibmpex_find_sensors_~i~2#1;havoc ibmpex_find_sensors_#t~mem163#1; {17749#true} is VALID [2022-02-20 21:35:42,639 INFO L290 TraceCheckUtils]: 124: Hoare triple {17749#true} assume { :begin_inline_ibmpex_query_sensor_name } true;ibmpex_query_sensor_name_#in~data#1.base, ibmpex_query_sensor_name_#in~data#1.offset, ibmpex_query_sensor_name_#in~sensor#1 := ibmpex_find_sensors_~data#1.base, ibmpex_find_sensors_~data#1.offset, ibmpex_find_sensors_~i~2#1;havoc ibmpex_query_sensor_name_#res#1;havoc ibmpex_query_sensor_name_#t~ret90#1, ibmpex_query_sensor_name_#t~mem91#1, ibmpex_query_sensor_name_#t~mem92#1, ibmpex_query_sensor_name_#t~short93#1, ibmpex_query_sensor_name_~data#1.base, ibmpex_query_sensor_name_~data#1.offset, ibmpex_query_sensor_name_~sensor#1;ibmpex_query_sensor_name_~data#1.base, ibmpex_query_sensor_name_~data#1.offset := ibmpex_query_sensor_name_#in~data#1.base, ibmpex_query_sensor_name_#in~data#1.offset;ibmpex_query_sensor_name_~sensor#1 := ibmpex_query_sensor_name_#in~sensor#1;call write~int(3, ibmpex_query_sensor_name_~data#1.base, 339 + ibmpex_query_sensor_name_~data#1.offset, 1);call write~int(ibmpex_query_sensor_name_~sensor#1, ibmpex_query_sensor_name_~data#1.base, 340 + ibmpex_query_sensor_name_~data#1.offset, 1);call write~int(2, ibmpex_query_sensor_name_~data#1.base, 329 + ibmpex_query_sensor_name_~data#1.offset, 2); {17749#true} is VALID [2022-02-20 21:35:42,640 INFO L272 TraceCheckUtils]: 125: Hoare triple {17749#true} call ibmpex_query_sensor_name_#t~ret90#1 := ibmpex_send_message(ibmpex_query_sensor_name_~data#1.base, ibmpex_query_sensor_name_~data#1.offset); {17855#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} is VALID [2022-02-20 21:35:42,640 INFO L290 TraceCheckUtils]: 126: Hoare triple {17855#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;havoc ~err~0#1;assume { :begin_inline_ipmi_validate_addr } true;ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset, ipmi_validate_addr_#in~arg1#1 := ~data#1.base, 193 + ~data#1.offset, 40;havoc ipmi_validate_addr_#res#1;havoc ipmi_validate_addr_#t~nondet254#1, ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset, ipmi_validate_addr_~arg1#1;ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset := ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset;ipmi_validate_addr_~arg1#1 := ipmi_validate_addr_#in~arg1#1;assume -2147483648 <= ipmi_validate_addr_#t~nondet254#1 && ipmi_validate_addr_#t~nondet254#1 <= 2147483647;ipmi_validate_addr_#res#1 := ipmi_validate_addr_#t~nondet254#1;havoc ipmi_validate_addr_#t~nondet254#1; {17749#true} is VALID [2022-02-20 21:35:42,640 INFO L290 TraceCheckUtils]: 127: Hoare triple {17749#true} #t~ret62#1 := ipmi_validate_addr_#res#1;assume { :end_inline_ipmi_validate_addr } true;assume -2147483648 <= #t~ret62#1 && #t~ret62#1 <= 2147483647;~err~0#1 := #t~ret62#1;havoc #t~ret62#1; {17749#true} is VALID [2022-02-20 21:35:42,640 INFO L290 TraceCheckUtils]: 128: Hoare triple {17749#true} assume 0 != ~err~0#1; {17749#true} is VALID [2022-02-20 21:35:42,640 INFO L290 TraceCheckUtils]: 129: Hoare triple {17749#true} havoc #t~nondet69#1;call #t~mem70#1.base, #t~mem70#1.offset := read~$Pointer$(~data#1.base, 24 + ~data#1.offset, 8);havoc #t~mem70#1.base, #t~mem70#1.offset;#res#1 := ~err~0#1; {17749#true} is VALID [2022-02-20 21:35:42,641 INFO L290 TraceCheckUtils]: 130: Hoare triple {17749#true} assume true; {17749#true} is VALID [2022-02-20 21:35:42,641 INFO L284 TraceCheckUtils]: 131: Hoare quadruple {17749#true} {17749#true} #636#return; {17749#true} is VALID [2022-02-20 21:35:42,641 INFO L290 TraceCheckUtils]: 132: Hoare triple {17749#true} assume -2147483648 <= ibmpex_query_sensor_name_#t~ret90#1 && ibmpex_query_sensor_name_#t~ret90#1 <= 2147483647;havoc ibmpex_query_sensor_name_#t~ret90#1; {17749#true} is VALID [2022-02-20 21:35:42,641 INFO L272 TraceCheckUtils]: 133: Hoare triple {17749#true} call wait_for_completion(ibmpex_query_sensor_name_~data#1.base, 231 + ibmpex_query_sensor_name_~data#1.offset); {17749#true} is VALID [2022-02-20 21:35:42,641 INFO L290 TraceCheckUtils]: 134: Hoare triple {17749#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset; {17749#true} is VALID [2022-02-20 21:35:42,641 INFO L290 TraceCheckUtils]: 135: Hoare triple {17749#true} assume true; {17749#true} is VALID [2022-02-20 21:35:42,642 INFO L284 TraceCheckUtils]: 136: Hoare quadruple {17749#true} {17749#true} #638#return; {17749#true} is VALID [2022-02-20 21:35:42,642 INFO L290 TraceCheckUtils]: 137: Hoare triple {17749#true} call ibmpex_query_sensor_name_#t~mem91#1 := read~int(ibmpex_query_sensor_name_~data#1.base, 899 + ibmpex_query_sensor_name_~data#1.offset, 1);ibmpex_query_sensor_name_#t~short93#1 := 0 != ibmpex_query_sensor_name_#t~mem91#1 % 256 % 4294967296; {17749#true} is VALID [2022-02-20 21:35:42,642 INFO L290 TraceCheckUtils]: 138: Hoare triple {17749#true} assume ibmpex_query_sensor_name_#t~short93#1; {17749#true} is VALID [2022-02-20 21:35:42,642 INFO L290 TraceCheckUtils]: 139: Hoare triple {17749#true} assume ibmpex_query_sensor_name_#t~short93#1;havoc ibmpex_query_sensor_name_#t~mem91#1;havoc ibmpex_query_sensor_name_#t~mem92#1;havoc ibmpex_query_sensor_name_#t~short93#1;ibmpex_query_sensor_name_#res#1 := -2; {17828#(<= (+ 2 |ULTIMATE.start_ibmpex_query_sensor_name_#res#1|) 0)} is VALID [2022-02-20 21:35:42,643 INFO L290 TraceCheckUtils]: 140: Hoare triple {17828#(<= (+ 2 |ULTIMATE.start_ibmpex_query_sensor_name_#res#1|) 0)} ibmpex_find_sensors_#t~ret152#1 := ibmpex_query_sensor_name_#res#1;assume { :end_inline_ibmpex_query_sensor_name } true;assume -2147483648 <= ibmpex_find_sensors_#t~ret152#1 && ibmpex_find_sensors_#t~ret152#1 <= 2147483647;ibmpex_find_sensors_~err~3#1 := ibmpex_find_sensors_#t~ret152#1;havoc ibmpex_find_sensors_#t~ret152#1; {17829#(<= (+ 2 |ULTIMATE.start_ibmpex_find_sensors_~err~3#1|) 0)} is VALID [2022-02-20 21:35:42,644 INFO L290 TraceCheckUtils]: 141: Hoare triple {17829#(<= (+ 2 |ULTIMATE.start_ibmpex_find_sensors_~err~3#1|) 0)} assume !(0 != ibmpex_find_sensors_~err~3#1);call ibmpex_find_sensors_#t~mem153#1 := read~int(ibmpex_find_sensors_~data#1.base, 891 + ibmpex_find_sensors_~data#1.offset, 8);assume { :begin_inline_is_power_sensor } true;is_power_sensor_#in~sensor_id#1.base, is_power_sensor_#in~sensor_id#1.offset, is_power_sensor_#in~len#1 := ibmpex_find_sensors_~data#1.base, 619 + ibmpex_find_sensors_~data#1.offset, (if ibmpex_find_sensors_#t~mem153#1 % 18446744073709551616 % 4294967296 <= 2147483647 then ibmpex_find_sensors_#t~mem153#1 % 18446744073709551616 % 4294967296 else ibmpex_find_sensors_#t~mem153#1 % 18446744073709551616 % 4294967296 - 4294967296);havoc is_power_sensor_#res#1;havoc is_power_sensor_#t~ret130#1, is_power_sensor_~sensor_id#1.base, is_power_sensor_~sensor_id#1.offset, is_power_sensor_~len#1, is_power_sensor_~tmp~9#1;is_power_sensor_~sensor_id#1.base, is_power_sensor_~sensor_id#1.offset := is_power_sensor_#in~sensor_id#1.base, is_power_sensor_#in~sensor_id#1.offset;is_power_sensor_~len#1 := is_power_sensor_#in~len#1;havoc is_power_sensor_~tmp~9#1; {17750#false} is VALID [2022-02-20 21:35:42,644 INFO L290 TraceCheckUtils]: 142: Hoare triple {17750#false} assume is_power_sensor_~len#1 <= 2;is_power_sensor_#res#1 := 0; {17750#false} is VALID [2022-02-20 21:35:42,644 INFO L290 TraceCheckUtils]: 143: Hoare triple {17750#false} ibmpex_find_sensors_#t~ret154#1 := is_power_sensor_#res#1;assume { :end_inline_is_power_sensor } true;assume -2147483648 <= ibmpex_find_sensors_#t~ret154#1 && ibmpex_find_sensors_#t~ret154#1 <= 2147483647;ibmpex_find_sensors_~tmp___1~1#1 := ibmpex_find_sensors_#t~ret154#1;havoc ibmpex_find_sensors_#t~mem153#1;havoc ibmpex_find_sensors_#t~ret154#1; {17750#false} is VALID [2022-02-20 21:35:42,644 INFO L290 TraceCheckUtils]: 144: Hoare triple {17750#false} assume 0 != ibmpex_find_sensors_~tmp___1~1#1;ibmpex_find_sensors_~sensor_type~0#1 := 2;ibmpex_find_sensors_~num_power~0#1 := 1 + ibmpex_find_sensors_~num_power~0#1;ibmpex_find_sensors_~sensor_counter~0#1 := ibmpex_find_sensors_~num_power~0#1;call ibmpex_find_sensors_#t~mem155#1.base, ibmpex_find_sensors_#t~mem155#1.offset := read~$Pointer$(ibmpex_find_sensors_~data#1.base, 907 + ibmpex_find_sensors_~data#1.offset, 8);call ibmpex_find_sensors_#t~mem156#1 := read~int(ibmpex_find_sensors_~data#1.base, 891 + ibmpex_find_sensors_~data#1.offset, 8);assume { :begin_inline_power_sensor_multiplier } true;power_sensor_multiplier_#in~data#1.base, power_sensor_multiplier_#in~data#1.offset, power_sensor_multiplier_#in~sensor_id#1.base, power_sensor_multiplier_#in~sensor_id#1.offset, power_sensor_multiplier_#in~len#1 := ibmpex_find_sensors_~data#1.base, ibmpex_find_sensors_~data#1.offset, ibmpex_find_sensors_~data#1.base, 619 + ibmpex_find_sensors_~data#1.offset, (if ibmpex_find_sensors_#t~mem156#1 % 18446744073709551616 % 4294967296 <= 2147483647 then ibmpex_find_sensors_#t~mem156#1 % 18446744073709551616 % 4294967296 else ibmpex_find_sensors_#t~mem156#1 % 18446744073709551616 % 4294967296 - 4294967296);havoc power_sensor_multiplier_#res#1;havoc power_sensor_multiplier_#t~mem132#1, power_sensor_multiplier_#t~ret133#1, power_sensor_multiplier_~data#1.base, power_sensor_multiplier_~data#1.offset, power_sensor_multiplier_~sensor_id#1.base, power_sensor_multiplier_~sensor_id#1.offset, power_sensor_multiplier_~len#1, power_sensor_multiplier_~i~1#1, power_sensor_multiplier_~tmp~11#1;power_sensor_multiplier_~data#1.base, power_sensor_multiplier_~data#1.offset := power_sensor_multiplier_#in~data#1.base, power_sensor_multiplier_#in~data#1.offset;power_sensor_multiplier_~sensor_id#1.base, power_sensor_multiplier_~sensor_id#1.offset := power_sensor_multiplier_#in~sensor_id#1.base, power_sensor_multiplier_#in~sensor_id#1.offset;power_sensor_multiplier_~len#1 := power_sensor_multiplier_#in~len#1;havoc power_sensor_multiplier_~i~1#1;havoc power_sensor_multiplier_~tmp~11#1;call power_sensor_multiplier_#t~mem132#1 := read~int(power_sensor_multiplier_~data#1.base, 904 + power_sensor_multiplier_~data#1.offset, 1); {17750#false} is VALID [2022-02-20 21:35:42,644 INFO L290 TraceCheckUtils]: 145: Hoare triple {17750#false} assume 2 == power_sensor_multiplier_#t~mem132#1 % 256 % 4294967296;havoc power_sensor_multiplier_#t~mem132#1;power_sensor_multiplier_#res#1 := 1000000; {17750#false} is VALID [2022-02-20 21:35:42,645 INFO L290 TraceCheckUtils]: 146: Hoare triple {17750#false} ibmpex_find_sensors_#t~ret157#1 := power_sensor_multiplier_#res#1;assume { :end_inline_power_sensor_multiplier } true;assume -2147483648 <= ibmpex_find_sensors_#t~ret157#1 && ibmpex_find_sensors_#t~ret157#1 <= 2147483647;call write~int(ibmpex_find_sensors_#t~ret157#1, ibmpex_find_sensors_#t~mem155#1.base, 10 + (ibmpex_find_sensors_#t~mem155#1.offset + 152 * (if ibmpex_find_sensors_~i~2#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then ibmpex_find_sensors_~i~2#1 % 18446744073709551616 % 18446744073709551616 else ibmpex_find_sensors_~i~2#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616)), 4);havoc ibmpex_find_sensors_#t~mem155#1.base, ibmpex_find_sensors_#t~mem155#1.offset;havoc ibmpex_find_sensors_#t~mem156#1;havoc ibmpex_find_sensors_#t~ret157#1; {17750#false} is VALID [2022-02-20 21:35:42,645 INFO L290 TraceCheckUtils]: 147: Hoare triple {17750#false} call ibmpex_find_sensors_#t~mem161#1.base, ibmpex_find_sensors_#t~mem161#1.offset := read~$Pointer$(ibmpex_find_sensors_~data#1.base, 907 + ibmpex_find_sensors_~data#1.offset, 8);call write~int(1, ibmpex_find_sensors_#t~mem161#1.base, ibmpex_find_sensors_#t~mem161#1.offset + 152 * (if ibmpex_find_sensors_~i~2#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then ibmpex_find_sensors_~i~2#1 % 18446744073709551616 % 18446744073709551616 else ibmpex_find_sensors_~i~2#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 4);havoc ibmpex_find_sensors_#t~mem161#1.base, ibmpex_find_sensors_#t~mem161#1.offset;ibmpex_find_sensors_~j~0#1 := 0; {17750#false} is VALID [2022-02-20 21:35:42,645 INFO L290 TraceCheckUtils]: 148: Hoare triple {17750#false} assume ibmpex_find_sensors_~j~0#1 <= 2; {17750#false} is VALID [2022-02-20 21:35:42,645 INFO L290 TraceCheckUtils]: 149: Hoare triple {17750#false} assume { :begin_inline_create_sensor } true;create_sensor_#in~data#1.base, create_sensor_#in~data#1.offset, create_sensor_#in~type#1, create_sensor_#in~counter#1, create_sensor_#in~sensor#1, create_sensor_#in~func#1 := ibmpex_find_sensors_~data#1.base, ibmpex_find_sensors_~data#1.offset, ibmpex_find_sensors_~sensor_type~0#1, ibmpex_find_sensors_~sensor_counter~0#1, ibmpex_find_sensors_~i~2#1, ibmpex_find_sensors_~j~0#1;havoc create_sensor_#res#1;havoc create_sensor_#t~ret134#1.base, create_sensor_#t~ret134#1.offset, create_sensor_#t~nondet135#1, create_sensor_#t~mem136#1.base, create_sensor_#t~mem136#1.offset, create_sensor_#t~nondet137#1, create_sensor_#t~mem138#1.base, create_sensor_#t~mem138#1.offset, create_sensor_#t~mem139#1.base, create_sensor_#t~mem139#1.offset, create_sensor_#t~mem140#1.base, create_sensor_#t~mem140#1.offset, create_sensor_#t~mem141#1.base, create_sensor_#t~mem141#1.offset, create_sensor_#t~mem142#1.base, create_sensor_#t~mem142#1.offset, create_sensor_#t~mem143#1.base, create_sensor_#t~mem143#1.offset, create_sensor_#t~mem144#1.base, create_sensor_#t~mem144#1.offset, create_sensor_#t~mem145#1.base, create_sensor_#t~mem145#1.offset, create_sensor_#t~ret146#1, create_sensor_#t~mem147#1.base, create_sensor_#t~mem147#1.offset, create_sensor_~data#1.base, create_sensor_~data#1.offset, create_sensor_~type#1, create_sensor_~counter#1, create_sensor_~sensor#1, create_sensor_~func#1, create_sensor_~err~2#1, create_sensor_~n~0#1.base, create_sensor_~n~0#1.offset, create_sensor_~tmp~12#1.base, create_sensor_~tmp~12#1.offset;create_sensor_~data#1.base, create_sensor_~data#1.offset := create_sensor_#in~data#1.base, create_sensor_#in~data#1.offset;create_sensor_~type#1 := create_sensor_#in~type#1;create_sensor_~counter#1 := create_sensor_#in~counter#1;create_sensor_~sensor#1 := create_sensor_#in~sensor#1;create_sensor_~func#1 := create_sensor_#in~func#1;havoc create_sensor_~err~2#1;havoc create_sensor_~n~0#1.base, create_sensor_~n~0#1.offset;havoc create_sensor_~tmp~12#1.base, create_sensor_~tmp~12#1.offset; {17750#false} is VALID [2022-02-20 21:35:42,646 INFO L272 TraceCheckUtils]: 150: Hoare triple {17750#false} call create_sensor_#t~ret134#1.base, create_sensor_#t~ret134#1.offset := kmalloc(32, 208); {17840#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:42,646 INFO L290 TraceCheckUtils]: 151: Hoare triple {17840#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {17749#true} is VALID [2022-02-20 21:35:42,646 INFO L272 TraceCheckUtils]: 152: Hoare triple {17749#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {17840#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:42,646 INFO L290 TraceCheckUtils]: 153: Hoare triple {17840#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {17749#true} is VALID [2022-02-20 21:35:42,647 INFO L290 TraceCheckUtils]: 154: Hoare triple {17749#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {17749#true} is VALID [2022-02-20 21:35:42,647 INFO L290 TraceCheckUtils]: 155: Hoare triple {17749#true} assume true; {17749#true} is VALID [2022-02-20 21:35:42,647 INFO L284 TraceCheckUtils]: 156: Hoare quadruple {17749#true} {17749#true} #590#return; {17749#true} is VALID [2022-02-20 21:35:42,647 INFO L290 TraceCheckUtils]: 157: Hoare triple {17749#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {17749#true} is VALID [2022-02-20 21:35:42,647 INFO L290 TraceCheckUtils]: 158: Hoare triple {17749#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {17749#true} is VALID [2022-02-20 21:35:42,648 INFO L290 TraceCheckUtils]: 159: Hoare triple {17749#true} assume true; {17749#true} is VALID [2022-02-20 21:35:42,648 INFO L284 TraceCheckUtils]: 160: Hoare quadruple {17749#true} {17750#false} #640#return; {17750#false} is VALID [2022-02-20 21:35:42,648 INFO L290 TraceCheckUtils]: 161: Hoare triple {17750#false} create_sensor_~tmp~12#1.base, create_sensor_~tmp~12#1.offset := create_sensor_#t~ret134#1.base, create_sensor_#t~ret134#1.offset;havoc create_sensor_#t~ret134#1.base, create_sensor_#t~ret134#1.offset;create_sensor_~n~0#1.base, create_sensor_~n~0#1.offset := create_sensor_~tmp~12#1.base, create_sensor_~tmp~12#1.offset; {17750#false} is VALID [2022-02-20 21:35:42,648 INFO L290 TraceCheckUtils]: 162: Hoare triple {17750#false} assume !(0 == (create_sensor_~n~0#1.base + create_sensor_~n~0#1.offset) % 18446744073709551616); {17750#false} is VALID [2022-02-20 21:35:42,648 INFO L290 TraceCheckUtils]: 163: Hoare triple {17750#false} assume 1 == create_sensor_~type#1;havoc create_sensor_#t~nondet135#1;call create_sensor_#t~mem136#1.base, create_sensor_#t~mem136#1.offset := read~$Pointer$(~#temp_sensor_name_templates~0.base, ~#temp_sensor_name_templates~0.offset + 8 * create_sensor_~func#1, 8);havoc create_sensor_#t~mem136#1.base, create_sensor_#t~mem136#1.offset; {17750#false} is VALID [2022-02-20 21:35:42,648 INFO L290 TraceCheckUtils]: 164: Hoare triple {17750#false} assume { :begin_inline_ldv_sysfs } true;~ldv_count_1~0 := 1 + ~ldv_count_1~0; {17750#false} is VALID [2022-02-20 21:35:42,650 INFO L290 TraceCheckUtils]: 165: Hoare triple {17750#false} assume { :end_inline_ldv_sysfs } true;call create_sensor_#t~mem139#1.base, create_sensor_#t~mem139#1.offset := read~$Pointer$(create_sensor_~data#1.base, 907 + create_sensor_~data#1.offset, 8);call write~$Pointer$(create_sensor_~n~0#1.base, create_sensor_~n~0#1.offset, create_sensor_#t~mem139#1.base, 14 + (create_sensor_#t~mem139#1.offset + 152 * (if create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 else create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616)) + 46 * create_sensor_~func#1, 8);havoc create_sensor_#t~mem139#1.base, create_sensor_#t~mem139#1.offset;call create_sensor_#t~mem140#1.base, create_sensor_#t~mem140#1.offset := read~$Pointer$(create_sensor_~data#1.base, 907 + create_sensor_~data#1.offset, 8);call write~int(292, create_sensor_#t~mem140#1.base, 8 + (14 + (create_sensor_#t~mem140#1.offset + 152 * (if create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 else create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616)) + 46 * create_sensor_~func#1), 4);havoc create_sensor_#t~mem140#1.base, create_sensor_#t~mem140#1.offset;call create_sensor_#t~mem141#1.base, create_sensor_#t~mem141#1.offset := read~$Pointer$(create_sensor_~data#1.base, 907 + create_sensor_~data#1.offset, 8);call write~$Pointer$(#funAddr~ibmpex_show_sensor.base, #funAddr~ibmpex_show_sensor.offset, create_sensor_#t~mem141#1.base, 28 + (14 + (create_sensor_#t~mem141#1.offset + 152 * (if create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 else create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616)) + 46 * create_sensor_~func#1), 8);havoc create_sensor_#t~mem141#1.base, create_sensor_#t~mem141#1.offset;call create_sensor_#t~mem142#1.base, create_sensor_#t~mem142#1.offset := read~$Pointer$(create_sensor_~data#1.base, 907 + create_sensor_~data#1.offset, 8);call write~int(create_sensor_~sensor#1, create_sensor_#t~mem142#1.base, 44 + (14 + (create_sensor_#t~mem142#1.offset + 152 * (if create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 else create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616)) + 46 * create_sensor_~func#1), 1);havoc create_sensor_#t~mem142#1.base, create_sensor_#t~mem142#1.offset;call create_sensor_#t~mem143#1.base, create_sensor_#t~mem143#1.offset := read~$Pointer$(create_sensor_~data#1.base, 907 + create_sensor_~data#1.offset, 8);call write~int(create_sensor_~func#1, create_sensor_#t~mem143#1.base, 45 + (14 + (create_sensor_#t~mem143#1.offset + 152 * (if create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 else create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616)) + 46 * create_sensor_~func#1), 1);havoc create_sensor_#t~mem143#1.base, create_sensor_#t~mem143#1.offset;call create_sensor_#t~mem144#1.base, create_sensor_#t~mem144#1.offset := read~$Pointer$(create_sensor_~data#1.base, 24 + create_sensor_~data#1.offset, 8);call create_sensor_#t~mem145#1.base, create_sensor_#t~mem145#1.offset := read~$Pointer$(create_sensor_~data#1.base, 907 + create_sensor_~data#1.offset, 8);assume { :begin_inline_ldv_device_create_file_5 } true;ldv_device_create_file_5_#in~ldv_func_arg1#1.base, ldv_device_create_file_5_#in~ldv_func_arg1#1.offset, ldv_device_create_file_5_#in~ldv_func_arg2#1.base, ldv_device_create_file_5_#in~ldv_func_arg2#1.offset := create_sensor_#t~mem144#1.base, create_sensor_#t~mem144#1.offset, create_sensor_#t~mem145#1.base, 14 + (create_sensor_#t~mem145#1.offset + 152 * (if create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 else create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616)) + 46 * create_sensor_~func#1;havoc ldv_device_create_file_5_#res#1;havoc ldv_device_create_file_5_#t~ret241#1, ldv_device_create_file_5_~ldv_func_arg1#1.base, ldv_device_create_file_5_~ldv_func_arg1#1.offset, ldv_device_create_file_5_~ldv_func_arg2#1.base, ldv_device_create_file_5_~ldv_func_arg2#1.offset, ldv_device_create_file_5_~tmp~19#1;ldv_device_create_file_5_~ldv_func_arg1#1.base, ldv_device_create_file_5_~ldv_func_arg1#1.offset := ldv_device_create_file_5_#in~ldv_func_arg1#1.base, ldv_device_create_file_5_#in~ldv_func_arg1#1.offset;ldv_device_create_file_5_~ldv_func_arg2#1.base, ldv_device_create_file_5_~ldv_func_arg2#1.offset := ldv_device_create_file_5_#in~ldv_func_arg2#1.base, ldv_device_create_file_5_#in~ldv_func_arg2#1.offset;havoc ldv_device_create_file_5_~tmp~19#1;assume { :begin_inline_ldv_device_create_file_dev_attr_of_sensor_device_attribute_2 } true;ldv_device_create_file_dev_attr_of_sensor_device_attribute_2_#in~attr#1.base, ldv_device_create_file_dev_attr_of_sensor_device_attribute_2_#in~attr#1.offset := ldv_device_create_file_5_~ldv_func_arg2#1.base, ldv_device_create_file_5_~ldv_func_arg2#1.offset;havoc ldv_device_create_file_dev_attr_of_sensor_device_attribute_2_#res#1;havoc ldv_device_create_file_dev_attr_of_sensor_device_attribute_2_~attr#1.base, ldv_device_create_file_dev_attr_of_sensor_device_attribute_2_~attr#1.offset;ldv_device_create_file_dev_attr_of_sensor_device_attribute_2_~attr#1.base, ldv_device_create_file_dev_attr_of_sensor_device_attribute_2_~attr#1.offset := ldv_device_create_file_dev_attr_of_sensor_device_attribute_2_#in~attr#1.base, ldv_device_create_file_dev_attr_of_sensor_device_attribute_2_#in~attr#1.offset; {17750#false} is VALID [2022-02-20 21:35:42,650 INFO L290 TraceCheckUtils]: 166: Hoare triple {17750#false} assume 0 == ~ldv_call_dev_attr_of_sensor_device_attribute_2~0;~ldv_count_2~0 := 1 + ~ldv_count_2~0;~ldv_call_dev_attr_of_sensor_device_attribute_2~0 := 1; {17750#false} is VALID [2022-02-20 21:35:42,650 INFO L290 TraceCheckUtils]: 167: Hoare triple {17750#false} assume ~ldv_count_1~0 >= ~ldv_count_2~0; {17750#false} is VALID [2022-02-20 21:35:42,650 INFO L290 TraceCheckUtils]: 168: Hoare triple {17750#false} ldv_device_create_file_dev_attr_of_sensor_device_attribute_2_#res#1 := 0; {17750#false} is VALID [2022-02-20 21:35:42,650 INFO L290 TraceCheckUtils]: 169: Hoare triple {17750#false} ldv_device_create_file_5_#t~ret241#1 := ldv_device_create_file_dev_attr_of_sensor_device_attribute_2_#res#1;assume { :end_inline_ldv_device_create_file_dev_attr_of_sensor_device_attribute_2 } true;assume -2147483648 <= ldv_device_create_file_5_#t~ret241#1 && ldv_device_create_file_5_#t~ret241#1 <= 2147483647;ldv_device_create_file_5_~tmp~19#1 := ldv_device_create_file_5_#t~ret241#1;havoc ldv_device_create_file_5_#t~ret241#1;ldv_device_create_file_5_#res#1 := ldv_device_create_file_5_~tmp~19#1; {17750#false} is VALID [2022-02-20 21:35:42,651 INFO L290 TraceCheckUtils]: 170: Hoare triple {17750#false} create_sensor_#t~ret146#1 := ldv_device_create_file_5_#res#1;assume { :end_inline_ldv_device_create_file_5 } true;assume -2147483648 <= create_sensor_#t~ret146#1 && create_sensor_#t~ret146#1 <= 2147483647;create_sensor_~err~2#1 := create_sensor_#t~ret146#1;havoc create_sensor_#t~mem144#1.base, create_sensor_#t~mem144#1.offset;havoc create_sensor_#t~mem145#1.base, create_sensor_#t~mem145#1.offset;havoc create_sensor_#t~ret146#1; {17750#false} is VALID [2022-02-20 21:35:42,651 INFO L290 TraceCheckUtils]: 171: Hoare triple {17750#false} assume !(0 != create_sensor_~err~2#1);create_sensor_#res#1 := 0; {17750#false} is VALID [2022-02-20 21:35:42,651 INFO L290 TraceCheckUtils]: 172: Hoare triple {17750#false} ibmpex_find_sensors_#t~ret162#1 := create_sensor_#res#1;assume { :end_inline_create_sensor } true;assume -2147483648 <= ibmpex_find_sensors_#t~ret162#1 && ibmpex_find_sensors_#t~ret162#1 <= 2147483647;ibmpex_find_sensors_~err~3#1 := ibmpex_find_sensors_#t~ret162#1;havoc ibmpex_find_sensors_#t~ret162#1; {17750#false} is VALID [2022-02-20 21:35:42,651 INFO L290 TraceCheckUtils]: 173: Hoare triple {17750#false} assume !(0 != ibmpex_find_sensors_~err~3#1);ibmpex_find_sensors_~j~0#1 := 1 + ibmpex_find_sensors_~j~0#1; {17750#false} is VALID [2022-02-20 21:35:42,651 INFO L290 TraceCheckUtils]: 174: Hoare triple {17750#false} assume !(ibmpex_find_sensors_~j~0#1 <= 2); {17750#false} is VALID [2022-02-20 21:35:42,651 INFO L290 TraceCheckUtils]: 175: Hoare triple {17750#false} ibmpex_find_sensors_~i~2#1 := 1 + ibmpex_find_sensors_~i~2#1; {17750#false} is VALID [2022-02-20 21:35:42,652 INFO L290 TraceCheckUtils]: 176: Hoare triple {17750#false} call ibmpex_find_sensors_#t~mem163#1 := read~int(ibmpex_find_sensors_~data#1.base, 906 + ibmpex_find_sensors_~data#1.offset, 1); {17750#false} is VALID [2022-02-20 21:35:42,652 INFO L290 TraceCheckUtils]: 177: Hoare triple {17750#false} assume !(ibmpex_find_sensors_#t~mem163#1 % 256 > ibmpex_find_sensors_~i~2#1);havoc ibmpex_find_sensors_#t~mem163#1;call ibmpex_find_sensors_#t~mem164#1.base, ibmpex_find_sensors_#t~mem164#1.offset := read~$Pointer$(ibmpex_find_sensors_~data#1.base, 24 + ibmpex_find_sensors_~data#1.offset, 8);assume { :begin_inline_ldv_device_create_file_6 } true;ldv_device_create_file_6_#in~ldv_func_arg1#1.base, ldv_device_create_file_6_#in~ldv_func_arg1#1.offset, ldv_device_create_file_6_#in~ldv_func_arg2#1.base, ldv_device_create_file_6_#in~ldv_func_arg2#1.offset := ibmpex_find_sensors_#t~mem164#1.base, ibmpex_find_sensors_#t~mem164#1.offset, ~#sensor_dev_attr_reset_high_low~0.base, ~#sensor_dev_attr_reset_high_low~0.offset;havoc ldv_device_create_file_6_#res#1;havoc ldv_device_create_file_6_#t~ret242#1, ldv_device_create_file_6_~ldv_func_arg1#1.base, ldv_device_create_file_6_~ldv_func_arg1#1.offset, ldv_device_create_file_6_~ldv_func_arg2#1.base, ldv_device_create_file_6_~ldv_func_arg2#1.offset, ldv_device_create_file_6_~tmp~20#1;ldv_device_create_file_6_~ldv_func_arg1#1.base, ldv_device_create_file_6_~ldv_func_arg1#1.offset := ldv_device_create_file_6_#in~ldv_func_arg1#1.base, ldv_device_create_file_6_#in~ldv_func_arg1#1.offset;ldv_device_create_file_6_~ldv_func_arg2#1.base, ldv_device_create_file_6_~ldv_func_arg2#1.offset := ldv_device_create_file_6_#in~ldv_func_arg2#1.base, ldv_device_create_file_6_#in~ldv_func_arg2#1.offset;havoc ldv_device_create_file_6_~tmp~20#1; {17750#false} is VALID [2022-02-20 21:35:42,652 INFO L272 TraceCheckUtils]: 178: Hoare triple {17750#false} call ldv_device_create_file_6_#t~ret242#1 := ldv_device_create_file_dev_attr_of_sensor_device_attribute(ldv_device_create_file_6_~ldv_func_arg2#1.base, ldv_device_create_file_6_~ldv_func_arg2#1.offset); {17750#false} is VALID [2022-02-20 21:35:42,652 INFO L290 TraceCheckUtils]: 179: Hoare triple {17750#false} ~attr.base, ~attr.offset := #in~attr.base, #in~attr.offset; {17750#false} is VALID [2022-02-20 21:35:42,652 INFO L290 TraceCheckUtils]: 180: Hoare triple {17750#false} assume 0 == ~ldv_call_dev_attr_of_sensor_device_attribute~0;~ldv_count_2~0 := 1 + ~ldv_count_2~0;~ldv_call_dev_attr_of_sensor_device_attribute~0 := 1; {17750#false} is VALID [2022-02-20 21:35:42,653 INFO L290 TraceCheckUtils]: 181: Hoare triple {17750#false} assume !(~ldv_count_1~0 >= ~ldv_count_2~0); {17750#false} is VALID [2022-02-20 21:35:42,653 INFO L272 TraceCheckUtils]: 182: Hoare triple {17750#false} call ldv_error(); {17750#false} is VALID [2022-02-20 21:35:42,653 INFO L290 TraceCheckUtils]: 183: Hoare triple {17750#false} assume !false; {17750#false} is VALID [2022-02-20 21:35:42,654 INFO L134 CoverageAnalysis]: Checked inductivity of 79 backedges. 2 proven. 0 refuted. 0 times theorem prover too weak. 77 trivial. 0 not checked. [2022-02-20 21:35:42,654 INFO L144 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-02-20 21:35:42,654 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [1685417656] [2022-02-20 21:35:42,654 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleSmtInterpolCraig [1685417656] provided 1 perfect and 0 imperfect interpolant sequences [2022-02-20 21:35:42,654 INFO L191 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-02-20 21:35:42,654 INFO L204 FreeRefinementEngine]: Number of different interpolants: perfect sequences [6] imperfect sequences [] total 6 [2022-02-20 21:35:42,655 INFO L118 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [1086934344] [2022-02-20 21:35:42,655 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-02-20 21:35:42,656 INFO L78 Accepts]: Start accepts. Automaton has has 6 states, 6 states have (on average 17.833333333333332) internal successors, (107), 4 states have internal predecessors, (107), 2 states have call successors, (19), 4 states have call predecessors, (19), 1 states have return successors, (17), 2 states have call predecessors, (17), 2 states have call successors, (17) Word has length 184 [2022-02-20 21:35:42,656 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-02-20 21:35:42,656 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with has 6 states, 6 states have (on average 17.833333333333332) internal successors, (107), 4 states have internal predecessors, (107), 2 states have call successors, (19), 4 states have call predecessors, (19), 1 states have return successors, (17), 2 states have call predecessors, (17), 2 states have call successors, (17) [2022-02-20 21:35:42,781 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 143 edges. 143 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 21:35:42,781 INFO L546 AbstractCegarLoop]: INTERPOLANT automaton has 6 states [2022-02-20 21:35:42,781 INFO L108 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2022-02-20 21:35:42,782 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 6 interpolants. [2022-02-20 21:35:42,782 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=9, Invalid=21, Unknown=0, NotChecked=0, Total=30 [2022-02-20 21:35:42,782 INFO L87 Difference]: Start difference. First operand 1025 states and 1354 transitions. Second operand has 6 states, 6 states have (on average 17.833333333333332) internal successors, (107), 4 states have internal predecessors, (107), 2 states have call successors, (19), 4 states have call predecessors, (19), 1 states have return successors, (17), 2 states have call predecessors, (17), 2 states have call successors, (17) [2022-02-20 21:35:47,088 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 21:35:47,088 INFO L93 Difference]: Finished difference Result 2698 states and 3689 transitions. [2022-02-20 21:35:47,088 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 8 states. [2022-02-20 21:35:47,089 INFO L78 Accepts]: Start accepts. Automaton has has 6 states, 6 states have (on average 17.833333333333332) internal successors, (107), 4 states have internal predecessors, (107), 2 states have call successors, (19), 4 states have call predecessors, (19), 1 states have return successors, (17), 2 states have call predecessors, (17), 2 states have call successors, (17) Word has length 184 [2022-02-20 21:35:47,089 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-02-20 21:35:47,090 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 6 states, 6 states have (on average 17.833333333333332) internal successors, (107), 4 states have internal predecessors, (107), 2 states have call successors, (19), 4 states have call predecessors, (19), 1 states have return successors, (17), 2 states have call predecessors, (17), 2 states have call successors, (17) [2022-02-20 21:35:47,101 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 8 states to 8 states and 920 transitions. [2022-02-20 21:35:47,102 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 6 states, 6 states have (on average 17.833333333333332) internal successors, (107), 4 states have internal predecessors, (107), 2 states have call successors, (19), 4 states have call predecessors, (19), 1 states have return successors, (17), 2 states have call predecessors, (17), 2 states have call successors, (17) [2022-02-20 21:35:47,112 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 8 states to 8 states and 920 transitions. [2022-02-20 21:35:47,113 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with 8 states and 920 transitions. [2022-02-20 21:35:47,808 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 920 edges. 920 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 21:35:47,985 INFO L225 Difference]: With dead ends: 2698 [2022-02-20 21:35:47,985 INFO L226 Difference]: Without dead ends: 1681 [2022-02-20 21:35:47,987 INFO L932 BasicCegarLoop]: 0 DeclaredPredicates, 48 GetRequests, 42 SyntacticMatches, 0 SemanticMatches, 6 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 1 ImplicationChecksByTransitivity, 0.0s TimeCoverageRelationStatistics Valid=17, Invalid=39, Unknown=0, NotChecked=0, Total=56 [2022-02-20 21:35:47,988 INFO L933 BasicCegarLoop]: 497 mSDtfsCounter, 291 mSDsluCounter, 1065 mSDsCounter, 0 mSdLazyCounter, 661 mSolverCounterSat, 119 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.9s Time, 0 mProtectedPredicate, 0 mProtectedAction, 333 SdHoareTripleChecker+Valid, 1562 SdHoareTripleChecker+Invalid, 780 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 119 IncrementalHoareTripleChecker+Valid, 661 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.9s IncrementalHoareTripleChecker+Time [2022-02-20 21:35:47,988 INFO L934 BasicCegarLoop]: SdHoareTripleChecker [333 Valid, 1562 Invalid, 780 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [119 Valid, 661 Invalid, 0 Unknown, 0 Unchecked, 0.9s Time] [2022-02-20 21:35:47,990 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 1681 states. [2022-02-20 21:35:48,441 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 1681 to 1033. [2022-02-20 21:35:48,442 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-02-20 21:35:48,445 INFO L82 GeneralOperation]: Start isEquivalent. First operand 1681 states. Second operand has 1033 states, 797 states have (on average 1.2772898368883312) internal successors, (1018), 806 states have internal predecessors, (1018), 171 states have call successors, (171), 65 states have call predecessors, (171), 64 states have return successors, (173), 169 states have call predecessors, (173), 169 states have call successors, (173) [2022-02-20 21:35:48,461 INFO L74 IsIncluded]: Start isIncluded. First operand 1681 states. Second operand has 1033 states, 797 states have (on average 1.2772898368883312) internal successors, (1018), 806 states have internal predecessors, (1018), 171 states have call successors, (171), 65 states have call predecessors, (171), 64 states have return successors, (173), 169 states have call predecessors, (173), 169 states have call successors, (173) [2022-02-20 21:35:48,464 INFO L87 Difference]: Start difference. First operand 1681 states. Second operand has 1033 states, 797 states have (on average 1.2772898368883312) internal successors, (1018), 806 states have internal predecessors, (1018), 171 states have call successors, (171), 65 states have call predecessors, (171), 64 states have return successors, (173), 169 states have call predecessors, (173), 169 states have call successors, (173) [2022-02-20 21:35:48,609 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 21:35:48,610 INFO L93 Difference]: Finished difference Result 1681 states and 2340 transitions. [2022-02-20 21:35:48,610 INFO L276 IsEmpty]: Start isEmpty. Operand 1681 states and 2340 transitions. [2022-02-20 21:35:48,615 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 21:35:48,615 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 21:35:48,619 INFO L74 IsIncluded]: Start isIncluded. First operand has 1033 states, 797 states have (on average 1.2772898368883312) internal successors, (1018), 806 states have internal predecessors, (1018), 171 states have call successors, (171), 65 states have call predecessors, (171), 64 states have return successors, (173), 169 states have call predecessors, (173), 169 states have call successors, (173) Second operand 1681 states. [2022-02-20 21:35:48,621 INFO L87 Difference]: Start difference. First operand has 1033 states, 797 states have (on average 1.2772898368883312) internal successors, (1018), 806 states have internal predecessors, (1018), 171 states have call successors, (171), 65 states have call predecessors, (171), 64 states have return successors, (173), 169 states have call predecessors, (173), 169 states have call successors, (173) Second operand 1681 states. [2022-02-20 21:35:48,766 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 21:35:48,766 INFO L93 Difference]: Finished difference Result 1681 states and 2340 transitions. [2022-02-20 21:35:48,767 INFO L276 IsEmpty]: Start isEmpty. Operand 1681 states and 2340 transitions. [2022-02-20 21:35:48,772 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 21:35:48,772 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 21:35:48,772 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-02-20 21:35:48,773 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-02-20 21:35:48,775 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 1033 states, 797 states have (on average 1.2772898368883312) internal successors, (1018), 806 states have internal predecessors, (1018), 171 states have call successors, (171), 65 states have call predecessors, (171), 64 states have return successors, (173), 169 states have call predecessors, (173), 169 states have call successors, (173) [2022-02-20 21:35:48,849 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 1033 states to 1033 states and 1362 transitions. [2022-02-20 21:35:48,850 INFO L78 Accepts]: Start accepts. Automaton has 1033 states and 1362 transitions. Word has length 184 [2022-02-20 21:35:48,851 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-02-20 21:35:48,851 INFO L470 AbstractCegarLoop]: Abstraction has 1033 states and 1362 transitions. [2022-02-20 21:35:48,851 INFO L471 AbstractCegarLoop]: INTERPOLANT automaton has has 6 states, 6 states have (on average 17.833333333333332) internal successors, (107), 4 states have internal predecessors, (107), 2 states have call successors, (19), 4 states have call predecessors, (19), 1 states have return successors, (17), 2 states have call predecessors, (17), 2 states have call successors, (17) [2022-02-20 21:35:48,851 INFO L276 IsEmpty]: Start isEmpty. Operand 1033 states and 1362 transitions. [2022-02-20 21:35:48,854 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 185 [2022-02-20 21:35:48,854 INFO L506 BasicCegarLoop]: Found error trace [2022-02-20 21:35:48,854 INFO L514 BasicCegarLoop]: trace histogram [4, 4, 4, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 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, 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:35:48,854 WARN L452 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable5 [2022-02-20 21:35:48,855 INFO L402 AbstractCegarLoop]: === Iteration 7 === Targeting ldv_errorErr0ASSERT_VIOLATIONERROR_FUNCTION === [ldv_errorErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-02-20 21:35:48,855 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-02-20 21:35:48,855 INFO L85 PathProgramCache]: Analyzing trace with hash -1580348874, now seen corresponding path program 1 times [2022-02-20 21:35:48,855 INFO L126 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-02-20 21:35:48,856 INFO L338 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [365134850] [2022-02-20 21:35:48,856 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 21:35:48,856 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-02-20 21:35:48,957 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:49,010 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 3 [2022-02-20 21:35:49,012 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:49,014 INFO L290 TraceCheckUtils]: 0: Hoare triple {26788#true} assume true; {26788#true} is VALID [2022-02-20 21:35:49,014 INFO L284 TraceCheckUtils]: 1: Hoare quadruple {26788#true} {26788#true} #612#return; {26788#true} is VALID [2022-02-20 21:35:49,014 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 14 [2022-02-20 21:35:49,015 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:49,017 INFO L290 TraceCheckUtils]: 0: Hoare triple {26788#true} assume true; {26788#true} is VALID [2022-02-20 21:35:49,018 INFO L284 TraceCheckUtils]: 1: Hoare quadruple {26788#true} {26788#true} #614#return; {26788#true} is VALID [2022-02-20 21:35:49,021 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 18 [2022-02-20 21:35:49,023 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:49,027 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:35:49,029 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:49,035 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:35:49,053 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:49,056 INFO L290 TraceCheckUtils]: 0: Hoare triple {26878#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {26788#true} is VALID [2022-02-20 21:35:49,056 INFO L290 TraceCheckUtils]: 1: Hoare triple {26788#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {26788#true} is VALID [2022-02-20 21:35:49,056 INFO L290 TraceCheckUtils]: 2: Hoare triple {26788#true} assume true; {26788#true} is VALID [2022-02-20 21:35:49,057 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {26788#true} {26788#true} #590#return; {26788#true} is VALID [2022-02-20 21:35:49,057 INFO L290 TraceCheckUtils]: 0: Hoare triple {26878#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {26788#true} is VALID [2022-02-20 21:35:49,057 INFO L272 TraceCheckUtils]: 1: Hoare triple {26788#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {26878#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:49,058 INFO L290 TraceCheckUtils]: 2: Hoare triple {26878#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {26788#true} is VALID [2022-02-20 21:35:49,058 INFO L290 TraceCheckUtils]: 3: Hoare triple {26788#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {26788#true} is VALID [2022-02-20 21:35:49,058 INFO L290 TraceCheckUtils]: 4: Hoare triple {26788#true} assume true; {26788#true} is VALID [2022-02-20 21:35:49,058 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {26788#true} {26788#true} #590#return; {26788#true} is VALID [2022-02-20 21:35:49,058 INFO L290 TraceCheckUtils]: 6: Hoare triple {26788#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {26788#true} is VALID [2022-02-20 21:35:49,058 INFO L290 TraceCheckUtils]: 7: Hoare triple {26788#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {26788#true} is VALID [2022-02-20 21:35:49,059 INFO L290 TraceCheckUtils]: 8: Hoare triple {26788#true} assume true; {26788#true} is VALID [2022-02-20 21:35:49,059 INFO L284 TraceCheckUtils]: 9: Hoare quadruple {26788#true} {26788#true} #588#return; {26788#true} is VALID [2022-02-20 21:35:49,059 INFO L290 TraceCheckUtils]: 0: Hoare triple {26878#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size;~flags := #in~flags;havoc ~tmp~2.base, ~tmp~2.offset; {26788#true} is VALID [2022-02-20 21:35:49,060 INFO L272 TraceCheckUtils]: 1: Hoare triple {26788#true} call #t~ret40.base, #t~ret40.offset := kmalloc(~size, ~bitwiseOr(~flags, 32768)); {26878#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:49,060 INFO L290 TraceCheckUtils]: 2: Hoare triple {26878#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {26788#true} is VALID [2022-02-20 21:35:49,060 INFO L272 TraceCheckUtils]: 3: Hoare triple {26788#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {26878#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:49,061 INFO L290 TraceCheckUtils]: 4: Hoare triple {26878#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {26788#true} is VALID [2022-02-20 21:35:49,061 INFO L290 TraceCheckUtils]: 5: Hoare triple {26788#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {26788#true} is VALID [2022-02-20 21:35:49,061 INFO L290 TraceCheckUtils]: 6: Hoare triple {26788#true} assume true; {26788#true} is VALID [2022-02-20 21:35:49,061 INFO L284 TraceCheckUtils]: 7: Hoare quadruple {26788#true} {26788#true} #590#return; {26788#true} is VALID [2022-02-20 21:35:49,061 INFO L290 TraceCheckUtils]: 8: Hoare triple {26788#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {26788#true} is VALID [2022-02-20 21:35:49,062 INFO L290 TraceCheckUtils]: 9: Hoare triple {26788#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {26788#true} is VALID [2022-02-20 21:35:49,062 INFO L290 TraceCheckUtils]: 10: Hoare triple {26788#true} assume true; {26788#true} is VALID [2022-02-20 21:35:49,062 INFO L284 TraceCheckUtils]: 11: Hoare quadruple {26788#true} {26788#true} #588#return; {26788#true} is VALID [2022-02-20 21:35:49,062 INFO L290 TraceCheckUtils]: 12: Hoare triple {26788#true} ~tmp~2.base, ~tmp~2.offset := #t~ret40.base, #t~ret40.offset;havoc #t~ret40.base, #t~ret40.offset;#res.base, #res.offset := ~tmp~2.base, ~tmp~2.offset; {26788#true} is VALID [2022-02-20 21:35:49,062 INFO L290 TraceCheckUtils]: 13: Hoare triple {26788#true} assume true; {26788#true} is VALID [2022-02-20 21:35:49,062 INFO L284 TraceCheckUtils]: 14: Hoare quadruple {26788#true} {26788#true} #616#return; {26788#true} is VALID [2022-02-20 21:35:49,068 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 41 [2022-02-20 21:35:49,070 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:49,077 INFO L290 TraceCheckUtils]: 0: Hoare triple {26893#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;havoc ~err~0#1;assume { :begin_inline_ipmi_validate_addr } true;ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset, ipmi_validate_addr_#in~arg1#1 := ~data#1.base, 193 + ~data#1.offset, 40;havoc ipmi_validate_addr_#res#1;havoc ipmi_validate_addr_#t~nondet254#1, ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset, ipmi_validate_addr_~arg1#1;ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset := ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset;ipmi_validate_addr_~arg1#1 := ipmi_validate_addr_#in~arg1#1;assume -2147483648 <= ipmi_validate_addr_#t~nondet254#1 && ipmi_validate_addr_#t~nondet254#1 <= 2147483647;ipmi_validate_addr_#res#1 := ipmi_validate_addr_#t~nondet254#1;havoc ipmi_validate_addr_#t~nondet254#1; {26788#true} is VALID [2022-02-20 21:35:49,077 INFO L290 TraceCheckUtils]: 1: Hoare triple {26788#true} #t~ret62#1 := ipmi_validate_addr_#res#1;assume { :end_inline_ipmi_validate_addr } true;assume -2147483648 <= #t~ret62#1 && #t~ret62#1 <= 2147483647;~err~0#1 := #t~ret62#1;havoc #t~ret62#1; {26788#true} is VALID [2022-02-20 21:35:49,077 INFO L290 TraceCheckUtils]: 2: Hoare triple {26788#true} assume 0 != ~err~0#1; {26788#true} is VALID [2022-02-20 21:35:49,077 INFO L290 TraceCheckUtils]: 3: Hoare triple {26788#true} havoc #t~nondet69#1;call #t~mem70#1.base, #t~mem70#1.offset := read~$Pointer$(~data#1.base, 24 + ~data#1.offset, 8);havoc #t~mem70#1.base, #t~mem70#1.offset;#res#1 := ~err~0#1; {26788#true} is VALID [2022-02-20 21:35:49,077 INFO L290 TraceCheckUtils]: 4: Hoare triple {26788#true} assume true; {26788#true} is VALID [2022-02-20 21:35:49,078 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {26788#true} {26788#true} #618#return; {26788#true} is VALID [2022-02-20 21:35:49,078 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 49 [2022-02-20 21:35:49,086 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:49,089 INFO L290 TraceCheckUtils]: 0: Hoare triple {26788#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset; {26788#true} is VALID [2022-02-20 21:35:49,089 INFO L290 TraceCheckUtils]: 1: Hoare triple {26788#true} assume true; {26788#true} is VALID [2022-02-20 21:35:49,089 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {26788#true} {26788#true} #620#return; {26788#true} is VALID [2022-02-20 21:35:49,090 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 56 [2022-02-20 21:35:49,096 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:49,100 INFO L290 TraceCheckUtils]: 0: Hoare triple {26788#true} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;~offset#1 := #in~offset#1;havoc ~tmp~3#1;assume { :begin_inline___be16_to_cpup } true;__be16_to_cpup_#in~p#1.base, __be16_to_cpup_#in~p#1.offset := ~data#1.base, ~data#1.offset + 2 * (if ~offset#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then ~offset#1 % 18446744073709551616 % 18446744073709551616 else ~offset#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616);havoc __be16_to_cpup_#res#1;havoc __be16_to_cpup_#t~ret3#1, __be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset, __be16_to_cpup_~tmp~1#1;__be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset := __be16_to_cpup_#in~p#1.base, __be16_to_cpup_#in~p#1.offset;havoc __be16_to_cpup_~tmp~1#1;assume { :begin_inline___swab16p } true;__swab16p_#in~p#1.base, __swab16p_#in~p#1.offset := __be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset;havoc __swab16p_#res#1;havoc __swab16p_#t~mem1#1, __swab16p_#t~ret2#1, __swab16p_~p#1.base, __swab16p_~p#1.offset, __swab16p_~tmp~0#1;__swab16p_~p#1.base, __swab16p_~p#1.offset := __swab16p_#in~p#1.base, __swab16p_#in~p#1.offset;havoc __swab16p_~tmp~0#1;call __swab16p_#t~mem1#1 := read~int(__swab16p_~p#1.base, __swab16p_~p#1.offset, 2);assume { :begin_inline___fswab16 } true;__fswab16_#in~val#1 := __swab16p_#t~mem1#1 % 65536;havoc __fswab16_#res#1;havoc __fswab16_~val#1;__fswab16_~val#1 := __fswab16_#in~val#1;__fswab16_#res#1 := (if (1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) || 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536)) && 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) then (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) else (if 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) && (1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) || 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536)) then (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) else (if (1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) && (1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) || 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536))) || ((1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) || 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536)) && 1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536)) then 1 else ~bitwiseOr((if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536), (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536))))); {26788#true} is VALID [2022-02-20 21:35:49,100 INFO L290 TraceCheckUtils]: 1: Hoare triple {26788#true} __swab16p_#t~ret2#1 := __fswab16_#res#1;assume { :end_inline___fswab16 } true;__swab16p_~tmp~0#1 := __swab16p_#t~ret2#1;havoc __swab16p_#t~mem1#1;havoc __swab16p_#t~ret2#1;__swab16p_#res#1 := __swab16p_~tmp~0#1; {26788#true} is VALID [2022-02-20 21:35:49,100 INFO L290 TraceCheckUtils]: 2: Hoare triple {26788#true} __be16_to_cpup_#t~ret3#1 := __swab16p_#res#1;assume { :end_inline___swab16p } true;__be16_to_cpup_~tmp~1#1 := __be16_to_cpup_#t~ret3#1;havoc __be16_to_cpup_#t~ret3#1;__be16_to_cpup_#res#1 := __be16_to_cpup_~tmp~1#1; {26788#true} is VALID [2022-02-20 21:35:49,100 INFO L290 TraceCheckUtils]: 3: Hoare triple {26788#true} #t~ret61#1 := __be16_to_cpup_#res#1;assume { :end_inline___be16_to_cpup } true;~tmp~3#1 := #t~ret61#1;havoc #t~ret61#1;#res#1 := ~tmp~3#1; {26788#true} is VALID [2022-02-20 21:35:49,101 INFO L290 TraceCheckUtils]: 4: Hoare triple {26788#true} assume true; {26788#true} is VALID [2022-02-20 21:35:49,101 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {26788#true} {26788#true} #622#return; {26788#true} is VALID [2022-02-20 21:35:49,101 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 66 [2022-02-20 21:35:49,102 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:49,105 INFO L290 TraceCheckUtils]: 0: Hoare triple {26878#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {26788#true} is VALID [2022-02-20 21:35:49,105 INFO L290 TraceCheckUtils]: 1: Hoare triple {26788#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {26788#true} is VALID [2022-02-20 21:35:49,105 INFO L290 TraceCheckUtils]: 2: Hoare triple {26788#true} assume true; {26788#true} is VALID [2022-02-20 21:35:49,105 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {26788#true} {26788#true} #624#return; {26788#true} is VALID [2022-02-20 21:35:49,105 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 73 [2022-02-20 21:35:49,107 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:49,110 INFO L290 TraceCheckUtils]: 0: Hoare triple {26788#true} ~ptr.base, ~ptr.offset := #in~ptr.base, #in~ptr.offset;#res := (if (~ptr.base + ~ptr.offset) % 18446744073709551616 > 2012 then 1 else 0); {26788#true} is VALID [2022-02-20 21:35:49,110 INFO L290 TraceCheckUtils]: 1: Hoare triple {26788#true} assume true; {26788#true} is VALID [2022-02-20 21:35:49,110 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {26788#true} {26788#true} #626#return; {26788#true} is VALID [2022-02-20 21:35:49,110 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 80 [2022-02-20 21:35:49,111 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:49,113 INFO L290 TraceCheckUtils]: 0: Hoare triple {26788#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset;~arg1.base, ~arg1.offset := #in~arg1.base, #in~arg1.offset; {26788#true} is VALID [2022-02-20 21:35:49,113 INFO L290 TraceCheckUtils]: 1: Hoare triple {26788#true} assume true; {26788#true} is VALID [2022-02-20 21:35:49,113 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {26788#true} {26788#true} #628#return; {26788#true} is VALID [2022-02-20 21:35:49,114 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 87 [2022-02-20 21:35:49,115 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:49,118 INFO L290 TraceCheckUtils]: 0: Hoare triple {26893#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;havoc ~err~0#1;assume { :begin_inline_ipmi_validate_addr } true;ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset, ipmi_validate_addr_#in~arg1#1 := ~data#1.base, 193 + ~data#1.offset, 40;havoc ipmi_validate_addr_#res#1;havoc ipmi_validate_addr_#t~nondet254#1, ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset, ipmi_validate_addr_~arg1#1;ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset := ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset;ipmi_validate_addr_~arg1#1 := ipmi_validate_addr_#in~arg1#1;assume -2147483648 <= ipmi_validate_addr_#t~nondet254#1 && ipmi_validate_addr_#t~nondet254#1 <= 2147483647;ipmi_validate_addr_#res#1 := ipmi_validate_addr_#t~nondet254#1;havoc ipmi_validate_addr_#t~nondet254#1; {26788#true} is VALID [2022-02-20 21:35:49,118 INFO L290 TraceCheckUtils]: 1: Hoare triple {26788#true} #t~ret62#1 := ipmi_validate_addr_#res#1;assume { :end_inline_ipmi_validate_addr } true;assume -2147483648 <= #t~ret62#1 && #t~ret62#1 <= 2147483647;~err~0#1 := #t~ret62#1;havoc #t~ret62#1; {26788#true} is VALID [2022-02-20 21:35:49,118 INFO L290 TraceCheckUtils]: 2: Hoare triple {26788#true} assume 0 != ~err~0#1; {26788#true} is VALID [2022-02-20 21:35:49,119 INFO L290 TraceCheckUtils]: 3: Hoare triple {26788#true} havoc #t~nondet69#1;call #t~mem70#1.base, #t~mem70#1.offset := read~$Pointer$(~data#1.base, 24 + ~data#1.offset, 8);havoc #t~mem70#1.base, #t~mem70#1.offset;#res#1 := ~err~0#1; {26788#true} is VALID [2022-02-20 21:35:49,119 INFO L290 TraceCheckUtils]: 4: Hoare triple {26788#true} assume true; {26788#true} is VALID [2022-02-20 21:35:49,119 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {26788#true} {26788#true} #630#return; {26788#true} is VALID [2022-02-20 21:35:49,119 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 95 [2022-02-20 21:35:49,120 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:49,122 INFO L290 TraceCheckUtils]: 0: Hoare triple {26788#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset; {26788#true} is VALID [2022-02-20 21:35:49,122 INFO L290 TraceCheckUtils]: 1: Hoare triple {26788#true} assume true; {26788#true} is VALID [2022-02-20 21:35:49,122 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {26788#true} {26788#true} #632#return; {26788#true} is VALID [2022-02-20 21:35:49,122 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 104 [2022-02-20 21:35:49,124 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:49,135 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:35:49,136 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:49,139 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:35:49,141 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:49,144 INFO L290 TraceCheckUtils]: 0: Hoare triple {26878#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {26788#true} is VALID [2022-02-20 21:35:49,144 INFO L290 TraceCheckUtils]: 1: Hoare triple {26788#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {26788#true} is VALID [2022-02-20 21:35:49,144 INFO L290 TraceCheckUtils]: 2: Hoare triple {26788#true} assume true; {26788#true} is VALID [2022-02-20 21:35:49,144 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {26788#true} {26788#true} #590#return; {26788#true} is VALID [2022-02-20 21:35:49,145 INFO L290 TraceCheckUtils]: 0: Hoare triple {26878#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {26788#true} is VALID [2022-02-20 21:35:49,145 INFO L272 TraceCheckUtils]: 1: Hoare triple {26788#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {26878#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:49,146 INFO L290 TraceCheckUtils]: 2: Hoare triple {26878#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {26788#true} is VALID [2022-02-20 21:35:49,146 INFO L290 TraceCheckUtils]: 3: Hoare triple {26788#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {26788#true} is VALID [2022-02-20 21:35:49,146 INFO L290 TraceCheckUtils]: 4: Hoare triple {26788#true} assume true; {26788#true} is VALID [2022-02-20 21:35:49,146 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {26788#true} {26788#true} #590#return; {26788#true} is VALID [2022-02-20 21:35:49,146 INFO L290 TraceCheckUtils]: 6: Hoare triple {26788#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {26788#true} is VALID [2022-02-20 21:35:49,146 INFO L290 TraceCheckUtils]: 7: Hoare triple {26788#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {26788#true} is VALID [2022-02-20 21:35:49,147 INFO L290 TraceCheckUtils]: 8: Hoare triple {26788#true} assume true; {26788#true} is VALID [2022-02-20 21:35:49,147 INFO L284 TraceCheckUtils]: 9: Hoare quadruple {26788#true} {26788#true} #588#return; {26788#true} is VALID [2022-02-20 21:35:49,147 INFO L290 TraceCheckUtils]: 0: Hoare triple {26878#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size;~flags := #in~flags;havoc ~tmp~2.base, ~tmp~2.offset; {26788#true} is VALID [2022-02-20 21:35:49,148 INFO L272 TraceCheckUtils]: 1: Hoare triple {26788#true} call #t~ret40.base, #t~ret40.offset := kmalloc(~size, ~bitwiseOr(~flags, 32768)); {26878#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:49,148 INFO L290 TraceCheckUtils]: 2: Hoare triple {26878#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {26788#true} is VALID [2022-02-20 21:35:49,148 INFO L272 TraceCheckUtils]: 3: Hoare triple {26788#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {26878#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:49,149 INFO L290 TraceCheckUtils]: 4: Hoare triple {26878#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {26788#true} is VALID [2022-02-20 21:35:49,149 INFO L290 TraceCheckUtils]: 5: Hoare triple {26788#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {26788#true} is VALID [2022-02-20 21:35:49,149 INFO L290 TraceCheckUtils]: 6: Hoare triple {26788#true} assume true; {26788#true} is VALID [2022-02-20 21:35:49,149 INFO L284 TraceCheckUtils]: 7: Hoare quadruple {26788#true} {26788#true} #590#return; {26788#true} is VALID [2022-02-20 21:35:49,149 INFO L290 TraceCheckUtils]: 8: Hoare triple {26788#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {26788#true} is VALID [2022-02-20 21:35:49,149 INFO L290 TraceCheckUtils]: 9: Hoare triple {26788#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {26788#true} is VALID [2022-02-20 21:35:49,150 INFO L290 TraceCheckUtils]: 10: Hoare triple {26788#true} assume true; {26788#true} is VALID [2022-02-20 21:35:49,150 INFO L284 TraceCheckUtils]: 11: Hoare quadruple {26788#true} {26788#true} #588#return; {26788#true} is VALID [2022-02-20 21:35:49,150 INFO L290 TraceCheckUtils]: 12: Hoare triple {26788#true} ~tmp~2.base, ~tmp~2.offset := #t~ret40.base, #t~ret40.offset;havoc #t~ret40.base, #t~ret40.offset;#res.base, #res.offset := ~tmp~2.base, ~tmp~2.offset; {26788#true} is VALID [2022-02-20 21:35:49,150 INFO L290 TraceCheckUtils]: 13: Hoare triple {26788#true} assume true; {26788#true} is VALID [2022-02-20 21:35:49,150 INFO L284 TraceCheckUtils]: 14: Hoare quadruple {26788#true} {26788#true} #634#return; {26788#true} is VALID [2022-02-20 21:35:49,151 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 125 [2022-02-20 21:35:49,153 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:49,155 INFO L290 TraceCheckUtils]: 0: Hoare triple {26893#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;havoc ~err~0#1;assume { :begin_inline_ipmi_validate_addr } true;ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset, ipmi_validate_addr_#in~arg1#1 := ~data#1.base, 193 + ~data#1.offset, 40;havoc ipmi_validate_addr_#res#1;havoc ipmi_validate_addr_#t~nondet254#1, ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset, ipmi_validate_addr_~arg1#1;ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset := ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset;ipmi_validate_addr_~arg1#1 := ipmi_validate_addr_#in~arg1#1;assume -2147483648 <= ipmi_validate_addr_#t~nondet254#1 && ipmi_validate_addr_#t~nondet254#1 <= 2147483647;ipmi_validate_addr_#res#1 := ipmi_validate_addr_#t~nondet254#1;havoc ipmi_validate_addr_#t~nondet254#1; {26788#true} is VALID [2022-02-20 21:35:49,155 INFO L290 TraceCheckUtils]: 1: Hoare triple {26788#true} #t~ret62#1 := ipmi_validate_addr_#res#1;assume { :end_inline_ipmi_validate_addr } true;assume -2147483648 <= #t~ret62#1 && #t~ret62#1 <= 2147483647;~err~0#1 := #t~ret62#1;havoc #t~ret62#1; {26788#true} is VALID [2022-02-20 21:35:49,156 INFO L290 TraceCheckUtils]: 2: Hoare triple {26788#true} assume 0 != ~err~0#1; {26788#true} is VALID [2022-02-20 21:35:49,156 INFO L290 TraceCheckUtils]: 3: Hoare triple {26788#true} havoc #t~nondet69#1;call #t~mem70#1.base, #t~mem70#1.offset := read~$Pointer$(~data#1.base, 24 + ~data#1.offset, 8);havoc #t~mem70#1.base, #t~mem70#1.offset;#res#1 := ~err~0#1; {26788#true} is VALID [2022-02-20 21:35:49,156 INFO L290 TraceCheckUtils]: 4: Hoare triple {26788#true} assume true; {26788#true} is VALID [2022-02-20 21:35:49,156 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {26788#true} {26788#true} #636#return; {26788#true} is VALID [2022-02-20 21:35:49,156 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 133 [2022-02-20 21:35:49,157 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:49,160 INFO L290 TraceCheckUtils]: 0: Hoare triple {26788#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset; {26788#true} is VALID [2022-02-20 21:35:49,160 INFO L290 TraceCheckUtils]: 1: Hoare triple {26788#true} assume true; {26788#true} is VALID [2022-02-20 21:35:49,161 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {26788#true} {26788#true} #638#return; {26788#true} is VALID [2022-02-20 21:35:49,161 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 150 [2022-02-20 21:35:49,164 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:49,169 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:35:49,171 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:49,173 INFO L290 TraceCheckUtils]: 0: Hoare triple {26878#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {26788#true} is VALID [2022-02-20 21:35:49,173 INFO L290 TraceCheckUtils]: 1: Hoare triple {26788#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {26788#true} is VALID [2022-02-20 21:35:49,173 INFO L290 TraceCheckUtils]: 2: Hoare triple {26788#true} assume true; {26788#true} is VALID [2022-02-20 21:35:49,174 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {26788#true} {26788#true} #590#return; {26788#true} is VALID [2022-02-20 21:35:49,174 INFO L290 TraceCheckUtils]: 0: Hoare triple {26878#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {26788#true} is VALID [2022-02-20 21:35:49,174 INFO L272 TraceCheckUtils]: 1: Hoare triple {26788#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {26878#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:49,175 INFO L290 TraceCheckUtils]: 2: Hoare triple {26878#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {26788#true} is VALID [2022-02-20 21:35:49,175 INFO L290 TraceCheckUtils]: 3: Hoare triple {26788#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {26788#true} is VALID [2022-02-20 21:35:49,175 INFO L290 TraceCheckUtils]: 4: Hoare triple {26788#true} assume true; {26788#true} is VALID [2022-02-20 21:35:49,175 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {26788#true} {26788#true} #590#return; {26788#true} is VALID [2022-02-20 21:35:49,175 INFO L290 TraceCheckUtils]: 6: Hoare triple {26788#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {26788#true} is VALID [2022-02-20 21:35:49,175 INFO L290 TraceCheckUtils]: 7: Hoare triple {26788#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {26788#true} is VALID [2022-02-20 21:35:49,176 INFO L290 TraceCheckUtils]: 8: Hoare triple {26788#true} assume true; {26788#true} is VALID [2022-02-20 21:35:49,176 INFO L284 TraceCheckUtils]: 9: Hoare quadruple {26788#true} {26789#false} #640#return; {26789#false} is VALID [2022-02-20 21:35:49,176 INFO L290 TraceCheckUtils]: 0: Hoare triple {26788#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(46, 2);call #Ultimate.allocInit(13, 3);call #Ultimate.allocInit(20, 4);call #Ultimate.allocInit(21, 5);call #Ultimate.allocInit(11, 6);call #Ultimate.allocInit(18, 7);call #Ultimate.allocInit(19, 8);call #Ultimate.allocInit(20, 9);call #Ultimate.allocInit(18, 10);call #Ultimate.allocInit(69, 11);call #Ultimate.allocInit(26, 12);call #Ultimate.allocInit(4, 13);call write~init~int(37, 13, 0, 1);call write~init~int(115, 13, 1, 1);call write~init~int(10, 13, 2, 1);call write~init~int(0, 13, 3, 1);call #Ultimate.allocInit(7, 14);call write~init~int(105, 14, 0, 1);call write~init~int(98, 14, 1, 1);call write~init~int(109, 14, 2, 1);call write~init~int(112, 14, 3, 1);call write~init~int(101, 14, 4, 1);call write~init~int(120, 14, 5, 1);call write~init~int(0, 14, 6, 1);call #Ultimate.allocInit(5, 15);call write~init~int(110, 15, 0, 1);call write~init~int(97, 15, 1, 1);call write~init~int(109, 15, 2, 1);call write~init~int(101, 15, 3, 1);call write~init~int(0, 15, 4, 1);call #Ultimate.allocInit(4, 16);call write~init~int(37, 16, 0, 1);call write~init~int(100, 16, 1, 1);call write~init~int(10, 16, 2, 1);call write~init~int(0, 16, 3, 1);call #Ultimate.allocInit(15, 17);call #Ultimate.allocInit(5, 18);call write~init~int(116, 18, 0, 1);call write~init~int(101, 18, 1, 1);call write~init~int(109, 18, 2, 1);call write~init~int(112, 18, 3, 1);call write~init~int(0, 18, 4, 1);call #Ultimate.allocInit(6, 19);call write~init~int(112, 19, 0, 1);call write~init~int(111, 19, 1, 1);call write~init~int(119, 19, 2, 1);call write~init~int(101, 19, 3, 1);call write~init~int(114, 19, 4, 1);call write~init~int(0, 19, 5, 1);call #Ultimate.allocInit(40, 20);call #Ultimate.allocInit(48, 21);call #Ultimate.allocInit(12, 22);call #Ultimate.allocInit(55, 23);call #Ultimate.allocInit(26, 24);call #Ultimate.allocInit(70, 25);~#power_sensor_sig~0.base, ~#power_sensor_sig~0.offset := 26, 0;call #Ultimate.allocInit(3, 26);call write~init~int(112, ~#power_sensor_sig~0.base, ~#power_sensor_sig~0.offset, 1);call write~init~int(119, ~#power_sensor_sig~0.base, 1 + ~#power_sensor_sig~0.offset, 1);call write~init~int(114, ~#power_sensor_sig~0.base, 2 + ~#power_sensor_sig~0.offset, 1);~#temp_sensor_sig~0.base, ~#temp_sensor_sig~0.offset := 27, 0;call #Ultimate.allocInit(3, 27);call write~init~int(116, ~#temp_sensor_sig~0.base, ~#temp_sensor_sig~0.offset, 1);call write~init~int(101, ~#temp_sensor_sig~0.base, 1 + ~#temp_sensor_sig~0.offset, 1);call write~init~int(109, ~#temp_sensor_sig~0.base, 2 + ~#temp_sensor_sig~0.offset, 1);~#watt_sensor_sig~0.base, ~#watt_sensor_sig~0.offset := 28, 0;call #Ultimate.allocInit(2, 28);call write~init~int(65, ~#watt_sensor_sig~0.base, ~#watt_sensor_sig~0.offset, 1);call write~init~int(67, ~#watt_sensor_sig~0.base, 1 + ~#watt_sensor_sig~0.offset, 1);~#power_sensor_name_templates~0.base, ~#power_sensor_name_templates~0.offset := 29, 0;call #Ultimate.allocInit(24, 29);call write~init~$Pointer$(3, 0, ~#power_sensor_name_templates~0.base, ~#power_sensor_name_templates~0.offset, 8);call write~init~$Pointer$(4, 0, ~#power_sensor_name_templates~0.base, 8 + ~#power_sensor_name_templates~0.offset, 8);call write~init~$Pointer$(5, 0, ~#power_sensor_name_templates~0.base, 16 + ~#power_sensor_name_templates~0.offset, 8);~#temp_sensor_name_templates~0.base, ~#temp_sensor_name_templates~0.offset := 30, 0;call #Ultimate.allocInit(24, 30);call write~init~$Pointer$(6, 0, ~#temp_sensor_name_templates~0.base, ~#temp_sensor_name_templates~0.offset, 8);call write~init~$Pointer$(7, 0, ~#temp_sensor_name_templates~0.base, 8 + ~#temp_sensor_name_templates~0.offset, 8);call write~init~$Pointer$(8, 0, ~#temp_sensor_name_templates~0.base, 16 + ~#temp_sensor_name_templates~0.offset, 8);~#driver_data~0.base, ~#driver_data~0.offset := 31, 0;call #Ultimate.allocInit(72, 31);call write~init~$Pointer$(~#driver_data~0.base, ~#driver_data~0.offset, ~#driver_data~0.base, ~#driver_data~0.offset, 8);call write~init~$Pointer$(~#driver_data~0.base, ~#driver_data~0.offset, ~#driver_data~0.base, 8 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(0, 0, ~#driver_data~0.base, 16 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(0, 0, ~#driver_data~0.base, 24 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(~#__this_module~0.base, ~#__this_module~0.offset, ~#driver_data~0.base, 32 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(#funAddr~ibmpex_register_bmc.base, #funAddr~ibmpex_register_bmc.offset, ~#driver_data~0.base, 40 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(#funAddr~ibmpex_bmc_gone.base, #funAddr~ibmpex_bmc_gone.offset, ~#driver_data~0.base, 48 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(#funAddr~ibmpex_msg_handler.base, #funAddr~ibmpex_msg_handler.offset, ~#driver_data~0.base, 56 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(0, 0, ~#driver_data~0.base, 64 + ~#driver_data~0.offset, 8);~#sensor_dev_attr_name~0.base, ~#sensor_dev_attr_name~0.offset := 32, 0;call #Ultimate.allocInit(48, 32);call write~init~$Pointer$(15, 0, ~#sensor_dev_attr_name~0.base, ~#sensor_dev_attr_name~0.offset, 8);call write~init~int(292, ~#sensor_dev_attr_name~0.base, 8 + ~#sensor_dev_attr_name~0.offset, 4);call write~init~$Pointer$(0, 0, ~#sensor_dev_attr_name~0.base, 12 + ~#sensor_dev_attr_name~0.offset, 8);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 20 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 21 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 22 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 23 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 24 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 25 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 26 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 27 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~$Pointer$(#funAddr~show_name.base, #funAddr~show_name.offset, ~#sensor_dev_attr_name~0.base, 28 + ~#sensor_dev_attr_name~0.offset, 8);call write~init~$Pointer$(0, 0, ~#sensor_dev_attr_name~0.base, 36 + ~#sensor_dev_attr_name~0.offset, 8);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 44 + ~#sensor_dev_attr_name~0.offset, 4);~#sensor_dev_attr_reset_high_low~0.base, ~#sensor_dev_attr_reset_high_low~0.offset := 33, 0;call #Ultimate.allocInit(48, 33);call write~init~$Pointer$(17, 0, ~#sensor_dev_attr_reset_high_low~0.base, ~#sensor_dev_attr_reset_high_low~0.offset, 8);call write~init~int(128, ~#sensor_dev_attr_reset_high_low~0.base, 8 + ~#sensor_dev_attr_reset_high_low~0.offset, 4);call write~init~$Pointer$(0, 0, ~#sensor_dev_attr_reset_high_low~0.base, 12 + ~#sensor_dev_attr_reset_high_low~0.offset, 8);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 20 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 21 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 22 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 23 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 24 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 25 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 26 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 27 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~$Pointer$(0, 0, ~#sensor_dev_attr_reset_high_low~0.base, 28 + ~#sensor_dev_attr_reset_high_low~0.offset, 8);call write~init~$Pointer$(#funAddr~ibmpex_reset_high_low.base, #funAddr~ibmpex_reset_high_low.offset, ~#sensor_dev_attr_reset_high_low~0.base, 36 + ~#sensor_dev_attr_reset_high_low~0.offset, 8);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 44 + ~#sensor_dev_attr_reset_high_low~0.offset, 4);~LDV_IN_INTERRUPT~0 := 0;~ldv_count_1~0 := 0;~ldv_count_2~0 := 0;~ldv_call_dev_attr_of_sensor_device_attribute~0 := 0;~ldv_call_dev_attr_of_sensor_device_attribute_2~0 := 0; {26788#true} is VALID [2022-02-20 21:35:49,176 INFO L290 TraceCheckUtils]: 1: Hoare triple {26788#true} assume { :end_inline_ULTIMATE.init } true;assume { :begin_inline_main } true;havoc main_#res#1;havoc main_#t~ret236#1, main_#t~nondet237#1, main_#t~switch238#1, main_#t~nondet239#1, main_~var_ibmpex_register_bmc_17_p0~0#1, main_~var_group1~0#1.base, main_~var_group1~0#1.offset, main_~var_ibmpex_bmc_gone_19_p0~0#1, main_~#var_group2~0#1.base, main_~#var_group2~0#1.offset, main_~#var_ibmpex_msg_handler_20_p1~0#1.base, main_~#var_ibmpex_msg_handler_20_p1~0#1.offset, main_~tmp~17#1, main_~tmp___0~4#1, main_~tmp___1~2#1;havoc main_~var_ibmpex_register_bmc_17_p0~0#1;havoc main_~var_group1~0#1.base, main_~var_group1~0#1.offset;havoc main_~var_ibmpex_bmc_gone_19_p0~0#1;call main_~#var_group2~0#1.base, main_~#var_group2~0#1.offset := #Ultimate.allocOnStack(374);call main_~#var_ibmpex_msg_handler_20_p1~0#1.base, main_~#var_ibmpex_msg_handler_20_p1~0#1.offset := #Ultimate.allocOnStack(915);havoc main_~tmp~17#1;havoc main_~tmp___0~4#1;havoc main_~tmp___1~2#1;~LDV_IN_INTERRUPT~0 := 1;assume { :begin_inline_ldv_initialize } true;~ldv_count_1~0 := 1 + ~ldv_count_1~0;~ldv_count_1~0 := 1 + ~ldv_count_1~0;~ldv_count_1~0 := 1 + ~ldv_count_1~0;~ldv_count_1~0 := 1 + ~ldv_count_1~0;~ldv_count_1~0 := 1 + ~ldv_count_1~0;~ldv_count_1~0 := 1 + ~ldv_count_1~0; {26788#true} is VALID [2022-02-20 21:35:49,177 INFO L290 TraceCheckUtils]: 2: Hoare triple {26788#true} assume { :end_inline_ldv_initialize } true; {26788#true} is VALID [2022-02-20 21:35:49,177 INFO L272 TraceCheckUtils]: 3: Hoare triple {26788#true} call ldv_handler_precall(); {26788#true} is VALID [2022-02-20 21:35:49,177 INFO L290 TraceCheckUtils]: 4: Hoare triple {26788#true} assume true; {26788#true} is VALID [2022-02-20 21:35:49,177 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {26788#true} {26788#true} #612#return; {26788#true} is VALID [2022-02-20 21:35:49,177 INFO L290 TraceCheckUtils]: 6: Hoare triple {26788#true} assume { :begin_inline_ibmpex_init } true;havoc ibmpex_init_#res#1;havoc ibmpex_init_#t~ret231#1, ibmpex_init_~tmp~16#1;havoc ibmpex_init_~tmp~16#1;assume { :begin_inline_ipmi_smi_watcher_register } true;ipmi_smi_watcher_register_#in~arg0#1.base, ipmi_smi_watcher_register_#in~arg0#1.offset := ~#driver_data~0.base, 16 + ~#driver_data~0.offset;havoc ipmi_smi_watcher_register_#res#1;havoc ipmi_smi_watcher_register_#t~nondet252#1, ipmi_smi_watcher_register_~arg0#1.base, ipmi_smi_watcher_register_~arg0#1.offset;ipmi_smi_watcher_register_~arg0#1.base, ipmi_smi_watcher_register_~arg0#1.offset := ipmi_smi_watcher_register_#in~arg0#1.base, ipmi_smi_watcher_register_#in~arg0#1.offset;assume -2147483648 <= ipmi_smi_watcher_register_#t~nondet252#1 && ipmi_smi_watcher_register_#t~nondet252#1 <= 2147483647;ipmi_smi_watcher_register_#res#1 := ipmi_smi_watcher_register_#t~nondet252#1;havoc ipmi_smi_watcher_register_#t~nondet252#1; {26788#true} is VALID [2022-02-20 21:35:49,177 INFO L290 TraceCheckUtils]: 7: Hoare triple {26788#true} ibmpex_init_#t~ret231#1 := ipmi_smi_watcher_register_#res#1;assume { :end_inline_ipmi_smi_watcher_register } true;assume -2147483648 <= ibmpex_init_#t~ret231#1 && ibmpex_init_#t~ret231#1 <= 2147483647;ibmpex_init_~tmp~16#1 := ibmpex_init_#t~ret231#1;havoc ibmpex_init_#t~ret231#1;ibmpex_init_#res#1 := ibmpex_init_~tmp~16#1; {26788#true} is VALID [2022-02-20 21:35:49,178 INFO L290 TraceCheckUtils]: 8: Hoare triple {26788#true} main_#t~ret236#1 := ibmpex_init_#res#1;assume { :end_inline_ibmpex_init } true;assume -2147483648 <= main_#t~ret236#1 && main_#t~ret236#1 <= 2147483647;main_~tmp~17#1 := main_#t~ret236#1;havoc main_#t~ret236#1; {26788#true} is VALID [2022-02-20 21:35:49,178 INFO L290 TraceCheckUtils]: 9: Hoare triple {26788#true} assume !(0 != main_~tmp~17#1); {26788#true} is VALID [2022-02-20 21:35:49,178 INFO L290 TraceCheckUtils]: 10: Hoare triple {26788#true} assume -2147483648 <= main_#t~nondet239#1 && main_#t~nondet239#1 <= 2147483647;main_~tmp___1~2#1 := main_#t~nondet239#1;havoc main_#t~nondet239#1; {26788#true} is VALID [2022-02-20 21:35:49,178 INFO L290 TraceCheckUtils]: 11: Hoare triple {26788#true} assume 0 != main_~tmp___1~2#1; {26788#true} is VALID [2022-02-20 21:35:49,178 INFO L290 TraceCheckUtils]: 12: Hoare triple {26788#true} assume -2147483648 <= main_#t~nondet237#1 && main_#t~nondet237#1 <= 2147483647;main_~tmp___0~4#1 := main_#t~nondet237#1;havoc main_#t~nondet237#1;main_#t~switch238#1 := 0 == main_~tmp___0~4#1; {26788#true} is VALID [2022-02-20 21:35:49,178 INFO L290 TraceCheckUtils]: 13: Hoare triple {26788#true} assume main_#t~switch238#1; {26788#true} is VALID [2022-02-20 21:35:49,179 INFO L272 TraceCheckUtils]: 14: Hoare triple {26788#true} call ldv_handler_precall(); {26788#true} is VALID [2022-02-20 21:35:49,179 INFO L290 TraceCheckUtils]: 15: Hoare triple {26788#true} assume true; {26788#true} is VALID [2022-02-20 21:35:49,179 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {26788#true} {26788#true} #614#return; {26788#true} is VALID [2022-02-20 21:35:49,179 INFO L290 TraceCheckUtils]: 17: Hoare triple {26788#true} assume { :begin_inline_ibmpex_register_bmc } true;ibmpex_register_bmc_#in~iface#1, ibmpex_register_bmc_#in~dev#1.base, ibmpex_register_bmc_#in~dev#1.offset := main_~var_ibmpex_register_bmc_17_p0~0#1, main_~var_group1~0#1.base, main_~var_group1~0#1.offset;havoc ibmpex_register_bmc_#t~ret178#1.base, ibmpex_register_bmc_#t~ret178#1.offset, ibmpex_register_bmc_#t~nondet179#1, ibmpex_register_bmc_#t~mem180#1, ibmpex_register_bmc_#t~ret181#1, ibmpex_register_bmc_#t~nondet182#1, ibmpex_register_bmc_#t~mem183#1, ibmpex_register_bmc_#t~ret184#1, ibmpex_register_bmc_#t~mem185#1.base, ibmpex_register_bmc_#t~mem185#1.offset, ibmpex_register_bmc_#t~ret186#1.base, ibmpex_register_bmc_#t~ret186#1.offset, ibmpex_register_bmc_#t~mem187#1.base, ibmpex_register_bmc_#t~mem187#1.offset, ibmpex_register_bmc_#t~ret188#1, ibmpex_register_bmc_#t~nondet189#1, ibmpex_register_bmc_#t~mem190#1.base, ibmpex_register_bmc_#t~mem190#1.offset, ibmpex_register_bmc_#t~mem191#1, ibmpex_register_bmc_#t~ret192#1, ibmpex_register_bmc_#t~nondet193#1, ibmpex_register_bmc_#t~mem194#1.base, ibmpex_register_bmc_#t~mem194#1.offset, ibmpex_register_bmc_#t~mem195#1.base, ibmpex_register_bmc_#t~mem195#1.offset, ibmpex_register_bmc_#t~mem196#1.base, ibmpex_register_bmc_#t~mem196#1.offset, ibmpex_register_bmc_#t~ret197#1, ibmpex_register_bmc_~iface#1, ibmpex_register_bmc_~dev#1.base, ibmpex_register_bmc_~dev#1.offset, ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset, ibmpex_register_bmc_~err~4#1, ibmpex_register_bmc_~tmp~14#1.base, ibmpex_register_bmc_~tmp~14#1.offset, ibmpex_register_bmc_~#__key~1#1.base, ibmpex_register_bmc_~#__key~1#1.offset, ibmpex_register_bmc_~tmp___0~3#1;ibmpex_register_bmc_~iface#1 := ibmpex_register_bmc_#in~iface#1;ibmpex_register_bmc_~dev#1.base, ibmpex_register_bmc_~dev#1.offset := ibmpex_register_bmc_#in~dev#1.base, ibmpex_register_bmc_#in~dev#1.offset;havoc ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset;havoc ibmpex_register_bmc_~err~4#1;havoc ibmpex_register_bmc_~tmp~14#1.base, ibmpex_register_bmc_~tmp~14#1.offset;call ibmpex_register_bmc_~#__key~1#1.base, ibmpex_register_bmc_~#__key~1#1.offset := #Ultimate.allocOnStack(8);havoc ibmpex_register_bmc_~tmp___0~3#1; {26788#true} is VALID [2022-02-20 21:35:49,180 INFO L272 TraceCheckUtils]: 18: Hoare triple {26788#true} call ibmpex_register_bmc_#t~ret178#1.base, ibmpex_register_bmc_#t~ret178#1.offset := kzalloc(968, 208); {26878#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:49,180 INFO L290 TraceCheckUtils]: 19: Hoare triple {26878#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size;~flags := #in~flags;havoc ~tmp~2.base, ~tmp~2.offset; {26788#true} is VALID [2022-02-20 21:35:49,180 INFO L272 TraceCheckUtils]: 20: Hoare triple {26788#true} call #t~ret40.base, #t~ret40.offset := kmalloc(~size, ~bitwiseOr(~flags, 32768)); {26878#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:49,181 INFO L290 TraceCheckUtils]: 21: Hoare triple {26878#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {26788#true} is VALID [2022-02-20 21:35:49,181 INFO L272 TraceCheckUtils]: 22: Hoare triple {26788#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {26878#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:49,181 INFO L290 TraceCheckUtils]: 23: Hoare triple {26878#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {26788#true} is VALID [2022-02-20 21:35:49,182 INFO L290 TraceCheckUtils]: 24: Hoare triple {26788#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {26788#true} is VALID [2022-02-20 21:35:49,182 INFO L290 TraceCheckUtils]: 25: Hoare triple {26788#true} assume true; {26788#true} is VALID [2022-02-20 21:35:49,182 INFO L284 TraceCheckUtils]: 26: Hoare quadruple {26788#true} {26788#true} #590#return; {26788#true} is VALID [2022-02-20 21:35:49,182 INFO L290 TraceCheckUtils]: 27: Hoare triple {26788#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {26788#true} is VALID [2022-02-20 21:35:49,182 INFO L290 TraceCheckUtils]: 28: Hoare triple {26788#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {26788#true} is VALID [2022-02-20 21:35:49,182 INFO L290 TraceCheckUtils]: 29: Hoare triple {26788#true} assume true; {26788#true} is VALID [2022-02-20 21:35:49,183 INFO L284 TraceCheckUtils]: 30: Hoare quadruple {26788#true} {26788#true} #588#return; {26788#true} is VALID [2022-02-20 21:35:49,183 INFO L290 TraceCheckUtils]: 31: Hoare triple {26788#true} ~tmp~2.base, ~tmp~2.offset := #t~ret40.base, #t~ret40.offset;havoc #t~ret40.base, #t~ret40.offset;#res.base, #res.offset := ~tmp~2.base, ~tmp~2.offset; {26788#true} is VALID [2022-02-20 21:35:49,183 INFO L290 TraceCheckUtils]: 32: Hoare triple {26788#true} assume true; {26788#true} is VALID [2022-02-20 21:35:49,183 INFO L284 TraceCheckUtils]: 33: Hoare quadruple {26788#true} {26788#true} #616#return; {26788#true} is VALID [2022-02-20 21:35:49,183 INFO L290 TraceCheckUtils]: 34: Hoare triple {26788#true} ibmpex_register_bmc_~tmp~14#1.base, ibmpex_register_bmc_~tmp~14#1.offset := ibmpex_register_bmc_#t~ret178#1.base, ibmpex_register_bmc_#t~ret178#1.offset;havoc ibmpex_register_bmc_#t~ret178#1.base, ibmpex_register_bmc_#t~ret178#1.offset;ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset := ibmpex_register_bmc_~tmp~14#1.base, ibmpex_register_bmc_~tmp~14#1.offset; {26788#true} is VALID [2022-02-20 21:35:49,183 INFO L290 TraceCheckUtils]: 35: Hoare triple {26788#true} assume !(0 == (ibmpex_register_bmc_~data~2#1.base + ibmpex_register_bmc_~data~2#1.offset) % 18446744073709551616);call write~int(12, ibmpex_register_bmc_~data~2#1.base, 193 + ibmpex_register_bmc_~data~2#1.offset, 4);call write~int(15, ibmpex_register_bmc_~data~2#1.base, 197 + ibmpex_register_bmc_~data~2#1.offset, 2);call write~int(0, ibmpex_register_bmc_~data~2#1.base, 199 + ibmpex_register_bmc_~data~2#1.offset, 1);call write~int(ibmpex_register_bmc_~iface#1, ibmpex_register_bmc_~data~2#1.base, 323 + ibmpex_register_bmc_~data~2#1.offset, 4);call write~$Pointer$(ibmpex_register_bmc_~dev#1.base, ibmpex_register_bmc_~dev#1.offset, ibmpex_register_bmc_~data~2#1.base, 24 + ibmpex_register_bmc_~data~2#1.offset, 8);call ibmpex_register_bmc_#t~mem180#1 := read~int(ibmpex_register_bmc_~data~2#1.base, 323 + ibmpex_register_bmc_~data~2#1.offset, 4);assume { :begin_inline_ipmi_create_user } true;ipmi_create_user_#in~arg0#1, ipmi_create_user_#in~arg1#1.base, ipmi_create_user_#in~arg1#1.offset, ipmi_create_user_#in~arg2#1.base, ipmi_create_user_#in~arg2#1.offset, ipmi_create_user_#in~arg3#1.base, ipmi_create_user_#in~arg3#1.offset := ibmpex_register_bmc_#t~mem180#1, ~#driver_data~0.base, 56 + ~#driver_data~0.offset, ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset, ibmpex_register_bmc_~data~2#1.base, 315 + ibmpex_register_bmc_~data~2#1.offset;havoc ipmi_create_user_#res#1;havoc ipmi_create_user_#t~nondet249#1, ipmi_create_user_~arg0#1, ipmi_create_user_~arg1#1.base, ipmi_create_user_~arg1#1.offset, ipmi_create_user_~arg2#1.base, ipmi_create_user_~arg2#1.offset, ipmi_create_user_~arg3#1.base, ipmi_create_user_~arg3#1.offset;ipmi_create_user_~arg0#1 := ipmi_create_user_#in~arg0#1;ipmi_create_user_~arg1#1.base, ipmi_create_user_~arg1#1.offset := ipmi_create_user_#in~arg1#1.base, ipmi_create_user_#in~arg1#1.offset;ipmi_create_user_~arg2#1.base, ipmi_create_user_~arg2#1.offset := ipmi_create_user_#in~arg2#1.base, ipmi_create_user_#in~arg2#1.offset;ipmi_create_user_~arg3#1.base, ipmi_create_user_~arg3#1.offset := ipmi_create_user_#in~arg3#1.base, ipmi_create_user_#in~arg3#1.offset;assume -2147483648 <= ipmi_create_user_#t~nondet249#1 && ipmi_create_user_#t~nondet249#1 <= 2147483647;ipmi_create_user_#res#1 := ipmi_create_user_#t~nondet249#1;havoc ipmi_create_user_#t~nondet249#1; {26788#true} is VALID [2022-02-20 21:35:49,184 INFO L290 TraceCheckUtils]: 36: Hoare triple {26788#true} ibmpex_register_bmc_#t~ret181#1 := ipmi_create_user_#res#1;assume { :end_inline_ipmi_create_user } true;assume -2147483648 <= ibmpex_register_bmc_#t~ret181#1 && ibmpex_register_bmc_#t~ret181#1 <= 2147483647;ibmpex_register_bmc_~err~4#1 := ibmpex_register_bmc_#t~ret181#1;havoc ibmpex_register_bmc_#t~mem180#1;havoc ibmpex_register_bmc_#t~ret181#1; {26788#true} is VALID [2022-02-20 21:35:49,184 INFO L290 TraceCheckUtils]: 37: Hoare triple {26788#true} assume !(ibmpex_register_bmc_~err~4#1 < 0);assume { :begin_inline___mutex_init } true;__mutex_init_#in~arg0#1.base, __mutex_init_#in~arg0#1.offset, __mutex_init_#in~arg1#1.base, __mutex_init_#in~arg1#1.offset, __mutex_init_#in~arg2#1.base, __mutex_init_#in~arg2#1.offset := ibmpex_register_bmc_~data~2#1.base, 32 + ibmpex_register_bmc_~data~2#1.offset, 22, 0, ibmpex_register_bmc_~#__key~1#1.base, ibmpex_register_bmc_~#__key~1#1.offset;havoc __mutex_init_~arg0#1.base, __mutex_init_~arg0#1.offset, __mutex_init_~arg1#1.base, __mutex_init_~arg1#1.offset, __mutex_init_~arg2#1.base, __mutex_init_~arg2#1.offset;__mutex_init_~arg0#1.base, __mutex_init_~arg0#1.offset := __mutex_init_#in~arg0#1.base, __mutex_init_#in~arg0#1.offset;__mutex_init_~arg1#1.base, __mutex_init_~arg1#1.offset := __mutex_init_#in~arg1#1.base, __mutex_init_#in~arg1#1.offset;__mutex_init_~arg2#1.base, __mutex_init_~arg2#1.offset := __mutex_init_#in~arg2#1.base, __mutex_init_#in~arg2#1.offset; {26788#true} is VALID [2022-02-20 21:35:49,184 INFO L290 TraceCheckUtils]: 38: Hoare triple {26788#true} assume { :end_inline___mutex_init } true;call write~int(0, ibmpex_register_bmc_~data~2#1.base, 611 + ibmpex_register_bmc_~data~2#1.offset, 8);assume { :begin_inline_init_completion } true;init_completion_#in~x#1.base, init_completion_#in~x#1.offset := ibmpex_register_bmc_~data~2#1.base, 231 + ibmpex_register_bmc_~data~2#1.offset;havoc init_completion_~x#1.base, init_completion_~x#1.offset, init_completion_~#__key~0#1.base, init_completion_~#__key~0#1.offset;init_completion_~x#1.base, init_completion_~x#1.offset := init_completion_#in~x#1.base, init_completion_#in~x#1.offset;call init_completion_~#__key~0#1.base, init_completion_~#__key~0#1.offset := #Ultimate.allocOnStack(8);call write~int(0, init_completion_~x#1.base, init_completion_~x#1.offset, 4);assume { :begin_inline___init_waitqueue_head } true;__init_waitqueue_head_#in~arg0#1.base, __init_waitqueue_head_#in~arg0#1.offset, __init_waitqueue_head_#in~arg1#1.base, __init_waitqueue_head_#in~arg1#1.offset := init_completion_~x#1.base, 4 + init_completion_~x#1.offset, init_completion_~#__key~0#1.base, init_completion_~#__key~0#1.offset;havoc __init_waitqueue_head_~arg0#1.base, __init_waitqueue_head_~arg0#1.offset, __init_waitqueue_head_~arg1#1.base, __init_waitqueue_head_~arg1#1.offset;__init_waitqueue_head_~arg0#1.base, __init_waitqueue_head_~arg0#1.offset := __init_waitqueue_head_#in~arg0#1.base, __init_waitqueue_head_#in~arg0#1.offset;__init_waitqueue_head_~arg1#1.base, __init_waitqueue_head_~arg1#1.offset := __init_waitqueue_head_#in~arg1#1.base, __init_waitqueue_head_#in~arg1#1.offset; {26788#true} is VALID [2022-02-20 21:35:49,184 INFO L290 TraceCheckUtils]: 39: Hoare triple {26788#true} assume { :end_inline___init_waitqueue_head } true;call ULTIMATE.dealloc(init_completion_~#__key~0#1.base, init_completion_~#__key~0#1.offset);havoc init_completion_~#__key~0#1.base, init_completion_~#__key~0#1.offset; {26788#true} is VALID [2022-02-20 21:35:49,184 INFO L290 TraceCheckUtils]: 40: Hoare triple {26788#true} assume { :end_inline_init_completion } true;call write~int(58, ibmpex_register_bmc_~data~2#1.base, 327 + ibmpex_register_bmc_~data~2#1.offset, 1);call write~int(60, ibmpex_register_bmc_~data~2#1.base, 328 + ibmpex_register_bmc_~data~2#1.offset, 1);call write~$Pointer$(ibmpex_register_bmc_~data~2#1.base, 339 + ibmpex_register_bmc_~data~2#1.offset, ibmpex_register_bmc_~data~2#1.base, 331 + ibmpex_register_bmc_~data~2#1.offset, 8);assume { :begin_inline_ibmpex_ver_check } true;ibmpex_ver_check_#in~data#1.base, ibmpex_ver_check_#in~data#1.offset := ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset;havoc ibmpex_ver_check_#res#1;havoc ibmpex_ver_check_#t~ret71#1, ibmpex_ver_check_#t~mem72#1, ibmpex_ver_check_#t~mem73#1, ibmpex_ver_check_#t~short74#1, ibmpex_ver_check_#t~mem75#1, ibmpex_ver_check_#t~mem76#1, ibmpex_ver_check_#t~ret77#1, ibmpex_ver_check_#t~nondet78#1, ibmpex_ver_check_#t~mem79#1.base, ibmpex_ver_check_#t~mem79#1.offset, ibmpex_ver_check_#t~mem80#1, ibmpex_ver_check_#t~mem81#1, ibmpex_ver_check_#t~mem82#1, ibmpex_ver_check_#t~mem83#1, ibmpex_ver_check_#t~mem84#1, ibmpex_ver_check_~data#1.base, ibmpex_ver_check_~data#1.offset, ibmpex_ver_check_~tmp~4#1;ibmpex_ver_check_~data#1.base, ibmpex_ver_check_~data#1.offset := ibmpex_ver_check_#in~data#1.base, ibmpex_ver_check_#in~data#1.offset;havoc ibmpex_ver_check_~tmp~4#1;call write~int(1, ibmpex_ver_check_~data#1.base, 339 + ibmpex_ver_check_~data#1.offset, 1);call write~int(1, ibmpex_ver_check_~data#1.base, 329 + ibmpex_ver_check_~data#1.offset, 2); {26788#true} is VALID [2022-02-20 21:35:49,185 INFO L272 TraceCheckUtils]: 41: Hoare triple {26788#true} call ibmpex_ver_check_#t~ret71#1 := ibmpex_send_message(ibmpex_ver_check_~data#1.base, ibmpex_ver_check_~data#1.offset); {26893#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} is VALID [2022-02-20 21:35:49,185 INFO L290 TraceCheckUtils]: 42: Hoare triple {26893#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;havoc ~err~0#1;assume { :begin_inline_ipmi_validate_addr } true;ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset, ipmi_validate_addr_#in~arg1#1 := ~data#1.base, 193 + ~data#1.offset, 40;havoc ipmi_validate_addr_#res#1;havoc ipmi_validate_addr_#t~nondet254#1, ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset, ipmi_validate_addr_~arg1#1;ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset := ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset;ipmi_validate_addr_~arg1#1 := ipmi_validate_addr_#in~arg1#1;assume -2147483648 <= ipmi_validate_addr_#t~nondet254#1 && ipmi_validate_addr_#t~nondet254#1 <= 2147483647;ipmi_validate_addr_#res#1 := ipmi_validate_addr_#t~nondet254#1;havoc ipmi_validate_addr_#t~nondet254#1; {26788#true} is VALID [2022-02-20 21:35:49,185 INFO L290 TraceCheckUtils]: 43: Hoare triple {26788#true} #t~ret62#1 := ipmi_validate_addr_#res#1;assume { :end_inline_ipmi_validate_addr } true;assume -2147483648 <= #t~ret62#1 && #t~ret62#1 <= 2147483647;~err~0#1 := #t~ret62#1;havoc #t~ret62#1; {26788#true} is VALID [2022-02-20 21:35:49,186 INFO L290 TraceCheckUtils]: 44: Hoare triple {26788#true} assume 0 != ~err~0#1; {26788#true} is VALID [2022-02-20 21:35:49,186 INFO L290 TraceCheckUtils]: 45: Hoare triple {26788#true} havoc #t~nondet69#1;call #t~mem70#1.base, #t~mem70#1.offset := read~$Pointer$(~data#1.base, 24 + ~data#1.offset, 8);havoc #t~mem70#1.base, #t~mem70#1.offset;#res#1 := ~err~0#1; {26788#true} is VALID [2022-02-20 21:35:49,186 INFO L290 TraceCheckUtils]: 46: Hoare triple {26788#true} assume true; {26788#true} is VALID [2022-02-20 21:35:49,186 INFO L284 TraceCheckUtils]: 47: Hoare quadruple {26788#true} {26788#true} #618#return; {26788#true} is VALID [2022-02-20 21:35:49,186 INFO L290 TraceCheckUtils]: 48: Hoare triple {26788#true} assume -2147483648 <= ibmpex_ver_check_#t~ret71#1 && ibmpex_ver_check_#t~ret71#1 <= 2147483647;havoc ibmpex_ver_check_#t~ret71#1; {26788#true} is VALID [2022-02-20 21:35:49,186 INFO L272 TraceCheckUtils]: 49: Hoare triple {26788#true} call wait_for_completion(ibmpex_ver_check_~data#1.base, 231 + ibmpex_ver_check_~data#1.offset); {26788#true} is VALID [2022-02-20 21:35:49,187 INFO L290 TraceCheckUtils]: 50: Hoare triple {26788#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset; {26788#true} is VALID [2022-02-20 21:35:49,187 INFO L290 TraceCheckUtils]: 51: Hoare triple {26788#true} assume true; {26788#true} is VALID [2022-02-20 21:35:49,187 INFO L284 TraceCheckUtils]: 52: Hoare quadruple {26788#true} {26788#true} #620#return; {26788#true} is VALID [2022-02-20 21:35:49,187 INFO L290 TraceCheckUtils]: 53: Hoare triple {26788#true} call ibmpex_ver_check_#t~mem72#1 := read~int(ibmpex_ver_check_~data#1.base, 899 + ibmpex_ver_check_~data#1.offset, 1);ibmpex_ver_check_#t~short74#1 := 0 != ibmpex_ver_check_#t~mem72#1 % 256 % 4294967296; {26788#true} is VALID [2022-02-20 21:35:49,187 INFO L290 TraceCheckUtils]: 54: Hoare triple {26788#true} assume !ibmpex_ver_check_#t~short74#1;call ibmpex_ver_check_#t~mem73#1 := read~int(ibmpex_ver_check_~data#1.base, 891 + ibmpex_ver_check_~data#1.offset, 8);ibmpex_ver_check_#t~short74#1 := 6 != ibmpex_ver_check_#t~mem73#1 % 18446744073709551616; {26788#true} is VALID [2022-02-20 21:35:49,188 INFO L290 TraceCheckUtils]: 55: Hoare triple {26788#true} assume !ibmpex_ver_check_#t~short74#1;havoc ibmpex_ver_check_#t~mem72#1;havoc ibmpex_ver_check_#t~mem73#1;havoc ibmpex_ver_check_#t~short74#1;call ibmpex_ver_check_#t~mem75#1 := read~int(ibmpex_ver_check_~data#1.base, 619 + ibmpex_ver_check_~data#1.offset, 1);call write~int(ibmpex_ver_check_#t~mem75#1, ibmpex_ver_check_~data#1.base, 904 + ibmpex_ver_check_~data#1.offset, 1);havoc ibmpex_ver_check_#t~mem75#1;call ibmpex_ver_check_#t~mem76#1 := read~int(ibmpex_ver_check_~data#1.base, 620 + ibmpex_ver_check_~data#1.offset, 1);call write~int(ibmpex_ver_check_#t~mem76#1, ibmpex_ver_check_~data#1.base, 905 + ibmpex_ver_check_~data#1.offset, 1);havoc ibmpex_ver_check_#t~mem76#1; {26788#true} is VALID [2022-02-20 21:35:49,188 INFO L272 TraceCheckUtils]: 56: Hoare triple {26788#true} call ibmpex_ver_check_#t~ret77#1 := extract_value(ibmpex_ver_check_~data#1.base, 619 + ibmpex_ver_check_~data#1.offset, 2); {26788#true} is VALID [2022-02-20 21:35:49,188 INFO L290 TraceCheckUtils]: 57: Hoare triple {26788#true} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;~offset#1 := #in~offset#1;havoc ~tmp~3#1;assume { :begin_inline___be16_to_cpup } true;__be16_to_cpup_#in~p#1.base, __be16_to_cpup_#in~p#1.offset := ~data#1.base, ~data#1.offset + 2 * (if ~offset#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then ~offset#1 % 18446744073709551616 % 18446744073709551616 else ~offset#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616);havoc __be16_to_cpup_#res#1;havoc __be16_to_cpup_#t~ret3#1, __be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset, __be16_to_cpup_~tmp~1#1;__be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset := __be16_to_cpup_#in~p#1.base, __be16_to_cpup_#in~p#1.offset;havoc __be16_to_cpup_~tmp~1#1;assume { :begin_inline___swab16p } true;__swab16p_#in~p#1.base, __swab16p_#in~p#1.offset := __be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset;havoc __swab16p_#res#1;havoc __swab16p_#t~mem1#1, __swab16p_#t~ret2#1, __swab16p_~p#1.base, __swab16p_~p#1.offset, __swab16p_~tmp~0#1;__swab16p_~p#1.base, __swab16p_~p#1.offset := __swab16p_#in~p#1.base, __swab16p_#in~p#1.offset;havoc __swab16p_~tmp~0#1;call __swab16p_#t~mem1#1 := read~int(__swab16p_~p#1.base, __swab16p_~p#1.offset, 2);assume { :begin_inline___fswab16 } true;__fswab16_#in~val#1 := __swab16p_#t~mem1#1 % 65536;havoc __fswab16_#res#1;havoc __fswab16_~val#1;__fswab16_~val#1 := __fswab16_#in~val#1;__fswab16_#res#1 := (if (1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) || 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536)) && 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) then (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) else (if 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) && (1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) || 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536)) then (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) else (if (1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) && (1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) || 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536))) || ((1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) || 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536)) && 1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536)) then 1 else ~bitwiseOr((if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536), (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536))))); {26788#true} is VALID [2022-02-20 21:35:49,188 INFO L290 TraceCheckUtils]: 58: Hoare triple {26788#true} __swab16p_#t~ret2#1 := __fswab16_#res#1;assume { :end_inline___fswab16 } true;__swab16p_~tmp~0#1 := __swab16p_#t~ret2#1;havoc __swab16p_#t~mem1#1;havoc __swab16p_#t~ret2#1;__swab16p_#res#1 := __swab16p_~tmp~0#1; {26788#true} is VALID [2022-02-20 21:35:49,188 INFO L290 TraceCheckUtils]: 59: Hoare triple {26788#true} __be16_to_cpup_#t~ret3#1 := __swab16p_#res#1;assume { :end_inline___swab16p } true;__be16_to_cpup_~tmp~1#1 := __be16_to_cpup_#t~ret3#1;havoc __be16_to_cpup_#t~ret3#1;__be16_to_cpup_#res#1 := __be16_to_cpup_~tmp~1#1; {26788#true} is VALID [2022-02-20 21:35:49,188 INFO L290 TraceCheckUtils]: 60: Hoare triple {26788#true} #t~ret61#1 := __be16_to_cpup_#res#1;assume { :end_inline___be16_to_cpup } true;~tmp~3#1 := #t~ret61#1;havoc #t~ret61#1;#res#1 := ~tmp~3#1; {26788#true} is VALID [2022-02-20 21:35:49,189 INFO L290 TraceCheckUtils]: 61: Hoare triple {26788#true} assume true; {26788#true} is VALID [2022-02-20 21:35:49,189 INFO L284 TraceCheckUtils]: 62: Hoare quadruple {26788#true} {26788#true} #622#return; {26788#true} is VALID [2022-02-20 21:35:49,189 INFO L290 TraceCheckUtils]: 63: Hoare triple {26788#true} ibmpex_ver_check_~tmp~4#1 := ibmpex_ver_check_#t~ret77#1;havoc ibmpex_ver_check_#t~ret77#1;havoc ibmpex_ver_check_#t~nondet78#1;call ibmpex_ver_check_#t~mem79#1.base, ibmpex_ver_check_#t~mem79#1.offset := read~$Pointer$(ibmpex_ver_check_~data#1.base, 24 + ibmpex_ver_check_~data#1.offset, 8);call ibmpex_ver_check_#t~mem80#1 := read~int(ibmpex_ver_check_~data#1.base, 904 + ibmpex_ver_check_~data#1.offset, 1);call ibmpex_ver_check_#t~mem81#1 := read~int(ibmpex_ver_check_~data#1.base, 905 + ibmpex_ver_check_~data#1.offset, 1);call ibmpex_ver_check_#t~mem82#1 := read~int(ibmpex_ver_check_~data#1.base, 623 + ibmpex_ver_check_~data#1.offset, 1);call ibmpex_ver_check_#t~mem83#1 := read~int(ibmpex_ver_check_~data#1.base, 624 + ibmpex_ver_check_~data#1.offset, 1);call ibmpex_ver_check_#t~mem84#1 := read~int(ibmpex_ver_check_~data#1.base, 323 + ibmpex_ver_check_~data#1.offset, 4);havoc ibmpex_ver_check_#t~mem79#1.base, ibmpex_ver_check_#t~mem79#1.offset;havoc ibmpex_ver_check_#t~mem80#1;havoc ibmpex_ver_check_#t~mem81#1;havoc ibmpex_ver_check_#t~mem82#1;havoc ibmpex_ver_check_#t~mem83#1;havoc ibmpex_ver_check_#t~mem84#1;ibmpex_ver_check_#res#1 := 0; {26788#true} is VALID [2022-02-20 21:35:49,189 INFO L290 TraceCheckUtils]: 64: Hoare triple {26788#true} ibmpex_register_bmc_#t~ret184#1 := ibmpex_ver_check_#res#1;assume { :end_inline_ibmpex_ver_check } true;assume -2147483648 <= ibmpex_register_bmc_#t~ret184#1 && ibmpex_register_bmc_#t~ret184#1 <= 2147483647;ibmpex_register_bmc_~err~4#1 := ibmpex_register_bmc_#t~ret184#1;havoc ibmpex_register_bmc_#t~ret184#1; {26788#true} is VALID [2022-02-20 21:35:49,189 INFO L290 TraceCheckUtils]: 65: Hoare triple {26788#true} assume !(0 != ibmpex_register_bmc_~err~4#1);call ibmpex_register_bmc_#t~mem185#1.base, ibmpex_register_bmc_#t~mem185#1.offset := read~$Pointer$(ibmpex_register_bmc_~data~2#1.base, 24 + ibmpex_register_bmc_~data~2#1.offset, 8);assume { :begin_inline_hwmon_device_register } true;hwmon_device_register_#in~arg0#1.base, hwmon_device_register_#in~arg0#1.offset := ibmpex_register_bmc_#t~mem185#1.base, ibmpex_register_bmc_#t~mem185#1.offset;havoc hwmon_device_register_#res#1.base, hwmon_device_register_#res#1.offset;havoc hwmon_device_register_#t~ret248#1.base, hwmon_device_register_#t~ret248#1.offset, hwmon_device_register_~arg0#1.base, hwmon_device_register_~arg0#1.offset;hwmon_device_register_~arg0#1.base, hwmon_device_register_~arg0#1.offset := hwmon_device_register_#in~arg0#1.base, hwmon_device_register_#in~arg0#1.offset; {26788#true} is VALID [2022-02-20 21:35:49,190 INFO L272 TraceCheckUtils]: 66: Hoare triple {26788#true} call hwmon_device_register_#t~ret248#1.base, hwmon_device_register_#t~ret248#1.offset := ldv_malloc(1035); {26878#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:49,190 INFO L290 TraceCheckUtils]: 67: Hoare triple {26878#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {26788#true} is VALID [2022-02-20 21:35:49,190 INFO L290 TraceCheckUtils]: 68: Hoare triple {26788#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {26788#true} is VALID [2022-02-20 21:35:49,190 INFO L290 TraceCheckUtils]: 69: Hoare triple {26788#true} assume true; {26788#true} is VALID [2022-02-20 21:35:49,191 INFO L284 TraceCheckUtils]: 70: Hoare quadruple {26788#true} {26788#true} #624#return; {26788#true} is VALID [2022-02-20 21:35:49,191 INFO L290 TraceCheckUtils]: 71: Hoare triple {26788#true} hwmon_device_register_#res#1.base, hwmon_device_register_#res#1.offset := hwmon_device_register_#t~ret248#1.base, hwmon_device_register_#t~ret248#1.offset;havoc hwmon_device_register_#t~ret248#1.base, hwmon_device_register_#t~ret248#1.offset; {26788#true} is VALID [2022-02-20 21:35:49,191 INFO L290 TraceCheckUtils]: 72: Hoare triple {26788#true} ibmpex_register_bmc_#t~ret186#1.base, ibmpex_register_bmc_#t~ret186#1.offset := hwmon_device_register_#res#1.base, hwmon_device_register_#res#1.offset;assume { :end_inline_hwmon_device_register } true;call write~$Pointer$(ibmpex_register_bmc_#t~ret186#1.base, ibmpex_register_bmc_#t~ret186#1.offset, ibmpex_register_bmc_~data~2#1.base, 16 + ibmpex_register_bmc_~data~2#1.offset, 8);havoc ibmpex_register_bmc_#t~mem185#1.base, ibmpex_register_bmc_#t~mem185#1.offset;havoc ibmpex_register_bmc_#t~ret186#1.base, ibmpex_register_bmc_#t~ret186#1.offset;call ibmpex_register_bmc_#t~mem187#1.base, ibmpex_register_bmc_#t~mem187#1.offset := read~$Pointer$(ibmpex_register_bmc_~data~2#1.base, 16 + ibmpex_register_bmc_~data~2#1.offset, 8);assume { :begin_inline_IS_ERR } true;IS_ERR_#in~ptr#1.base, IS_ERR_#in~ptr#1.offset := ibmpex_register_bmc_#t~mem187#1.base, ibmpex_register_bmc_#t~mem187#1.offset;havoc IS_ERR_#res#1;havoc IS_ERR_#t~ret240#1, IS_ERR_~ptr#1.base, IS_ERR_~ptr#1.offset, IS_ERR_~tmp~18#1;IS_ERR_~ptr#1.base, IS_ERR_~ptr#1.offset := IS_ERR_#in~ptr#1.base, IS_ERR_#in~ptr#1.offset;havoc IS_ERR_~tmp~18#1; {26788#true} is VALID [2022-02-20 21:35:49,191 INFO L272 TraceCheckUtils]: 73: Hoare triple {26788#true} call IS_ERR_#t~ret240#1 := ldv_is_err(IS_ERR_~ptr#1.base, IS_ERR_~ptr#1.offset); {26788#true} is VALID [2022-02-20 21:35:49,191 INFO L290 TraceCheckUtils]: 74: Hoare triple {26788#true} ~ptr.base, ~ptr.offset := #in~ptr.base, #in~ptr.offset;#res := (if (~ptr.base + ~ptr.offset) % 18446744073709551616 > 2012 then 1 else 0); {26788#true} is VALID [2022-02-20 21:35:49,191 INFO L290 TraceCheckUtils]: 75: Hoare triple {26788#true} assume true; {26788#true} is VALID [2022-02-20 21:35:49,192 INFO L284 TraceCheckUtils]: 76: Hoare quadruple {26788#true} {26788#true} #626#return; {26788#true} is VALID [2022-02-20 21:35:49,192 INFO L290 TraceCheckUtils]: 77: Hoare triple {26788#true} assume -9223372036854775808 <= IS_ERR_#t~ret240#1 && IS_ERR_#t~ret240#1 <= 9223372036854775807;IS_ERR_~tmp~18#1 := IS_ERR_#t~ret240#1;havoc IS_ERR_#t~ret240#1;IS_ERR_#res#1 := IS_ERR_~tmp~18#1; {26788#true} is VALID [2022-02-20 21:35:49,192 INFO L290 TraceCheckUtils]: 78: Hoare triple {26788#true} ibmpex_register_bmc_#t~ret188#1 := IS_ERR_#res#1;assume { :end_inline_IS_ERR } true;assume -9223372036854775808 <= ibmpex_register_bmc_#t~ret188#1 && ibmpex_register_bmc_#t~ret188#1 <= 9223372036854775807;ibmpex_register_bmc_~tmp___0~3#1 := ibmpex_register_bmc_#t~ret188#1;havoc ibmpex_register_bmc_#t~mem187#1.base, ibmpex_register_bmc_#t~mem187#1.offset;havoc ibmpex_register_bmc_#t~ret188#1; {26788#true} is VALID [2022-02-20 21:35:49,192 INFO L290 TraceCheckUtils]: 79: Hoare triple {26788#true} assume !(0 != ibmpex_register_bmc_~tmp___0~3#1); {26788#true} is VALID [2022-02-20 21:35:49,192 INFO L272 TraceCheckUtils]: 80: Hoare triple {26788#true} call dev_set_drvdata(ibmpex_register_bmc_~dev#1.base, ibmpex_register_bmc_~dev#1.offset, ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset); {26788#true} is VALID [2022-02-20 21:35:49,193 INFO L290 TraceCheckUtils]: 81: Hoare triple {26788#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset;~arg1.base, ~arg1.offset := #in~arg1.base, #in~arg1.offset; {26788#true} is VALID [2022-02-20 21:35:49,193 INFO L290 TraceCheckUtils]: 82: Hoare triple {26788#true} assume true; {26788#true} is VALID [2022-02-20 21:35:49,193 INFO L284 TraceCheckUtils]: 83: Hoare quadruple {26788#true} {26788#true} #628#return; {26788#true} is VALID [2022-02-20 21:35:49,193 INFO L290 TraceCheckUtils]: 84: Hoare triple {26788#true} assume { :begin_inline_list_add_tail } true;list_add_tail_#in~new#1.base, list_add_tail_#in~new#1.offset, list_add_tail_#in~head#1.base, list_add_tail_#in~head#1.offset := ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset, ~#driver_data~0.base, ~#driver_data~0.offset;havoc list_add_tail_#t~mem12#1.base, list_add_tail_#t~mem12#1.offset, list_add_tail_~new#1.base, list_add_tail_~new#1.offset, list_add_tail_~head#1.base, list_add_tail_~head#1.offset;list_add_tail_~new#1.base, list_add_tail_~new#1.offset := list_add_tail_#in~new#1.base, list_add_tail_#in~new#1.offset;list_add_tail_~head#1.base, list_add_tail_~head#1.offset := list_add_tail_#in~head#1.base, list_add_tail_#in~head#1.offset;call list_add_tail_#t~mem12#1.base, list_add_tail_#t~mem12#1.offset := read~$Pointer$(list_add_tail_~head#1.base, 8 + list_add_tail_~head#1.offset, 8);assume { :begin_inline___list_add } true;__list_add_#in~arg0#1.base, __list_add_#in~arg0#1.offset, __list_add_#in~arg1#1.base, __list_add_#in~arg1#1.offset, __list_add_#in~arg2#1.base, __list_add_#in~arg2#1.offset := list_add_tail_~new#1.base, list_add_tail_~new#1.offset, list_add_tail_#t~mem12#1.base, list_add_tail_#t~mem12#1.offset, list_add_tail_~head#1.base, list_add_tail_~head#1.offset;havoc __list_add_~arg0#1.base, __list_add_~arg0#1.offset, __list_add_~arg1#1.base, __list_add_~arg1#1.offset, __list_add_~arg2#1.base, __list_add_~arg2#1.offset;__list_add_~arg0#1.base, __list_add_~arg0#1.offset := __list_add_#in~arg0#1.base, __list_add_#in~arg0#1.offset;__list_add_~arg1#1.base, __list_add_~arg1#1.offset := __list_add_#in~arg1#1.base, __list_add_#in~arg1#1.offset;__list_add_~arg2#1.base, __list_add_~arg2#1.offset := __list_add_#in~arg2#1.base, __list_add_#in~arg2#1.offset; {26788#true} is VALID [2022-02-20 21:35:49,193 INFO L290 TraceCheckUtils]: 85: Hoare triple {26788#true} assume { :end_inline___list_add } true;havoc list_add_tail_#t~mem12#1.base, list_add_tail_#t~mem12#1.offset; {26788#true} is VALID [2022-02-20 21:35:49,193 INFO L290 TraceCheckUtils]: 86: Hoare triple {26788#true} assume { :end_inline_list_add_tail } true;assume { :begin_inline_ibmpex_find_sensors } true;ibmpex_find_sensors_#in~data#1.base, ibmpex_find_sensors_#in~data#1.offset := ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset;havoc ibmpex_find_sensors_#res#1;havoc ibmpex_find_sensors_#t~ret148#1, ibmpex_find_sensors_#t~mem149#1, ibmpex_find_sensors_#t~ret150#1.base, ibmpex_find_sensors_#t~ret150#1.offset, ibmpex_find_sensors_#t~mem151#1.base, ibmpex_find_sensors_#t~mem151#1.offset, ibmpex_find_sensors_#t~ret152#1, ibmpex_find_sensors_#t~mem153#1, ibmpex_find_sensors_#t~ret154#1, ibmpex_find_sensors_#t~mem155#1.base, ibmpex_find_sensors_#t~mem155#1.offset, ibmpex_find_sensors_#t~mem156#1, ibmpex_find_sensors_#t~ret157#1, ibmpex_find_sensors_#t~mem158#1, ibmpex_find_sensors_#t~ret159#1, ibmpex_find_sensors_#t~mem160#1.base, ibmpex_find_sensors_#t~mem160#1.offset, ibmpex_find_sensors_#t~mem161#1.base, ibmpex_find_sensors_#t~mem161#1.offset, ibmpex_find_sensors_#t~ret162#1, ibmpex_find_sensors_#t~mem163#1, ibmpex_find_sensors_#t~mem164#1.base, ibmpex_find_sensors_#t~mem164#1.offset, ibmpex_find_sensors_#t~ret165#1, ibmpex_find_sensors_#t~mem166#1.base, ibmpex_find_sensors_#t~mem166#1.offset, ibmpex_find_sensors_#t~ret167#1, ibmpex_find_sensors_#t~mem168#1.base, ibmpex_find_sensors_#t~mem168#1.offset, ibmpex_find_sensors_#t~mem169#1.base, ibmpex_find_sensors_#t~mem169#1.offset, ibmpex_find_sensors_#t~mem170#1.base, ibmpex_find_sensors_#t~mem170#1.offset, ibmpex_find_sensors_#t~mem171#1.base, ibmpex_find_sensors_#t~mem171#1.offset, ibmpex_find_sensors_#t~mem172#1.base, ibmpex_find_sensors_#t~mem172#1.offset, ibmpex_find_sensors_#t~mem173#1.base, ibmpex_find_sensors_#t~mem173#1.offset, ibmpex_find_sensors_#t~mem174#1.base, ibmpex_find_sensors_#t~mem174#1.offset, ibmpex_find_sensors_#t~mem175#1.base, ibmpex_find_sensors_#t~mem175#1.offset, ibmpex_find_sensors_#t~mem176#1, ibmpex_find_sensors_#t~mem177#1.base, ibmpex_find_sensors_#t~mem177#1.offset, ibmpex_find_sensors_~data#1.base, ibmpex_find_sensors_~data#1.offset, ibmpex_find_sensors_~i~2#1, ibmpex_find_sensors_~j~0#1, ibmpex_find_sensors_~err~3#1, ibmpex_find_sensors_~sensor_type~0#1, ibmpex_find_sensors_~sensor_counter~0#1, ibmpex_find_sensors_~num_power~0#1, ibmpex_find_sensors_~num_temp~0#1, ibmpex_find_sensors_~tmp~13#1.base, ibmpex_find_sensors_~tmp~13#1.offset, ibmpex_find_sensors_~tmp___0~2#1, ibmpex_find_sensors_~tmp___1~1#1;ibmpex_find_sensors_~data#1.base, ibmpex_find_sensors_~data#1.offset := ibmpex_find_sensors_#in~data#1.base, ibmpex_find_sensors_#in~data#1.offset;havoc ibmpex_find_sensors_~i~2#1;havoc ibmpex_find_sensors_~j~0#1;havoc ibmpex_find_sensors_~err~3#1;havoc ibmpex_find_sensors_~sensor_type~0#1;havoc ibmpex_find_sensors_~sensor_counter~0#1;havoc ibmpex_find_sensors_~num_power~0#1;havoc ibmpex_find_sensors_~num_temp~0#1;havoc ibmpex_find_sensors_~tmp~13#1.base, ibmpex_find_sensors_~tmp~13#1.offset;havoc ibmpex_find_sensors_~tmp___0~2#1;havoc ibmpex_find_sensors_~tmp___1~1#1;ibmpex_find_sensors_~num_power~0#1 := 0;ibmpex_find_sensors_~num_temp~0#1 := 0;assume { :begin_inline_ibmpex_query_sensor_count } true;ibmpex_query_sensor_count_#in~data#1.base, ibmpex_query_sensor_count_#in~data#1.offset := ibmpex_find_sensors_~data#1.base, ibmpex_find_sensors_~data#1.offset;havoc ibmpex_query_sensor_count_#res#1;havoc ibmpex_query_sensor_count_#t~ret85#1, ibmpex_query_sensor_count_#t~mem86#1, ibmpex_query_sensor_count_#t~mem87#1, ibmpex_query_sensor_count_#t~short88#1, ibmpex_query_sensor_count_#t~mem89#1, ibmpex_query_sensor_count_~data#1.base, ibmpex_query_sensor_count_~data#1.offset;ibmpex_query_sensor_count_~data#1.base, ibmpex_query_sensor_count_~data#1.offset := ibmpex_query_sensor_count_#in~data#1.base, ibmpex_query_sensor_count_#in~data#1.offset;call write~int(2, ibmpex_query_sensor_count_~data#1.base, 339 + ibmpex_query_sensor_count_~data#1.offset, 1);call write~int(1, ibmpex_query_sensor_count_~data#1.base, 329 + ibmpex_query_sensor_count_~data#1.offset, 2); {26788#true} is VALID [2022-02-20 21:35:49,194 INFO L272 TraceCheckUtils]: 87: Hoare triple {26788#true} call ibmpex_query_sensor_count_#t~ret85#1 := ibmpex_send_message(ibmpex_query_sensor_count_~data#1.base, ibmpex_query_sensor_count_~data#1.offset); {26893#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} is VALID [2022-02-20 21:35:49,194 INFO L290 TraceCheckUtils]: 88: Hoare triple {26893#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;havoc ~err~0#1;assume { :begin_inline_ipmi_validate_addr } true;ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset, ipmi_validate_addr_#in~arg1#1 := ~data#1.base, 193 + ~data#1.offset, 40;havoc ipmi_validate_addr_#res#1;havoc ipmi_validate_addr_#t~nondet254#1, ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset, ipmi_validate_addr_~arg1#1;ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset := ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset;ipmi_validate_addr_~arg1#1 := ipmi_validate_addr_#in~arg1#1;assume -2147483648 <= ipmi_validate_addr_#t~nondet254#1 && ipmi_validate_addr_#t~nondet254#1 <= 2147483647;ipmi_validate_addr_#res#1 := ipmi_validate_addr_#t~nondet254#1;havoc ipmi_validate_addr_#t~nondet254#1; {26788#true} is VALID [2022-02-20 21:35:49,195 INFO L290 TraceCheckUtils]: 89: Hoare triple {26788#true} #t~ret62#1 := ipmi_validate_addr_#res#1;assume { :end_inline_ipmi_validate_addr } true;assume -2147483648 <= #t~ret62#1 && #t~ret62#1 <= 2147483647;~err~0#1 := #t~ret62#1;havoc #t~ret62#1; {26788#true} is VALID [2022-02-20 21:35:49,195 INFO L290 TraceCheckUtils]: 90: Hoare triple {26788#true} assume 0 != ~err~0#1; {26788#true} is VALID [2022-02-20 21:35:49,195 INFO L290 TraceCheckUtils]: 91: Hoare triple {26788#true} havoc #t~nondet69#1;call #t~mem70#1.base, #t~mem70#1.offset := read~$Pointer$(~data#1.base, 24 + ~data#1.offset, 8);havoc #t~mem70#1.base, #t~mem70#1.offset;#res#1 := ~err~0#1; {26788#true} is VALID [2022-02-20 21:35:49,195 INFO L290 TraceCheckUtils]: 92: Hoare triple {26788#true} assume true; {26788#true} is VALID [2022-02-20 21:35:49,195 INFO L284 TraceCheckUtils]: 93: Hoare quadruple {26788#true} {26788#true} #630#return; {26788#true} is VALID [2022-02-20 21:35:49,195 INFO L290 TraceCheckUtils]: 94: Hoare triple {26788#true} assume -2147483648 <= ibmpex_query_sensor_count_#t~ret85#1 && ibmpex_query_sensor_count_#t~ret85#1 <= 2147483647;havoc ibmpex_query_sensor_count_#t~ret85#1; {26788#true} is VALID [2022-02-20 21:35:49,196 INFO L272 TraceCheckUtils]: 95: Hoare triple {26788#true} call wait_for_completion(ibmpex_query_sensor_count_~data#1.base, 231 + ibmpex_query_sensor_count_~data#1.offset); {26788#true} is VALID [2022-02-20 21:35:49,196 INFO L290 TraceCheckUtils]: 96: Hoare triple {26788#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset; {26788#true} is VALID [2022-02-20 21:35:49,196 INFO L290 TraceCheckUtils]: 97: Hoare triple {26788#true} assume true; {26788#true} is VALID [2022-02-20 21:35:49,196 INFO L284 TraceCheckUtils]: 98: Hoare quadruple {26788#true} {26788#true} #632#return; {26788#true} is VALID [2022-02-20 21:35:49,196 INFO L290 TraceCheckUtils]: 99: Hoare triple {26788#true} call ibmpex_query_sensor_count_#t~mem86#1 := read~int(ibmpex_query_sensor_count_~data#1.base, 899 + ibmpex_query_sensor_count_~data#1.offset, 1);ibmpex_query_sensor_count_#t~short88#1 := 0 != ibmpex_query_sensor_count_#t~mem86#1 % 256 % 4294967296; {26788#true} is VALID [2022-02-20 21:35:49,196 INFO L290 TraceCheckUtils]: 100: Hoare triple {26788#true} assume !ibmpex_query_sensor_count_#t~short88#1;call ibmpex_query_sensor_count_#t~mem87#1 := read~int(ibmpex_query_sensor_count_~data#1.base, 891 + ibmpex_query_sensor_count_~data#1.offset, 8);ibmpex_query_sensor_count_#t~short88#1 := 1 != ibmpex_query_sensor_count_#t~mem87#1 % 18446744073709551616; {26788#true} is VALID [2022-02-20 21:35:49,197 INFO L290 TraceCheckUtils]: 101: Hoare triple {26788#true} assume !ibmpex_query_sensor_count_#t~short88#1;havoc ibmpex_query_sensor_count_#t~mem86#1;havoc ibmpex_query_sensor_count_#t~mem87#1;havoc ibmpex_query_sensor_count_#t~short88#1;call ibmpex_query_sensor_count_#t~mem89#1 := read~int(ibmpex_query_sensor_count_~data#1.base, 619 + ibmpex_query_sensor_count_~data#1.offset, 1);ibmpex_query_sensor_count_#res#1 := ibmpex_query_sensor_count_#t~mem89#1 % 256;havoc ibmpex_query_sensor_count_#t~mem89#1; {26788#true} is VALID [2022-02-20 21:35:49,197 INFO L290 TraceCheckUtils]: 102: Hoare triple {26788#true} ibmpex_find_sensors_#t~ret148#1 := ibmpex_query_sensor_count_#res#1;assume { :end_inline_ibmpex_query_sensor_count } true;assume -2147483648 <= ibmpex_find_sensors_#t~ret148#1 && ibmpex_find_sensors_#t~ret148#1 <= 2147483647;ibmpex_find_sensors_~err~3#1 := ibmpex_find_sensors_#t~ret148#1;havoc ibmpex_find_sensors_#t~ret148#1; {26788#true} is VALID [2022-02-20 21:35:49,197 INFO L290 TraceCheckUtils]: 103: Hoare triple {26788#true} assume !(ibmpex_find_sensors_~err~3#1 <= 0);call write~int(ibmpex_find_sensors_~err~3#1, ibmpex_find_sensors_~data#1.base, 906 + ibmpex_find_sensors_~data#1.offset, 1);call ibmpex_find_sensors_#t~mem149#1 := read~int(ibmpex_find_sensors_~data#1.base, 906 + ibmpex_find_sensors_~data#1.offset, 1); {26788#true} is VALID [2022-02-20 21:35:49,198 INFO L272 TraceCheckUtils]: 104: Hoare triple {26788#true} call ibmpex_find_sensors_#t~ret150#1.base, ibmpex_find_sensors_#t~ret150#1.offset := kzalloc(184 * (ibmpex_find_sensors_#t~mem149#1 % 256), 208); {26878#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:49,198 INFO L290 TraceCheckUtils]: 105: Hoare triple {26878#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size;~flags := #in~flags;havoc ~tmp~2.base, ~tmp~2.offset; {26788#true} is VALID [2022-02-20 21:35:49,198 INFO L272 TraceCheckUtils]: 106: Hoare triple {26788#true} call #t~ret40.base, #t~ret40.offset := kmalloc(~size, ~bitwiseOr(~flags, 32768)); {26878#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:49,199 INFO L290 TraceCheckUtils]: 107: Hoare triple {26878#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {26788#true} is VALID [2022-02-20 21:35:49,199 INFO L272 TraceCheckUtils]: 108: Hoare triple {26788#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {26878#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:49,199 INFO L290 TraceCheckUtils]: 109: Hoare triple {26878#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {26788#true} is VALID [2022-02-20 21:35:49,200 INFO L290 TraceCheckUtils]: 110: Hoare triple {26788#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {26788#true} is VALID [2022-02-20 21:35:49,200 INFO L290 TraceCheckUtils]: 111: Hoare triple {26788#true} assume true; {26788#true} is VALID [2022-02-20 21:35:49,200 INFO L284 TraceCheckUtils]: 112: Hoare quadruple {26788#true} {26788#true} #590#return; {26788#true} is VALID [2022-02-20 21:35:49,200 INFO L290 TraceCheckUtils]: 113: Hoare triple {26788#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {26788#true} is VALID [2022-02-20 21:35:49,200 INFO L290 TraceCheckUtils]: 114: Hoare triple {26788#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {26788#true} is VALID [2022-02-20 21:35:49,200 INFO L290 TraceCheckUtils]: 115: Hoare triple {26788#true} assume true; {26788#true} is VALID [2022-02-20 21:35:49,201 INFO L284 TraceCheckUtils]: 116: Hoare quadruple {26788#true} {26788#true} #588#return; {26788#true} is VALID [2022-02-20 21:35:49,201 INFO L290 TraceCheckUtils]: 117: Hoare triple {26788#true} ~tmp~2.base, ~tmp~2.offset := #t~ret40.base, #t~ret40.offset;havoc #t~ret40.base, #t~ret40.offset;#res.base, #res.offset := ~tmp~2.base, ~tmp~2.offset; {26788#true} is VALID [2022-02-20 21:35:49,201 INFO L290 TraceCheckUtils]: 118: Hoare triple {26788#true} assume true; {26788#true} is VALID [2022-02-20 21:35:49,201 INFO L284 TraceCheckUtils]: 119: Hoare quadruple {26788#true} {26788#true} #634#return; {26788#true} is VALID [2022-02-20 21:35:49,201 INFO L290 TraceCheckUtils]: 120: Hoare triple {26788#true} ibmpex_find_sensors_~tmp~13#1.base, ibmpex_find_sensors_~tmp~13#1.offset := ibmpex_find_sensors_#t~ret150#1.base, ibmpex_find_sensors_#t~ret150#1.offset;havoc ibmpex_find_sensors_#t~mem149#1;havoc ibmpex_find_sensors_#t~ret150#1.base, ibmpex_find_sensors_#t~ret150#1.offset;call write~$Pointer$(ibmpex_find_sensors_~tmp~13#1.base, ibmpex_find_sensors_~tmp~13#1.offset, ibmpex_find_sensors_~data#1.base, 907 + ibmpex_find_sensors_~data#1.offset, 8);call ibmpex_find_sensors_#t~mem151#1.base, ibmpex_find_sensors_#t~mem151#1.offset := read~$Pointer$(ibmpex_find_sensors_~data#1.base, 907 + ibmpex_find_sensors_~data#1.offset, 8); {26788#true} is VALID [2022-02-20 21:35:49,201 INFO L290 TraceCheckUtils]: 121: Hoare triple {26788#true} assume !(0 == (ibmpex_find_sensors_#t~mem151#1.base + ibmpex_find_sensors_#t~mem151#1.offset) % 18446744073709551616);havoc ibmpex_find_sensors_#t~mem151#1.base, ibmpex_find_sensors_#t~mem151#1.offset;ibmpex_find_sensors_~i~2#1 := 0; {26788#true} is VALID [2022-02-20 21:35:49,202 INFO L290 TraceCheckUtils]: 122: Hoare triple {26788#true} call ibmpex_find_sensors_#t~mem163#1 := read~int(ibmpex_find_sensors_~data#1.base, 906 + ibmpex_find_sensors_~data#1.offset, 1); {26788#true} is VALID [2022-02-20 21:35:49,202 INFO L290 TraceCheckUtils]: 123: Hoare triple {26788#true} assume ibmpex_find_sensors_#t~mem163#1 % 256 > ibmpex_find_sensors_~i~2#1;havoc ibmpex_find_sensors_#t~mem163#1; {26788#true} is VALID [2022-02-20 21:35:49,202 INFO L290 TraceCheckUtils]: 124: Hoare triple {26788#true} assume { :begin_inline_ibmpex_query_sensor_name } true;ibmpex_query_sensor_name_#in~data#1.base, ibmpex_query_sensor_name_#in~data#1.offset, ibmpex_query_sensor_name_#in~sensor#1 := ibmpex_find_sensors_~data#1.base, ibmpex_find_sensors_~data#1.offset, ibmpex_find_sensors_~i~2#1;havoc ibmpex_query_sensor_name_#res#1;havoc ibmpex_query_sensor_name_#t~ret90#1, ibmpex_query_sensor_name_#t~mem91#1, ibmpex_query_sensor_name_#t~mem92#1, ibmpex_query_sensor_name_#t~short93#1, ibmpex_query_sensor_name_~data#1.base, ibmpex_query_sensor_name_~data#1.offset, ibmpex_query_sensor_name_~sensor#1;ibmpex_query_sensor_name_~data#1.base, ibmpex_query_sensor_name_~data#1.offset := ibmpex_query_sensor_name_#in~data#1.base, ibmpex_query_sensor_name_#in~data#1.offset;ibmpex_query_sensor_name_~sensor#1 := ibmpex_query_sensor_name_#in~sensor#1;call write~int(3, ibmpex_query_sensor_name_~data#1.base, 339 + ibmpex_query_sensor_name_~data#1.offset, 1);call write~int(ibmpex_query_sensor_name_~sensor#1, ibmpex_query_sensor_name_~data#1.base, 340 + ibmpex_query_sensor_name_~data#1.offset, 1);call write~int(2, ibmpex_query_sensor_name_~data#1.base, 329 + ibmpex_query_sensor_name_~data#1.offset, 2); {26788#true} is VALID [2022-02-20 21:35:49,203 INFO L272 TraceCheckUtils]: 125: Hoare triple {26788#true} call ibmpex_query_sensor_name_#t~ret90#1 := ibmpex_send_message(ibmpex_query_sensor_name_~data#1.base, ibmpex_query_sensor_name_~data#1.offset); {26893#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} is VALID [2022-02-20 21:35:49,203 INFO L290 TraceCheckUtils]: 126: Hoare triple {26893#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;havoc ~err~0#1;assume { :begin_inline_ipmi_validate_addr } true;ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset, ipmi_validate_addr_#in~arg1#1 := ~data#1.base, 193 + ~data#1.offset, 40;havoc ipmi_validate_addr_#res#1;havoc ipmi_validate_addr_#t~nondet254#1, ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset, ipmi_validate_addr_~arg1#1;ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset := ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset;ipmi_validate_addr_~arg1#1 := ipmi_validate_addr_#in~arg1#1;assume -2147483648 <= ipmi_validate_addr_#t~nondet254#1 && ipmi_validate_addr_#t~nondet254#1 <= 2147483647;ipmi_validate_addr_#res#1 := ipmi_validate_addr_#t~nondet254#1;havoc ipmi_validate_addr_#t~nondet254#1; {26788#true} is VALID [2022-02-20 21:35:49,203 INFO L290 TraceCheckUtils]: 127: Hoare triple {26788#true} #t~ret62#1 := ipmi_validate_addr_#res#1;assume { :end_inline_ipmi_validate_addr } true;assume -2147483648 <= #t~ret62#1 && #t~ret62#1 <= 2147483647;~err~0#1 := #t~ret62#1;havoc #t~ret62#1; {26788#true} is VALID [2022-02-20 21:35:49,203 INFO L290 TraceCheckUtils]: 128: Hoare triple {26788#true} assume 0 != ~err~0#1; {26788#true} is VALID [2022-02-20 21:35:49,203 INFO L290 TraceCheckUtils]: 129: Hoare triple {26788#true} havoc #t~nondet69#1;call #t~mem70#1.base, #t~mem70#1.offset := read~$Pointer$(~data#1.base, 24 + ~data#1.offset, 8);havoc #t~mem70#1.base, #t~mem70#1.offset;#res#1 := ~err~0#1; {26788#true} is VALID [2022-02-20 21:35:49,204 INFO L290 TraceCheckUtils]: 130: Hoare triple {26788#true} assume true; {26788#true} is VALID [2022-02-20 21:35:49,204 INFO L284 TraceCheckUtils]: 131: Hoare quadruple {26788#true} {26788#true} #636#return; {26788#true} is VALID [2022-02-20 21:35:49,204 INFO L290 TraceCheckUtils]: 132: Hoare triple {26788#true} assume -2147483648 <= ibmpex_query_sensor_name_#t~ret90#1 && ibmpex_query_sensor_name_#t~ret90#1 <= 2147483647;havoc ibmpex_query_sensor_name_#t~ret90#1; {26788#true} is VALID [2022-02-20 21:35:49,204 INFO L272 TraceCheckUtils]: 133: Hoare triple {26788#true} call wait_for_completion(ibmpex_query_sensor_name_~data#1.base, 231 + ibmpex_query_sensor_name_~data#1.offset); {26788#true} is VALID [2022-02-20 21:35:49,204 INFO L290 TraceCheckUtils]: 134: Hoare triple {26788#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset; {26788#true} is VALID [2022-02-20 21:35:49,205 INFO L290 TraceCheckUtils]: 135: Hoare triple {26788#true} assume true; {26788#true} is VALID [2022-02-20 21:35:49,205 INFO L284 TraceCheckUtils]: 136: Hoare quadruple {26788#true} {26788#true} #638#return; {26788#true} is VALID [2022-02-20 21:35:49,205 INFO L290 TraceCheckUtils]: 137: Hoare triple {26788#true} call ibmpex_query_sensor_name_#t~mem91#1 := read~int(ibmpex_query_sensor_name_~data#1.base, 899 + ibmpex_query_sensor_name_~data#1.offset, 1);ibmpex_query_sensor_name_#t~short93#1 := 0 != ibmpex_query_sensor_name_#t~mem91#1 % 256 % 4294967296; {26788#true} is VALID [2022-02-20 21:35:49,205 INFO L290 TraceCheckUtils]: 138: Hoare triple {26788#true} assume ibmpex_query_sensor_name_#t~short93#1; {26867#|ULTIMATE.start_ibmpex_query_sensor_name_#t~short93#1|} is VALID [2022-02-20 21:35:49,206 INFO L290 TraceCheckUtils]: 139: Hoare triple {26867#|ULTIMATE.start_ibmpex_query_sensor_name_#t~short93#1|} assume !ibmpex_query_sensor_name_#t~short93#1;havoc ibmpex_query_sensor_name_#t~mem91#1;havoc ibmpex_query_sensor_name_#t~mem92#1;havoc ibmpex_query_sensor_name_#t~short93#1;ibmpex_query_sensor_name_#res#1 := 0; {26789#false} is VALID [2022-02-20 21:35:49,206 INFO L290 TraceCheckUtils]: 140: Hoare triple {26789#false} ibmpex_find_sensors_#t~ret152#1 := ibmpex_query_sensor_name_#res#1;assume { :end_inline_ibmpex_query_sensor_name } true;assume -2147483648 <= ibmpex_find_sensors_#t~ret152#1 && ibmpex_find_sensors_#t~ret152#1 <= 2147483647;ibmpex_find_sensors_~err~3#1 := ibmpex_find_sensors_#t~ret152#1;havoc ibmpex_find_sensors_#t~ret152#1; {26789#false} is VALID [2022-02-20 21:35:49,206 INFO L290 TraceCheckUtils]: 141: Hoare triple {26789#false} assume !(0 != ibmpex_find_sensors_~err~3#1);call ibmpex_find_sensors_#t~mem153#1 := read~int(ibmpex_find_sensors_~data#1.base, 891 + ibmpex_find_sensors_~data#1.offset, 8);assume { :begin_inline_is_power_sensor } true;is_power_sensor_#in~sensor_id#1.base, is_power_sensor_#in~sensor_id#1.offset, is_power_sensor_#in~len#1 := ibmpex_find_sensors_~data#1.base, 619 + ibmpex_find_sensors_~data#1.offset, (if ibmpex_find_sensors_#t~mem153#1 % 18446744073709551616 % 4294967296 <= 2147483647 then ibmpex_find_sensors_#t~mem153#1 % 18446744073709551616 % 4294967296 else ibmpex_find_sensors_#t~mem153#1 % 18446744073709551616 % 4294967296 - 4294967296);havoc is_power_sensor_#res#1;havoc is_power_sensor_#t~ret130#1, is_power_sensor_~sensor_id#1.base, is_power_sensor_~sensor_id#1.offset, is_power_sensor_~len#1, is_power_sensor_~tmp~9#1;is_power_sensor_~sensor_id#1.base, is_power_sensor_~sensor_id#1.offset := is_power_sensor_#in~sensor_id#1.base, is_power_sensor_#in~sensor_id#1.offset;is_power_sensor_~len#1 := is_power_sensor_#in~len#1;havoc is_power_sensor_~tmp~9#1; {26789#false} is VALID [2022-02-20 21:35:49,206 INFO L290 TraceCheckUtils]: 142: Hoare triple {26789#false} assume is_power_sensor_~len#1 <= 2;is_power_sensor_#res#1 := 0; {26789#false} is VALID [2022-02-20 21:35:49,206 INFO L290 TraceCheckUtils]: 143: Hoare triple {26789#false} ibmpex_find_sensors_#t~ret154#1 := is_power_sensor_#res#1;assume { :end_inline_is_power_sensor } true;assume -2147483648 <= ibmpex_find_sensors_#t~ret154#1 && ibmpex_find_sensors_#t~ret154#1 <= 2147483647;ibmpex_find_sensors_~tmp___1~1#1 := ibmpex_find_sensors_#t~ret154#1;havoc ibmpex_find_sensors_#t~mem153#1;havoc ibmpex_find_sensors_#t~ret154#1; {26789#false} is VALID [2022-02-20 21:35:49,206 INFO L290 TraceCheckUtils]: 144: Hoare triple {26789#false} assume 0 != ibmpex_find_sensors_~tmp___1~1#1;ibmpex_find_sensors_~sensor_type~0#1 := 2;ibmpex_find_sensors_~num_power~0#1 := 1 + ibmpex_find_sensors_~num_power~0#1;ibmpex_find_sensors_~sensor_counter~0#1 := ibmpex_find_sensors_~num_power~0#1;call ibmpex_find_sensors_#t~mem155#1.base, ibmpex_find_sensors_#t~mem155#1.offset := read~$Pointer$(ibmpex_find_sensors_~data#1.base, 907 + ibmpex_find_sensors_~data#1.offset, 8);call ibmpex_find_sensors_#t~mem156#1 := read~int(ibmpex_find_sensors_~data#1.base, 891 + ibmpex_find_sensors_~data#1.offset, 8);assume { :begin_inline_power_sensor_multiplier } true;power_sensor_multiplier_#in~data#1.base, power_sensor_multiplier_#in~data#1.offset, power_sensor_multiplier_#in~sensor_id#1.base, power_sensor_multiplier_#in~sensor_id#1.offset, power_sensor_multiplier_#in~len#1 := ibmpex_find_sensors_~data#1.base, ibmpex_find_sensors_~data#1.offset, ibmpex_find_sensors_~data#1.base, 619 + ibmpex_find_sensors_~data#1.offset, (if ibmpex_find_sensors_#t~mem156#1 % 18446744073709551616 % 4294967296 <= 2147483647 then ibmpex_find_sensors_#t~mem156#1 % 18446744073709551616 % 4294967296 else ibmpex_find_sensors_#t~mem156#1 % 18446744073709551616 % 4294967296 - 4294967296);havoc power_sensor_multiplier_#res#1;havoc power_sensor_multiplier_#t~mem132#1, power_sensor_multiplier_#t~ret133#1, power_sensor_multiplier_~data#1.base, power_sensor_multiplier_~data#1.offset, power_sensor_multiplier_~sensor_id#1.base, power_sensor_multiplier_~sensor_id#1.offset, power_sensor_multiplier_~len#1, power_sensor_multiplier_~i~1#1, power_sensor_multiplier_~tmp~11#1;power_sensor_multiplier_~data#1.base, power_sensor_multiplier_~data#1.offset := power_sensor_multiplier_#in~data#1.base, power_sensor_multiplier_#in~data#1.offset;power_sensor_multiplier_~sensor_id#1.base, power_sensor_multiplier_~sensor_id#1.offset := power_sensor_multiplier_#in~sensor_id#1.base, power_sensor_multiplier_#in~sensor_id#1.offset;power_sensor_multiplier_~len#1 := power_sensor_multiplier_#in~len#1;havoc power_sensor_multiplier_~i~1#1;havoc power_sensor_multiplier_~tmp~11#1;call power_sensor_multiplier_#t~mem132#1 := read~int(power_sensor_multiplier_~data#1.base, 904 + power_sensor_multiplier_~data#1.offset, 1); {26789#false} is VALID [2022-02-20 21:35:49,207 INFO L290 TraceCheckUtils]: 145: Hoare triple {26789#false} assume 2 == power_sensor_multiplier_#t~mem132#1 % 256 % 4294967296;havoc power_sensor_multiplier_#t~mem132#1;power_sensor_multiplier_#res#1 := 1000000; {26789#false} is VALID [2022-02-20 21:35:49,207 INFO L290 TraceCheckUtils]: 146: Hoare triple {26789#false} ibmpex_find_sensors_#t~ret157#1 := power_sensor_multiplier_#res#1;assume { :end_inline_power_sensor_multiplier } true;assume -2147483648 <= ibmpex_find_sensors_#t~ret157#1 && ibmpex_find_sensors_#t~ret157#1 <= 2147483647;call write~int(ibmpex_find_sensors_#t~ret157#1, ibmpex_find_sensors_#t~mem155#1.base, 10 + (ibmpex_find_sensors_#t~mem155#1.offset + 152 * (if ibmpex_find_sensors_~i~2#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then ibmpex_find_sensors_~i~2#1 % 18446744073709551616 % 18446744073709551616 else ibmpex_find_sensors_~i~2#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616)), 4);havoc ibmpex_find_sensors_#t~mem155#1.base, ibmpex_find_sensors_#t~mem155#1.offset;havoc ibmpex_find_sensors_#t~mem156#1;havoc ibmpex_find_sensors_#t~ret157#1; {26789#false} is VALID [2022-02-20 21:35:49,207 INFO L290 TraceCheckUtils]: 147: Hoare triple {26789#false} call ibmpex_find_sensors_#t~mem161#1.base, ibmpex_find_sensors_#t~mem161#1.offset := read~$Pointer$(ibmpex_find_sensors_~data#1.base, 907 + ibmpex_find_sensors_~data#1.offset, 8);call write~int(1, ibmpex_find_sensors_#t~mem161#1.base, ibmpex_find_sensors_#t~mem161#1.offset + 152 * (if ibmpex_find_sensors_~i~2#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then ibmpex_find_sensors_~i~2#1 % 18446744073709551616 % 18446744073709551616 else ibmpex_find_sensors_~i~2#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 4);havoc ibmpex_find_sensors_#t~mem161#1.base, ibmpex_find_sensors_#t~mem161#1.offset;ibmpex_find_sensors_~j~0#1 := 0; {26789#false} is VALID [2022-02-20 21:35:49,207 INFO L290 TraceCheckUtils]: 148: Hoare triple {26789#false} assume ibmpex_find_sensors_~j~0#1 <= 2; {26789#false} is VALID [2022-02-20 21:35:49,207 INFO L290 TraceCheckUtils]: 149: Hoare triple {26789#false} assume { :begin_inline_create_sensor } true;create_sensor_#in~data#1.base, create_sensor_#in~data#1.offset, create_sensor_#in~type#1, create_sensor_#in~counter#1, create_sensor_#in~sensor#1, create_sensor_#in~func#1 := ibmpex_find_sensors_~data#1.base, ibmpex_find_sensors_~data#1.offset, ibmpex_find_sensors_~sensor_type~0#1, ibmpex_find_sensors_~sensor_counter~0#1, ibmpex_find_sensors_~i~2#1, ibmpex_find_sensors_~j~0#1;havoc create_sensor_#res#1;havoc create_sensor_#t~ret134#1.base, create_sensor_#t~ret134#1.offset, create_sensor_#t~nondet135#1, create_sensor_#t~mem136#1.base, create_sensor_#t~mem136#1.offset, create_sensor_#t~nondet137#1, create_sensor_#t~mem138#1.base, create_sensor_#t~mem138#1.offset, create_sensor_#t~mem139#1.base, create_sensor_#t~mem139#1.offset, create_sensor_#t~mem140#1.base, create_sensor_#t~mem140#1.offset, create_sensor_#t~mem141#1.base, create_sensor_#t~mem141#1.offset, create_sensor_#t~mem142#1.base, create_sensor_#t~mem142#1.offset, create_sensor_#t~mem143#1.base, create_sensor_#t~mem143#1.offset, create_sensor_#t~mem144#1.base, create_sensor_#t~mem144#1.offset, create_sensor_#t~mem145#1.base, create_sensor_#t~mem145#1.offset, create_sensor_#t~ret146#1, create_sensor_#t~mem147#1.base, create_sensor_#t~mem147#1.offset, create_sensor_~data#1.base, create_sensor_~data#1.offset, create_sensor_~type#1, create_sensor_~counter#1, create_sensor_~sensor#1, create_sensor_~func#1, create_sensor_~err~2#1, create_sensor_~n~0#1.base, create_sensor_~n~0#1.offset, create_sensor_~tmp~12#1.base, create_sensor_~tmp~12#1.offset;create_sensor_~data#1.base, create_sensor_~data#1.offset := create_sensor_#in~data#1.base, create_sensor_#in~data#1.offset;create_sensor_~type#1 := create_sensor_#in~type#1;create_sensor_~counter#1 := create_sensor_#in~counter#1;create_sensor_~sensor#1 := create_sensor_#in~sensor#1;create_sensor_~func#1 := create_sensor_#in~func#1;havoc create_sensor_~err~2#1;havoc create_sensor_~n~0#1.base, create_sensor_~n~0#1.offset;havoc create_sensor_~tmp~12#1.base, create_sensor_~tmp~12#1.offset; {26789#false} is VALID [2022-02-20 21:35:49,208 INFO L272 TraceCheckUtils]: 150: Hoare triple {26789#false} call create_sensor_#t~ret134#1.base, create_sensor_#t~ret134#1.offset := kmalloc(32, 208); {26878#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:49,208 INFO L290 TraceCheckUtils]: 151: Hoare triple {26878#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {26788#true} is VALID [2022-02-20 21:35:49,208 INFO L272 TraceCheckUtils]: 152: Hoare triple {26788#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {26878#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:49,208 INFO L290 TraceCheckUtils]: 153: Hoare triple {26878#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {26788#true} is VALID [2022-02-20 21:35:49,209 INFO L290 TraceCheckUtils]: 154: Hoare triple {26788#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {26788#true} is VALID [2022-02-20 21:35:49,209 INFO L290 TraceCheckUtils]: 155: Hoare triple {26788#true} assume true; {26788#true} is VALID [2022-02-20 21:35:49,209 INFO L284 TraceCheckUtils]: 156: Hoare quadruple {26788#true} {26788#true} #590#return; {26788#true} is VALID [2022-02-20 21:35:49,209 INFO L290 TraceCheckUtils]: 157: Hoare triple {26788#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {26788#true} is VALID [2022-02-20 21:35:49,209 INFO L290 TraceCheckUtils]: 158: Hoare triple {26788#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {26788#true} is VALID [2022-02-20 21:35:49,210 INFO L290 TraceCheckUtils]: 159: Hoare triple {26788#true} assume true; {26788#true} is VALID [2022-02-20 21:35:49,210 INFO L284 TraceCheckUtils]: 160: Hoare quadruple {26788#true} {26789#false} #640#return; {26789#false} is VALID [2022-02-20 21:35:49,210 INFO L290 TraceCheckUtils]: 161: Hoare triple {26789#false} create_sensor_~tmp~12#1.base, create_sensor_~tmp~12#1.offset := create_sensor_#t~ret134#1.base, create_sensor_#t~ret134#1.offset;havoc create_sensor_#t~ret134#1.base, create_sensor_#t~ret134#1.offset;create_sensor_~n~0#1.base, create_sensor_~n~0#1.offset := create_sensor_~tmp~12#1.base, create_sensor_~tmp~12#1.offset; {26789#false} is VALID [2022-02-20 21:35:49,210 INFO L290 TraceCheckUtils]: 162: Hoare triple {26789#false} assume !(0 == (create_sensor_~n~0#1.base + create_sensor_~n~0#1.offset) % 18446744073709551616); {26789#false} is VALID [2022-02-20 21:35:49,210 INFO L290 TraceCheckUtils]: 163: Hoare triple {26789#false} assume 1 == create_sensor_~type#1;havoc create_sensor_#t~nondet135#1;call create_sensor_#t~mem136#1.base, create_sensor_#t~mem136#1.offset := read~$Pointer$(~#temp_sensor_name_templates~0.base, ~#temp_sensor_name_templates~0.offset + 8 * create_sensor_~func#1, 8);havoc create_sensor_#t~mem136#1.base, create_sensor_#t~mem136#1.offset; {26789#false} is VALID [2022-02-20 21:35:49,210 INFO L290 TraceCheckUtils]: 164: Hoare triple {26789#false} assume { :begin_inline_ldv_sysfs } true;~ldv_count_1~0 := 1 + ~ldv_count_1~0; {26789#false} is VALID [2022-02-20 21:35:49,211 INFO L290 TraceCheckUtils]: 165: Hoare triple {26789#false} assume { :end_inline_ldv_sysfs } true;call create_sensor_#t~mem139#1.base, create_sensor_#t~mem139#1.offset := read~$Pointer$(create_sensor_~data#1.base, 907 + create_sensor_~data#1.offset, 8);call write~$Pointer$(create_sensor_~n~0#1.base, create_sensor_~n~0#1.offset, create_sensor_#t~mem139#1.base, 14 + (create_sensor_#t~mem139#1.offset + 152 * (if create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 else create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616)) + 46 * create_sensor_~func#1, 8);havoc create_sensor_#t~mem139#1.base, create_sensor_#t~mem139#1.offset;call create_sensor_#t~mem140#1.base, create_sensor_#t~mem140#1.offset := read~$Pointer$(create_sensor_~data#1.base, 907 + create_sensor_~data#1.offset, 8);call write~int(292, create_sensor_#t~mem140#1.base, 8 + (14 + (create_sensor_#t~mem140#1.offset + 152 * (if create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 else create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616)) + 46 * create_sensor_~func#1), 4);havoc create_sensor_#t~mem140#1.base, create_sensor_#t~mem140#1.offset;call create_sensor_#t~mem141#1.base, create_sensor_#t~mem141#1.offset := read~$Pointer$(create_sensor_~data#1.base, 907 + create_sensor_~data#1.offset, 8);call write~$Pointer$(#funAddr~ibmpex_show_sensor.base, #funAddr~ibmpex_show_sensor.offset, create_sensor_#t~mem141#1.base, 28 + (14 + (create_sensor_#t~mem141#1.offset + 152 * (if create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 else create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616)) + 46 * create_sensor_~func#1), 8);havoc create_sensor_#t~mem141#1.base, create_sensor_#t~mem141#1.offset;call create_sensor_#t~mem142#1.base, create_sensor_#t~mem142#1.offset := read~$Pointer$(create_sensor_~data#1.base, 907 + create_sensor_~data#1.offset, 8);call write~int(create_sensor_~sensor#1, create_sensor_#t~mem142#1.base, 44 + (14 + (create_sensor_#t~mem142#1.offset + 152 * (if create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 else create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616)) + 46 * create_sensor_~func#1), 1);havoc create_sensor_#t~mem142#1.base, create_sensor_#t~mem142#1.offset;call create_sensor_#t~mem143#1.base, create_sensor_#t~mem143#1.offset := read~$Pointer$(create_sensor_~data#1.base, 907 + create_sensor_~data#1.offset, 8);call write~int(create_sensor_~func#1, create_sensor_#t~mem143#1.base, 45 + (14 + (create_sensor_#t~mem143#1.offset + 152 * (if create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 else create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616)) + 46 * create_sensor_~func#1), 1);havoc create_sensor_#t~mem143#1.base, create_sensor_#t~mem143#1.offset;call create_sensor_#t~mem144#1.base, create_sensor_#t~mem144#1.offset := read~$Pointer$(create_sensor_~data#1.base, 24 + create_sensor_~data#1.offset, 8);call create_sensor_#t~mem145#1.base, create_sensor_#t~mem145#1.offset := read~$Pointer$(create_sensor_~data#1.base, 907 + create_sensor_~data#1.offset, 8);assume { :begin_inline_ldv_device_create_file_5 } true;ldv_device_create_file_5_#in~ldv_func_arg1#1.base, ldv_device_create_file_5_#in~ldv_func_arg1#1.offset, ldv_device_create_file_5_#in~ldv_func_arg2#1.base, ldv_device_create_file_5_#in~ldv_func_arg2#1.offset := create_sensor_#t~mem144#1.base, create_sensor_#t~mem144#1.offset, create_sensor_#t~mem145#1.base, 14 + (create_sensor_#t~mem145#1.offset + 152 * (if create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 else create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616)) + 46 * create_sensor_~func#1;havoc ldv_device_create_file_5_#res#1;havoc ldv_device_create_file_5_#t~ret241#1, ldv_device_create_file_5_~ldv_func_arg1#1.base, ldv_device_create_file_5_~ldv_func_arg1#1.offset, ldv_device_create_file_5_~ldv_func_arg2#1.base, ldv_device_create_file_5_~ldv_func_arg2#1.offset, ldv_device_create_file_5_~tmp~19#1;ldv_device_create_file_5_~ldv_func_arg1#1.base, ldv_device_create_file_5_~ldv_func_arg1#1.offset := ldv_device_create_file_5_#in~ldv_func_arg1#1.base, ldv_device_create_file_5_#in~ldv_func_arg1#1.offset;ldv_device_create_file_5_~ldv_func_arg2#1.base, ldv_device_create_file_5_~ldv_func_arg2#1.offset := ldv_device_create_file_5_#in~ldv_func_arg2#1.base, ldv_device_create_file_5_#in~ldv_func_arg2#1.offset;havoc ldv_device_create_file_5_~tmp~19#1;assume { :begin_inline_ldv_device_create_file_dev_attr_of_sensor_device_attribute_2 } true;ldv_device_create_file_dev_attr_of_sensor_device_attribute_2_#in~attr#1.base, ldv_device_create_file_dev_attr_of_sensor_device_attribute_2_#in~attr#1.offset := ldv_device_create_file_5_~ldv_func_arg2#1.base, ldv_device_create_file_5_~ldv_func_arg2#1.offset;havoc ldv_device_create_file_dev_attr_of_sensor_device_attribute_2_#res#1;havoc ldv_device_create_file_dev_attr_of_sensor_device_attribute_2_~attr#1.base, ldv_device_create_file_dev_attr_of_sensor_device_attribute_2_~attr#1.offset;ldv_device_create_file_dev_attr_of_sensor_device_attribute_2_~attr#1.base, ldv_device_create_file_dev_attr_of_sensor_device_attribute_2_~attr#1.offset := ldv_device_create_file_dev_attr_of_sensor_device_attribute_2_#in~attr#1.base, ldv_device_create_file_dev_attr_of_sensor_device_attribute_2_#in~attr#1.offset; {26789#false} is VALID [2022-02-20 21:35:49,211 INFO L290 TraceCheckUtils]: 166: Hoare triple {26789#false} assume 0 == ~ldv_call_dev_attr_of_sensor_device_attribute_2~0;~ldv_count_2~0 := 1 + ~ldv_count_2~0;~ldv_call_dev_attr_of_sensor_device_attribute_2~0 := 1; {26789#false} is VALID [2022-02-20 21:35:49,211 INFO L290 TraceCheckUtils]: 167: Hoare triple {26789#false} assume ~ldv_count_1~0 >= ~ldv_count_2~0; {26789#false} is VALID [2022-02-20 21:35:49,211 INFO L290 TraceCheckUtils]: 168: Hoare triple {26789#false} ldv_device_create_file_dev_attr_of_sensor_device_attribute_2_#res#1 := 0; {26789#false} is VALID [2022-02-20 21:35:49,211 INFO L290 TraceCheckUtils]: 169: Hoare triple {26789#false} ldv_device_create_file_5_#t~ret241#1 := ldv_device_create_file_dev_attr_of_sensor_device_attribute_2_#res#1;assume { :end_inline_ldv_device_create_file_dev_attr_of_sensor_device_attribute_2 } true;assume -2147483648 <= ldv_device_create_file_5_#t~ret241#1 && ldv_device_create_file_5_#t~ret241#1 <= 2147483647;ldv_device_create_file_5_~tmp~19#1 := ldv_device_create_file_5_#t~ret241#1;havoc ldv_device_create_file_5_#t~ret241#1;ldv_device_create_file_5_#res#1 := ldv_device_create_file_5_~tmp~19#1; {26789#false} is VALID [2022-02-20 21:35:49,212 INFO L290 TraceCheckUtils]: 170: Hoare triple {26789#false} create_sensor_#t~ret146#1 := ldv_device_create_file_5_#res#1;assume { :end_inline_ldv_device_create_file_5 } true;assume -2147483648 <= create_sensor_#t~ret146#1 && create_sensor_#t~ret146#1 <= 2147483647;create_sensor_~err~2#1 := create_sensor_#t~ret146#1;havoc create_sensor_#t~mem144#1.base, create_sensor_#t~mem144#1.offset;havoc create_sensor_#t~mem145#1.base, create_sensor_#t~mem145#1.offset;havoc create_sensor_#t~ret146#1; {26789#false} is VALID [2022-02-20 21:35:49,212 INFO L290 TraceCheckUtils]: 171: Hoare triple {26789#false} assume !(0 != create_sensor_~err~2#1);create_sensor_#res#1 := 0; {26789#false} is VALID [2022-02-20 21:35:49,212 INFO L290 TraceCheckUtils]: 172: Hoare triple {26789#false} ibmpex_find_sensors_#t~ret162#1 := create_sensor_#res#1;assume { :end_inline_create_sensor } true;assume -2147483648 <= ibmpex_find_sensors_#t~ret162#1 && ibmpex_find_sensors_#t~ret162#1 <= 2147483647;ibmpex_find_sensors_~err~3#1 := ibmpex_find_sensors_#t~ret162#1;havoc ibmpex_find_sensors_#t~ret162#1; {26789#false} is VALID [2022-02-20 21:35:49,212 INFO L290 TraceCheckUtils]: 173: Hoare triple {26789#false} assume !(0 != ibmpex_find_sensors_~err~3#1);ibmpex_find_sensors_~j~0#1 := 1 + ibmpex_find_sensors_~j~0#1; {26789#false} is VALID [2022-02-20 21:35:49,212 INFO L290 TraceCheckUtils]: 174: Hoare triple {26789#false} assume !(ibmpex_find_sensors_~j~0#1 <= 2); {26789#false} is VALID [2022-02-20 21:35:49,212 INFO L290 TraceCheckUtils]: 175: Hoare triple {26789#false} ibmpex_find_sensors_~i~2#1 := 1 + ibmpex_find_sensors_~i~2#1; {26789#false} is VALID [2022-02-20 21:35:49,213 INFO L290 TraceCheckUtils]: 176: Hoare triple {26789#false} call ibmpex_find_sensors_#t~mem163#1 := read~int(ibmpex_find_sensors_~data#1.base, 906 + ibmpex_find_sensors_~data#1.offset, 1); {26789#false} is VALID [2022-02-20 21:35:49,213 INFO L290 TraceCheckUtils]: 177: Hoare triple {26789#false} assume !(ibmpex_find_sensors_#t~mem163#1 % 256 > ibmpex_find_sensors_~i~2#1);havoc ibmpex_find_sensors_#t~mem163#1;call ibmpex_find_sensors_#t~mem164#1.base, ibmpex_find_sensors_#t~mem164#1.offset := read~$Pointer$(ibmpex_find_sensors_~data#1.base, 24 + ibmpex_find_sensors_~data#1.offset, 8);assume { :begin_inline_ldv_device_create_file_6 } true;ldv_device_create_file_6_#in~ldv_func_arg1#1.base, ldv_device_create_file_6_#in~ldv_func_arg1#1.offset, ldv_device_create_file_6_#in~ldv_func_arg2#1.base, ldv_device_create_file_6_#in~ldv_func_arg2#1.offset := ibmpex_find_sensors_#t~mem164#1.base, ibmpex_find_sensors_#t~mem164#1.offset, ~#sensor_dev_attr_reset_high_low~0.base, ~#sensor_dev_attr_reset_high_low~0.offset;havoc ldv_device_create_file_6_#res#1;havoc ldv_device_create_file_6_#t~ret242#1, ldv_device_create_file_6_~ldv_func_arg1#1.base, ldv_device_create_file_6_~ldv_func_arg1#1.offset, ldv_device_create_file_6_~ldv_func_arg2#1.base, ldv_device_create_file_6_~ldv_func_arg2#1.offset, ldv_device_create_file_6_~tmp~20#1;ldv_device_create_file_6_~ldv_func_arg1#1.base, ldv_device_create_file_6_~ldv_func_arg1#1.offset := ldv_device_create_file_6_#in~ldv_func_arg1#1.base, ldv_device_create_file_6_#in~ldv_func_arg1#1.offset;ldv_device_create_file_6_~ldv_func_arg2#1.base, ldv_device_create_file_6_~ldv_func_arg2#1.offset := ldv_device_create_file_6_#in~ldv_func_arg2#1.base, ldv_device_create_file_6_#in~ldv_func_arg2#1.offset;havoc ldv_device_create_file_6_~tmp~20#1; {26789#false} is VALID [2022-02-20 21:35:49,213 INFO L272 TraceCheckUtils]: 178: Hoare triple {26789#false} call ldv_device_create_file_6_#t~ret242#1 := ldv_device_create_file_dev_attr_of_sensor_device_attribute(ldv_device_create_file_6_~ldv_func_arg2#1.base, ldv_device_create_file_6_~ldv_func_arg2#1.offset); {26789#false} is VALID [2022-02-20 21:35:49,213 INFO L290 TraceCheckUtils]: 179: Hoare triple {26789#false} ~attr.base, ~attr.offset := #in~attr.base, #in~attr.offset; {26789#false} is VALID [2022-02-20 21:35:49,213 INFO L290 TraceCheckUtils]: 180: Hoare triple {26789#false} assume 0 == ~ldv_call_dev_attr_of_sensor_device_attribute~0;~ldv_count_2~0 := 1 + ~ldv_count_2~0;~ldv_call_dev_attr_of_sensor_device_attribute~0 := 1; {26789#false} is VALID [2022-02-20 21:35:49,213 INFO L290 TraceCheckUtils]: 181: Hoare triple {26789#false} assume !(~ldv_count_1~0 >= ~ldv_count_2~0); {26789#false} is VALID [2022-02-20 21:35:49,214 INFO L272 TraceCheckUtils]: 182: Hoare triple {26789#false} call ldv_error(); {26789#false} is VALID [2022-02-20 21:35:49,214 INFO L290 TraceCheckUtils]: 183: Hoare triple {26789#false} assume !false; {26789#false} is VALID [2022-02-20 21:35:49,214 INFO L134 CoverageAnalysis]: Checked inductivity of 79 backedges. 2 proven. 0 refuted. 0 times theorem prover too weak. 77 trivial. 0 not checked. [2022-02-20 21:35:49,215 INFO L144 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-02-20 21:35:49,215 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [365134850] [2022-02-20 21:35:49,215 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleSmtInterpolCraig [365134850] provided 1 perfect and 0 imperfect interpolant sequences [2022-02-20 21:35:49,215 INFO L191 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-02-20 21:35:49,215 INFO L204 FreeRefinementEngine]: Number of different interpolants: perfect sequences [5] imperfect sequences [] total 5 [2022-02-20 21:35:49,215 INFO L118 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [464139483] [2022-02-20 21:35:49,216 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-02-20 21:35:49,216 INFO L78 Accepts]: Start accepts. Automaton has has 5 states, 5 states have (on average 21.4) internal successors, (107), 3 states have internal predecessors, (107), 2 states have call successors, (19), 4 states have call predecessors, (19), 1 states have return successors, (17), 2 states have call predecessors, (17), 2 states have call successors, (17) Word has length 184 [2022-02-20 21:35:49,218 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-02-20 21:35:49,218 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with has 5 states, 5 states have (on average 21.4) internal successors, (107), 3 states have internal predecessors, (107), 2 states have call successors, (19), 4 states have call predecessors, (19), 1 states have return successors, (17), 2 states have call predecessors, (17), 2 states have call successors, (17) [2022-02-20 21:35:49,334 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 143 edges. 143 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 21:35:49,336 INFO L546 AbstractCegarLoop]: INTERPOLANT automaton has 5 states [2022-02-20 21:35:49,336 INFO L108 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2022-02-20 21:35:49,336 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 5 interpolants. [2022-02-20 21:35:49,337 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=7, Invalid=13, Unknown=0, NotChecked=0, Total=20 [2022-02-20 21:35:49,337 INFO L87 Difference]: Start difference. First operand 1033 states and 1362 transitions. Second operand has 5 states, 5 states have (on average 21.4) internal successors, (107), 3 states have internal predecessors, (107), 2 states have call successors, (19), 4 states have call predecessors, (19), 1 states have return successors, (17), 2 states have call predecessors, (17), 2 states have call successors, (17) [2022-02-20 21:35:51,627 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 21:35:51,628 INFO L93 Difference]: Finished difference Result 2178 states and 2895 transitions. [2022-02-20 21:35:51,628 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 6 states. [2022-02-20 21:35:51,628 INFO L78 Accepts]: Start accepts. Automaton has has 5 states, 5 states have (on average 21.4) internal successors, (107), 3 states have internal predecessors, (107), 2 states have call successors, (19), 4 states have call predecessors, (19), 1 states have return successors, (17), 2 states have call predecessors, (17), 2 states have call successors, (17) Word has length 184 [2022-02-20 21:35:51,631 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-02-20 21:35:51,632 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 5 states, 5 states have (on average 21.4) internal successors, (107), 3 states have internal predecessors, (107), 2 states have call successors, (19), 4 states have call predecessors, (19), 1 states have return successors, (17), 2 states have call predecessors, (17), 2 states have call successors, (17) [2022-02-20 21:35:51,639 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 6 states to 6 states and 724 transitions. [2022-02-20 21:35:51,639 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 5 states, 5 states have (on average 21.4) internal successors, (107), 3 states have internal predecessors, (107), 2 states have call successors, (19), 4 states have call predecessors, (19), 1 states have return successors, (17), 2 states have call predecessors, (17), 2 states have call successors, (17) [2022-02-20 21:35:51,645 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 6 states to 6 states and 724 transitions. [2022-02-20 21:35:51,645 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with 6 states and 724 transitions. [2022-02-20 21:35:52,200 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 724 edges. 724 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 21:35:52,268 INFO L225 Difference]: With dead ends: 2178 [2022-02-20 21:35:52,269 INFO L226 Difference]: Without dead ends: 1153 [2022-02-20 21:35:52,271 INFO L932 BasicCegarLoop]: 0 DeclaredPredicates, 45 GetRequests, 41 SyntacticMatches, 0 SemanticMatches, 4 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 0 ImplicationChecksByTransitivity, 0.0s TimeCoverageRelationStatistics Valid=11, Invalid=19, Unknown=0, NotChecked=0, Total=30 [2022-02-20 21:35:52,271 INFO L933 BasicCegarLoop]: 318 mSDtfsCounter, 155 mSDsluCounter, 508 mSDsCounter, 0 mSdLazyCounter, 349 mSolverCounterSat, 117 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.5s Time, 0 mProtectedPredicate, 0 mProtectedAction, 163 SdHoareTripleChecker+Valid, 826 SdHoareTripleChecker+Invalid, 466 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 117 IncrementalHoareTripleChecker+Valid, 349 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.5s IncrementalHoareTripleChecker+Time [2022-02-20 21:35:52,272 INFO L934 BasicCegarLoop]: SdHoareTripleChecker [163 Valid, 826 Invalid, 466 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [117 Valid, 349 Invalid, 0 Unknown, 0 Unchecked, 0.5s Time] [2022-02-20 21:35:52,273 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 1153 states. [2022-02-20 21:35:52,700 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 1153 to 1037. [2022-02-20 21:35:52,700 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-02-20 21:35:52,703 INFO L82 GeneralOperation]: Start isEquivalent. First operand 1153 states. Second operand has 1037 states, 801 states have (on average 1.2759051186017478) internal successors, (1022), 810 states have internal predecessors, (1022), 171 states have call successors, (171), 65 states have call predecessors, (171), 64 states have return successors, (173), 169 states have call predecessors, (173), 169 states have call successors, (173) [2022-02-20 21:35:52,705 INFO L74 IsIncluded]: Start isIncluded. First operand 1153 states. Second operand has 1037 states, 801 states have (on average 1.2759051186017478) internal successors, (1022), 810 states have internal predecessors, (1022), 171 states have call successors, (171), 65 states have call predecessors, (171), 64 states have return successors, (173), 169 states have call predecessors, (173), 169 states have call successors, (173) [2022-02-20 21:35:52,706 INFO L87 Difference]: Start difference. First operand 1153 states. Second operand has 1037 states, 801 states have (on average 1.2759051186017478) internal successors, (1022), 810 states have internal predecessors, (1022), 171 states have call successors, (171), 65 states have call predecessors, (171), 64 states have return successors, (173), 169 states have call predecessors, (173), 169 states have call successors, (173) [2022-02-20 21:35:52,777 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 21:35:52,777 INFO L93 Difference]: Finished difference Result 1153 states and 1538 transitions. [2022-02-20 21:35:52,778 INFO L276 IsEmpty]: Start isEmpty. Operand 1153 states and 1538 transitions. [2022-02-20 21:35:52,781 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 21:35:52,781 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 21:35:52,783 INFO L74 IsIncluded]: Start isIncluded. First operand has 1037 states, 801 states have (on average 1.2759051186017478) internal successors, (1022), 810 states have internal predecessors, (1022), 171 states have call successors, (171), 65 states have call predecessors, (171), 64 states have return successors, (173), 169 states have call predecessors, (173), 169 states have call successors, (173) Second operand 1153 states. [2022-02-20 21:35:52,785 INFO L87 Difference]: Start difference. First operand has 1037 states, 801 states have (on average 1.2759051186017478) internal successors, (1022), 810 states have internal predecessors, (1022), 171 states have call successors, (171), 65 states have call predecessors, (171), 64 states have return successors, (173), 169 states have call predecessors, (173), 169 states have call successors, (173) Second operand 1153 states. [2022-02-20 21:35:52,849 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 21:35:52,849 INFO L93 Difference]: Finished difference Result 1153 states and 1538 transitions. [2022-02-20 21:35:52,850 INFO L276 IsEmpty]: Start isEmpty. Operand 1153 states and 1538 transitions. [2022-02-20 21:35:52,853 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 21:35:52,853 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 21:35:52,853 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-02-20 21:35:52,853 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-02-20 21:35:52,856 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 1037 states, 801 states have (on average 1.2759051186017478) internal successors, (1022), 810 states have internal predecessors, (1022), 171 states have call successors, (171), 65 states have call predecessors, (171), 64 states have return successors, (173), 169 states have call predecessors, (173), 169 states have call successors, (173) [2022-02-20 21:35:52,934 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 1037 states to 1037 states and 1366 transitions. [2022-02-20 21:35:52,935 INFO L78 Accepts]: Start accepts. Automaton has 1037 states and 1366 transitions. Word has length 184 [2022-02-20 21:35:52,935 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-02-20 21:35:52,936 INFO L470 AbstractCegarLoop]: Abstraction has 1037 states and 1366 transitions. [2022-02-20 21:35:52,936 INFO L471 AbstractCegarLoop]: INTERPOLANT automaton has has 5 states, 5 states have (on average 21.4) internal successors, (107), 3 states have internal predecessors, (107), 2 states have call successors, (19), 4 states have call predecessors, (19), 1 states have return successors, (17), 2 states have call predecessors, (17), 2 states have call successors, (17) [2022-02-20 21:35:52,936 INFO L276 IsEmpty]: Start isEmpty. Operand 1037 states and 1366 transitions. [2022-02-20 21:35:52,940 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 185 [2022-02-20 21:35:52,940 INFO L506 BasicCegarLoop]: Found error trace [2022-02-20 21:35:52,940 INFO L514 BasicCegarLoop]: trace histogram [4, 4, 4, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 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, 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:35:52,940 WARN L452 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable6 [2022-02-20 21:35:52,941 INFO L402 AbstractCegarLoop]: === Iteration 8 === Targeting ldv_errorErr0ASSERT_VIOLATIONERROR_FUNCTION === [ldv_errorErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-02-20 21:35:52,941 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-02-20 21:35:52,941 INFO L85 PathProgramCache]: Analyzing trace with hash 347923828, now seen corresponding path program 1 times [2022-02-20 21:35:52,942 INFO L126 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-02-20 21:35:52,942 INFO L338 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [949474387] [2022-02-20 21:35:52,942 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 21:35:52,942 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-02-20 21:35:53,044 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:53,104 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 3 [2022-02-20 21:35:53,105 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:53,108 INFO L290 TraceCheckUtils]: 0: Hoare triple {33971#true} assume true; {33971#true} is VALID [2022-02-20 21:35:53,108 INFO L284 TraceCheckUtils]: 1: Hoare quadruple {33971#true} {33971#true} #612#return; {33971#true} is VALID [2022-02-20 21:35:53,108 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 14 [2022-02-20 21:35:53,108 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:53,112 INFO L290 TraceCheckUtils]: 0: Hoare triple {33971#true} assume true; {33971#true} is VALID [2022-02-20 21:35:53,112 INFO L284 TraceCheckUtils]: 1: Hoare quadruple {33971#true} {33971#true} #614#return; {33971#true} is VALID [2022-02-20 21:35:53,117 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 18 [2022-02-20 21:35:53,119 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:53,122 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:35:53,123 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:53,126 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:35:53,128 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:53,130 INFO L290 TraceCheckUtils]: 0: Hoare triple {34062#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {33971#true} is VALID [2022-02-20 21:35:53,131 INFO L290 TraceCheckUtils]: 1: Hoare triple {33971#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {33971#true} is VALID [2022-02-20 21:35:53,131 INFO L290 TraceCheckUtils]: 2: Hoare triple {33971#true} assume true; {33971#true} is VALID [2022-02-20 21:35:53,131 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {33971#true} {33971#true} #590#return; {33971#true} is VALID [2022-02-20 21:35:53,131 INFO L290 TraceCheckUtils]: 0: Hoare triple {34062#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {33971#true} is VALID [2022-02-20 21:35:53,132 INFO L272 TraceCheckUtils]: 1: Hoare triple {33971#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {34062#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:53,132 INFO L290 TraceCheckUtils]: 2: Hoare triple {34062#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {33971#true} is VALID [2022-02-20 21:35:53,132 INFO L290 TraceCheckUtils]: 3: Hoare triple {33971#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {33971#true} is VALID [2022-02-20 21:35:53,132 INFO L290 TraceCheckUtils]: 4: Hoare triple {33971#true} assume true; {33971#true} is VALID [2022-02-20 21:35:53,133 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {33971#true} {33971#true} #590#return; {33971#true} is VALID [2022-02-20 21:35:53,133 INFO L290 TraceCheckUtils]: 6: Hoare triple {33971#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {33971#true} is VALID [2022-02-20 21:35:53,133 INFO L290 TraceCheckUtils]: 7: Hoare triple {33971#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {33971#true} is VALID [2022-02-20 21:35:53,133 INFO L290 TraceCheckUtils]: 8: Hoare triple {33971#true} assume true; {33971#true} is VALID [2022-02-20 21:35:53,133 INFO L284 TraceCheckUtils]: 9: Hoare quadruple {33971#true} {33971#true} #588#return; {33971#true} is VALID [2022-02-20 21:35:53,134 INFO L290 TraceCheckUtils]: 0: Hoare triple {34062#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size;~flags := #in~flags;havoc ~tmp~2.base, ~tmp~2.offset; {33971#true} is VALID [2022-02-20 21:35:53,134 INFO L272 TraceCheckUtils]: 1: Hoare triple {33971#true} call #t~ret40.base, #t~ret40.offset := kmalloc(~size, ~bitwiseOr(~flags, 32768)); {34062#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:53,134 INFO L290 TraceCheckUtils]: 2: Hoare triple {34062#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {33971#true} is VALID [2022-02-20 21:35:53,135 INFO L272 TraceCheckUtils]: 3: Hoare triple {33971#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {34062#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:53,135 INFO L290 TraceCheckUtils]: 4: Hoare triple {34062#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {33971#true} is VALID [2022-02-20 21:35:53,135 INFO L290 TraceCheckUtils]: 5: Hoare triple {33971#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {33971#true} is VALID [2022-02-20 21:35:53,135 INFO L290 TraceCheckUtils]: 6: Hoare triple {33971#true} assume true; {33971#true} is VALID [2022-02-20 21:35:53,136 INFO L284 TraceCheckUtils]: 7: Hoare quadruple {33971#true} {33971#true} #590#return; {33971#true} is VALID [2022-02-20 21:35:53,136 INFO L290 TraceCheckUtils]: 8: Hoare triple {33971#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {33971#true} is VALID [2022-02-20 21:35:53,136 INFO L290 TraceCheckUtils]: 9: Hoare triple {33971#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {33971#true} is VALID [2022-02-20 21:35:53,136 INFO L290 TraceCheckUtils]: 10: Hoare triple {33971#true} assume true; {33971#true} is VALID [2022-02-20 21:35:53,136 INFO L284 TraceCheckUtils]: 11: Hoare quadruple {33971#true} {33971#true} #588#return; {33971#true} is VALID [2022-02-20 21:35:53,137 INFO L290 TraceCheckUtils]: 12: Hoare triple {33971#true} ~tmp~2.base, ~tmp~2.offset := #t~ret40.base, #t~ret40.offset;havoc #t~ret40.base, #t~ret40.offset;#res.base, #res.offset := ~tmp~2.base, ~tmp~2.offset; {33971#true} is VALID [2022-02-20 21:35:53,137 INFO L290 TraceCheckUtils]: 13: Hoare triple {33971#true} assume true; {33971#true} is VALID [2022-02-20 21:35:53,137 INFO L284 TraceCheckUtils]: 14: Hoare quadruple {33971#true} {33971#true} #616#return; {33971#true} is VALID [2022-02-20 21:35:53,143 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 41 [2022-02-20 21:35:53,145 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:53,148 INFO L290 TraceCheckUtils]: 0: Hoare triple {34077#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;havoc ~err~0#1;assume { :begin_inline_ipmi_validate_addr } true;ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset, ipmi_validate_addr_#in~arg1#1 := ~data#1.base, 193 + ~data#1.offset, 40;havoc ipmi_validate_addr_#res#1;havoc ipmi_validate_addr_#t~nondet254#1, ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset, ipmi_validate_addr_~arg1#1;ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset := ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset;ipmi_validate_addr_~arg1#1 := ipmi_validate_addr_#in~arg1#1;assume -2147483648 <= ipmi_validate_addr_#t~nondet254#1 && ipmi_validate_addr_#t~nondet254#1 <= 2147483647;ipmi_validate_addr_#res#1 := ipmi_validate_addr_#t~nondet254#1;havoc ipmi_validate_addr_#t~nondet254#1; {33971#true} is VALID [2022-02-20 21:35:53,149 INFO L290 TraceCheckUtils]: 1: Hoare triple {33971#true} #t~ret62#1 := ipmi_validate_addr_#res#1;assume { :end_inline_ipmi_validate_addr } true;assume -2147483648 <= #t~ret62#1 && #t~ret62#1 <= 2147483647;~err~0#1 := #t~ret62#1;havoc #t~ret62#1; {33971#true} is VALID [2022-02-20 21:35:53,149 INFO L290 TraceCheckUtils]: 2: Hoare triple {33971#true} assume 0 != ~err~0#1; {33971#true} is VALID [2022-02-20 21:35:53,149 INFO L290 TraceCheckUtils]: 3: Hoare triple {33971#true} havoc #t~nondet69#1;call #t~mem70#1.base, #t~mem70#1.offset := read~$Pointer$(~data#1.base, 24 + ~data#1.offset, 8);havoc #t~mem70#1.base, #t~mem70#1.offset;#res#1 := ~err~0#1; {33971#true} is VALID [2022-02-20 21:35:53,149 INFO L290 TraceCheckUtils]: 4: Hoare triple {33971#true} assume true; {33971#true} is VALID [2022-02-20 21:35:53,149 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {33971#true} {33971#true} #618#return; {33971#true} is VALID [2022-02-20 21:35:53,150 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 49 [2022-02-20 21:35:53,150 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:53,152 INFO L290 TraceCheckUtils]: 0: Hoare triple {33971#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset; {33971#true} is VALID [2022-02-20 21:35:53,152 INFO L290 TraceCheckUtils]: 1: Hoare triple {33971#true} assume true; {33971#true} is VALID [2022-02-20 21:35:53,153 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {33971#true} {33971#true} #620#return; {33971#true} is VALID [2022-02-20 21:35:53,153 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 56 [2022-02-20 21:35:53,155 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:53,160 INFO L290 TraceCheckUtils]: 0: Hoare triple {33971#true} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;~offset#1 := #in~offset#1;havoc ~tmp~3#1;assume { :begin_inline___be16_to_cpup } true;__be16_to_cpup_#in~p#1.base, __be16_to_cpup_#in~p#1.offset := ~data#1.base, ~data#1.offset + 2 * (if ~offset#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then ~offset#1 % 18446744073709551616 % 18446744073709551616 else ~offset#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616);havoc __be16_to_cpup_#res#1;havoc __be16_to_cpup_#t~ret3#1, __be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset, __be16_to_cpup_~tmp~1#1;__be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset := __be16_to_cpup_#in~p#1.base, __be16_to_cpup_#in~p#1.offset;havoc __be16_to_cpup_~tmp~1#1;assume { :begin_inline___swab16p } true;__swab16p_#in~p#1.base, __swab16p_#in~p#1.offset := __be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset;havoc __swab16p_#res#1;havoc __swab16p_#t~mem1#1, __swab16p_#t~ret2#1, __swab16p_~p#1.base, __swab16p_~p#1.offset, __swab16p_~tmp~0#1;__swab16p_~p#1.base, __swab16p_~p#1.offset := __swab16p_#in~p#1.base, __swab16p_#in~p#1.offset;havoc __swab16p_~tmp~0#1;call __swab16p_#t~mem1#1 := read~int(__swab16p_~p#1.base, __swab16p_~p#1.offset, 2);assume { :begin_inline___fswab16 } true;__fswab16_#in~val#1 := __swab16p_#t~mem1#1 % 65536;havoc __fswab16_#res#1;havoc __fswab16_~val#1;__fswab16_~val#1 := __fswab16_#in~val#1;__fswab16_#res#1 := (if (1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) || 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536)) && 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) then (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) else (if 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) && (1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) || 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536)) then (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) else (if (1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) && (1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) || 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536))) || ((1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) || 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536)) && 1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536)) then 1 else ~bitwiseOr((if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536), (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536))))); {33971#true} is VALID [2022-02-20 21:35:53,160 INFO L290 TraceCheckUtils]: 1: Hoare triple {33971#true} __swab16p_#t~ret2#1 := __fswab16_#res#1;assume { :end_inline___fswab16 } true;__swab16p_~tmp~0#1 := __swab16p_#t~ret2#1;havoc __swab16p_#t~mem1#1;havoc __swab16p_#t~ret2#1;__swab16p_#res#1 := __swab16p_~tmp~0#1; {33971#true} is VALID [2022-02-20 21:35:53,160 INFO L290 TraceCheckUtils]: 2: Hoare triple {33971#true} __be16_to_cpup_#t~ret3#1 := __swab16p_#res#1;assume { :end_inline___swab16p } true;__be16_to_cpup_~tmp~1#1 := __be16_to_cpup_#t~ret3#1;havoc __be16_to_cpup_#t~ret3#1;__be16_to_cpup_#res#1 := __be16_to_cpup_~tmp~1#1; {33971#true} is VALID [2022-02-20 21:35:53,160 INFO L290 TraceCheckUtils]: 3: Hoare triple {33971#true} #t~ret61#1 := __be16_to_cpup_#res#1;assume { :end_inline___be16_to_cpup } true;~tmp~3#1 := #t~ret61#1;havoc #t~ret61#1;#res#1 := ~tmp~3#1; {33971#true} is VALID [2022-02-20 21:35:53,161 INFO L290 TraceCheckUtils]: 4: Hoare triple {33971#true} assume true; {33971#true} is VALID [2022-02-20 21:35:53,161 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {33971#true} {33971#true} #622#return; {33971#true} is VALID [2022-02-20 21:35:53,161 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 66 [2022-02-20 21:35:53,162 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:53,164 INFO L290 TraceCheckUtils]: 0: Hoare triple {34062#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {33971#true} is VALID [2022-02-20 21:35:53,165 INFO L290 TraceCheckUtils]: 1: Hoare triple {33971#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {33971#true} is VALID [2022-02-20 21:35:53,165 INFO L290 TraceCheckUtils]: 2: Hoare triple {33971#true} assume true; {33971#true} is VALID [2022-02-20 21:35:53,165 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {33971#true} {33971#true} #624#return; {33971#true} is VALID [2022-02-20 21:35:53,165 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 73 [2022-02-20 21:35:53,166 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:53,169 INFO L290 TraceCheckUtils]: 0: Hoare triple {33971#true} ~ptr.base, ~ptr.offset := #in~ptr.base, #in~ptr.offset;#res := (if (~ptr.base + ~ptr.offset) % 18446744073709551616 > 2012 then 1 else 0); {33971#true} is VALID [2022-02-20 21:35:53,169 INFO L290 TraceCheckUtils]: 1: Hoare triple {33971#true} assume true; {33971#true} is VALID [2022-02-20 21:35:53,169 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {33971#true} {33971#true} #626#return; {33971#true} is VALID [2022-02-20 21:35:53,169 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 80 [2022-02-20 21:35:53,170 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:53,172 INFO L290 TraceCheckUtils]: 0: Hoare triple {33971#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset;~arg1.base, ~arg1.offset := #in~arg1.base, #in~arg1.offset; {33971#true} is VALID [2022-02-20 21:35:53,172 INFO L290 TraceCheckUtils]: 1: Hoare triple {33971#true} assume true; {33971#true} is VALID [2022-02-20 21:35:53,172 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {33971#true} {33971#true} #628#return; {33971#true} is VALID [2022-02-20 21:35:53,172 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 87 [2022-02-20 21:35:53,174 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:53,177 INFO L290 TraceCheckUtils]: 0: Hoare triple {34077#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;havoc ~err~0#1;assume { :begin_inline_ipmi_validate_addr } true;ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset, ipmi_validate_addr_#in~arg1#1 := ~data#1.base, 193 + ~data#1.offset, 40;havoc ipmi_validate_addr_#res#1;havoc ipmi_validate_addr_#t~nondet254#1, ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset, ipmi_validate_addr_~arg1#1;ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset := ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset;ipmi_validate_addr_~arg1#1 := ipmi_validate_addr_#in~arg1#1;assume -2147483648 <= ipmi_validate_addr_#t~nondet254#1 && ipmi_validate_addr_#t~nondet254#1 <= 2147483647;ipmi_validate_addr_#res#1 := ipmi_validate_addr_#t~nondet254#1;havoc ipmi_validate_addr_#t~nondet254#1; {33971#true} is VALID [2022-02-20 21:35:53,177 INFO L290 TraceCheckUtils]: 1: Hoare triple {33971#true} #t~ret62#1 := ipmi_validate_addr_#res#1;assume { :end_inline_ipmi_validate_addr } true;assume -2147483648 <= #t~ret62#1 && #t~ret62#1 <= 2147483647;~err~0#1 := #t~ret62#1;havoc #t~ret62#1; {33971#true} is VALID [2022-02-20 21:35:53,177 INFO L290 TraceCheckUtils]: 2: Hoare triple {33971#true} assume 0 != ~err~0#1; {33971#true} is VALID [2022-02-20 21:35:53,177 INFO L290 TraceCheckUtils]: 3: Hoare triple {33971#true} havoc #t~nondet69#1;call #t~mem70#1.base, #t~mem70#1.offset := read~$Pointer$(~data#1.base, 24 + ~data#1.offset, 8);havoc #t~mem70#1.base, #t~mem70#1.offset;#res#1 := ~err~0#1; {33971#true} is VALID [2022-02-20 21:35:53,177 INFO L290 TraceCheckUtils]: 4: Hoare triple {33971#true} assume true; {33971#true} is VALID [2022-02-20 21:35:53,178 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {33971#true} {33971#true} #630#return; {33971#true} is VALID [2022-02-20 21:35:53,178 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 95 [2022-02-20 21:35:53,178 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:53,180 INFO L290 TraceCheckUtils]: 0: Hoare triple {33971#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset; {33971#true} is VALID [2022-02-20 21:35:53,181 INFO L290 TraceCheckUtils]: 1: Hoare triple {33971#true} assume true; {33971#true} is VALID [2022-02-20 21:35:53,181 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {33971#true} {33971#true} #632#return; {33971#true} is VALID [2022-02-20 21:35:53,181 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 104 [2022-02-20 21:35:53,183 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:53,186 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:35:53,187 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:53,190 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:35:53,191 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:53,194 INFO L290 TraceCheckUtils]: 0: Hoare triple {34062#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {33971#true} is VALID [2022-02-20 21:35:53,194 INFO L290 TraceCheckUtils]: 1: Hoare triple {33971#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {33971#true} is VALID [2022-02-20 21:35:53,195 INFO L290 TraceCheckUtils]: 2: Hoare triple {33971#true} assume true; {33971#true} is VALID [2022-02-20 21:35:53,195 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {33971#true} {33971#true} #590#return; {33971#true} is VALID [2022-02-20 21:35:53,195 INFO L290 TraceCheckUtils]: 0: Hoare triple {34062#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {33971#true} is VALID [2022-02-20 21:35:53,196 INFO L272 TraceCheckUtils]: 1: Hoare triple {33971#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {34062#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:53,196 INFO L290 TraceCheckUtils]: 2: Hoare triple {34062#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {33971#true} is VALID [2022-02-20 21:35:53,196 INFO L290 TraceCheckUtils]: 3: Hoare triple {33971#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {33971#true} is VALID [2022-02-20 21:35:53,196 INFO L290 TraceCheckUtils]: 4: Hoare triple {33971#true} assume true; {33971#true} is VALID [2022-02-20 21:35:53,196 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {33971#true} {33971#true} #590#return; {33971#true} is VALID [2022-02-20 21:35:53,197 INFO L290 TraceCheckUtils]: 6: Hoare triple {33971#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {33971#true} is VALID [2022-02-20 21:35:53,197 INFO L290 TraceCheckUtils]: 7: Hoare triple {33971#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {33971#true} is VALID [2022-02-20 21:35:53,197 INFO L290 TraceCheckUtils]: 8: Hoare triple {33971#true} assume true; {33971#true} is VALID [2022-02-20 21:35:53,197 INFO L284 TraceCheckUtils]: 9: Hoare quadruple {33971#true} {33971#true} #588#return; {33971#true} is VALID [2022-02-20 21:35:53,197 INFO L290 TraceCheckUtils]: 0: Hoare triple {34062#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size;~flags := #in~flags;havoc ~tmp~2.base, ~tmp~2.offset; {33971#true} is VALID [2022-02-20 21:35:53,198 INFO L272 TraceCheckUtils]: 1: Hoare triple {33971#true} call #t~ret40.base, #t~ret40.offset := kmalloc(~size, ~bitwiseOr(~flags, 32768)); {34062#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:53,198 INFO L290 TraceCheckUtils]: 2: Hoare triple {34062#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {33971#true} is VALID [2022-02-20 21:35:53,199 INFO L272 TraceCheckUtils]: 3: Hoare triple {33971#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {34062#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:53,199 INFO L290 TraceCheckUtils]: 4: Hoare triple {34062#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {33971#true} is VALID [2022-02-20 21:35:53,199 INFO L290 TraceCheckUtils]: 5: Hoare triple {33971#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {33971#true} is VALID [2022-02-20 21:35:53,199 INFO L290 TraceCheckUtils]: 6: Hoare triple {33971#true} assume true; {33971#true} is VALID [2022-02-20 21:35:53,200 INFO L284 TraceCheckUtils]: 7: Hoare quadruple {33971#true} {33971#true} #590#return; {33971#true} is VALID [2022-02-20 21:35:53,200 INFO L290 TraceCheckUtils]: 8: Hoare triple {33971#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {33971#true} is VALID [2022-02-20 21:35:53,200 INFO L290 TraceCheckUtils]: 9: Hoare triple {33971#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {33971#true} is VALID [2022-02-20 21:35:53,200 INFO L290 TraceCheckUtils]: 10: Hoare triple {33971#true} assume true; {33971#true} is VALID [2022-02-20 21:35:53,200 INFO L284 TraceCheckUtils]: 11: Hoare quadruple {33971#true} {33971#true} #588#return; {33971#true} is VALID [2022-02-20 21:35:53,201 INFO L290 TraceCheckUtils]: 12: Hoare triple {33971#true} ~tmp~2.base, ~tmp~2.offset := #t~ret40.base, #t~ret40.offset;havoc #t~ret40.base, #t~ret40.offset;#res.base, #res.offset := ~tmp~2.base, ~tmp~2.offset; {33971#true} is VALID [2022-02-20 21:35:53,201 INFO L290 TraceCheckUtils]: 13: Hoare triple {33971#true} assume true; {33971#true} is VALID [2022-02-20 21:35:53,201 INFO L284 TraceCheckUtils]: 14: Hoare quadruple {33971#true} {33971#true} #634#return; {33971#true} is VALID [2022-02-20 21:35:53,201 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 125 [2022-02-20 21:35:53,203 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:53,206 INFO L290 TraceCheckUtils]: 0: Hoare triple {34077#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;havoc ~err~0#1;assume { :begin_inline_ipmi_validate_addr } true;ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset, ipmi_validate_addr_#in~arg1#1 := ~data#1.base, 193 + ~data#1.offset, 40;havoc ipmi_validate_addr_#res#1;havoc ipmi_validate_addr_#t~nondet254#1, ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset, ipmi_validate_addr_~arg1#1;ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset := ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset;ipmi_validate_addr_~arg1#1 := ipmi_validate_addr_#in~arg1#1;assume -2147483648 <= ipmi_validate_addr_#t~nondet254#1 && ipmi_validate_addr_#t~nondet254#1 <= 2147483647;ipmi_validate_addr_#res#1 := ipmi_validate_addr_#t~nondet254#1;havoc ipmi_validate_addr_#t~nondet254#1; {33971#true} is VALID [2022-02-20 21:35:53,207 INFO L290 TraceCheckUtils]: 1: Hoare triple {33971#true} #t~ret62#1 := ipmi_validate_addr_#res#1;assume { :end_inline_ipmi_validate_addr } true;assume -2147483648 <= #t~ret62#1 && #t~ret62#1 <= 2147483647;~err~0#1 := #t~ret62#1;havoc #t~ret62#1; {33971#true} is VALID [2022-02-20 21:35:53,207 INFO L290 TraceCheckUtils]: 2: Hoare triple {33971#true} assume 0 != ~err~0#1; {33971#true} is VALID [2022-02-20 21:35:53,207 INFO L290 TraceCheckUtils]: 3: Hoare triple {33971#true} havoc #t~nondet69#1;call #t~mem70#1.base, #t~mem70#1.offset := read~$Pointer$(~data#1.base, 24 + ~data#1.offset, 8);havoc #t~mem70#1.base, #t~mem70#1.offset;#res#1 := ~err~0#1; {33971#true} is VALID [2022-02-20 21:35:53,207 INFO L290 TraceCheckUtils]: 4: Hoare triple {33971#true} assume true; {33971#true} is VALID [2022-02-20 21:35:53,207 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {33971#true} {33971#true} #636#return; {33971#true} is VALID [2022-02-20 21:35:53,207 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 133 [2022-02-20 21:35:53,208 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:53,210 INFO L290 TraceCheckUtils]: 0: Hoare triple {33971#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset; {33971#true} is VALID [2022-02-20 21:35:53,210 INFO L290 TraceCheckUtils]: 1: Hoare triple {33971#true} assume true; {33971#true} is VALID [2022-02-20 21:35:53,211 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {33971#true} {33971#true} #638#return; {33971#true} is VALID [2022-02-20 21:35:53,211 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 150 [2022-02-20 21:35:53,213 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:53,216 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:35:53,217 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:35:53,220 INFO L290 TraceCheckUtils]: 0: Hoare triple {34062#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {33971#true} is VALID [2022-02-20 21:35:53,220 INFO L290 TraceCheckUtils]: 1: Hoare triple {33971#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {33971#true} is VALID [2022-02-20 21:35:53,220 INFO L290 TraceCheckUtils]: 2: Hoare triple {33971#true} assume true; {33971#true} is VALID [2022-02-20 21:35:53,220 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {33971#true} {33971#true} #590#return; {33971#true} is VALID [2022-02-20 21:35:53,220 INFO L290 TraceCheckUtils]: 0: Hoare triple {34062#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {33971#true} is VALID [2022-02-20 21:35:53,221 INFO L272 TraceCheckUtils]: 1: Hoare triple {33971#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {34062#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:53,221 INFO L290 TraceCheckUtils]: 2: Hoare triple {34062#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {33971#true} is VALID [2022-02-20 21:35:53,221 INFO L290 TraceCheckUtils]: 3: Hoare triple {33971#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {33971#true} is VALID [2022-02-20 21:35:53,222 INFO L290 TraceCheckUtils]: 4: Hoare triple {33971#true} assume true; {33971#true} is VALID [2022-02-20 21:35:53,222 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {33971#true} {33971#true} #590#return; {33971#true} is VALID [2022-02-20 21:35:53,222 INFO L290 TraceCheckUtils]: 6: Hoare triple {33971#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {33971#true} is VALID [2022-02-20 21:35:53,222 INFO L290 TraceCheckUtils]: 7: Hoare triple {33971#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {33971#true} is VALID [2022-02-20 21:35:53,222 INFO L290 TraceCheckUtils]: 8: Hoare triple {33971#true} assume true; {33971#true} is VALID [2022-02-20 21:35:53,222 INFO L284 TraceCheckUtils]: 9: Hoare quadruple {33971#true} {33972#false} #640#return; {33972#false} is VALID [2022-02-20 21:35:53,223 INFO L290 TraceCheckUtils]: 0: Hoare triple {33971#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(46, 2);call #Ultimate.allocInit(13, 3);call #Ultimate.allocInit(20, 4);call #Ultimate.allocInit(21, 5);call #Ultimate.allocInit(11, 6);call #Ultimate.allocInit(18, 7);call #Ultimate.allocInit(19, 8);call #Ultimate.allocInit(20, 9);call #Ultimate.allocInit(18, 10);call #Ultimate.allocInit(69, 11);call #Ultimate.allocInit(26, 12);call #Ultimate.allocInit(4, 13);call write~init~int(37, 13, 0, 1);call write~init~int(115, 13, 1, 1);call write~init~int(10, 13, 2, 1);call write~init~int(0, 13, 3, 1);call #Ultimate.allocInit(7, 14);call write~init~int(105, 14, 0, 1);call write~init~int(98, 14, 1, 1);call write~init~int(109, 14, 2, 1);call write~init~int(112, 14, 3, 1);call write~init~int(101, 14, 4, 1);call write~init~int(120, 14, 5, 1);call write~init~int(0, 14, 6, 1);call #Ultimate.allocInit(5, 15);call write~init~int(110, 15, 0, 1);call write~init~int(97, 15, 1, 1);call write~init~int(109, 15, 2, 1);call write~init~int(101, 15, 3, 1);call write~init~int(0, 15, 4, 1);call #Ultimate.allocInit(4, 16);call write~init~int(37, 16, 0, 1);call write~init~int(100, 16, 1, 1);call write~init~int(10, 16, 2, 1);call write~init~int(0, 16, 3, 1);call #Ultimate.allocInit(15, 17);call #Ultimate.allocInit(5, 18);call write~init~int(116, 18, 0, 1);call write~init~int(101, 18, 1, 1);call write~init~int(109, 18, 2, 1);call write~init~int(112, 18, 3, 1);call write~init~int(0, 18, 4, 1);call #Ultimate.allocInit(6, 19);call write~init~int(112, 19, 0, 1);call write~init~int(111, 19, 1, 1);call write~init~int(119, 19, 2, 1);call write~init~int(101, 19, 3, 1);call write~init~int(114, 19, 4, 1);call write~init~int(0, 19, 5, 1);call #Ultimate.allocInit(40, 20);call #Ultimate.allocInit(48, 21);call #Ultimate.allocInit(12, 22);call #Ultimate.allocInit(55, 23);call #Ultimate.allocInit(26, 24);call #Ultimate.allocInit(70, 25);~#power_sensor_sig~0.base, ~#power_sensor_sig~0.offset := 26, 0;call #Ultimate.allocInit(3, 26);call write~init~int(112, ~#power_sensor_sig~0.base, ~#power_sensor_sig~0.offset, 1);call write~init~int(119, ~#power_sensor_sig~0.base, 1 + ~#power_sensor_sig~0.offset, 1);call write~init~int(114, ~#power_sensor_sig~0.base, 2 + ~#power_sensor_sig~0.offset, 1);~#temp_sensor_sig~0.base, ~#temp_sensor_sig~0.offset := 27, 0;call #Ultimate.allocInit(3, 27);call write~init~int(116, ~#temp_sensor_sig~0.base, ~#temp_sensor_sig~0.offset, 1);call write~init~int(101, ~#temp_sensor_sig~0.base, 1 + ~#temp_sensor_sig~0.offset, 1);call write~init~int(109, ~#temp_sensor_sig~0.base, 2 + ~#temp_sensor_sig~0.offset, 1);~#watt_sensor_sig~0.base, ~#watt_sensor_sig~0.offset := 28, 0;call #Ultimate.allocInit(2, 28);call write~init~int(65, ~#watt_sensor_sig~0.base, ~#watt_sensor_sig~0.offset, 1);call write~init~int(67, ~#watt_sensor_sig~0.base, 1 + ~#watt_sensor_sig~0.offset, 1);~#power_sensor_name_templates~0.base, ~#power_sensor_name_templates~0.offset := 29, 0;call #Ultimate.allocInit(24, 29);call write~init~$Pointer$(3, 0, ~#power_sensor_name_templates~0.base, ~#power_sensor_name_templates~0.offset, 8);call write~init~$Pointer$(4, 0, ~#power_sensor_name_templates~0.base, 8 + ~#power_sensor_name_templates~0.offset, 8);call write~init~$Pointer$(5, 0, ~#power_sensor_name_templates~0.base, 16 + ~#power_sensor_name_templates~0.offset, 8);~#temp_sensor_name_templates~0.base, ~#temp_sensor_name_templates~0.offset := 30, 0;call #Ultimate.allocInit(24, 30);call write~init~$Pointer$(6, 0, ~#temp_sensor_name_templates~0.base, ~#temp_sensor_name_templates~0.offset, 8);call write~init~$Pointer$(7, 0, ~#temp_sensor_name_templates~0.base, 8 + ~#temp_sensor_name_templates~0.offset, 8);call write~init~$Pointer$(8, 0, ~#temp_sensor_name_templates~0.base, 16 + ~#temp_sensor_name_templates~0.offset, 8);~#driver_data~0.base, ~#driver_data~0.offset := 31, 0;call #Ultimate.allocInit(72, 31);call write~init~$Pointer$(~#driver_data~0.base, ~#driver_data~0.offset, ~#driver_data~0.base, ~#driver_data~0.offset, 8);call write~init~$Pointer$(~#driver_data~0.base, ~#driver_data~0.offset, ~#driver_data~0.base, 8 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(0, 0, ~#driver_data~0.base, 16 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(0, 0, ~#driver_data~0.base, 24 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(~#__this_module~0.base, ~#__this_module~0.offset, ~#driver_data~0.base, 32 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(#funAddr~ibmpex_register_bmc.base, #funAddr~ibmpex_register_bmc.offset, ~#driver_data~0.base, 40 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(#funAddr~ibmpex_bmc_gone.base, #funAddr~ibmpex_bmc_gone.offset, ~#driver_data~0.base, 48 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(#funAddr~ibmpex_msg_handler.base, #funAddr~ibmpex_msg_handler.offset, ~#driver_data~0.base, 56 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(0, 0, ~#driver_data~0.base, 64 + ~#driver_data~0.offset, 8);~#sensor_dev_attr_name~0.base, ~#sensor_dev_attr_name~0.offset := 32, 0;call #Ultimate.allocInit(48, 32);call write~init~$Pointer$(15, 0, ~#sensor_dev_attr_name~0.base, ~#sensor_dev_attr_name~0.offset, 8);call write~init~int(292, ~#sensor_dev_attr_name~0.base, 8 + ~#sensor_dev_attr_name~0.offset, 4);call write~init~$Pointer$(0, 0, ~#sensor_dev_attr_name~0.base, 12 + ~#sensor_dev_attr_name~0.offset, 8);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 20 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 21 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 22 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 23 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 24 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 25 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 26 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 27 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~$Pointer$(#funAddr~show_name.base, #funAddr~show_name.offset, ~#sensor_dev_attr_name~0.base, 28 + ~#sensor_dev_attr_name~0.offset, 8);call write~init~$Pointer$(0, 0, ~#sensor_dev_attr_name~0.base, 36 + ~#sensor_dev_attr_name~0.offset, 8);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 44 + ~#sensor_dev_attr_name~0.offset, 4);~#sensor_dev_attr_reset_high_low~0.base, ~#sensor_dev_attr_reset_high_low~0.offset := 33, 0;call #Ultimate.allocInit(48, 33);call write~init~$Pointer$(17, 0, ~#sensor_dev_attr_reset_high_low~0.base, ~#sensor_dev_attr_reset_high_low~0.offset, 8);call write~init~int(128, ~#sensor_dev_attr_reset_high_low~0.base, 8 + ~#sensor_dev_attr_reset_high_low~0.offset, 4);call write~init~$Pointer$(0, 0, ~#sensor_dev_attr_reset_high_low~0.base, 12 + ~#sensor_dev_attr_reset_high_low~0.offset, 8);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 20 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 21 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 22 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 23 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 24 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 25 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 26 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 27 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~$Pointer$(0, 0, ~#sensor_dev_attr_reset_high_low~0.base, 28 + ~#sensor_dev_attr_reset_high_low~0.offset, 8);call write~init~$Pointer$(#funAddr~ibmpex_reset_high_low.base, #funAddr~ibmpex_reset_high_low.offset, ~#sensor_dev_attr_reset_high_low~0.base, 36 + ~#sensor_dev_attr_reset_high_low~0.offset, 8);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 44 + ~#sensor_dev_attr_reset_high_low~0.offset, 4);~LDV_IN_INTERRUPT~0 := 0;~ldv_count_1~0 := 0;~ldv_count_2~0 := 0;~ldv_call_dev_attr_of_sensor_device_attribute~0 := 0;~ldv_call_dev_attr_of_sensor_device_attribute_2~0 := 0; {33971#true} is VALID [2022-02-20 21:35:53,223 INFO L290 TraceCheckUtils]: 1: Hoare triple {33971#true} assume { :end_inline_ULTIMATE.init } true;assume { :begin_inline_main } true;havoc main_#res#1;havoc main_#t~ret236#1, main_#t~nondet237#1, main_#t~switch238#1, main_#t~nondet239#1, main_~var_ibmpex_register_bmc_17_p0~0#1, main_~var_group1~0#1.base, main_~var_group1~0#1.offset, main_~var_ibmpex_bmc_gone_19_p0~0#1, main_~#var_group2~0#1.base, main_~#var_group2~0#1.offset, main_~#var_ibmpex_msg_handler_20_p1~0#1.base, main_~#var_ibmpex_msg_handler_20_p1~0#1.offset, main_~tmp~17#1, main_~tmp___0~4#1, main_~tmp___1~2#1;havoc main_~var_ibmpex_register_bmc_17_p0~0#1;havoc main_~var_group1~0#1.base, main_~var_group1~0#1.offset;havoc main_~var_ibmpex_bmc_gone_19_p0~0#1;call main_~#var_group2~0#1.base, main_~#var_group2~0#1.offset := #Ultimate.allocOnStack(374);call main_~#var_ibmpex_msg_handler_20_p1~0#1.base, main_~#var_ibmpex_msg_handler_20_p1~0#1.offset := #Ultimate.allocOnStack(915);havoc main_~tmp~17#1;havoc main_~tmp___0~4#1;havoc main_~tmp___1~2#1;~LDV_IN_INTERRUPT~0 := 1;assume { :begin_inline_ldv_initialize } true;~ldv_count_1~0 := 1 + ~ldv_count_1~0;~ldv_count_1~0 := 1 + ~ldv_count_1~0;~ldv_count_1~0 := 1 + ~ldv_count_1~0;~ldv_count_1~0 := 1 + ~ldv_count_1~0;~ldv_count_1~0 := 1 + ~ldv_count_1~0;~ldv_count_1~0 := 1 + ~ldv_count_1~0; {33971#true} is VALID [2022-02-20 21:35:53,223 INFO L290 TraceCheckUtils]: 2: Hoare triple {33971#true} assume { :end_inline_ldv_initialize } true; {33971#true} is VALID [2022-02-20 21:35:53,223 INFO L272 TraceCheckUtils]: 3: Hoare triple {33971#true} call ldv_handler_precall(); {33971#true} is VALID [2022-02-20 21:35:53,223 INFO L290 TraceCheckUtils]: 4: Hoare triple {33971#true} assume true; {33971#true} is VALID [2022-02-20 21:35:53,224 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {33971#true} {33971#true} #612#return; {33971#true} is VALID [2022-02-20 21:35:53,224 INFO L290 TraceCheckUtils]: 6: Hoare triple {33971#true} assume { :begin_inline_ibmpex_init } true;havoc ibmpex_init_#res#1;havoc ibmpex_init_#t~ret231#1, ibmpex_init_~tmp~16#1;havoc ibmpex_init_~tmp~16#1;assume { :begin_inline_ipmi_smi_watcher_register } true;ipmi_smi_watcher_register_#in~arg0#1.base, ipmi_smi_watcher_register_#in~arg0#1.offset := ~#driver_data~0.base, 16 + ~#driver_data~0.offset;havoc ipmi_smi_watcher_register_#res#1;havoc ipmi_smi_watcher_register_#t~nondet252#1, ipmi_smi_watcher_register_~arg0#1.base, ipmi_smi_watcher_register_~arg0#1.offset;ipmi_smi_watcher_register_~arg0#1.base, ipmi_smi_watcher_register_~arg0#1.offset := ipmi_smi_watcher_register_#in~arg0#1.base, ipmi_smi_watcher_register_#in~arg0#1.offset;assume -2147483648 <= ipmi_smi_watcher_register_#t~nondet252#1 && ipmi_smi_watcher_register_#t~nondet252#1 <= 2147483647;ipmi_smi_watcher_register_#res#1 := ipmi_smi_watcher_register_#t~nondet252#1;havoc ipmi_smi_watcher_register_#t~nondet252#1; {33971#true} is VALID [2022-02-20 21:35:53,224 INFO L290 TraceCheckUtils]: 7: Hoare triple {33971#true} ibmpex_init_#t~ret231#1 := ipmi_smi_watcher_register_#res#1;assume { :end_inline_ipmi_smi_watcher_register } true;assume -2147483648 <= ibmpex_init_#t~ret231#1 && ibmpex_init_#t~ret231#1 <= 2147483647;ibmpex_init_~tmp~16#1 := ibmpex_init_#t~ret231#1;havoc ibmpex_init_#t~ret231#1;ibmpex_init_#res#1 := ibmpex_init_~tmp~16#1; {33971#true} is VALID [2022-02-20 21:35:53,224 INFO L290 TraceCheckUtils]: 8: Hoare triple {33971#true} main_#t~ret236#1 := ibmpex_init_#res#1;assume { :end_inline_ibmpex_init } true;assume -2147483648 <= main_#t~ret236#1 && main_#t~ret236#1 <= 2147483647;main_~tmp~17#1 := main_#t~ret236#1;havoc main_#t~ret236#1; {33971#true} is VALID [2022-02-20 21:35:53,224 INFO L290 TraceCheckUtils]: 9: Hoare triple {33971#true} assume !(0 != main_~tmp~17#1); {33971#true} is VALID [2022-02-20 21:35:53,225 INFO L290 TraceCheckUtils]: 10: Hoare triple {33971#true} assume -2147483648 <= main_#t~nondet239#1 && main_#t~nondet239#1 <= 2147483647;main_~tmp___1~2#1 := main_#t~nondet239#1;havoc main_#t~nondet239#1; {33971#true} is VALID [2022-02-20 21:35:53,225 INFO L290 TraceCheckUtils]: 11: Hoare triple {33971#true} assume 0 != main_~tmp___1~2#1; {33971#true} is VALID [2022-02-20 21:35:53,225 INFO L290 TraceCheckUtils]: 12: Hoare triple {33971#true} assume -2147483648 <= main_#t~nondet237#1 && main_#t~nondet237#1 <= 2147483647;main_~tmp___0~4#1 := main_#t~nondet237#1;havoc main_#t~nondet237#1;main_#t~switch238#1 := 0 == main_~tmp___0~4#1; {33971#true} is VALID [2022-02-20 21:35:53,225 INFO L290 TraceCheckUtils]: 13: Hoare triple {33971#true} assume main_#t~switch238#1; {33971#true} is VALID [2022-02-20 21:35:53,225 INFO L272 TraceCheckUtils]: 14: Hoare triple {33971#true} call ldv_handler_precall(); {33971#true} is VALID [2022-02-20 21:35:53,225 INFO L290 TraceCheckUtils]: 15: Hoare triple {33971#true} assume true; {33971#true} is VALID [2022-02-20 21:35:53,226 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {33971#true} {33971#true} #614#return; {33971#true} is VALID [2022-02-20 21:35:53,226 INFO L290 TraceCheckUtils]: 17: Hoare triple {33971#true} assume { :begin_inline_ibmpex_register_bmc } true;ibmpex_register_bmc_#in~iface#1, ibmpex_register_bmc_#in~dev#1.base, ibmpex_register_bmc_#in~dev#1.offset := main_~var_ibmpex_register_bmc_17_p0~0#1, main_~var_group1~0#1.base, main_~var_group1~0#1.offset;havoc ibmpex_register_bmc_#t~ret178#1.base, ibmpex_register_bmc_#t~ret178#1.offset, ibmpex_register_bmc_#t~nondet179#1, ibmpex_register_bmc_#t~mem180#1, ibmpex_register_bmc_#t~ret181#1, ibmpex_register_bmc_#t~nondet182#1, ibmpex_register_bmc_#t~mem183#1, ibmpex_register_bmc_#t~ret184#1, ibmpex_register_bmc_#t~mem185#1.base, ibmpex_register_bmc_#t~mem185#1.offset, ibmpex_register_bmc_#t~ret186#1.base, ibmpex_register_bmc_#t~ret186#1.offset, ibmpex_register_bmc_#t~mem187#1.base, ibmpex_register_bmc_#t~mem187#1.offset, ibmpex_register_bmc_#t~ret188#1, ibmpex_register_bmc_#t~nondet189#1, ibmpex_register_bmc_#t~mem190#1.base, ibmpex_register_bmc_#t~mem190#1.offset, ibmpex_register_bmc_#t~mem191#1, ibmpex_register_bmc_#t~ret192#1, ibmpex_register_bmc_#t~nondet193#1, ibmpex_register_bmc_#t~mem194#1.base, ibmpex_register_bmc_#t~mem194#1.offset, ibmpex_register_bmc_#t~mem195#1.base, ibmpex_register_bmc_#t~mem195#1.offset, ibmpex_register_bmc_#t~mem196#1.base, ibmpex_register_bmc_#t~mem196#1.offset, ibmpex_register_bmc_#t~ret197#1, ibmpex_register_bmc_~iface#1, ibmpex_register_bmc_~dev#1.base, ibmpex_register_bmc_~dev#1.offset, ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset, ibmpex_register_bmc_~err~4#1, ibmpex_register_bmc_~tmp~14#1.base, ibmpex_register_bmc_~tmp~14#1.offset, ibmpex_register_bmc_~#__key~1#1.base, ibmpex_register_bmc_~#__key~1#1.offset, ibmpex_register_bmc_~tmp___0~3#1;ibmpex_register_bmc_~iface#1 := ibmpex_register_bmc_#in~iface#1;ibmpex_register_bmc_~dev#1.base, ibmpex_register_bmc_~dev#1.offset := ibmpex_register_bmc_#in~dev#1.base, ibmpex_register_bmc_#in~dev#1.offset;havoc ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset;havoc ibmpex_register_bmc_~err~4#1;havoc ibmpex_register_bmc_~tmp~14#1.base, ibmpex_register_bmc_~tmp~14#1.offset;call ibmpex_register_bmc_~#__key~1#1.base, ibmpex_register_bmc_~#__key~1#1.offset := #Ultimate.allocOnStack(8);havoc ibmpex_register_bmc_~tmp___0~3#1; {33971#true} is VALID [2022-02-20 21:35:53,226 INFO L272 TraceCheckUtils]: 18: Hoare triple {33971#true} call ibmpex_register_bmc_#t~ret178#1.base, ibmpex_register_bmc_#t~ret178#1.offset := kzalloc(968, 208); {34062#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:53,227 INFO L290 TraceCheckUtils]: 19: Hoare triple {34062#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size;~flags := #in~flags;havoc ~tmp~2.base, ~tmp~2.offset; {33971#true} is VALID [2022-02-20 21:35:53,227 INFO L272 TraceCheckUtils]: 20: Hoare triple {33971#true} call #t~ret40.base, #t~ret40.offset := kmalloc(~size, ~bitwiseOr(~flags, 32768)); {34062#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:53,227 INFO L290 TraceCheckUtils]: 21: Hoare triple {34062#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {33971#true} is VALID [2022-02-20 21:35:53,228 INFO L272 TraceCheckUtils]: 22: Hoare triple {33971#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {34062#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:53,228 INFO L290 TraceCheckUtils]: 23: Hoare triple {34062#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {33971#true} is VALID [2022-02-20 21:35:53,228 INFO L290 TraceCheckUtils]: 24: Hoare triple {33971#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {33971#true} is VALID [2022-02-20 21:35:53,228 INFO L290 TraceCheckUtils]: 25: Hoare triple {33971#true} assume true; {33971#true} is VALID [2022-02-20 21:35:53,229 INFO L284 TraceCheckUtils]: 26: Hoare quadruple {33971#true} {33971#true} #590#return; {33971#true} is VALID [2022-02-20 21:35:53,229 INFO L290 TraceCheckUtils]: 27: Hoare triple {33971#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {33971#true} is VALID [2022-02-20 21:35:53,229 INFO L290 TraceCheckUtils]: 28: Hoare triple {33971#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {33971#true} is VALID [2022-02-20 21:35:53,229 INFO L290 TraceCheckUtils]: 29: Hoare triple {33971#true} assume true; {33971#true} is VALID [2022-02-20 21:35:53,229 INFO L284 TraceCheckUtils]: 30: Hoare quadruple {33971#true} {33971#true} #588#return; {33971#true} is VALID [2022-02-20 21:35:53,229 INFO L290 TraceCheckUtils]: 31: Hoare triple {33971#true} ~tmp~2.base, ~tmp~2.offset := #t~ret40.base, #t~ret40.offset;havoc #t~ret40.base, #t~ret40.offset;#res.base, #res.offset := ~tmp~2.base, ~tmp~2.offset; {33971#true} is VALID [2022-02-20 21:35:53,230 INFO L290 TraceCheckUtils]: 32: Hoare triple {33971#true} assume true; {33971#true} is VALID [2022-02-20 21:35:53,230 INFO L284 TraceCheckUtils]: 33: Hoare quadruple {33971#true} {33971#true} #616#return; {33971#true} is VALID [2022-02-20 21:35:53,230 INFO L290 TraceCheckUtils]: 34: Hoare triple {33971#true} ibmpex_register_bmc_~tmp~14#1.base, ibmpex_register_bmc_~tmp~14#1.offset := ibmpex_register_bmc_#t~ret178#1.base, ibmpex_register_bmc_#t~ret178#1.offset;havoc ibmpex_register_bmc_#t~ret178#1.base, ibmpex_register_bmc_#t~ret178#1.offset;ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset := ibmpex_register_bmc_~tmp~14#1.base, ibmpex_register_bmc_~tmp~14#1.offset; {33971#true} is VALID [2022-02-20 21:35:53,230 INFO L290 TraceCheckUtils]: 35: Hoare triple {33971#true} assume !(0 == (ibmpex_register_bmc_~data~2#1.base + ibmpex_register_bmc_~data~2#1.offset) % 18446744073709551616);call write~int(12, ibmpex_register_bmc_~data~2#1.base, 193 + ibmpex_register_bmc_~data~2#1.offset, 4);call write~int(15, ibmpex_register_bmc_~data~2#1.base, 197 + ibmpex_register_bmc_~data~2#1.offset, 2);call write~int(0, ibmpex_register_bmc_~data~2#1.base, 199 + ibmpex_register_bmc_~data~2#1.offset, 1);call write~int(ibmpex_register_bmc_~iface#1, ibmpex_register_bmc_~data~2#1.base, 323 + ibmpex_register_bmc_~data~2#1.offset, 4);call write~$Pointer$(ibmpex_register_bmc_~dev#1.base, ibmpex_register_bmc_~dev#1.offset, ibmpex_register_bmc_~data~2#1.base, 24 + ibmpex_register_bmc_~data~2#1.offset, 8);call ibmpex_register_bmc_#t~mem180#1 := read~int(ibmpex_register_bmc_~data~2#1.base, 323 + ibmpex_register_bmc_~data~2#1.offset, 4);assume { :begin_inline_ipmi_create_user } true;ipmi_create_user_#in~arg0#1, ipmi_create_user_#in~arg1#1.base, ipmi_create_user_#in~arg1#1.offset, ipmi_create_user_#in~arg2#1.base, ipmi_create_user_#in~arg2#1.offset, ipmi_create_user_#in~arg3#1.base, ipmi_create_user_#in~arg3#1.offset := ibmpex_register_bmc_#t~mem180#1, ~#driver_data~0.base, 56 + ~#driver_data~0.offset, ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset, ibmpex_register_bmc_~data~2#1.base, 315 + ibmpex_register_bmc_~data~2#1.offset;havoc ipmi_create_user_#res#1;havoc ipmi_create_user_#t~nondet249#1, ipmi_create_user_~arg0#1, ipmi_create_user_~arg1#1.base, ipmi_create_user_~arg1#1.offset, ipmi_create_user_~arg2#1.base, ipmi_create_user_~arg2#1.offset, ipmi_create_user_~arg3#1.base, ipmi_create_user_~arg3#1.offset;ipmi_create_user_~arg0#1 := ipmi_create_user_#in~arg0#1;ipmi_create_user_~arg1#1.base, ipmi_create_user_~arg1#1.offset := ipmi_create_user_#in~arg1#1.base, ipmi_create_user_#in~arg1#1.offset;ipmi_create_user_~arg2#1.base, ipmi_create_user_~arg2#1.offset := ipmi_create_user_#in~arg2#1.base, ipmi_create_user_#in~arg2#1.offset;ipmi_create_user_~arg3#1.base, ipmi_create_user_~arg3#1.offset := ipmi_create_user_#in~arg3#1.base, ipmi_create_user_#in~arg3#1.offset;assume -2147483648 <= ipmi_create_user_#t~nondet249#1 && ipmi_create_user_#t~nondet249#1 <= 2147483647;ipmi_create_user_#res#1 := ipmi_create_user_#t~nondet249#1;havoc ipmi_create_user_#t~nondet249#1; {33971#true} is VALID [2022-02-20 21:35:53,230 INFO L290 TraceCheckUtils]: 36: Hoare triple {33971#true} ibmpex_register_bmc_#t~ret181#1 := ipmi_create_user_#res#1;assume { :end_inline_ipmi_create_user } true;assume -2147483648 <= ibmpex_register_bmc_#t~ret181#1 && ibmpex_register_bmc_#t~ret181#1 <= 2147483647;ibmpex_register_bmc_~err~4#1 := ibmpex_register_bmc_#t~ret181#1;havoc ibmpex_register_bmc_#t~mem180#1;havoc ibmpex_register_bmc_#t~ret181#1; {33971#true} is VALID [2022-02-20 21:35:53,231 INFO L290 TraceCheckUtils]: 37: Hoare triple {33971#true} assume !(ibmpex_register_bmc_~err~4#1 < 0);assume { :begin_inline___mutex_init } true;__mutex_init_#in~arg0#1.base, __mutex_init_#in~arg0#1.offset, __mutex_init_#in~arg1#1.base, __mutex_init_#in~arg1#1.offset, __mutex_init_#in~arg2#1.base, __mutex_init_#in~arg2#1.offset := ibmpex_register_bmc_~data~2#1.base, 32 + ibmpex_register_bmc_~data~2#1.offset, 22, 0, ibmpex_register_bmc_~#__key~1#1.base, ibmpex_register_bmc_~#__key~1#1.offset;havoc __mutex_init_~arg0#1.base, __mutex_init_~arg0#1.offset, __mutex_init_~arg1#1.base, __mutex_init_~arg1#1.offset, __mutex_init_~arg2#1.base, __mutex_init_~arg2#1.offset;__mutex_init_~arg0#1.base, __mutex_init_~arg0#1.offset := __mutex_init_#in~arg0#1.base, __mutex_init_#in~arg0#1.offset;__mutex_init_~arg1#1.base, __mutex_init_~arg1#1.offset := __mutex_init_#in~arg1#1.base, __mutex_init_#in~arg1#1.offset;__mutex_init_~arg2#1.base, __mutex_init_~arg2#1.offset := __mutex_init_#in~arg2#1.base, __mutex_init_#in~arg2#1.offset; {33971#true} is VALID [2022-02-20 21:35:53,231 INFO L290 TraceCheckUtils]: 38: Hoare triple {33971#true} assume { :end_inline___mutex_init } true;call write~int(0, ibmpex_register_bmc_~data~2#1.base, 611 + ibmpex_register_bmc_~data~2#1.offset, 8);assume { :begin_inline_init_completion } true;init_completion_#in~x#1.base, init_completion_#in~x#1.offset := ibmpex_register_bmc_~data~2#1.base, 231 + ibmpex_register_bmc_~data~2#1.offset;havoc init_completion_~x#1.base, init_completion_~x#1.offset, init_completion_~#__key~0#1.base, init_completion_~#__key~0#1.offset;init_completion_~x#1.base, init_completion_~x#1.offset := init_completion_#in~x#1.base, init_completion_#in~x#1.offset;call init_completion_~#__key~0#1.base, init_completion_~#__key~0#1.offset := #Ultimate.allocOnStack(8);call write~int(0, init_completion_~x#1.base, init_completion_~x#1.offset, 4);assume { :begin_inline___init_waitqueue_head } true;__init_waitqueue_head_#in~arg0#1.base, __init_waitqueue_head_#in~arg0#1.offset, __init_waitqueue_head_#in~arg1#1.base, __init_waitqueue_head_#in~arg1#1.offset := init_completion_~x#1.base, 4 + init_completion_~x#1.offset, init_completion_~#__key~0#1.base, init_completion_~#__key~0#1.offset;havoc __init_waitqueue_head_~arg0#1.base, __init_waitqueue_head_~arg0#1.offset, __init_waitqueue_head_~arg1#1.base, __init_waitqueue_head_~arg1#1.offset;__init_waitqueue_head_~arg0#1.base, __init_waitqueue_head_~arg0#1.offset := __init_waitqueue_head_#in~arg0#1.base, __init_waitqueue_head_#in~arg0#1.offset;__init_waitqueue_head_~arg1#1.base, __init_waitqueue_head_~arg1#1.offset := __init_waitqueue_head_#in~arg1#1.base, __init_waitqueue_head_#in~arg1#1.offset; {33971#true} is VALID [2022-02-20 21:35:53,231 INFO L290 TraceCheckUtils]: 39: Hoare triple {33971#true} assume { :end_inline___init_waitqueue_head } true;call ULTIMATE.dealloc(init_completion_~#__key~0#1.base, init_completion_~#__key~0#1.offset);havoc init_completion_~#__key~0#1.base, init_completion_~#__key~0#1.offset; {33971#true} is VALID [2022-02-20 21:35:53,231 INFO L290 TraceCheckUtils]: 40: Hoare triple {33971#true} assume { :end_inline_init_completion } true;call write~int(58, ibmpex_register_bmc_~data~2#1.base, 327 + ibmpex_register_bmc_~data~2#1.offset, 1);call write~int(60, ibmpex_register_bmc_~data~2#1.base, 328 + ibmpex_register_bmc_~data~2#1.offset, 1);call write~$Pointer$(ibmpex_register_bmc_~data~2#1.base, 339 + ibmpex_register_bmc_~data~2#1.offset, ibmpex_register_bmc_~data~2#1.base, 331 + ibmpex_register_bmc_~data~2#1.offset, 8);assume { :begin_inline_ibmpex_ver_check } true;ibmpex_ver_check_#in~data#1.base, ibmpex_ver_check_#in~data#1.offset := ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset;havoc ibmpex_ver_check_#res#1;havoc ibmpex_ver_check_#t~ret71#1, ibmpex_ver_check_#t~mem72#1, ibmpex_ver_check_#t~mem73#1, ibmpex_ver_check_#t~short74#1, ibmpex_ver_check_#t~mem75#1, ibmpex_ver_check_#t~mem76#1, ibmpex_ver_check_#t~ret77#1, ibmpex_ver_check_#t~nondet78#1, ibmpex_ver_check_#t~mem79#1.base, ibmpex_ver_check_#t~mem79#1.offset, ibmpex_ver_check_#t~mem80#1, ibmpex_ver_check_#t~mem81#1, ibmpex_ver_check_#t~mem82#1, ibmpex_ver_check_#t~mem83#1, ibmpex_ver_check_#t~mem84#1, ibmpex_ver_check_~data#1.base, ibmpex_ver_check_~data#1.offset, ibmpex_ver_check_~tmp~4#1;ibmpex_ver_check_~data#1.base, ibmpex_ver_check_~data#1.offset := ibmpex_ver_check_#in~data#1.base, ibmpex_ver_check_#in~data#1.offset;havoc ibmpex_ver_check_~tmp~4#1;call write~int(1, ibmpex_ver_check_~data#1.base, 339 + ibmpex_ver_check_~data#1.offset, 1);call write~int(1, ibmpex_ver_check_~data#1.base, 329 + ibmpex_ver_check_~data#1.offset, 2); {33971#true} is VALID [2022-02-20 21:35:53,232 INFO L272 TraceCheckUtils]: 41: Hoare triple {33971#true} call ibmpex_ver_check_#t~ret71#1 := ibmpex_send_message(ibmpex_ver_check_~data#1.base, ibmpex_ver_check_~data#1.offset); {34077#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} is VALID [2022-02-20 21:35:53,232 INFO L290 TraceCheckUtils]: 42: Hoare triple {34077#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;havoc ~err~0#1;assume { :begin_inline_ipmi_validate_addr } true;ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset, ipmi_validate_addr_#in~arg1#1 := ~data#1.base, 193 + ~data#1.offset, 40;havoc ipmi_validate_addr_#res#1;havoc ipmi_validate_addr_#t~nondet254#1, ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset, ipmi_validate_addr_~arg1#1;ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset := ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset;ipmi_validate_addr_~arg1#1 := ipmi_validate_addr_#in~arg1#1;assume -2147483648 <= ipmi_validate_addr_#t~nondet254#1 && ipmi_validate_addr_#t~nondet254#1 <= 2147483647;ipmi_validate_addr_#res#1 := ipmi_validate_addr_#t~nondet254#1;havoc ipmi_validate_addr_#t~nondet254#1; {33971#true} is VALID [2022-02-20 21:35:53,232 INFO L290 TraceCheckUtils]: 43: Hoare triple {33971#true} #t~ret62#1 := ipmi_validate_addr_#res#1;assume { :end_inline_ipmi_validate_addr } true;assume -2147483648 <= #t~ret62#1 && #t~ret62#1 <= 2147483647;~err~0#1 := #t~ret62#1;havoc #t~ret62#1; {33971#true} is VALID [2022-02-20 21:35:53,232 INFO L290 TraceCheckUtils]: 44: Hoare triple {33971#true} assume 0 != ~err~0#1; {33971#true} is VALID [2022-02-20 21:35:53,233 INFO L290 TraceCheckUtils]: 45: Hoare triple {33971#true} havoc #t~nondet69#1;call #t~mem70#1.base, #t~mem70#1.offset := read~$Pointer$(~data#1.base, 24 + ~data#1.offset, 8);havoc #t~mem70#1.base, #t~mem70#1.offset;#res#1 := ~err~0#1; {33971#true} is VALID [2022-02-20 21:35:53,233 INFO L290 TraceCheckUtils]: 46: Hoare triple {33971#true} assume true; {33971#true} is VALID [2022-02-20 21:35:53,233 INFO L284 TraceCheckUtils]: 47: Hoare quadruple {33971#true} {33971#true} #618#return; {33971#true} is VALID [2022-02-20 21:35:53,233 INFO L290 TraceCheckUtils]: 48: Hoare triple {33971#true} assume -2147483648 <= ibmpex_ver_check_#t~ret71#1 && ibmpex_ver_check_#t~ret71#1 <= 2147483647;havoc ibmpex_ver_check_#t~ret71#1; {33971#true} is VALID [2022-02-20 21:35:53,233 INFO L272 TraceCheckUtils]: 49: Hoare triple {33971#true} call wait_for_completion(ibmpex_ver_check_~data#1.base, 231 + ibmpex_ver_check_~data#1.offset); {33971#true} is VALID [2022-02-20 21:35:53,234 INFO L290 TraceCheckUtils]: 50: Hoare triple {33971#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset; {33971#true} is VALID [2022-02-20 21:35:53,235 INFO L290 TraceCheckUtils]: 51: Hoare triple {33971#true} assume true; {33971#true} is VALID [2022-02-20 21:35:53,235 INFO L284 TraceCheckUtils]: 52: Hoare quadruple {33971#true} {33971#true} #620#return; {33971#true} is VALID [2022-02-20 21:35:53,235 INFO L290 TraceCheckUtils]: 53: Hoare triple {33971#true} call ibmpex_ver_check_#t~mem72#1 := read~int(ibmpex_ver_check_~data#1.base, 899 + ibmpex_ver_check_~data#1.offset, 1);ibmpex_ver_check_#t~short74#1 := 0 != ibmpex_ver_check_#t~mem72#1 % 256 % 4294967296; {33971#true} is VALID [2022-02-20 21:35:53,235 INFO L290 TraceCheckUtils]: 54: Hoare triple {33971#true} assume !ibmpex_ver_check_#t~short74#1;call ibmpex_ver_check_#t~mem73#1 := read~int(ibmpex_ver_check_~data#1.base, 891 + ibmpex_ver_check_~data#1.offset, 8);ibmpex_ver_check_#t~short74#1 := 6 != ibmpex_ver_check_#t~mem73#1 % 18446744073709551616; {33971#true} is VALID [2022-02-20 21:35:53,235 INFO L290 TraceCheckUtils]: 55: Hoare triple {33971#true} assume !ibmpex_ver_check_#t~short74#1;havoc ibmpex_ver_check_#t~mem72#1;havoc ibmpex_ver_check_#t~mem73#1;havoc ibmpex_ver_check_#t~short74#1;call ibmpex_ver_check_#t~mem75#1 := read~int(ibmpex_ver_check_~data#1.base, 619 + ibmpex_ver_check_~data#1.offset, 1);call write~int(ibmpex_ver_check_#t~mem75#1, ibmpex_ver_check_~data#1.base, 904 + ibmpex_ver_check_~data#1.offset, 1);havoc ibmpex_ver_check_#t~mem75#1;call ibmpex_ver_check_#t~mem76#1 := read~int(ibmpex_ver_check_~data#1.base, 620 + ibmpex_ver_check_~data#1.offset, 1);call write~int(ibmpex_ver_check_#t~mem76#1, ibmpex_ver_check_~data#1.base, 905 + ibmpex_ver_check_~data#1.offset, 1);havoc ibmpex_ver_check_#t~mem76#1; {33971#true} is VALID [2022-02-20 21:35:53,235 INFO L272 TraceCheckUtils]: 56: Hoare triple {33971#true} call ibmpex_ver_check_#t~ret77#1 := extract_value(ibmpex_ver_check_~data#1.base, 619 + ibmpex_ver_check_~data#1.offset, 2); {33971#true} is VALID [2022-02-20 21:35:53,236 INFO L290 TraceCheckUtils]: 57: Hoare triple {33971#true} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;~offset#1 := #in~offset#1;havoc ~tmp~3#1;assume { :begin_inline___be16_to_cpup } true;__be16_to_cpup_#in~p#1.base, __be16_to_cpup_#in~p#1.offset := ~data#1.base, ~data#1.offset + 2 * (if ~offset#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then ~offset#1 % 18446744073709551616 % 18446744073709551616 else ~offset#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616);havoc __be16_to_cpup_#res#1;havoc __be16_to_cpup_#t~ret3#1, __be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset, __be16_to_cpup_~tmp~1#1;__be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset := __be16_to_cpup_#in~p#1.base, __be16_to_cpup_#in~p#1.offset;havoc __be16_to_cpup_~tmp~1#1;assume { :begin_inline___swab16p } true;__swab16p_#in~p#1.base, __swab16p_#in~p#1.offset := __be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset;havoc __swab16p_#res#1;havoc __swab16p_#t~mem1#1, __swab16p_#t~ret2#1, __swab16p_~p#1.base, __swab16p_~p#1.offset, __swab16p_~tmp~0#1;__swab16p_~p#1.base, __swab16p_~p#1.offset := __swab16p_#in~p#1.base, __swab16p_#in~p#1.offset;havoc __swab16p_~tmp~0#1;call __swab16p_#t~mem1#1 := read~int(__swab16p_~p#1.base, __swab16p_~p#1.offset, 2);assume { :begin_inline___fswab16 } true;__fswab16_#in~val#1 := __swab16p_#t~mem1#1 % 65536;havoc __fswab16_#res#1;havoc __fswab16_~val#1;__fswab16_~val#1 := __fswab16_#in~val#1;__fswab16_#res#1 := (if (1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) || 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536)) && 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) then (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) else (if 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) && (1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) || 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536)) then (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) else (if (1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) && (1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) || 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536))) || ((1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) || 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536)) && 1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536)) then 1 else ~bitwiseOr((if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536), (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536))))); {33971#true} is VALID [2022-02-20 21:35:53,236 INFO L290 TraceCheckUtils]: 58: Hoare triple {33971#true} __swab16p_#t~ret2#1 := __fswab16_#res#1;assume { :end_inline___fswab16 } true;__swab16p_~tmp~0#1 := __swab16p_#t~ret2#1;havoc __swab16p_#t~mem1#1;havoc __swab16p_#t~ret2#1;__swab16p_#res#1 := __swab16p_~tmp~0#1; {33971#true} is VALID [2022-02-20 21:35:53,236 INFO L290 TraceCheckUtils]: 59: Hoare triple {33971#true} __be16_to_cpup_#t~ret3#1 := __swab16p_#res#1;assume { :end_inline___swab16p } true;__be16_to_cpup_~tmp~1#1 := __be16_to_cpup_#t~ret3#1;havoc __be16_to_cpup_#t~ret3#1;__be16_to_cpup_#res#1 := __be16_to_cpup_~tmp~1#1; {33971#true} is VALID [2022-02-20 21:35:53,236 INFO L290 TraceCheckUtils]: 60: Hoare triple {33971#true} #t~ret61#1 := __be16_to_cpup_#res#1;assume { :end_inline___be16_to_cpup } true;~tmp~3#1 := #t~ret61#1;havoc #t~ret61#1;#res#1 := ~tmp~3#1; {33971#true} is VALID [2022-02-20 21:35:53,236 INFO L290 TraceCheckUtils]: 61: Hoare triple {33971#true} assume true; {33971#true} is VALID [2022-02-20 21:35:53,237 INFO L284 TraceCheckUtils]: 62: Hoare quadruple {33971#true} {33971#true} #622#return; {33971#true} is VALID [2022-02-20 21:35:53,237 INFO L290 TraceCheckUtils]: 63: Hoare triple {33971#true} ibmpex_ver_check_~tmp~4#1 := ibmpex_ver_check_#t~ret77#1;havoc ibmpex_ver_check_#t~ret77#1;havoc ibmpex_ver_check_#t~nondet78#1;call ibmpex_ver_check_#t~mem79#1.base, ibmpex_ver_check_#t~mem79#1.offset := read~$Pointer$(ibmpex_ver_check_~data#1.base, 24 + ibmpex_ver_check_~data#1.offset, 8);call ibmpex_ver_check_#t~mem80#1 := read~int(ibmpex_ver_check_~data#1.base, 904 + ibmpex_ver_check_~data#1.offset, 1);call ibmpex_ver_check_#t~mem81#1 := read~int(ibmpex_ver_check_~data#1.base, 905 + ibmpex_ver_check_~data#1.offset, 1);call ibmpex_ver_check_#t~mem82#1 := read~int(ibmpex_ver_check_~data#1.base, 623 + ibmpex_ver_check_~data#1.offset, 1);call ibmpex_ver_check_#t~mem83#1 := read~int(ibmpex_ver_check_~data#1.base, 624 + ibmpex_ver_check_~data#1.offset, 1);call ibmpex_ver_check_#t~mem84#1 := read~int(ibmpex_ver_check_~data#1.base, 323 + ibmpex_ver_check_~data#1.offset, 4);havoc ibmpex_ver_check_#t~mem79#1.base, ibmpex_ver_check_#t~mem79#1.offset;havoc ibmpex_ver_check_#t~mem80#1;havoc ibmpex_ver_check_#t~mem81#1;havoc ibmpex_ver_check_#t~mem82#1;havoc ibmpex_ver_check_#t~mem83#1;havoc ibmpex_ver_check_#t~mem84#1;ibmpex_ver_check_#res#1 := 0; {33971#true} is VALID [2022-02-20 21:35:53,237 INFO L290 TraceCheckUtils]: 64: Hoare triple {33971#true} ibmpex_register_bmc_#t~ret184#1 := ibmpex_ver_check_#res#1;assume { :end_inline_ibmpex_ver_check } true;assume -2147483648 <= ibmpex_register_bmc_#t~ret184#1 && ibmpex_register_bmc_#t~ret184#1 <= 2147483647;ibmpex_register_bmc_~err~4#1 := ibmpex_register_bmc_#t~ret184#1;havoc ibmpex_register_bmc_#t~ret184#1; {33971#true} is VALID [2022-02-20 21:35:53,237 INFO L290 TraceCheckUtils]: 65: Hoare triple {33971#true} assume !(0 != ibmpex_register_bmc_~err~4#1);call ibmpex_register_bmc_#t~mem185#1.base, ibmpex_register_bmc_#t~mem185#1.offset := read~$Pointer$(ibmpex_register_bmc_~data~2#1.base, 24 + ibmpex_register_bmc_~data~2#1.offset, 8);assume { :begin_inline_hwmon_device_register } true;hwmon_device_register_#in~arg0#1.base, hwmon_device_register_#in~arg0#1.offset := ibmpex_register_bmc_#t~mem185#1.base, ibmpex_register_bmc_#t~mem185#1.offset;havoc hwmon_device_register_#res#1.base, hwmon_device_register_#res#1.offset;havoc hwmon_device_register_#t~ret248#1.base, hwmon_device_register_#t~ret248#1.offset, hwmon_device_register_~arg0#1.base, hwmon_device_register_~arg0#1.offset;hwmon_device_register_~arg0#1.base, hwmon_device_register_~arg0#1.offset := hwmon_device_register_#in~arg0#1.base, hwmon_device_register_#in~arg0#1.offset; {33971#true} is VALID [2022-02-20 21:35:53,238 INFO L272 TraceCheckUtils]: 66: Hoare triple {33971#true} call hwmon_device_register_#t~ret248#1.base, hwmon_device_register_#t~ret248#1.offset := ldv_malloc(1035); {34062#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:53,238 INFO L290 TraceCheckUtils]: 67: Hoare triple {34062#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {33971#true} is VALID [2022-02-20 21:35:53,238 INFO L290 TraceCheckUtils]: 68: Hoare triple {33971#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {33971#true} is VALID [2022-02-20 21:35:53,238 INFO L290 TraceCheckUtils]: 69: Hoare triple {33971#true} assume true; {33971#true} is VALID [2022-02-20 21:35:53,238 INFO L284 TraceCheckUtils]: 70: Hoare quadruple {33971#true} {33971#true} #624#return; {33971#true} is VALID [2022-02-20 21:35:53,238 INFO L290 TraceCheckUtils]: 71: Hoare triple {33971#true} hwmon_device_register_#res#1.base, hwmon_device_register_#res#1.offset := hwmon_device_register_#t~ret248#1.base, hwmon_device_register_#t~ret248#1.offset;havoc hwmon_device_register_#t~ret248#1.base, hwmon_device_register_#t~ret248#1.offset; {33971#true} is VALID [2022-02-20 21:35:53,239 INFO L290 TraceCheckUtils]: 72: Hoare triple {33971#true} ibmpex_register_bmc_#t~ret186#1.base, ibmpex_register_bmc_#t~ret186#1.offset := hwmon_device_register_#res#1.base, hwmon_device_register_#res#1.offset;assume { :end_inline_hwmon_device_register } true;call write~$Pointer$(ibmpex_register_bmc_#t~ret186#1.base, ibmpex_register_bmc_#t~ret186#1.offset, ibmpex_register_bmc_~data~2#1.base, 16 + ibmpex_register_bmc_~data~2#1.offset, 8);havoc ibmpex_register_bmc_#t~mem185#1.base, ibmpex_register_bmc_#t~mem185#1.offset;havoc ibmpex_register_bmc_#t~ret186#1.base, ibmpex_register_bmc_#t~ret186#1.offset;call ibmpex_register_bmc_#t~mem187#1.base, ibmpex_register_bmc_#t~mem187#1.offset := read~$Pointer$(ibmpex_register_bmc_~data~2#1.base, 16 + ibmpex_register_bmc_~data~2#1.offset, 8);assume { :begin_inline_IS_ERR } true;IS_ERR_#in~ptr#1.base, IS_ERR_#in~ptr#1.offset := ibmpex_register_bmc_#t~mem187#1.base, ibmpex_register_bmc_#t~mem187#1.offset;havoc IS_ERR_#res#1;havoc IS_ERR_#t~ret240#1, IS_ERR_~ptr#1.base, IS_ERR_~ptr#1.offset, IS_ERR_~tmp~18#1;IS_ERR_~ptr#1.base, IS_ERR_~ptr#1.offset := IS_ERR_#in~ptr#1.base, IS_ERR_#in~ptr#1.offset;havoc IS_ERR_~tmp~18#1; {33971#true} is VALID [2022-02-20 21:35:53,239 INFO L272 TraceCheckUtils]: 73: Hoare triple {33971#true} call IS_ERR_#t~ret240#1 := ldv_is_err(IS_ERR_~ptr#1.base, IS_ERR_~ptr#1.offset); {33971#true} is VALID [2022-02-20 21:35:53,239 INFO L290 TraceCheckUtils]: 74: Hoare triple {33971#true} ~ptr.base, ~ptr.offset := #in~ptr.base, #in~ptr.offset;#res := (if (~ptr.base + ~ptr.offset) % 18446744073709551616 > 2012 then 1 else 0); {33971#true} is VALID [2022-02-20 21:35:53,239 INFO L290 TraceCheckUtils]: 75: Hoare triple {33971#true} assume true; {33971#true} is VALID [2022-02-20 21:35:53,239 INFO L284 TraceCheckUtils]: 76: Hoare quadruple {33971#true} {33971#true} #626#return; {33971#true} is VALID [2022-02-20 21:35:53,240 INFO L290 TraceCheckUtils]: 77: Hoare triple {33971#true} assume -9223372036854775808 <= IS_ERR_#t~ret240#1 && IS_ERR_#t~ret240#1 <= 9223372036854775807;IS_ERR_~tmp~18#1 := IS_ERR_#t~ret240#1;havoc IS_ERR_#t~ret240#1;IS_ERR_#res#1 := IS_ERR_~tmp~18#1; {33971#true} is VALID [2022-02-20 21:35:53,240 INFO L290 TraceCheckUtils]: 78: Hoare triple {33971#true} ibmpex_register_bmc_#t~ret188#1 := IS_ERR_#res#1;assume { :end_inline_IS_ERR } true;assume -9223372036854775808 <= ibmpex_register_bmc_#t~ret188#1 && ibmpex_register_bmc_#t~ret188#1 <= 9223372036854775807;ibmpex_register_bmc_~tmp___0~3#1 := ibmpex_register_bmc_#t~ret188#1;havoc ibmpex_register_bmc_#t~mem187#1.base, ibmpex_register_bmc_#t~mem187#1.offset;havoc ibmpex_register_bmc_#t~ret188#1; {33971#true} is VALID [2022-02-20 21:35:53,240 INFO L290 TraceCheckUtils]: 79: Hoare triple {33971#true} assume !(0 != ibmpex_register_bmc_~tmp___0~3#1); {33971#true} is VALID [2022-02-20 21:35:53,240 INFO L272 TraceCheckUtils]: 80: Hoare triple {33971#true} call dev_set_drvdata(ibmpex_register_bmc_~dev#1.base, ibmpex_register_bmc_~dev#1.offset, ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset); {33971#true} is VALID [2022-02-20 21:35:53,240 INFO L290 TraceCheckUtils]: 81: Hoare triple {33971#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset;~arg1.base, ~arg1.offset := #in~arg1.base, #in~arg1.offset; {33971#true} is VALID [2022-02-20 21:35:53,240 INFO L290 TraceCheckUtils]: 82: Hoare triple {33971#true} assume true; {33971#true} is VALID [2022-02-20 21:35:53,241 INFO L284 TraceCheckUtils]: 83: Hoare quadruple {33971#true} {33971#true} #628#return; {33971#true} is VALID [2022-02-20 21:35:53,241 INFO L290 TraceCheckUtils]: 84: Hoare triple {33971#true} assume { :begin_inline_list_add_tail } true;list_add_tail_#in~new#1.base, list_add_tail_#in~new#1.offset, list_add_tail_#in~head#1.base, list_add_tail_#in~head#1.offset := ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset, ~#driver_data~0.base, ~#driver_data~0.offset;havoc list_add_tail_#t~mem12#1.base, list_add_tail_#t~mem12#1.offset, list_add_tail_~new#1.base, list_add_tail_~new#1.offset, list_add_tail_~head#1.base, list_add_tail_~head#1.offset;list_add_tail_~new#1.base, list_add_tail_~new#1.offset := list_add_tail_#in~new#1.base, list_add_tail_#in~new#1.offset;list_add_tail_~head#1.base, list_add_tail_~head#1.offset := list_add_tail_#in~head#1.base, list_add_tail_#in~head#1.offset;call list_add_tail_#t~mem12#1.base, list_add_tail_#t~mem12#1.offset := read~$Pointer$(list_add_tail_~head#1.base, 8 + list_add_tail_~head#1.offset, 8);assume { :begin_inline___list_add } true;__list_add_#in~arg0#1.base, __list_add_#in~arg0#1.offset, __list_add_#in~arg1#1.base, __list_add_#in~arg1#1.offset, __list_add_#in~arg2#1.base, __list_add_#in~arg2#1.offset := list_add_tail_~new#1.base, list_add_tail_~new#1.offset, list_add_tail_#t~mem12#1.base, list_add_tail_#t~mem12#1.offset, list_add_tail_~head#1.base, list_add_tail_~head#1.offset;havoc __list_add_~arg0#1.base, __list_add_~arg0#1.offset, __list_add_~arg1#1.base, __list_add_~arg1#1.offset, __list_add_~arg2#1.base, __list_add_~arg2#1.offset;__list_add_~arg0#1.base, __list_add_~arg0#1.offset := __list_add_#in~arg0#1.base, __list_add_#in~arg0#1.offset;__list_add_~arg1#1.base, __list_add_~arg1#1.offset := __list_add_#in~arg1#1.base, __list_add_#in~arg1#1.offset;__list_add_~arg2#1.base, __list_add_~arg2#1.offset := __list_add_#in~arg2#1.base, __list_add_#in~arg2#1.offset; {33971#true} is VALID [2022-02-20 21:35:53,241 INFO L290 TraceCheckUtils]: 85: Hoare triple {33971#true} assume { :end_inline___list_add } true;havoc list_add_tail_#t~mem12#1.base, list_add_tail_#t~mem12#1.offset; {33971#true} is VALID [2022-02-20 21:35:53,241 INFO L290 TraceCheckUtils]: 86: Hoare triple {33971#true} assume { :end_inline_list_add_tail } true;assume { :begin_inline_ibmpex_find_sensors } true;ibmpex_find_sensors_#in~data#1.base, ibmpex_find_sensors_#in~data#1.offset := ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset;havoc ibmpex_find_sensors_#res#1;havoc ibmpex_find_sensors_#t~ret148#1, ibmpex_find_sensors_#t~mem149#1, ibmpex_find_sensors_#t~ret150#1.base, ibmpex_find_sensors_#t~ret150#1.offset, ibmpex_find_sensors_#t~mem151#1.base, ibmpex_find_sensors_#t~mem151#1.offset, ibmpex_find_sensors_#t~ret152#1, ibmpex_find_sensors_#t~mem153#1, ibmpex_find_sensors_#t~ret154#1, ibmpex_find_sensors_#t~mem155#1.base, ibmpex_find_sensors_#t~mem155#1.offset, ibmpex_find_sensors_#t~mem156#1, ibmpex_find_sensors_#t~ret157#1, ibmpex_find_sensors_#t~mem158#1, ibmpex_find_sensors_#t~ret159#1, ibmpex_find_sensors_#t~mem160#1.base, ibmpex_find_sensors_#t~mem160#1.offset, ibmpex_find_sensors_#t~mem161#1.base, ibmpex_find_sensors_#t~mem161#1.offset, ibmpex_find_sensors_#t~ret162#1, ibmpex_find_sensors_#t~mem163#1, ibmpex_find_sensors_#t~mem164#1.base, ibmpex_find_sensors_#t~mem164#1.offset, ibmpex_find_sensors_#t~ret165#1, ibmpex_find_sensors_#t~mem166#1.base, ibmpex_find_sensors_#t~mem166#1.offset, ibmpex_find_sensors_#t~ret167#1, ibmpex_find_sensors_#t~mem168#1.base, ibmpex_find_sensors_#t~mem168#1.offset, ibmpex_find_sensors_#t~mem169#1.base, ibmpex_find_sensors_#t~mem169#1.offset, ibmpex_find_sensors_#t~mem170#1.base, ibmpex_find_sensors_#t~mem170#1.offset, ibmpex_find_sensors_#t~mem171#1.base, ibmpex_find_sensors_#t~mem171#1.offset, ibmpex_find_sensors_#t~mem172#1.base, ibmpex_find_sensors_#t~mem172#1.offset, ibmpex_find_sensors_#t~mem173#1.base, ibmpex_find_sensors_#t~mem173#1.offset, ibmpex_find_sensors_#t~mem174#1.base, ibmpex_find_sensors_#t~mem174#1.offset, ibmpex_find_sensors_#t~mem175#1.base, ibmpex_find_sensors_#t~mem175#1.offset, ibmpex_find_sensors_#t~mem176#1, ibmpex_find_sensors_#t~mem177#1.base, ibmpex_find_sensors_#t~mem177#1.offset, ibmpex_find_sensors_~data#1.base, ibmpex_find_sensors_~data#1.offset, ibmpex_find_sensors_~i~2#1, ibmpex_find_sensors_~j~0#1, ibmpex_find_sensors_~err~3#1, ibmpex_find_sensors_~sensor_type~0#1, ibmpex_find_sensors_~sensor_counter~0#1, ibmpex_find_sensors_~num_power~0#1, ibmpex_find_sensors_~num_temp~0#1, ibmpex_find_sensors_~tmp~13#1.base, ibmpex_find_sensors_~tmp~13#1.offset, ibmpex_find_sensors_~tmp___0~2#1, ibmpex_find_sensors_~tmp___1~1#1;ibmpex_find_sensors_~data#1.base, ibmpex_find_sensors_~data#1.offset := ibmpex_find_sensors_#in~data#1.base, ibmpex_find_sensors_#in~data#1.offset;havoc ibmpex_find_sensors_~i~2#1;havoc ibmpex_find_sensors_~j~0#1;havoc ibmpex_find_sensors_~err~3#1;havoc ibmpex_find_sensors_~sensor_type~0#1;havoc ibmpex_find_sensors_~sensor_counter~0#1;havoc ibmpex_find_sensors_~num_power~0#1;havoc ibmpex_find_sensors_~num_temp~0#1;havoc ibmpex_find_sensors_~tmp~13#1.base, ibmpex_find_sensors_~tmp~13#1.offset;havoc ibmpex_find_sensors_~tmp___0~2#1;havoc ibmpex_find_sensors_~tmp___1~1#1;ibmpex_find_sensors_~num_power~0#1 := 0;ibmpex_find_sensors_~num_temp~0#1 := 0;assume { :begin_inline_ibmpex_query_sensor_count } true;ibmpex_query_sensor_count_#in~data#1.base, ibmpex_query_sensor_count_#in~data#1.offset := ibmpex_find_sensors_~data#1.base, ibmpex_find_sensors_~data#1.offset;havoc ibmpex_query_sensor_count_#res#1;havoc ibmpex_query_sensor_count_#t~ret85#1, ibmpex_query_sensor_count_#t~mem86#1, ibmpex_query_sensor_count_#t~mem87#1, ibmpex_query_sensor_count_#t~short88#1, ibmpex_query_sensor_count_#t~mem89#1, ibmpex_query_sensor_count_~data#1.base, ibmpex_query_sensor_count_~data#1.offset;ibmpex_query_sensor_count_~data#1.base, ibmpex_query_sensor_count_~data#1.offset := ibmpex_query_sensor_count_#in~data#1.base, ibmpex_query_sensor_count_#in~data#1.offset;call write~int(2, ibmpex_query_sensor_count_~data#1.base, 339 + ibmpex_query_sensor_count_~data#1.offset, 1);call write~int(1, ibmpex_query_sensor_count_~data#1.base, 329 + ibmpex_query_sensor_count_~data#1.offset, 2); {33971#true} is VALID [2022-02-20 21:35:53,242 INFO L272 TraceCheckUtils]: 87: Hoare triple {33971#true} call ibmpex_query_sensor_count_#t~ret85#1 := ibmpex_send_message(ibmpex_query_sensor_count_~data#1.base, ibmpex_query_sensor_count_~data#1.offset); {34077#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} is VALID [2022-02-20 21:35:53,242 INFO L290 TraceCheckUtils]: 88: Hoare triple {34077#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;havoc ~err~0#1;assume { :begin_inline_ipmi_validate_addr } true;ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset, ipmi_validate_addr_#in~arg1#1 := ~data#1.base, 193 + ~data#1.offset, 40;havoc ipmi_validate_addr_#res#1;havoc ipmi_validate_addr_#t~nondet254#1, ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset, ipmi_validate_addr_~arg1#1;ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset := ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset;ipmi_validate_addr_~arg1#1 := ipmi_validate_addr_#in~arg1#1;assume -2147483648 <= ipmi_validate_addr_#t~nondet254#1 && ipmi_validate_addr_#t~nondet254#1 <= 2147483647;ipmi_validate_addr_#res#1 := ipmi_validate_addr_#t~nondet254#1;havoc ipmi_validate_addr_#t~nondet254#1; {33971#true} is VALID [2022-02-20 21:35:53,242 INFO L290 TraceCheckUtils]: 89: Hoare triple {33971#true} #t~ret62#1 := ipmi_validate_addr_#res#1;assume { :end_inline_ipmi_validate_addr } true;assume -2147483648 <= #t~ret62#1 && #t~ret62#1 <= 2147483647;~err~0#1 := #t~ret62#1;havoc #t~ret62#1; {33971#true} is VALID [2022-02-20 21:35:53,243 INFO L290 TraceCheckUtils]: 90: Hoare triple {33971#true} assume 0 != ~err~0#1; {33971#true} is VALID [2022-02-20 21:35:53,243 INFO L290 TraceCheckUtils]: 91: Hoare triple {33971#true} havoc #t~nondet69#1;call #t~mem70#1.base, #t~mem70#1.offset := read~$Pointer$(~data#1.base, 24 + ~data#1.offset, 8);havoc #t~mem70#1.base, #t~mem70#1.offset;#res#1 := ~err~0#1; {33971#true} is VALID [2022-02-20 21:35:53,243 INFO L290 TraceCheckUtils]: 92: Hoare triple {33971#true} assume true; {33971#true} is VALID [2022-02-20 21:35:53,243 INFO L284 TraceCheckUtils]: 93: Hoare quadruple {33971#true} {33971#true} #630#return; {33971#true} is VALID [2022-02-20 21:35:53,243 INFO L290 TraceCheckUtils]: 94: Hoare triple {33971#true} assume -2147483648 <= ibmpex_query_sensor_count_#t~ret85#1 && ibmpex_query_sensor_count_#t~ret85#1 <= 2147483647;havoc ibmpex_query_sensor_count_#t~ret85#1; {33971#true} is VALID [2022-02-20 21:35:53,243 INFO L272 TraceCheckUtils]: 95: Hoare triple {33971#true} call wait_for_completion(ibmpex_query_sensor_count_~data#1.base, 231 + ibmpex_query_sensor_count_~data#1.offset); {33971#true} is VALID [2022-02-20 21:35:53,244 INFO L290 TraceCheckUtils]: 96: Hoare triple {33971#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset; {33971#true} is VALID [2022-02-20 21:35:53,244 INFO L290 TraceCheckUtils]: 97: Hoare triple {33971#true} assume true; {33971#true} is VALID [2022-02-20 21:35:53,244 INFO L284 TraceCheckUtils]: 98: Hoare quadruple {33971#true} {33971#true} #632#return; {33971#true} is VALID [2022-02-20 21:35:53,244 INFO L290 TraceCheckUtils]: 99: Hoare triple {33971#true} call ibmpex_query_sensor_count_#t~mem86#1 := read~int(ibmpex_query_sensor_count_~data#1.base, 899 + ibmpex_query_sensor_count_~data#1.offset, 1);ibmpex_query_sensor_count_#t~short88#1 := 0 != ibmpex_query_sensor_count_#t~mem86#1 % 256 % 4294967296; {33971#true} is VALID [2022-02-20 21:35:53,244 INFO L290 TraceCheckUtils]: 100: Hoare triple {33971#true} assume !ibmpex_query_sensor_count_#t~short88#1;call ibmpex_query_sensor_count_#t~mem87#1 := read~int(ibmpex_query_sensor_count_~data#1.base, 891 + ibmpex_query_sensor_count_~data#1.offset, 8);ibmpex_query_sensor_count_#t~short88#1 := 1 != ibmpex_query_sensor_count_#t~mem87#1 % 18446744073709551616; {33971#true} is VALID [2022-02-20 21:35:53,244 INFO L290 TraceCheckUtils]: 101: Hoare triple {33971#true} assume !ibmpex_query_sensor_count_#t~short88#1;havoc ibmpex_query_sensor_count_#t~mem86#1;havoc ibmpex_query_sensor_count_#t~mem87#1;havoc ibmpex_query_sensor_count_#t~short88#1;call ibmpex_query_sensor_count_#t~mem89#1 := read~int(ibmpex_query_sensor_count_~data#1.base, 619 + ibmpex_query_sensor_count_~data#1.offset, 1);ibmpex_query_sensor_count_#res#1 := ibmpex_query_sensor_count_#t~mem89#1 % 256;havoc ibmpex_query_sensor_count_#t~mem89#1; {33971#true} is VALID [2022-02-20 21:35:53,245 INFO L290 TraceCheckUtils]: 102: Hoare triple {33971#true} ibmpex_find_sensors_#t~ret148#1 := ibmpex_query_sensor_count_#res#1;assume { :end_inline_ibmpex_query_sensor_count } true;assume -2147483648 <= ibmpex_find_sensors_#t~ret148#1 && ibmpex_find_sensors_#t~ret148#1 <= 2147483647;ibmpex_find_sensors_~err~3#1 := ibmpex_find_sensors_#t~ret148#1;havoc ibmpex_find_sensors_#t~ret148#1; {33971#true} is VALID [2022-02-20 21:35:53,245 INFO L290 TraceCheckUtils]: 103: Hoare triple {33971#true} assume !(ibmpex_find_sensors_~err~3#1 <= 0);call write~int(ibmpex_find_sensors_~err~3#1, ibmpex_find_sensors_~data#1.base, 906 + ibmpex_find_sensors_~data#1.offset, 1);call ibmpex_find_sensors_#t~mem149#1 := read~int(ibmpex_find_sensors_~data#1.base, 906 + ibmpex_find_sensors_~data#1.offset, 1); {33971#true} is VALID [2022-02-20 21:35:53,245 INFO L272 TraceCheckUtils]: 104: Hoare triple {33971#true} call ibmpex_find_sensors_#t~ret150#1.base, ibmpex_find_sensors_#t~ret150#1.offset := kzalloc(184 * (ibmpex_find_sensors_#t~mem149#1 % 256), 208); {34062#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:53,246 INFO L290 TraceCheckUtils]: 105: Hoare triple {34062#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size;~flags := #in~flags;havoc ~tmp~2.base, ~tmp~2.offset; {33971#true} is VALID [2022-02-20 21:35:53,246 INFO L272 TraceCheckUtils]: 106: Hoare triple {33971#true} call #t~ret40.base, #t~ret40.offset := kmalloc(~size, ~bitwiseOr(~flags, 32768)); {34062#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:53,246 INFO L290 TraceCheckUtils]: 107: Hoare triple {34062#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {33971#true} is VALID [2022-02-20 21:35:53,247 INFO L272 TraceCheckUtils]: 108: Hoare triple {33971#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {34062#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:53,247 INFO L290 TraceCheckUtils]: 109: Hoare triple {34062#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {33971#true} is VALID [2022-02-20 21:35:53,247 INFO L290 TraceCheckUtils]: 110: Hoare triple {33971#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {33971#true} is VALID [2022-02-20 21:35:53,248 INFO L290 TraceCheckUtils]: 111: Hoare triple {33971#true} assume true; {33971#true} is VALID [2022-02-20 21:35:53,248 INFO L284 TraceCheckUtils]: 112: Hoare quadruple {33971#true} {33971#true} #590#return; {33971#true} is VALID [2022-02-20 21:35:53,248 INFO L290 TraceCheckUtils]: 113: Hoare triple {33971#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {33971#true} is VALID [2022-02-20 21:35:53,248 INFO L290 TraceCheckUtils]: 114: Hoare triple {33971#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {33971#true} is VALID [2022-02-20 21:35:53,248 INFO L290 TraceCheckUtils]: 115: Hoare triple {33971#true} assume true; {33971#true} is VALID [2022-02-20 21:35:53,248 INFO L284 TraceCheckUtils]: 116: Hoare quadruple {33971#true} {33971#true} #588#return; {33971#true} is VALID [2022-02-20 21:35:53,249 INFO L290 TraceCheckUtils]: 117: Hoare triple {33971#true} ~tmp~2.base, ~tmp~2.offset := #t~ret40.base, #t~ret40.offset;havoc #t~ret40.base, #t~ret40.offset;#res.base, #res.offset := ~tmp~2.base, ~tmp~2.offset; {33971#true} is VALID [2022-02-20 21:35:53,249 INFO L290 TraceCheckUtils]: 118: Hoare triple {33971#true} assume true; {33971#true} is VALID [2022-02-20 21:35:53,249 INFO L284 TraceCheckUtils]: 119: Hoare quadruple {33971#true} {33971#true} #634#return; {33971#true} is VALID [2022-02-20 21:35:53,249 INFO L290 TraceCheckUtils]: 120: Hoare triple {33971#true} ibmpex_find_sensors_~tmp~13#1.base, ibmpex_find_sensors_~tmp~13#1.offset := ibmpex_find_sensors_#t~ret150#1.base, ibmpex_find_sensors_#t~ret150#1.offset;havoc ibmpex_find_sensors_#t~mem149#1;havoc ibmpex_find_sensors_#t~ret150#1.base, ibmpex_find_sensors_#t~ret150#1.offset;call write~$Pointer$(ibmpex_find_sensors_~tmp~13#1.base, ibmpex_find_sensors_~tmp~13#1.offset, ibmpex_find_sensors_~data#1.base, 907 + ibmpex_find_sensors_~data#1.offset, 8);call ibmpex_find_sensors_#t~mem151#1.base, ibmpex_find_sensors_#t~mem151#1.offset := read~$Pointer$(ibmpex_find_sensors_~data#1.base, 907 + ibmpex_find_sensors_~data#1.offset, 8); {33971#true} is VALID [2022-02-20 21:35:53,249 INFO L290 TraceCheckUtils]: 121: Hoare triple {33971#true} assume !(0 == (ibmpex_find_sensors_#t~mem151#1.base + ibmpex_find_sensors_#t~mem151#1.offset) % 18446744073709551616);havoc ibmpex_find_sensors_#t~mem151#1.base, ibmpex_find_sensors_#t~mem151#1.offset;ibmpex_find_sensors_~i~2#1 := 0; {33971#true} is VALID [2022-02-20 21:35:53,249 INFO L290 TraceCheckUtils]: 122: Hoare triple {33971#true} call ibmpex_find_sensors_#t~mem163#1 := read~int(ibmpex_find_sensors_~data#1.base, 906 + ibmpex_find_sensors_~data#1.offset, 1); {33971#true} is VALID [2022-02-20 21:35:53,250 INFO L290 TraceCheckUtils]: 123: Hoare triple {33971#true} assume ibmpex_find_sensors_#t~mem163#1 % 256 > ibmpex_find_sensors_~i~2#1;havoc ibmpex_find_sensors_#t~mem163#1; {33971#true} is VALID [2022-02-20 21:35:53,250 INFO L290 TraceCheckUtils]: 124: Hoare triple {33971#true} assume { :begin_inline_ibmpex_query_sensor_name } true;ibmpex_query_sensor_name_#in~data#1.base, ibmpex_query_sensor_name_#in~data#1.offset, ibmpex_query_sensor_name_#in~sensor#1 := ibmpex_find_sensors_~data#1.base, ibmpex_find_sensors_~data#1.offset, ibmpex_find_sensors_~i~2#1;havoc ibmpex_query_sensor_name_#res#1;havoc ibmpex_query_sensor_name_#t~ret90#1, ibmpex_query_sensor_name_#t~mem91#1, ibmpex_query_sensor_name_#t~mem92#1, ibmpex_query_sensor_name_#t~short93#1, ibmpex_query_sensor_name_~data#1.base, ibmpex_query_sensor_name_~data#1.offset, ibmpex_query_sensor_name_~sensor#1;ibmpex_query_sensor_name_~data#1.base, ibmpex_query_sensor_name_~data#1.offset := ibmpex_query_sensor_name_#in~data#1.base, ibmpex_query_sensor_name_#in~data#1.offset;ibmpex_query_sensor_name_~sensor#1 := ibmpex_query_sensor_name_#in~sensor#1;call write~int(3, ibmpex_query_sensor_name_~data#1.base, 339 + ibmpex_query_sensor_name_~data#1.offset, 1);call write~int(ibmpex_query_sensor_name_~sensor#1, ibmpex_query_sensor_name_~data#1.base, 340 + ibmpex_query_sensor_name_~data#1.offset, 1);call write~int(2, ibmpex_query_sensor_name_~data#1.base, 329 + ibmpex_query_sensor_name_~data#1.offset, 2); {33971#true} is VALID [2022-02-20 21:35:53,251 INFO L272 TraceCheckUtils]: 125: Hoare triple {33971#true} call ibmpex_query_sensor_name_#t~ret90#1 := ibmpex_send_message(ibmpex_query_sensor_name_~data#1.base, ibmpex_query_sensor_name_~data#1.offset); {34077#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} is VALID [2022-02-20 21:35:53,251 INFO L290 TraceCheckUtils]: 126: Hoare triple {34077#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;havoc ~err~0#1;assume { :begin_inline_ipmi_validate_addr } true;ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset, ipmi_validate_addr_#in~arg1#1 := ~data#1.base, 193 + ~data#1.offset, 40;havoc ipmi_validate_addr_#res#1;havoc ipmi_validate_addr_#t~nondet254#1, ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset, ipmi_validate_addr_~arg1#1;ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset := ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset;ipmi_validate_addr_~arg1#1 := ipmi_validate_addr_#in~arg1#1;assume -2147483648 <= ipmi_validate_addr_#t~nondet254#1 && ipmi_validate_addr_#t~nondet254#1 <= 2147483647;ipmi_validate_addr_#res#1 := ipmi_validate_addr_#t~nondet254#1;havoc ipmi_validate_addr_#t~nondet254#1; {33971#true} is VALID [2022-02-20 21:35:53,251 INFO L290 TraceCheckUtils]: 127: Hoare triple {33971#true} #t~ret62#1 := ipmi_validate_addr_#res#1;assume { :end_inline_ipmi_validate_addr } true;assume -2147483648 <= #t~ret62#1 && #t~ret62#1 <= 2147483647;~err~0#1 := #t~ret62#1;havoc #t~ret62#1; {33971#true} is VALID [2022-02-20 21:35:53,251 INFO L290 TraceCheckUtils]: 128: Hoare triple {33971#true} assume 0 != ~err~0#1; {33971#true} is VALID [2022-02-20 21:35:53,251 INFO L290 TraceCheckUtils]: 129: Hoare triple {33971#true} havoc #t~nondet69#1;call #t~mem70#1.base, #t~mem70#1.offset := read~$Pointer$(~data#1.base, 24 + ~data#1.offset, 8);havoc #t~mem70#1.base, #t~mem70#1.offset;#res#1 := ~err~0#1; {33971#true} is VALID [2022-02-20 21:35:53,252 INFO L290 TraceCheckUtils]: 130: Hoare triple {33971#true} assume true; {33971#true} is VALID [2022-02-20 21:35:53,252 INFO L284 TraceCheckUtils]: 131: Hoare quadruple {33971#true} {33971#true} #636#return; {33971#true} is VALID [2022-02-20 21:35:53,252 INFO L290 TraceCheckUtils]: 132: Hoare triple {33971#true} assume -2147483648 <= ibmpex_query_sensor_name_#t~ret90#1 && ibmpex_query_sensor_name_#t~ret90#1 <= 2147483647;havoc ibmpex_query_sensor_name_#t~ret90#1; {33971#true} is VALID [2022-02-20 21:35:53,252 INFO L272 TraceCheckUtils]: 133: Hoare triple {33971#true} call wait_for_completion(ibmpex_query_sensor_name_~data#1.base, 231 + ibmpex_query_sensor_name_~data#1.offset); {33971#true} is VALID [2022-02-20 21:35:53,252 INFO L290 TraceCheckUtils]: 134: Hoare triple {33971#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset; {33971#true} is VALID [2022-02-20 21:35:53,252 INFO L290 TraceCheckUtils]: 135: Hoare triple {33971#true} assume true; {33971#true} is VALID [2022-02-20 21:35:53,253 INFO L284 TraceCheckUtils]: 136: Hoare quadruple {33971#true} {33971#true} #638#return; {33971#true} is VALID [2022-02-20 21:35:53,253 INFO L290 TraceCheckUtils]: 137: Hoare triple {33971#true} call ibmpex_query_sensor_name_#t~mem91#1 := read~int(ibmpex_query_sensor_name_~data#1.base, 899 + ibmpex_query_sensor_name_~data#1.offset, 1);ibmpex_query_sensor_name_#t~short93#1 := 0 != ibmpex_query_sensor_name_#t~mem91#1 % 256 % 4294967296; {33971#true} is VALID [2022-02-20 21:35:53,253 INFO L290 TraceCheckUtils]: 138: Hoare triple {33971#true} assume !ibmpex_query_sensor_name_#t~short93#1;call ibmpex_query_sensor_name_#t~mem92#1 := read~int(ibmpex_query_sensor_name_~data#1.base, 891 + ibmpex_query_sensor_name_~data#1.offset, 8);ibmpex_query_sensor_name_#t~short93#1 := 0 == ibmpex_query_sensor_name_#t~mem92#1 % 18446744073709551616; {33971#true} is VALID [2022-02-20 21:35:53,253 INFO L290 TraceCheckUtils]: 139: Hoare triple {33971#true} assume !ibmpex_query_sensor_name_#t~short93#1;havoc ibmpex_query_sensor_name_#t~mem91#1;havoc ibmpex_query_sensor_name_#t~mem92#1;havoc ibmpex_query_sensor_name_#t~short93#1;ibmpex_query_sensor_name_#res#1 := 0; {33971#true} is VALID [2022-02-20 21:35:53,253 INFO L290 TraceCheckUtils]: 140: Hoare triple {33971#true} ibmpex_find_sensors_#t~ret152#1 := ibmpex_query_sensor_name_#res#1;assume { :end_inline_ibmpex_query_sensor_name } true;assume -2147483648 <= ibmpex_find_sensors_#t~ret152#1 && ibmpex_find_sensors_#t~ret152#1 <= 2147483647;ibmpex_find_sensors_~err~3#1 := ibmpex_find_sensors_#t~ret152#1;havoc ibmpex_find_sensors_#t~ret152#1; {33971#true} is VALID [2022-02-20 21:35:53,253 INFO L290 TraceCheckUtils]: 141: Hoare triple {33971#true} assume !(0 != ibmpex_find_sensors_~err~3#1);call ibmpex_find_sensors_#t~mem153#1 := read~int(ibmpex_find_sensors_~data#1.base, 891 + ibmpex_find_sensors_~data#1.offset, 8);assume { :begin_inline_is_power_sensor } true;is_power_sensor_#in~sensor_id#1.base, is_power_sensor_#in~sensor_id#1.offset, is_power_sensor_#in~len#1 := ibmpex_find_sensors_~data#1.base, 619 + ibmpex_find_sensors_~data#1.offset, (if ibmpex_find_sensors_#t~mem153#1 % 18446744073709551616 % 4294967296 <= 2147483647 then ibmpex_find_sensors_#t~mem153#1 % 18446744073709551616 % 4294967296 else ibmpex_find_sensors_#t~mem153#1 % 18446744073709551616 % 4294967296 - 4294967296);havoc is_power_sensor_#res#1;havoc is_power_sensor_#t~ret130#1, is_power_sensor_~sensor_id#1.base, is_power_sensor_~sensor_id#1.offset, is_power_sensor_~len#1, is_power_sensor_~tmp~9#1;is_power_sensor_~sensor_id#1.base, is_power_sensor_~sensor_id#1.offset := is_power_sensor_#in~sensor_id#1.base, is_power_sensor_#in~sensor_id#1.offset;is_power_sensor_~len#1 := is_power_sensor_#in~len#1;havoc is_power_sensor_~tmp~9#1; {33971#true} is VALID [2022-02-20 21:35:53,254 INFO L290 TraceCheckUtils]: 142: Hoare triple {33971#true} assume is_power_sensor_~len#1 <= 2;is_power_sensor_#res#1 := 0; {34050#(= |ULTIMATE.start_is_power_sensor_#res#1| 0)} is VALID [2022-02-20 21:35:53,254 INFO L290 TraceCheckUtils]: 143: Hoare triple {34050#(= |ULTIMATE.start_is_power_sensor_#res#1| 0)} ibmpex_find_sensors_#t~ret154#1 := is_power_sensor_#res#1;assume { :end_inline_is_power_sensor } true;assume -2147483648 <= ibmpex_find_sensors_#t~ret154#1 && ibmpex_find_sensors_#t~ret154#1 <= 2147483647;ibmpex_find_sensors_~tmp___1~1#1 := ibmpex_find_sensors_#t~ret154#1;havoc ibmpex_find_sensors_#t~mem153#1;havoc ibmpex_find_sensors_#t~ret154#1; {34051#(= |ULTIMATE.start_ibmpex_find_sensors_~tmp___1~1#1| 0)} is VALID [2022-02-20 21:35:53,255 INFO L290 TraceCheckUtils]: 144: Hoare triple {34051#(= |ULTIMATE.start_ibmpex_find_sensors_~tmp___1~1#1| 0)} assume 0 != ibmpex_find_sensors_~tmp___1~1#1;ibmpex_find_sensors_~sensor_type~0#1 := 2;ibmpex_find_sensors_~num_power~0#1 := 1 + ibmpex_find_sensors_~num_power~0#1;ibmpex_find_sensors_~sensor_counter~0#1 := ibmpex_find_sensors_~num_power~0#1;call ibmpex_find_sensors_#t~mem155#1.base, ibmpex_find_sensors_#t~mem155#1.offset := read~$Pointer$(ibmpex_find_sensors_~data#1.base, 907 + ibmpex_find_sensors_~data#1.offset, 8);call ibmpex_find_sensors_#t~mem156#1 := read~int(ibmpex_find_sensors_~data#1.base, 891 + ibmpex_find_sensors_~data#1.offset, 8);assume { :begin_inline_power_sensor_multiplier } true;power_sensor_multiplier_#in~data#1.base, power_sensor_multiplier_#in~data#1.offset, power_sensor_multiplier_#in~sensor_id#1.base, power_sensor_multiplier_#in~sensor_id#1.offset, power_sensor_multiplier_#in~len#1 := ibmpex_find_sensors_~data#1.base, ibmpex_find_sensors_~data#1.offset, ibmpex_find_sensors_~data#1.base, 619 + ibmpex_find_sensors_~data#1.offset, (if ibmpex_find_sensors_#t~mem156#1 % 18446744073709551616 % 4294967296 <= 2147483647 then ibmpex_find_sensors_#t~mem156#1 % 18446744073709551616 % 4294967296 else ibmpex_find_sensors_#t~mem156#1 % 18446744073709551616 % 4294967296 - 4294967296);havoc power_sensor_multiplier_#res#1;havoc power_sensor_multiplier_#t~mem132#1, power_sensor_multiplier_#t~ret133#1, power_sensor_multiplier_~data#1.base, power_sensor_multiplier_~data#1.offset, power_sensor_multiplier_~sensor_id#1.base, power_sensor_multiplier_~sensor_id#1.offset, power_sensor_multiplier_~len#1, power_sensor_multiplier_~i~1#1, power_sensor_multiplier_~tmp~11#1;power_sensor_multiplier_~data#1.base, power_sensor_multiplier_~data#1.offset := power_sensor_multiplier_#in~data#1.base, power_sensor_multiplier_#in~data#1.offset;power_sensor_multiplier_~sensor_id#1.base, power_sensor_multiplier_~sensor_id#1.offset := power_sensor_multiplier_#in~sensor_id#1.base, power_sensor_multiplier_#in~sensor_id#1.offset;power_sensor_multiplier_~len#1 := power_sensor_multiplier_#in~len#1;havoc power_sensor_multiplier_~i~1#1;havoc power_sensor_multiplier_~tmp~11#1;call power_sensor_multiplier_#t~mem132#1 := read~int(power_sensor_multiplier_~data#1.base, 904 + power_sensor_multiplier_~data#1.offset, 1); {33972#false} is VALID [2022-02-20 21:35:53,255 INFO L290 TraceCheckUtils]: 145: Hoare triple {33972#false} assume 2 == power_sensor_multiplier_#t~mem132#1 % 256 % 4294967296;havoc power_sensor_multiplier_#t~mem132#1;power_sensor_multiplier_#res#1 := 1000000; {33972#false} is VALID [2022-02-20 21:35:53,255 INFO L290 TraceCheckUtils]: 146: Hoare triple {33972#false} ibmpex_find_sensors_#t~ret157#1 := power_sensor_multiplier_#res#1;assume { :end_inline_power_sensor_multiplier } true;assume -2147483648 <= ibmpex_find_sensors_#t~ret157#1 && ibmpex_find_sensors_#t~ret157#1 <= 2147483647;call write~int(ibmpex_find_sensors_#t~ret157#1, ibmpex_find_sensors_#t~mem155#1.base, 10 + (ibmpex_find_sensors_#t~mem155#1.offset + 152 * (if ibmpex_find_sensors_~i~2#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then ibmpex_find_sensors_~i~2#1 % 18446744073709551616 % 18446744073709551616 else ibmpex_find_sensors_~i~2#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616)), 4);havoc ibmpex_find_sensors_#t~mem155#1.base, ibmpex_find_sensors_#t~mem155#1.offset;havoc ibmpex_find_sensors_#t~mem156#1;havoc ibmpex_find_sensors_#t~ret157#1; {33972#false} is VALID [2022-02-20 21:35:53,255 INFO L290 TraceCheckUtils]: 147: Hoare triple {33972#false} call ibmpex_find_sensors_#t~mem161#1.base, ibmpex_find_sensors_#t~mem161#1.offset := read~$Pointer$(ibmpex_find_sensors_~data#1.base, 907 + ibmpex_find_sensors_~data#1.offset, 8);call write~int(1, ibmpex_find_sensors_#t~mem161#1.base, ibmpex_find_sensors_#t~mem161#1.offset + 152 * (if ibmpex_find_sensors_~i~2#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then ibmpex_find_sensors_~i~2#1 % 18446744073709551616 % 18446744073709551616 else ibmpex_find_sensors_~i~2#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 4);havoc ibmpex_find_sensors_#t~mem161#1.base, ibmpex_find_sensors_#t~mem161#1.offset;ibmpex_find_sensors_~j~0#1 := 0; {33972#false} is VALID [2022-02-20 21:35:53,255 INFO L290 TraceCheckUtils]: 148: Hoare triple {33972#false} assume ibmpex_find_sensors_~j~0#1 <= 2; {33972#false} is VALID [2022-02-20 21:35:53,256 INFO L290 TraceCheckUtils]: 149: Hoare triple {33972#false} assume { :begin_inline_create_sensor } true;create_sensor_#in~data#1.base, create_sensor_#in~data#1.offset, create_sensor_#in~type#1, create_sensor_#in~counter#1, create_sensor_#in~sensor#1, create_sensor_#in~func#1 := ibmpex_find_sensors_~data#1.base, ibmpex_find_sensors_~data#1.offset, ibmpex_find_sensors_~sensor_type~0#1, ibmpex_find_sensors_~sensor_counter~0#1, ibmpex_find_sensors_~i~2#1, ibmpex_find_sensors_~j~0#1;havoc create_sensor_#res#1;havoc create_sensor_#t~ret134#1.base, create_sensor_#t~ret134#1.offset, create_sensor_#t~nondet135#1, create_sensor_#t~mem136#1.base, create_sensor_#t~mem136#1.offset, create_sensor_#t~nondet137#1, create_sensor_#t~mem138#1.base, create_sensor_#t~mem138#1.offset, create_sensor_#t~mem139#1.base, create_sensor_#t~mem139#1.offset, create_sensor_#t~mem140#1.base, create_sensor_#t~mem140#1.offset, create_sensor_#t~mem141#1.base, create_sensor_#t~mem141#1.offset, create_sensor_#t~mem142#1.base, create_sensor_#t~mem142#1.offset, create_sensor_#t~mem143#1.base, create_sensor_#t~mem143#1.offset, create_sensor_#t~mem144#1.base, create_sensor_#t~mem144#1.offset, create_sensor_#t~mem145#1.base, create_sensor_#t~mem145#1.offset, create_sensor_#t~ret146#1, create_sensor_#t~mem147#1.base, create_sensor_#t~mem147#1.offset, create_sensor_~data#1.base, create_sensor_~data#1.offset, create_sensor_~type#1, create_sensor_~counter#1, create_sensor_~sensor#1, create_sensor_~func#1, create_sensor_~err~2#1, create_sensor_~n~0#1.base, create_sensor_~n~0#1.offset, create_sensor_~tmp~12#1.base, create_sensor_~tmp~12#1.offset;create_sensor_~data#1.base, create_sensor_~data#1.offset := create_sensor_#in~data#1.base, create_sensor_#in~data#1.offset;create_sensor_~type#1 := create_sensor_#in~type#1;create_sensor_~counter#1 := create_sensor_#in~counter#1;create_sensor_~sensor#1 := create_sensor_#in~sensor#1;create_sensor_~func#1 := create_sensor_#in~func#1;havoc create_sensor_~err~2#1;havoc create_sensor_~n~0#1.base, create_sensor_~n~0#1.offset;havoc create_sensor_~tmp~12#1.base, create_sensor_~tmp~12#1.offset; {33972#false} is VALID [2022-02-20 21:35:53,256 INFO L272 TraceCheckUtils]: 150: Hoare triple {33972#false} call create_sensor_#t~ret134#1.base, create_sensor_#t~ret134#1.offset := kmalloc(32, 208); {34062#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:53,256 INFO L290 TraceCheckUtils]: 151: Hoare triple {34062#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {33971#true} is VALID [2022-02-20 21:35:53,257 INFO L272 TraceCheckUtils]: 152: Hoare triple {33971#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {34062#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:35:53,257 INFO L290 TraceCheckUtils]: 153: Hoare triple {34062#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {33971#true} is VALID [2022-02-20 21:35:53,257 INFO L290 TraceCheckUtils]: 154: Hoare triple {33971#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {33971#true} is VALID [2022-02-20 21:35:53,257 INFO L290 TraceCheckUtils]: 155: Hoare triple {33971#true} assume true; {33971#true} is VALID [2022-02-20 21:35:53,257 INFO L284 TraceCheckUtils]: 156: Hoare quadruple {33971#true} {33971#true} #590#return; {33971#true} is VALID [2022-02-20 21:35:53,257 INFO L290 TraceCheckUtils]: 157: Hoare triple {33971#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {33971#true} is VALID [2022-02-20 21:35:53,258 INFO L290 TraceCheckUtils]: 158: Hoare triple {33971#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {33971#true} is VALID [2022-02-20 21:35:53,258 INFO L290 TraceCheckUtils]: 159: Hoare triple {33971#true} assume true; {33971#true} is VALID [2022-02-20 21:35:53,258 INFO L284 TraceCheckUtils]: 160: Hoare quadruple {33971#true} {33972#false} #640#return; {33972#false} is VALID [2022-02-20 21:35:53,258 INFO L290 TraceCheckUtils]: 161: Hoare triple {33972#false} create_sensor_~tmp~12#1.base, create_sensor_~tmp~12#1.offset := create_sensor_#t~ret134#1.base, create_sensor_#t~ret134#1.offset;havoc create_sensor_#t~ret134#1.base, create_sensor_#t~ret134#1.offset;create_sensor_~n~0#1.base, create_sensor_~n~0#1.offset := create_sensor_~tmp~12#1.base, create_sensor_~tmp~12#1.offset; {33972#false} is VALID [2022-02-20 21:35:53,258 INFO L290 TraceCheckUtils]: 162: Hoare triple {33972#false} assume !(0 == (create_sensor_~n~0#1.base + create_sensor_~n~0#1.offset) % 18446744073709551616); {33972#false} is VALID [2022-02-20 21:35:53,258 INFO L290 TraceCheckUtils]: 163: Hoare triple {33972#false} assume 1 == create_sensor_~type#1;havoc create_sensor_#t~nondet135#1;call create_sensor_#t~mem136#1.base, create_sensor_#t~mem136#1.offset := read~$Pointer$(~#temp_sensor_name_templates~0.base, ~#temp_sensor_name_templates~0.offset + 8 * create_sensor_~func#1, 8);havoc create_sensor_#t~mem136#1.base, create_sensor_#t~mem136#1.offset; {33972#false} is VALID [2022-02-20 21:35:53,259 INFO L290 TraceCheckUtils]: 164: Hoare triple {33972#false} assume { :begin_inline_ldv_sysfs } true;~ldv_count_1~0 := 1 + ~ldv_count_1~0; {33972#false} is VALID [2022-02-20 21:35:53,259 INFO L290 TraceCheckUtils]: 165: Hoare triple {33972#false} assume { :end_inline_ldv_sysfs } true;call create_sensor_#t~mem139#1.base, create_sensor_#t~mem139#1.offset := read~$Pointer$(create_sensor_~data#1.base, 907 + create_sensor_~data#1.offset, 8);call write~$Pointer$(create_sensor_~n~0#1.base, create_sensor_~n~0#1.offset, create_sensor_#t~mem139#1.base, 14 + (create_sensor_#t~mem139#1.offset + 152 * (if create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 else create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616)) + 46 * create_sensor_~func#1, 8);havoc create_sensor_#t~mem139#1.base, create_sensor_#t~mem139#1.offset;call create_sensor_#t~mem140#1.base, create_sensor_#t~mem140#1.offset := read~$Pointer$(create_sensor_~data#1.base, 907 + create_sensor_~data#1.offset, 8);call write~int(292, create_sensor_#t~mem140#1.base, 8 + (14 + (create_sensor_#t~mem140#1.offset + 152 * (if create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 else create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616)) + 46 * create_sensor_~func#1), 4);havoc create_sensor_#t~mem140#1.base, create_sensor_#t~mem140#1.offset;call create_sensor_#t~mem141#1.base, create_sensor_#t~mem141#1.offset := read~$Pointer$(create_sensor_~data#1.base, 907 + create_sensor_~data#1.offset, 8);call write~$Pointer$(#funAddr~ibmpex_show_sensor.base, #funAddr~ibmpex_show_sensor.offset, create_sensor_#t~mem141#1.base, 28 + (14 + (create_sensor_#t~mem141#1.offset + 152 * (if create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 else create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616)) + 46 * create_sensor_~func#1), 8);havoc create_sensor_#t~mem141#1.base, create_sensor_#t~mem141#1.offset;call create_sensor_#t~mem142#1.base, create_sensor_#t~mem142#1.offset := read~$Pointer$(create_sensor_~data#1.base, 907 + create_sensor_~data#1.offset, 8);call write~int(create_sensor_~sensor#1, create_sensor_#t~mem142#1.base, 44 + (14 + (create_sensor_#t~mem142#1.offset + 152 * (if create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 else create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616)) + 46 * create_sensor_~func#1), 1);havoc create_sensor_#t~mem142#1.base, create_sensor_#t~mem142#1.offset;call create_sensor_#t~mem143#1.base, create_sensor_#t~mem143#1.offset := read~$Pointer$(create_sensor_~data#1.base, 907 + create_sensor_~data#1.offset, 8);call write~int(create_sensor_~func#1, create_sensor_#t~mem143#1.base, 45 + (14 + (create_sensor_#t~mem143#1.offset + 152 * (if create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 else create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616)) + 46 * create_sensor_~func#1), 1);havoc create_sensor_#t~mem143#1.base, create_sensor_#t~mem143#1.offset;call create_sensor_#t~mem144#1.base, create_sensor_#t~mem144#1.offset := read~$Pointer$(create_sensor_~data#1.base, 24 + create_sensor_~data#1.offset, 8);call create_sensor_#t~mem145#1.base, create_sensor_#t~mem145#1.offset := read~$Pointer$(create_sensor_~data#1.base, 907 + create_sensor_~data#1.offset, 8);assume { :begin_inline_ldv_device_create_file_5 } true;ldv_device_create_file_5_#in~ldv_func_arg1#1.base, ldv_device_create_file_5_#in~ldv_func_arg1#1.offset, ldv_device_create_file_5_#in~ldv_func_arg2#1.base, ldv_device_create_file_5_#in~ldv_func_arg2#1.offset := create_sensor_#t~mem144#1.base, create_sensor_#t~mem144#1.offset, create_sensor_#t~mem145#1.base, 14 + (create_sensor_#t~mem145#1.offset + 152 * (if create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 else create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616)) + 46 * create_sensor_~func#1;havoc ldv_device_create_file_5_#res#1;havoc ldv_device_create_file_5_#t~ret241#1, ldv_device_create_file_5_~ldv_func_arg1#1.base, ldv_device_create_file_5_~ldv_func_arg1#1.offset, ldv_device_create_file_5_~ldv_func_arg2#1.base, ldv_device_create_file_5_~ldv_func_arg2#1.offset, ldv_device_create_file_5_~tmp~19#1;ldv_device_create_file_5_~ldv_func_arg1#1.base, ldv_device_create_file_5_~ldv_func_arg1#1.offset := ldv_device_create_file_5_#in~ldv_func_arg1#1.base, ldv_device_create_file_5_#in~ldv_func_arg1#1.offset;ldv_device_create_file_5_~ldv_func_arg2#1.base, ldv_device_create_file_5_~ldv_func_arg2#1.offset := ldv_device_create_file_5_#in~ldv_func_arg2#1.base, ldv_device_create_file_5_#in~ldv_func_arg2#1.offset;havoc ldv_device_create_file_5_~tmp~19#1;assume { :begin_inline_ldv_device_create_file_dev_attr_of_sensor_device_attribute_2 } true;ldv_device_create_file_dev_attr_of_sensor_device_attribute_2_#in~attr#1.base, ldv_device_create_file_dev_attr_of_sensor_device_attribute_2_#in~attr#1.offset := ldv_device_create_file_5_~ldv_func_arg2#1.base, ldv_device_create_file_5_~ldv_func_arg2#1.offset;havoc ldv_device_create_file_dev_attr_of_sensor_device_attribute_2_#res#1;havoc ldv_device_create_file_dev_attr_of_sensor_device_attribute_2_~attr#1.base, ldv_device_create_file_dev_attr_of_sensor_device_attribute_2_~attr#1.offset;ldv_device_create_file_dev_attr_of_sensor_device_attribute_2_~attr#1.base, ldv_device_create_file_dev_attr_of_sensor_device_attribute_2_~attr#1.offset := ldv_device_create_file_dev_attr_of_sensor_device_attribute_2_#in~attr#1.base, ldv_device_create_file_dev_attr_of_sensor_device_attribute_2_#in~attr#1.offset; {33972#false} is VALID [2022-02-20 21:35:53,259 INFO L290 TraceCheckUtils]: 166: Hoare triple {33972#false} assume 0 == ~ldv_call_dev_attr_of_sensor_device_attribute_2~0;~ldv_count_2~0 := 1 + ~ldv_count_2~0;~ldv_call_dev_attr_of_sensor_device_attribute_2~0 := 1; {33972#false} is VALID [2022-02-20 21:35:53,259 INFO L290 TraceCheckUtils]: 167: Hoare triple {33972#false} assume ~ldv_count_1~0 >= ~ldv_count_2~0; {33972#false} is VALID [2022-02-20 21:35:53,259 INFO L290 TraceCheckUtils]: 168: Hoare triple {33972#false} ldv_device_create_file_dev_attr_of_sensor_device_attribute_2_#res#1 := 0; {33972#false} is VALID [2022-02-20 21:35:53,260 INFO L290 TraceCheckUtils]: 169: Hoare triple {33972#false} ldv_device_create_file_5_#t~ret241#1 := ldv_device_create_file_dev_attr_of_sensor_device_attribute_2_#res#1;assume { :end_inline_ldv_device_create_file_dev_attr_of_sensor_device_attribute_2 } true;assume -2147483648 <= ldv_device_create_file_5_#t~ret241#1 && ldv_device_create_file_5_#t~ret241#1 <= 2147483647;ldv_device_create_file_5_~tmp~19#1 := ldv_device_create_file_5_#t~ret241#1;havoc ldv_device_create_file_5_#t~ret241#1;ldv_device_create_file_5_#res#1 := ldv_device_create_file_5_~tmp~19#1; {33972#false} is VALID [2022-02-20 21:35:53,260 INFO L290 TraceCheckUtils]: 170: Hoare triple {33972#false} create_sensor_#t~ret146#1 := ldv_device_create_file_5_#res#1;assume { :end_inline_ldv_device_create_file_5 } true;assume -2147483648 <= create_sensor_#t~ret146#1 && create_sensor_#t~ret146#1 <= 2147483647;create_sensor_~err~2#1 := create_sensor_#t~ret146#1;havoc create_sensor_#t~mem144#1.base, create_sensor_#t~mem144#1.offset;havoc create_sensor_#t~mem145#1.base, create_sensor_#t~mem145#1.offset;havoc create_sensor_#t~ret146#1; {33972#false} is VALID [2022-02-20 21:35:53,260 INFO L290 TraceCheckUtils]: 171: Hoare triple {33972#false} assume !(0 != create_sensor_~err~2#1);create_sensor_#res#1 := 0; {33972#false} is VALID [2022-02-20 21:35:53,260 INFO L290 TraceCheckUtils]: 172: Hoare triple {33972#false} ibmpex_find_sensors_#t~ret162#1 := create_sensor_#res#1;assume { :end_inline_create_sensor } true;assume -2147483648 <= ibmpex_find_sensors_#t~ret162#1 && ibmpex_find_sensors_#t~ret162#1 <= 2147483647;ibmpex_find_sensors_~err~3#1 := ibmpex_find_sensors_#t~ret162#1;havoc ibmpex_find_sensors_#t~ret162#1; {33972#false} is VALID [2022-02-20 21:35:53,260 INFO L290 TraceCheckUtils]: 173: Hoare triple {33972#false} assume !(0 != ibmpex_find_sensors_~err~3#1);ibmpex_find_sensors_~j~0#1 := 1 + ibmpex_find_sensors_~j~0#1; {33972#false} is VALID [2022-02-20 21:35:53,260 INFO L290 TraceCheckUtils]: 174: Hoare triple {33972#false} assume !(ibmpex_find_sensors_~j~0#1 <= 2); {33972#false} is VALID [2022-02-20 21:35:53,261 INFO L290 TraceCheckUtils]: 175: Hoare triple {33972#false} ibmpex_find_sensors_~i~2#1 := 1 + ibmpex_find_sensors_~i~2#1; {33972#false} is VALID [2022-02-20 21:35:53,261 INFO L290 TraceCheckUtils]: 176: Hoare triple {33972#false} call ibmpex_find_sensors_#t~mem163#1 := read~int(ibmpex_find_sensors_~data#1.base, 906 + ibmpex_find_sensors_~data#1.offset, 1); {33972#false} is VALID [2022-02-20 21:35:53,261 INFO L290 TraceCheckUtils]: 177: Hoare triple {33972#false} assume !(ibmpex_find_sensors_#t~mem163#1 % 256 > ibmpex_find_sensors_~i~2#1);havoc ibmpex_find_sensors_#t~mem163#1;call ibmpex_find_sensors_#t~mem164#1.base, ibmpex_find_sensors_#t~mem164#1.offset := read~$Pointer$(ibmpex_find_sensors_~data#1.base, 24 + ibmpex_find_sensors_~data#1.offset, 8);assume { :begin_inline_ldv_device_create_file_6 } true;ldv_device_create_file_6_#in~ldv_func_arg1#1.base, ldv_device_create_file_6_#in~ldv_func_arg1#1.offset, ldv_device_create_file_6_#in~ldv_func_arg2#1.base, ldv_device_create_file_6_#in~ldv_func_arg2#1.offset := ibmpex_find_sensors_#t~mem164#1.base, ibmpex_find_sensors_#t~mem164#1.offset, ~#sensor_dev_attr_reset_high_low~0.base, ~#sensor_dev_attr_reset_high_low~0.offset;havoc ldv_device_create_file_6_#res#1;havoc ldv_device_create_file_6_#t~ret242#1, ldv_device_create_file_6_~ldv_func_arg1#1.base, ldv_device_create_file_6_~ldv_func_arg1#1.offset, ldv_device_create_file_6_~ldv_func_arg2#1.base, ldv_device_create_file_6_~ldv_func_arg2#1.offset, ldv_device_create_file_6_~tmp~20#1;ldv_device_create_file_6_~ldv_func_arg1#1.base, ldv_device_create_file_6_~ldv_func_arg1#1.offset := ldv_device_create_file_6_#in~ldv_func_arg1#1.base, ldv_device_create_file_6_#in~ldv_func_arg1#1.offset;ldv_device_create_file_6_~ldv_func_arg2#1.base, ldv_device_create_file_6_~ldv_func_arg2#1.offset := ldv_device_create_file_6_#in~ldv_func_arg2#1.base, ldv_device_create_file_6_#in~ldv_func_arg2#1.offset;havoc ldv_device_create_file_6_~tmp~20#1; {33972#false} is VALID [2022-02-20 21:35:53,261 INFO L272 TraceCheckUtils]: 178: Hoare triple {33972#false} call ldv_device_create_file_6_#t~ret242#1 := ldv_device_create_file_dev_attr_of_sensor_device_attribute(ldv_device_create_file_6_~ldv_func_arg2#1.base, ldv_device_create_file_6_~ldv_func_arg2#1.offset); {33972#false} is VALID [2022-02-20 21:35:53,261 INFO L290 TraceCheckUtils]: 179: Hoare triple {33972#false} ~attr.base, ~attr.offset := #in~attr.base, #in~attr.offset; {33972#false} is VALID [2022-02-20 21:35:53,261 INFO L290 TraceCheckUtils]: 180: Hoare triple {33972#false} assume 0 == ~ldv_call_dev_attr_of_sensor_device_attribute~0;~ldv_count_2~0 := 1 + ~ldv_count_2~0;~ldv_call_dev_attr_of_sensor_device_attribute~0 := 1; {33972#false} is VALID [2022-02-20 21:35:53,262 INFO L290 TraceCheckUtils]: 181: Hoare triple {33972#false} assume !(~ldv_count_1~0 >= ~ldv_count_2~0); {33972#false} is VALID [2022-02-20 21:35:53,262 INFO L272 TraceCheckUtils]: 182: Hoare triple {33972#false} call ldv_error(); {33972#false} is VALID [2022-02-20 21:35:53,262 INFO L290 TraceCheckUtils]: 183: Hoare triple {33972#false} assume !false; {33972#false} is VALID [2022-02-20 21:35:53,263 INFO L134 CoverageAnalysis]: Checked inductivity of 79 backedges. 2 proven. 0 refuted. 0 times theorem prover too weak. 77 trivial. 0 not checked. [2022-02-20 21:35:53,263 INFO L144 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-02-20 21:35:53,263 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [949474387] [2022-02-20 21:35:53,263 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleSmtInterpolCraig [949474387] provided 1 perfect and 0 imperfect interpolant sequences [2022-02-20 21:35:53,263 INFO L191 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-02-20 21:35:53,263 INFO L204 FreeRefinementEngine]: Number of different interpolants: perfect sequences [6] imperfect sequences [] total 6 [2022-02-20 21:35:53,264 INFO L118 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [698010267] [2022-02-20 21:35:53,264 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-02-20 21:35:53,264 INFO L78 Accepts]: Start accepts. Automaton has has 6 states, 6 states have (on average 17.833333333333332) internal successors, (107), 4 states have internal predecessors, (107), 2 states have call successors, (19), 4 states have call predecessors, (19), 1 states have return successors, (17), 2 states have call predecessors, (17), 2 states have call successors, (17) Word has length 184 [2022-02-20 21:35:53,265 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-02-20 21:35:53,265 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with has 6 states, 6 states have (on average 17.833333333333332) internal successors, (107), 4 states have internal predecessors, (107), 2 states have call successors, (19), 4 states have call predecessors, (19), 1 states have return successors, (17), 2 states have call predecessors, (17), 2 states have call successors, (17) [2022-02-20 21:35:53,382 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 143 edges. 143 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 21:35:53,383 INFO L546 AbstractCegarLoop]: INTERPOLANT automaton has 6 states [2022-02-20 21:35:53,383 INFO L108 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2022-02-20 21:35:53,383 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 6 interpolants. [2022-02-20 21:35:53,383 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=9, Invalid=21, Unknown=0, NotChecked=0, Total=30 [2022-02-20 21:35:53,384 INFO L87 Difference]: Start difference. First operand 1037 states and 1366 transitions. Second operand has 6 states, 6 states have (on average 17.833333333333332) internal successors, (107), 4 states have internal predecessors, (107), 2 states have call successors, (19), 4 states have call predecessors, (19), 1 states have return successors, (17), 2 states have call predecessors, (17), 2 states have call successors, (17) [2022-02-20 21:35:59,005 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 21:35:59,005 INFO L93 Difference]: Finished difference Result 3838 states and 5391 transitions. [2022-02-20 21:35:59,005 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 8 states. [2022-02-20 21:35:59,005 INFO L78 Accepts]: Start accepts. Automaton has has 6 states, 6 states have (on average 17.833333333333332) internal successors, (107), 4 states have internal predecessors, (107), 2 states have call successors, (19), 4 states have call predecessors, (19), 1 states have return successors, (17), 2 states have call predecessors, (17), 2 states have call successors, (17) Word has length 184 [2022-02-20 21:35:59,006 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-02-20 21:35:59,006 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 6 states, 6 states have (on average 17.833333333333332) internal successors, (107), 4 states have internal predecessors, (107), 2 states have call successors, (19), 4 states have call predecessors, (19), 1 states have return successors, (17), 2 states have call predecessors, (17), 2 states have call successors, (17) [2022-02-20 21:35:59,015 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 8 states to 8 states and 1326 transitions. [2022-02-20 21:35:59,016 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 6 states, 6 states have (on average 17.833333333333332) internal successors, (107), 4 states have internal predecessors, (107), 2 states have call successors, (19), 4 states have call predecessors, (19), 1 states have return successors, (17), 2 states have call predecessors, (17), 2 states have call successors, (17) [2022-02-20 21:35:59,025 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 8 states to 8 states and 1326 transitions. [2022-02-20 21:35:59,025 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with 8 states and 1326 transitions. [2022-02-20 21:36:00,044 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 1326 edges. 1326 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 21:36:00,395 INFO L225 Difference]: With dead ends: 3838 [2022-02-20 21:36:00,395 INFO L226 Difference]: Without dead ends: 2809 [2022-02-20 21:36:00,397 INFO L932 BasicCegarLoop]: 0 DeclaredPredicates, 48 GetRequests, 42 SyntacticMatches, 0 SemanticMatches, 6 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 1 ImplicationChecksByTransitivity, 0.0s TimeCoverageRelationStatistics Valid=17, Invalid=39, Unknown=0, NotChecked=0, Total=56 [2022-02-20 21:36:00,398 INFO L933 BasicCegarLoop]: 668 mSDtfsCounter, 656 mSDsluCounter, 1436 mSDsCounter, 0 mSdLazyCounter, 793 mSolverCounterSat, 185 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 1.2s Time, 0 mProtectedPredicate, 0 mProtectedAction, 729 SdHoareTripleChecker+Valid, 2104 SdHoareTripleChecker+Invalid, 978 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 185 IncrementalHoareTripleChecker+Valid, 793 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 1.2s IncrementalHoareTripleChecker+Time [2022-02-20 21:36:00,398 INFO L934 BasicCegarLoop]: SdHoareTripleChecker [729 Valid, 2104 Invalid, 978 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [185 Valid, 793 Invalid, 0 Unknown, 0 Unchecked, 1.2s Time] [2022-02-20 21:36:00,400 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 2809 states. [2022-02-20 21:36:00,813 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 2809 to 1045. [2022-02-20 21:36:00,813 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-02-20 21:36:00,815 INFO L82 GeneralOperation]: Start isEquivalent. First operand 2809 states. Second operand has 1045 states, 809 states have (on average 1.273176761433869) internal successors, (1030), 818 states have internal predecessors, (1030), 171 states have call successors, (171), 65 states have call predecessors, (171), 64 states have return successors, (173), 169 states have call predecessors, (173), 169 states have call successors, (173) [2022-02-20 21:36:00,816 INFO L74 IsIncluded]: Start isIncluded. First operand 2809 states. Second operand has 1045 states, 809 states have (on average 1.273176761433869) internal successors, (1030), 818 states have internal predecessors, (1030), 171 states have call successors, (171), 65 states have call predecessors, (171), 64 states have return successors, (173), 169 states have call predecessors, (173), 169 states have call successors, (173) [2022-02-20 21:36:00,818 INFO L87 Difference]: Start difference. First operand 2809 states. Second operand has 1045 states, 809 states have (on average 1.273176761433869) internal successors, (1030), 818 states have internal predecessors, (1030), 171 states have call successors, (171), 65 states have call predecessors, (171), 64 states have return successors, (173), 169 states have call predecessors, (173), 169 states have call successors, (173) [2022-02-20 21:36:01,039 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 21:36:01,039 INFO L93 Difference]: Finished difference Result 2809 states and 4030 transitions. [2022-02-20 21:36:01,040 INFO L276 IsEmpty]: Start isEmpty. Operand 2809 states and 4030 transitions. [2022-02-20 21:36:01,050 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 21:36:01,050 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 21:36:01,053 INFO L74 IsIncluded]: Start isIncluded. First operand has 1045 states, 809 states have (on average 1.273176761433869) internal successors, (1030), 818 states have internal predecessors, (1030), 171 states have call successors, (171), 65 states have call predecessors, (171), 64 states have return successors, (173), 169 states have call predecessors, (173), 169 states have call successors, (173) Second operand 2809 states. [2022-02-20 21:36:01,054 INFO L87 Difference]: Start difference. First operand has 1045 states, 809 states have (on average 1.273176761433869) internal successors, (1030), 818 states have internal predecessors, (1030), 171 states have call successors, (171), 65 states have call predecessors, (171), 64 states have return successors, (173), 169 states have call predecessors, (173), 169 states have call successors, (173) Second operand 2809 states. [2022-02-20 21:36:01,333 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 21:36:01,333 INFO L93 Difference]: Finished difference Result 2809 states and 4030 transitions. [2022-02-20 21:36:01,333 INFO L276 IsEmpty]: Start isEmpty. Operand 2809 states and 4030 transitions. [2022-02-20 21:36:01,341 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 21:36:01,341 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 21:36:01,341 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-02-20 21:36:01,342 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-02-20 21:36:01,344 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 1045 states, 809 states have (on average 1.273176761433869) internal successors, (1030), 818 states have internal predecessors, (1030), 171 states have call successors, (171), 65 states have call predecessors, (171), 64 states have return successors, (173), 169 states have call predecessors, (173), 169 states have call successors, (173) [2022-02-20 21:36:01,405 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 1045 states to 1045 states and 1374 transitions. [2022-02-20 21:36:01,406 INFO L78 Accepts]: Start accepts. Automaton has 1045 states and 1374 transitions. Word has length 184 [2022-02-20 21:36:01,406 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-02-20 21:36:01,406 INFO L470 AbstractCegarLoop]: Abstraction has 1045 states and 1374 transitions. [2022-02-20 21:36:01,406 INFO L471 AbstractCegarLoop]: INTERPOLANT automaton has has 6 states, 6 states have (on average 17.833333333333332) internal successors, (107), 4 states have internal predecessors, (107), 2 states have call successors, (19), 4 states have call predecessors, (19), 1 states have return successors, (17), 2 states have call predecessors, (17), 2 states have call successors, (17) [2022-02-20 21:36:01,407 INFO L276 IsEmpty]: Start isEmpty. Operand 1045 states and 1374 transitions. [2022-02-20 21:36:01,409 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 186 [2022-02-20 21:36:01,409 INFO L506 BasicCegarLoop]: Found error trace [2022-02-20 21:36:01,409 INFO L514 BasicCegarLoop]: trace histogram [4, 4, 4, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 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, 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:36:01,410 WARN L452 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable7 [2022-02-20 21:36:01,410 INFO L402 AbstractCegarLoop]: === Iteration 9 === Targeting ldv_errorErr0ASSERT_VIOLATIONERROR_FUNCTION === [ldv_errorErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-02-20 21:36:01,410 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-02-20 21:36:01,410 INFO L85 PathProgramCache]: Analyzing trace with hash 830531558, now seen corresponding path program 1 times [2022-02-20 21:36:01,411 INFO L126 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-02-20 21:36:01,411 INFO L338 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [722616765] [2022-02-20 21:36:01,411 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 21:36:01,411 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-02-20 21:36:01,502 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:36:01,562 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 3 [2022-02-20 21:36:01,563 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:36:01,565 INFO L290 TraceCheckUtils]: 0: Hoare triple {46988#true} assume true; {46988#true} is VALID [2022-02-20 21:36:01,566 INFO L284 TraceCheckUtils]: 1: Hoare quadruple {46988#true} {46988#true} #612#return; {46988#true} is VALID [2022-02-20 21:36:01,566 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 14 [2022-02-20 21:36:01,566 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:36:01,568 INFO L290 TraceCheckUtils]: 0: Hoare triple {46988#true} assume true; {46988#true} is VALID [2022-02-20 21:36:01,569 INFO L284 TraceCheckUtils]: 1: Hoare quadruple {46988#true} {46988#true} #614#return; {46988#true} is VALID [2022-02-20 21:36:01,574 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 18 [2022-02-20 21:36:01,576 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:36:01,580 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:36:01,582 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:36:01,584 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:36:01,586 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:36:01,589 INFO L290 TraceCheckUtils]: 0: Hoare triple {47079#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {46988#true} is VALID [2022-02-20 21:36:01,589 INFO L290 TraceCheckUtils]: 1: Hoare triple {46988#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {46988#true} is VALID [2022-02-20 21:36:01,589 INFO L290 TraceCheckUtils]: 2: Hoare triple {46988#true} assume true; {46988#true} is VALID [2022-02-20 21:36:01,589 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {46988#true} {46988#true} #590#return; {46988#true} is VALID [2022-02-20 21:36:01,589 INFO L290 TraceCheckUtils]: 0: Hoare triple {47079#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {46988#true} is VALID [2022-02-20 21:36:01,590 INFO L272 TraceCheckUtils]: 1: Hoare triple {46988#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {47079#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:36:01,591 INFO L290 TraceCheckUtils]: 2: Hoare triple {47079#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {46988#true} is VALID [2022-02-20 21:36:01,591 INFO L290 TraceCheckUtils]: 3: Hoare triple {46988#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {46988#true} is VALID [2022-02-20 21:36:01,591 INFO L290 TraceCheckUtils]: 4: Hoare triple {46988#true} assume true; {46988#true} is VALID [2022-02-20 21:36:01,591 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {46988#true} {46988#true} #590#return; {46988#true} is VALID [2022-02-20 21:36:01,591 INFO L290 TraceCheckUtils]: 6: Hoare triple {46988#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {46988#true} is VALID [2022-02-20 21:36:01,592 INFO L290 TraceCheckUtils]: 7: Hoare triple {46988#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {46988#true} is VALID [2022-02-20 21:36:01,592 INFO L290 TraceCheckUtils]: 8: Hoare triple {46988#true} assume true; {46988#true} is VALID [2022-02-20 21:36:01,592 INFO L284 TraceCheckUtils]: 9: Hoare quadruple {46988#true} {46988#true} #588#return; {46988#true} is VALID [2022-02-20 21:36:01,592 INFO L290 TraceCheckUtils]: 0: Hoare triple {47079#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size;~flags := #in~flags;havoc ~tmp~2.base, ~tmp~2.offset; {46988#true} is VALID [2022-02-20 21:36:01,593 INFO L272 TraceCheckUtils]: 1: Hoare triple {46988#true} call #t~ret40.base, #t~ret40.offset := kmalloc(~size, ~bitwiseOr(~flags, 32768)); {47079#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:36:01,593 INFO L290 TraceCheckUtils]: 2: Hoare triple {47079#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {46988#true} is VALID [2022-02-20 21:36:01,594 INFO L272 TraceCheckUtils]: 3: Hoare triple {46988#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {47079#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:36:01,594 INFO L290 TraceCheckUtils]: 4: Hoare triple {47079#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {46988#true} is VALID [2022-02-20 21:36:01,594 INFO L290 TraceCheckUtils]: 5: Hoare triple {46988#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {46988#true} is VALID [2022-02-20 21:36:01,594 INFO L290 TraceCheckUtils]: 6: Hoare triple {46988#true} assume true; {46988#true} is VALID [2022-02-20 21:36:01,594 INFO L284 TraceCheckUtils]: 7: Hoare quadruple {46988#true} {46988#true} #590#return; {46988#true} is VALID [2022-02-20 21:36:01,594 INFO L290 TraceCheckUtils]: 8: Hoare triple {46988#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {46988#true} is VALID [2022-02-20 21:36:01,595 INFO L290 TraceCheckUtils]: 9: Hoare triple {46988#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {46988#true} is VALID [2022-02-20 21:36:01,595 INFO L290 TraceCheckUtils]: 10: Hoare triple {46988#true} assume true; {46988#true} is VALID [2022-02-20 21:36:01,595 INFO L284 TraceCheckUtils]: 11: Hoare quadruple {46988#true} {46988#true} #588#return; {46988#true} is VALID [2022-02-20 21:36:01,595 INFO L290 TraceCheckUtils]: 12: Hoare triple {46988#true} ~tmp~2.base, ~tmp~2.offset := #t~ret40.base, #t~ret40.offset;havoc #t~ret40.base, #t~ret40.offset;#res.base, #res.offset := ~tmp~2.base, ~tmp~2.offset; {46988#true} is VALID [2022-02-20 21:36:01,595 INFO L290 TraceCheckUtils]: 13: Hoare triple {46988#true} assume true; {46988#true} is VALID [2022-02-20 21:36:01,595 INFO L284 TraceCheckUtils]: 14: Hoare quadruple {46988#true} {46988#true} #616#return; {46988#true} is VALID [2022-02-20 21:36:01,604 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 41 [2022-02-20 21:36:01,606 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:36:01,609 INFO L290 TraceCheckUtils]: 0: Hoare triple {47094#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;havoc ~err~0#1;assume { :begin_inline_ipmi_validate_addr } true;ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset, ipmi_validate_addr_#in~arg1#1 := ~data#1.base, 193 + ~data#1.offset, 40;havoc ipmi_validate_addr_#res#1;havoc ipmi_validate_addr_#t~nondet254#1, ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset, ipmi_validate_addr_~arg1#1;ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset := ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset;ipmi_validate_addr_~arg1#1 := ipmi_validate_addr_#in~arg1#1;assume -2147483648 <= ipmi_validate_addr_#t~nondet254#1 && ipmi_validate_addr_#t~nondet254#1 <= 2147483647;ipmi_validate_addr_#res#1 := ipmi_validate_addr_#t~nondet254#1;havoc ipmi_validate_addr_#t~nondet254#1; {46988#true} is VALID [2022-02-20 21:36:01,610 INFO L290 TraceCheckUtils]: 1: Hoare triple {46988#true} #t~ret62#1 := ipmi_validate_addr_#res#1;assume { :end_inline_ipmi_validate_addr } true;assume -2147483648 <= #t~ret62#1 && #t~ret62#1 <= 2147483647;~err~0#1 := #t~ret62#1;havoc #t~ret62#1; {46988#true} is VALID [2022-02-20 21:36:01,610 INFO L290 TraceCheckUtils]: 2: Hoare triple {46988#true} assume 0 != ~err~0#1; {46988#true} is VALID [2022-02-20 21:36:01,610 INFO L290 TraceCheckUtils]: 3: Hoare triple {46988#true} havoc #t~nondet69#1;call #t~mem70#1.base, #t~mem70#1.offset := read~$Pointer$(~data#1.base, 24 + ~data#1.offset, 8);havoc #t~mem70#1.base, #t~mem70#1.offset;#res#1 := ~err~0#1; {46988#true} is VALID [2022-02-20 21:36:01,610 INFO L290 TraceCheckUtils]: 4: Hoare triple {46988#true} assume true; {46988#true} is VALID [2022-02-20 21:36:01,610 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {46988#true} {46988#true} #618#return; {46988#true} is VALID [2022-02-20 21:36:01,611 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 49 [2022-02-20 21:36:01,611 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:36:01,614 INFO L290 TraceCheckUtils]: 0: Hoare triple {46988#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset; {46988#true} is VALID [2022-02-20 21:36:01,614 INFO L290 TraceCheckUtils]: 1: Hoare triple {46988#true} assume true; {46988#true} is VALID [2022-02-20 21:36:01,614 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {46988#true} {46988#true} #620#return; {46988#true} is VALID [2022-02-20 21:36:01,614 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 56 [2022-02-20 21:36:01,616 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:36:01,620 INFO L290 TraceCheckUtils]: 0: Hoare triple {46988#true} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;~offset#1 := #in~offset#1;havoc ~tmp~3#1;assume { :begin_inline___be16_to_cpup } true;__be16_to_cpup_#in~p#1.base, __be16_to_cpup_#in~p#1.offset := ~data#1.base, ~data#1.offset + 2 * (if ~offset#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then ~offset#1 % 18446744073709551616 % 18446744073709551616 else ~offset#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616);havoc __be16_to_cpup_#res#1;havoc __be16_to_cpup_#t~ret3#1, __be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset, __be16_to_cpup_~tmp~1#1;__be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset := __be16_to_cpup_#in~p#1.base, __be16_to_cpup_#in~p#1.offset;havoc __be16_to_cpup_~tmp~1#1;assume { :begin_inline___swab16p } true;__swab16p_#in~p#1.base, __swab16p_#in~p#1.offset := __be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset;havoc __swab16p_#res#1;havoc __swab16p_#t~mem1#1, __swab16p_#t~ret2#1, __swab16p_~p#1.base, __swab16p_~p#1.offset, __swab16p_~tmp~0#1;__swab16p_~p#1.base, __swab16p_~p#1.offset := __swab16p_#in~p#1.base, __swab16p_#in~p#1.offset;havoc __swab16p_~tmp~0#1;call __swab16p_#t~mem1#1 := read~int(__swab16p_~p#1.base, __swab16p_~p#1.offset, 2);assume { :begin_inline___fswab16 } true;__fswab16_#in~val#1 := __swab16p_#t~mem1#1 % 65536;havoc __fswab16_#res#1;havoc __fswab16_~val#1;__fswab16_~val#1 := __fswab16_#in~val#1;__fswab16_#res#1 := (if (1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) || 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536)) && 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) then (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) else (if 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) && (1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) || 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536)) then (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) else (if (1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) && (1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) || 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536))) || ((1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) || 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536)) && 1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536)) then 1 else ~bitwiseOr((if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536), (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536))))); {46988#true} is VALID [2022-02-20 21:36:01,620 INFO L290 TraceCheckUtils]: 1: Hoare triple {46988#true} __swab16p_#t~ret2#1 := __fswab16_#res#1;assume { :end_inline___fswab16 } true;__swab16p_~tmp~0#1 := __swab16p_#t~ret2#1;havoc __swab16p_#t~mem1#1;havoc __swab16p_#t~ret2#1;__swab16p_#res#1 := __swab16p_~tmp~0#1; {46988#true} is VALID [2022-02-20 21:36:01,620 INFO L290 TraceCheckUtils]: 2: Hoare triple {46988#true} __be16_to_cpup_#t~ret3#1 := __swab16p_#res#1;assume { :end_inline___swab16p } true;__be16_to_cpup_~tmp~1#1 := __be16_to_cpup_#t~ret3#1;havoc __be16_to_cpup_#t~ret3#1;__be16_to_cpup_#res#1 := __be16_to_cpup_~tmp~1#1; {46988#true} is VALID [2022-02-20 21:36:01,621 INFO L290 TraceCheckUtils]: 3: Hoare triple {46988#true} #t~ret61#1 := __be16_to_cpup_#res#1;assume { :end_inline___be16_to_cpup } true;~tmp~3#1 := #t~ret61#1;havoc #t~ret61#1;#res#1 := ~tmp~3#1; {46988#true} is VALID [2022-02-20 21:36:01,621 INFO L290 TraceCheckUtils]: 4: Hoare triple {46988#true} assume true; {46988#true} is VALID [2022-02-20 21:36:01,621 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {46988#true} {46988#true} #622#return; {46988#true} is VALID [2022-02-20 21:36:01,621 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 66 [2022-02-20 21:36:01,622 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:36:01,625 INFO L290 TraceCheckUtils]: 0: Hoare triple {47079#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {46988#true} is VALID [2022-02-20 21:36:01,625 INFO L290 TraceCheckUtils]: 1: Hoare triple {46988#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {46988#true} is VALID [2022-02-20 21:36:01,625 INFO L290 TraceCheckUtils]: 2: Hoare triple {46988#true} assume true; {46988#true} is VALID [2022-02-20 21:36:01,625 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {46988#true} {46988#true} #624#return; {46988#true} is VALID [2022-02-20 21:36:01,626 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 73 [2022-02-20 21:36:01,626 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:36:01,629 INFO L290 TraceCheckUtils]: 0: Hoare triple {46988#true} ~ptr.base, ~ptr.offset := #in~ptr.base, #in~ptr.offset;#res := (if (~ptr.base + ~ptr.offset) % 18446744073709551616 > 2012 then 1 else 0); {46988#true} is VALID [2022-02-20 21:36:01,629 INFO L290 TraceCheckUtils]: 1: Hoare triple {46988#true} assume true; {46988#true} is VALID [2022-02-20 21:36:01,629 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {46988#true} {46988#true} #626#return; {46988#true} is VALID [2022-02-20 21:36:01,629 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 80 [2022-02-20 21:36:01,631 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:36:01,633 INFO L290 TraceCheckUtils]: 0: Hoare triple {46988#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset;~arg1.base, ~arg1.offset := #in~arg1.base, #in~arg1.offset; {46988#true} is VALID [2022-02-20 21:36:01,633 INFO L290 TraceCheckUtils]: 1: Hoare triple {46988#true} assume true; {46988#true} is VALID [2022-02-20 21:36:01,633 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {46988#true} {46988#true} #628#return; {46988#true} is VALID [2022-02-20 21:36:01,633 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 87 [2022-02-20 21:36:01,635 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:36:01,638 INFO L290 TraceCheckUtils]: 0: Hoare triple {47094#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;havoc ~err~0#1;assume { :begin_inline_ipmi_validate_addr } true;ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset, ipmi_validate_addr_#in~arg1#1 := ~data#1.base, 193 + ~data#1.offset, 40;havoc ipmi_validate_addr_#res#1;havoc ipmi_validate_addr_#t~nondet254#1, ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset, ipmi_validate_addr_~arg1#1;ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset := ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset;ipmi_validate_addr_~arg1#1 := ipmi_validate_addr_#in~arg1#1;assume -2147483648 <= ipmi_validate_addr_#t~nondet254#1 && ipmi_validate_addr_#t~nondet254#1 <= 2147483647;ipmi_validate_addr_#res#1 := ipmi_validate_addr_#t~nondet254#1;havoc ipmi_validate_addr_#t~nondet254#1; {46988#true} is VALID [2022-02-20 21:36:01,638 INFO L290 TraceCheckUtils]: 1: Hoare triple {46988#true} #t~ret62#1 := ipmi_validate_addr_#res#1;assume { :end_inline_ipmi_validate_addr } true;assume -2147483648 <= #t~ret62#1 && #t~ret62#1 <= 2147483647;~err~0#1 := #t~ret62#1;havoc #t~ret62#1; {46988#true} is VALID [2022-02-20 21:36:01,638 INFO L290 TraceCheckUtils]: 2: Hoare triple {46988#true} assume 0 != ~err~0#1; {46988#true} is VALID [2022-02-20 21:36:01,638 INFO L290 TraceCheckUtils]: 3: Hoare triple {46988#true} havoc #t~nondet69#1;call #t~mem70#1.base, #t~mem70#1.offset := read~$Pointer$(~data#1.base, 24 + ~data#1.offset, 8);havoc #t~mem70#1.base, #t~mem70#1.offset;#res#1 := ~err~0#1; {46988#true} is VALID [2022-02-20 21:36:01,639 INFO L290 TraceCheckUtils]: 4: Hoare triple {46988#true} assume true; {46988#true} is VALID [2022-02-20 21:36:01,639 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {46988#true} {46988#true} #630#return; {46988#true} is VALID [2022-02-20 21:36:01,639 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 95 [2022-02-20 21:36:01,640 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:36:01,642 INFO L290 TraceCheckUtils]: 0: Hoare triple {46988#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset; {46988#true} is VALID [2022-02-20 21:36:01,642 INFO L290 TraceCheckUtils]: 1: Hoare triple {46988#true} assume true; {46988#true} is VALID [2022-02-20 21:36:01,643 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {46988#true} {46988#true} #632#return; {46988#true} is VALID [2022-02-20 21:36:01,643 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 104 [2022-02-20 21:36:01,645 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:36:01,647 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:36:01,649 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:36:01,652 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:36:01,653 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:36:01,655 INFO L290 TraceCheckUtils]: 0: Hoare triple {47079#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {46988#true} is VALID [2022-02-20 21:36:01,655 INFO L290 TraceCheckUtils]: 1: Hoare triple {46988#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {46988#true} is VALID [2022-02-20 21:36:01,655 INFO L290 TraceCheckUtils]: 2: Hoare triple {46988#true} assume true; {46988#true} is VALID [2022-02-20 21:36:01,656 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {46988#true} {46988#true} #590#return; {46988#true} is VALID [2022-02-20 21:36:01,656 INFO L290 TraceCheckUtils]: 0: Hoare triple {47079#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {46988#true} is VALID [2022-02-20 21:36:01,656 INFO L272 TraceCheckUtils]: 1: Hoare triple {46988#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {47079#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:36:01,657 INFO L290 TraceCheckUtils]: 2: Hoare triple {47079#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {46988#true} is VALID [2022-02-20 21:36:01,657 INFO L290 TraceCheckUtils]: 3: Hoare triple {46988#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {46988#true} is VALID [2022-02-20 21:36:01,657 INFO L290 TraceCheckUtils]: 4: Hoare triple {46988#true} assume true; {46988#true} is VALID [2022-02-20 21:36:01,657 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {46988#true} {46988#true} #590#return; {46988#true} is VALID [2022-02-20 21:36:01,657 INFO L290 TraceCheckUtils]: 6: Hoare triple {46988#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {46988#true} is VALID [2022-02-20 21:36:01,658 INFO L290 TraceCheckUtils]: 7: Hoare triple {46988#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {46988#true} is VALID [2022-02-20 21:36:01,658 INFO L290 TraceCheckUtils]: 8: Hoare triple {46988#true} assume true; {46988#true} is VALID [2022-02-20 21:36:01,658 INFO L284 TraceCheckUtils]: 9: Hoare quadruple {46988#true} {46988#true} #588#return; {46988#true} is VALID [2022-02-20 21:36:01,658 INFO L290 TraceCheckUtils]: 0: Hoare triple {47079#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size;~flags := #in~flags;havoc ~tmp~2.base, ~tmp~2.offset; {46988#true} is VALID [2022-02-20 21:36:01,659 INFO L272 TraceCheckUtils]: 1: Hoare triple {46988#true} call #t~ret40.base, #t~ret40.offset := kmalloc(~size, ~bitwiseOr(~flags, 32768)); {47079#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:36:01,659 INFO L290 TraceCheckUtils]: 2: Hoare triple {47079#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {46988#true} is VALID [2022-02-20 21:36:01,660 INFO L272 TraceCheckUtils]: 3: Hoare triple {46988#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {47079#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:36:01,660 INFO L290 TraceCheckUtils]: 4: Hoare triple {47079#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {46988#true} is VALID [2022-02-20 21:36:01,660 INFO L290 TraceCheckUtils]: 5: Hoare triple {46988#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {46988#true} is VALID [2022-02-20 21:36:01,660 INFO L290 TraceCheckUtils]: 6: Hoare triple {46988#true} assume true; {46988#true} is VALID [2022-02-20 21:36:01,660 INFO L284 TraceCheckUtils]: 7: Hoare quadruple {46988#true} {46988#true} #590#return; {46988#true} is VALID [2022-02-20 21:36:01,660 INFO L290 TraceCheckUtils]: 8: Hoare triple {46988#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {46988#true} is VALID [2022-02-20 21:36:01,661 INFO L290 TraceCheckUtils]: 9: Hoare triple {46988#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {46988#true} is VALID [2022-02-20 21:36:01,661 INFO L290 TraceCheckUtils]: 10: Hoare triple {46988#true} assume true; {46988#true} is VALID [2022-02-20 21:36:01,661 INFO L284 TraceCheckUtils]: 11: Hoare quadruple {46988#true} {46988#true} #588#return; {46988#true} is VALID [2022-02-20 21:36:01,661 INFO L290 TraceCheckUtils]: 12: Hoare triple {46988#true} ~tmp~2.base, ~tmp~2.offset := #t~ret40.base, #t~ret40.offset;havoc #t~ret40.base, #t~ret40.offset;#res.base, #res.offset := ~tmp~2.base, ~tmp~2.offset; {46988#true} is VALID [2022-02-20 21:36:01,661 INFO L290 TraceCheckUtils]: 13: Hoare triple {46988#true} assume true; {46988#true} is VALID [2022-02-20 21:36:01,662 INFO L284 TraceCheckUtils]: 14: Hoare quadruple {46988#true} {46988#true} #634#return; {46988#true} is VALID [2022-02-20 21:36:01,662 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 125 [2022-02-20 21:36:01,664 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:36:01,668 INFO L290 TraceCheckUtils]: 0: Hoare triple {47094#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;havoc ~err~0#1;assume { :begin_inline_ipmi_validate_addr } true;ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset, ipmi_validate_addr_#in~arg1#1 := ~data#1.base, 193 + ~data#1.offset, 40;havoc ipmi_validate_addr_#res#1;havoc ipmi_validate_addr_#t~nondet254#1, ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset, ipmi_validate_addr_~arg1#1;ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset := ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset;ipmi_validate_addr_~arg1#1 := ipmi_validate_addr_#in~arg1#1;assume -2147483648 <= ipmi_validate_addr_#t~nondet254#1 && ipmi_validate_addr_#t~nondet254#1 <= 2147483647;ipmi_validate_addr_#res#1 := ipmi_validate_addr_#t~nondet254#1;havoc ipmi_validate_addr_#t~nondet254#1; {46988#true} is VALID [2022-02-20 21:36:01,668 INFO L290 TraceCheckUtils]: 1: Hoare triple {46988#true} #t~ret62#1 := ipmi_validate_addr_#res#1;assume { :end_inline_ipmi_validate_addr } true;assume -2147483648 <= #t~ret62#1 && #t~ret62#1 <= 2147483647;~err~0#1 := #t~ret62#1;havoc #t~ret62#1; {46988#true} is VALID [2022-02-20 21:36:01,668 INFO L290 TraceCheckUtils]: 2: Hoare triple {46988#true} assume 0 != ~err~0#1; {46988#true} is VALID [2022-02-20 21:36:01,668 INFO L290 TraceCheckUtils]: 3: Hoare triple {46988#true} havoc #t~nondet69#1;call #t~mem70#1.base, #t~mem70#1.offset := read~$Pointer$(~data#1.base, 24 + ~data#1.offset, 8);havoc #t~mem70#1.base, #t~mem70#1.offset;#res#1 := ~err~0#1; {46988#true} is VALID [2022-02-20 21:36:01,668 INFO L290 TraceCheckUtils]: 4: Hoare triple {46988#true} assume true; {46988#true} is VALID [2022-02-20 21:36:01,669 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {46988#true} {46988#true} #636#return; {46988#true} is VALID [2022-02-20 21:36:01,669 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 133 [2022-02-20 21:36:01,670 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:36:01,672 INFO L290 TraceCheckUtils]: 0: Hoare triple {46988#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset; {46988#true} is VALID [2022-02-20 21:36:01,672 INFO L290 TraceCheckUtils]: 1: Hoare triple {46988#true} assume true; {46988#true} is VALID [2022-02-20 21:36:01,672 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {46988#true} {46988#true} #638#return; {46988#true} is VALID [2022-02-20 21:36:01,672 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 151 [2022-02-20 21:36:01,675 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:36:01,679 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 1 [2022-02-20 21:36:01,681 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 21:36:01,688 INFO L290 TraceCheckUtils]: 0: Hoare triple {47079#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {46988#true} is VALID [2022-02-20 21:36:01,688 INFO L290 TraceCheckUtils]: 1: Hoare triple {46988#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {46988#true} is VALID [2022-02-20 21:36:01,688 INFO L290 TraceCheckUtils]: 2: Hoare triple {46988#true} assume true; {46988#true} is VALID [2022-02-20 21:36:01,689 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {46988#true} {46988#true} #590#return; {46988#true} is VALID [2022-02-20 21:36:01,689 INFO L290 TraceCheckUtils]: 0: Hoare triple {47079#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {46988#true} is VALID [2022-02-20 21:36:01,690 INFO L272 TraceCheckUtils]: 1: Hoare triple {46988#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {47079#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:36:01,690 INFO L290 TraceCheckUtils]: 2: Hoare triple {47079#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {46988#true} is VALID [2022-02-20 21:36:01,690 INFO L290 TraceCheckUtils]: 3: Hoare triple {46988#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {46988#true} is VALID [2022-02-20 21:36:01,690 INFO L290 TraceCheckUtils]: 4: Hoare triple {46988#true} assume true; {46988#true} is VALID [2022-02-20 21:36:01,690 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {46988#true} {46988#true} #590#return; {46988#true} is VALID [2022-02-20 21:36:01,690 INFO L290 TraceCheckUtils]: 6: Hoare triple {46988#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {46988#true} is VALID [2022-02-20 21:36:01,691 INFO L290 TraceCheckUtils]: 7: Hoare triple {46988#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {46988#true} is VALID [2022-02-20 21:36:01,691 INFO L290 TraceCheckUtils]: 8: Hoare triple {46988#true} assume true; {46988#true} is VALID [2022-02-20 21:36:01,691 INFO L284 TraceCheckUtils]: 9: Hoare quadruple {46988#true} {47068#(= 2 |ULTIMATE.start_create_sensor_~type#1|)} #640#return; {47068#(= 2 |ULTIMATE.start_create_sensor_~type#1|)} is VALID [2022-02-20 21:36:01,692 INFO L290 TraceCheckUtils]: 0: Hoare triple {46988#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(46, 2);call #Ultimate.allocInit(13, 3);call #Ultimate.allocInit(20, 4);call #Ultimate.allocInit(21, 5);call #Ultimate.allocInit(11, 6);call #Ultimate.allocInit(18, 7);call #Ultimate.allocInit(19, 8);call #Ultimate.allocInit(20, 9);call #Ultimate.allocInit(18, 10);call #Ultimate.allocInit(69, 11);call #Ultimate.allocInit(26, 12);call #Ultimate.allocInit(4, 13);call write~init~int(37, 13, 0, 1);call write~init~int(115, 13, 1, 1);call write~init~int(10, 13, 2, 1);call write~init~int(0, 13, 3, 1);call #Ultimate.allocInit(7, 14);call write~init~int(105, 14, 0, 1);call write~init~int(98, 14, 1, 1);call write~init~int(109, 14, 2, 1);call write~init~int(112, 14, 3, 1);call write~init~int(101, 14, 4, 1);call write~init~int(120, 14, 5, 1);call write~init~int(0, 14, 6, 1);call #Ultimate.allocInit(5, 15);call write~init~int(110, 15, 0, 1);call write~init~int(97, 15, 1, 1);call write~init~int(109, 15, 2, 1);call write~init~int(101, 15, 3, 1);call write~init~int(0, 15, 4, 1);call #Ultimate.allocInit(4, 16);call write~init~int(37, 16, 0, 1);call write~init~int(100, 16, 1, 1);call write~init~int(10, 16, 2, 1);call write~init~int(0, 16, 3, 1);call #Ultimate.allocInit(15, 17);call #Ultimate.allocInit(5, 18);call write~init~int(116, 18, 0, 1);call write~init~int(101, 18, 1, 1);call write~init~int(109, 18, 2, 1);call write~init~int(112, 18, 3, 1);call write~init~int(0, 18, 4, 1);call #Ultimate.allocInit(6, 19);call write~init~int(112, 19, 0, 1);call write~init~int(111, 19, 1, 1);call write~init~int(119, 19, 2, 1);call write~init~int(101, 19, 3, 1);call write~init~int(114, 19, 4, 1);call write~init~int(0, 19, 5, 1);call #Ultimate.allocInit(40, 20);call #Ultimate.allocInit(48, 21);call #Ultimate.allocInit(12, 22);call #Ultimate.allocInit(55, 23);call #Ultimate.allocInit(26, 24);call #Ultimate.allocInit(70, 25);~#power_sensor_sig~0.base, ~#power_sensor_sig~0.offset := 26, 0;call #Ultimate.allocInit(3, 26);call write~init~int(112, ~#power_sensor_sig~0.base, ~#power_sensor_sig~0.offset, 1);call write~init~int(119, ~#power_sensor_sig~0.base, 1 + ~#power_sensor_sig~0.offset, 1);call write~init~int(114, ~#power_sensor_sig~0.base, 2 + ~#power_sensor_sig~0.offset, 1);~#temp_sensor_sig~0.base, ~#temp_sensor_sig~0.offset := 27, 0;call #Ultimate.allocInit(3, 27);call write~init~int(116, ~#temp_sensor_sig~0.base, ~#temp_sensor_sig~0.offset, 1);call write~init~int(101, ~#temp_sensor_sig~0.base, 1 + ~#temp_sensor_sig~0.offset, 1);call write~init~int(109, ~#temp_sensor_sig~0.base, 2 + ~#temp_sensor_sig~0.offset, 1);~#watt_sensor_sig~0.base, ~#watt_sensor_sig~0.offset := 28, 0;call #Ultimate.allocInit(2, 28);call write~init~int(65, ~#watt_sensor_sig~0.base, ~#watt_sensor_sig~0.offset, 1);call write~init~int(67, ~#watt_sensor_sig~0.base, 1 + ~#watt_sensor_sig~0.offset, 1);~#power_sensor_name_templates~0.base, ~#power_sensor_name_templates~0.offset := 29, 0;call #Ultimate.allocInit(24, 29);call write~init~$Pointer$(3, 0, ~#power_sensor_name_templates~0.base, ~#power_sensor_name_templates~0.offset, 8);call write~init~$Pointer$(4, 0, ~#power_sensor_name_templates~0.base, 8 + ~#power_sensor_name_templates~0.offset, 8);call write~init~$Pointer$(5, 0, ~#power_sensor_name_templates~0.base, 16 + ~#power_sensor_name_templates~0.offset, 8);~#temp_sensor_name_templates~0.base, ~#temp_sensor_name_templates~0.offset := 30, 0;call #Ultimate.allocInit(24, 30);call write~init~$Pointer$(6, 0, ~#temp_sensor_name_templates~0.base, ~#temp_sensor_name_templates~0.offset, 8);call write~init~$Pointer$(7, 0, ~#temp_sensor_name_templates~0.base, 8 + ~#temp_sensor_name_templates~0.offset, 8);call write~init~$Pointer$(8, 0, ~#temp_sensor_name_templates~0.base, 16 + ~#temp_sensor_name_templates~0.offset, 8);~#driver_data~0.base, ~#driver_data~0.offset := 31, 0;call #Ultimate.allocInit(72, 31);call write~init~$Pointer$(~#driver_data~0.base, ~#driver_data~0.offset, ~#driver_data~0.base, ~#driver_data~0.offset, 8);call write~init~$Pointer$(~#driver_data~0.base, ~#driver_data~0.offset, ~#driver_data~0.base, 8 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(0, 0, ~#driver_data~0.base, 16 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(0, 0, ~#driver_data~0.base, 24 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(~#__this_module~0.base, ~#__this_module~0.offset, ~#driver_data~0.base, 32 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(#funAddr~ibmpex_register_bmc.base, #funAddr~ibmpex_register_bmc.offset, ~#driver_data~0.base, 40 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(#funAddr~ibmpex_bmc_gone.base, #funAddr~ibmpex_bmc_gone.offset, ~#driver_data~0.base, 48 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(#funAddr~ibmpex_msg_handler.base, #funAddr~ibmpex_msg_handler.offset, ~#driver_data~0.base, 56 + ~#driver_data~0.offset, 8);call write~init~$Pointer$(0, 0, ~#driver_data~0.base, 64 + ~#driver_data~0.offset, 8);~#sensor_dev_attr_name~0.base, ~#sensor_dev_attr_name~0.offset := 32, 0;call #Ultimate.allocInit(48, 32);call write~init~$Pointer$(15, 0, ~#sensor_dev_attr_name~0.base, ~#sensor_dev_attr_name~0.offset, 8);call write~init~int(292, ~#sensor_dev_attr_name~0.base, 8 + ~#sensor_dev_attr_name~0.offset, 4);call write~init~$Pointer$(0, 0, ~#sensor_dev_attr_name~0.base, 12 + ~#sensor_dev_attr_name~0.offset, 8);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 20 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 21 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 22 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 23 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 24 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 25 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 26 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 27 + ~#sensor_dev_attr_name~0.offset, 1);call write~init~$Pointer$(#funAddr~show_name.base, #funAddr~show_name.offset, ~#sensor_dev_attr_name~0.base, 28 + ~#sensor_dev_attr_name~0.offset, 8);call write~init~$Pointer$(0, 0, ~#sensor_dev_attr_name~0.base, 36 + ~#sensor_dev_attr_name~0.offset, 8);call write~init~int(0, ~#sensor_dev_attr_name~0.base, 44 + ~#sensor_dev_attr_name~0.offset, 4);~#sensor_dev_attr_reset_high_low~0.base, ~#sensor_dev_attr_reset_high_low~0.offset := 33, 0;call #Ultimate.allocInit(48, 33);call write~init~$Pointer$(17, 0, ~#sensor_dev_attr_reset_high_low~0.base, ~#sensor_dev_attr_reset_high_low~0.offset, 8);call write~init~int(128, ~#sensor_dev_attr_reset_high_low~0.base, 8 + ~#sensor_dev_attr_reset_high_low~0.offset, 4);call write~init~$Pointer$(0, 0, ~#sensor_dev_attr_reset_high_low~0.base, 12 + ~#sensor_dev_attr_reset_high_low~0.offset, 8);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 20 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 21 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 22 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 23 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 24 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 25 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 26 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 27 + ~#sensor_dev_attr_reset_high_low~0.offset, 1);call write~init~$Pointer$(0, 0, ~#sensor_dev_attr_reset_high_low~0.base, 28 + ~#sensor_dev_attr_reset_high_low~0.offset, 8);call write~init~$Pointer$(#funAddr~ibmpex_reset_high_low.base, #funAddr~ibmpex_reset_high_low.offset, ~#sensor_dev_attr_reset_high_low~0.base, 36 + ~#sensor_dev_attr_reset_high_low~0.offset, 8);call write~init~int(0, ~#sensor_dev_attr_reset_high_low~0.base, 44 + ~#sensor_dev_attr_reset_high_low~0.offset, 4);~LDV_IN_INTERRUPT~0 := 0;~ldv_count_1~0 := 0;~ldv_count_2~0 := 0;~ldv_call_dev_attr_of_sensor_device_attribute~0 := 0;~ldv_call_dev_attr_of_sensor_device_attribute_2~0 := 0; {46988#true} is VALID [2022-02-20 21:36:01,692 INFO L290 TraceCheckUtils]: 1: Hoare triple {46988#true} assume { :end_inline_ULTIMATE.init } true;assume { :begin_inline_main } true;havoc main_#res#1;havoc main_#t~ret236#1, main_#t~nondet237#1, main_#t~switch238#1, main_#t~nondet239#1, main_~var_ibmpex_register_bmc_17_p0~0#1, main_~var_group1~0#1.base, main_~var_group1~0#1.offset, main_~var_ibmpex_bmc_gone_19_p0~0#1, main_~#var_group2~0#1.base, main_~#var_group2~0#1.offset, main_~#var_ibmpex_msg_handler_20_p1~0#1.base, main_~#var_ibmpex_msg_handler_20_p1~0#1.offset, main_~tmp~17#1, main_~tmp___0~4#1, main_~tmp___1~2#1;havoc main_~var_ibmpex_register_bmc_17_p0~0#1;havoc main_~var_group1~0#1.base, main_~var_group1~0#1.offset;havoc main_~var_ibmpex_bmc_gone_19_p0~0#1;call main_~#var_group2~0#1.base, main_~#var_group2~0#1.offset := #Ultimate.allocOnStack(374);call main_~#var_ibmpex_msg_handler_20_p1~0#1.base, main_~#var_ibmpex_msg_handler_20_p1~0#1.offset := #Ultimate.allocOnStack(915);havoc main_~tmp~17#1;havoc main_~tmp___0~4#1;havoc main_~tmp___1~2#1;~LDV_IN_INTERRUPT~0 := 1;assume { :begin_inline_ldv_initialize } true;~ldv_count_1~0 := 1 + ~ldv_count_1~0;~ldv_count_1~0 := 1 + ~ldv_count_1~0;~ldv_count_1~0 := 1 + ~ldv_count_1~0;~ldv_count_1~0 := 1 + ~ldv_count_1~0;~ldv_count_1~0 := 1 + ~ldv_count_1~0;~ldv_count_1~0 := 1 + ~ldv_count_1~0; {46988#true} is VALID [2022-02-20 21:36:01,692 INFO L290 TraceCheckUtils]: 2: Hoare triple {46988#true} assume { :end_inline_ldv_initialize } true; {46988#true} is VALID [2022-02-20 21:36:01,692 INFO L272 TraceCheckUtils]: 3: Hoare triple {46988#true} call ldv_handler_precall(); {46988#true} is VALID [2022-02-20 21:36:01,693 INFO L290 TraceCheckUtils]: 4: Hoare triple {46988#true} assume true; {46988#true} is VALID [2022-02-20 21:36:01,693 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {46988#true} {46988#true} #612#return; {46988#true} is VALID [2022-02-20 21:36:01,693 INFO L290 TraceCheckUtils]: 6: Hoare triple {46988#true} assume { :begin_inline_ibmpex_init } true;havoc ibmpex_init_#res#1;havoc ibmpex_init_#t~ret231#1, ibmpex_init_~tmp~16#1;havoc ibmpex_init_~tmp~16#1;assume { :begin_inline_ipmi_smi_watcher_register } true;ipmi_smi_watcher_register_#in~arg0#1.base, ipmi_smi_watcher_register_#in~arg0#1.offset := ~#driver_data~0.base, 16 + ~#driver_data~0.offset;havoc ipmi_smi_watcher_register_#res#1;havoc ipmi_smi_watcher_register_#t~nondet252#1, ipmi_smi_watcher_register_~arg0#1.base, ipmi_smi_watcher_register_~arg0#1.offset;ipmi_smi_watcher_register_~arg0#1.base, ipmi_smi_watcher_register_~arg0#1.offset := ipmi_smi_watcher_register_#in~arg0#1.base, ipmi_smi_watcher_register_#in~arg0#1.offset;assume -2147483648 <= ipmi_smi_watcher_register_#t~nondet252#1 && ipmi_smi_watcher_register_#t~nondet252#1 <= 2147483647;ipmi_smi_watcher_register_#res#1 := ipmi_smi_watcher_register_#t~nondet252#1;havoc ipmi_smi_watcher_register_#t~nondet252#1; {46988#true} is VALID [2022-02-20 21:36:01,693 INFO L290 TraceCheckUtils]: 7: Hoare triple {46988#true} ibmpex_init_#t~ret231#1 := ipmi_smi_watcher_register_#res#1;assume { :end_inline_ipmi_smi_watcher_register } true;assume -2147483648 <= ibmpex_init_#t~ret231#1 && ibmpex_init_#t~ret231#1 <= 2147483647;ibmpex_init_~tmp~16#1 := ibmpex_init_#t~ret231#1;havoc ibmpex_init_#t~ret231#1;ibmpex_init_#res#1 := ibmpex_init_~tmp~16#1; {46988#true} is VALID [2022-02-20 21:36:01,693 INFO L290 TraceCheckUtils]: 8: Hoare triple {46988#true} main_#t~ret236#1 := ibmpex_init_#res#1;assume { :end_inline_ibmpex_init } true;assume -2147483648 <= main_#t~ret236#1 && main_#t~ret236#1 <= 2147483647;main_~tmp~17#1 := main_#t~ret236#1;havoc main_#t~ret236#1; {46988#true} is VALID [2022-02-20 21:36:01,693 INFO L290 TraceCheckUtils]: 9: Hoare triple {46988#true} assume !(0 != main_~tmp~17#1); {46988#true} is VALID [2022-02-20 21:36:01,694 INFO L290 TraceCheckUtils]: 10: Hoare triple {46988#true} assume -2147483648 <= main_#t~nondet239#1 && main_#t~nondet239#1 <= 2147483647;main_~tmp___1~2#1 := main_#t~nondet239#1;havoc main_#t~nondet239#1; {46988#true} is VALID [2022-02-20 21:36:01,694 INFO L290 TraceCheckUtils]: 11: Hoare triple {46988#true} assume 0 != main_~tmp___1~2#1; {46988#true} is VALID [2022-02-20 21:36:01,694 INFO L290 TraceCheckUtils]: 12: Hoare triple {46988#true} assume -2147483648 <= main_#t~nondet237#1 && main_#t~nondet237#1 <= 2147483647;main_~tmp___0~4#1 := main_#t~nondet237#1;havoc main_#t~nondet237#1;main_#t~switch238#1 := 0 == main_~tmp___0~4#1; {46988#true} is VALID [2022-02-20 21:36:01,694 INFO L290 TraceCheckUtils]: 13: Hoare triple {46988#true} assume main_#t~switch238#1; {46988#true} is VALID [2022-02-20 21:36:01,694 INFO L272 TraceCheckUtils]: 14: Hoare triple {46988#true} call ldv_handler_precall(); {46988#true} is VALID [2022-02-20 21:36:01,694 INFO L290 TraceCheckUtils]: 15: Hoare triple {46988#true} assume true; {46988#true} is VALID [2022-02-20 21:36:01,695 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {46988#true} {46988#true} #614#return; {46988#true} is VALID [2022-02-20 21:36:01,695 INFO L290 TraceCheckUtils]: 17: Hoare triple {46988#true} assume { :begin_inline_ibmpex_register_bmc } true;ibmpex_register_bmc_#in~iface#1, ibmpex_register_bmc_#in~dev#1.base, ibmpex_register_bmc_#in~dev#1.offset := main_~var_ibmpex_register_bmc_17_p0~0#1, main_~var_group1~0#1.base, main_~var_group1~0#1.offset;havoc ibmpex_register_bmc_#t~ret178#1.base, ibmpex_register_bmc_#t~ret178#1.offset, ibmpex_register_bmc_#t~nondet179#1, ibmpex_register_bmc_#t~mem180#1, ibmpex_register_bmc_#t~ret181#1, ibmpex_register_bmc_#t~nondet182#1, ibmpex_register_bmc_#t~mem183#1, ibmpex_register_bmc_#t~ret184#1, ibmpex_register_bmc_#t~mem185#1.base, ibmpex_register_bmc_#t~mem185#1.offset, ibmpex_register_bmc_#t~ret186#1.base, ibmpex_register_bmc_#t~ret186#1.offset, ibmpex_register_bmc_#t~mem187#1.base, ibmpex_register_bmc_#t~mem187#1.offset, ibmpex_register_bmc_#t~ret188#1, ibmpex_register_bmc_#t~nondet189#1, ibmpex_register_bmc_#t~mem190#1.base, ibmpex_register_bmc_#t~mem190#1.offset, ibmpex_register_bmc_#t~mem191#1, ibmpex_register_bmc_#t~ret192#1, ibmpex_register_bmc_#t~nondet193#1, ibmpex_register_bmc_#t~mem194#1.base, ibmpex_register_bmc_#t~mem194#1.offset, ibmpex_register_bmc_#t~mem195#1.base, ibmpex_register_bmc_#t~mem195#1.offset, ibmpex_register_bmc_#t~mem196#1.base, ibmpex_register_bmc_#t~mem196#1.offset, ibmpex_register_bmc_#t~ret197#1, ibmpex_register_bmc_~iface#1, ibmpex_register_bmc_~dev#1.base, ibmpex_register_bmc_~dev#1.offset, ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset, ibmpex_register_bmc_~err~4#1, ibmpex_register_bmc_~tmp~14#1.base, ibmpex_register_bmc_~tmp~14#1.offset, ibmpex_register_bmc_~#__key~1#1.base, ibmpex_register_bmc_~#__key~1#1.offset, ibmpex_register_bmc_~tmp___0~3#1;ibmpex_register_bmc_~iface#1 := ibmpex_register_bmc_#in~iface#1;ibmpex_register_bmc_~dev#1.base, ibmpex_register_bmc_~dev#1.offset := ibmpex_register_bmc_#in~dev#1.base, ibmpex_register_bmc_#in~dev#1.offset;havoc ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset;havoc ibmpex_register_bmc_~err~4#1;havoc ibmpex_register_bmc_~tmp~14#1.base, ibmpex_register_bmc_~tmp~14#1.offset;call ibmpex_register_bmc_~#__key~1#1.base, ibmpex_register_bmc_~#__key~1#1.offset := #Ultimate.allocOnStack(8);havoc ibmpex_register_bmc_~tmp___0~3#1; {46988#true} is VALID [2022-02-20 21:36:01,696 INFO L272 TraceCheckUtils]: 18: Hoare triple {46988#true} call ibmpex_register_bmc_#t~ret178#1.base, ibmpex_register_bmc_#t~ret178#1.offset := kzalloc(968, 208); {47079#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:36:01,696 INFO L290 TraceCheckUtils]: 19: Hoare triple {47079#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size;~flags := #in~flags;havoc ~tmp~2.base, ~tmp~2.offset; {46988#true} is VALID [2022-02-20 21:36:01,696 INFO L272 TraceCheckUtils]: 20: Hoare triple {46988#true} call #t~ret40.base, #t~ret40.offset := kmalloc(~size, ~bitwiseOr(~flags, 32768)); {47079#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:36:01,697 INFO L290 TraceCheckUtils]: 21: Hoare triple {47079#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {46988#true} is VALID [2022-02-20 21:36:01,697 INFO L272 TraceCheckUtils]: 22: Hoare triple {46988#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {47079#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:36:01,697 INFO L290 TraceCheckUtils]: 23: Hoare triple {47079#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {46988#true} is VALID [2022-02-20 21:36:01,697 INFO L290 TraceCheckUtils]: 24: Hoare triple {46988#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {46988#true} is VALID [2022-02-20 21:36:01,698 INFO L290 TraceCheckUtils]: 25: Hoare triple {46988#true} assume true; {46988#true} is VALID [2022-02-20 21:36:01,698 INFO L284 TraceCheckUtils]: 26: Hoare quadruple {46988#true} {46988#true} #590#return; {46988#true} is VALID [2022-02-20 21:36:01,698 INFO L290 TraceCheckUtils]: 27: Hoare triple {46988#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {46988#true} is VALID [2022-02-20 21:36:01,698 INFO L290 TraceCheckUtils]: 28: Hoare triple {46988#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {46988#true} is VALID [2022-02-20 21:36:01,698 INFO L290 TraceCheckUtils]: 29: Hoare triple {46988#true} assume true; {46988#true} is VALID [2022-02-20 21:36:01,699 INFO L284 TraceCheckUtils]: 30: Hoare quadruple {46988#true} {46988#true} #588#return; {46988#true} is VALID [2022-02-20 21:36:01,699 INFO L290 TraceCheckUtils]: 31: Hoare triple {46988#true} ~tmp~2.base, ~tmp~2.offset := #t~ret40.base, #t~ret40.offset;havoc #t~ret40.base, #t~ret40.offset;#res.base, #res.offset := ~tmp~2.base, ~tmp~2.offset; {46988#true} is VALID [2022-02-20 21:36:01,699 INFO L290 TraceCheckUtils]: 32: Hoare triple {46988#true} assume true; {46988#true} is VALID [2022-02-20 21:36:01,699 INFO L284 TraceCheckUtils]: 33: Hoare quadruple {46988#true} {46988#true} #616#return; {46988#true} is VALID [2022-02-20 21:36:01,699 INFO L290 TraceCheckUtils]: 34: Hoare triple {46988#true} ibmpex_register_bmc_~tmp~14#1.base, ibmpex_register_bmc_~tmp~14#1.offset := ibmpex_register_bmc_#t~ret178#1.base, ibmpex_register_bmc_#t~ret178#1.offset;havoc ibmpex_register_bmc_#t~ret178#1.base, ibmpex_register_bmc_#t~ret178#1.offset;ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset := ibmpex_register_bmc_~tmp~14#1.base, ibmpex_register_bmc_~tmp~14#1.offset; {46988#true} is VALID [2022-02-20 21:36:01,699 INFO L290 TraceCheckUtils]: 35: Hoare triple {46988#true} assume !(0 == (ibmpex_register_bmc_~data~2#1.base + ibmpex_register_bmc_~data~2#1.offset) % 18446744073709551616);call write~int(12, ibmpex_register_bmc_~data~2#1.base, 193 + ibmpex_register_bmc_~data~2#1.offset, 4);call write~int(15, ibmpex_register_bmc_~data~2#1.base, 197 + ibmpex_register_bmc_~data~2#1.offset, 2);call write~int(0, ibmpex_register_bmc_~data~2#1.base, 199 + ibmpex_register_bmc_~data~2#1.offset, 1);call write~int(ibmpex_register_bmc_~iface#1, ibmpex_register_bmc_~data~2#1.base, 323 + ibmpex_register_bmc_~data~2#1.offset, 4);call write~$Pointer$(ibmpex_register_bmc_~dev#1.base, ibmpex_register_bmc_~dev#1.offset, ibmpex_register_bmc_~data~2#1.base, 24 + ibmpex_register_bmc_~data~2#1.offset, 8);call ibmpex_register_bmc_#t~mem180#1 := read~int(ibmpex_register_bmc_~data~2#1.base, 323 + ibmpex_register_bmc_~data~2#1.offset, 4);assume { :begin_inline_ipmi_create_user } true;ipmi_create_user_#in~arg0#1, ipmi_create_user_#in~arg1#1.base, ipmi_create_user_#in~arg1#1.offset, ipmi_create_user_#in~arg2#1.base, ipmi_create_user_#in~arg2#1.offset, ipmi_create_user_#in~arg3#1.base, ipmi_create_user_#in~arg3#1.offset := ibmpex_register_bmc_#t~mem180#1, ~#driver_data~0.base, 56 + ~#driver_data~0.offset, ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset, ibmpex_register_bmc_~data~2#1.base, 315 + ibmpex_register_bmc_~data~2#1.offset;havoc ipmi_create_user_#res#1;havoc ipmi_create_user_#t~nondet249#1, ipmi_create_user_~arg0#1, ipmi_create_user_~arg1#1.base, ipmi_create_user_~arg1#1.offset, ipmi_create_user_~arg2#1.base, ipmi_create_user_~arg2#1.offset, ipmi_create_user_~arg3#1.base, ipmi_create_user_~arg3#1.offset;ipmi_create_user_~arg0#1 := ipmi_create_user_#in~arg0#1;ipmi_create_user_~arg1#1.base, ipmi_create_user_~arg1#1.offset := ipmi_create_user_#in~arg1#1.base, ipmi_create_user_#in~arg1#1.offset;ipmi_create_user_~arg2#1.base, ipmi_create_user_~arg2#1.offset := ipmi_create_user_#in~arg2#1.base, ipmi_create_user_#in~arg2#1.offset;ipmi_create_user_~arg3#1.base, ipmi_create_user_~arg3#1.offset := ipmi_create_user_#in~arg3#1.base, ipmi_create_user_#in~arg3#1.offset;assume -2147483648 <= ipmi_create_user_#t~nondet249#1 && ipmi_create_user_#t~nondet249#1 <= 2147483647;ipmi_create_user_#res#1 := ipmi_create_user_#t~nondet249#1;havoc ipmi_create_user_#t~nondet249#1; {46988#true} is VALID [2022-02-20 21:36:01,700 INFO L290 TraceCheckUtils]: 36: Hoare triple {46988#true} ibmpex_register_bmc_#t~ret181#1 := ipmi_create_user_#res#1;assume { :end_inline_ipmi_create_user } true;assume -2147483648 <= ibmpex_register_bmc_#t~ret181#1 && ibmpex_register_bmc_#t~ret181#1 <= 2147483647;ibmpex_register_bmc_~err~4#1 := ibmpex_register_bmc_#t~ret181#1;havoc ibmpex_register_bmc_#t~mem180#1;havoc ibmpex_register_bmc_#t~ret181#1; {46988#true} is VALID [2022-02-20 21:36:01,700 INFO L290 TraceCheckUtils]: 37: Hoare triple {46988#true} assume !(ibmpex_register_bmc_~err~4#1 < 0);assume { :begin_inline___mutex_init } true;__mutex_init_#in~arg0#1.base, __mutex_init_#in~arg0#1.offset, __mutex_init_#in~arg1#1.base, __mutex_init_#in~arg1#1.offset, __mutex_init_#in~arg2#1.base, __mutex_init_#in~arg2#1.offset := ibmpex_register_bmc_~data~2#1.base, 32 + ibmpex_register_bmc_~data~2#1.offset, 22, 0, ibmpex_register_bmc_~#__key~1#1.base, ibmpex_register_bmc_~#__key~1#1.offset;havoc __mutex_init_~arg0#1.base, __mutex_init_~arg0#1.offset, __mutex_init_~arg1#1.base, __mutex_init_~arg1#1.offset, __mutex_init_~arg2#1.base, __mutex_init_~arg2#1.offset;__mutex_init_~arg0#1.base, __mutex_init_~arg0#1.offset := __mutex_init_#in~arg0#1.base, __mutex_init_#in~arg0#1.offset;__mutex_init_~arg1#1.base, __mutex_init_~arg1#1.offset := __mutex_init_#in~arg1#1.base, __mutex_init_#in~arg1#1.offset;__mutex_init_~arg2#1.base, __mutex_init_~arg2#1.offset := __mutex_init_#in~arg2#1.base, __mutex_init_#in~arg2#1.offset; {46988#true} is VALID [2022-02-20 21:36:01,700 INFO L290 TraceCheckUtils]: 38: Hoare triple {46988#true} assume { :end_inline___mutex_init } true;call write~int(0, ibmpex_register_bmc_~data~2#1.base, 611 + ibmpex_register_bmc_~data~2#1.offset, 8);assume { :begin_inline_init_completion } true;init_completion_#in~x#1.base, init_completion_#in~x#1.offset := ibmpex_register_bmc_~data~2#1.base, 231 + ibmpex_register_bmc_~data~2#1.offset;havoc init_completion_~x#1.base, init_completion_~x#1.offset, init_completion_~#__key~0#1.base, init_completion_~#__key~0#1.offset;init_completion_~x#1.base, init_completion_~x#1.offset := init_completion_#in~x#1.base, init_completion_#in~x#1.offset;call init_completion_~#__key~0#1.base, init_completion_~#__key~0#1.offset := #Ultimate.allocOnStack(8);call write~int(0, init_completion_~x#1.base, init_completion_~x#1.offset, 4);assume { :begin_inline___init_waitqueue_head } true;__init_waitqueue_head_#in~arg0#1.base, __init_waitqueue_head_#in~arg0#1.offset, __init_waitqueue_head_#in~arg1#1.base, __init_waitqueue_head_#in~arg1#1.offset := init_completion_~x#1.base, 4 + init_completion_~x#1.offset, init_completion_~#__key~0#1.base, init_completion_~#__key~0#1.offset;havoc __init_waitqueue_head_~arg0#1.base, __init_waitqueue_head_~arg0#1.offset, __init_waitqueue_head_~arg1#1.base, __init_waitqueue_head_~arg1#1.offset;__init_waitqueue_head_~arg0#1.base, __init_waitqueue_head_~arg0#1.offset := __init_waitqueue_head_#in~arg0#1.base, __init_waitqueue_head_#in~arg0#1.offset;__init_waitqueue_head_~arg1#1.base, __init_waitqueue_head_~arg1#1.offset := __init_waitqueue_head_#in~arg1#1.base, __init_waitqueue_head_#in~arg1#1.offset; {46988#true} is VALID [2022-02-20 21:36:01,700 INFO L290 TraceCheckUtils]: 39: Hoare triple {46988#true} assume { :end_inline___init_waitqueue_head } true;call ULTIMATE.dealloc(init_completion_~#__key~0#1.base, init_completion_~#__key~0#1.offset);havoc init_completion_~#__key~0#1.base, init_completion_~#__key~0#1.offset; {46988#true} is VALID [2022-02-20 21:36:01,700 INFO L290 TraceCheckUtils]: 40: Hoare triple {46988#true} assume { :end_inline_init_completion } true;call write~int(58, ibmpex_register_bmc_~data~2#1.base, 327 + ibmpex_register_bmc_~data~2#1.offset, 1);call write~int(60, ibmpex_register_bmc_~data~2#1.base, 328 + ibmpex_register_bmc_~data~2#1.offset, 1);call write~$Pointer$(ibmpex_register_bmc_~data~2#1.base, 339 + ibmpex_register_bmc_~data~2#1.offset, ibmpex_register_bmc_~data~2#1.base, 331 + ibmpex_register_bmc_~data~2#1.offset, 8);assume { :begin_inline_ibmpex_ver_check } true;ibmpex_ver_check_#in~data#1.base, ibmpex_ver_check_#in~data#1.offset := ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset;havoc ibmpex_ver_check_#res#1;havoc ibmpex_ver_check_#t~ret71#1, ibmpex_ver_check_#t~mem72#1, ibmpex_ver_check_#t~mem73#1, ibmpex_ver_check_#t~short74#1, ibmpex_ver_check_#t~mem75#1, ibmpex_ver_check_#t~mem76#1, ibmpex_ver_check_#t~ret77#1, ibmpex_ver_check_#t~nondet78#1, ibmpex_ver_check_#t~mem79#1.base, ibmpex_ver_check_#t~mem79#1.offset, ibmpex_ver_check_#t~mem80#1, ibmpex_ver_check_#t~mem81#1, ibmpex_ver_check_#t~mem82#1, ibmpex_ver_check_#t~mem83#1, ibmpex_ver_check_#t~mem84#1, ibmpex_ver_check_~data#1.base, ibmpex_ver_check_~data#1.offset, ibmpex_ver_check_~tmp~4#1;ibmpex_ver_check_~data#1.base, ibmpex_ver_check_~data#1.offset := ibmpex_ver_check_#in~data#1.base, ibmpex_ver_check_#in~data#1.offset;havoc ibmpex_ver_check_~tmp~4#1;call write~int(1, ibmpex_ver_check_~data#1.base, 339 + ibmpex_ver_check_~data#1.offset, 1);call write~int(1, ibmpex_ver_check_~data#1.base, 329 + ibmpex_ver_check_~data#1.offset, 2); {46988#true} is VALID [2022-02-20 21:36:01,701 INFO L272 TraceCheckUtils]: 41: Hoare triple {46988#true} call ibmpex_ver_check_#t~ret71#1 := ibmpex_send_message(ibmpex_ver_check_~data#1.base, ibmpex_ver_check_~data#1.offset); {47094#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} is VALID [2022-02-20 21:36:01,701 INFO L290 TraceCheckUtils]: 42: Hoare triple {47094#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;havoc ~err~0#1;assume { :begin_inline_ipmi_validate_addr } true;ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset, ipmi_validate_addr_#in~arg1#1 := ~data#1.base, 193 + ~data#1.offset, 40;havoc ipmi_validate_addr_#res#1;havoc ipmi_validate_addr_#t~nondet254#1, ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset, ipmi_validate_addr_~arg1#1;ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset := ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset;ipmi_validate_addr_~arg1#1 := ipmi_validate_addr_#in~arg1#1;assume -2147483648 <= ipmi_validate_addr_#t~nondet254#1 && ipmi_validate_addr_#t~nondet254#1 <= 2147483647;ipmi_validate_addr_#res#1 := ipmi_validate_addr_#t~nondet254#1;havoc ipmi_validate_addr_#t~nondet254#1; {46988#true} is VALID [2022-02-20 21:36:01,702 INFO L290 TraceCheckUtils]: 43: Hoare triple {46988#true} #t~ret62#1 := ipmi_validate_addr_#res#1;assume { :end_inline_ipmi_validate_addr } true;assume -2147483648 <= #t~ret62#1 && #t~ret62#1 <= 2147483647;~err~0#1 := #t~ret62#1;havoc #t~ret62#1; {46988#true} is VALID [2022-02-20 21:36:01,702 INFO L290 TraceCheckUtils]: 44: Hoare triple {46988#true} assume 0 != ~err~0#1; {46988#true} is VALID [2022-02-20 21:36:01,702 INFO L290 TraceCheckUtils]: 45: Hoare triple {46988#true} havoc #t~nondet69#1;call #t~mem70#1.base, #t~mem70#1.offset := read~$Pointer$(~data#1.base, 24 + ~data#1.offset, 8);havoc #t~mem70#1.base, #t~mem70#1.offset;#res#1 := ~err~0#1; {46988#true} is VALID [2022-02-20 21:36:01,702 INFO L290 TraceCheckUtils]: 46: Hoare triple {46988#true} assume true; {46988#true} is VALID [2022-02-20 21:36:01,702 INFO L284 TraceCheckUtils]: 47: Hoare quadruple {46988#true} {46988#true} #618#return; {46988#true} is VALID [2022-02-20 21:36:01,702 INFO L290 TraceCheckUtils]: 48: Hoare triple {46988#true} assume -2147483648 <= ibmpex_ver_check_#t~ret71#1 && ibmpex_ver_check_#t~ret71#1 <= 2147483647;havoc ibmpex_ver_check_#t~ret71#1; {46988#true} is VALID [2022-02-20 21:36:01,703 INFO L272 TraceCheckUtils]: 49: Hoare triple {46988#true} call wait_for_completion(ibmpex_ver_check_~data#1.base, 231 + ibmpex_ver_check_~data#1.offset); {46988#true} is VALID [2022-02-20 21:36:01,703 INFO L290 TraceCheckUtils]: 50: Hoare triple {46988#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset; {46988#true} is VALID [2022-02-20 21:36:01,703 INFO L290 TraceCheckUtils]: 51: Hoare triple {46988#true} assume true; {46988#true} is VALID [2022-02-20 21:36:01,703 INFO L284 TraceCheckUtils]: 52: Hoare quadruple {46988#true} {46988#true} #620#return; {46988#true} is VALID [2022-02-20 21:36:01,703 INFO L290 TraceCheckUtils]: 53: Hoare triple {46988#true} call ibmpex_ver_check_#t~mem72#1 := read~int(ibmpex_ver_check_~data#1.base, 899 + ibmpex_ver_check_~data#1.offset, 1);ibmpex_ver_check_#t~short74#1 := 0 != ibmpex_ver_check_#t~mem72#1 % 256 % 4294967296; {46988#true} is VALID [2022-02-20 21:36:01,704 INFO L290 TraceCheckUtils]: 54: Hoare triple {46988#true} assume !ibmpex_ver_check_#t~short74#1;call ibmpex_ver_check_#t~mem73#1 := read~int(ibmpex_ver_check_~data#1.base, 891 + ibmpex_ver_check_~data#1.offset, 8);ibmpex_ver_check_#t~short74#1 := 6 != ibmpex_ver_check_#t~mem73#1 % 18446744073709551616; {46988#true} is VALID [2022-02-20 21:36:01,704 INFO L290 TraceCheckUtils]: 55: Hoare triple {46988#true} assume !ibmpex_ver_check_#t~short74#1;havoc ibmpex_ver_check_#t~mem72#1;havoc ibmpex_ver_check_#t~mem73#1;havoc ibmpex_ver_check_#t~short74#1;call ibmpex_ver_check_#t~mem75#1 := read~int(ibmpex_ver_check_~data#1.base, 619 + ibmpex_ver_check_~data#1.offset, 1);call write~int(ibmpex_ver_check_#t~mem75#1, ibmpex_ver_check_~data#1.base, 904 + ibmpex_ver_check_~data#1.offset, 1);havoc ibmpex_ver_check_#t~mem75#1;call ibmpex_ver_check_#t~mem76#1 := read~int(ibmpex_ver_check_~data#1.base, 620 + ibmpex_ver_check_~data#1.offset, 1);call write~int(ibmpex_ver_check_#t~mem76#1, ibmpex_ver_check_~data#1.base, 905 + ibmpex_ver_check_~data#1.offset, 1);havoc ibmpex_ver_check_#t~mem76#1; {46988#true} is VALID [2022-02-20 21:36:01,704 INFO L272 TraceCheckUtils]: 56: Hoare triple {46988#true} call ibmpex_ver_check_#t~ret77#1 := extract_value(ibmpex_ver_check_~data#1.base, 619 + ibmpex_ver_check_~data#1.offset, 2); {46988#true} is VALID [2022-02-20 21:36:01,704 INFO L290 TraceCheckUtils]: 57: Hoare triple {46988#true} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;~offset#1 := #in~offset#1;havoc ~tmp~3#1;assume { :begin_inline___be16_to_cpup } true;__be16_to_cpup_#in~p#1.base, __be16_to_cpup_#in~p#1.offset := ~data#1.base, ~data#1.offset + 2 * (if ~offset#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then ~offset#1 % 18446744073709551616 % 18446744073709551616 else ~offset#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616);havoc __be16_to_cpup_#res#1;havoc __be16_to_cpup_#t~ret3#1, __be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset, __be16_to_cpup_~tmp~1#1;__be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset := __be16_to_cpup_#in~p#1.base, __be16_to_cpup_#in~p#1.offset;havoc __be16_to_cpup_~tmp~1#1;assume { :begin_inline___swab16p } true;__swab16p_#in~p#1.base, __swab16p_#in~p#1.offset := __be16_to_cpup_~p#1.base, __be16_to_cpup_~p#1.offset;havoc __swab16p_#res#1;havoc __swab16p_#t~mem1#1, __swab16p_#t~ret2#1, __swab16p_~p#1.base, __swab16p_~p#1.offset, __swab16p_~tmp~0#1;__swab16p_~p#1.base, __swab16p_~p#1.offset := __swab16p_#in~p#1.base, __swab16p_#in~p#1.offset;havoc __swab16p_~tmp~0#1;call __swab16p_#t~mem1#1 := read~int(__swab16p_~p#1.base, __swab16p_~p#1.offset, 2);assume { :begin_inline___fswab16 } true;__fswab16_#in~val#1 := __swab16p_#t~mem1#1 % 65536;havoc __fswab16_#res#1;havoc __fswab16_~val#1;__fswab16_~val#1 := __fswab16_#in~val#1;__fswab16_#res#1 := (if (1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) || 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536)) && 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) then (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) else (if 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) && (1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) || 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536)) then (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) else (if (1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) && (1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536) || 0 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536))) || ((1 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536) || 0 == (if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536)) && 1 == (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536)) then 1 else ~bitwiseOr((if 256 * (__fswab16_~val#1 % 65536) % 65536 <= 32767 then 256 * (__fswab16_~val#1 % 65536) % 65536 else 256 * (__fswab16_~val#1 % 65536) % 65536 - 65536), (if __fswab16_~val#1 % 65536 / 256 % 65536 <= 32767 then __fswab16_~val#1 % 65536 / 256 % 65536 else __fswab16_~val#1 % 65536 / 256 % 65536 - 65536))))); {46988#true} is VALID [2022-02-20 21:36:01,704 INFO L290 TraceCheckUtils]: 58: Hoare triple {46988#true} __swab16p_#t~ret2#1 := __fswab16_#res#1;assume { :end_inline___fswab16 } true;__swab16p_~tmp~0#1 := __swab16p_#t~ret2#1;havoc __swab16p_#t~mem1#1;havoc __swab16p_#t~ret2#1;__swab16p_#res#1 := __swab16p_~tmp~0#1; {46988#true} is VALID [2022-02-20 21:36:01,704 INFO L290 TraceCheckUtils]: 59: Hoare triple {46988#true} __be16_to_cpup_#t~ret3#1 := __swab16p_#res#1;assume { :end_inline___swab16p } true;__be16_to_cpup_~tmp~1#1 := __be16_to_cpup_#t~ret3#1;havoc __be16_to_cpup_#t~ret3#1;__be16_to_cpup_#res#1 := __be16_to_cpup_~tmp~1#1; {46988#true} is VALID [2022-02-20 21:36:01,705 INFO L290 TraceCheckUtils]: 60: Hoare triple {46988#true} #t~ret61#1 := __be16_to_cpup_#res#1;assume { :end_inline___be16_to_cpup } true;~tmp~3#1 := #t~ret61#1;havoc #t~ret61#1;#res#1 := ~tmp~3#1; {46988#true} is VALID [2022-02-20 21:36:01,705 INFO L290 TraceCheckUtils]: 61: Hoare triple {46988#true} assume true; {46988#true} is VALID [2022-02-20 21:36:01,705 INFO L284 TraceCheckUtils]: 62: Hoare quadruple {46988#true} {46988#true} #622#return; {46988#true} is VALID [2022-02-20 21:36:01,705 INFO L290 TraceCheckUtils]: 63: Hoare triple {46988#true} ibmpex_ver_check_~tmp~4#1 := ibmpex_ver_check_#t~ret77#1;havoc ibmpex_ver_check_#t~ret77#1;havoc ibmpex_ver_check_#t~nondet78#1;call ibmpex_ver_check_#t~mem79#1.base, ibmpex_ver_check_#t~mem79#1.offset := read~$Pointer$(ibmpex_ver_check_~data#1.base, 24 + ibmpex_ver_check_~data#1.offset, 8);call ibmpex_ver_check_#t~mem80#1 := read~int(ibmpex_ver_check_~data#1.base, 904 + ibmpex_ver_check_~data#1.offset, 1);call ibmpex_ver_check_#t~mem81#1 := read~int(ibmpex_ver_check_~data#1.base, 905 + ibmpex_ver_check_~data#1.offset, 1);call ibmpex_ver_check_#t~mem82#1 := read~int(ibmpex_ver_check_~data#1.base, 623 + ibmpex_ver_check_~data#1.offset, 1);call ibmpex_ver_check_#t~mem83#1 := read~int(ibmpex_ver_check_~data#1.base, 624 + ibmpex_ver_check_~data#1.offset, 1);call ibmpex_ver_check_#t~mem84#1 := read~int(ibmpex_ver_check_~data#1.base, 323 + ibmpex_ver_check_~data#1.offset, 4);havoc ibmpex_ver_check_#t~mem79#1.base, ibmpex_ver_check_#t~mem79#1.offset;havoc ibmpex_ver_check_#t~mem80#1;havoc ibmpex_ver_check_#t~mem81#1;havoc ibmpex_ver_check_#t~mem82#1;havoc ibmpex_ver_check_#t~mem83#1;havoc ibmpex_ver_check_#t~mem84#1;ibmpex_ver_check_#res#1 := 0; {46988#true} is VALID [2022-02-20 21:36:01,705 INFO L290 TraceCheckUtils]: 64: Hoare triple {46988#true} ibmpex_register_bmc_#t~ret184#1 := ibmpex_ver_check_#res#1;assume { :end_inline_ibmpex_ver_check } true;assume -2147483648 <= ibmpex_register_bmc_#t~ret184#1 && ibmpex_register_bmc_#t~ret184#1 <= 2147483647;ibmpex_register_bmc_~err~4#1 := ibmpex_register_bmc_#t~ret184#1;havoc ibmpex_register_bmc_#t~ret184#1; {46988#true} is VALID [2022-02-20 21:36:01,706 INFO L290 TraceCheckUtils]: 65: Hoare triple {46988#true} assume !(0 != ibmpex_register_bmc_~err~4#1);call ibmpex_register_bmc_#t~mem185#1.base, ibmpex_register_bmc_#t~mem185#1.offset := read~$Pointer$(ibmpex_register_bmc_~data~2#1.base, 24 + ibmpex_register_bmc_~data~2#1.offset, 8);assume { :begin_inline_hwmon_device_register } true;hwmon_device_register_#in~arg0#1.base, hwmon_device_register_#in~arg0#1.offset := ibmpex_register_bmc_#t~mem185#1.base, ibmpex_register_bmc_#t~mem185#1.offset;havoc hwmon_device_register_#res#1.base, hwmon_device_register_#res#1.offset;havoc hwmon_device_register_#t~ret248#1.base, hwmon_device_register_#t~ret248#1.offset, hwmon_device_register_~arg0#1.base, hwmon_device_register_~arg0#1.offset;hwmon_device_register_~arg0#1.base, hwmon_device_register_~arg0#1.offset := hwmon_device_register_#in~arg0#1.base, hwmon_device_register_#in~arg0#1.offset; {46988#true} is VALID [2022-02-20 21:36:01,706 INFO L272 TraceCheckUtils]: 66: Hoare triple {46988#true} call hwmon_device_register_#t~ret248#1.base, hwmon_device_register_#t~ret248#1.offset := ldv_malloc(1035); {47079#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:36:01,706 INFO L290 TraceCheckUtils]: 67: Hoare triple {47079#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {46988#true} is VALID [2022-02-20 21:36:01,707 INFO L290 TraceCheckUtils]: 68: Hoare triple {46988#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {46988#true} is VALID [2022-02-20 21:36:01,707 INFO L290 TraceCheckUtils]: 69: Hoare triple {46988#true} assume true; {46988#true} is VALID [2022-02-20 21:36:01,707 INFO L284 TraceCheckUtils]: 70: Hoare quadruple {46988#true} {46988#true} #624#return; {46988#true} is VALID [2022-02-20 21:36:01,707 INFO L290 TraceCheckUtils]: 71: Hoare triple {46988#true} hwmon_device_register_#res#1.base, hwmon_device_register_#res#1.offset := hwmon_device_register_#t~ret248#1.base, hwmon_device_register_#t~ret248#1.offset;havoc hwmon_device_register_#t~ret248#1.base, hwmon_device_register_#t~ret248#1.offset; {46988#true} is VALID [2022-02-20 21:36:01,707 INFO L290 TraceCheckUtils]: 72: Hoare triple {46988#true} ibmpex_register_bmc_#t~ret186#1.base, ibmpex_register_bmc_#t~ret186#1.offset := hwmon_device_register_#res#1.base, hwmon_device_register_#res#1.offset;assume { :end_inline_hwmon_device_register } true;call write~$Pointer$(ibmpex_register_bmc_#t~ret186#1.base, ibmpex_register_bmc_#t~ret186#1.offset, ibmpex_register_bmc_~data~2#1.base, 16 + ibmpex_register_bmc_~data~2#1.offset, 8);havoc ibmpex_register_bmc_#t~mem185#1.base, ibmpex_register_bmc_#t~mem185#1.offset;havoc ibmpex_register_bmc_#t~ret186#1.base, ibmpex_register_bmc_#t~ret186#1.offset;call ibmpex_register_bmc_#t~mem187#1.base, ibmpex_register_bmc_#t~mem187#1.offset := read~$Pointer$(ibmpex_register_bmc_~data~2#1.base, 16 + ibmpex_register_bmc_~data~2#1.offset, 8);assume { :begin_inline_IS_ERR } true;IS_ERR_#in~ptr#1.base, IS_ERR_#in~ptr#1.offset := ibmpex_register_bmc_#t~mem187#1.base, ibmpex_register_bmc_#t~mem187#1.offset;havoc IS_ERR_#res#1;havoc IS_ERR_#t~ret240#1, IS_ERR_~ptr#1.base, IS_ERR_~ptr#1.offset, IS_ERR_~tmp~18#1;IS_ERR_~ptr#1.base, IS_ERR_~ptr#1.offset := IS_ERR_#in~ptr#1.base, IS_ERR_#in~ptr#1.offset;havoc IS_ERR_~tmp~18#1; {46988#true} is VALID [2022-02-20 21:36:01,707 INFO L272 TraceCheckUtils]: 73: Hoare triple {46988#true} call IS_ERR_#t~ret240#1 := ldv_is_err(IS_ERR_~ptr#1.base, IS_ERR_~ptr#1.offset); {46988#true} is VALID [2022-02-20 21:36:01,708 INFO L290 TraceCheckUtils]: 74: Hoare triple {46988#true} ~ptr.base, ~ptr.offset := #in~ptr.base, #in~ptr.offset;#res := (if (~ptr.base + ~ptr.offset) % 18446744073709551616 > 2012 then 1 else 0); {46988#true} is VALID [2022-02-20 21:36:01,708 INFO L290 TraceCheckUtils]: 75: Hoare triple {46988#true} assume true; {46988#true} is VALID [2022-02-20 21:36:01,708 INFO L284 TraceCheckUtils]: 76: Hoare quadruple {46988#true} {46988#true} #626#return; {46988#true} is VALID [2022-02-20 21:36:01,708 INFO L290 TraceCheckUtils]: 77: Hoare triple {46988#true} assume -9223372036854775808 <= IS_ERR_#t~ret240#1 && IS_ERR_#t~ret240#1 <= 9223372036854775807;IS_ERR_~tmp~18#1 := IS_ERR_#t~ret240#1;havoc IS_ERR_#t~ret240#1;IS_ERR_#res#1 := IS_ERR_~tmp~18#1; {46988#true} is VALID [2022-02-20 21:36:01,708 INFO L290 TraceCheckUtils]: 78: Hoare triple {46988#true} ibmpex_register_bmc_#t~ret188#1 := IS_ERR_#res#1;assume { :end_inline_IS_ERR } true;assume -9223372036854775808 <= ibmpex_register_bmc_#t~ret188#1 && ibmpex_register_bmc_#t~ret188#1 <= 9223372036854775807;ibmpex_register_bmc_~tmp___0~3#1 := ibmpex_register_bmc_#t~ret188#1;havoc ibmpex_register_bmc_#t~mem187#1.base, ibmpex_register_bmc_#t~mem187#1.offset;havoc ibmpex_register_bmc_#t~ret188#1; {46988#true} is VALID [2022-02-20 21:36:01,709 INFO L290 TraceCheckUtils]: 79: Hoare triple {46988#true} assume !(0 != ibmpex_register_bmc_~tmp___0~3#1); {46988#true} is VALID [2022-02-20 21:36:01,709 INFO L272 TraceCheckUtils]: 80: Hoare triple {46988#true} call dev_set_drvdata(ibmpex_register_bmc_~dev#1.base, ibmpex_register_bmc_~dev#1.offset, ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset); {46988#true} is VALID [2022-02-20 21:36:01,709 INFO L290 TraceCheckUtils]: 81: Hoare triple {46988#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset;~arg1.base, ~arg1.offset := #in~arg1.base, #in~arg1.offset; {46988#true} is VALID [2022-02-20 21:36:01,709 INFO L290 TraceCheckUtils]: 82: Hoare triple {46988#true} assume true; {46988#true} is VALID [2022-02-20 21:36:01,709 INFO L284 TraceCheckUtils]: 83: Hoare quadruple {46988#true} {46988#true} #628#return; {46988#true} is VALID [2022-02-20 21:36:01,709 INFO L290 TraceCheckUtils]: 84: Hoare triple {46988#true} assume { :begin_inline_list_add_tail } true;list_add_tail_#in~new#1.base, list_add_tail_#in~new#1.offset, list_add_tail_#in~head#1.base, list_add_tail_#in~head#1.offset := ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset, ~#driver_data~0.base, ~#driver_data~0.offset;havoc list_add_tail_#t~mem12#1.base, list_add_tail_#t~mem12#1.offset, list_add_tail_~new#1.base, list_add_tail_~new#1.offset, list_add_tail_~head#1.base, list_add_tail_~head#1.offset;list_add_tail_~new#1.base, list_add_tail_~new#1.offset := list_add_tail_#in~new#1.base, list_add_tail_#in~new#1.offset;list_add_tail_~head#1.base, list_add_tail_~head#1.offset := list_add_tail_#in~head#1.base, list_add_tail_#in~head#1.offset;call list_add_tail_#t~mem12#1.base, list_add_tail_#t~mem12#1.offset := read~$Pointer$(list_add_tail_~head#1.base, 8 + list_add_tail_~head#1.offset, 8);assume { :begin_inline___list_add } true;__list_add_#in~arg0#1.base, __list_add_#in~arg0#1.offset, __list_add_#in~arg1#1.base, __list_add_#in~arg1#1.offset, __list_add_#in~arg2#1.base, __list_add_#in~arg2#1.offset := list_add_tail_~new#1.base, list_add_tail_~new#1.offset, list_add_tail_#t~mem12#1.base, list_add_tail_#t~mem12#1.offset, list_add_tail_~head#1.base, list_add_tail_~head#1.offset;havoc __list_add_~arg0#1.base, __list_add_~arg0#1.offset, __list_add_~arg1#1.base, __list_add_~arg1#1.offset, __list_add_~arg2#1.base, __list_add_~arg2#1.offset;__list_add_~arg0#1.base, __list_add_~arg0#1.offset := __list_add_#in~arg0#1.base, __list_add_#in~arg0#1.offset;__list_add_~arg1#1.base, __list_add_~arg1#1.offset := __list_add_#in~arg1#1.base, __list_add_#in~arg1#1.offset;__list_add_~arg2#1.base, __list_add_~arg2#1.offset := __list_add_#in~arg2#1.base, __list_add_#in~arg2#1.offset; {46988#true} is VALID [2022-02-20 21:36:01,710 INFO L290 TraceCheckUtils]: 85: Hoare triple {46988#true} assume { :end_inline___list_add } true;havoc list_add_tail_#t~mem12#1.base, list_add_tail_#t~mem12#1.offset; {46988#true} is VALID [2022-02-20 21:36:01,710 INFO L290 TraceCheckUtils]: 86: Hoare triple {46988#true} assume { :end_inline_list_add_tail } true;assume { :begin_inline_ibmpex_find_sensors } true;ibmpex_find_sensors_#in~data#1.base, ibmpex_find_sensors_#in~data#1.offset := ibmpex_register_bmc_~data~2#1.base, ibmpex_register_bmc_~data~2#1.offset;havoc ibmpex_find_sensors_#res#1;havoc ibmpex_find_sensors_#t~ret148#1, ibmpex_find_sensors_#t~mem149#1, ibmpex_find_sensors_#t~ret150#1.base, ibmpex_find_sensors_#t~ret150#1.offset, ibmpex_find_sensors_#t~mem151#1.base, ibmpex_find_sensors_#t~mem151#1.offset, ibmpex_find_sensors_#t~ret152#1, ibmpex_find_sensors_#t~mem153#1, ibmpex_find_sensors_#t~ret154#1, ibmpex_find_sensors_#t~mem155#1.base, ibmpex_find_sensors_#t~mem155#1.offset, ibmpex_find_sensors_#t~mem156#1, ibmpex_find_sensors_#t~ret157#1, ibmpex_find_sensors_#t~mem158#1, ibmpex_find_sensors_#t~ret159#1, ibmpex_find_sensors_#t~mem160#1.base, ibmpex_find_sensors_#t~mem160#1.offset, ibmpex_find_sensors_#t~mem161#1.base, ibmpex_find_sensors_#t~mem161#1.offset, ibmpex_find_sensors_#t~ret162#1, ibmpex_find_sensors_#t~mem163#1, ibmpex_find_sensors_#t~mem164#1.base, ibmpex_find_sensors_#t~mem164#1.offset, ibmpex_find_sensors_#t~ret165#1, ibmpex_find_sensors_#t~mem166#1.base, ibmpex_find_sensors_#t~mem166#1.offset, ibmpex_find_sensors_#t~ret167#1, ibmpex_find_sensors_#t~mem168#1.base, ibmpex_find_sensors_#t~mem168#1.offset, ibmpex_find_sensors_#t~mem169#1.base, ibmpex_find_sensors_#t~mem169#1.offset, ibmpex_find_sensors_#t~mem170#1.base, ibmpex_find_sensors_#t~mem170#1.offset, ibmpex_find_sensors_#t~mem171#1.base, ibmpex_find_sensors_#t~mem171#1.offset, ibmpex_find_sensors_#t~mem172#1.base, ibmpex_find_sensors_#t~mem172#1.offset, ibmpex_find_sensors_#t~mem173#1.base, ibmpex_find_sensors_#t~mem173#1.offset, ibmpex_find_sensors_#t~mem174#1.base, ibmpex_find_sensors_#t~mem174#1.offset, ibmpex_find_sensors_#t~mem175#1.base, ibmpex_find_sensors_#t~mem175#1.offset, ibmpex_find_sensors_#t~mem176#1, ibmpex_find_sensors_#t~mem177#1.base, ibmpex_find_sensors_#t~mem177#1.offset, ibmpex_find_sensors_~data#1.base, ibmpex_find_sensors_~data#1.offset, ibmpex_find_sensors_~i~2#1, ibmpex_find_sensors_~j~0#1, ibmpex_find_sensors_~err~3#1, ibmpex_find_sensors_~sensor_type~0#1, ibmpex_find_sensors_~sensor_counter~0#1, ibmpex_find_sensors_~num_power~0#1, ibmpex_find_sensors_~num_temp~0#1, ibmpex_find_sensors_~tmp~13#1.base, ibmpex_find_sensors_~tmp~13#1.offset, ibmpex_find_sensors_~tmp___0~2#1, ibmpex_find_sensors_~tmp___1~1#1;ibmpex_find_sensors_~data#1.base, ibmpex_find_sensors_~data#1.offset := ibmpex_find_sensors_#in~data#1.base, ibmpex_find_sensors_#in~data#1.offset;havoc ibmpex_find_sensors_~i~2#1;havoc ibmpex_find_sensors_~j~0#1;havoc ibmpex_find_sensors_~err~3#1;havoc ibmpex_find_sensors_~sensor_type~0#1;havoc ibmpex_find_sensors_~sensor_counter~0#1;havoc ibmpex_find_sensors_~num_power~0#1;havoc ibmpex_find_sensors_~num_temp~0#1;havoc ibmpex_find_sensors_~tmp~13#1.base, ibmpex_find_sensors_~tmp~13#1.offset;havoc ibmpex_find_sensors_~tmp___0~2#1;havoc ibmpex_find_sensors_~tmp___1~1#1;ibmpex_find_sensors_~num_power~0#1 := 0;ibmpex_find_sensors_~num_temp~0#1 := 0;assume { :begin_inline_ibmpex_query_sensor_count } true;ibmpex_query_sensor_count_#in~data#1.base, ibmpex_query_sensor_count_#in~data#1.offset := ibmpex_find_sensors_~data#1.base, ibmpex_find_sensors_~data#1.offset;havoc ibmpex_query_sensor_count_#res#1;havoc ibmpex_query_sensor_count_#t~ret85#1, ibmpex_query_sensor_count_#t~mem86#1, ibmpex_query_sensor_count_#t~mem87#1, ibmpex_query_sensor_count_#t~short88#1, ibmpex_query_sensor_count_#t~mem89#1, ibmpex_query_sensor_count_~data#1.base, ibmpex_query_sensor_count_~data#1.offset;ibmpex_query_sensor_count_~data#1.base, ibmpex_query_sensor_count_~data#1.offset := ibmpex_query_sensor_count_#in~data#1.base, ibmpex_query_sensor_count_#in~data#1.offset;call write~int(2, ibmpex_query_sensor_count_~data#1.base, 339 + ibmpex_query_sensor_count_~data#1.offset, 1);call write~int(1, ibmpex_query_sensor_count_~data#1.base, 329 + ibmpex_query_sensor_count_~data#1.offset, 2); {46988#true} is VALID [2022-02-20 21:36:01,711 INFO L272 TraceCheckUtils]: 87: Hoare triple {46988#true} call ibmpex_query_sensor_count_#t~ret85#1 := ibmpex_send_message(ibmpex_query_sensor_count_~data#1.base, ibmpex_query_sensor_count_~data#1.offset); {47094#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} is VALID [2022-02-20 21:36:01,711 INFO L290 TraceCheckUtils]: 88: Hoare triple {47094#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;havoc ~err~0#1;assume { :begin_inline_ipmi_validate_addr } true;ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset, ipmi_validate_addr_#in~arg1#1 := ~data#1.base, 193 + ~data#1.offset, 40;havoc ipmi_validate_addr_#res#1;havoc ipmi_validate_addr_#t~nondet254#1, ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset, ipmi_validate_addr_~arg1#1;ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset := ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset;ipmi_validate_addr_~arg1#1 := ipmi_validate_addr_#in~arg1#1;assume -2147483648 <= ipmi_validate_addr_#t~nondet254#1 && ipmi_validate_addr_#t~nondet254#1 <= 2147483647;ipmi_validate_addr_#res#1 := ipmi_validate_addr_#t~nondet254#1;havoc ipmi_validate_addr_#t~nondet254#1; {46988#true} is VALID [2022-02-20 21:36:01,711 INFO L290 TraceCheckUtils]: 89: Hoare triple {46988#true} #t~ret62#1 := ipmi_validate_addr_#res#1;assume { :end_inline_ipmi_validate_addr } true;assume -2147483648 <= #t~ret62#1 && #t~ret62#1 <= 2147483647;~err~0#1 := #t~ret62#1;havoc #t~ret62#1; {46988#true} is VALID [2022-02-20 21:36:01,711 INFO L290 TraceCheckUtils]: 90: Hoare triple {46988#true} assume 0 != ~err~0#1; {46988#true} is VALID [2022-02-20 21:36:01,711 INFO L290 TraceCheckUtils]: 91: Hoare triple {46988#true} havoc #t~nondet69#1;call #t~mem70#1.base, #t~mem70#1.offset := read~$Pointer$(~data#1.base, 24 + ~data#1.offset, 8);havoc #t~mem70#1.base, #t~mem70#1.offset;#res#1 := ~err~0#1; {46988#true} is VALID [2022-02-20 21:36:01,712 INFO L290 TraceCheckUtils]: 92: Hoare triple {46988#true} assume true; {46988#true} is VALID [2022-02-20 21:36:01,712 INFO L284 TraceCheckUtils]: 93: Hoare quadruple {46988#true} {46988#true} #630#return; {46988#true} is VALID [2022-02-20 21:36:01,712 INFO L290 TraceCheckUtils]: 94: Hoare triple {46988#true} assume -2147483648 <= ibmpex_query_sensor_count_#t~ret85#1 && ibmpex_query_sensor_count_#t~ret85#1 <= 2147483647;havoc ibmpex_query_sensor_count_#t~ret85#1; {46988#true} is VALID [2022-02-20 21:36:01,712 INFO L272 TraceCheckUtils]: 95: Hoare triple {46988#true} call wait_for_completion(ibmpex_query_sensor_count_~data#1.base, 231 + ibmpex_query_sensor_count_~data#1.offset); {46988#true} is VALID [2022-02-20 21:36:01,712 INFO L290 TraceCheckUtils]: 96: Hoare triple {46988#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset; {46988#true} is VALID [2022-02-20 21:36:01,712 INFO L290 TraceCheckUtils]: 97: Hoare triple {46988#true} assume true; {46988#true} is VALID [2022-02-20 21:36:01,713 INFO L284 TraceCheckUtils]: 98: Hoare quadruple {46988#true} {46988#true} #632#return; {46988#true} is VALID [2022-02-20 21:36:01,713 INFO L290 TraceCheckUtils]: 99: Hoare triple {46988#true} call ibmpex_query_sensor_count_#t~mem86#1 := read~int(ibmpex_query_sensor_count_~data#1.base, 899 + ibmpex_query_sensor_count_~data#1.offset, 1);ibmpex_query_sensor_count_#t~short88#1 := 0 != ibmpex_query_sensor_count_#t~mem86#1 % 256 % 4294967296; {46988#true} is VALID [2022-02-20 21:36:01,713 INFO L290 TraceCheckUtils]: 100: Hoare triple {46988#true} assume !ibmpex_query_sensor_count_#t~short88#1;call ibmpex_query_sensor_count_#t~mem87#1 := read~int(ibmpex_query_sensor_count_~data#1.base, 891 + ibmpex_query_sensor_count_~data#1.offset, 8);ibmpex_query_sensor_count_#t~short88#1 := 1 != ibmpex_query_sensor_count_#t~mem87#1 % 18446744073709551616; {46988#true} is VALID [2022-02-20 21:36:01,713 INFO L290 TraceCheckUtils]: 101: Hoare triple {46988#true} assume !ibmpex_query_sensor_count_#t~short88#1;havoc ibmpex_query_sensor_count_#t~mem86#1;havoc ibmpex_query_sensor_count_#t~mem87#1;havoc ibmpex_query_sensor_count_#t~short88#1;call ibmpex_query_sensor_count_#t~mem89#1 := read~int(ibmpex_query_sensor_count_~data#1.base, 619 + ibmpex_query_sensor_count_~data#1.offset, 1);ibmpex_query_sensor_count_#res#1 := ibmpex_query_sensor_count_#t~mem89#1 % 256;havoc ibmpex_query_sensor_count_#t~mem89#1; {46988#true} is VALID [2022-02-20 21:36:01,713 INFO L290 TraceCheckUtils]: 102: Hoare triple {46988#true} ibmpex_find_sensors_#t~ret148#1 := ibmpex_query_sensor_count_#res#1;assume { :end_inline_ibmpex_query_sensor_count } true;assume -2147483648 <= ibmpex_find_sensors_#t~ret148#1 && ibmpex_find_sensors_#t~ret148#1 <= 2147483647;ibmpex_find_sensors_~err~3#1 := ibmpex_find_sensors_#t~ret148#1;havoc ibmpex_find_sensors_#t~ret148#1; {46988#true} is VALID [2022-02-20 21:36:01,713 INFO L290 TraceCheckUtils]: 103: Hoare triple {46988#true} assume !(ibmpex_find_sensors_~err~3#1 <= 0);call write~int(ibmpex_find_sensors_~err~3#1, ibmpex_find_sensors_~data#1.base, 906 + ibmpex_find_sensors_~data#1.offset, 1);call ibmpex_find_sensors_#t~mem149#1 := read~int(ibmpex_find_sensors_~data#1.base, 906 + ibmpex_find_sensors_~data#1.offset, 1); {46988#true} is VALID [2022-02-20 21:36:01,714 INFO L272 TraceCheckUtils]: 104: Hoare triple {46988#true} call ibmpex_find_sensors_#t~ret150#1.base, ibmpex_find_sensors_#t~ret150#1.offset := kzalloc(184 * (ibmpex_find_sensors_#t~mem149#1 % 256), 208); {47079#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:36:01,714 INFO L290 TraceCheckUtils]: 105: Hoare triple {47079#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size := #in~size;~flags := #in~flags;havoc ~tmp~2.base, ~tmp~2.offset; {46988#true} is VALID [2022-02-20 21:36:01,715 INFO L272 TraceCheckUtils]: 106: Hoare triple {46988#true} call #t~ret40.base, #t~ret40.offset := kmalloc(~size, ~bitwiseOr(~flags, 32768)); {47079#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:36:01,715 INFO L290 TraceCheckUtils]: 107: Hoare triple {47079#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {46988#true} is VALID [2022-02-20 21:36:01,716 INFO L272 TraceCheckUtils]: 108: Hoare triple {46988#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {47079#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:36:01,716 INFO L290 TraceCheckUtils]: 109: Hoare triple {47079#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {46988#true} is VALID [2022-02-20 21:36:01,716 INFO L290 TraceCheckUtils]: 110: Hoare triple {46988#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {46988#true} is VALID [2022-02-20 21:36:01,716 INFO L290 TraceCheckUtils]: 111: Hoare triple {46988#true} assume true; {46988#true} is VALID [2022-02-20 21:36:01,716 INFO L284 TraceCheckUtils]: 112: Hoare quadruple {46988#true} {46988#true} #590#return; {46988#true} is VALID [2022-02-20 21:36:01,717 INFO L290 TraceCheckUtils]: 113: Hoare triple {46988#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {46988#true} is VALID [2022-02-20 21:36:01,717 INFO L290 TraceCheckUtils]: 114: Hoare triple {46988#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {46988#true} is VALID [2022-02-20 21:36:01,717 INFO L290 TraceCheckUtils]: 115: Hoare triple {46988#true} assume true; {46988#true} is VALID [2022-02-20 21:36:01,717 INFO L284 TraceCheckUtils]: 116: Hoare quadruple {46988#true} {46988#true} #588#return; {46988#true} is VALID [2022-02-20 21:36:01,717 INFO L290 TraceCheckUtils]: 117: Hoare triple {46988#true} ~tmp~2.base, ~tmp~2.offset := #t~ret40.base, #t~ret40.offset;havoc #t~ret40.base, #t~ret40.offset;#res.base, #res.offset := ~tmp~2.base, ~tmp~2.offset; {46988#true} is VALID [2022-02-20 21:36:01,718 INFO L290 TraceCheckUtils]: 118: Hoare triple {46988#true} assume true; {46988#true} is VALID [2022-02-20 21:36:01,718 INFO L284 TraceCheckUtils]: 119: Hoare quadruple {46988#true} {46988#true} #634#return; {46988#true} is VALID [2022-02-20 21:36:01,718 INFO L290 TraceCheckUtils]: 120: Hoare triple {46988#true} ibmpex_find_sensors_~tmp~13#1.base, ibmpex_find_sensors_~tmp~13#1.offset := ibmpex_find_sensors_#t~ret150#1.base, ibmpex_find_sensors_#t~ret150#1.offset;havoc ibmpex_find_sensors_#t~mem149#1;havoc ibmpex_find_sensors_#t~ret150#1.base, ibmpex_find_sensors_#t~ret150#1.offset;call write~$Pointer$(ibmpex_find_sensors_~tmp~13#1.base, ibmpex_find_sensors_~tmp~13#1.offset, ibmpex_find_sensors_~data#1.base, 907 + ibmpex_find_sensors_~data#1.offset, 8);call ibmpex_find_sensors_#t~mem151#1.base, ibmpex_find_sensors_#t~mem151#1.offset := read~$Pointer$(ibmpex_find_sensors_~data#1.base, 907 + ibmpex_find_sensors_~data#1.offset, 8); {46988#true} is VALID [2022-02-20 21:36:01,718 INFO L290 TraceCheckUtils]: 121: Hoare triple {46988#true} assume !(0 == (ibmpex_find_sensors_#t~mem151#1.base + ibmpex_find_sensors_#t~mem151#1.offset) % 18446744073709551616);havoc ibmpex_find_sensors_#t~mem151#1.base, ibmpex_find_sensors_#t~mem151#1.offset;ibmpex_find_sensors_~i~2#1 := 0; {46988#true} is VALID [2022-02-20 21:36:01,718 INFO L290 TraceCheckUtils]: 122: Hoare triple {46988#true} call ibmpex_find_sensors_#t~mem163#1 := read~int(ibmpex_find_sensors_~data#1.base, 906 + ibmpex_find_sensors_~data#1.offset, 1); {46988#true} is VALID [2022-02-20 21:36:01,718 INFO L290 TraceCheckUtils]: 123: Hoare triple {46988#true} assume ibmpex_find_sensors_#t~mem163#1 % 256 > ibmpex_find_sensors_~i~2#1;havoc ibmpex_find_sensors_#t~mem163#1; {46988#true} is VALID [2022-02-20 21:36:01,719 INFO L290 TraceCheckUtils]: 124: Hoare triple {46988#true} assume { :begin_inline_ibmpex_query_sensor_name } true;ibmpex_query_sensor_name_#in~data#1.base, ibmpex_query_sensor_name_#in~data#1.offset, ibmpex_query_sensor_name_#in~sensor#1 := ibmpex_find_sensors_~data#1.base, ibmpex_find_sensors_~data#1.offset, ibmpex_find_sensors_~i~2#1;havoc ibmpex_query_sensor_name_#res#1;havoc ibmpex_query_sensor_name_#t~ret90#1, ibmpex_query_sensor_name_#t~mem91#1, ibmpex_query_sensor_name_#t~mem92#1, ibmpex_query_sensor_name_#t~short93#1, ibmpex_query_sensor_name_~data#1.base, ibmpex_query_sensor_name_~data#1.offset, ibmpex_query_sensor_name_~sensor#1;ibmpex_query_sensor_name_~data#1.base, ibmpex_query_sensor_name_~data#1.offset := ibmpex_query_sensor_name_#in~data#1.base, ibmpex_query_sensor_name_#in~data#1.offset;ibmpex_query_sensor_name_~sensor#1 := ibmpex_query_sensor_name_#in~sensor#1;call write~int(3, ibmpex_query_sensor_name_~data#1.base, 339 + ibmpex_query_sensor_name_~data#1.offset, 1);call write~int(ibmpex_query_sensor_name_~sensor#1, ibmpex_query_sensor_name_~data#1.base, 340 + ibmpex_query_sensor_name_~data#1.offset, 1);call write~int(2, ibmpex_query_sensor_name_~data#1.base, 329 + ibmpex_query_sensor_name_~data#1.offset, 2); {46988#true} is VALID [2022-02-20 21:36:01,719 INFO L272 TraceCheckUtils]: 125: Hoare triple {46988#true} call ibmpex_query_sensor_name_#t~ret90#1 := ibmpex_send_message(ibmpex_query_sensor_name_~data#1.base, ibmpex_query_sensor_name_~data#1.offset); {47094#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} is VALID [2022-02-20 21:36:01,720 INFO L290 TraceCheckUtils]: 126: Hoare triple {47094#(and (= |#memory_int| |old(#memory_int)|) (= |#memory_$Pointer$.base| |old(#memory_$Pointer$.base)|) (= |#memory_$Pointer$.offset| |old(#memory_$Pointer$.offset)|))} ~data#1.base, ~data#1.offset := #in~data#1.base, #in~data#1.offset;havoc ~err~0#1;assume { :begin_inline_ipmi_validate_addr } true;ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset, ipmi_validate_addr_#in~arg1#1 := ~data#1.base, 193 + ~data#1.offset, 40;havoc ipmi_validate_addr_#res#1;havoc ipmi_validate_addr_#t~nondet254#1, ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset, ipmi_validate_addr_~arg1#1;ipmi_validate_addr_~arg0#1.base, ipmi_validate_addr_~arg0#1.offset := ipmi_validate_addr_#in~arg0#1.base, ipmi_validate_addr_#in~arg0#1.offset;ipmi_validate_addr_~arg1#1 := ipmi_validate_addr_#in~arg1#1;assume -2147483648 <= ipmi_validate_addr_#t~nondet254#1 && ipmi_validate_addr_#t~nondet254#1 <= 2147483647;ipmi_validate_addr_#res#1 := ipmi_validate_addr_#t~nondet254#1;havoc ipmi_validate_addr_#t~nondet254#1; {46988#true} is VALID [2022-02-20 21:36:01,720 INFO L290 TraceCheckUtils]: 127: Hoare triple {46988#true} #t~ret62#1 := ipmi_validate_addr_#res#1;assume { :end_inline_ipmi_validate_addr } true;assume -2147483648 <= #t~ret62#1 && #t~ret62#1 <= 2147483647;~err~0#1 := #t~ret62#1;havoc #t~ret62#1; {46988#true} is VALID [2022-02-20 21:36:01,720 INFO L290 TraceCheckUtils]: 128: Hoare triple {46988#true} assume 0 != ~err~0#1; {46988#true} is VALID [2022-02-20 21:36:01,720 INFO L290 TraceCheckUtils]: 129: Hoare triple {46988#true} havoc #t~nondet69#1;call #t~mem70#1.base, #t~mem70#1.offset := read~$Pointer$(~data#1.base, 24 + ~data#1.offset, 8);havoc #t~mem70#1.base, #t~mem70#1.offset;#res#1 := ~err~0#1; {46988#true} is VALID [2022-02-20 21:36:01,720 INFO L290 TraceCheckUtils]: 130: Hoare triple {46988#true} assume true; {46988#true} is VALID [2022-02-20 21:36:01,720 INFO L284 TraceCheckUtils]: 131: Hoare quadruple {46988#true} {46988#true} #636#return; {46988#true} is VALID [2022-02-20 21:36:01,721 INFO L290 TraceCheckUtils]: 132: Hoare triple {46988#true} assume -2147483648 <= ibmpex_query_sensor_name_#t~ret90#1 && ibmpex_query_sensor_name_#t~ret90#1 <= 2147483647;havoc ibmpex_query_sensor_name_#t~ret90#1; {46988#true} is VALID [2022-02-20 21:36:01,721 INFO L272 TraceCheckUtils]: 133: Hoare triple {46988#true} call wait_for_completion(ibmpex_query_sensor_name_~data#1.base, 231 + ibmpex_query_sensor_name_~data#1.offset); {46988#true} is VALID [2022-02-20 21:36:01,721 INFO L290 TraceCheckUtils]: 134: Hoare triple {46988#true} ~arg0.base, ~arg0.offset := #in~arg0.base, #in~arg0.offset; {46988#true} is VALID [2022-02-20 21:36:01,721 INFO L290 TraceCheckUtils]: 135: Hoare triple {46988#true} assume true; {46988#true} is VALID [2022-02-20 21:36:01,721 INFO L284 TraceCheckUtils]: 136: Hoare quadruple {46988#true} {46988#true} #638#return; {46988#true} is VALID [2022-02-20 21:36:01,721 INFO L290 TraceCheckUtils]: 137: Hoare triple {46988#true} call ibmpex_query_sensor_name_#t~mem91#1 := read~int(ibmpex_query_sensor_name_~data#1.base, 899 + ibmpex_query_sensor_name_~data#1.offset, 1);ibmpex_query_sensor_name_#t~short93#1 := 0 != ibmpex_query_sensor_name_#t~mem91#1 % 256 % 4294967296; {46988#true} is VALID [2022-02-20 21:36:01,722 INFO L290 TraceCheckUtils]: 138: Hoare triple {46988#true} assume !ibmpex_query_sensor_name_#t~short93#1;call ibmpex_query_sensor_name_#t~mem92#1 := read~int(ibmpex_query_sensor_name_~data#1.base, 891 + ibmpex_query_sensor_name_~data#1.offset, 8);ibmpex_query_sensor_name_#t~short93#1 := 0 == ibmpex_query_sensor_name_#t~mem92#1 % 18446744073709551616; {46988#true} is VALID [2022-02-20 21:36:01,722 INFO L290 TraceCheckUtils]: 139: Hoare triple {46988#true} assume !ibmpex_query_sensor_name_#t~short93#1;havoc ibmpex_query_sensor_name_#t~mem91#1;havoc ibmpex_query_sensor_name_#t~mem92#1;havoc ibmpex_query_sensor_name_#t~short93#1;ibmpex_query_sensor_name_#res#1 := 0; {46988#true} is VALID [2022-02-20 21:36:01,722 INFO L290 TraceCheckUtils]: 140: Hoare triple {46988#true} ibmpex_find_sensors_#t~ret152#1 := ibmpex_query_sensor_name_#res#1;assume { :end_inline_ibmpex_query_sensor_name } true;assume -2147483648 <= ibmpex_find_sensors_#t~ret152#1 && ibmpex_find_sensors_#t~ret152#1 <= 2147483647;ibmpex_find_sensors_~err~3#1 := ibmpex_find_sensors_#t~ret152#1;havoc ibmpex_find_sensors_#t~ret152#1; {46988#true} is VALID [2022-02-20 21:36:01,722 INFO L290 TraceCheckUtils]: 141: Hoare triple {46988#true} assume !(0 != ibmpex_find_sensors_~err~3#1);call ibmpex_find_sensors_#t~mem153#1 := read~int(ibmpex_find_sensors_~data#1.base, 891 + ibmpex_find_sensors_~data#1.offset, 8);assume { :begin_inline_is_power_sensor } true;is_power_sensor_#in~sensor_id#1.base, is_power_sensor_#in~sensor_id#1.offset, is_power_sensor_#in~len#1 := ibmpex_find_sensors_~data#1.base, 619 + ibmpex_find_sensors_~data#1.offset, (if ibmpex_find_sensors_#t~mem153#1 % 18446744073709551616 % 4294967296 <= 2147483647 then ibmpex_find_sensors_#t~mem153#1 % 18446744073709551616 % 4294967296 else ibmpex_find_sensors_#t~mem153#1 % 18446744073709551616 % 4294967296 - 4294967296);havoc is_power_sensor_#res#1;havoc is_power_sensor_#t~ret130#1, is_power_sensor_~sensor_id#1.base, is_power_sensor_~sensor_id#1.offset, is_power_sensor_~len#1, is_power_sensor_~tmp~9#1;is_power_sensor_~sensor_id#1.base, is_power_sensor_~sensor_id#1.offset := is_power_sensor_#in~sensor_id#1.base, is_power_sensor_#in~sensor_id#1.offset;is_power_sensor_~len#1 := is_power_sensor_#in~len#1;havoc is_power_sensor_~tmp~9#1; {46988#true} is VALID [2022-02-20 21:36:01,722 INFO L290 TraceCheckUtils]: 142: Hoare triple {46988#true} assume !(is_power_sensor_~len#1 <= 2);call is_power_sensor_#t~ret130#1 := memcmp(is_power_sensor_~sensor_id#1.base, is_power_sensor_~sensor_id#1.offset, ~#power_sensor_sig~0.base, ~#power_sensor_sig~0.offset, 3);assume -2147483648 <= is_power_sensor_#t~ret130#1 && is_power_sensor_#t~ret130#1 <= 2147483647;is_power_sensor_~tmp~9#1 := is_power_sensor_#t~ret130#1;havoc is_power_sensor_#t~ret130#1; {46988#true} is VALID [2022-02-20 21:36:01,723 INFO L290 TraceCheckUtils]: 143: Hoare triple {46988#true} assume 0 == is_power_sensor_~tmp~9#1;is_power_sensor_#res#1 := 1; {46988#true} is VALID [2022-02-20 21:36:01,723 INFO L290 TraceCheckUtils]: 144: Hoare triple {46988#true} ibmpex_find_sensors_#t~ret154#1 := is_power_sensor_#res#1;assume { :end_inline_is_power_sensor } true;assume -2147483648 <= ibmpex_find_sensors_#t~ret154#1 && ibmpex_find_sensors_#t~ret154#1 <= 2147483647;ibmpex_find_sensors_~tmp___1~1#1 := ibmpex_find_sensors_#t~ret154#1;havoc ibmpex_find_sensors_#t~mem153#1;havoc ibmpex_find_sensors_#t~ret154#1; {46988#true} is VALID [2022-02-20 21:36:01,724 INFO L290 TraceCheckUtils]: 145: Hoare triple {46988#true} assume 0 != ibmpex_find_sensors_~tmp___1~1#1;ibmpex_find_sensors_~sensor_type~0#1 := 2;ibmpex_find_sensors_~num_power~0#1 := 1 + ibmpex_find_sensors_~num_power~0#1;ibmpex_find_sensors_~sensor_counter~0#1 := ibmpex_find_sensors_~num_power~0#1;call ibmpex_find_sensors_#t~mem155#1.base, ibmpex_find_sensors_#t~mem155#1.offset := read~$Pointer$(ibmpex_find_sensors_~data#1.base, 907 + ibmpex_find_sensors_~data#1.offset, 8);call ibmpex_find_sensors_#t~mem156#1 := read~int(ibmpex_find_sensors_~data#1.base, 891 + ibmpex_find_sensors_~data#1.offset, 8);assume { :begin_inline_power_sensor_multiplier } true;power_sensor_multiplier_#in~data#1.base, power_sensor_multiplier_#in~data#1.offset, power_sensor_multiplier_#in~sensor_id#1.base, power_sensor_multiplier_#in~sensor_id#1.offset, power_sensor_multiplier_#in~len#1 := ibmpex_find_sensors_~data#1.base, ibmpex_find_sensors_~data#1.offset, ibmpex_find_sensors_~data#1.base, 619 + ibmpex_find_sensors_~data#1.offset, (if ibmpex_find_sensors_#t~mem156#1 % 18446744073709551616 % 4294967296 <= 2147483647 then ibmpex_find_sensors_#t~mem156#1 % 18446744073709551616 % 4294967296 else ibmpex_find_sensors_#t~mem156#1 % 18446744073709551616 % 4294967296 - 4294967296);havoc power_sensor_multiplier_#res#1;havoc power_sensor_multiplier_#t~mem132#1, power_sensor_multiplier_#t~ret133#1, power_sensor_multiplier_~data#1.base, power_sensor_multiplier_~data#1.offset, power_sensor_multiplier_~sensor_id#1.base, power_sensor_multiplier_~sensor_id#1.offset, power_sensor_multiplier_~len#1, power_sensor_multiplier_~i~1#1, power_sensor_multiplier_~tmp~11#1;power_sensor_multiplier_~data#1.base, power_sensor_multiplier_~data#1.offset := power_sensor_multiplier_#in~data#1.base, power_sensor_multiplier_#in~data#1.offset;power_sensor_multiplier_~sensor_id#1.base, power_sensor_multiplier_~sensor_id#1.offset := power_sensor_multiplier_#in~sensor_id#1.base, power_sensor_multiplier_#in~sensor_id#1.offset;power_sensor_multiplier_~len#1 := power_sensor_multiplier_#in~len#1;havoc power_sensor_multiplier_~i~1#1;havoc power_sensor_multiplier_~tmp~11#1;call power_sensor_multiplier_#t~mem132#1 := read~int(power_sensor_multiplier_~data#1.base, 904 + power_sensor_multiplier_~data#1.offset, 1); {47067#(= |ULTIMATE.start_ibmpex_find_sensors_~sensor_type~0#1| 2)} is VALID [2022-02-20 21:36:01,724 INFO L290 TraceCheckUtils]: 146: Hoare triple {47067#(= |ULTIMATE.start_ibmpex_find_sensors_~sensor_type~0#1| 2)} assume 2 == power_sensor_multiplier_#t~mem132#1 % 256 % 4294967296;havoc power_sensor_multiplier_#t~mem132#1;power_sensor_multiplier_#res#1 := 1000000; {47067#(= |ULTIMATE.start_ibmpex_find_sensors_~sensor_type~0#1| 2)} is VALID [2022-02-20 21:36:01,724 INFO L290 TraceCheckUtils]: 147: Hoare triple {47067#(= |ULTIMATE.start_ibmpex_find_sensors_~sensor_type~0#1| 2)} ibmpex_find_sensors_#t~ret157#1 := power_sensor_multiplier_#res#1;assume { :end_inline_power_sensor_multiplier } true;assume -2147483648 <= ibmpex_find_sensors_#t~ret157#1 && ibmpex_find_sensors_#t~ret157#1 <= 2147483647;call write~int(ibmpex_find_sensors_#t~ret157#1, ibmpex_find_sensors_#t~mem155#1.base, 10 + (ibmpex_find_sensors_#t~mem155#1.offset + 152 * (if ibmpex_find_sensors_~i~2#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then ibmpex_find_sensors_~i~2#1 % 18446744073709551616 % 18446744073709551616 else ibmpex_find_sensors_~i~2#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616)), 4);havoc ibmpex_find_sensors_#t~mem155#1.base, ibmpex_find_sensors_#t~mem155#1.offset;havoc ibmpex_find_sensors_#t~mem156#1;havoc ibmpex_find_sensors_#t~ret157#1; {47067#(= |ULTIMATE.start_ibmpex_find_sensors_~sensor_type~0#1| 2)} is VALID [2022-02-20 21:36:01,725 INFO L290 TraceCheckUtils]: 148: Hoare triple {47067#(= |ULTIMATE.start_ibmpex_find_sensors_~sensor_type~0#1| 2)} call ibmpex_find_sensors_#t~mem161#1.base, ibmpex_find_sensors_#t~mem161#1.offset := read~$Pointer$(ibmpex_find_sensors_~data#1.base, 907 + ibmpex_find_sensors_~data#1.offset, 8);call write~int(1, ibmpex_find_sensors_#t~mem161#1.base, ibmpex_find_sensors_#t~mem161#1.offset + 152 * (if ibmpex_find_sensors_~i~2#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then ibmpex_find_sensors_~i~2#1 % 18446744073709551616 % 18446744073709551616 else ibmpex_find_sensors_~i~2#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616), 4);havoc ibmpex_find_sensors_#t~mem161#1.base, ibmpex_find_sensors_#t~mem161#1.offset;ibmpex_find_sensors_~j~0#1 := 0; {47067#(= |ULTIMATE.start_ibmpex_find_sensors_~sensor_type~0#1| 2)} is VALID [2022-02-20 21:36:01,725 INFO L290 TraceCheckUtils]: 149: Hoare triple {47067#(= |ULTIMATE.start_ibmpex_find_sensors_~sensor_type~0#1| 2)} assume ibmpex_find_sensors_~j~0#1 <= 2; {47067#(= |ULTIMATE.start_ibmpex_find_sensors_~sensor_type~0#1| 2)} is VALID [2022-02-20 21:36:01,726 INFO L290 TraceCheckUtils]: 150: Hoare triple {47067#(= |ULTIMATE.start_ibmpex_find_sensors_~sensor_type~0#1| 2)} assume { :begin_inline_create_sensor } true;create_sensor_#in~data#1.base, create_sensor_#in~data#1.offset, create_sensor_#in~type#1, create_sensor_#in~counter#1, create_sensor_#in~sensor#1, create_sensor_#in~func#1 := ibmpex_find_sensors_~data#1.base, ibmpex_find_sensors_~data#1.offset, ibmpex_find_sensors_~sensor_type~0#1, ibmpex_find_sensors_~sensor_counter~0#1, ibmpex_find_sensors_~i~2#1, ibmpex_find_sensors_~j~0#1;havoc create_sensor_#res#1;havoc create_sensor_#t~ret134#1.base, create_sensor_#t~ret134#1.offset, create_sensor_#t~nondet135#1, create_sensor_#t~mem136#1.base, create_sensor_#t~mem136#1.offset, create_sensor_#t~nondet137#1, create_sensor_#t~mem138#1.base, create_sensor_#t~mem138#1.offset, create_sensor_#t~mem139#1.base, create_sensor_#t~mem139#1.offset, create_sensor_#t~mem140#1.base, create_sensor_#t~mem140#1.offset, create_sensor_#t~mem141#1.base, create_sensor_#t~mem141#1.offset, create_sensor_#t~mem142#1.base, create_sensor_#t~mem142#1.offset, create_sensor_#t~mem143#1.base, create_sensor_#t~mem143#1.offset, create_sensor_#t~mem144#1.base, create_sensor_#t~mem144#1.offset, create_sensor_#t~mem145#1.base, create_sensor_#t~mem145#1.offset, create_sensor_#t~ret146#1, create_sensor_#t~mem147#1.base, create_sensor_#t~mem147#1.offset, create_sensor_~data#1.base, create_sensor_~data#1.offset, create_sensor_~type#1, create_sensor_~counter#1, create_sensor_~sensor#1, create_sensor_~func#1, create_sensor_~err~2#1, create_sensor_~n~0#1.base, create_sensor_~n~0#1.offset, create_sensor_~tmp~12#1.base, create_sensor_~tmp~12#1.offset;create_sensor_~data#1.base, create_sensor_~data#1.offset := create_sensor_#in~data#1.base, create_sensor_#in~data#1.offset;create_sensor_~type#1 := create_sensor_#in~type#1;create_sensor_~counter#1 := create_sensor_#in~counter#1;create_sensor_~sensor#1 := create_sensor_#in~sensor#1;create_sensor_~func#1 := create_sensor_#in~func#1;havoc create_sensor_~err~2#1;havoc create_sensor_~n~0#1.base, create_sensor_~n~0#1.offset;havoc create_sensor_~tmp~12#1.base, create_sensor_~tmp~12#1.offset; {47068#(= 2 |ULTIMATE.start_create_sensor_~type#1|)} is VALID [2022-02-20 21:36:01,727 INFO L272 TraceCheckUtils]: 151: Hoare triple {47068#(= 2 |ULTIMATE.start_create_sensor_~type#1|)} call create_sensor_#t~ret134#1.base, create_sensor_#t~ret134#1.offset := kmalloc(32, 208); {47079#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:36:01,727 INFO L290 TraceCheckUtils]: 152: Hoare triple {47079#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;~flags#1 := #in~flags#1;havoc ~tmp___2~0#1.base, ~tmp___2~0#1.offset;assume { :begin_inline___kmalloc } true;__kmalloc_#in~size#1, __kmalloc_#in~t#1 := ~size#1, ~flags#1;havoc __kmalloc_#res#1.base, __kmalloc_#res#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset, __kmalloc_~size#1, __kmalloc_~t#1;__kmalloc_~size#1 := __kmalloc_#in~size#1;__kmalloc_~t#1 := __kmalloc_#in~t#1; {46988#true} is VALID [2022-02-20 21:36:01,727 INFO L272 TraceCheckUtils]: 153: Hoare triple {46988#true} call __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset := ldv_malloc(__kmalloc_~size#1); {47079#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} is VALID [2022-02-20 21:36:01,727 INFO L290 TraceCheckUtils]: 154: Hoare triple {47079#(and (= |old(#length)| |#length|) (= |old(#valid)| |#valid|))} ~size#1 := #in~size#1;assume -2147483648 <= #t~nondet35#1 && #t~nondet35#1 <= 2147483647; {46988#true} is VALID [2022-02-20 21:36:01,728 INFO L290 TraceCheckUtils]: 155: Hoare triple {46988#true} assume !(0 != #t~nondet35#1);havoc #t~nondet35#1;#res#1.base, #res#1.offset := 0, 0; {46988#true} is VALID [2022-02-20 21:36:01,728 INFO L290 TraceCheckUtils]: 156: Hoare triple {46988#true} assume true; {46988#true} is VALID [2022-02-20 21:36:01,728 INFO L284 TraceCheckUtils]: 157: Hoare quadruple {46988#true} {46988#true} #590#return; {46988#true} is VALID [2022-02-20 21:36:01,728 INFO L290 TraceCheckUtils]: 158: Hoare triple {46988#true} __kmalloc_#res#1.base, __kmalloc_#res#1.offset := __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset;havoc __kmalloc_#t~ret38#1.base, __kmalloc_#t~ret38#1.offset; {46988#true} is VALID [2022-02-20 21:36:01,728 INFO L290 TraceCheckUtils]: 159: Hoare triple {46988#true} #t~ret39#1.base, #t~ret39#1.offset := __kmalloc_#res#1.base, __kmalloc_#res#1.offset;assume { :end_inline___kmalloc } true;~tmp___2~0#1.base, ~tmp___2~0#1.offset := #t~ret39#1.base, #t~ret39#1.offset;havoc #t~ret39#1.base, #t~ret39#1.offset;#res#1.base, #res#1.offset := ~tmp___2~0#1.base, ~tmp___2~0#1.offset; {46988#true} is VALID [2022-02-20 21:36:01,728 INFO L290 TraceCheckUtils]: 160: Hoare triple {46988#true} assume true; {46988#true} is VALID [2022-02-20 21:36:01,729 INFO L284 TraceCheckUtils]: 161: Hoare quadruple {46988#true} {47068#(= 2 |ULTIMATE.start_create_sensor_~type#1|)} #640#return; {47068#(= 2 |ULTIMATE.start_create_sensor_~type#1|)} is VALID [2022-02-20 21:36:01,730 INFO L290 TraceCheckUtils]: 162: Hoare triple {47068#(= 2 |ULTIMATE.start_create_sensor_~type#1|)} create_sensor_~tmp~12#1.base, create_sensor_~tmp~12#1.offset := create_sensor_#t~ret134#1.base, create_sensor_#t~ret134#1.offset;havoc create_sensor_#t~ret134#1.base, create_sensor_#t~ret134#1.offset;create_sensor_~n~0#1.base, create_sensor_~n~0#1.offset := create_sensor_~tmp~12#1.base, create_sensor_~tmp~12#1.offset; {47068#(= 2 |ULTIMATE.start_create_sensor_~type#1|)} is VALID [2022-02-20 21:36:01,730 INFO L290 TraceCheckUtils]: 163: Hoare triple {47068#(= 2 |ULTIMATE.start_create_sensor_~type#1|)} assume !(0 == (create_sensor_~n~0#1.base + create_sensor_~n~0#1.offset) % 18446744073709551616); {47068#(= 2 |ULTIMATE.start_create_sensor_~type#1|)} is VALID [2022-02-20 21:36:01,730 INFO L290 TraceCheckUtils]: 164: Hoare triple {47068#(= 2 |ULTIMATE.start_create_sensor_~type#1|)} assume 1 == create_sensor_~type#1;havoc create_sensor_#t~nondet135#1;call create_sensor_#t~mem136#1.base, create_sensor_#t~mem136#1.offset := read~$Pointer$(~#temp_sensor_name_templates~0.base, ~#temp_sensor_name_templates~0.offset + 8 * create_sensor_~func#1, 8);havoc create_sensor_#t~mem136#1.base, create_sensor_#t~mem136#1.offset; {46989#false} is VALID [2022-02-20 21:36:01,730 INFO L290 TraceCheckUtils]: 165: Hoare triple {46989#false} assume { :begin_inline_ldv_sysfs } true;~ldv_count_1~0 := 1 + ~ldv_count_1~0; {46989#false} is VALID [2022-02-20 21:36:01,731 INFO L290 TraceCheckUtils]: 166: Hoare triple {46989#false} assume { :end_inline_ldv_sysfs } true;call create_sensor_#t~mem139#1.base, create_sensor_#t~mem139#1.offset := read~$Pointer$(create_sensor_~data#1.base, 907 + create_sensor_~data#1.offset, 8);call write~$Pointer$(create_sensor_~n~0#1.base, create_sensor_~n~0#1.offset, create_sensor_#t~mem139#1.base, 14 + (create_sensor_#t~mem139#1.offset + 152 * (if create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 else create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616)) + 46 * create_sensor_~func#1, 8);havoc create_sensor_#t~mem139#1.base, create_sensor_#t~mem139#1.offset;call create_sensor_#t~mem140#1.base, create_sensor_#t~mem140#1.offset := read~$Pointer$(create_sensor_~data#1.base, 907 + create_sensor_~data#1.offset, 8);call write~int(292, create_sensor_#t~mem140#1.base, 8 + (14 + (create_sensor_#t~mem140#1.offset + 152 * (if create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 else create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616)) + 46 * create_sensor_~func#1), 4);havoc create_sensor_#t~mem140#1.base, create_sensor_#t~mem140#1.offset;call create_sensor_#t~mem141#1.base, create_sensor_#t~mem141#1.offset := read~$Pointer$(create_sensor_~data#1.base, 907 + create_sensor_~data#1.offset, 8);call write~$Pointer$(#funAddr~ibmpex_show_sensor.base, #funAddr~ibmpex_show_sensor.offset, create_sensor_#t~mem141#1.base, 28 + (14 + (create_sensor_#t~mem141#1.offset + 152 * (if create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 else create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616)) + 46 * create_sensor_~func#1), 8);havoc create_sensor_#t~mem141#1.base, create_sensor_#t~mem141#1.offset;call create_sensor_#t~mem142#1.base, create_sensor_#t~mem142#1.offset := read~$Pointer$(create_sensor_~data#1.base, 907 + create_sensor_~data#1.offset, 8);call write~int(create_sensor_~sensor#1, create_sensor_#t~mem142#1.base, 44 + (14 + (create_sensor_#t~mem142#1.offset + 152 * (if create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 else create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616)) + 46 * create_sensor_~func#1), 1);havoc create_sensor_#t~mem142#1.base, create_sensor_#t~mem142#1.offset;call create_sensor_#t~mem143#1.base, create_sensor_#t~mem143#1.offset := read~$Pointer$(create_sensor_~data#1.base, 907 + create_sensor_~data#1.offset, 8);call write~int(create_sensor_~func#1, create_sensor_#t~mem143#1.base, 45 + (14 + (create_sensor_#t~mem143#1.offset + 152 * (if create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 else create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616)) + 46 * create_sensor_~func#1), 1);havoc create_sensor_#t~mem143#1.base, create_sensor_#t~mem143#1.offset;call create_sensor_#t~mem144#1.base, create_sensor_#t~mem144#1.offset := read~$Pointer$(create_sensor_~data#1.base, 24 + create_sensor_~data#1.offset, 8);call create_sensor_#t~mem145#1.base, create_sensor_#t~mem145#1.offset := read~$Pointer$(create_sensor_~data#1.base, 907 + create_sensor_~data#1.offset, 8);assume { :begin_inline_ldv_device_create_file_5 } true;ldv_device_create_file_5_#in~ldv_func_arg1#1.base, ldv_device_create_file_5_#in~ldv_func_arg1#1.offset, ldv_device_create_file_5_#in~ldv_func_arg2#1.base, ldv_device_create_file_5_#in~ldv_func_arg2#1.offset := create_sensor_#t~mem144#1.base, create_sensor_#t~mem144#1.offset, create_sensor_#t~mem145#1.base, 14 + (create_sensor_#t~mem145#1.offset + 152 * (if create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 <= 9223372036854775807 then create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 else create_sensor_~sensor#1 % 18446744073709551616 % 18446744073709551616 - 18446744073709551616)) + 46 * create_sensor_~func#1;havoc ldv_device_create_file_5_#res#1;havoc ldv_device_create_file_5_#t~ret241#1, ldv_device_create_file_5_~ldv_func_arg1#1.base, ldv_device_create_file_5_~ldv_func_arg1#1.offset, ldv_device_create_file_5_~ldv_func_arg2#1.base, ldv_device_create_file_5_~ldv_func_arg2#1.offset, ldv_device_create_file_5_~tmp~19#1;ldv_device_create_file_5_~ldv_func_arg1#1.base, ldv_device_create_file_5_~ldv_func_arg1#1.offset := ldv_device_create_file_5_#in~ldv_func_arg1#1.base, ldv_device_create_file_5_#in~ldv_func_arg1#1.offset;ldv_device_create_file_5_~ldv_func_arg2#1.base, ldv_device_create_file_5_~ldv_func_arg2#1.offset := ldv_device_create_file_5_#in~ldv_func_arg2#1.base, ldv_device_create_file_5_#in~ldv_func_arg2#1.offset;havoc ldv_device_create_file_5_~tmp~19#1;assume { :begin_inline_ldv_device_create_file_dev_attr_of_sensor_device_attribute_2 } true;ldv_device_create_file_dev_attr_of_sensor_device_attribute_2_#in~attr#1.base, ldv_device_create_file_dev_attr_of_sensor_device_attribute_2_#in~attr#1.offset := ldv_device_create_file_5_~ldv_func_arg2#1.base, ldv_device_create_file_5_~ldv_func_arg2#1.offset;havoc ldv_device_create_file_dev_attr_of_sensor_device_attribute_2_#res#1;havoc ldv_device_create_file_dev_attr_of_sensor_device_attribute_2_~attr#1.base, ldv_device_create_file_dev_attr_of_sensor_device_attribute_2_~attr#1.offset;ldv_device_create_file_dev_attr_of_sensor_device_attribute_2_~attr#1.base, ldv_device_create_file_dev_attr_of_sensor_device_attribute_2_~attr#1.offset := ldv_device_create_file_dev_attr_of_sensor_device_attribute_2_#in~attr#1.base, ldv_device_create_file_dev_attr_of_sensor_device_attribute_2_#in~attr#1.offset; {46989#false} is VALID [2022-02-20 21:36:01,731 INFO L290 TraceCheckUtils]: 167: Hoare triple {46989#false} assume 0 == ~ldv_call_dev_attr_of_sensor_device_attribute_2~0;~ldv_count_2~0 := 1 + ~ldv_count_2~0;~ldv_call_dev_attr_of_sensor_device_attribute_2~0 := 1; {46989#false} is VALID [2022-02-20 21:36:01,731 INFO L290 TraceCheckUtils]: 168: Hoare triple {46989#false} assume ~ldv_count_1~0 >= ~ldv_count_2~0; {46989#false} is VALID [2022-02-20 21:36:01,731 INFO L290 TraceCheckUtils]: 169: Hoare triple {46989#false} ldv_device_create_file_dev_attr_of_sensor_device_attribute_2_#res#1 := 0; {46989#false} is VALID [2022-02-20 21:36:01,731 INFO L290 TraceCheckUtils]: 170: Hoare triple {46989#false} ldv_device_create_file_5_#t~ret241#1 := ldv_device_create_file_dev_attr_of_sensor_device_attribute_2_#res#1;assume { :end_inline_ldv_device_create_file_dev_attr_of_sensor_device_attribute_2 } true;assume -2147483648 <= ldv_device_create_file_5_#t~ret241#1 && ldv_device_create_file_5_#t~ret241#1 <= 2147483647;ldv_device_create_file_5_~tmp~19#1 := ldv_device_create_file_5_#t~ret241#1;havoc ldv_device_create_file_5_#t~ret241#1;ldv_device_create_file_5_#res#1 := ldv_device_create_file_5_~tmp~19#1; {46989#false} is VALID [2022-02-20 21:36:01,732 INFO L290 TraceCheckUtils]: 171: Hoare triple {46989#false} create_sensor_#t~ret146#1 := ldv_device_create_file_5_#res#1;assume { :end_inline_ldv_device_create_file_5 } true;assume -2147483648 <= create_sensor_#t~ret146#1 && create_sensor_#t~ret146#1 <= 2147483647;create_sensor_~err~2#1 := create_sensor_#t~ret146#1;havoc create_sensor_#t~mem144#1.base, create_sensor_#t~mem144#1.offset;havoc create_sensor_#t~mem145#1.base, create_sensor_#t~mem145#1.offset;havoc create_sensor_#t~ret146#1; {46989#false} is VALID [2022-02-20 21:36:01,732 INFO L290 TraceCheckUtils]: 172: Hoare triple {46989#false} assume !(0 != create_sensor_~err~2#1);create_sensor_#res#1 := 0; {46989#false} is VALID [2022-02-20 21:36:01,732 INFO L290 TraceCheckUtils]: 173: Hoare triple {46989#false} ibmpex_find_sensors_#t~ret162#1 := create_sensor_#res#1;assume { :end_inline_create_sensor } true;assume -2147483648 <= ibmpex_find_sensors_#t~ret162#1 && ibmpex_find_sensors_#t~ret162#1 <= 2147483647;ibmpex_find_sensors_~err~3#1 := ibmpex_find_sensors_#t~ret162#1;havoc ibmpex_find_sensors_#t~ret162#1; {46989#false} is VALID [2022-02-20 21:36:01,732 INFO L290 TraceCheckUtils]: 174: Hoare triple {46989#false} assume !(0 != ibmpex_find_sensors_~err~3#1);ibmpex_find_sensors_~j~0#1 := 1 + ibmpex_find_sensors_~j~0#1; {46989#false} is VALID [2022-02-20 21:36:01,732 INFO L290 TraceCheckUtils]: 175: Hoare triple {46989#false} assume !(ibmpex_find_sensors_~j~0#1 <= 2); {46989#false} is VALID [2022-02-20 21:36:01,732 INFO L290 TraceCheckUtils]: 176: Hoare triple {46989#false} ibmpex_find_sensors_~i~2#1 := 1 + ibmpex_find_sensors_~i~2#1; {46989#false} is VALID [2022-02-20 21:36:01,733 INFO L290 TraceCheckUtils]: 177: Hoare triple {46989#false} call ibmpex_find_sensors_#t~mem163#1 := read~int(ibmpex_find_sensors_~data#1.base, 906 + ibmpex_find_sensors_~data#1.offset, 1); {46989#false} is VALID [2022-02-20 21:36:01,733 INFO L290 TraceCheckUtils]: 178: Hoare triple {46989#false} assume !(ibmpex_find_sensors_#t~mem163#1 % 256 > ibmpex_find_sensors_~i~2#1);havoc ibmpex_find_sensors_#t~mem163#1;call ibmpex_find_sensors_#t~mem164#1.base, ibmpex_find_sensors_#t~mem164#1.offset := read~$Pointer$(ibmpex_find_sensors_~data#1.base, 24 + ibmpex_find_sensors_~data#1.offset, 8);assume { :begin_inline_ldv_device_create_file_6 } true;ldv_device_create_file_6_#in~ldv_func_arg1#1.base, ldv_device_create_file_6_#in~ldv_func_arg1#1.offset, ldv_device_create_file_6_#in~ldv_func_arg2#1.base, ldv_device_create_file_6_#in~ldv_func_arg2#1.offset := ibmpex_find_sensors_#t~mem164#1.base, ibmpex_find_sensors_#t~mem164#1.offset, ~#sensor_dev_attr_reset_high_low~0.base, ~#sensor_dev_attr_reset_high_low~0.offset;havoc ldv_device_create_file_6_#res#1;havoc ldv_device_create_file_6_#t~ret242#1, ldv_device_create_file_6_~ldv_func_arg1#1.base, ldv_device_create_file_6_~ldv_func_arg1#1.offset, ldv_device_create_file_6_~ldv_func_arg2#1.base, ldv_device_create_file_6_~ldv_func_arg2#1.offset, ldv_device_create_file_6_~tmp~20#1;ldv_device_create_file_6_~ldv_func_arg1#1.base, ldv_device_create_file_6_~ldv_func_arg1#1.offset := ldv_device_create_file_6_#in~ldv_func_arg1#1.base, ldv_device_create_file_6_#in~ldv_func_arg1#1.offset;ldv_device_create_file_6_~ldv_func_arg2#1.base, ldv_device_create_file_6_~ldv_func_arg2#1.offset := ldv_device_create_file_6_#in~ldv_func_arg2#1.base, ldv_device_create_file_6_#in~ldv_func_arg2#1.offset;havoc ldv_device_create_file_6_~tmp~20#1; {46989#false} is VALID [2022-02-20 21:36:01,733 INFO L272 TraceCheckUtils]: 179: Hoare triple {46989#false} call ldv_device_create_file_6_#t~ret242#1 := ldv_device_create_file_dev_attr_of_sensor_device_attribute(ldv_device_create_file_6_~ldv_func_arg2#1.base, ldv_device_create_file_6_~ldv_func_arg2#1.offset); {46989#false} is VALID [2022-02-20 21:36:01,733 INFO L290 TraceCheckUtils]: 180: Hoare triple {46989#false} ~attr.base, ~attr.offset := #in~attr.base, #in~attr.offset; {46989#false} is VALID [2022-02-20 21:36:01,733 INFO L290 TraceCheckUtils]: 181: Hoare triple {46989#false} assume 0 == ~ldv_call_dev_attr_of_sensor_device_attribute~0;~ldv_count_2~0 := 1 + ~ldv_count_2~0;~ldv_call_dev_attr_of_sensor_device_attribute~0 := 1; {46989#false} is VALID [2022-02-20 21:36:01,733 INFO L290 TraceCheckUtils]: 182: Hoare triple {46989#false} assume !(~ldv_count_1~0 >= ~ldv_count_2~0); {46989#false} is VALID [2022-02-20 21:36:01,734 INFO L272 TraceCheckUtils]: 183: Hoare triple {46989#false} call ldv_error(); {46989#false} is VALID [2022-02-20 21:36:01,734 INFO L290 TraceCheckUtils]: 184: Hoare triple {46989#false} assume !false; {46989#false} is VALID [2022-02-20 21:36:01,734 INFO L134 CoverageAnalysis]: Checked inductivity of 79 backedges. 3 proven. 0 refuted. 0 times theorem prover too weak. 76 trivial. 0 not checked. [2022-02-20 21:36:01,734 INFO L144 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-02-20 21:36:01,735 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [722616765] [2022-02-20 21:36:01,735 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleSmtInterpolCraig [722616765] provided 1 perfect and 0 imperfect interpolant sequences [2022-02-20 21:36:01,735 INFO L191 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-02-20 21:36:01,735 INFO L204 FreeRefinementEngine]: Number of different interpolants: perfect sequences [6] imperfect sequences [] total 6 [2022-02-20 21:36:01,735 INFO L118 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [1337509694] [2022-02-20 21:36:01,736 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-02-20 21:36:01,736 INFO L78 Accepts]: Start accepts. Automaton has has 6 states, 6 states have (on average 18.0) internal successors, (108), 4 states have internal predecessors, (108), 3 states have call successors, (19), 4 states have call predecessors, (19), 1 states have return successors, (17), 2 states have call predecessors, (17), 2 states have call successors, (17) Word has length 185 [2022-02-20 21:36:01,737 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-02-20 21:36:01,737 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with has 6 states, 6 states have (on average 18.0) internal successors, (108), 4 states have internal predecessors, (108), 3 states have call successors, (19), 4 states have call predecessors, (19), 1 states have return successors, (17), 2 states have call predecessors, (17), 2 states have call successors, (17) [2022-02-20 21:36:01,863 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 144 edges. 144 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 21:36:01,863 INFO L546 AbstractCegarLoop]: INTERPOLANT automaton has 6 states [2022-02-20 21:36:01,864 INFO L108 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2022-02-20 21:36:01,864 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 6 interpolants. [2022-02-20 21:36:01,864 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=9, Invalid=21, Unknown=0, NotChecked=0, Total=30 [2022-02-20 21:36:01,864 INFO L87 Difference]: Start difference. First operand 1045 states and 1374 transitions. Second operand has 6 states, 6 states have (on average 18.0) internal successors, (108), 4 states have internal predecessors, (108), 3 states have call successors, (19), 4 states have call predecessors, (19), 1 states have return successors, (17), 2 states have call predecessors, (17), 2 states have call successors, (17) [2022-02-20 21:36:08,012 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 21:36:08,012 INFO L93 Difference]: Finished difference Result 3946 states and 5543 transitions. [2022-02-20 21:36:08,012 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 8 states. [2022-02-20 21:36:08,013 INFO L78 Accepts]: Start accepts. Automaton has has 6 states, 6 states have (on average 18.0) internal successors, (108), 4 states have internal predecessors, (108), 3 states have call successors, (19), 4 states have call predecessors, (19), 1 states have return successors, (17), 2 states have call predecessors, (17), 2 states have call successors, (17) Word has length 185 [2022-02-20 21:36:08,013 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-02-20 21:36:08,013 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 6 states, 6 states have (on average 18.0) internal successors, (108), 4 states have internal predecessors, (108), 3 states have call successors, (19), 4 states have call predecessors, (19), 1 states have return successors, (17), 2 states have call predecessors, (17), 2 states have call successors, (17) [2022-02-20 21:36:08,027 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 8 states to 8 states and 1354 transitions. [2022-02-20 21:36:08,027 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 6 states, 6 states have (on average 18.0) internal successors, (108), 4 states have internal predecessors, (108), 3 states have call successors, (19), 4 states have call predecessors, (19), 1 states have return successors, (17), 2 states have call predecessors, (17), 2 states have call successors, (17) [2022-02-20 21:36:08,041 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 8 states to 8 states and 1354 transitions. [2022-02-20 21:36:08,041 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with 8 states and 1354 transitions.