./Ultimate.py --spec ../sv-benchmarks/c/properties/unreach-call.prp --file ../sv-benchmarks/c/product-lines/email_spec8_product29.cil.c --full-output -ea --architecture 32bit -------------------------------------------------------------------------------- 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/product-lines/email_spec8_product29.cil.c -s /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/config/svcomp-Reach-32bit-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 32bit --witnessprinter.graph.data.programhash 9244be1607acf28cf3da39a66e263e3f7b227fe42ed993f89a6311649f8ded26 --- Real Ultimate output --- This is Ultimate 0.2.2-dev-03d7b7b [2022-02-20 18:03:30,817 INFO L177 SettingsManager]: Resetting all preferences to default values... [2022-02-20 18:03:30,819 INFO L181 SettingsManager]: Resetting UltimateCore preferences to default values [2022-02-20 18:03:30,856 INFO L184 SettingsManager]: Ultimate Commandline Interface provides no preferences, ignoring... [2022-02-20 18:03:30,857 INFO L181 SettingsManager]: Resetting Boogie Preprocessor preferences to default values [2022-02-20 18:03:30,859 INFO L181 SettingsManager]: Resetting Boogie Procedure Inliner preferences to default values [2022-02-20 18:03:30,860 INFO L181 SettingsManager]: Resetting Abstract Interpretation preferences to default values [2022-02-20 18:03:30,863 INFO L181 SettingsManager]: Resetting LassoRanker preferences to default values [2022-02-20 18:03:30,864 INFO L181 SettingsManager]: Resetting Reaching Definitions preferences to default values [2022-02-20 18:03:30,869 INFO L181 SettingsManager]: Resetting SyntaxChecker preferences to default values [2022-02-20 18:03:30,869 INFO L181 SettingsManager]: Resetting Sifa preferences to default values [2022-02-20 18:03:30,871 INFO L184 SettingsManager]: Büchi Program Product provides no preferences, ignoring... [2022-02-20 18:03:30,871 INFO L181 SettingsManager]: Resetting LTL2Aut preferences to default values [2022-02-20 18:03:30,873 INFO L181 SettingsManager]: Resetting PEA to Boogie preferences to default values [2022-02-20 18:03:30,874 INFO L181 SettingsManager]: Resetting BlockEncodingV2 preferences to default values [2022-02-20 18:03:30,877 INFO L181 SettingsManager]: Resetting ChcToBoogie preferences to default values [2022-02-20 18:03:30,878 INFO L181 SettingsManager]: Resetting AutomataScriptInterpreter preferences to default values [2022-02-20 18:03:30,878 INFO L181 SettingsManager]: Resetting BuchiAutomizer preferences to default values [2022-02-20 18:03:30,880 INFO L181 SettingsManager]: Resetting CACSL2BoogieTranslator preferences to default values [2022-02-20 18:03:30,884 INFO L181 SettingsManager]: Resetting CodeCheck preferences to default values [2022-02-20 18:03:30,885 INFO L181 SettingsManager]: Resetting InvariantSynthesis preferences to default values [2022-02-20 18:03:30,900 INFO L181 SettingsManager]: Resetting RCFGBuilder preferences to default values [2022-02-20 18:03:30,901 INFO L181 SettingsManager]: Resetting Referee preferences to default values [2022-02-20 18:03:30,902 INFO L181 SettingsManager]: Resetting TraceAbstraction preferences to default values [2022-02-20 18:03:30,904 INFO L184 SettingsManager]: TraceAbstractionConcurrent provides no preferences, ignoring... [2022-02-20 18:03:30,904 INFO L184 SettingsManager]: TraceAbstractionWithAFAs provides no preferences, ignoring... [2022-02-20 18:03:30,905 INFO L181 SettingsManager]: Resetting TreeAutomizer preferences to default values [2022-02-20 18:03:30,906 INFO L181 SettingsManager]: Resetting IcfgToChc preferences to default values [2022-02-20 18:03:30,906 INFO L181 SettingsManager]: Resetting IcfgTransformer preferences to default values [2022-02-20 18:03:30,907 INFO L184 SettingsManager]: ReqToTest provides no preferences, ignoring... [2022-02-20 18:03:30,907 INFO L181 SettingsManager]: Resetting Boogie Printer preferences to default values [2022-02-20 18:03:30,908 INFO L181 SettingsManager]: Resetting ChcSmtPrinter preferences to default values [2022-02-20 18:03:30,909 INFO L181 SettingsManager]: Resetting ReqPrinter preferences to default values [2022-02-20 18:03:30,909 INFO L181 SettingsManager]: Resetting Witness Printer preferences to default values [2022-02-20 18:03:30,910 INFO L184 SettingsManager]: Boogie PL CUP Parser provides no preferences, ignoring... [2022-02-20 18:03:30,911 INFO L181 SettingsManager]: Resetting CDTParser preferences to default values [2022-02-20 18:03:30,911 INFO L184 SettingsManager]: AutomataScriptParser provides no preferences, ignoring... [2022-02-20 18:03:30,911 INFO L184 SettingsManager]: ReqParser provides no preferences, ignoring... [2022-02-20 18:03:30,911 INFO L181 SettingsManager]: Resetting SmtParser preferences to default values [2022-02-20 18:03:30,912 INFO L181 SettingsManager]: Resetting Witness Parser preferences to default values [2022-02-20 18:03:30,912 INFO L188 SettingsManager]: Finished resetting all preferences to default values... [2022-02-20 18:03:30,913 INFO L101 SettingsManager]: Beginning loading settings from /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/config/svcomp-Reach-32bit-Automizer_Default.epf [2022-02-20 18:03:30,941 INFO L113 SettingsManager]: Loading preferences was successful [2022-02-20 18:03:30,942 INFO L115 SettingsManager]: Preferences different from defaults after loading the file: [2022-02-20 18:03:30,942 INFO L136 SettingsManager]: Preferences of UltimateCore differ from their defaults: [2022-02-20 18:03:30,942 INFO L138 SettingsManager]: * Log level for class=de.uni_freiburg.informatik.ultimate.lib.smtlibutils.quantifier.QuantifierPusher=ERROR; [2022-02-20 18:03:30,943 INFO L136 SettingsManager]: Preferences of Boogie Procedure Inliner differ from their defaults: [2022-02-20 18:03:30,943 INFO L138 SettingsManager]: * Ignore calls to procedures called more than once=ONLY_FOR_SEQUENTIAL_PROGRAMS [2022-02-20 18:03:30,944 INFO L136 SettingsManager]: Preferences of BlockEncodingV2 differ from their defaults: [2022-02-20 18:03:30,944 INFO L138 SettingsManager]: * Create parallel compositions if possible=false [2022-02-20 18:03:30,944 INFO L138 SettingsManager]: * Use SBE=true [2022-02-20 18:03:30,944 INFO L136 SettingsManager]: Preferences of CACSL2BoogieTranslator differ from their defaults: [2022-02-20 18:03:30,945 INFO L138 SettingsManager]: * sizeof long=4 [2022-02-20 18:03:30,945 INFO L138 SettingsManager]: * Overapproximate operations on floating types=true [2022-02-20 18:03:30,945 INFO L138 SettingsManager]: * sizeof POINTER=4 [2022-02-20 18:03:30,945 INFO L138 SettingsManager]: * Check division by zero=IGNORE [2022-02-20 18:03:30,946 INFO L138 SettingsManager]: * Pointer to allocated memory at dereference=IGNORE [2022-02-20 18:03:30,946 INFO L138 SettingsManager]: * If two pointers are subtracted or compared they have the same base address=IGNORE [2022-02-20 18:03:30,946 INFO L138 SettingsManager]: * Check array bounds for arrays that are off heap=IGNORE [2022-02-20 18:03:30,946 INFO L138 SettingsManager]: * sizeof long double=12 [2022-02-20 18:03:30,946 INFO L138 SettingsManager]: * Check if freed pointer was valid=false [2022-02-20 18:03:30,946 INFO L138 SettingsManager]: * Use constant arrays=true [2022-02-20 18:03:30,947 INFO L138 SettingsManager]: * Pointer base address is valid at dereference=IGNORE [2022-02-20 18:03:30,947 INFO L136 SettingsManager]: Preferences of RCFGBuilder differ from their defaults: [2022-02-20 18:03:30,947 INFO L138 SettingsManager]: * Size of a code block=SequenceOfStatements [2022-02-20 18:03:30,947 INFO L138 SettingsManager]: * SMT solver=External_DefaultMode [2022-02-20 18:03:30,947 INFO L138 SettingsManager]: * Command for external solver=z3 SMTLIB2_COMPLIANT=true -memory:2024 -smt2 -in -t:2000 [2022-02-20 18:03:30,948 INFO L136 SettingsManager]: Preferences of TraceAbstraction differ from their defaults: [2022-02-20 18:03:30,948 INFO L138 SettingsManager]: * Compute Interpolants along a Counterexample=FPandBP [2022-02-20 18:03:30,949 INFO L138 SettingsManager]: * Positions where we compute the Hoare Annotation=LoopsAndPotentialCycles [2022-02-20 18:03:30,949 INFO L138 SettingsManager]: * Trace refinement strategy=CAMEL [2022-02-20 18:03:30,949 INFO L138 SettingsManager]: * Command for external solver=z3 SMTLIB2_COMPLIANT=true -memory:2024 -smt2 -in [2022-02-20 18:03:30,949 INFO L138 SettingsManager]: * Large block encoding in concurrent analysis=OFF [2022-02-20 18:03:30,949 INFO L138 SettingsManager]: * Automaton type used in concurrency analysis=PETRI_NET [2022-02-20 18:03:30,950 INFO L138 SettingsManager]: * Compute Hoare Annotation of negated interpolant automaton, abstraction and CFG=true [2022-02-20 18:03:30,950 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 -> 32bit Applying setting for plugin de.uni_freiburg.informatik.ultimate.witnessprinter: Graph data programhash -> 9244be1607acf28cf3da39a66e263e3f7b227fe42ed993f89a6311649f8ded26 [2022-02-20 18:03:31,131 INFO L75 nceAwareModelManager]: Repository-Root is: /tmp [2022-02-20 18:03:31,151 INFO L261 ainManager$Toolchain]: [Toolchain 1]: Applicable parser(s) successfully (re)initialized [2022-02-20 18:03:31,153 INFO L217 ainManager$Toolchain]: [Toolchain 1]: Toolchain selected. [2022-02-20 18:03:31,154 INFO L271 PluginConnector]: Initializing CDTParser... [2022-02-20 18:03:31,154 INFO L275 PluginConnector]: CDTParser initialized [2022-02-20 18:03:31,155 INFO L432 ainManager$Toolchain]: [Toolchain 1]: Parsing single file: /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/../sv-benchmarks/c/product-lines/email_spec8_product29.cil.c [2022-02-20 18:03:31,208 INFO L220 CDTParser]: Created temporary CDT project at /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/data/6066181c0/a8781ab8ec2940ff8625c398cc3ca025/FLAGab729e66b [2022-02-20 18:03:31,609 INFO L306 CDTParser]: Found 1 translation units. [2022-02-20 18:03:31,619 INFO L160 CDTParser]: Scanning /storage/repos/ultimate/releaseScripts/default/sv-benchmarks/c/product-lines/email_spec8_product29.cil.c [2022-02-20 18:03:31,641 INFO L349 CDTParser]: About to delete temporary CDT project at /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/data/6066181c0/a8781ab8ec2940ff8625c398cc3ca025/FLAGab729e66b [2022-02-20 18:03:31,952 INFO L357 CDTParser]: Successfully deleted /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/data/6066181c0/a8781ab8ec2940ff8625c398cc3ca025 [2022-02-20 18:03:31,954 INFO L299 ainManager$Toolchain]: ####################### [Toolchain 1] ####################### [2022-02-20 18:03:31,955 INFO L131 ToolchainWalker]: Walking toolchain with 6 elements. [2022-02-20 18:03:31,956 INFO L113 PluginConnector]: ------------------------CACSL2BoogieTranslator---------------------------- [2022-02-20 18:03:31,956 INFO L271 PluginConnector]: Initializing CACSL2BoogieTranslator... [2022-02-20 18:03:31,958 INFO L275 PluginConnector]: CACSL2BoogieTranslator initialized [2022-02-20 18:03:31,959 INFO L185 PluginConnector]: Executing the observer ACSLObjectContainerObserver from plugin CACSL2BoogieTranslator for "CDTParser AST 20.02 06:03:31" (1/1) ... [2022-02-20 18:03:31,960 INFO L205 PluginConnector]: Invalid model from CACSL2BoogieTranslator for observer de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator.ACSLObjectContainerObserver@6b5ac1e9 and model type de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 06:03:31, skipping insertion in model container [2022-02-20 18:03:31,960 INFO L185 PluginConnector]: Executing the observer CACSL2BoogieTranslatorObserver from plugin CACSL2BoogieTranslator for "CDTParser AST 20.02 06:03:31" (1/1) ... [2022-02-20 18:03:31,965 INFO L145 MainTranslator]: Starting translation in SV-COMP mode [2022-02-20 18:03:32,036 INFO L178 MainTranslator]: Built tables and reachable declarations [2022-02-20 18:03:32,383 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/product-lines/email_spec8_product29.cil.c[29472,29485] [2022-02-20 18:03:32,528 INFO L210 PostProcessor]: Analyzing one entry point: main [2022-02-20 18:03:32,536 INFO L203 MainTranslator]: Completed pre-run [2022-02-20 18:03:32,587 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/product-lines/email_spec8_product29.cil.c[29472,29485] [2022-02-20 18:03:32,657 INFO L210 PostProcessor]: Analyzing one entry point: main [2022-02-20 18:03:32,682 INFO L208 MainTranslator]: Completed translation [2022-02-20 18:03:32,683 INFO L202 PluginConnector]: Adding new model de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 06:03:32 WrapperNode [2022-02-20 18:03:32,683 INFO L132 PluginConnector]: ------------------------ END CACSL2BoogieTranslator---------------------------- [2022-02-20 18:03:32,686 INFO L113 PluginConnector]: ------------------------Boogie Procedure Inliner---------------------------- [2022-02-20 18:03:32,687 INFO L271 PluginConnector]: Initializing Boogie Procedure Inliner... [2022-02-20 18:03:32,687 INFO L275 PluginConnector]: Boogie Procedure Inliner initialized [2022-02-20 18:03:32,692 INFO L185 PluginConnector]: Executing the observer TypeChecker from plugin Boogie Procedure Inliner for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 06:03:32" (1/1) ... [2022-02-20 18:03:32,718 INFO L185 PluginConnector]: Executing the observer Inliner from plugin Boogie Procedure Inliner for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 06:03:32" (1/1) ... [2022-02-20 18:03:32,778 INFO L137 Inliner]: procedures = 132, calls = 232, calls flagged for inlining = 56, calls inlined = 48, statements flattened = 939 [2022-02-20 18:03:32,778 INFO L132 PluginConnector]: ------------------------ END Boogie Procedure Inliner---------------------------- [2022-02-20 18:03:32,779 INFO L113 PluginConnector]: ------------------------Boogie Preprocessor---------------------------- [2022-02-20 18:03:32,779 INFO L271 PluginConnector]: Initializing Boogie Preprocessor... [2022-02-20 18:03:32,779 INFO L275 PluginConnector]: Boogie Preprocessor initialized [2022-02-20 18:03:32,784 INFO L185 PluginConnector]: Executing the observer EnsureBoogieModelObserver from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 06:03:32" (1/1) ... [2022-02-20 18:03:32,785 INFO L185 PluginConnector]: Executing the observer TypeChecker from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 06:03:32" (1/1) ... [2022-02-20 18:03:32,789 INFO L185 PluginConnector]: Executing the observer ConstExpander from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 06:03:32" (1/1) ... [2022-02-20 18:03:32,795 INFO L185 PluginConnector]: Executing the observer StructExpander from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 06:03:32" (1/1) ... [2022-02-20 18:03:32,808 INFO L185 PluginConnector]: Executing the observer UnstructureCode from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 06:03:32" (1/1) ... [2022-02-20 18:03:32,815 INFO L185 PluginConnector]: Executing the observer FunctionInliner from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 06:03:32" (1/1) ... [2022-02-20 18:03:32,834 INFO L185 PluginConnector]: Executing the observer BoogieSymbolTableConstructor from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 06:03:32" (1/1) ... [2022-02-20 18:03:32,840 INFO L132 PluginConnector]: ------------------------ END Boogie Preprocessor---------------------------- [2022-02-20 18:03:32,841 INFO L113 PluginConnector]: ------------------------RCFGBuilder---------------------------- [2022-02-20 18:03:32,841 INFO L271 PluginConnector]: Initializing RCFGBuilder... [2022-02-20 18:03:32,841 INFO L275 PluginConnector]: RCFGBuilder initialized [2022-02-20 18:03:32,845 INFO L185 PluginConnector]: Executing the observer RCFGBuilderObserver from plugin RCFGBuilder for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 06:03:32" (1/1) ... [2022-02-20 18:03:32,869 INFO L173 SolverBuilder]: Constructing external solver with command: z3 SMTLIB2_COMPLIANT=true -memory:2024 -smt2 -in -t:2000 [2022-02-20 18:03:32,882 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-02-20 18:03:32,892 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 18:03:32,894 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 18:03:32,919 INFO L130 BoogieDeclarations]: Found specification of procedure getClientPrivateKey [2022-02-20 18:03:32,919 INFO L138 BoogieDeclarations]: Found implementation of procedure getClientPrivateKey [2022-02-20 18:03:32,920 INFO L130 BoogieDeclarations]: Found specification of procedure getClientAddressBookSize [2022-02-20 18:03:32,920 INFO L138 BoogieDeclarations]: Found implementation of procedure getClientAddressBookSize [2022-02-20 18:03:32,920 INFO L130 BoogieDeclarations]: Found specification of procedure setEmailEncryptionKey [2022-02-20 18:03:32,920 INFO L138 BoogieDeclarations]: Found implementation of procedure setEmailEncryptionKey [2022-02-20 18:03:32,920 INFO L130 BoogieDeclarations]: Found specification of procedure setClientAddressBookAddress [2022-02-20 18:03:32,920 INFO L138 BoogieDeclarations]: Found implementation of procedure setClientAddressBookAddress [2022-02-20 18:03:32,920 INFO L130 BoogieDeclarations]: Found specification of procedure getEmailEncryptionKey [2022-02-20 18:03:32,921 INFO L138 BoogieDeclarations]: Found implementation of procedure getEmailEncryptionKey [2022-02-20 18:03:32,921 INFO L130 BoogieDeclarations]: Found specification of procedure getEmailTo [2022-02-20 18:03:32,921 INFO L138 BoogieDeclarations]: Found implementation of procedure getEmailTo [2022-02-20 18:03:32,921 INFO L130 BoogieDeclarations]: Found specification of procedure setEmailFrom [2022-02-20 18:03:32,921 INFO L138 BoogieDeclarations]: Found implementation of procedure setEmailFrom [2022-02-20 18:03:32,922 INFO L130 BoogieDeclarations]: Found specification of procedure isReadable [2022-02-20 18:03:32,922 INFO L138 BoogieDeclarations]: Found implementation of procedure isReadable [2022-02-20 18:03:32,922 INFO L130 BoogieDeclarations]: Found specification of procedure createClientKeyringEntry [2022-02-20 18:03:32,922 INFO L138 BoogieDeclarations]: Found implementation of procedure createClientKeyringEntry [2022-02-20 18:03:32,922 INFO L130 BoogieDeclarations]: Found specification of procedure setEmailIsEncrypted [2022-02-20 18:03:32,922 INFO L138 BoogieDeclarations]: Found implementation of procedure setEmailIsEncrypted [2022-02-20 18:03:32,922 INFO L130 BoogieDeclarations]: Found specification of procedure getEmailSignKey [2022-02-20 18:03:32,922 INFO L138 BoogieDeclarations]: Found implementation of procedure getEmailSignKey [2022-02-20 18:03:32,922 INFO L130 BoogieDeclarations]: Found specification of procedure chuckKeyAdd [2022-02-20 18:03:32,923 INFO L138 BoogieDeclarations]: Found implementation of procedure chuckKeyAdd [2022-02-20 18:03:32,923 INFO L130 BoogieDeclarations]: Found specification of procedure puts [2022-02-20 18:03:32,923 INFO L130 BoogieDeclarations]: Found specification of procedure getEmailFrom [2022-02-20 18:03:32,923 INFO L138 BoogieDeclarations]: Found implementation of procedure getEmailFrom [2022-02-20 18:03:32,923 INFO L130 BoogieDeclarations]: Found specification of procedure setClientId [2022-02-20 18:03:32,923 INFO L138 BoogieDeclarations]: Found implementation of procedure setClientId [2022-02-20 18:03:32,923 INFO L130 BoogieDeclarations]: Found specification of procedure #Ultimate.allocInit [2022-02-20 18:03:32,923 INFO L130 BoogieDeclarations]: Found specification of procedure isSigned [2022-02-20 18:03:32,923 INFO L138 BoogieDeclarations]: Found implementation of procedure isSigned [2022-02-20 18:03:32,924 INFO L130 BoogieDeclarations]: Found specification of procedure isKeyPairValid [2022-02-20 18:03:32,924 INFO L138 BoogieDeclarations]: Found implementation of procedure isKeyPairValid [2022-02-20 18:03:32,924 INFO L130 BoogieDeclarations]: Found specification of procedure setClientAddressBookSize [2022-02-20 18:03:32,924 INFO L138 BoogieDeclarations]: Found implementation of procedure setClientAddressBookSize [2022-02-20 18:03:32,924 INFO L130 BoogieDeclarations]: Found specification of procedure setClientKeyringUser [2022-02-20 18:03:32,924 INFO L138 BoogieDeclarations]: Found implementation of procedure setClientKeyringUser [2022-02-20 18:03:32,925 INFO L130 BoogieDeclarations]: Found specification of procedure setClientKeyringPublicKey [2022-02-20 18:03:32,925 INFO L138 BoogieDeclarations]: Found implementation of procedure setClientKeyringPublicKey [2022-02-20 18:03:32,925 INFO L130 BoogieDeclarations]: Found specification of procedure outgoing [2022-02-20 18:03:32,925 INFO L138 BoogieDeclarations]: Found implementation of procedure outgoing [2022-02-20 18:03:32,925 INFO L130 BoogieDeclarations]: Found specification of procedure findPublicKey [2022-02-20 18:03:32,925 INFO L138 BoogieDeclarations]: Found implementation of procedure findPublicKey [2022-02-20 18:03:32,925 INFO L130 BoogieDeclarations]: Found specification of procedure outgoing__wrappee__Encrypt [2022-02-20 18:03:32,926 INFO L138 BoogieDeclarations]: Found implementation of procedure outgoing__wrappee__Encrypt [2022-02-20 18:03:32,926 INFO L130 BoogieDeclarations]: Found specification of procedure sendEmail [2022-02-20 18:03:32,926 INFO L138 BoogieDeclarations]: Found implementation of procedure sendEmail [2022-02-20 18:03:32,926 INFO L130 BoogieDeclarations]: Found specification of procedure isEncrypted [2022-02-20 18:03:32,926 INFO L138 BoogieDeclarations]: Found implementation of procedure isEncrypted [2022-02-20 18:03:32,926 INFO L130 BoogieDeclarations]: Found specification of procedure setClientPrivateKey [2022-02-20 18:03:32,926 INFO L138 BoogieDeclarations]: Found implementation of procedure setClientPrivateKey [2022-02-20 18:03:32,926 INFO L130 BoogieDeclarations]: Found specification of procedure setEmailTo [2022-02-20 18:03:32,927 INFO L138 BoogieDeclarations]: Found implementation of procedure setEmailTo [2022-02-20 18:03:32,927 INFO L130 BoogieDeclarations]: Found specification of procedure write~init~int [2022-02-20 18:03:32,928 INFO L130 BoogieDeclarations]: Found specification of procedure generateKeyPair [2022-02-20 18:03:32,928 INFO L138 BoogieDeclarations]: Found implementation of procedure generateKeyPair [2022-02-20 18:03:32,928 INFO L130 BoogieDeclarations]: Found specification of procedure getClientAddressBookAddress [2022-02-20 18:03:32,929 INFO L138 BoogieDeclarations]: Found implementation of procedure getClientAddressBookAddress [2022-02-20 18:03:32,929 INFO L130 BoogieDeclarations]: Found specification of procedure ULTIMATE.start [2022-02-20 18:03:32,929 INFO L138 BoogieDeclarations]: Found implementation of procedure ULTIMATE.start [2022-02-20 18:03:33,152 INFO L234 CfgBuilder]: Building ICFG [2022-02-20 18:03:33,156 INFO L260 CfgBuilder]: Building CFG for each procedure with an implementation [2022-02-20 18:03:34,064 INFO L275 CfgBuilder]: Performing block encoding [2022-02-20 18:03:34,085 INFO L294 CfgBuilder]: Using the 1 location(s) as analysis (start of procedure ULTIMATE.start) [2022-02-20 18:03:34,086 INFO L299 CfgBuilder]: Removed 1 assume(true) statements. [2022-02-20 18:03:34,088 INFO L202 PluginConnector]: Adding new model de.uni_freiburg.informatik.ultimate.plugins.generator.rcfgbuilder CFG 20.02 06:03:34 BoogieIcfgContainer [2022-02-20 18:03:34,095 INFO L132 PluginConnector]: ------------------------ END RCFGBuilder---------------------------- [2022-02-20 18:03:34,097 INFO L113 PluginConnector]: ------------------------TraceAbstraction---------------------------- [2022-02-20 18:03:34,097 INFO L271 PluginConnector]: Initializing TraceAbstraction... [2022-02-20 18:03:34,100 INFO L275 PluginConnector]: TraceAbstraction initialized [2022-02-20 18:03:34,101 INFO L185 PluginConnector]: Executing the observer TraceAbstractionObserver from plugin TraceAbstraction for "CDTParser AST 20.02 06:03:31" (1/3) ... [2022-02-20 18:03:34,101 INFO L205 PluginConnector]: Invalid model from TraceAbstraction for observer de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction.TraceAbstractionObserver@2f724d8d and model type de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction AST 20.02 06:03:34, skipping insertion in model container [2022-02-20 18:03:34,101 INFO L185 PluginConnector]: Executing the observer TraceAbstractionObserver from plugin TraceAbstraction for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 06:03:32" (2/3) ... [2022-02-20 18:03:34,102 INFO L205 PluginConnector]: Invalid model from TraceAbstraction for observer de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction.TraceAbstractionObserver@2f724d8d and model type de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction AST 20.02 06:03:34, skipping insertion in model container [2022-02-20 18:03:34,102 INFO L185 PluginConnector]: Executing the observer TraceAbstractionObserver from plugin TraceAbstraction for "de.uni_freiburg.informatik.ultimate.plugins.generator.rcfgbuilder CFG 20.02 06:03:34" (3/3) ... [2022-02-20 18:03:34,104 INFO L111 eAbstractionObserver]: Analyzing ICFG email_spec8_product29.cil.c [2022-02-20 18:03:34,109 INFO L205 ceAbstractionStarter]: Automizer settings: Hoare:true NWA Interpolation:FPandBP Determinization: PREDICATE_ABSTRACTION [2022-02-20 18:03:34,109 INFO L164 ceAbstractionStarter]: Applying trace abstraction to program that has 1 error locations. [2022-02-20 18:03:34,162 INFO L338 AbstractCegarLoop]: ======== Iteration 0 == of CEGAR loop == AllErrorsAtOnce ======== [2022-02-20 18:03:34,168 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 18:03:34,169 INFO L340 AbstractCegarLoop]: Starting to check reachability of 1 error locations. [2022-02-20 18:03:34,198 INFO L276 IsEmpty]: Start isEmpty. Operand has 409 states, 316 states have (on average 1.5537974683544304) internal successors, (491), 321 states have internal predecessors, (491), 63 states have call successors, (63), 28 states have call predecessors, (63), 28 states have return successors, (63), 62 states have call predecessors, (63), 63 states have call successors, (63) [2022-02-20 18:03:34,221 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 111 [2022-02-20 18:03:34,221 INFO L506 BasicCegarLoop]: Found error trace [2022-02-20 18:03:34,222 INFO L514 BasicCegarLoop]: trace histogram [3, 3, 3, 3, 3, 3, 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] [2022-02-20 18:03:34,223 INFO L402 AbstractCegarLoop]: === Iteration 1 === Targeting outgoing__wrappee__EncryptErr0ASSERT_VIOLATIONERROR_FUNCTION === [outgoing__wrappee__EncryptErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-02-20 18:03:34,227 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-02-20 18:03:34,227 INFO L85 PathProgramCache]: Analyzing trace with hash 1913469271, now seen corresponding path program 1 times [2022-02-20 18:03:34,235 INFO L126 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-02-20 18:03:34,235 INFO L338 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [370835179] [2022-02-20 18:03:34,236 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 18:03:34,237 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-02-20 18:03:34,381 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:34,518 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 6 [2022-02-20 18:03:34,527 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:34,538 INFO L290 TraceCheckUtils]: 0: Hoare triple {472#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {412#true} is VALID [2022-02-20 18:03:34,539 INFO L290 TraceCheckUtils]: 1: Hoare triple {412#true} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {412#true} is VALID [2022-02-20 18:03:34,539 INFO L290 TraceCheckUtils]: 2: Hoare triple {412#true} assume true; {412#true} is VALID [2022-02-20 18:03:34,540 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {412#true} {412#true} #1224#return; {412#true} is VALID [2022-02-20 18:03:34,548 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 12 [2022-02-20 18:03:34,554 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:34,574 INFO L290 TraceCheckUtils]: 0: Hoare triple {473#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {412#true} is VALID [2022-02-20 18:03:34,575 INFO L290 TraceCheckUtils]: 1: Hoare triple {412#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {412#true} is VALID [2022-02-20 18:03:34,576 INFO L290 TraceCheckUtils]: 2: Hoare triple {412#true} assume true; {412#true} is VALID [2022-02-20 18:03:34,576 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {412#true} {412#true} #1226#return; {412#true} is VALID [2022-02-20 18:03:34,576 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 18 [2022-02-20 18:03:34,580 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:34,606 INFO L290 TraceCheckUtils]: 0: Hoare triple {472#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {474#(= setClientId_~handle |setClientId_#in~handle|)} is VALID [2022-02-20 18:03:34,607 INFO L290 TraceCheckUtils]: 1: Hoare triple {474#(= setClientId_~handle |setClientId_#in~handle|)} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {475#(= |setClientId_#in~handle| 1)} is VALID [2022-02-20 18:03:34,608 INFO L290 TraceCheckUtils]: 2: Hoare triple {475#(= |setClientId_#in~handle| 1)} assume true; {475#(= |setClientId_#in~handle| 1)} is VALID [2022-02-20 18:03:34,609 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {475#(= |setClientId_#in~handle| 1)} {422#(= |ULTIMATE.start_setup_rjh__wrappee__Base_~rjh___0#1| 2)} #1228#return; {413#false} is VALID [2022-02-20 18:03:34,609 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 24 [2022-02-20 18:03:34,613 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:34,620 INFO L290 TraceCheckUtils]: 0: Hoare triple {473#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {412#true} is VALID [2022-02-20 18:03:34,620 INFO L290 TraceCheckUtils]: 1: Hoare triple {412#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {412#true} is VALID [2022-02-20 18:03:34,621 INFO L290 TraceCheckUtils]: 2: Hoare triple {412#true} assume true; {412#true} is VALID [2022-02-20 18:03:34,622 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {412#true} {413#false} #1230#return; {413#false} is VALID [2022-02-20 18:03:34,622 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 30 [2022-02-20 18:03:34,627 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:34,637 INFO L290 TraceCheckUtils]: 0: Hoare triple {472#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {412#true} is VALID [2022-02-20 18:03:34,638 INFO L290 TraceCheckUtils]: 1: Hoare triple {412#true} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {412#true} is VALID [2022-02-20 18:03:34,638 INFO L290 TraceCheckUtils]: 2: Hoare triple {412#true} assume true; {412#true} is VALID [2022-02-20 18:03:34,639 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {412#true} {413#false} #1232#return; {413#false} is VALID [2022-02-20 18:03:34,639 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 36 [2022-02-20 18:03:34,645 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:34,657 INFO L290 TraceCheckUtils]: 0: Hoare triple {473#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {412#true} is VALID [2022-02-20 18:03:34,658 INFO L290 TraceCheckUtils]: 1: Hoare triple {412#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {412#true} is VALID [2022-02-20 18:03:34,658 INFO L290 TraceCheckUtils]: 2: Hoare triple {412#true} assume true; {412#true} is VALID [2022-02-20 18:03:34,658 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {412#true} {413#false} #1234#return; {413#false} is VALID [2022-02-20 18:03:34,668 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 47 [2022-02-20 18:03:34,673 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:34,688 INFO L290 TraceCheckUtils]: 0: Hoare triple {476#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} ~handle := #in~handle;~value := #in~value; {412#true} is VALID [2022-02-20 18:03:34,689 INFO L290 TraceCheckUtils]: 1: Hoare triple {412#true} assume 1 == ~handle;~__ste_email_from0~0 := ~value; {412#true} is VALID [2022-02-20 18:03:34,689 INFO L290 TraceCheckUtils]: 2: Hoare triple {412#true} assume true; {412#true} is VALID [2022-02-20 18:03:34,689 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {412#true} {413#false} #1210#return; {413#false} is VALID [2022-02-20 18:03:34,699 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 52 [2022-02-20 18:03:34,700 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:34,706 INFO L290 TraceCheckUtils]: 0: Hoare triple {477#(and (= ~__ste_email_to0~0 |old(~__ste_email_to0~0)|) (= ~__ste_email_to1~0 |old(~__ste_email_to1~0)|))} ~handle := #in~handle;~value := #in~value; {412#true} is VALID [2022-02-20 18:03:34,706 INFO L290 TraceCheckUtils]: 1: Hoare triple {412#true} assume 1 == ~handle;~__ste_email_to0~0 := ~value; {412#true} is VALID [2022-02-20 18:03:34,707 INFO L290 TraceCheckUtils]: 2: Hoare triple {412#true} assume true; {412#true} is VALID [2022-02-20 18:03:34,707 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {412#true} {413#false} #1212#return; {413#false} is VALID [2022-02-20 18:03:34,707 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 61 [2022-02-20 18:03:34,709 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:34,715 INFO L290 TraceCheckUtils]: 0: Hoare triple {412#true} ~handle := #in~handle;havoc ~retValue_acc~36; {412#true} is VALID [2022-02-20 18:03:34,715 INFO L290 TraceCheckUtils]: 1: Hoare triple {412#true} assume 1 == ~handle;~retValue_acc~36 := ~__ste_client_privateKey0~0;#res := ~retValue_acc~36; {412#true} is VALID [2022-02-20 18:03:34,715 INFO L290 TraceCheckUtils]: 2: Hoare triple {412#true} assume true; {412#true} is VALID [2022-02-20 18:03:34,715 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {412#true} {413#false} #1150#return; {413#false} is VALID [2022-02-20 18:03:34,716 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 69 [2022-02-20 18:03:34,718 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:34,722 INFO L290 TraceCheckUtils]: 0: Hoare triple {412#true} ~handle := #in~handle;havoc ~retValue_acc~30; {412#true} is VALID [2022-02-20 18:03:34,723 INFO L290 TraceCheckUtils]: 1: Hoare triple {412#true} assume 1 == ~handle;~retValue_acc~30 := ~__ste_ClientAddressBook_size0~0;#res := ~retValue_acc~30; {412#true} is VALID [2022-02-20 18:03:34,723 INFO L290 TraceCheckUtils]: 2: Hoare triple {412#true} assume true; {412#true} is VALID [2022-02-20 18:03:34,723 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {412#true} {413#false} #1152#return; {413#false} is VALID [2022-02-20 18:03:34,724 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 78 [2022-02-20 18:03:34,727 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:34,757 INFO L290 TraceCheckUtils]: 0: Hoare triple {412#true} ~handle := #in~handle;havoc ~retValue_acc~3; {412#true} is VALID [2022-02-20 18:03:34,757 INFO L290 TraceCheckUtils]: 1: Hoare triple {412#true} assume 1 == ~handle;~retValue_acc~3 := ~__ste_email_to0~0;#res := ~retValue_acc~3; {412#true} is VALID [2022-02-20 18:03:34,757 INFO L290 TraceCheckUtils]: 2: Hoare triple {412#true} assume true; {412#true} is VALID [2022-02-20 18:03:34,757 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {412#true} {413#false} #1170#return; {413#false} is VALID [2022-02-20 18:03:34,757 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 84 [2022-02-20 18:03:34,759 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:34,763 INFO L290 TraceCheckUtils]: 0: Hoare triple {412#true} ~handle := #in~handle;~userid := #in~userid;havoc ~retValue_acc~41; {412#true} is VALID [2022-02-20 18:03:34,763 INFO L290 TraceCheckUtils]: 1: Hoare triple {412#true} assume 1 == ~handle; {412#true} is VALID [2022-02-20 18:03:34,764 INFO L290 TraceCheckUtils]: 2: Hoare triple {412#true} assume ~userid == ~__ste_Client_Keyring0_User0~0;~retValue_acc~41 := ~__ste_Client_Keyring0_PublicKey0~0;#res := ~retValue_acc~41; {412#true} is VALID [2022-02-20 18:03:34,764 INFO L290 TraceCheckUtils]: 3: Hoare triple {412#true} assume true; {412#true} is VALID [2022-02-20 18:03:34,764 INFO L284 TraceCheckUtils]: 4: Hoare quadruple {412#true} {413#false} #1172#return; {413#false} is VALID [2022-02-20 18:03:34,764 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 95 [2022-02-20 18:03:34,766 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:34,769 INFO L290 TraceCheckUtils]: 0: Hoare triple {476#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} ~handle := #in~handle;~value := #in~value; {412#true} is VALID [2022-02-20 18:03:34,769 INFO L290 TraceCheckUtils]: 1: Hoare triple {412#true} assume 1 == ~handle;~__ste_email_from0~0 := ~value; {412#true} is VALID [2022-02-20 18:03:34,769 INFO L290 TraceCheckUtils]: 2: Hoare triple {412#true} assume true; {412#true} is VALID [2022-02-20 18:03:34,770 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {412#true} {413#false} #1178#return; {413#false} is VALID [2022-02-20 18:03:34,770 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 102 [2022-02-20 18:03:34,771 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:34,774 INFO L290 TraceCheckUtils]: 0: Hoare triple {412#true} ~handle := #in~handle;havoc ~retValue_acc~6; {412#true} is VALID [2022-02-20 18:03:34,775 INFO L290 TraceCheckUtils]: 1: Hoare triple {412#true} assume 1 == ~handle;~retValue_acc~6 := ~__ste_email_isEncrypted0~0;#res := ~retValue_acc~6; {412#true} is VALID [2022-02-20 18:03:34,775 INFO L290 TraceCheckUtils]: 2: Hoare triple {412#true} assume true; {412#true} is VALID [2022-02-20 18:03:34,775 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {412#true} {413#false} #1180#return; {413#false} is VALID [2022-02-20 18:03:34,776 INFO L290 TraceCheckUtils]: 0: Hoare triple {412#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(28, 2);call #Ultimate.allocInit(12, 3);call #Ultimate.allocInit(10, 4);call #Ultimate.allocInit(12, 5);call #Ultimate.allocInit(10, 6);call #Ultimate.allocInit(18, 7);call #Ultimate.allocInit(16, 8);call #Ultimate.allocInit(21, 9);call #Ultimate.allocInit(13, 10);call #Ultimate.allocInit(16, 11);call #Ultimate.allocInit(25, 12);call #Ultimate.allocInit(17, 13);call #Ultimate.allocInit(17, 14);call #Ultimate.allocInit(13, 15);call #Ultimate.allocInit(17, 16);call #Ultimate.allocInit(30, 17);call #Ultimate.allocInit(9, 18);call #Ultimate.allocInit(21, 19);call #Ultimate.allocInit(30, 20);call #Ultimate.allocInit(9, 21);call #Ultimate.allocInit(21, 22);call #Ultimate.allocInit(30, 23);call #Ultimate.allocInit(9, 24);call #Ultimate.allocInit(25, 25);call #Ultimate.allocInit(30, 26);call #Ultimate.allocInit(9, 27);call #Ultimate.allocInit(25, 28);call #Ultimate.allocInit(4, 29);call write~init~int(37, 29, 0, 1);call write~init~int(115, 29, 1, 1);call write~init~int(10, 29, 2, 1);call write~init~int(0, 29, 3, 1);call #Ultimate.allocInit(10, 30);call #Ultimate.allocInit(34, 31);call #Ultimate.allocInit(30, 32);call #Ultimate.allocInit(16, 33);call #Ultimate.allocInit(20, 34);call #Ultimate.allocInit(44, 35);call #Ultimate.allocInit(44, 36);call #Ultimate.allocInit(9, 37);call #Ultimate.allocInit(9, 38);call #Ultimate.allocInit(11, 39);call #Ultimate.allocInit(19, 40);call #Ultimate.allocInit(4, 41);call write~init~int(37, 41, 0, 1);call write~init~int(100, 41, 1, 1);call write~init~int(10, 41, 2, 1);call write~init~int(0, 41, 3, 1);call #Ultimate.allocInit(4, 42);call write~init~int(37, 42, 0, 1);call write~init~int(100, 42, 1, 1);call write~init~int(10, 42, 2, 1);call write~init~int(0, 42, 3, 1);~__ste_Email_counter~0 := 0;~__ste_email_id0~0 := 0;~__ste_email_id1~0 := 0;~__ste_email_from0~0 := 0;~__ste_email_from1~0 := 0;~__ste_email_to0~0 := 0;~__ste_email_to1~0 := 0;~__ste_email_subject0~0.base, ~__ste_email_subject0~0.offset := 0, 0;~__ste_email_subject1~0.base, ~__ste_email_subject1~0.offset := 0, 0;~__ste_email_body0~0.base, ~__ste_email_body0~0.offset := 0, 0;~__ste_email_body1~0.base, ~__ste_email_body1~0.offset := 0, 0;~__ste_email_isEncrypted0~0 := 0;~__ste_email_isEncrypted1~0 := 0;~__ste_email_encryptionKey0~0 := 0;~__ste_email_encryptionKey1~0 := 0;~__ste_email_isSigned0~0 := 0;~__ste_email_isSigned1~0 := 0;~__ste_email_signKey0~0 := 0;~__ste_email_signKey1~0 := 0;~__ste_email_isSignatureVerified0~0 := 0;~__ste_email_isSignatureVerified1~0 := 0;~__SELECTED_FEATURE_Base~0 := 0;~__SELECTED_FEATURE_Keys~0 := 0;~__SELECTED_FEATURE_Encrypt~0 := 0;~__SELECTED_FEATURE_AutoResponder~0 := 0;~__SELECTED_FEATURE_AddressBook~0 := 0;~__SELECTED_FEATURE_Sign~0 := 0;~__SELECTED_FEATURE_Forward~0 := 0;~__SELECTED_FEATURE_Verify~0 := 0;~__SELECTED_FEATURE_Decrypt~0 := 0;~__GUIDSL_ROOT_PRODUCTION~0 := 0;~__GUIDSL_NON_TERMINAL_main~0 := 0;~in_encrypted~0 := 0;~head~0.base, ~head~0.offset := 0, 0;~queue_empty~0 := 1;~queued_message~0 := 0;~queued_client~0 := 0;~bob~0 := 0;~rjh~0 := 0;~chuck~0 := 0;~__ste_Client_counter~0 := 0;~__ste_client_name0~0.base, ~__ste_client_name0~0.offset := 0, 0;~__ste_client_name1~0.base, ~__ste_client_name1~0.offset := 0, 0;~__ste_client_name2~0.base, ~__ste_client_name2~0.offset := 0, 0;~__ste_client_outbuffer0~0 := 0;~__ste_client_outbuffer1~0 := 0;~__ste_client_outbuffer2~0 := 0;~__ste_client_outbuffer3~0 := 0;~__ste_ClientAddressBook_size0~0 := 0;~__ste_ClientAddressBook_size1~0 := 0;~__ste_ClientAddressBook_size2~0 := 0;~__ste_Client_AddressBook0_Alias0~0 := 0;~__ste_Client_AddressBook0_Alias1~0 := 0;~__ste_Client_AddressBook0_Alias2~0 := 0;~__ste_Client_AddressBook1_Alias0~0 := 0;~__ste_Client_AddressBook1_Alias1~0 := 0;~__ste_Client_AddressBook1_Alias2~0 := 0;~__ste_Client_AddressBook2_Alias0~0 := 0;~__ste_Client_AddressBook2_Alias1~0 := 0;~__ste_Client_AddressBook2_Alias2~0 := 0;~__ste_Client_AddressBook0_Address0~0 := 0;~__ste_Client_AddressBook0_Address1~0 := 0;~__ste_Client_AddressBook0_Address2~0 := 0;~__ste_Client_AddressBook1_Address0~0 := 0;~__ste_Client_AddressBook1_Address1~0 := 0;~__ste_Client_AddressBook1_Address2~0 := 0;~__ste_Client_AddressBook2_Address0~0 := 0;~__ste_Client_AddressBook2_Address1~0 := 0;~__ste_Client_AddressBook2_Address2~0 := 0;~__ste_client_autoResponse0~0 := 0;~__ste_client_autoResponse1~0 := 0;~__ste_client_autoResponse2~0 := 0;~__ste_client_privateKey0~0 := 0;~__ste_client_privateKey1~0 := 0;~__ste_client_privateKey2~0 := 0;~__ste_ClientKeyring_size0~0 := 0;~__ste_ClientKeyring_size1~0 := 0;~__ste_ClientKeyring_size2~0 := 0;~__ste_Client_Keyring0_User0~0 := 0;~__ste_Client_Keyring0_User1~0 := 0;~__ste_Client_Keyring0_User2~0 := 0;~__ste_Client_Keyring1_User0~0 := 0;~__ste_Client_Keyring1_User1~0 := 0;~__ste_Client_Keyring1_User2~0 := 0;~__ste_Client_Keyring2_User0~0 := 0;~__ste_Client_Keyring2_User1~0 := 0;~__ste_Client_Keyring2_User2~0 := 0;~__ste_Client_Keyring0_PublicKey0~0 := 0;~__ste_Client_Keyring0_PublicKey1~0 := 0;~__ste_Client_Keyring0_PublicKey2~0 := 0;~__ste_Client_Keyring1_PublicKey0~0 := 0;~__ste_Client_Keyring1_PublicKey1~0 := 0;~__ste_Client_Keyring1_PublicKey2~0 := 0;~__ste_Client_Keyring2_PublicKey0~0 := 0;~__ste_Client_Keyring2_PublicKey1~0 := 0;~__ste_Client_Keyring2_PublicKey2~0 := 0;~__ste_client_forwardReceiver0~0 := 0;~__ste_client_forwardReceiver1~0 := 0;~__ste_client_forwardReceiver2~0 := 0;~__ste_client_forwardReceiver3~0 := 0;~__ste_client_idCounter0~0 := 0;~__ste_client_idCounter1~0 := 0;~__ste_client_idCounter2~0 := 0; {412#true} is VALID [2022-02-20 18:03:34,777 INFO L290 TraceCheckUtils]: 1: Hoare triple {412#true} assume { :end_inline_ULTIMATE.init } true;assume { :begin_inline_main } true;havoc main_#res#1;havoc main_#t~nondet100#1, main_#t~ret101#1, main_~retValue_acc~26#1, main_~tmp~20#1;assume -2147483648 <= main_#t~nondet100#1 && main_#t~nondet100#1 <= 2147483647;main_~retValue_acc~26#1 := main_#t~nondet100#1;havoc main_#t~nondet100#1;havoc main_~tmp~20#1;assume { :begin_inline_select_helpers } true; {412#true} is VALID [2022-02-20 18:03:34,777 INFO L290 TraceCheckUtils]: 2: Hoare triple {412#true} assume { :end_inline_select_helpers } true;assume { :begin_inline_select_features } true; {412#true} is VALID [2022-02-20 18:03:34,777 INFO L290 TraceCheckUtils]: 3: Hoare triple {412#true} assume { :end_inline_select_features } true;assume { :begin_inline_valid_product } true;havoc valid_product_#res#1;havoc valid_product_~retValue_acc~12#1;havoc valid_product_~retValue_acc~12#1;valid_product_~retValue_acc~12#1 := 1;valid_product_#res#1 := valid_product_~retValue_acc~12#1; {412#true} is VALID [2022-02-20 18:03:34,777 INFO L290 TraceCheckUtils]: 4: Hoare triple {412#true} main_#t~ret101#1 := valid_product_#res#1;assume { :end_inline_valid_product } true;assume -2147483648 <= main_#t~ret101#1 && main_#t~ret101#1 <= 2147483647;main_~tmp~20#1 := main_#t~ret101#1;havoc main_#t~ret101#1; {412#true} is VALID [2022-02-20 18:03:34,778 INFO L290 TraceCheckUtils]: 5: Hoare triple {412#true} assume 0 != main_~tmp~20#1;assume { :begin_inline_setup } true;havoc setup_#t~nondet97#1, setup_#t~nondet98#1, setup_#t~nondet99#1, setup_~__cil_tmp1~0#1.base, setup_~__cil_tmp1~0#1.offset, setup_~__cil_tmp2~1#1.base, setup_~__cil_tmp2~1#1.offset, setup_~__cil_tmp3~4#1.base, setup_~__cil_tmp3~4#1.offset;havoc setup_~__cil_tmp1~0#1.base, setup_~__cil_tmp1~0#1.offset;havoc setup_~__cil_tmp2~1#1.base, setup_~__cil_tmp2~1#1.offset;havoc setup_~__cil_tmp3~4#1.base, setup_~__cil_tmp3~4#1.offset;~bob~0 := 1;assume { :begin_inline_setup_bob } true;setup_bob_#in~bob___0#1 := ~bob~0;havoc setup_bob_~bob___0#1;setup_bob_~bob___0#1 := setup_bob_#in~bob___0#1;assume { :begin_inline_setup_bob__wrappee__Base } true;setup_bob__wrappee__Base_#in~bob___0#1 := setup_bob_~bob___0#1;havoc setup_bob__wrappee__Base_~bob___0#1;setup_bob__wrappee__Base_~bob___0#1 := setup_bob__wrappee__Base_#in~bob___0#1; {412#true} is VALID [2022-02-20 18:03:34,779 INFO L272 TraceCheckUtils]: 6: Hoare triple {412#true} call setClientId(setup_bob__wrappee__Base_~bob___0#1, setup_bob__wrappee__Base_~bob___0#1); {472#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} is VALID [2022-02-20 18:03:34,779 INFO L290 TraceCheckUtils]: 7: Hoare triple {472#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {412#true} is VALID [2022-02-20 18:03:34,779 INFO L290 TraceCheckUtils]: 8: Hoare triple {412#true} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {412#true} is VALID [2022-02-20 18:03:34,779 INFO L290 TraceCheckUtils]: 9: Hoare triple {412#true} assume true; {412#true} is VALID [2022-02-20 18:03:34,780 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {412#true} {412#true} #1224#return; {412#true} is VALID [2022-02-20 18:03:34,780 INFO L290 TraceCheckUtils]: 11: Hoare triple {412#true} assume { :end_inline_setup_bob__wrappee__Base } true; {412#true} is VALID [2022-02-20 18:03:34,781 INFO L272 TraceCheckUtils]: 12: Hoare triple {412#true} call setClientPrivateKey(setup_bob_~bob___0#1, 123); {473#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} is VALID [2022-02-20 18:03:34,781 INFO L290 TraceCheckUtils]: 13: Hoare triple {473#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {412#true} is VALID [2022-02-20 18:03:34,781 INFO L290 TraceCheckUtils]: 14: Hoare triple {412#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {412#true} is VALID [2022-02-20 18:03:34,782 INFO L290 TraceCheckUtils]: 15: Hoare triple {412#true} assume true; {412#true} is VALID [2022-02-20 18:03:34,782 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {412#true} {412#true} #1226#return; {412#true} is VALID [2022-02-20 18:03:34,782 INFO L290 TraceCheckUtils]: 17: Hoare triple {412#true} assume { :end_inline_setup_bob } true;setup_~__cil_tmp1~0#1.base, setup_~__cil_tmp1~0#1.offset := 37, 0;havoc setup_#t~nondet97#1;~rjh~0 := 2;assume { :begin_inline_setup_rjh } true;setup_rjh_#in~rjh___0#1 := ~rjh~0;havoc setup_rjh_~rjh___0#1;setup_rjh_~rjh___0#1 := setup_rjh_#in~rjh___0#1;assume { :begin_inline_setup_rjh__wrappee__Base } true;setup_rjh__wrappee__Base_#in~rjh___0#1 := setup_rjh_~rjh___0#1;havoc setup_rjh__wrappee__Base_~rjh___0#1;setup_rjh__wrappee__Base_~rjh___0#1 := setup_rjh__wrappee__Base_#in~rjh___0#1; {422#(= |ULTIMATE.start_setup_rjh__wrappee__Base_~rjh___0#1| 2)} is VALID [2022-02-20 18:03:34,783 INFO L272 TraceCheckUtils]: 18: Hoare triple {422#(= |ULTIMATE.start_setup_rjh__wrappee__Base_~rjh___0#1| 2)} call setClientId(setup_rjh__wrappee__Base_~rjh___0#1, setup_rjh__wrappee__Base_~rjh___0#1); {472#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} is VALID [2022-02-20 18:03:34,784 INFO L290 TraceCheckUtils]: 19: Hoare triple {472#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {474#(= setClientId_~handle |setClientId_#in~handle|)} is VALID [2022-02-20 18:03:34,784 INFO L290 TraceCheckUtils]: 20: Hoare triple {474#(= setClientId_~handle |setClientId_#in~handle|)} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {475#(= |setClientId_#in~handle| 1)} is VALID [2022-02-20 18:03:34,785 INFO L290 TraceCheckUtils]: 21: Hoare triple {475#(= |setClientId_#in~handle| 1)} assume true; {475#(= |setClientId_#in~handle| 1)} is VALID [2022-02-20 18:03:34,786 INFO L284 TraceCheckUtils]: 22: Hoare quadruple {475#(= |setClientId_#in~handle| 1)} {422#(= |ULTIMATE.start_setup_rjh__wrappee__Base_~rjh___0#1| 2)} #1228#return; {413#false} is VALID [2022-02-20 18:03:34,786 INFO L290 TraceCheckUtils]: 23: Hoare triple {413#false} assume { :end_inline_setup_rjh__wrappee__Base } true; {413#false} is VALID [2022-02-20 18:03:34,786 INFO L272 TraceCheckUtils]: 24: Hoare triple {413#false} call setClientPrivateKey(setup_rjh_~rjh___0#1, 456); {473#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} is VALID [2022-02-20 18:03:34,787 INFO L290 TraceCheckUtils]: 25: Hoare triple {473#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {412#true} is VALID [2022-02-20 18:03:34,787 INFO L290 TraceCheckUtils]: 26: Hoare triple {412#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {412#true} is VALID [2022-02-20 18:03:34,787 INFO L290 TraceCheckUtils]: 27: Hoare triple {412#true} assume true; {412#true} is VALID [2022-02-20 18:03:34,787 INFO L284 TraceCheckUtils]: 28: Hoare quadruple {412#true} {413#false} #1230#return; {413#false} is VALID [2022-02-20 18:03:34,787 INFO L290 TraceCheckUtils]: 29: Hoare triple {413#false} assume { :end_inline_setup_rjh } true;setup_~__cil_tmp2~1#1.base, setup_~__cil_tmp2~1#1.offset := 38, 0;havoc setup_#t~nondet98#1;~chuck~0 := 3;assume { :begin_inline_setup_chuck } true;setup_chuck_#in~chuck___0#1 := ~chuck~0;havoc setup_chuck_~chuck___0#1;setup_chuck_~chuck___0#1 := setup_chuck_#in~chuck___0#1;assume { :begin_inline_setup_chuck__wrappee__Base } true;setup_chuck__wrappee__Base_#in~chuck___0#1 := setup_chuck_~chuck___0#1;havoc setup_chuck__wrappee__Base_~chuck___0#1;setup_chuck__wrappee__Base_~chuck___0#1 := setup_chuck__wrappee__Base_#in~chuck___0#1; {413#false} is VALID [2022-02-20 18:03:34,788 INFO L272 TraceCheckUtils]: 30: Hoare triple {413#false} call setClientId(setup_chuck__wrappee__Base_~chuck___0#1, setup_chuck__wrappee__Base_~chuck___0#1); {472#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} is VALID [2022-02-20 18:03:34,788 INFO L290 TraceCheckUtils]: 31: Hoare triple {472#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {412#true} is VALID [2022-02-20 18:03:34,788 INFO L290 TraceCheckUtils]: 32: Hoare triple {412#true} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {412#true} is VALID [2022-02-20 18:03:34,788 INFO L290 TraceCheckUtils]: 33: Hoare triple {412#true} assume true; {412#true} is VALID [2022-02-20 18:03:34,789 INFO L284 TraceCheckUtils]: 34: Hoare quadruple {412#true} {413#false} #1232#return; {413#false} is VALID [2022-02-20 18:03:34,789 INFO L290 TraceCheckUtils]: 35: Hoare triple {413#false} assume { :end_inline_setup_chuck__wrappee__Base } true; {413#false} is VALID [2022-02-20 18:03:34,789 INFO L272 TraceCheckUtils]: 36: Hoare triple {413#false} call setClientPrivateKey(setup_chuck_~chuck___0#1, 789); {473#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} is VALID [2022-02-20 18:03:34,789 INFO L290 TraceCheckUtils]: 37: Hoare triple {473#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {412#true} is VALID [2022-02-20 18:03:34,789 INFO L290 TraceCheckUtils]: 38: Hoare triple {412#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {412#true} is VALID [2022-02-20 18:03:34,790 INFO L290 TraceCheckUtils]: 39: Hoare triple {412#true} assume true; {412#true} is VALID [2022-02-20 18:03:34,790 INFO L284 TraceCheckUtils]: 40: Hoare quadruple {412#true} {413#false} #1234#return; {413#false} is VALID [2022-02-20 18:03:34,790 INFO L290 TraceCheckUtils]: 41: Hoare triple {413#false} assume { :end_inline_setup_chuck } true;setup_~__cil_tmp3~4#1.base, setup_~__cil_tmp3~4#1.offset := 39, 0;havoc setup_#t~nondet99#1; {413#false} is VALID [2022-02-20 18:03:34,790 INFO L290 TraceCheckUtils]: 42: Hoare triple {413#false} assume { :end_inline_setup } true;assume { :begin_inline_test } true;havoc test_#t~nondet55#1, test_#t~nondet56#1, test_#t~nondet57#1, test_#t~nondet58#1, test_#t~nondet59#1, test_#t~nondet60#1, test_#t~nondet61#1, test_#t~nondet62#1, test_#t~nondet63#1, test_#t~nondet64#1, test_#t~nondet65#1, test_~op1~0#1, test_~op2~0#1, test_~op3~0#1, test_~op4~0#1, test_~op5~0#1, test_~op6~0#1, test_~op7~0#1, test_~op8~0#1, test_~op9~0#1, test_~op10~0#1, test_~op11~0#1, test_~splverifierCounter~0#1, test_~tmp~9#1, test_~tmp___0~3#1, test_~tmp___1~1#1, test_~tmp___2~1#1, test_~tmp___3~0#1, test_~tmp___4~0#1, test_~tmp___5~0#1, test_~tmp___6~0#1, test_~tmp___7~0#1, test_~tmp___8~0#1, test_~tmp___9~0#1;havoc test_~op1~0#1;havoc test_~op2~0#1;havoc test_~op3~0#1;havoc test_~op4~0#1;havoc test_~op5~0#1;havoc test_~op6~0#1;havoc test_~op7~0#1;havoc test_~op8~0#1;havoc test_~op9~0#1;havoc test_~op10~0#1;havoc test_~op11~0#1;havoc test_~splverifierCounter~0#1;havoc test_~tmp~9#1;havoc test_~tmp___0~3#1;havoc test_~tmp___1~1#1;havoc test_~tmp___2~1#1;havoc test_~tmp___3~0#1;havoc test_~tmp___4~0#1;havoc test_~tmp___5~0#1;havoc test_~tmp___6~0#1;havoc test_~tmp___7~0#1;havoc test_~tmp___8~0#1;havoc test_~tmp___9~0#1;test_~op1~0#1 := 0;test_~op2~0#1 := 0;test_~op3~0#1 := 0;test_~op4~0#1 := 0;test_~op5~0#1 := 0;test_~op6~0#1 := 0;test_~op7~0#1 := 0;test_~op8~0#1 := 0;test_~op9~0#1 := 0;test_~op10~0#1 := 0;test_~op11~0#1 := 0;test_~splverifierCounter~0#1 := 0; {413#false} is VALID [2022-02-20 18:03:34,791 INFO L290 TraceCheckUtils]: 43: Hoare triple {413#false} assume false; {413#false} is VALID [2022-02-20 18:03:34,791 INFO L290 TraceCheckUtils]: 44: Hoare triple {413#false} assume { :begin_inline_bobToRjh } true;havoc bobToRjh_#t~ret92#1, bobToRjh_#t~ret93#1, bobToRjh_#t~ret94#1, bobToRjh_#t~ret95#1, bobToRjh_~tmp~19#1, bobToRjh_~tmp___0~8#1, bobToRjh_~tmp___1~5#1;havoc bobToRjh_~tmp~19#1;havoc bobToRjh_~tmp___0~8#1;havoc bobToRjh_~tmp___1~5#1;call bobToRjh_#t~ret92#1 := puts(35, 0);assume -2147483648 <= bobToRjh_#t~ret92#1 && bobToRjh_#t~ret92#1 <= 2147483647;havoc bobToRjh_#t~ret92#1; {413#false} is VALID [2022-02-20 18:03:34,791 INFO L272 TraceCheckUtils]: 45: Hoare triple {413#false} call sendEmail(~bob~0, ~rjh~0); {413#false} is VALID [2022-02-20 18:03:34,791 INFO L290 TraceCheckUtils]: 46: Hoare triple {413#false} ~sender#1 := #in~sender#1;~receiver#1 := #in~receiver#1;havoc ~email~0#1;havoc ~tmp~16#1;assume { :begin_inline_createEmail } true;createEmail_#in~from#1, createEmail_#in~to#1 := 0, ~receiver#1;havoc createEmail_#res#1;havoc createEmail_~from#1, createEmail_~to#1, createEmail_~retValue_acc~16#1, createEmail_~msg~0#1;createEmail_~from#1 := createEmail_#in~from#1;createEmail_~to#1 := createEmail_#in~to#1;havoc createEmail_~retValue_acc~16#1;havoc createEmail_~msg~0#1;createEmail_~msg~0#1 := 1; {413#false} is VALID [2022-02-20 18:03:34,792 INFO L272 TraceCheckUtils]: 47: Hoare triple {413#false} call setEmailFrom(createEmail_~msg~0#1, createEmail_~from#1); {476#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} is VALID [2022-02-20 18:03:34,792 INFO L290 TraceCheckUtils]: 48: Hoare triple {476#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} ~handle := #in~handle;~value := #in~value; {412#true} is VALID [2022-02-20 18:03:34,792 INFO L290 TraceCheckUtils]: 49: Hoare triple {412#true} assume 1 == ~handle;~__ste_email_from0~0 := ~value; {412#true} is VALID [2022-02-20 18:03:34,792 INFO L290 TraceCheckUtils]: 50: Hoare triple {412#true} assume true; {412#true} is VALID [2022-02-20 18:03:34,793 INFO L284 TraceCheckUtils]: 51: Hoare quadruple {412#true} {413#false} #1210#return; {413#false} is VALID [2022-02-20 18:03:34,793 INFO L272 TraceCheckUtils]: 52: Hoare triple {413#false} call setEmailTo(createEmail_~msg~0#1, createEmail_~to#1); {477#(and (= ~__ste_email_to0~0 |old(~__ste_email_to0~0)|) (= ~__ste_email_to1~0 |old(~__ste_email_to1~0)|))} is VALID [2022-02-20 18:03:34,793 INFO L290 TraceCheckUtils]: 53: Hoare triple {477#(and (= ~__ste_email_to0~0 |old(~__ste_email_to0~0)|) (= ~__ste_email_to1~0 |old(~__ste_email_to1~0)|))} ~handle := #in~handle;~value := #in~value; {412#true} is VALID [2022-02-20 18:03:34,793 INFO L290 TraceCheckUtils]: 54: Hoare triple {412#true} assume 1 == ~handle;~__ste_email_to0~0 := ~value; {412#true} is VALID [2022-02-20 18:03:34,793 INFO L290 TraceCheckUtils]: 55: Hoare triple {412#true} assume true; {412#true} is VALID [2022-02-20 18:03:34,794 INFO L284 TraceCheckUtils]: 56: Hoare quadruple {412#true} {413#false} #1212#return; {413#false} is VALID [2022-02-20 18:03:34,794 INFO L290 TraceCheckUtils]: 57: Hoare triple {413#false} createEmail_~retValue_acc~16#1 := createEmail_~msg~0#1;createEmail_#res#1 := createEmail_~retValue_acc~16#1; {413#false} is VALID [2022-02-20 18:03:34,794 INFO L290 TraceCheckUtils]: 58: Hoare triple {413#false} #t~ret83#1 := createEmail_#res#1;assume { :end_inline_createEmail } true;assume -2147483648 <= #t~ret83#1 && #t~ret83#1 <= 2147483647;~tmp~16#1 := #t~ret83#1;havoc #t~ret83#1;~email~0#1 := ~tmp~16#1; {413#false} is VALID [2022-02-20 18:03:34,794 INFO L272 TraceCheckUtils]: 59: Hoare triple {413#false} call outgoing(~sender#1, ~email~0#1); {413#false} is VALID [2022-02-20 18:03:34,794 INFO L290 TraceCheckUtils]: 60: Hoare triple {413#false} ~client#1 := #in~client#1;~msg#1 := #in~msg#1;assume { :begin_inline_sign } true;sign_#in~client#1, sign_#in~msg#1 := ~client#1, ~msg#1;havoc sign_#t~ret85#1, sign_~client#1, sign_~msg#1, sign_~privkey~1#1, sign_~tmp~17#1;sign_~client#1 := sign_#in~client#1;sign_~msg#1 := sign_#in~msg#1;havoc sign_~privkey~1#1;havoc sign_~tmp~17#1; {413#false} is VALID [2022-02-20 18:03:34,795 INFO L272 TraceCheckUtils]: 61: Hoare triple {413#false} call sign_#t~ret85#1 := getClientPrivateKey(sign_~client#1); {412#true} is VALID [2022-02-20 18:03:34,795 INFO L290 TraceCheckUtils]: 62: Hoare triple {412#true} ~handle := #in~handle;havoc ~retValue_acc~36; {412#true} is VALID [2022-02-20 18:03:34,795 INFO L290 TraceCheckUtils]: 63: Hoare triple {412#true} assume 1 == ~handle;~retValue_acc~36 := ~__ste_client_privateKey0~0;#res := ~retValue_acc~36; {412#true} is VALID [2022-02-20 18:03:34,795 INFO L290 TraceCheckUtils]: 64: Hoare triple {412#true} assume true; {412#true} is VALID [2022-02-20 18:03:34,796 INFO L284 TraceCheckUtils]: 65: Hoare quadruple {412#true} {413#false} #1150#return; {413#false} is VALID [2022-02-20 18:03:34,796 INFO L290 TraceCheckUtils]: 66: Hoare triple {413#false} assume -2147483648 <= sign_#t~ret85#1 && sign_#t~ret85#1 <= 2147483647;sign_~tmp~17#1 := sign_#t~ret85#1;havoc sign_#t~ret85#1;sign_~privkey~1#1 := sign_~tmp~17#1; {413#false} is VALID [2022-02-20 18:03:34,796 INFO L290 TraceCheckUtils]: 67: Hoare triple {413#false} assume 0 == sign_~privkey~1#1; {413#false} is VALID [2022-02-20 18:03:34,796 INFO L290 TraceCheckUtils]: 68: Hoare triple {413#false} assume { :end_inline_sign } true;assume { :begin_inline_outgoing__wrappee__AddressBook } true;outgoing__wrappee__AddressBook_#in~client#1, outgoing__wrappee__AddressBook_#in~msg#1 := ~client#1, ~msg#1;havoc outgoing__wrappee__AddressBook_#t~ret71#1, outgoing__wrappee__AddressBook_#t~ret72#1, outgoing__wrappee__AddressBook_#t~ret73#1, outgoing__wrappee__AddressBook_#t~ret74#1, outgoing__wrappee__AddressBook_#t~ret75#1, outgoing__wrappee__AddressBook_#t~ret76#1, outgoing__wrappee__AddressBook_~client#1, outgoing__wrappee__AddressBook_~msg#1, outgoing__wrappee__AddressBook_~size~0#1, outgoing__wrappee__AddressBook_~tmp~13#1, outgoing__wrappee__AddressBook_~receiver~1#1, outgoing__wrappee__AddressBook_~tmp___0~5#1, outgoing__wrappee__AddressBook_~second~0#1, outgoing__wrappee__AddressBook_~tmp___1~2#1, outgoing__wrappee__AddressBook_~tmp___2~2#1;outgoing__wrappee__AddressBook_~client#1 := outgoing__wrappee__AddressBook_#in~client#1;outgoing__wrappee__AddressBook_~msg#1 := outgoing__wrappee__AddressBook_#in~msg#1;havoc outgoing__wrappee__AddressBook_~size~0#1;havoc outgoing__wrappee__AddressBook_~tmp~13#1;havoc outgoing__wrappee__AddressBook_~receiver~1#1;havoc outgoing__wrappee__AddressBook_~tmp___0~5#1;havoc outgoing__wrappee__AddressBook_~second~0#1;havoc outgoing__wrappee__AddressBook_~tmp___1~2#1;havoc outgoing__wrappee__AddressBook_~tmp___2~2#1; {413#false} is VALID [2022-02-20 18:03:34,797 INFO L272 TraceCheckUtils]: 69: Hoare triple {413#false} call outgoing__wrappee__AddressBook_#t~ret71#1 := getClientAddressBookSize(outgoing__wrappee__AddressBook_~client#1); {412#true} is VALID [2022-02-20 18:03:34,797 INFO L290 TraceCheckUtils]: 70: Hoare triple {412#true} ~handle := #in~handle;havoc ~retValue_acc~30; {412#true} is VALID [2022-02-20 18:03:34,797 INFO L290 TraceCheckUtils]: 71: Hoare triple {412#true} assume 1 == ~handle;~retValue_acc~30 := ~__ste_ClientAddressBook_size0~0;#res := ~retValue_acc~30; {412#true} is VALID [2022-02-20 18:03:34,797 INFO L290 TraceCheckUtils]: 72: Hoare triple {412#true} assume true; {412#true} is VALID [2022-02-20 18:03:34,797 INFO L284 TraceCheckUtils]: 73: Hoare quadruple {412#true} {413#false} #1152#return; {413#false} is VALID [2022-02-20 18:03:34,798 INFO L290 TraceCheckUtils]: 74: Hoare triple {413#false} assume -2147483648 <= outgoing__wrappee__AddressBook_#t~ret71#1 && outgoing__wrappee__AddressBook_#t~ret71#1 <= 2147483647;outgoing__wrappee__AddressBook_~tmp~13#1 := outgoing__wrappee__AddressBook_#t~ret71#1;havoc outgoing__wrappee__AddressBook_#t~ret71#1;outgoing__wrappee__AddressBook_~size~0#1 := outgoing__wrappee__AddressBook_~tmp~13#1; {413#false} is VALID [2022-02-20 18:03:34,798 INFO L290 TraceCheckUtils]: 75: Hoare triple {413#false} assume !(0 != outgoing__wrappee__AddressBook_~size~0#1); {413#false} is VALID [2022-02-20 18:03:34,798 INFO L272 TraceCheckUtils]: 76: Hoare triple {413#false} call outgoing__wrappee__Encrypt(outgoing__wrappee__AddressBook_~client#1, outgoing__wrappee__AddressBook_~msg#1); {413#false} is VALID [2022-02-20 18:03:34,798 INFO L290 TraceCheckUtils]: 77: Hoare triple {413#false} ~client#1 := #in~client#1;~msg#1 := #in~msg#1;havoc ~receiver~0#1;havoc ~tmp~12#1;havoc ~pubkey~0#1;havoc ~tmp___0~4#1; {413#false} is VALID [2022-02-20 18:03:34,799 INFO L272 TraceCheckUtils]: 78: Hoare triple {413#false} call #t~ret69#1 := getEmailTo(~msg#1); {412#true} is VALID [2022-02-20 18:03:34,799 INFO L290 TraceCheckUtils]: 79: Hoare triple {412#true} ~handle := #in~handle;havoc ~retValue_acc~3; {412#true} is VALID [2022-02-20 18:03:34,799 INFO L290 TraceCheckUtils]: 80: Hoare triple {412#true} assume 1 == ~handle;~retValue_acc~3 := ~__ste_email_to0~0;#res := ~retValue_acc~3; {412#true} is VALID [2022-02-20 18:03:34,799 INFO L290 TraceCheckUtils]: 81: Hoare triple {412#true} assume true; {412#true} is VALID [2022-02-20 18:03:34,799 INFO L284 TraceCheckUtils]: 82: Hoare quadruple {412#true} {413#false} #1170#return; {413#false} is VALID [2022-02-20 18:03:34,800 INFO L290 TraceCheckUtils]: 83: Hoare triple {413#false} assume -2147483648 <= #t~ret69#1 && #t~ret69#1 <= 2147483647;~tmp~12#1 := #t~ret69#1;havoc #t~ret69#1;~receiver~0#1 := ~tmp~12#1; {413#false} is VALID [2022-02-20 18:03:34,800 INFO L272 TraceCheckUtils]: 84: Hoare triple {413#false} call #t~ret70#1 := findPublicKey(~client#1, ~receiver~0#1); {412#true} is VALID [2022-02-20 18:03:34,800 INFO L290 TraceCheckUtils]: 85: Hoare triple {412#true} ~handle := #in~handle;~userid := #in~userid;havoc ~retValue_acc~41; {412#true} is VALID [2022-02-20 18:03:34,800 INFO L290 TraceCheckUtils]: 86: Hoare triple {412#true} assume 1 == ~handle; {412#true} is VALID [2022-02-20 18:03:34,800 INFO L290 TraceCheckUtils]: 87: Hoare triple {412#true} assume ~userid == ~__ste_Client_Keyring0_User0~0;~retValue_acc~41 := ~__ste_Client_Keyring0_PublicKey0~0;#res := ~retValue_acc~41; {412#true} is VALID [2022-02-20 18:03:34,801 INFO L290 TraceCheckUtils]: 88: Hoare triple {412#true} assume true; {412#true} is VALID [2022-02-20 18:03:34,801 INFO L284 TraceCheckUtils]: 89: Hoare quadruple {412#true} {413#false} #1172#return; {413#false} is VALID [2022-02-20 18:03:34,801 INFO L290 TraceCheckUtils]: 90: Hoare triple {413#false} assume -2147483648 <= #t~ret70#1 && #t~ret70#1 <= 2147483647;~tmp___0~4#1 := #t~ret70#1;havoc #t~ret70#1;~pubkey~0#1 := ~tmp___0~4#1; {413#false} is VALID [2022-02-20 18:03:34,801 INFO L290 TraceCheckUtils]: 91: Hoare triple {413#false} assume !(0 != ~pubkey~0#1); {413#false} is VALID [2022-02-20 18:03:34,802 INFO L290 TraceCheckUtils]: 92: Hoare triple {413#false} assume { :begin_inline_outgoing__wrappee__Keys } true;outgoing__wrappee__Keys_#in~client#1, outgoing__wrappee__Keys_#in~msg#1 := ~client#1, ~msg#1;havoc outgoing__wrappee__Keys_#t~ret68#1, outgoing__wrappee__Keys_~client#1, outgoing__wrappee__Keys_~msg#1, outgoing__wrappee__Keys_~tmp~11#1;outgoing__wrappee__Keys_~client#1 := outgoing__wrappee__Keys_#in~client#1;outgoing__wrappee__Keys_~msg#1 := outgoing__wrappee__Keys_#in~msg#1;havoc outgoing__wrappee__Keys_~tmp~11#1;assume { :begin_inline_getClientId } true;getClientId_#in~handle#1 := outgoing__wrappee__Keys_~client#1;havoc getClientId_#res#1;havoc getClientId_~handle#1, getClientId_~retValue_acc~43#1;getClientId_~handle#1 := getClientId_#in~handle#1;havoc getClientId_~retValue_acc~43#1; {413#false} is VALID [2022-02-20 18:03:34,802 INFO L290 TraceCheckUtils]: 93: Hoare triple {413#false} assume 1 == getClientId_~handle#1;getClientId_~retValue_acc~43#1 := ~__ste_client_idCounter0~0;getClientId_#res#1 := getClientId_~retValue_acc~43#1; {413#false} is VALID [2022-02-20 18:03:34,802 INFO L290 TraceCheckUtils]: 94: Hoare triple {413#false} outgoing__wrappee__Keys_#t~ret68#1 := getClientId_#res#1;assume { :end_inline_getClientId } true;assume -2147483648 <= outgoing__wrappee__Keys_#t~ret68#1 && outgoing__wrappee__Keys_#t~ret68#1 <= 2147483647;outgoing__wrappee__Keys_~tmp~11#1 := outgoing__wrappee__Keys_#t~ret68#1;havoc outgoing__wrappee__Keys_#t~ret68#1; {413#false} is VALID [2022-02-20 18:03:34,802 INFO L272 TraceCheckUtils]: 95: Hoare triple {413#false} call setEmailFrom(outgoing__wrappee__Keys_~msg#1, outgoing__wrappee__Keys_~tmp~11#1); {476#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} is VALID [2022-02-20 18:03:34,826 INFO L290 TraceCheckUtils]: 96: Hoare triple {476#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} ~handle := #in~handle;~value := #in~value; {412#true} is VALID [2022-02-20 18:03:34,826 INFO L290 TraceCheckUtils]: 97: Hoare triple {412#true} assume 1 == ~handle;~__ste_email_from0~0 := ~value; {412#true} is VALID [2022-02-20 18:03:34,826 INFO L290 TraceCheckUtils]: 98: Hoare triple {412#true} assume true; {412#true} is VALID [2022-02-20 18:03:34,827 INFO L284 TraceCheckUtils]: 99: Hoare quadruple {412#true} {413#false} #1178#return; {413#false} is VALID [2022-02-20 18:03:34,827 INFO L290 TraceCheckUtils]: 100: Hoare triple {413#false} assume { :begin_inline_mail } true;mail_#in~client#1, mail_#in~msg#1 := outgoing__wrappee__Keys_~client#1, outgoing__wrappee__Keys_~msg#1;havoc mail_#t~ret66#1, mail_#t~ret67#1, mail_~client#1, mail_~msg#1, mail_~__utac__ad__arg1~0#1, mail_~tmp~10#1;mail_~client#1 := mail_#in~client#1;mail_~msg#1 := mail_#in~msg#1;havoc mail_~__utac__ad__arg1~0#1;havoc mail_~tmp~10#1;mail_~__utac__ad__arg1~0#1 := mail_~msg#1;assume { :begin_inline___utac_acc__EncryptAutoResponder_spec__2 } true;__utac_acc__EncryptAutoResponder_spec__2_#in~msg#1 := mail_~__utac__ad__arg1~0#1;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1, __utac_acc__EncryptAutoResponder_spec__2_#t~nondet29#1, __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1, __utac_acc__EncryptAutoResponder_spec__2_~msg#1, __utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.base, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.offset;__utac_acc__EncryptAutoResponder_spec__2_~msg#1 := __utac_acc__EncryptAutoResponder_spec__2_#in~msg#1;havoc __utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1;havoc __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.base, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.offset;call __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1 := puts(15, 0);assume -2147483648 <= __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1 && __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1 <= 2147483647;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1;__utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.base, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.offset := 16, 0;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~nondet29#1; {413#false} is VALID [2022-02-20 18:03:34,827 INFO L290 TraceCheckUtils]: 101: Hoare triple {413#false} assume 0 != ~in_encrypted~0; {413#false} is VALID [2022-02-20 18:03:34,827 INFO L272 TraceCheckUtils]: 102: Hoare triple {413#false} call __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1 := isEncrypted(__utac_acc__EncryptAutoResponder_spec__2_~msg#1); {412#true} is VALID [2022-02-20 18:03:34,828 INFO L290 TraceCheckUtils]: 103: Hoare triple {412#true} ~handle := #in~handle;havoc ~retValue_acc~6; {412#true} is VALID [2022-02-20 18:03:34,828 INFO L290 TraceCheckUtils]: 104: Hoare triple {412#true} assume 1 == ~handle;~retValue_acc~6 := ~__ste_email_isEncrypted0~0;#res := ~retValue_acc~6; {412#true} is VALID [2022-02-20 18:03:34,828 INFO L290 TraceCheckUtils]: 105: Hoare triple {412#true} assume true; {412#true} is VALID [2022-02-20 18:03:34,828 INFO L284 TraceCheckUtils]: 106: Hoare quadruple {412#true} {413#false} #1180#return; {413#false} is VALID [2022-02-20 18:03:34,828 INFO L290 TraceCheckUtils]: 107: Hoare triple {413#false} assume -2147483648 <= __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1 && __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1 <= 2147483647;__utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1 := __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1; {413#false} is VALID [2022-02-20 18:03:34,829 INFO L290 TraceCheckUtils]: 108: Hoare triple {413#false} assume !(0 != __utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1);assume { :begin_inline___automaton_fail } true; {413#false} is VALID [2022-02-20 18:03:34,829 INFO L290 TraceCheckUtils]: 109: Hoare triple {413#false} assume !false; {413#false} is VALID [2022-02-20 18:03:34,830 INFO L134 CoverageAnalysis]: Checked inductivity of 28 backedges. 3 proven. 3 refuted. 0 times theorem prover too weak. 22 trivial. 0 not checked. [2022-02-20 18:03:34,830 INFO L144 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-02-20 18:03:34,830 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [370835179] [2022-02-20 18:03:34,831 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleSmtInterpolCraig [370835179] provided 0 perfect and 1 imperfect interpolant sequences [2022-02-20 18:03:34,831 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [426858502] [2022-02-20 18:03:34,832 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 18:03:34,832 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-02-20 18:03:34,832 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-02-20 18:03:34,843 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 18:03:34,915 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 18:03:35,192 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:35,198 INFO L263 TraceCheckSpWp]: Trace formula consists of 1110 conjuncts, 1 conjunts are in the unsatisfiable core [2022-02-20 18:03:35,255 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:35,262 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-02-20 18:03:35,491 INFO L290 TraceCheckUtils]: 0: Hoare triple {412#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(28, 2);call #Ultimate.allocInit(12, 3);call #Ultimate.allocInit(10, 4);call #Ultimate.allocInit(12, 5);call #Ultimate.allocInit(10, 6);call #Ultimate.allocInit(18, 7);call #Ultimate.allocInit(16, 8);call #Ultimate.allocInit(21, 9);call #Ultimate.allocInit(13, 10);call #Ultimate.allocInit(16, 11);call #Ultimate.allocInit(25, 12);call #Ultimate.allocInit(17, 13);call #Ultimate.allocInit(17, 14);call #Ultimate.allocInit(13, 15);call #Ultimate.allocInit(17, 16);call #Ultimate.allocInit(30, 17);call #Ultimate.allocInit(9, 18);call #Ultimate.allocInit(21, 19);call #Ultimate.allocInit(30, 20);call #Ultimate.allocInit(9, 21);call #Ultimate.allocInit(21, 22);call #Ultimate.allocInit(30, 23);call #Ultimate.allocInit(9, 24);call #Ultimate.allocInit(25, 25);call #Ultimate.allocInit(30, 26);call #Ultimate.allocInit(9, 27);call #Ultimate.allocInit(25, 28);call #Ultimate.allocInit(4, 29);call write~init~int(37, 29, 0, 1);call write~init~int(115, 29, 1, 1);call write~init~int(10, 29, 2, 1);call write~init~int(0, 29, 3, 1);call #Ultimate.allocInit(10, 30);call #Ultimate.allocInit(34, 31);call #Ultimate.allocInit(30, 32);call #Ultimate.allocInit(16, 33);call #Ultimate.allocInit(20, 34);call #Ultimate.allocInit(44, 35);call #Ultimate.allocInit(44, 36);call #Ultimate.allocInit(9, 37);call #Ultimate.allocInit(9, 38);call #Ultimate.allocInit(11, 39);call #Ultimate.allocInit(19, 40);call #Ultimate.allocInit(4, 41);call write~init~int(37, 41, 0, 1);call write~init~int(100, 41, 1, 1);call write~init~int(10, 41, 2, 1);call write~init~int(0, 41, 3, 1);call #Ultimate.allocInit(4, 42);call write~init~int(37, 42, 0, 1);call write~init~int(100, 42, 1, 1);call write~init~int(10, 42, 2, 1);call write~init~int(0, 42, 3, 1);~__ste_Email_counter~0 := 0;~__ste_email_id0~0 := 0;~__ste_email_id1~0 := 0;~__ste_email_from0~0 := 0;~__ste_email_from1~0 := 0;~__ste_email_to0~0 := 0;~__ste_email_to1~0 := 0;~__ste_email_subject0~0.base, ~__ste_email_subject0~0.offset := 0, 0;~__ste_email_subject1~0.base, ~__ste_email_subject1~0.offset := 0, 0;~__ste_email_body0~0.base, ~__ste_email_body0~0.offset := 0, 0;~__ste_email_body1~0.base, ~__ste_email_body1~0.offset := 0, 0;~__ste_email_isEncrypted0~0 := 0;~__ste_email_isEncrypted1~0 := 0;~__ste_email_encryptionKey0~0 := 0;~__ste_email_encryptionKey1~0 := 0;~__ste_email_isSigned0~0 := 0;~__ste_email_isSigned1~0 := 0;~__ste_email_signKey0~0 := 0;~__ste_email_signKey1~0 := 0;~__ste_email_isSignatureVerified0~0 := 0;~__ste_email_isSignatureVerified1~0 := 0;~__SELECTED_FEATURE_Base~0 := 0;~__SELECTED_FEATURE_Keys~0 := 0;~__SELECTED_FEATURE_Encrypt~0 := 0;~__SELECTED_FEATURE_AutoResponder~0 := 0;~__SELECTED_FEATURE_AddressBook~0 := 0;~__SELECTED_FEATURE_Sign~0 := 0;~__SELECTED_FEATURE_Forward~0 := 0;~__SELECTED_FEATURE_Verify~0 := 0;~__SELECTED_FEATURE_Decrypt~0 := 0;~__GUIDSL_ROOT_PRODUCTION~0 := 0;~__GUIDSL_NON_TERMINAL_main~0 := 0;~in_encrypted~0 := 0;~head~0.base, ~head~0.offset := 0, 0;~queue_empty~0 := 1;~queued_message~0 := 0;~queued_client~0 := 0;~bob~0 := 0;~rjh~0 := 0;~chuck~0 := 0;~__ste_Client_counter~0 := 0;~__ste_client_name0~0.base, ~__ste_client_name0~0.offset := 0, 0;~__ste_client_name1~0.base, ~__ste_client_name1~0.offset := 0, 0;~__ste_client_name2~0.base, ~__ste_client_name2~0.offset := 0, 0;~__ste_client_outbuffer0~0 := 0;~__ste_client_outbuffer1~0 := 0;~__ste_client_outbuffer2~0 := 0;~__ste_client_outbuffer3~0 := 0;~__ste_ClientAddressBook_size0~0 := 0;~__ste_ClientAddressBook_size1~0 := 0;~__ste_ClientAddressBook_size2~0 := 0;~__ste_Client_AddressBook0_Alias0~0 := 0;~__ste_Client_AddressBook0_Alias1~0 := 0;~__ste_Client_AddressBook0_Alias2~0 := 0;~__ste_Client_AddressBook1_Alias0~0 := 0;~__ste_Client_AddressBook1_Alias1~0 := 0;~__ste_Client_AddressBook1_Alias2~0 := 0;~__ste_Client_AddressBook2_Alias0~0 := 0;~__ste_Client_AddressBook2_Alias1~0 := 0;~__ste_Client_AddressBook2_Alias2~0 := 0;~__ste_Client_AddressBook0_Address0~0 := 0;~__ste_Client_AddressBook0_Address1~0 := 0;~__ste_Client_AddressBook0_Address2~0 := 0;~__ste_Client_AddressBook1_Address0~0 := 0;~__ste_Client_AddressBook1_Address1~0 := 0;~__ste_Client_AddressBook1_Address2~0 := 0;~__ste_Client_AddressBook2_Address0~0 := 0;~__ste_Client_AddressBook2_Address1~0 := 0;~__ste_Client_AddressBook2_Address2~0 := 0;~__ste_client_autoResponse0~0 := 0;~__ste_client_autoResponse1~0 := 0;~__ste_client_autoResponse2~0 := 0;~__ste_client_privateKey0~0 := 0;~__ste_client_privateKey1~0 := 0;~__ste_client_privateKey2~0 := 0;~__ste_ClientKeyring_size0~0 := 0;~__ste_ClientKeyring_size1~0 := 0;~__ste_ClientKeyring_size2~0 := 0;~__ste_Client_Keyring0_User0~0 := 0;~__ste_Client_Keyring0_User1~0 := 0;~__ste_Client_Keyring0_User2~0 := 0;~__ste_Client_Keyring1_User0~0 := 0;~__ste_Client_Keyring1_User1~0 := 0;~__ste_Client_Keyring1_User2~0 := 0;~__ste_Client_Keyring2_User0~0 := 0;~__ste_Client_Keyring2_User1~0 := 0;~__ste_Client_Keyring2_User2~0 := 0;~__ste_Client_Keyring0_PublicKey0~0 := 0;~__ste_Client_Keyring0_PublicKey1~0 := 0;~__ste_Client_Keyring0_PublicKey2~0 := 0;~__ste_Client_Keyring1_PublicKey0~0 := 0;~__ste_Client_Keyring1_PublicKey1~0 := 0;~__ste_Client_Keyring1_PublicKey2~0 := 0;~__ste_Client_Keyring2_PublicKey0~0 := 0;~__ste_Client_Keyring2_PublicKey1~0 := 0;~__ste_Client_Keyring2_PublicKey2~0 := 0;~__ste_client_forwardReceiver0~0 := 0;~__ste_client_forwardReceiver1~0 := 0;~__ste_client_forwardReceiver2~0 := 0;~__ste_client_forwardReceiver3~0 := 0;~__ste_client_idCounter0~0 := 0;~__ste_client_idCounter1~0 := 0;~__ste_client_idCounter2~0 := 0; {412#true} is VALID [2022-02-20 18:03:35,492 INFO L290 TraceCheckUtils]: 1: Hoare triple {412#true} assume { :end_inline_ULTIMATE.init } true;assume { :begin_inline_main } true;havoc main_#res#1;havoc main_#t~nondet100#1, main_#t~ret101#1, main_~retValue_acc~26#1, main_~tmp~20#1;assume -2147483648 <= main_#t~nondet100#1 && main_#t~nondet100#1 <= 2147483647;main_~retValue_acc~26#1 := main_#t~nondet100#1;havoc main_#t~nondet100#1;havoc main_~tmp~20#1;assume { :begin_inline_select_helpers } true; {412#true} is VALID [2022-02-20 18:03:35,492 INFO L290 TraceCheckUtils]: 2: Hoare triple {412#true} assume { :end_inline_select_helpers } true;assume { :begin_inline_select_features } true; {412#true} is VALID [2022-02-20 18:03:35,492 INFO L290 TraceCheckUtils]: 3: Hoare triple {412#true} assume { :end_inline_select_features } true;assume { :begin_inline_valid_product } true;havoc valid_product_#res#1;havoc valid_product_~retValue_acc~12#1;havoc valid_product_~retValue_acc~12#1;valid_product_~retValue_acc~12#1 := 1;valid_product_#res#1 := valid_product_~retValue_acc~12#1; {412#true} is VALID [2022-02-20 18:03:35,493 INFO L290 TraceCheckUtils]: 4: Hoare triple {412#true} main_#t~ret101#1 := valid_product_#res#1;assume { :end_inline_valid_product } true;assume -2147483648 <= main_#t~ret101#1 && main_#t~ret101#1 <= 2147483647;main_~tmp~20#1 := main_#t~ret101#1;havoc main_#t~ret101#1; {412#true} is VALID [2022-02-20 18:03:35,493 INFO L290 TraceCheckUtils]: 5: Hoare triple {412#true} assume 0 != main_~tmp~20#1;assume { :begin_inline_setup } true;havoc setup_#t~nondet97#1, setup_#t~nondet98#1, setup_#t~nondet99#1, setup_~__cil_tmp1~0#1.base, setup_~__cil_tmp1~0#1.offset, setup_~__cil_tmp2~1#1.base, setup_~__cil_tmp2~1#1.offset, setup_~__cil_tmp3~4#1.base, setup_~__cil_tmp3~4#1.offset;havoc setup_~__cil_tmp1~0#1.base, setup_~__cil_tmp1~0#1.offset;havoc setup_~__cil_tmp2~1#1.base, setup_~__cil_tmp2~1#1.offset;havoc setup_~__cil_tmp3~4#1.base, setup_~__cil_tmp3~4#1.offset;~bob~0 := 1;assume { :begin_inline_setup_bob } true;setup_bob_#in~bob___0#1 := ~bob~0;havoc setup_bob_~bob___0#1;setup_bob_~bob___0#1 := setup_bob_#in~bob___0#1;assume { :begin_inline_setup_bob__wrappee__Base } true;setup_bob__wrappee__Base_#in~bob___0#1 := setup_bob_~bob___0#1;havoc setup_bob__wrappee__Base_~bob___0#1;setup_bob__wrappee__Base_~bob___0#1 := setup_bob__wrappee__Base_#in~bob___0#1; {412#true} is VALID [2022-02-20 18:03:35,493 INFO L272 TraceCheckUtils]: 6: Hoare triple {412#true} call setClientId(setup_bob__wrappee__Base_~bob___0#1, setup_bob__wrappee__Base_~bob___0#1); {412#true} is VALID [2022-02-20 18:03:35,493 INFO L290 TraceCheckUtils]: 7: Hoare triple {412#true} ~handle := #in~handle;~value := #in~value; {412#true} is VALID [2022-02-20 18:03:35,493 INFO L290 TraceCheckUtils]: 8: Hoare triple {412#true} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {412#true} is VALID [2022-02-20 18:03:35,494 INFO L290 TraceCheckUtils]: 9: Hoare triple {412#true} assume true; {412#true} is VALID [2022-02-20 18:03:35,494 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {412#true} {412#true} #1224#return; {412#true} is VALID [2022-02-20 18:03:35,494 INFO L290 TraceCheckUtils]: 11: Hoare triple {412#true} assume { :end_inline_setup_bob__wrappee__Base } true; {412#true} is VALID [2022-02-20 18:03:35,494 INFO L272 TraceCheckUtils]: 12: Hoare triple {412#true} call setClientPrivateKey(setup_bob_~bob___0#1, 123); {412#true} is VALID [2022-02-20 18:03:35,494 INFO L290 TraceCheckUtils]: 13: Hoare triple {412#true} ~handle := #in~handle;~value := #in~value; {412#true} is VALID [2022-02-20 18:03:35,494 INFO L290 TraceCheckUtils]: 14: Hoare triple {412#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {412#true} is VALID [2022-02-20 18:03:35,495 INFO L290 TraceCheckUtils]: 15: Hoare triple {412#true} assume true; {412#true} is VALID [2022-02-20 18:03:35,495 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {412#true} {412#true} #1226#return; {412#true} is VALID [2022-02-20 18:03:35,495 INFO L290 TraceCheckUtils]: 17: Hoare triple {412#true} assume { :end_inline_setup_bob } true;setup_~__cil_tmp1~0#1.base, setup_~__cil_tmp1~0#1.offset := 37, 0;havoc setup_#t~nondet97#1;~rjh~0 := 2;assume { :begin_inline_setup_rjh } true;setup_rjh_#in~rjh___0#1 := ~rjh~0;havoc setup_rjh_~rjh___0#1;setup_rjh_~rjh___0#1 := setup_rjh_#in~rjh___0#1;assume { :begin_inline_setup_rjh__wrappee__Base } true;setup_rjh__wrappee__Base_#in~rjh___0#1 := setup_rjh_~rjh___0#1;havoc setup_rjh__wrappee__Base_~rjh___0#1;setup_rjh__wrappee__Base_~rjh___0#1 := setup_rjh__wrappee__Base_#in~rjh___0#1; {412#true} is VALID [2022-02-20 18:03:35,495 INFO L272 TraceCheckUtils]: 18: Hoare triple {412#true} call setClientId(setup_rjh__wrappee__Base_~rjh___0#1, setup_rjh__wrappee__Base_~rjh___0#1); {412#true} is VALID [2022-02-20 18:03:35,496 INFO L290 TraceCheckUtils]: 19: Hoare triple {412#true} ~handle := #in~handle;~value := #in~value; {412#true} is VALID [2022-02-20 18:03:35,496 INFO L290 TraceCheckUtils]: 20: Hoare triple {412#true} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {412#true} is VALID [2022-02-20 18:03:35,496 INFO L290 TraceCheckUtils]: 21: Hoare triple {412#true} assume true; {412#true} is VALID [2022-02-20 18:03:35,496 INFO L284 TraceCheckUtils]: 22: Hoare quadruple {412#true} {412#true} #1228#return; {412#true} is VALID [2022-02-20 18:03:35,496 INFO L290 TraceCheckUtils]: 23: Hoare triple {412#true} assume { :end_inline_setup_rjh__wrappee__Base } true; {412#true} is VALID [2022-02-20 18:03:35,496 INFO L272 TraceCheckUtils]: 24: Hoare triple {412#true} call setClientPrivateKey(setup_rjh_~rjh___0#1, 456); {412#true} is VALID [2022-02-20 18:03:35,497 INFO L290 TraceCheckUtils]: 25: Hoare triple {412#true} ~handle := #in~handle;~value := #in~value; {412#true} is VALID [2022-02-20 18:03:35,497 INFO L290 TraceCheckUtils]: 26: Hoare triple {412#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {412#true} is VALID [2022-02-20 18:03:35,497 INFO L290 TraceCheckUtils]: 27: Hoare triple {412#true} assume true; {412#true} is VALID [2022-02-20 18:03:35,497 INFO L284 TraceCheckUtils]: 28: Hoare quadruple {412#true} {412#true} #1230#return; {412#true} is VALID [2022-02-20 18:03:35,497 INFO L290 TraceCheckUtils]: 29: Hoare triple {412#true} assume { :end_inline_setup_rjh } true;setup_~__cil_tmp2~1#1.base, setup_~__cil_tmp2~1#1.offset := 38, 0;havoc setup_#t~nondet98#1;~chuck~0 := 3;assume { :begin_inline_setup_chuck } true;setup_chuck_#in~chuck___0#1 := ~chuck~0;havoc setup_chuck_~chuck___0#1;setup_chuck_~chuck___0#1 := setup_chuck_#in~chuck___0#1;assume { :begin_inline_setup_chuck__wrappee__Base } true;setup_chuck__wrappee__Base_#in~chuck___0#1 := setup_chuck_~chuck___0#1;havoc setup_chuck__wrappee__Base_~chuck___0#1;setup_chuck__wrappee__Base_~chuck___0#1 := setup_chuck__wrappee__Base_#in~chuck___0#1; {412#true} is VALID [2022-02-20 18:03:35,498 INFO L272 TraceCheckUtils]: 30: Hoare triple {412#true} call setClientId(setup_chuck__wrappee__Base_~chuck___0#1, setup_chuck__wrappee__Base_~chuck___0#1); {412#true} is VALID [2022-02-20 18:03:35,498 INFO L290 TraceCheckUtils]: 31: Hoare triple {412#true} ~handle := #in~handle;~value := #in~value; {412#true} is VALID [2022-02-20 18:03:35,498 INFO L290 TraceCheckUtils]: 32: Hoare triple {412#true} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {412#true} is VALID [2022-02-20 18:03:35,498 INFO L290 TraceCheckUtils]: 33: Hoare triple {412#true} assume true; {412#true} is VALID [2022-02-20 18:03:35,498 INFO L284 TraceCheckUtils]: 34: Hoare quadruple {412#true} {412#true} #1232#return; {412#true} is VALID [2022-02-20 18:03:35,499 INFO L290 TraceCheckUtils]: 35: Hoare triple {412#true} assume { :end_inline_setup_chuck__wrappee__Base } true; {412#true} is VALID [2022-02-20 18:03:35,499 INFO L272 TraceCheckUtils]: 36: Hoare triple {412#true} call setClientPrivateKey(setup_chuck_~chuck___0#1, 789); {412#true} is VALID [2022-02-20 18:03:35,499 INFO L290 TraceCheckUtils]: 37: Hoare triple {412#true} ~handle := #in~handle;~value := #in~value; {412#true} is VALID [2022-02-20 18:03:35,499 INFO L290 TraceCheckUtils]: 38: Hoare triple {412#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {412#true} is VALID [2022-02-20 18:03:35,499 INFO L290 TraceCheckUtils]: 39: Hoare triple {412#true} assume true; {412#true} is VALID [2022-02-20 18:03:35,500 INFO L284 TraceCheckUtils]: 40: Hoare quadruple {412#true} {412#true} #1234#return; {412#true} is VALID [2022-02-20 18:03:35,500 INFO L290 TraceCheckUtils]: 41: Hoare triple {412#true} assume { :end_inline_setup_chuck } true;setup_~__cil_tmp3~4#1.base, setup_~__cil_tmp3~4#1.offset := 39, 0;havoc setup_#t~nondet99#1; {412#true} is VALID [2022-02-20 18:03:35,500 INFO L290 TraceCheckUtils]: 42: Hoare triple {412#true} assume { :end_inline_setup } true;assume { :begin_inline_test } true;havoc test_#t~nondet55#1, test_#t~nondet56#1, test_#t~nondet57#1, test_#t~nondet58#1, test_#t~nondet59#1, test_#t~nondet60#1, test_#t~nondet61#1, test_#t~nondet62#1, test_#t~nondet63#1, test_#t~nondet64#1, test_#t~nondet65#1, test_~op1~0#1, test_~op2~0#1, test_~op3~0#1, test_~op4~0#1, test_~op5~0#1, test_~op6~0#1, test_~op7~0#1, test_~op8~0#1, test_~op9~0#1, test_~op10~0#1, test_~op11~0#1, test_~splverifierCounter~0#1, test_~tmp~9#1, test_~tmp___0~3#1, test_~tmp___1~1#1, test_~tmp___2~1#1, test_~tmp___3~0#1, test_~tmp___4~0#1, test_~tmp___5~0#1, test_~tmp___6~0#1, test_~tmp___7~0#1, test_~tmp___8~0#1, test_~tmp___9~0#1;havoc test_~op1~0#1;havoc test_~op2~0#1;havoc test_~op3~0#1;havoc test_~op4~0#1;havoc test_~op5~0#1;havoc test_~op6~0#1;havoc test_~op7~0#1;havoc test_~op8~0#1;havoc test_~op9~0#1;havoc test_~op10~0#1;havoc test_~op11~0#1;havoc test_~splverifierCounter~0#1;havoc test_~tmp~9#1;havoc test_~tmp___0~3#1;havoc test_~tmp___1~1#1;havoc test_~tmp___2~1#1;havoc test_~tmp___3~0#1;havoc test_~tmp___4~0#1;havoc test_~tmp___5~0#1;havoc test_~tmp___6~0#1;havoc test_~tmp___7~0#1;havoc test_~tmp___8~0#1;havoc test_~tmp___9~0#1;test_~op1~0#1 := 0;test_~op2~0#1 := 0;test_~op3~0#1 := 0;test_~op4~0#1 := 0;test_~op5~0#1 := 0;test_~op6~0#1 := 0;test_~op7~0#1 := 0;test_~op8~0#1 := 0;test_~op9~0#1 := 0;test_~op10~0#1 := 0;test_~op11~0#1 := 0;test_~splverifierCounter~0#1 := 0; {412#true} is VALID [2022-02-20 18:03:35,501 INFO L290 TraceCheckUtils]: 43: Hoare triple {412#true} assume false; {413#false} is VALID [2022-02-20 18:03:35,501 INFO L290 TraceCheckUtils]: 44: Hoare triple {413#false} assume { :begin_inline_bobToRjh } true;havoc bobToRjh_#t~ret92#1, bobToRjh_#t~ret93#1, bobToRjh_#t~ret94#1, bobToRjh_#t~ret95#1, bobToRjh_~tmp~19#1, bobToRjh_~tmp___0~8#1, bobToRjh_~tmp___1~5#1;havoc bobToRjh_~tmp~19#1;havoc bobToRjh_~tmp___0~8#1;havoc bobToRjh_~tmp___1~5#1;call bobToRjh_#t~ret92#1 := puts(35, 0);assume -2147483648 <= bobToRjh_#t~ret92#1 && bobToRjh_#t~ret92#1 <= 2147483647;havoc bobToRjh_#t~ret92#1; {413#false} is VALID [2022-02-20 18:03:35,501 INFO L272 TraceCheckUtils]: 45: Hoare triple {413#false} call sendEmail(~bob~0, ~rjh~0); {413#false} is VALID [2022-02-20 18:03:35,501 INFO L290 TraceCheckUtils]: 46: Hoare triple {413#false} ~sender#1 := #in~sender#1;~receiver#1 := #in~receiver#1;havoc ~email~0#1;havoc ~tmp~16#1;assume { :begin_inline_createEmail } true;createEmail_#in~from#1, createEmail_#in~to#1 := 0, ~receiver#1;havoc createEmail_#res#1;havoc createEmail_~from#1, createEmail_~to#1, createEmail_~retValue_acc~16#1, createEmail_~msg~0#1;createEmail_~from#1 := createEmail_#in~from#1;createEmail_~to#1 := createEmail_#in~to#1;havoc createEmail_~retValue_acc~16#1;havoc createEmail_~msg~0#1;createEmail_~msg~0#1 := 1; {413#false} is VALID [2022-02-20 18:03:35,502 INFO L272 TraceCheckUtils]: 47: Hoare triple {413#false} call setEmailFrom(createEmail_~msg~0#1, createEmail_~from#1); {413#false} is VALID [2022-02-20 18:03:35,502 INFO L290 TraceCheckUtils]: 48: Hoare triple {413#false} ~handle := #in~handle;~value := #in~value; {413#false} is VALID [2022-02-20 18:03:35,502 INFO L290 TraceCheckUtils]: 49: Hoare triple {413#false} assume 1 == ~handle;~__ste_email_from0~0 := ~value; {413#false} is VALID [2022-02-20 18:03:35,502 INFO L290 TraceCheckUtils]: 50: Hoare triple {413#false} assume true; {413#false} is VALID [2022-02-20 18:03:35,502 INFO L284 TraceCheckUtils]: 51: Hoare quadruple {413#false} {413#false} #1210#return; {413#false} is VALID [2022-02-20 18:03:35,502 INFO L272 TraceCheckUtils]: 52: Hoare triple {413#false} call setEmailTo(createEmail_~msg~0#1, createEmail_~to#1); {413#false} is VALID [2022-02-20 18:03:35,503 INFO L290 TraceCheckUtils]: 53: Hoare triple {413#false} ~handle := #in~handle;~value := #in~value; {413#false} is VALID [2022-02-20 18:03:35,503 INFO L290 TraceCheckUtils]: 54: Hoare triple {413#false} assume 1 == ~handle;~__ste_email_to0~0 := ~value; {413#false} is VALID [2022-02-20 18:03:35,503 INFO L290 TraceCheckUtils]: 55: Hoare triple {413#false} assume true; {413#false} is VALID [2022-02-20 18:03:35,503 INFO L284 TraceCheckUtils]: 56: Hoare quadruple {413#false} {413#false} #1212#return; {413#false} is VALID [2022-02-20 18:03:35,503 INFO L290 TraceCheckUtils]: 57: Hoare triple {413#false} createEmail_~retValue_acc~16#1 := createEmail_~msg~0#1;createEmail_#res#1 := createEmail_~retValue_acc~16#1; {413#false} is VALID [2022-02-20 18:03:35,504 INFO L290 TraceCheckUtils]: 58: Hoare triple {413#false} #t~ret83#1 := createEmail_#res#1;assume { :end_inline_createEmail } true;assume -2147483648 <= #t~ret83#1 && #t~ret83#1 <= 2147483647;~tmp~16#1 := #t~ret83#1;havoc #t~ret83#1;~email~0#1 := ~tmp~16#1; {413#false} is VALID [2022-02-20 18:03:35,504 INFO L272 TraceCheckUtils]: 59: Hoare triple {413#false} call outgoing(~sender#1, ~email~0#1); {413#false} is VALID [2022-02-20 18:03:35,504 INFO L290 TraceCheckUtils]: 60: Hoare triple {413#false} ~client#1 := #in~client#1;~msg#1 := #in~msg#1;assume { :begin_inline_sign } true;sign_#in~client#1, sign_#in~msg#1 := ~client#1, ~msg#1;havoc sign_#t~ret85#1, sign_~client#1, sign_~msg#1, sign_~privkey~1#1, sign_~tmp~17#1;sign_~client#1 := sign_#in~client#1;sign_~msg#1 := sign_#in~msg#1;havoc sign_~privkey~1#1;havoc sign_~tmp~17#1; {413#false} is VALID [2022-02-20 18:03:35,504 INFO L272 TraceCheckUtils]: 61: Hoare triple {413#false} call sign_#t~ret85#1 := getClientPrivateKey(sign_~client#1); {413#false} is VALID [2022-02-20 18:03:35,504 INFO L290 TraceCheckUtils]: 62: Hoare triple {413#false} ~handle := #in~handle;havoc ~retValue_acc~36; {413#false} is VALID [2022-02-20 18:03:35,505 INFO L290 TraceCheckUtils]: 63: Hoare triple {413#false} assume 1 == ~handle;~retValue_acc~36 := ~__ste_client_privateKey0~0;#res := ~retValue_acc~36; {413#false} is VALID [2022-02-20 18:03:35,505 INFO L290 TraceCheckUtils]: 64: Hoare triple {413#false} assume true; {413#false} is VALID [2022-02-20 18:03:35,505 INFO L284 TraceCheckUtils]: 65: Hoare quadruple {413#false} {413#false} #1150#return; {413#false} is VALID [2022-02-20 18:03:35,505 INFO L290 TraceCheckUtils]: 66: Hoare triple {413#false} assume -2147483648 <= sign_#t~ret85#1 && sign_#t~ret85#1 <= 2147483647;sign_~tmp~17#1 := sign_#t~ret85#1;havoc sign_#t~ret85#1;sign_~privkey~1#1 := sign_~tmp~17#1; {413#false} is VALID [2022-02-20 18:03:35,505 INFO L290 TraceCheckUtils]: 67: Hoare triple {413#false} assume 0 == sign_~privkey~1#1; {413#false} is VALID [2022-02-20 18:03:35,505 INFO L290 TraceCheckUtils]: 68: Hoare triple {413#false} assume { :end_inline_sign } true;assume { :begin_inline_outgoing__wrappee__AddressBook } true;outgoing__wrappee__AddressBook_#in~client#1, outgoing__wrappee__AddressBook_#in~msg#1 := ~client#1, ~msg#1;havoc outgoing__wrappee__AddressBook_#t~ret71#1, outgoing__wrappee__AddressBook_#t~ret72#1, outgoing__wrappee__AddressBook_#t~ret73#1, outgoing__wrappee__AddressBook_#t~ret74#1, outgoing__wrappee__AddressBook_#t~ret75#1, outgoing__wrappee__AddressBook_#t~ret76#1, outgoing__wrappee__AddressBook_~client#1, outgoing__wrappee__AddressBook_~msg#1, outgoing__wrappee__AddressBook_~size~0#1, outgoing__wrappee__AddressBook_~tmp~13#1, outgoing__wrappee__AddressBook_~receiver~1#1, outgoing__wrappee__AddressBook_~tmp___0~5#1, outgoing__wrappee__AddressBook_~second~0#1, outgoing__wrappee__AddressBook_~tmp___1~2#1, outgoing__wrappee__AddressBook_~tmp___2~2#1;outgoing__wrappee__AddressBook_~client#1 := outgoing__wrappee__AddressBook_#in~client#1;outgoing__wrappee__AddressBook_~msg#1 := outgoing__wrappee__AddressBook_#in~msg#1;havoc outgoing__wrappee__AddressBook_~size~0#1;havoc outgoing__wrappee__AddressBook_~tmp~13#1;havoc outgoing__wrappee__AddressBook_~receiver~1#1;havoc outgoing__wrappee__AddressBook_~tmp___0~5#1;havoc outgoing__wrappee__AddressBook_~second~0#1;havoc outgoing__wrappee__AddressBook_~tmp___1~2#1;havoc outgoing__wrappee__AddressBook_~tmp___2~2#1; {413#false} is VALID [2022-02-20 18:03:35,506 INFO L272 TraceCheckUtils]: 69: Hoare triple {413#false} call outgoing__wrappee__AddressBook_#t~ret71#1 := getClientAddressBookSize(outgoing__wrappee__AddressBook_~client#1); {413#false} is VALID [2022-02-20 18:03:35,506 INFO L290 TraceCheckUtils]: 70: Hoare triple {413#false} ~handle := #in~handle;havoc ~retValue_acc~30; {413#false} is VALID [2022-02-20 18:03:35,506 INFO L290 TraceCheckUtils]: 71: Hoare triple {413#false} assume 1 == ~handle;~retValue_acc~30 := ~__ste_ClientAddressBook_size0~0;#res := ~retValue_acc~30; {413#false} is VALID [2022-02-20 18:03:35,506 INFO L290 TraceCheckUtils]: 72: Hoare triple {413#false} assume true; {413#false} is VALID [2022-02-20 18:03:35,506 INFO L284 TraceCheckUtils]: 73: Hoare quadruple {413#false} {413#false} #1152#return; {413#false} is VALID [2022-02-20 18:03:35,507 INFO L290 TraceCheckUtils]: 74: Hoare triple {413#false} assume -2147483648 <= outgoing__wrappee__AddressBook_#t~ret71#1 && outgoing__wrappee__AddressBook_#t~ret71#1 <= 2147483647;outgoing__wrappee__AddressBook_~tmp~13#1 := outgoing__wrappee__AddressBook_#t~ret71#1;havoc outgoing__wrappee__AddressBook_#t~ret71#1;outgoing__wrappee__AddressBook_~size~0#1 := outgoing__wrappee__AddressBook_~tmp~13#1; {413#false} is VALID [2022-02-20 18:03:35,507 INFO L290 TraceCheckUtils]: 75: Hoare triple {413#false} assume !(0 != outgoing__wrappee__AddressBook_~size~0#1); {413#false} is VALID [2022-02-20 18:03:35,507 INFO L272 TraceCheckUtils]: 76: Hoare triple {413#false} call outgoing__wrappee__Encrypt(outgoing__wrappee__AddressBook_~client#1, outgoing__wrappee__AddressBook_~msg#1); {413#false} is VALID [2022-02-20 18:03:35,507 INFO L290 TraceCheckUtils]: 77: Hoare triple {413#false} ~client#1 := #in~client#1;~msg#1 := #in~msg#1;havoc ~receiver~0#1;havoc ~tmp~12#1;havoc ~pubkey~0#1;havoc ~tmp___0~4#1; {413#false} is VALID [2022-02-20 18:03:35,507 INFO L272 TraceCheckUtils]: 78: Hoare triple {413#false} call #t~ret69#1 := getEmailTo(~msg#1); {413#false} is VALID [2022-02-20 18:03:35,508 INFO L290 TraceCheckUtils]: 79: Hoare triple {413#false} ~handle := #in~handle;havoc ~retValue_acc~3; {413#false} is VALID [2022-02-20 18:03:35,508 INFO L290 TraceCheckUtils]: 80: Hoare triple {413#false} assume 1 == ~handle;~retValue_acc~3 := ~__ste_email_to0~0;#res := ~retValue_acc~3; {413#false} is VALID [2022-02-20 18:03:35,508 INFO L290 TraceCheckUtils]: 81: Hoare triple {413#false} assume true; {413#false} is VALID [2022-02-20 18:03:35,508 INFO L284 TraceCheckUtils]: 82: Hoare quadruple {413#false} {413#false} #1170#return; {413#false} is VALID [2022-02-20 18:03:35,508 INFO L290 TraceCheckUtils]: 83: Hoare triple {413#false} assume -2147483648 <= #t~ret69#1 && #t~ret69#1 <= 2147483647;~tmp~12#1 := #t~ret69#1;havoc #t~ret69#1;~receiver~0#1 := ~tmp~12#1; {413#false} is VALID [2022-02-20 18:03:35,509 INFO L272 TraceCheckUtils]: 84: Hoare triple {413#false} call #t~ret70#1 := findPublicKey(~client#1, ~receiver~0#1); {413#false} is VALID [2022-02-20 18:03:35,509 INFO L290 TraceCheckUtils]: 85: Hoare triple {413#false} ~handle := #in~handle;~userid := #in~userid;havoc ~retValue_acc~41; {413#false} is VALID [2022-02-20 18:03:35,509 INFO L290 TraceCheckUtils]: 86: Hoare triple {413#false} assume 1 == ~handle; {413#false} is VALID [2022-02-20 18:03:35,509 INFO L290 TraceCheckUtils]: 87: Hoare triple {413#false} assume ~userid == ~__ste_Client_Keyring0_User0~0;~retValue_acc~41 := ~__ste_Client_Keyring0_PublicKey0~0;#res := ~retValue_acc~41; {413#false} is VALID [2022-02-20 18:03:35,509 INFO L290 TraceCheckUtils]: 88: Hoare triple {413#false} assume true; {413#false} is VALID [2022-02-20 18:03:35,509 INFO L284 TraceCheckUtils]: 89: Hoare quadruple {413#false} {413#false} #1172#return; {413#false} is VALID [2022-02-20 18:03:35,510 INFO L290 TraceCheckUtils]: 90: Hoare triple {413#false} assume -2147483648 <= #t~ret70#1 && #t~ret70#1 <= 2147483647;~tmp___0~4#1 := #t~ret70#1;havoc #t~ret70#1;~pubkey~0#1 := ~tmp___0~4#1; {413#false} is VALID [2022-02-20 18:03:35,510 INFO L290 TraceCheckUtils]: 91: Hoare triple {413#false} assume !(0 != ~pubkey~0#1); {413#false} is VALID [2022-02-20 18:03:35,510 INFO L290 TraceCheckUtils]: 92: Hoare triple {413#false} assume { :begin_inline_outgoing__wrappee__Keys } true;outgoing__wrappee__Keys_#in~client#1, outgoing__wrappee__Keys_#in~msg#1 := ~client#1, ~msg#1;havoc outgoing__wrappee__Keys_#t~ret68#1, outgoing__wrappee__Keys_~client#1, outgoing__wrappee__Keys_~msg#1, outgoing__wrappee__Keys_~tmp~11#1;outgoing__wrappee__Keys_~client#1 := outgoing__wrappee__Keys_#in~client#1;outgoing__wrappee__Keys_~msg#1 := outgoing__wrappee__Keys_#in~msg#1;havoc outgoing__wrappee__Keys_~tmp~11#1;assume { :begin_inline_getClientId } true;getClientId_#in~handle#1 := outgoing__wrappee__Keys_~client#1;havoc getClientId_#res#1;havoc getClientId_~handle#1, getClientId_~retValue_acc~43#1;getClientId_~handle#1 := getClientId_#in~handle#1;havoc getClientId_~retValue_acc~43#1; {413#false} is VALID [2022-02-20 18:03:35,510 INFO L290 TraceCheckUtils]: 93: Hoare triple {413#false} assume 1 == getClientId_~handle#1;getClientId_~retValue_acc~43#1 := ~__ste_client_idCounter0~0;getClientId_#res#1 := getClientId_~retValue_acc~43#1; {413#false} is VALID [2022-02-20 18:03:35,510 INFO L290 TraceCheckUtils]: 94: Hoare triple {413#false} outgoing__wrappee__Keys_#t~ret68#1 := getClientId_#res#1;assume { :end_inline_getClientId } true;assume -2147483648 <= outgoing__wrappee__Keys_#t~ret68#1 && outgoing__wrappee__Keys_#t~ret68#1 <= 2147483647;outgoing__wrappee__Keys_~tmp~11#1 := outgoing__wrappee__Keys_#t~ret68#1;havoc outgoing__wrappee__Keys_#t~ret68#1; {413#false} is VALID [2022-02-20 18:03:35,511 INFO L272 TraceCheckUtils]: 95: Hoare triple {413#false} call setEmailFrom(outgoing__wrappee__Keys_~msg#1, outgoing__wrappee__Keys_~tmp~11#1); {413#false} is VALID [2022-02-20 18:03:35,511 INFO L290 TraceCheckUtils]: 96: Hoare triple {413#false} ~handle := #in~handle;~value := #in~value; {413#false} is VALID [2022-02-20 18:03:35,511 INFO L290 TraceCheckUtils]: 97: Hoare triple {413#false} assume 1 == ~handle;~__ste_email_from0~0 := ~value; {413#false} is VALID [2022-02-20 18:03:35,511 INFO L290 TraceCheckUtils]: 98: Hoare triple {413#false} assume true; {413#false} is VALID [2022-02-20 18:03:35,511 INFO L284 TraceCheckUtils]: 99: Hoare quadruple {413#false} {413#false} #1178#return; {413#false} is VALID [2022-02-20 18:03:35,512 INFO L290 TraceCheckUtils]: 100: Hoare triple {413#false} assume { :begin_inline_mail } true;mail_#in~client#1, mail_#in~msg#1 := outgoing__wrappee__Keys_~client#1, outgoing__wrappee__Keys_~msg#1;havoc mail_#t~ret66#1, mail_#t~ret67#1, mail_~client#1, mail_~msg#1, mail_~__utac__ad__arg1~0#1, mail_~tmp~10#1;mail_~client#1 := mail_#in~client#1;mail_~msg#1 := mail_#in~msg#1;havoc mail_~__utac__ad__arg1~0#1;havoc mail_~tmp~10#1;mail_~__utac__ad__arg1~0#1 := mail_~msg#1;assume { :begin_inline___utac_acc__EncryptAutoResponder_spec__2 } true;__utac_acc__EncryptAutoResponder_spec__2_#in~msg#1 := mail_~__utac__ad__arg1~0#1;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1, __utac_acc__EncryptAutoResponder_spec__2_#t~nondet29#1, __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1, __utac_acc__EncryptAutoResponder_spec__2_~msg#1, __utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.base, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.offset;__utac_acc__EncryptAutoResponder_spec__2_~msg#1 := __utac_acc__EncryptAutoResponder_spec__2_#in~msg#1;havoc __utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1;havoc __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.base, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.offset;call __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1 := puts(15, 0);assume -2147483648 <= __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1 && __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1 <= 2147483647;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1;__utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.base, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.offset := 16, 0;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~nondet29#1; {413#false} is VALID [2022-02-20 18:03:35,512 INFO L290 TraceCheckUtils]: 101: Hoare triple {413#false} assume 0 != ~in_encrypted~0; {413#false} is VALID [2022-02-20 18:03:35,512 INFO L272 TraceCheckUtils]: 102: Hoare triple {413#false} call __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1 := isEncrypted(__utac_acc__EncryptAutoResponder_spec__2_~msg#1); {413#false} is VALID [2022-02-20 18:03:35,512 INFO L290 TraceCheckUtils]: 103: Hoare triple {413#false} ~handle := #in~handle;havoc ~retValue_acc~6; {413#false} is VALID [2022-02-20 18:03:35,512 INFO L290 TraceCheckUtils]: 104: Hoare triple {413#false} assume 1 == ~handle;~retValue_acc~6 := ~__ste_email_isEncrypted0~0;#res := ~retValue_acc~6; {413#false} is VALID [2022-02-20 18:03:35,512 INFO L290 TraceCheckUtils]: 105: Hoare triple {413#false} assume true; {413#false} is VALID [2022-02-20 18:03:35,513 INFO L284 TraceCheckUtils]: 106: Hoare quadruple {413#false} {413#false} #1180#return; {413#false} is VALID [2022-02-20 18:03:35,513 INFO L290 TraceCheckUtils]: 107: Hoare triple {413#false} assume -2147483648 <= __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1 && __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1 <= 2147483647;__utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1 := __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1; {413#false} is VALID [2022-02-20 18:03:35,513 INFO L290 TraceCheckUtils]: 108: Hoare triple {413#false} assume !(0 != __utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1);assume { :begin_inline___automaton_fail } true; {413#false} is VALID [2022-02-20 18:03:35,513 INFO L290 TraceCheckUtils]: 109: Hoare triple {413#false} assume !false; {413#false} is VALID [2022-02-20 18:03:35,514 INFO L134 CoverageAnalysis]: Checked inductivity of 28 backedges. 0 proven. 0 refuted. 0 times theorem prover too weak. 28 trivial. 0 not checked. [2022-02-20 18:03:35,514 INFO L324 TraceCheckSpWp]: Omiting computation of backward sequence because forward sequence was already perfect [2022-02-20 18:03:35,514 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleZ3 [426858502] provided 1 perfect and 0 imperfect interpolant sequences [2022-02-20 18:03:35,514 INFO L191 FreeRefinementEngine]: Found 1 perfect and 1 imperfect interpolant sequences. [2022-02-20 18:03:35,515 INFO L204 FreeRefinementEngine]: Number of different interpolants: perfect sequences [2] imperfect sequences [9] total 9 [2022-02-20 18:03:35,517 INFO L118 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [271213244] [2022-02-20 18:03:35,517 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-02-20 18:03:35,523 INFO L78 Accepts]: Start accepts. Automaton has has 2 states, 2 states have (on average 32.0) internal successors, (64), 2 states have internal predecessors, (64), 2 states have call successors, (17), 2 states have call predecessors, (17), 2 states have return successors, (14), 2 states have call predecessors, (14), 2 states have call successors, (14) Word has length 110 [2022-02-20 18:03:35,525 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-02-20 18:03:35,528 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with has 2 states, 2 states have (on average 32.0) internal successors, (64), 2 states have internal predecessors, (64), 2 states have call successors, (17), 2 states have call predecessors, (17), 2 states have return successors, (14), 2 states have call predecessors, (14), 2 states have call successors, (14) [2022-02-20 18:03:35,633 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 95 edges. 95 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 18:03:35,634 INFO L546 AbstractCegarLoop]: INTERPOLANT automaton has 2 states [2022-02-20 18:03:35,634 INFO L108 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2022-02-20 18:03:35,661 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 2 interpolants. [2022-02-20 18:03:35,662 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=15, Invalid=57, Unknown=0, NotChecked=0, Total=72 [2022-02-20 18:03:35,669 INFO L87 Difference]: Start difference. First operand has 409 states, 316 states have (on average 1.5537974683544304) internal successors, (491), 321 states have internal predecessors, (491), 63 states have call successors, (63), 28 states have call predecessors, (63), 28 states have return successors, (63), 62 states have call predecessors, (63), 63 states have call successors, (63) Second operand has 2 states, 2 states have (on average 32.0) internal successors, (64), 2 states have internal predecessors, (64), 2 states have call successors, (17), 2 states have call predecessors, (17), 2 states have return successors, (14), 2 states have call predecessors, (14), 2 states have call successors, (14) [2022-02-20 18:03:36,158 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 18:03:36,159 INFO L93 Difference]: Finished difference Result 630 states and 932 transitions. [2022-02-20 18:03:36,159 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 2 states. [2022-02-20 18:03:36,160 INFO L78 Accepts]: Start accepts. Automaton has has 2 states, 2 states have (on average 32.0) internal successors, (64), 2 states have internal predecessors, (64), 2 states have call successors, (17), 2 states have call predecessors, (17), 2 states have return successors, (14), 2 states have call predecessors, (14), 2 states have call successors, (14) Word has length 110 [2022-02-20 18:03:36,160 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-02-20 18:03:36,162 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 2 states, 2 states have (on average 32.0) internal successors, (64), 2 states have internal predecessors, (64), 2 states have call successors, (17), 2 states have call predecessors, (17), 2 states have return successors, (14), 2 states have call predecessors, (14), 2 states have call successors, (14) [2022-02-20 18:03:36,205 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 2 states to 2 states and 932 transitions. [2022-02-20 18:03:36,206 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 2 states, 2 states have (on average 32.0) internal successors, (64), 2 states have internal predecessors, (64), 2 states have call successors, (17), 2 states have call predecessors, (17), 2 states have return successors, (14), 2 states have call predecessors, (14), 2 states have call successors, (14) [2022-02-20 18:03:36,229 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 2 states to 2 states and 932 transitions. [2022-02-20 18:03:36,229 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with 2 states and 932 transitions. [2022-02-20 18:03:36,843 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 932 edges. 932 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 18:03:36,897 INFO L225 Difference]: With dead ends: 630 [2022-02-20 18:03:36,898 INFO L226 Difference]: Without dead ends: 402 [2022-02-20 18:03:36,906 INFO L932 BasicCegarLoop]: 0 DeclaredPredicates, 141 GetRequests, 134 SyntacticMatches, 0 SemanticMatches, 7 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 0 ImplicationChecksByTransitivity, 0.0s TimeCoverageRelationStatistics Valid=15, Invalid=57, Unknown=0, NotChecked=0, Total=72 [2022-02-20 18:03:36,909 INFO L933 BasicCegarLoop]: 613 mSDtfsCounter, 0 mSDsluCounter, 0 mSDsCounter, 0 mSdLazyCounter, 0 mSolverCounterSat, 0 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.0s Time, 0 mProtectedPredicate, 0 mProtectedAction, 0 SdHoareTripleChecker+Valid, 613 SdHoareTripleChecker+Invalid, 0 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 0 IncrementalHoareTripleChecker+Valid, 0 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.0s IncrementalHoareTripleChecker+Time [2022-02-20 18:03:36,913 INFO L934 BasicCegarLoop]: SdHoareTripleChecker [0 Valid, 613 Invalid, 0 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [0 Valid, 0 Invalid, 0 Unknown, 0 Unchecked, 0.0s Time] [2022-02-20 18:03:36,942 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 402 states. [2022-02-20 18:03:36,983 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 402 to 402. [2022-02-20 18:03:36,985 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-02-20 18:03:36,988 INFO L82 GeneralOperation]: Start isEquivalent. First operand 402 states. Second operand has 402 states, 310 states have (on average 1.5483870967741935) internal successors, (480), 314 states have internal predecessors, (480), 63 states have call successors, (63), 28 states have call predecessors, (63), 28 states have return successors, (62), 61 states have call predecessors, (62), 62 states have call successors, (62) [2022-02-20 18:03:36,992 INFO L74 IsIncluded]: Start isIncluded. First operand 402 states. Second operand has 402 states, 310 states have (on average 1.5483870967741935) internal successors, (480), 314 states have internal predecessors, (480), 63 states have call successors, (63), 28 states have call predecessors, (63), 28 states have return successors, (62), 61 states have call predecessors, (62), 62 states have call successors, (62) [2022-02-20 18:03:36,994 INFO L87 Difference]: Start difference. First operand 402 states. Second operand has 402 states, 310 states have (on average 1.5483870967741935) internal successors, (480), 314 states have internal predecessors, (480), 63 states have call successors, (63), 28 states have call predecessors, (63), 28 states have return successors, (62), 61 states have call predecessors, (62), 62 states have call successors, (62) [2022-02-20 18:03:37,023 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 18:03:37,023 INFO L93 Difference]: Finished difference Result 402 states and 605 transitions. [2022-02-20 18:03:37,023 INFO L276 IsEmpty]: Start isEmpty. Operand 402 states and 605 transitions. [2022-02-20 18:03:37,025 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 18:03:37,025 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 18:03:37,027 INFO L74 IsIncluded]: Start isIncluded. First operand has 402 states, 310 states have (on average 1.5483870967741935) internal successors, (480), 314 states have internal predecessors, (480), 63 states have call successors, (63), 28 states have call predecessors, (63), 28 states have return successors, (62), 61 states have call predecessors, (62), 62 states have call successors, (62) Second operand 402 states. [2022-02-20 18:03:37,029 INFO L87 Difference]: Start difference. First operand has 402 states, 310 states have (on average 1.5483870967741935) internal successors, (480), 314 states have internal predecessors, (480), 63 states have call successors, (63), 28 states have call predecessors, (63), 28 states have return successors, (62), 61 states have call predecessors, (62), 62 states have call successors, (62) Second operand 402 states. [2022-02-20 18:03:37,052 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 18:03:37,052 INFO L93 Difference]: Finished difference Result 402 states and 605 transitions. [2022-02-20 18:03:37,053 INFO L276 IsEmpty]: Start isEmpty. Operand 402 states and 605 transitions. [2022-02-20 18:03:37,055 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 18:03:37,055 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 18:03:37,055 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-02-20 18:03:37,056 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-02-20 18:03:37,058 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 402 states, 310 states have (on average 1.5483870967741935) internal successors, (480), 314 states have internal predecessors, (480), 63 states have call successors, (63), 28 states have call predecessors, (63), 28 states have return successors, (62), 61 states have call predecessors, (62), 62 states have call successors, (62) [2022-02-20 18:03:37,078 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 402 states to 402 states and 605 transitions. [2022-02-20 18:03:37,080 INFO L78 Accepts]: Start accepts. Automaton has 402 states and 605 transitions. Word has length 110 [2022-02-20 18:03:37,082 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-02-20 18:03:37,082 INFO L470 AbstractCegarLoop]: Abstraction has 402 states and 605 transitions. [2022-02-20 18:03:37,082 INFO L471 AbstractCegarLoop]: INTERPOLANT automaton has has 2 states, 2 states have (on average 32.0) internal successors, (64), 2 states have internal predecessors, (64), 2 states have call successors, (17), 2 states have call predecessors, (17), 2 states have return successors, (14), 2 states have call predecessors, (14), 2 states have call successors, (14) [2022-02-20 18:03:37,083 INFO L276 IsEmpty]: Start isEmpty. Operand 402 states and 605 transitions. [2022-02-20 18:03:37,086 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 112 [2022-02-20 18:03:37,086 INFO L506 BasicCegarLoop]: Found error trace [2022-02-20 18:03:37,086 INFO L514 BasicCegarLoop]: trace histogram [3, 3, 3, 3, 3, 3, 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] [2022-02-20 18:03:37,117 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 18:03:37,291 WARN L452 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: 2 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true,SelfDestructingSolverStorable0 [2022-02-20 18:03:37,292 INFO L402 AbstractCegarLoop]: === Iteration 2 === Targeting outgoing__wrappee__EncryptErr0ASSERT_VIOLATIONERROR_FUNCTION === [outgoing__wrappee__EncryptErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-02-20 18:03:37,293 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-02-20 18:03:37,293 INFO L85 PathProgramCache]: Analyzing trace with hash -491967672, now seen corresponding path program 1 times [2022-02-20 18:03:37,293 INFO L126 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-02-20 18:03:37,293 INFO L338 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [58714821] [2022-02-20 18:03:37,293 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 18:03:37,293 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-02-20 18:03:37,332 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:37,405 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 6 [2022-02-20 18:03:37,407 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:37,421 INFO L290 TraceCheckUtils]: 0: Hoare triple {3077#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {3017#true} is VALID [2022-02-20 18:03:37,421 INFO L290 TraceCheckUtils]: 1: Hoare triple {3017#true} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {3017#true} is VALID [2022-02-20 18:03:37,421 INFO L290 TraceCheckUtils]: 2: Hoare triple {3017#true} assume true; {3017#true} is VALID [2022-02-20 18:03:37,421 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {3017#true} {3017#true} #1224#return; {3017#true} is VALID [2022-02-20 18:03:37,427 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 12 [2022-02-20 18:03:37,429 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:37,431 INFO L290 TraceCheckUtils]: 0: Hoare triple {3078#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {3017#true} is VALID [2022-02-20 18:03:37,432 INFO L290 TraceCheckUtils]: 1: Hoare triple {3017#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {3017#true} is VALID [2022-02-20 18:03:37,432 INFO L290 TraceCheckUtils]: 2: Hoare triple {3017#true} assume true; {3017#true} is VALID [2022-02-20 18:03:37,432 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {3017#true} {3017#true} #1226#return; {3017#true} is VALID [2022-02-20 18:03:37,433 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 18 [2022-02-20 18:03:37,435 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:37,446 INFO L290 TraceCheckUtils]: 0: Hoare triple {3077#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {3079#(= setClientId_~handle |setClientId_#in~handle|)} is VALID [2022-02-20 18:03:37,447 INFO L290 TraceCheckUtils]: 1: Hoare triple {3079#(= setClientId_~handle |setClientId_#in~handle|)} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {3080#(= |setClientId_#in~handle| 1)} is VALID [2022-02-20 18:03:37,447 INFO L290 TraceCheckUtils]: 2: Hoare triple {3080#(= |setClientId_#in~handle| 1)} assume true; {3080#(= |setClientId_#in~handle| 1)} is VALID [2022-02-20 18:03:37,448 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {3080#(= |setClientId_#in~handle| 1)} {3027#(= |ULTIMATE.start_setup_rjh__wrappee__Base_~rjh___0#1| 2)} #1228#return; {3018#false} is VALID [2022-02-20 18:03:37,448 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 24 [2022-02-20 18:03:37,449 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:37,452 INFO L290 TraceCheckUtils]: 0: Hoare triple {3078#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {3017#true} is VALID [2022-02-20 18:03:37,452 INFO L290 TraceCheckUtils]: 1: Hoare triple {3017#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {3017#true} is VALID [2022-02-20 18:03:37,452 INFO L290 TraceCheckUtils]: 2: Hoare triple {3017#true} assume true; {3017#true} is VALID [2022-02-20 18:03:37,452 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {3017#true} {3018#false} #1230#return; {3018#false} is VALID [2022-02-20 18:03:37,452 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 30 [2022-02-20 18:03:37,455 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:37,460 INFO L290 TraceCheckUtils]: 0: Hoare triple {3077#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {3017#true} is VALID [2022-02-20 18:03:37,460 INFO L290 TraceCheckUtils]: 1: Hoare triple {3017#true} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {3017#true} is VALID [2022-02-20 18:03:37,461 INFO L290 TraceCheckUtils]: 2: Hoare triple {3017#true} assume true; {3017#true} is VALID [2022-02-20 18:03:37,461 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {3017#true} {3018#false} #1232#return; {3018#false} is VALID [2022-02-20 18:03:37,462 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 36 [2022-02-20 18:03:37,463 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:37,466 INFO L290 TraceCheckUtils]: 0: Hoare triple {3078#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {3017#true} is VALID [2022-02-20 18:03:37,467 INFO L290 TraceCheckUtils]: 1: Hoare triple {3017#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {3017#true} is VALID [2022-02-20 18:03:37,467 INFO L290 TraceCheckUtils]: 2: Hoare triple {3017#true} assume true; {3017#true} is VALID [2022-02-20 18:03:37,467 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {3017#true} {3018#false} #1234#return; {3018#false} is VALID [2022-02-20 18:03:37,473 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 48 [2022-02-20 18:03:37,475 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:37,478 INFO L290 TraceCheckUtils]: 0: Hoare triple {3081#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} ~handle := #in~handle;~value := #in~value; {3017#true} is VALID [2022-02-20 18:03:37,478 INFO L290 TraceCheckUtils]: 1: Hoare triple {3017#true} assume 1 == ~handle;~__ste_email_from0~0 := ~value; {3017#true} is VALID [2022-02-20 18:03:37,488 INFO L290 TraceCheckUtils]: 2: Hoare triple {3017#true} assume true; {3017#true} is VALID [2022-02-20 18:03:37,488 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {3017#true} {3018#false} #1210#return; {3018#false} is VALID [2022-02-20 18:03:37,496 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 53 [2022-02-20 18:03:37,497 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:37,500 INFO L290 TraceCheckUtils]: 0: Hoare triple {3082#(and (= ~__ste_email_to0~0 |old(~__ste_email_to0~0)|) (= ~__ste_email_to1~0 |old(~__ste_email_to1~0)|))} ~handle := #in~handle;~value := #in~value; {3017#true} is VALID [2022-02-20 18:03:37,500 INFO L290 TraceCheckUtils]: 1: Hoare triple {3017#true} assume 1 == ~handle;~__ste_email_to0~0 := ~value; {3017#true} is VALID [2022-02-20 18:03:37,500 INFO L290 TraceCheckUtils]: 2: Hoare triple {3017#true} assume true; {3017#true} is VALID [2022-02-20 18:03:37,501 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {3017#true} {3018#false} #1212#return; {3018#false} is VALID [2022-02-20 18:03:37,501 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 62 [2022-02-20 18:03:37,502 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:37,504 INFO L290 TraceCheckUtils]: 0: Hoare triple {3017#true} ~handle := #in~handle;havoc ~retValue_acc~36; {3017#true} is VALID [2022-02-20 18:03:37,510 INFO L290 TraceCheckUtils]: 1: Hoare triple {3017#true} assume 1 == ~handle;~retValue_acc~36 := ~__ste_client_privateKey0~0;#res := ~retValue_acc~36; {3017#true} is VALID [2022-02-20 18:03:37,510 INFO L290 TraceCheckUtils]: 2: Hoare triple {3017#true} assume true; {3017#true} is VALID [2022-02-20 18:03:37,510 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {3017#true} {3018#false} #1150#return; {3018#false} is VALID [2022-02-20 18:03:37,511 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 70 [2022-02-20 18:03:37,512 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:37,514 INFO L290 TraceCheckUtils]: 0: Hoare triple {3017#true} ~handle := #in~handle;havoc ~retValue_acc~30; {3017#true} is VALID [2022-02-20 18:03:37,515 INFO L290 TraceCheckUtils]: 1: Hoare triple {3017#true} assume 1 == ~handle;~retValue_acc~30 := ~__ste_ClientAddressBook_size0~0;#res := ~retValue_acc~30; {3017#true} is VALID [2022-02-20 18:03:37,515 INFO L290 TraceCheckUtils]: 2: Hoare triple {3017#true} assume true; {3017#true} is VALID [2022-02-20 18:03:37,515 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {3017#true} {3018#false} #1152#return; {3018#false} is VALID [2022-02-20 18:03:37,515 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 79 [2022-02-20 18:03:37,516 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:37,518 INFO L290 TraceCheckUtils]: 0: Hoare triple {3017#true} ~handle := #in~handle;havoc ~retValue_acc~3; {3017#true} is VALID [2022-02-20 18:03:37,519 INFO L290 TraceCheckUtils]: 1: Hoare triple {3017#true} assume 1 == ~handle;~retValue_acc~3 := ~__ste_email_to0~0;#res := ~retValue_acc~3; {3017#true} is VALID [2022-02-20 18:03:37,519 INFO L290 TraceCheckUtils]: 2: Hoare triple {3017#true} assume true; {3017#true} is VALID [2022-02-20 18:03:37,519 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {3017#true} {3018#false} #1170#return; {3018#false} is VALID [2022-02-20 18:03:37,519 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 85 [2022-02-20 18:03:37,521 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:37,523 INFO L290 TraceCheckUtils]: 0: Hoare triple {3017#true} ~handle := #in~handle;~userid := #in~userid;havoc ~retValue_acc~41; {3017#true} is VALID [2022-02-20 18:03:37,523 INFO L290 TraceCheckUtils]: 1: Hoare triple {3017#true} assume 1 == ~handle; {3017#true} is VALID [2022-02-20 18:03:37,523 INFO L290 TraceCheckUtils]: 2: Hoare triple {3017#true} assume ~userid == ~__ste_Client_Keyring0_User0~0;~retValue_acc~41 := ~__ste_Client_Keyring0_PublicKey0~0;#res := ~retValue_acc~41; {3017#true} is VALID [2022-02-20 18:03:37,523 INFO L290 TraceCheckUtils]: 3: Hoare triple {3017#true} assume true; {3017#true} is VALID [2022-02-20 18:03:37,524 INFO L284 TraceCheckUtils]: 4: Hoare quadruple {3017#true} {3018#false} #1172#return; {3018#false} is VALID [2022-02-20 18:03:37,524 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 96 [2022-02-20 18:03:37,525 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:37,527 INFO L290 TraceCheckUtils]: 0: Hoare triple {3081#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} ~handle := #in~handle;~value := #in~value; {3017#true} is VALID [2022-02-20 18:03:37,528 INFO L290 TraceCheckUtils]: 1: Hoare triple {3017#true} assume 1 == ~handle;~__ste_email_from0~0 := ~value; {3017#true} is VALID [2022-02-20 18:03:37,528 INFO L290 TraceCheckUtils]: 2: Hoare triple {3017#true} assume true; {3017#true} is VALID [2022-02-20 18:03:37,528 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {3017#true} {3018#false} #1178#return; {3018#false} is VALID [2022-02-20 18:03:37,528 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 103 [2022-02-20 18:03:37,529 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:37,531 INFO L290 TraceCheckUtils]: 0: Hoare triple {3017#true} ~handle := #in~handle;havoc ~retValue_acc~6; {3017#true} is VALID [2022-02-20 18:03:37,533 INFO L290 TraceCheckUtils]: 1: Hoare triple {3017#true} assume 1 == ~handle;~retValue_acc~6 := ~__ste_email_isEncrypted0~0;#res := ~retValue_acc~6; {3017#true} is VALID [2022-02-20 18:03:37,536 INFO L290 TraceCheckUtils]: 2: Hoare triple {3017#true} assume true; {3017#true} is VALID [2022-02-20 18:03:37,536 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {3017#true} {3018#false} #1180#return; {3018#false} is VALID [2022-02-20 18:03:37,536 INFO L290 TraceCheckUtils]: 0: Hoare triple {3017#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(28, 2);call #Ultimate.allocInit(12, 3);call #Ultimate.allocInit(10, 4);call #Ultimate.allocInit(12, 5);call #Ultimate.allocInit(10, 6);call #Ultimate.allocInit(18, 7);call #Ultimate.allocInit(16, 8);call #Ultimate.allocInit(21, 9);call #Ultimate.allocInit(13, 10);call #Ultimate.allocInit(16, 11);call #Ultimate.allocInit(25, 12);call #Ultimate.allocInit(17, 13);call #Ultimate.allocInit(17, 14);call #Ultimate.allocInit(13, 15);call #Ultimate.allocInit(17, 16);call #Ultimate.allocInit(30, 17);call #Ultimate.allocInit(9, 18);call #Ultimate.allocInit(21, 19);call #Ultimate.allocInit(30, 20);call #Ultimate.allocInit(9, 21);call #Ultimate.allocInit(21, 22);call #Ultimate.allocInit(30, 23);call #Ultimate.allocInit(9, 24);call #Ultimate.allocInit(25, 25);call #Ultimate.allocInit(30, 26);call #Ultimate.allocInit(9, 27);call #Ultimate.allocInit(25, 28);call #Ultimate.allocInit(4, 29);call write~init~int(37, 29, 0, 1);call write~init~int(115, 29, 1, 1);call write~init~int(10, 29, 2, 1);call write~init~int(0, 29, 3, 1);call #Ultimate.allocInit(10, 30);call #Ultimate.allocInit(34, 31);call #Ultimate.allocInit(30, 32);call #Ultimate.allocInit(16, 33);call #Ultimate.allocInit(20, 34);call #Ultimate.allocInit(44, 35);call #Ultimate.allocInit(44, 36);call #Ultimate.allocInit(9, 37);call #Ultimate.allocInit(9, 38);call #Ultimate.allocInit(11, 39);call #Ultimate.allocInit(19, 40);call #Ultimate.allocInit(4, 41);call write~init~int(37, 41, 0, 1);call write~init~int(100, 41, 1, 1);call write~init~int(10, 41, 2, 1);call write~init~int(0, 41, 3, 1);call #Ultimate.allocInit(4, 42);call write~init~int(37, 42, 0, 1);call write~init~int(100, 42, 1, 1);call write~init~int(10, 42, 2, 1);call write~init~int(0, 42, 3, 1);~__ste_Email_counter~0 := 0;~__ste_email_id0~0 := 0;~__ste_email_id1~0 := 0;~__ste_email_from0~0 := 0;~__ste_email_from1~0 := 0;~__ste_email_to0~0 := 0;~__ste_email_to1~0 := 0;~__ste_email_subject0~0.base, ~__ste_email_subject0~0.offset := 0, 0;~__ste_email_subject1~0.base, ~__ste_email_subject1~0.offset := 0, 0;~__ste_email_body0~0.base, ~__ste_email_body0~0.offset := 0, 0;~__ste_email_body1~0.base, ~__ste_email_body1~0.offset := 0, 0;~__ste_email_isEncrypted0~0 := 0;~__ste_email_isEncrypted1~0 := 0;~__ste_email_encryptionKey0~0 := 0;~__ste_email_encryptionKey1~0 := 0;~__ste_email_isSigned0~0 := 0;~__ste_email_isSigned1~0 := 0;~__ste_email_signKey0~0 := 0;~__ste_email_signKey1~0 := 0;~__ste_email_isSignatureVerified0~0 := 0;~__ste_email_isSignatureVerified1~0 := 0;~__SELECTED_FEATURE_Base~0 := 0;~__SELECTED_FEATURE_Keys~0 := 0;~__SELECTED_FEATURE_Encrypt~0 := 0;~__SELECTED_FEATURE_AutoResponder~0 := 0;~__SELECTED_FEATURE_AddressBook~0 := 0;~__SELECTED_FEATURE_Sign~0 := 0;~__SELECTED_FEATURE_Forward~0 := 0;~__SELECTED_FEATURE_Verify~0 := 0;~__SELECTED_FEATURE_Decrypt~0 := 0;~__GUIDSL_ROOT_PRODUCTION~0 := 0;~__GUIDSL_NON_TERMINAL_main~0 := 0;~in_encrypted~0 := 0;~head~0.base, ~head~0.offset := 0, 0;~queue_empty~0 := 1;~queued_message~0 := 0;~queued_client~0 := 0;~bob~0 := 0;~rjh~0 := 0;~chuck~0 := 0;~__ste_Client_counter~0 := 0;~__ste_client_name0~0.base, ~__ste_client_name0~0.offset := 0, 0;~__ste_client_name1~0.base, ~__ste_client_name1~0.offset := 0, 0;~__ste_client_name2~0.base, ~__ste_client_name2~0.offset := 0, 0;~__ste_client_outbuffer0~0 := 0;~__ste_client_outbuffer1~0 := 0;~__ste_client_outbuffer2~0 := 0;~__ste_client_outbuffer3~0 := 0;~__ste_ClientAddressBook_size0~0 := 0;~__ste_ClientAddressBook_size1~0 := 0;~__ste_ClientAddressBook_size2~0 := 0;~__ste_Client_AddressBook0_Alias0~0 := 0;~__ste_Client_AddressBook0_Alias1~0 := 0;~__ste_Client_AddressBook0_Alias2~0 := 0;~__ste_Client_AddressBook1_Alias0~0 := 0;~__ste_Client_AddressBook1_Alias1~0 := 0;~__ste_Client_AddressBook1_Alias2~0 := 0;~__ste_Client_AddressBook2_Alias0~0 := 0;~__ste_Client_AddressBook2_Alias1~0 := 0;~__ste_Client_AddressBook2_Alias2~0 := 0;~__ste_Client_AddressBook0_Address0~0 := 0;~__ste_Client_AddressBook0_Address1~0 := 0;~__ste_Client_AddressBook0_Address2~0 := 0;~__ste_Client_AddressBook1_Address0~0 := 0;~__ste_Client_AddressBook1_Address1~0 := 0;~__ste_Client_AddressBook1_Address2~0 := 0;~__ste_Client_AddressBook2_Address0~0 := 0;~__ste_Client_AddressBook2_Address1~0 := 0;~__ste_Client_AddressBook2_Address2~0 := 0;~__ste_client_autoResponse0~0 := 0;~__ste_client_autoResponse1~0 := 0;~__ste_client_autoResponse2~0 := 0;~__ste_client_privateKey0~0 := 0;~__ste_client_privateKey1~0 := 0;~__ste_client_privateKey2~0 := 0;~__ste_ClientKeyring_size0~0 := 0;~__ste_ClientKeyring_size1~0 := 0;~__ste_ClientKeyring_size2~0 := 0;~__ste_Client_Keyring0_User0~0 := 0;~__ste_Client_Keyring0_User1~0 := 0;~__ste_Client_Keyring0_User2~0 := 0;~__ste_Client_Keyring1_User0~0 := 0;~__ste_Client_Keyring1_User1~0 := 0;~__ste_Client_Keyring1_User2~0 := 0;~__ste_Client_Keyring2_User0~0 := 0;~__ste_Client_Keyring2_User1~0 := 0;~__ste_Client_Keyring2_User2~0 := 0;~__ste_Client_Keyring0_PublicKey0~0 := 0;~__ste_Client_Keyring0_PublicKey1~0 := 0;~__ste_Client_Keyring0_PublicKey2~0 := 0;~__ste_Client_Keyring1_PublicKey0~0 := 0;~__ste_Client_Keyring1_PublicKey1~0 := 0;~__ste_Client_Keyring1_PublicKey2~0 := 0;~__ste_Client_Keyring2_PublicKey0~0 := 0;~__ste_Client_Keyring2_PublicKey1~0 := 0;~__ste_Client_Keyring2_PublicKey2~0 := 0;~__ste_client_forwardReceiver0~0 := 0;~__ste_client_forwardReceiver1~0 := 0;~__ste_client_forwardReceiver2~0 := 0;~__ste_client_forwardReceiver3~0 := 0;~__ste_client_idCounter0~0 := 0;~__ste_client_idCounter1~0 := 0;~__ste_client_idCounter2~0 := 0; {3017#true} is VALID [2022-02-20 18:03:37,536 INFO L290 TraceCheckUtils]: 1: Hoare triple {3017#true} assume { :end_inline_ULTIMATE.init } true;assume { :begin_inline_main } true;havoc main_#res#1;havoc main_#t~nondet100#1, main_#t~ret101#1, main_~retValue_acc~26#1, main_~tmp~20#1;assume -2147483648 <= main_#t~nondet100#1 && main_#t~nondet100#1 <= 2147483647;main_~retValue_acc~26#1 := main_#t~nondet100#1;havoc main_#t~nondet100#1;havoc main_~tmp~20#1;assume { :begin_inline_select_helpers } true; {3017#true} is VALID [2022-02-20 18:03:37,537 INFO L290 TraceCheckUtils]: 2: Hoare triple {3017#true} assume { :end_inline_select_helpers } true;assume { :begin_inline_select_features } true; {3017#true} is VALID [2022-02-20 18:03:37,537 INFO L290 TraceCheckUtils]: 3: Hoare triple {3017#true} assume { :end_inline_select_features } true;assume { :begin_inline_valid_product } true;havoc valid_product_#res#1;havoc valid_product_~retValue_acc~12#1;havoc valid_product_~retValue_acc~12#1;valid_product_~retValue_acc~12#1 := 1;valid_product_#res#1 := valid_product_~retValue_acc~12#1; {3017#true} is VALID [2022-02-20 18:03:37,537 INFO L290 TraceCheckUtils]: 4: Hoare triple {3017#true} main_#t~ret101#1 := valid_product_#res#1;assume { :end_inline_valid_product } true;assume -2147483648 <= main_#t~ret101#1 && main_#t~ret101#1 <= 2147483647;main_~tmp~20#1 := main_#t~ret101#1;havoc main_#t~ret101#1; {3017#true} is VALID [2022-02-20 18:03:37,537 INFO L290 TraceCheckUtils]: 5: Hoare triple {3017#true} assume 0 != main_~tmp~20#1;assume { :begin_inline_setup } true;havoc setup_#t~nondet97#1, setup_#t~nondet98#1, setup_#t~nondet99#1, setup_~__cil_tmp1~0#1.base, setup_~__cil_tmp1~0#1.offset, setup_~__cil_tmp2~1#1.base, setup_~__cil_tmp2~1#1.offset, setup_~__cil_tmp3~4#1.base, setup_~__cil_tmp3~4#1.offset;havoc setup_~__cil_tmp1~0#1.base, setup_~__cil_tmp1~0#1.offset;havoc setup_~__cil_tmp2~1#1.base, setup_~__cil_tmp2~1#1.offset;havoc setup_~__cil_tmp3~4#1.base, setup_~__cil_tmp3~4#1.offset;~bob~0 := 1;assume { :begin_inline_setup_bob } true;setup_bob_#in~bob___0#1 := ~bob~0;havoc setup_bob_~bob___0#1;setup_bob_~bob___0#1 := setup_bob_#in~bob___0#1;assume { :begin_inline_setup_bob__wrappee__Base } true;setup_bob__wrappee__Base_#in~bob___0#1 := setup_bob_~bob___0#1;havoc setup_bob__wrappee__Base_~bob___0#1;setup_bob__wrappee__Base_~bob___0#1 := setup_bob__wrappee__Base_#in~bob___0#1; {3017#true} is VALID [2022-02-20 18:03:37,538 INFO L272 TraceCheckUtils]: 6: Hoare triple {3017#true} call setClientId(setup_bob__wrappee__Base_~bob___0#1, setup_bob__wrappee__Base_~bob___0#1); {3077#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} is VALID [2022-02-20 18:03:37,538 INFO L290 TraceCheckUtils]: 7: Hoare triple {3077#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {3017#true} is VALID [2022-02-20 18:03:37,538 INFO L290 TraceCheckUtils]: 8: Hoare triple {3017#true} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {3017#true} is VALID [2022-02-20 18:03:37,538 INFO L290 TraceCheckUtils]: 9: Hoare triple {3017#true} assume true; {3017#true} is VALID [2022-02-20 18:03:37,538 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {3017#true} {3017#true} #1224#return; {3017#true} is VALID [2022-02-20 18:03:37,538 INFO L290 TraceCheckUtils]: 11: Hoare triple {3017#true} assume { :end_inline_setup_bob__wrappee__Base } true; {3017#true} is VALID [2022-02-20 18:03:37,539 INFO L272 TraceCheckUtils]: 12: Hoare triple {3017#true} call setClientPrivateKey(setup_bob_~bob___0#1, 123); {3078#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} is VALID [2022-02-20 18:03:37,539 INFO L290 TraceCheckUtils]: 13: Hoare triple {3078#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {3017#true} is VALID [2022-02-20 18:03:37,539 INFO L290 TraceCheckUtils]: 14: Hoare triple {3017#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {3017#true} is VALID [2022-02-20 18:03:37,540 INFO L290 TraceCheckUtils]: 15: Hoare triple {3017#true} assume true; {3017#true} is VALID [2022-02-20 18:03:37,540 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {3017#true} {3017#true} #1226#return; {3017#true} is VALID [2022-02-20 18:03:37,541 INFO L290 TraceCheckUtils]: 17: Hoare triple {3017#true} assume { :end_inline_setup_bob } true;setup_~__cil_tmp1~0#1.base, setup_~__cil_tmp1~0#1.offset := 37, 0;havoc setup_#t~nondet97#1;~rjh~0 := 2;assume { :begin_inline_setup_rjh } true;setup_rjh_#in~rjh___0#1 := ~rjh~0;havoc setup_rjh_~rjh___0#1;setup_rjh_~rjh___0#1 := setup_rjh_#in~rjh___0#1;assume { :begin_inline_setup_rjh__wrappee__Base } true;setup_rjh__wrappee__Base_#in~rjh___0#1 := setup_rjh_~rjh___0#1;havoc setup_rjh__wrappee__Base_~rjh___0#1;setup_rjh__wrappee__Base_~rjh___0#1 := setup_rjh__wrappee__Base_#in~rjh___0#1; {3027#(= |ULTIMATE.start_setup_rjh__wrappee__Base_~rjh___0#1| 2)} is VALID [2022-02-20 18:03:37,542 INFO L272 TraceCheckUtils]: 18: Hoare triple {3027#(= |ULTIMATE.start_setup_rjh__wrappee__Base_~rjh___0#1| 2)} call setClientId(setup_rjh__wrappee__Base_~rjh___0#1, setup_rjh__wrappee__Base_~rjh___0#1); {3077#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} is VALID [2022-02-20 18:03:37,542 INFO L290 TraceCheckUtils]: 19: Hoare triple {3077#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {3079#(= setClientId_~handle |setClientId_#in~handle|)} is VALID [2022-02-20 18:03:37,542 INFO L290 TraceCheckUtils]: 20: Hoare triple {3079#(= setClientId_~handle |setClientId_#in~handle|)} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {3080#(= |setClientId_#in~handle| 1)} is VALID [2022-02-20 18:03:37,542 INFO L290 TraceCheckUtils]: 21: Hoare triple {3080#(= |setClientId_#in~handle| 1)} assume true; {3080#(= |setClientId_#in~handle| 1)} is VALID [2022-02-20 18:03:37,543 INFO L284 TraceCheckUtils]: 22: Hoare quadruple {3080#(= |setClientId_#in~handle| 1)} {3027#(= |ULTIMATE.start_setup_rjh__wrappee__Base_~rjh___0#1| 2)} #1228#return; {3018#false} is VALID [2022-02-20 18:03:37,543 INFO L290 TraceCheckUtils]: 23: Hoare triple {3018#false} assume { :end_inline_setup_rjh__wrappee__Base } true; {3018#false} is VALID [2022-02-20 18:03:37,543 INFO L272 TraceCheckUtils]: 24: Hoare triple {3018#false} call setClientPrivateKey(setup_rjh_~rjh___0#1, 456); {3078#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} is VALID [2022-02-20 18:03:37,544 INFO L290 TraceCheckUtils]: 25: Hoare triple {3078#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {3017#true} is VALID [2022-02-20 18:03:37,544 INFO L290 TraceCheckUtils]: 26: Hoare triple {3017#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {3017#true} is VALID [2022-02-20 18:03:37,544 INFO L290 TraceCheckUtils]: 27: Hoare triple {3017#true} assume true; {3017#true} is VALID [2022-02-20 18:03:37,544 INFO L284 TraceCheckUtils]: 28: Hoare quadruple {3017#true} {3018#false} #1230#return; {3018#false} is VALID [2022-02-20 18:03:37,544 INFO L290 TraceCheckUtils]: 29: Hoare triple {3018#false} assume { :end_inline_setup_rjh } true;setup_~__cil_tmp2~1#1.base, setup_~__cil_tmp2~1#1.offset := 38, 0;havoc setup_#t~nondet98#1;~chuck~0 := 3;assume { :begin_inline_setup_chuck } true;setup_chuck_#in~chuck___0#1 := ~chuck~0;havoc setup_chuck_~chuck___0#1;setup_chuck_~chuck___0#1 := setup_chuck_#in~chuck___0#1;assume { :begin_inline_setup_chuck__wrappee__Base } true;setup_chuck__wrappee__Base_#in~chuck___0#1 := setup_chuck_~chuck___0#1;havoc setup_chuck__wrappee__Base_~chuck___0#1;setup_chuck__wrappee__Base_~chuck___0#1 := setup_chuck__wrappee__Base_#in~chuck___0#1; {3018#false} is VALID [2022-02-20 18:03:37,544 INFO L272 TraceCheckUtils]: 30: Hoare triple {3018#false} call setClientId(setup_chuck__wrappee__Base_~chuck___0#1, setup_chuck__wrappee__Base_~chuck___0#1); {3077#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} is VALID [2022-02-20 18:03:37,544 INFO L290 TraceCheckUtils]: 31: Hoare triple {3077#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {3017#true} is VALID [2022-02-20 18:03:37,544 INFO L290 TraceCheckUtils]: 32: Hoare triple {3017#true} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {3017#true} is VALID [2022-02-20 18:03:37,545 INFO L290 TraceCheckUtils]: 33: Hoare triple {3017#true} assume true; {3017#true} is VALID [2022-02-20 18:03:37,545 INFO L284 TraceCheckUtils]: 34: Hoare quadruple {3017#true} {3018#false} #1232#return; {3018#false} is VALID [2022-02-20 18:03:37,545 INFO L290 TraceCheckUtils]: 35: Hoare triple {3018#false} assume { :end_inline_setup_chuck__wrappee__Base } true; {3018#false} is VALID [2022-02-20 18:03:37,545 INFO L272 TraceCheckUtils]: 36: Hoare triple {3018#false} call setClientPrivateKey(setup_chuck_~chuck___0#1, 789); {3078#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} is VALID [2022-02-20 18:03:37,545 INFO L290 TraceCheckUtils]: 37: Hoare triple {3078#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {3017#true} is VALID [2022-02-20 18:03:37,545 INFO L290 TraceCheckUtils]: 38: Hoare triple {3017#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {3017#true} is VALID [2022-02-20 18:03:37,545 INFO L290 TraceCheckUtils]: 39: Hoare triple {3017#true} assume true; {3017#true} is VALID [2022-02-20 18:03:37,546 INFO L284 TraceCheckUtils]: 40: Hoare quadruple {3017#true} {3018#false} #1234#return; {3018#false} is VALID [2022-02-20 18:03:37,550 INFO L290 TraceCheckUtils]: 41: Hoare triple {3018#false} assume { :end_inline_setup_chuck } true;setup_~__cil_tmp3~4#1.base, setup_~__cil_tmp3~4#1.offset := 39, 0;havoc setup_#t~nondet99#1; {3018#false} is VALID [2022-02-20 18:03:37,550 INFO L290 TraceCheckUtils]: 42: Hoare triple {3018#false} assume { :end_inline_setup } true;assume { :begin_inline_test } true;havoc test_#t~nondet55#1, test_#t~nondet56#1, test_#t~nondet57#1, test_#t~nondet58#1, test_#t~nondet59#1, test_#t~nondet60#1, test_#t~nondet61#1, test_#t~nondet62#1, test_#t~nondet63#1, test_#t~nondet64#1, test_#t~nondet65#1, test_~op1~0#1, test_~op2~0#1, test_~op3~0#1, test_~op4~0#1, test_~op5~0#1, test_~op6~0#1, test_~op7~0#1, test_~op8~0#1, test_~op9~0#1, test_~op10~0#1, test_~op11~0#1, test_~splverifierCounter~0#1, test_~tmp~9#1, test_~tmp___0~3#1, test_~tmp___1~1#1, test_~tmp___2~1#1, test_~tmp___3~0#1, test_~tmp___4~0#1, test_~tmp___5~0#1, test_~tmp___6~0#1, test_~tmp___7~0#1, test_~tmp___8~0#1, test_~tmp___9~0#1;havoc test_~op1~0#1;havoc test_~op2~0#1;havoc test_~op3~0#1;havoc test_~op4~0#1;havoc test_~op5~0#1;havoc test_~op6~0#1;havoc test_~op7~0#1;havoc test_~op8~0#1;havoc test_~op9~0#1;havoc test_~op10~0#1;havoc test_~op11~0#1;havoc test_~splverifierCounter~0#1;havoc test_~tmp~9#1;havoc test_~tmp___0~3#1;havoc test_~tmp___1~1#1;havoc test_~tmp___2~1#1;havoc test_~tmp___3~0#1;havoc test_~tmp___4~0#1;havoc test_~tmp___5~0#1;havoc test_~tmp___6~0#1;havoc test_~tmp___7~0#1;havoc test_~tmp___8~0#1;havoc test_~tmp___9~0#1;test_~op1~0#1 := 0;test_~op2~0#1 := 0;test_~op3~0#1 := 0;test_~op4~0#1 := 0;test_~op5~0#1 := 0;test_~op6~0#1 := 0;test_~op7~0#1 := 0;test_~op8~0#1 := 0;test_~op9~0#1 := 0;test_~op10~0#1 := 0;test_~op11~0#1 := 0;test_~splverifierCounter~0#1 := 0; {3018#false} is VALID [2022-02-20 18:03:37,551 INFO L290 TraceCheckUtils]: 43: Hoare triple {3018#false} assume !false; {3018#false} is VALID [2022-02-20 18:03:37,551 INFO L290 TraceCheckUtils]: 44: Hoare triple {3018#false} assume !(test_~splverifierCounter~0#1 < 4); {3018#false} is VALID [2022-02-20 18:03:37,551 INFO L290 TraceCheckUtils]: 45: Hoare triple {3018#false} assume { :begin_inline_bobToRjh } true;havoc bobToRjh_#t~ret92#1, bobToRjh_#t~ret93#1, bobToRjh_#t~ret94#1, bobToRjh_#t~ret95#1, bobToRjh_~tmp~19#1, bobToRjh_~tmp___0~8#1, bobToRjh_~tmp___1~5#1;havoc bobToRjh_~tmp~19#1;havoc bobToRjh_~tmp___0~8#1;havoc bobToRjh_~tmp___1~5#1;call bobToRjh_#t~ret92#1 := puts(35, 0);assume -2147483648 <= bobToRjh_#t~ret92#1 && bobToRjh_#t~ret92#1 <= 2147483647;havoc bobToRjh_#t~ret92#1; {3018#false} is VALID [2022-02-20 18:03:37,551 INFO L272 TraceCheckUtils]: 46: Hoare triple {3018#false} call sendEmail(~bob~0, ~rjh~0); {3018#false} is VALID [2022-02-20 18:03:37,551 INFO L290 TraceCheckUtils]: 47: Hoare triple {3018#false} ~sender#1 := #in~sender#1;~receiver#1 := #in~receiver#1;havoc ~email~0#1;havoc ~tmp~16#1;assume { :begin_inline_createEmail } true;createEmail_#in~from#1, createEmail_#in~to#1 := 0, ~receiver#1;havoc createEmail_#res#1;havoc createEmail_~from#1, createEmail_~to#1, createEmail_~retValue_acc~16#1, createEmail_~msg~0#1;createEmail_~from#1 := createEmail_#in~from#1;createEmail_~to#1 := createEmail_#in~to#1;havoc createEmail_~retValue_acc~16#1;havoc createEmail_~msg~0#1;createEmail_~msg~0#1 := 1; {3018#false} is VALID [2022-02-20 18:03:37,551 INFO L272 TraceCheckUtils]: 48: Hoare triple {3018#false} call setEmailFrom(createEmail_~msg~0#1, createEmail_~from#1); {3081#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} is VALID [2022-02-20 18:03:37,551 INFO L290 TraceCheckUtils]: 49: Hoare triple {3081#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} ~handle := #in~handle;~value := #in~value; {3017#true} is VALID [2022-02-20 18:03:37,551 INFO L290 TraceCheckUtils]: 50: Hoare triple {3017#true} assume 1 == ~handle;~__ste_email_from0~0 := ~value; {3017#true} is VALID [2022-02-20 18:03:37,552 INFO L290 TraceCheckUtils]: 51: Hoare triple {3017#true} assume true; {3017#true} is VALID [2022-02-20 18:03:37,552 INFO L284 TraceCheckUtils]: 52: Hoare quadruple {3017#true} {3018#false} #1210#return; {3018#false} is VALID [2022-02-20 18:03:37,552 INFO L272 TraceCheckUtils]: 53: Hoare triple {3018#false} call setEmailTo(createEmail_~msg~0#1, createEmail_~to#1); {3082#(and (= ~__ste_email_to0~0 |old(~__ste_email_to0~0)|) (= ~__ste_email_to1~0 |old(~__ste_email_to1~0)|))} is VALID [2022-02-20 18:03:37,552 INFO L290 TraceCheckUtils]: 54: Hoare triple {3082#(and (= ~__ste_email_to0~0 |old(~__ste_email_to0~0)|) (= ~__ste_email_to1~0 |old(~__ste_email_to1~0)|))} ~handle := #in~handle;~value := #in~value; {3017#true} is VALID [2022-02-20 18:03:37,552 INFO L290 TraceCheckUtils]: 55: Hoare triple {3017#true} assume 1 == ~handle;~__ste_email_to0~0 := ~value; {3017#true} is VALID [2022-02-20 18:03:37,552 INFO L290 TraceCheckUtils]: 56: Hoare triple {3017#true} assume true; {3017#true} is VALID [2022-02-20 18:03:37,552 INFO L284 TraceCheckUtils]: 57: Hoare quadruple {3017#true} {3018#false} #1212#return; {3018#false} is VALID [2022-02-20 18:03:37,552 INFO L290 TraceCheckUtils]: 58: Hoare triple {3018#false} createEmail_~retValue_acc~16#1 := createEmail_~msg~0#1;createEmail_#res#1 := createEmail_~retValue_acc~16#1; {3018#false} is VALID [2022-02-20 18:03:37,554 INFO L290 TraceCheckUtils]: 59: Hoare triple {3018#false} #t~ret83#1 := createEmail_#res#1;assume { :end_inline_createEmail } true;assume -2147483648 <= #t~ret83#1 && #t~ret83#1 <= 2147483647;~tmp~16#1 := #t~ret83#1;havoc #t~ret83#1;~email~0#1 := ~tmp~16#1; {3018#false} is VALID [2022-02-20 18:03:37,554 INFO L272 TraceCheckUtils]: 60: Hoare triple {3018#false} call outgoing(~sender#1, ~email~0#1); {3018#false} is VALID [2022-02-20 18:03:37,554 INFO L290 TraceCheckUtils]: 61: Hoare triple {3018#false} ~client#1 := #in~client#1;~msg#1 := #in~msg#1;assume { :begin_inline_sign } true;sign_#in~client#1, sign_#in~msg#1 := ~client#1, ~msg#1;havoc sign_#t~ret85#1, sign_~client#1, sign_~msg#1, sign_~privkey~1#1, sign_~tmp~17#1;sign_~client#1 := sign_#in~client#1;sign_~msg#1 := sign_#in~msg#1;havoc sign_~privkey~1#1;havoc sign_~tmp~17#1; {3018#false} is VALID [2022-02-20 18:03:37,554 INFO L272 TraceCheckUtils]: 62: Hoare triple {3018#false} call sign_#t~ret85#1 := getClientPrivateKey(sign_~client#1); {3017#true} is VALID [2022-02-20 18:03:37,555 INFO L290 TraceCheckUtils]: 63: Hoare triple {3017#true} ~handle := #in~handle;havoc ~retValue_acc~36; {3017#true} is VALID [2022-02-20 18:03:37,555 INFO L290 TraceCheckUtils]: 64: Hoare triple {3017#true} assume 1 == ~handle;~retValue_acc~36 := ~__ste_client_privateKey0~0;#res := ~retValue_acc~36; {3017#true} is VALID [2022-02-20 18:03:37,555 INFO L290 TraceCheckUtils]: 65: Hoare triple {3017#true} assume true; {3017#true} is VALID [2022-02-20 18:03:37,555 INFO L284 TraceCheckUtils]: 66: Hoare quadruple {3017#true} {3018#false} #1150#return; {3018#false} is VALID [2022-02-20 18:03:37,555 INFO L290 TraceCheckUtils]: 67: Hoare triple {3018#false} assume -2147483648 <= sign_#t~ret85#1 && sign_#t~ret85#1 <= 2147483647;sign_~tmp~17#1 := sign_#t~ret85#1;havoc sign_#t~ret85#1;sign_~privkey~1#1 := sign_~tmp~17#1; {3018#false} is VALID [2022-02-20 18:03:37,555 INFO L290 TraceCheckUtils]: 68: Hoare triple {3018#false} assume 0 == sign_~privkey~1#1; {3018#false} is VALID [2022-02-20 18:03:37,555 INFO L290 TraceCheckUtils]: 69: Hoare triple {3018#false} assume { :end_inline_sign } true;assume { :begin_inline_outgoing__wrappee__AddressBook } true;outgoing__wrappee__AddressBook_#in~client#1, outgoing__wrappee__AddressBook_#in~msg#1 := ~client#1, ~msg#1;havoc outgoing__wrappee__AddressBook_#t~ret71#1, outgoing__wrappee__AddressBook_#t~ret72#1, outgoing__wrappee__AddressBook_#t~ret73#1, outgoing__wrappee__AddressBook_#t~ret74#1, outgoing__wrappee__AddressBook_#t~ret75#1, outgoing__wrappee__AddressBook_#t~ret76#1, outgoing__wrappee__AddressBook_~client#1, outgoing__wrappee__AddressBook_~msg#1, outgoing__wrappee__AddressBook_~size~0#1, outgoing__wrappee__AddressBook_~tmp~13#1, outgoing__wrappee__AddressBook_~receiver~1#1, outgoing__wrappee__AddressBook_~tmp___0~5#1, outgoing__wrappee__AddressBook_~second~0#1, outgoing__wrappee__AddressBook_~tmp___1~2#1, outgoing__wrappee__AddressBook_~tmp___2~2#1;outgoing__wrappee__AddressBook_~client#1 := outgoing__wrappee__AddressBook_#in~client#1;outgoing__wrappee__AddressBook_~msg#1 := outgoing__wrappee__AddressBook_#in~msg#1;havoc outgoing__wrappee__AddressBook_~size~0#1;havoc outgoing__wrappee__AddressBook_~tmp~13#1;havoc outgoing__wrappee__AddressBook_~receiver~1#1;havoc outgoing__wrappee__AddressBook_~tmp___0~5#1;havoc outgoing__wrappee__AddressBook_~second~0#1;havoc outgoing__wrappee__AddressBook_~tmp___1~2#1;havoc outgoing__wrappee__AddressBook_~tmp___2~2#1; {3018#false} is VALID [2022-02-20 18:03:37,556 INFO L272 TraceCheckUtils]: 70: Hoare triple {3018#false} call outgoing__wrappee__AddressBook_#t~ret71#1 := getClientAddressBookSize(outgoing__wrappee__AddressBook_~client#1); {3017#true} is VALID [2022-02-20 18:03:37,556 INFO L290 TraceCheckUtils]: 71: Hoare triple {3017#true} ~handle := #in~handle;havoc ~retValue_acc~30; {3017#true} is VALID [2022-02-20 18:03:37,556 INFO L290 TraceCheckUtils]: 72: Hoare triple {3017#true} assume 1 == ~handle;~retValue_acc~30 := ~__ste_ClientAddressBook_size0~0;#res := ~retValue_acc~30; {3017#true} is VALID [2022-02-20 18:03:37,556 INFO L290 TraceCheckUtils]: 73: Hoare triple {3017#true} assume true; {3017#true} is VALID [2022-02-20 18:03:37,556 INFO L284 TraceCheckUtils]: 74: Hoare quadruple {3017#true} {3018#false} #1152#return; {3018#false} is VALID [2022-02-20 18:03:37,557 INFO L290 TraceCheckUtils]: 75: Hoare triple {3018#false} assume -2147483648 <= outgoing__wrappee__AddressBook_#t~ret71#1 && outgoing__wrappee__AddressBook_#t~ret71#1 <= 2147483647;outgoing__wrappee__AddressBook_~tmp~13#1 := outgoing__wrappee__AddressBook_#t~ret71#1;havoc outgoing__wrappee__AddressBook_#t~ret71#1;outgoing__wrappee__AddressBook_~size~0#1 := outgoing__wrappee__AddressBook_~tmp~13#1; {3018#false} is VALID [2022-02-20 18:03:37,557 INFO L290 TraceCheckUtils]: 76: Hoare triple {3018#false} assume !(0 != outgoing__wrappee__AddressBook_~size~0#1); {3018#false} is VALID [2022-02-20 18:03:37,557 INFO L272 TraceCheckUtils]: 77: Hoare triple {3018#false} call outgoing__wrappee__Encrypt(outgoing__wrappee__AddressBook_~client#1, outgoing__wrappee__AddressBook_~msg#1); {3018#false} is VALID [2022-02-20 18:03:37,558 INFO L290 TraceCheckUtils]: 78: Hoare triple {3018#false} ~client#1 := #in~client#1;~msg#1 := #in~msg#1;havoc ~receiver~0#1;havoc ~tmp~12#1;havoc ~pubkey~0#1;havoc ~tmp___0~4#1; {3018#false} is VALID [2022-02-20 18:03:37,558 INFO L272 TraceCheckUtils]: 79: Hoare triple {3018#false} call #t~ret69#1 := getEmailTo(~msg#1); {3017#true} is VALID [2022-02-20 18:03:37,558 INFO L290 TraceCheckUtils]: 80: Hoare triple {3017#true} ~handle := #in~handle;havoc ~retValue_acc~3; {3017#true} is VALID [2022-02-20 18:03:37,558 INFO L290 TraceCheckUtils]: 81: Hoare triple {3017#true} assume 1 == ~handle;~retValue_acc~3 := ~__ste_email_to0~0;#res := ~retValue_acc~3; {3017#true} is VALID [2022-02-20 18:03:37,558 INFO L290 TraceCheckUtils]: 82: Hoare triple {3017#true} assume true; {3017#true} is VALID [2022-02-20 18:03:37,558 INFO L284 TraceCheckUtils]: 83: Hoare quadruple {3017#true} {3018#false} #1170#return; {3018#false} is VALID [2022-02-20 18:03:37,558 INFO L290 TraceCheckUtils]: 84: Hoare triple {3018#false} assume -2147483648 <= #t~ret69#1 && #t~ret69#1 <= 2147483647;~tmp~12#1 := #t~ret69#1;havoc #t~ret69#1;~receiver~0#1 := ~tmp~12#1; {3018#false} is VALID [2022-02-20 18:03:37,558 INFO L272 TraceCheckUtils]: 85: Hoare triple {3018#false} call #t~ret70#1 := findPublicKey(~client#1, ~receiver~0#1); {3017#true} is VALID [2022-02-20 18:03:37,559 INFO L290 TraceCheckUtils]: 86: Hoare triple {3017#true} ~handle := #in~handle;~userid := #in~userid;havoc ~retValue_acc~41; {3017#true} is VALID [2022-02-20 18:03:37,559 INFO L290 TraceCheckUtils]: 87: Hoare triple {3017#true} assume 1 == ~handle; {3017#true} is VALID [2022-02-20 18:03:37,559 INFO L290 TraceCheckUtils]: 88: Hoare triple {3017#true} assume ~userid == ~__ste_Client_Keyring0_User0~0;~retValue_acc~41 := ~__ste_Client_Keyring0_PublicKey0~0;#res := ~retValue_acc~41; {3017#true} is VALID [2022-02-20 18:03:37,559 INFO L290 TraceCheckUtils]: 89: Hoare triple {3017#true} assume true; {3017#true} is VALID [2022-02-20 18:03:37,559 INFO L284 TraceCheckUtils]: 90: Hoare quadruple {3017#true} {3018#false} #1172#return; {3018#false} is VALID [2022-02-20 18:03:37,562 INFO L290 TraceCheckUtils]: 91: Hoare triple {3018#false} assume -2147483648 <= #t~ret70#1 && #t~ret70#1 <= 2147483647;~tmp___0~4#1 := #t~ret70#1;havoc #t~ret70#1;~pubkey~0#1 := ~tmp___0~4#1; {3018#false} is VALID [2022-02-20 18:03:37,563 INFO L290 TraceCheckUtils]: 92: Hoare triple {3018#false} assume !(0 != ~pubkey~0#1); {3018#false} is VALID [2022-02-20 18:03:37,563 INFO L290 TraceCheckUtils]: 93: Hoare triple {3018#false} assume { :begin_inline_outgoing__wrappee__Keys } true;outgoing__wrappee__Keys_#in~client#1, outgoing__wrappee__Keys_#in~msg#1 := ~client#1, ~msg#1;havoc outgoing__wrappee__Keys_#t~ret68#1, outgoing__wrappee__Keys_~client#1, outgoing__wrappee__Keys_~msg#1, outgoing__wrappee__Keys_~tmp~11#1;outgoing__wrappee__Keys_~client#1 := outgoing__wrappee__Keys_#in~client#1;outgoing__wrappee__Keys_~msg#1 := outgoing__wrappee__Keys_#in~msg#1;havoc outgoing__wrappee__Keys_~tmp~11#1;assume { :begin_inline_getClientId } true;getClientId_#in~handle#1 := outgoing__wrappee__Keys_~client#1;havoc getClientId_#res#1;havoc getClientId_~handle#1, getClientId_~retValue_acc~43#1;getClientId_~handle#1 := getClientId_#in~handle#1;havoc getClientId_~retValue_acc~43#1; {3018#false} is VALID [2022-02-20 18:03:37,563 INFO L290 TraceCheckUtils]: 94: Hoare triple {3018#false} assume 1 == getClientId_~handle#1;getClientId_~retValue_acc~43#1 := ~__ste_client_idCounter0~0;getClientId_#res#1 := getClientId_~retValue_acc~43#1; {3018#false} is VALID [2022-02-20 18:03:37,563 INFO L290 TraceCheckUtils]: 95: Hoare triple {3018#false} outgoing__wrappee__Keys_#t~ret68#1 := getClientId_#res#1;assume { :end_inline_getClientId } true;assume -2147483648 <= outgoing__wrappee__Keys_#t~ret68#1 && outgoing__wrappee__Keys_#t~ret68#1 <= 2147483647;outgoing__wrappee__Keys_~tmp~11#1 := outgoing__wrappee__Keys_#t~ret68#1;havoc outgoing__wrappee__Keys_#t~ret68#1; {3018#false} is VALID [2022-02-20 18:03:37,563 INFO L272 TraceCheckUtils]: 96: Hoare triple {3018#false} call setEmailFrom(outgoing__wrappee__Keys_~msg#1, outgoing__wrappee__Keys_~tmp~11#1); {3081#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} is VALID [2022-02-20 18:03:37,563 INFO L290 TraceCheckUtils]: 97: Hoare triple {3081#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} ~handle := #in~handle;~value := #in~value; {3017#true} is VALID [2022-02-20 18:03:37,564 INFO L290 TraceCheckUtils]: 98: Hoare triple {3017#true} assume 1 == ~handle;~__ste_email_from0~0 := ~value; {3017#true} is VALID [2022-02-20 18:03:37,564 INFO L290 TraceCheckUtils]: 99: Hoare triple {3017#true} assume true; {3017#true} is VALID [2022-02-20 18:03:37,564 INFO L284 TraceCheckUtils]: 100: Hoare quadruple {3017#true} {3018#false} #1178#return; {3018#false} is VALID [2022-02-20 18:03:37,564 INFO L290 TraceCheckUtils]: 101: Hoare triple {3018#false} assume { :begin_inline_mail } true;mail_#in~client#1, mail_#in~msg#1 := outgoing__wrappee__Keys_~client#1, outgoing__wrappee__Keys_~msg#1;havoc mail_#t~ret66#1, mail_#t~ret67#1, mail_~client#1, mail_~msg#1, mail_~__utac__ad__arg1~0#1, mail_~tmp~10#1;mail_~client#1 := mail_#in~client#1;mail_~msg#1 := mail_#in~msg#1;havoc mail_~__utac__ad__arg1~0#1;havoc mail_~tmp~10#1;mail_~__utac__ad__arg1~0#1 := mail_~msg#1;assume { :begin_inline___utac_acc__EncryptAutoResponder_spec__2 } true;__utac_acc__EncryptAutoResponder_spec__2_#in~msg#1 := mail_~__utac__ad__arg1~0#1;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1, __utac_acc__EncryptAutoResponder_spec__2_#t~nondet29#1, __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1, __utac_acc__EncryptAutoResponder_spec__2_~msg#1, __utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.base, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.offset;__utac_acc__EncryptAutoResponder_spec__2_~msg#1 := __utac_acc__EncryptAutoResponder_spec__2_#in~msg#1;havoc __utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1;havoc __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.base, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.offset;call __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1 := puts(15, 0);assume -2147483648 <= __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1 && __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1 <= 2147483647;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1;__utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.base, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.offset := 16, 0;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~nondet29#1; {3018#false} is VALID [2022-02-20 18:03:37,564 INFO L290 TraceCheckUtils]: 102: Hoare triple {3018#false} assume 0 != ~in_encrypted~0; {3018#false} is VALID [2022-02-20 18:03:37,564 INFO L272 TraceCheckUtils]: 103: Hoare triple {3018#false} call __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1 := isEncrypted(__utac_acc__EncryptAutoResponder_spec__2_~msg#1); {3017#true} is VALID [2022-02-20 18:03:37,564 INFO L290 TraceCheckUtils]: 104: Hoare triple {3017#true} ~handle := #in~handle;havoc ~retValue_acc~6; {3017#true} is VALID [2022-02-20 18:03:37,564 INFO L290 TraceCheckUtils]: 105: Hoare triple {3017#true} assume 1 == ~handle;~retValue_acc~6 := ~__ste_email_isEncrypted0~0;#res := ~retValue_acc~6; {3017#true} is VALID [2022-02-20 18:03:37,565 INFO L290 TraceCheckUtils]: 106: Hoare triple {3017#true} assume true; {3017#true} is VALID [2022-02-20 18:03:37,565 INFO L284 TraceCheckUtils]: 107: Hoare quadruple {3017#true} {3018#false} #1180#return; {3018#false} is VALID [2022-02-20 18:03:37,565 INFO L290 TraceCheckUtils]: 108: Hoare triple {3018#false} assume -2147483648 <= __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1 && __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1 <= 2147483647;__utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1 := __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1; {3018#false} is VALID [2022-02-20 18:03:37,565 INFO L290 TraceCheckUtils]: 109: Hoare triple {3018#false} assume !(0 != __utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1);assume { :begin_inline___automaton_fail } true; {3018#false} is VALID [2022-02-20 18:03:37,565 INFO L290 TraceCheckUtils]: 110: Hoare triple {3018#false} assume !false; {3018#false} is VALID [2022-02-20 18:03:37,573 INFO L134 CoverageAnalysis]: Checked inductivity of 28 backedges. 3 proven. 3 refuted. 0 times theorem prover too weak. 22 trivial. 0 not checked. [2022-02-20 18:03:37,573 INFO L144 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-02-20 18:03:37,573 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [58714821] [2022-02-20 18:03:37,574 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleSmtInterpolCraig [58714821] provided 0 perfect and 1 imperfect interpolant sequences [2022-02-20 18:03:37,574 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [1554473942] [2022-02-20 18:03:37,574 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 18:03:37,574 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-02-20 18:03:37,574 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-02-20 18:03:37,584 INFO L229 MonitoredProcess]: Starting monitored process 3 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2022-02-20 18:03:37,599 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (3)] Waiting until timeout for monitored process [2022-02-20 18:03:37,840 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:37,845 INFO L263 TraceCheckSpWp]: Trace formula consists of 1111 conjuncts, 2 conjunts are in the unsatisfiable core [2022-02-20 18:03:37,931 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:37,934 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-02-20 18:03:38,148 INFO L290 TraceCheckUtils]: 0: Hoare triple {3017#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(28, 2);call #Ultimate.allocInit(12, 3);call #Ultimate.allocInit(10, 4);call #Ultimate.allocInit(12, 5);call #Ultimate.allocInit(10, 6);call #Ultimate.allocInit(18, 7);call #Ultimate.allocInit(16, 8);call #Ultimate.allocInit(21, 9);call #Ultimate.allocInit(13, 10);call #Ultimate.allocInit(16, 11);call #Ultimate.allocInit(25, 12);call #Ultimate.allocInit(17, 13);call #Ultimate.allocInit(17, 14);call #Ultimate.allocInit(13, 15);call #Ultimate.allocInit(17, 16);call #Ultimate.allocInit(30, 17);call #Ultimate.allocInit(9, 18);call #Ultimate.allocInit(21, 19);call #Ultimate.allocInit(30, 20);call #Ultimate.allocInit(9, 21);call #Ultimate.allocInit(21, 22);call #Ultimate.allocInit(30, 23);call #Ultimate.allocInit(9, 24);call #Ultimate.allocInit(25, 25);call #Ultimate.allocInit(30, 26);call #Ultimate.allocInit(9, 27);call #Ultimate.allocInit(25, 28);call #Ultimate.allocInit(4, 29);call write~init~int(37, 29, 0, 1);call write~init~int(115, 29, 1, 1);call write~init~int(10, 29, 2, 1);call write~init~int(0, 29, 3, 1);call #Ultimate.allocInit(10, 30);call #Ultimate.allocInit(34, 31);call #Ultimate.allocInit(30, 32);call #Ultimate.allocInit(16, 33);call #Ultimate.allocInit(20, 34);call #Ultimate.allocInit(44, 35);call #Ultimate.allocInit(44, 36);call #Ultimate.allocInit(9, 37);call #Ultimate.allocInit(9, 38);call #Ultimate.allocInit(11, 39);call #Ultimate.allocInit(19, 40);call #Ultimate.allocInit(4, 41);call write~init~int(37, 41, 0, 1);call write~init~int(100, 41, 1, 1);call write~init~int(10, 41, 2, 1);call write~init~int(0, 41, 3, 1);call #Ultimate.allocInit(4, 42);call write~init~int(37, 42, 0, 1);call write~init~int(100, 42, 1, 1);call write~init~int(10, 42, 2, 1);call write~init~int(0, 42, 3, 1);~__ste_Email_counter~0 := 0;~__ste_email_id0~0 := 0;~__ste_email_id1~0 := 0;~__ste_email_from0~0 := 0;~__ste_email_from1~0 := 0;~__ste_email_to0~0 := 0;~__ste_email_to1~0 := 0;~__ste_email_subject0~0.base, ~__ste_email_subject0~0.offset := 0, 0;~__ste_email_subject1~0.base, ~__ste_email_subject1~0.offset := 0, 0;~__ste_email_body0~0.base, ~__ste_email_body0~0.offset := 0, 0;~__ste_email_body1~0.base, ~__ste_email_body1~0.offset := 0, 0;~__ste_email_isEncrypted0~0 := 0;~__ste_email_isEncrypted1~0 := 0;~__ste_email_encryptionKey0~0 := 0;~__ste_email_encryptionKey1~0 := 0;~__ste_email_isSigned0~0 := 0;~__ste_email_isSigned1~0 := 0;~__ste_email_signKey0~0 := 0;~__ste_email_signKey1~0 := 0;~__ste_email_isSignatureVerified0~0 := 0;~__ste_email_isSignatureVerified1~0 := 0;~__SELECTED_FEATURE_Base~0 := 0;~__SELECTED_FEATURE_Keys~0 := 0;~__SELECTED_FEATURE_Encrypt~0 := 0;~__SELECTED_FEATURE_AutoResponder~0 := 0;~__SELECTED_FEATURE_AddressBook~0 := 0;~__SELECTED_FEATURE_Sign~0 := 0;~__SELECTED_FEATURE_Forward~0 := 0;~__SELECTED_FEATURE_Verify~0 := 0;~__SELECTED_FEATURE_Decrypt~0 := 0;~__GUIDSL_ROOT_PRODUCTION~0 := 0;~__GUIDSL_NON_TERMINAL_main~0 := 0;~in_encrypted~0 := 0;~head~0.base, ~head~0.offset := 0, 0;~queue_empty~0 := 1;~queued_message~0 := 0;~queued_client~0 := 0;~bob~0 := 0;~rjh~0 := 0;~chuck~0 := 0;~__ste_Client_counter~0 := 0;~__ste_client_name0~0.base, ~__ste_client_name0~0.offset := 0, 0;~__ste_client_name1~0.base, ~__ste_client_name1~0.offset := 0, 0;~__ste_client_name2~0.base, ~__ste_client_name2~0.offset := 0, 0;~__ste_client_outbuffer0~0 := 0;~__ste_client_outbuffer1~0 := 0;~__ste_client_outbuffer2~0 := 0;~__ste_client_outbuffer3~0 := 0;~__ste_ClientAddressBook_size0~0 := 0;~__ste_ClientAddressBook_size1~0 := 0;~__ste_ClientAddressBook_size2~0 := 0;~__ste_Client_AddressBook0_Alias0~0 := 0;~__ste_Client_AddressBook0_Alias1~0 := 0;~__ste_Client_AddressBook0_Alias2~0 := 0;~__ste_Client_AddressBook1_Alias0~0 := 0;~__ste_Client_AddressBook1_Alias1~0 := 0;~__ste_Client_AddressBook1_Alias2~0 := 0;~__ste_Client_AddressBook2_Alias0~0 := 0;~__ste_Client_AddressBook2_Alias1~0 := 0;~__ste_Client_AddressBook2_Alias2~0 := 0;~__ste_Client_AddressBook0_Address0~0 := 0;~__ste_Client_AddressBook0_Address1~0 := 0;~__ste_Client_AddressBook0_Address2~0 := 0;~__ste_Client_AddressBook1_Address0~0 := 0;~__ste_Client_AddressBook1_Address1~0 := 0;~__ste_Client_AddressBook1_Address2~0 := 0;~__ste_Client_AddressBook2_Address0~0 := 0;~__ste_Client_AddressBook2_Address1~0 := 0;~__ste_Client_AddressBook2_Address2~0 := 0;~__ste_client_autoResponse0~0 := 0;~__ste_client_autoResponse1~0 := 0;~__ste_client_autoResponse2~0 := 0;~__ste_client_privateKey0~0 := 0;~__ste_client_privateKey1~0 := 0;~__ste_client_privateKey2~0 := 0;~__ste_ClientKeyring_size0~0 := 0;~__ste_ClientKeyring_size1~0 := 0;~__ste_ClientKeyring_size2~0 := 0;~__ste_Client_Keyring0_User0~0 := 0;~__ste_Client_Keyring0_User1~0 := 0;~__ste_Client_Keyring0_User2~0 := 0;~__ste_Client_Keyring1_User0~0 := 0;~__ste_Client_Keyring1_User1~0 := 0;~__ste_Client_Keyring1_User2~0 := 0;~__ste_Client_Keyring2_User0~0 := 0;~__ste_Client_Keyring2_User1~0 := 0;~__ste_Client_Keyring2_User2~0 := 0;~__ste_Client_Keyring0_PublicKey0~0 := 0;~__ste_Client_Keyring0_PublicKey1~0 := 0;~__ste_Client_Keyring0_PublicKey2~0 := 0;~__ste_Client_Keyring1_PublicKey0~0 := 0;~__ste_Client_Keyring1_PublicKey1~0 := 0;~__ste_Client_Keyring1_PublicKey2~0 := 0;~__ste_Client_Keyring2_PublicKey0~0 := 0;~__ste_Client_Keyring2_PublicKey1~0 := 0;~__ste_Client_Keyring2_PublicKey2~0 := 0;~__ste_client_forwardReceiver0~0 := 0;~__ste_client_forwardReceiver1~0 := 0;~__ste_client_forwardReceiver2~0 := 0;~__ste_client_forwardReceiver3~0 := 0;~__ste_client_idCounter0~0 := 0;~__ste_client_idCounter1~0 := 0;~__ste_client_idCounter2~0 := 0; {3017#true} is VALID [2022-02-20 18:03:38,148 INFO L290 TraceCheckUtils]: 1: Hoare triple {3017#true} assume { :end_inline_ULTIMATE.init } true;assume { :begin_inline_main } true;havoc main_#res#1;havoc main_#t~nondet100#1, main_#t~ret101#1, main_~retValue_acc~26#1, main_~tmp~20#1;assume -2147483648 <= main_#t~nondet100#1 && main_#t~nondet100#1 <= 2147483647;main_~retValue_acc~26#1 := main_#t~nondet100#1;havoc main_#t~nondet100#1;havoc main_~tmp~20#1;assume { :begin_inline_select_helpers } true; {3017#true} is VALID [2022-02-20 18:03:38,149 INFO L290 TraceCheckUtils]: 2: Hoare triple {3017#true} assume { :end_inline_select_helpers } true;assume { :begin_inline_select_features } true; {3017#true} is VALID [2022-02-20 18:03:38,149 INFO L290 TraceCheckUtils]: 3: Hoare triple {3017#true} assume { :end_inline_select_features } true;assume { :begin_inline_valid_product } true;havoc valid_product_#res#1;havoc valid_product_~retValue_acc~12#1;havoc valid_product_~retValue_acc~12#1;valid_product_~retValue_acc~12#1 := 1;valid_product_#res#1 := valid_product_~retValue_acc~12#1; {3017#true} is VALID [2022-02-20 18:03:38,149 INFO L290 TraceCheckUtils]: 4: Hoare triple {3017#true} main_#t~ret101#1 := valid_product_#res#1;assume { :end_inline_valid_product } true;assume -2147483648 <= main_#t~ret101#1 && main_#t~ret101#1 <= 2147483647;main_~tmp~20#1 := main_#t~ret101#1;havoc main_#t~ret101#1; {3017#true} is VALID [2022-02-20 18:03:38,149 INFO L290 TraceCheckUtils]: 5: Hoare triple {3017#true} assume 0 != main_~tmp~20#1;assume { :begin_inline_setup } true;havoc setup_#t~nondet97#1, setup_#t~nondet98#1, setup_#t~nondet99#1, setup_~__cil_tmp1~0#1.base, setup_~__cil_tmp1~0#1.offset, setup_~__cil_tmp2~1#1.base, setup_~__cil_tmp2~1#1.offset, setup_~__cil_tmp3~4#1.base, setup_~__cil_tmp3~4#1.offset;havoc setup_~__cil_tmp1~0#1.base, setup_~__cil_tmp1~0#1.offset;havoc setup_~__cil_tmp2~1#1.base, setup_~__cil_tmp2~1#1.offset;havoc setup_~__cil_tmp3~4#1.base, setup_~__cil_tmp3~4#1.offset;~bob~0 := 1;assume { :begin_inline_setup_bob } true;setup_bob_#in~bob___0#1 := ~bob~0;havoc setup_bob_~bob___0#1;setup_bob_~bob___0#1 := setup_bob_#in~bob___0#1;assume { :begin_inline_setup_bob__wrappee__Base } true;setup_bob__wrappee__Base_#in~bob___0#1 := setup_bob_~bob___0#1;havoc setup_bob__wrappee__Base_~bob___0#1;setup_bob__wrappee__Base_~bob___0#1 := setup_bob__wrappee__Base_#in~bob___0#1; {3017#true} is VALID [2022-02-20 18:03:38,149 INFO L272 TraceCheckUtils]: 6: Hoare triple {3017#true} call setClientId(setup_bob__wrappee__Base_~bob___0#1, setup_bob__wrappee__Base_~bob___0#1); {3017#true} is VALID [2022-02-20 18:03:38,149 INFO L290 TraceCheckUtils]: 7: Hoare triple {3017#true} ~handle := #in~handle;~value := #in~value; {3017#true} is VALID [2022-02-20 18:03:38,149 INFO L290 TraceCheckUtils]: 8: Hoare triple {3017#true} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {3017#true} is VALID [2022-02-20 18:03:38,149 INFO L290 TraceCheckUtils]: 9: Hoare triple {3017#true} assume true; {3017#true} is VALID [2022-02-20 18:03:38,149 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {3017#true} {3017#true} #1224#return; {3017#true} is VALID [2022-02-20 18:03:38,149 INFO L290 TraceCheckUtils]: 11: Hoare triple {3017#true} assume { :end_inline_setup_bob__wrappee__Base } true; {3017#true} is VALID [2022-02-20 18:03:38,149 INFO L272 TraceCheckUtils]: 12: Hoare triple {3017#true} call setClientPrivateKey(setup_bob_~bob___0#1, 123); {3017#true} is VALID [2022-02-20 18:03:38,149 INFO L290 TraceCheckUtils]: 13: Hoare triple {3017#true} ~handle := #in~handle;~value := #in~value; {3017#true} is VALID [2022-02-20 18:03:38,149 INFO L290 TraceCheckUtils]: 14: Hoare triple {3017#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {3017#true} is VALID [2022-02-20 18:03:38,149 INFO L290 TraceCheckUtils]: 15: Hoare triple {3017#true} assume true; {3017#true} is VALID [2022-02-20 18:03:38,150 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {3017#true} {3017#true} #1226#return; {3017#true} is VALID [2022-02-20 18:03:38,150 INFO L290 TraceCheckUtils]: 17: Hoare triple {3017#true} assume { :end_inline_setup_bob } true;setup_~__cil_tmp1~0#1.base, setup_~__cil_tmp1~0#1.offset := 37, 0;havoc setup_#t~nondet97#1;~rjh~0 := 2;assume { :begin_inline_setup_rjh } true;setup_rjh_#in~rjh___0#1 := ~rjh~0;havoc setup_rjh_~rjh___0#1;setup_rjh_~rjh___0#1 := setup_rjh_#in~rjh___0#1;assume { :begin_inline_setup_rjh__wrappee__Base } true;setup_rjh__wrappee__Base_#in~rjh___0#1 := setup_rjh_~rjh___0#1;havoc setup_rjh__wrappee__Base_~rjh___0#1;setup_rjh__wrappee__Base_~rjh___0#1 := setup_rjh__wrappee__Base_#in~rjh___0#1; {3017#true} is VALID [2022-02-20 18:03:38,150 INFO L272 TraceCheckUtils]: 18: Hoare triple {3017#true} call setClientId(setup_rjh__wrappee__Base_~rjh___0#1, setup_rjh__wrappee__Base_~rjh___0#1); {3017#true} is VALID [2022-02-20 18:03:38,150 INFO L290 TraceCheckUtils]: 19: Hoare triple {3017#true} ~handle := #in~handle;~value := #in~value; {3017#true} is VALID [2022-02-20 18:03:38,150 INFO L290 TraceCheckUtils]: 20: Hoare triple {3017#true} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {3017#true} is VALID [2022-02-20 18:03:38,150 INFO L290 TraceCheckUtils]: 21: Hoare triple {3017#true} assume true; {3017#true} is VALID [2022-02-20 18:03:38,150 INFO L284 TraceCheckUtils]: 22: Hoare quadruple {3017#true} {3017#true} #1228#return; {3017#true} is VALID [2022-02-20 18:03:38,150 INFO L290 TraceCheckUtils]: 23: Hoare triple {3017#true} assume { :end_inline_setup_rjh__wrappee__Base } true; {3017#true} is VALID [2022-02-20 18:03:38,150 INFO L272 TraceCheckUtils]: 24: Hoare triple {3017#true} call setClientPrivateKey(setup_rjh_~rjh___0#1, 456); {3017#true} is VALID [2022-02-20 18:03:38,150 INFO L290 TraceCheckUtils]: 25: Hoare triple {3017#true} ~handle := #in~handle;~value := #in~value; {3017#true} is VALID [2022-02-20 18:03:38,150 INFO L290 TraceCheckUtils]: 26: Hoare triple {3017#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {3017#true} is VALID [2022-02-20 18:03:38,150 INFO L290 TraceCheckUtils]: 27: Hoare triple {3017#true} assume true; {3017#true} is VALID [2022-02-20 18:03:38,151 INFO L284 TraceCheckUtils]: 28: Hoare quadruple {3017#true} {3017#true} #1230#return; {3017#true} is VALID [2022-02-20 18:03:38,151 INFO L290 TraceCheckUtils]: 29: Hoare triple {3017#true} assume { :end_inline_setup_rjh } true;setup_~__cil_tmp2~1#1.base, setup_~__cil_tmp2~1#1.offset := 38, 0;havoc setup_#t~nondet98#1;~chuck~0 := 3;assume { :begin_inline_setup_chuck } true;setup_chuck_#in~chuck___0#1 := ~chuck~0;havoc setup_chuck_~chuck___0#1;setup_chuck_~chuck___0#1 := setup_chuck_#in~chuck___0#1;assume { :begin_inline_setup_chuck__wrappee__Base } true;setup_chuck__wrappee__Base_#in~chuck___0#1 := setup_chuck_~chuck___0#1;havoc setup_chuck__wrappee__Base_~chuck___0#1;setup_chuck__wrappee__Base_~chuck___0#1 := setup_chuck__wrappee__Base_#in~chuck___0#1; {3017#true} is VALID [2022-02-20 18:03:38,151 INFO L272 TraceCheckUtils]: 30: Hoare triple {3017#true} call setClientId(setup_chuck__wrappee__Base_~chuck___0#1, setup_chuck__wrappee__Base_~chuck___0#1); {3017#true} is VALID [2022-02-20 18:03:38,151 INFO L290 TraceCheckUtils]: 31: Hoare triple {3017#true} ~handle := #in~handle;~value := #in~value; {3017#true} is VALID [2022-02-20 18:03:38,151 INFO L290 TraceCheckUtils]: 32: Hoare triple {3017#true} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {3017#true} is VALID [2022-02-20 18:03:38,151 INFO L290 TraceCheckUtils]: 33: Hoare triple {3017#true} assume true; {3017#true} is VALID [2022-02-20 18:03:38,151 INFO L284 TraceCheckUtils]: 34: Hoare quadruple {3017#true} {3017#true} #1232#return; {3017#true} is VALID [2022-02-20 18:03:38,151 INFO L290 TraceCheckUtils]: 35: Hoare triple {3017#true} assume { :end_inline_setup_chuck__wrappee__Base } true; {3017#true} is VALID [2022-02-20 18:03:38,151 INFO L272 TraceCheckUtils]: 36: Hoare triple {3017#true} call setClientPrivateKey(setup_chuck_~chuck___0#1, 789); {3017#true} is VALID [2022-02-20 18:03:38,151 INFO L290 TraceCheckUtils]: 37: Hoare triple {3017#true} ~handle := #in~handle;~value := #in~value; {3017#true} is VALID [2022-02-20 18:03:38,151 INFO L290 TraceCheckUtils]: 38: Hoare triple {3017#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {3017#true} is VALID [2022-02-20 18:03:38,151 INFO L290 TraceCheckUtils]: 39: Hoare triple {3017#true} assume true; {3017#true} is VALID [2022-02-20 18:03:38,151 INFO L284 TraceCheckUtils]: 40: Hoare quadruple {3017#true} {3017#true} #1234#return; {3017#true} is VALID [2022-02-20 18:03:38,152 INFO L290 TraceCheckUtils]: 41: Hoare triple {3017#true} assume { :end_inline_setup_chuck } true;setup_~__cil_tmp3~4#1.base, setup_~__cil_tmp3~4#1.offset := 39, 0;havoc setup_#t~nondet99#1; {3017#true} is VALID [2022-02-20 18:03:38,153 INFO L290 TraceCheckUtils]: 42: Hoare triple {3017#true} assume { :end_inline_setup } true;assume { :begin_inline_test } true;havoc test_#t~nondet55#1, test_#t~nondet56#1, test_#t~nondet57#1, test_#t~nondet58#1, test_#t~nondet59#1, test_#t~nondet60#1, test_#t~nondet61#1, test_#t~nondet62#1, test_#t~nondet63#1, test_#t~nondet64#1, test_#t~nondet65#1, test_~op1~0#1, test_~op2~0#1, test_~op3~0#1, test_~op4~0#1, test_~op5~0#1, test_~op6~0#1, test_~op7~0#1, test_~op8~0#1, test_~op9~0#1, test_~op10~0#1, test_~op11~0#1, test_~splverifierCounter~0#1, test_~tmp~9#1, test_~tmp___0~3#1, test_~tmp___1~1#1, test_~tmp___2~1#1, test_~tmp___3~0#1, test_~tmp___4~0#1, test_~tmp___5~0#1, test_~tmp___6~0#1, test_~tmp___7~0#1, test_~tmp___8~0#1, test_~tmp___9~0#1;havoc test_~op1~0#1;havoc test_~op2~0#1;havoc test_~op3~0#1;havoc test_~op4~0#1;havoc test_~op5~0#1;havoc test_~op6~0#1;havoc test_~op7~0#1;havoc test_~op8~0#1;havoc test_~op9~0#1;havoc test_~op10~0#1;havoc test_~op11~0#1;havoc test_~splverifierCounter~0#1;havoc test_~tmp~9#1;havoc test_~tmp___0~3#1;havoc test_~tmp___1~1#1;havoc test_~tmp___2~1#1;havoc test_~tmp___3~0#1;havoc test_~tmp___4~0#1;havoc test_~tmp___5~0#1;havoc test_~tmp___6~0#1;havoc test_~tmp___7~0#1;havoc test_~tmp___8~0#1;havoc test_~tmp___9~0#1;test_~op1~0#1 := 0;test_~op2~0#1 := 0;test_~op3~0#1 := 0;test_~op4~0#1 := 0;test_~op5~0#1 := 0;test_~op6~0#1 := 0;test_~op7~0#1 := 0;test_~op8~0#1 := 0;test_~op9~0#1 := 0;test_~op10~0#1 := 0;test_~op11~0#1 := 0;test_~splverifierCounter~0#1 := 0; {3212#(<= |ULTIMATE.start_test_~splverifierCounter~0#1| 0)} is VALID [2022-02-20 18:03:38,153 INFO L290 TraceCheckUtils]: 43: Hoare triple {3212#(<= |ULTIMATE.start_test_~splverifierCounter~0#1| 0)} assume !false; {3212#(<= |ULTIMATE.start_test_~splverifierCounter~0#1| 0)} is VALID [2022-02-20 18:03:38,154 INFO L290 TraceCheckUtils]: 44: Hoare triple {3212#(<= |ULTIMATE.start_test_~splverifierCounter~0#1| 0)} assume !(test_~splverifierCounter~0#1 < 4); {3018#false} is VALID [2022-02-20 18:03:38,154 INFO L290 TraceCheckUtils]: 45: Hoare triple {3018#false} assume { :begin_inline_bobToRjh } true;havoc bobToRjh_#t~ret92#1, bobToRjh_#t~ret93#1, bobToRjh_#t~ret94#1, bobToRjh_#t~ret95#1, bobToRjh_~tmp~19#1, bobToRjh_~tmp___0~8#1, bobToRjh_~tmp___1~5#1;havoc bobToRjh_~tmp~19#1;havoc bobToRjh_~tmp___0~8#1;havoc bobToRjh_~tmp___1~5#1;call bobToRjh_#t~ret92#1 := puts(35, 0);assume -2147483648 <= bobToRjh_#t~ret92#1 && bobToRjh_#t~ret92#1 <= 2147483647;havoc bobToRjh_#t~ret92#1; {3018#false} is VALID [2022-02-20 18:03:38,154 INFO L272 TraceCheckUtils]: 46: Hoare triple {3018#false} call sendEmail(~bob~0, ~rjh~0); {3018#false} is VALID [2022-02-20 18:03:38,154 INFO L290 TraceCheckUtils]: 47: Hoare triple {3018#false} ~sender#1 := #in~sender#1;~receiver#1 := #in~receiver#1;havoc ~email~0#1;havoc ~tmp~16#1;assume { :begin_inline_createEmail } true;createEmail_#in~from#1, createEmail_#in~to#1 := 0, ~receiver#1;havoc createEmail_#res#1;havoc createEmail_~from#1, createEmail_~to#1, createEmail_~retValue_acc~16#1, createEmail_~msg~0#1;createEmail_~from#1 := createEmail_#in~from#1;createEmail_~to#1 := createEmail_#in~to#1;havoc createEmail_~retValue_acc~16#1;havoc createEmail_~msg~0#1;createEmail_~msg~0#1 := 1; {3018#false} is VALID [2022-02-20 18:03:38,154 INFO L272 TraceCheckUtils]: 48: Hoare triple {3018#false} call setEmailFrom(createEmail_~msg~0#1, createEmail_~from#1); {3018#false} is VALID [2022-02-20 18:03:38,154 INFO L290 TraceCheckUtils]: 49: Hoare triple {3018#false} ~handle := #in~handle;~value := #in~value; {3018#false} is VALID [2022-02-20 18:03:38,154 INFO L290 TraceCheckUtils]: 50: Hoare triple {3018#false} assume 1 == ~handle;~__ste_email_from0~0 := ~value; {3018#false} is VALID [2022-02-20 18:03:38,154 INFO L290 TraceCheckUtils]: 51: Hoare triple {3018#false} assume true; {3018#false} is VALID [2022-02-20 18:03:38,154 INFO L284 TraceCheckUtils]: 52: Hoare quadruple {3018#false} {3018#false} #1210#return; {3018#false} is VALID [2022-02-20 18:03:38,154 INFO L272 TraceCheckUtils]: 53: Hoare triple {3018#false} call setEmailTo(createEmail_~msg~0#1, createEmail_~to#1); {3018#false} is VALID [2022-02-20 18:03:38,154 INFO L290 TraceCheckUtils]: 54: Hoare triple {3018#false} ~handle := #in~handle;~value := #in~value; {3018#false} is VALID [2022-02-20 18:03:38,154 INFO L290 TraceCheckUtils]: 55: Hoare triple {3018#false} assume 1 == ~handle;~__ste_email_to0~0 := ~value; {3018#false} is VALID [2022-02-20 18:03:38,155 INFO L290 TraceCheckUtils]: 56: Hoare triple {3018#false} assume true; {3018#false} is VALID [2022-02-20 18:03:38,155 INFO L284 TraceCheckUtils]: 57: Hoare quadruple {3018#false} {3018#false} #1212#return; {3018#false} is VALID [2022-02-20 18:03:38,155 INFO L290 TraceCheckUtils]: 58: Hoare triple {3018#false} createEmail_~retValue_acc~16#1 := createEmail_~msg~0#1;createEmail_#res#1 := createEmail_~retValue_acc~16#1; {3018#false} is VALID [2022-02-20 18:03:38,155 INFO L290 TraceCheckUtils]: 59: Hoare triple {3018#false} #t~ret83#1 := createEmail_#res#1;assume { :end_inline_createEmail } true;assume -2147483648 <= #t~ret83#1 && #t~ret83#1 <= 2147483647;~tmp~16#1 := #t~ret83#1;havoc #t~ret83#1;~email~0#1 := ~tmp~16#1; {3018#false} is VALID [2022-02-20 18:03:38,155 INFO L272 TraceCheckUtils]: 60: Hoare triple {3018#false} call outgoing(~sender#1, ~email~0#1); {3018#false} is VALID [2022-02-20 18:03:38,155 INFO L290 TraceCheckUtils]: 61: Hoare triple {3018#false} ~client#1 := #in~client#1;~msg#1 := #in~msg#1;assume { :begin_inline_sign } true;sign_#in~client#1, sign_#in~msg#1 := ~client#1, ~msg#1;havoc sign_#t~ret85#1, sign_~client#1, sign_~msg#1, sign_~privkey~1#1, sign_~tmp~17#1;sign_~client#1 := sign_#in~client#1;sign_~msg#1 := sign_#in~msg#1;havoc sign_~privkey~1#1;havoc sign_~tmp~17#1; {3018#false} is VALID [2022-02-20 18:03:38,155 INFO L272 TraceCheckUtils]: 62: Hoare triple {3018#false} call sign_#t~ret85#1 := getClientPrivateKey(sign_~client#1); {3018#false} is VALID [2022-02-20 18:03:38,155 INFO L290 TraceCheckUtils]: 63: Hoare triple {3018#false} ~handle := #in~handle;havoc ~retValue_acc~36; {3018#false} is VALID [2022-02-20 18:03:38,155 INFO L290 TraceCheckUtils]: 64: Hoare triple {3018#false} assume 1 == ~handle;~retValue_acc~36 := ~__ste_client_privateKey0~0;#res := ~retValue_acc~36; {3018#false} is VALID [2022-02-20 18:03:38,155 INFO L290 TraceCheckUtils]: 65: Hoare triple {3018#false} assume true; {3018#false} is VALID [2022-02-20 18:03:38,155 INFO L284 TraceCheckUtils]: 66: Hoare quadruple {3018#false} {3018#false} #1150#return; {3018#false} is VALID [2022-02-20 18:03:38,156 INFO L290 TraceCheckUtils]: 67: Hoare triple {3018#false} assume -2147483648 <= sign_#t~ret85#1 && sign_#t~ret85#1 <= 2147483647;sign_~tmp~17#1 := sign_#t~ret85#1;havoc sign_#t~ret85#1;sign_~privkey~1#1 := sign_~tmp~17#1; {3018#false} is VALID [2022-02-20 18:03:38,156 INFO L290 TraceCheckUtils]: 68: Hoare triple {3018#false} assume 0 == sign_~privkey~1#1; {3018#false} is VALID [2022-02-20 18:03:38,156 INFO L290 TraceCheckUtils]: 69: Hoare triple {3018#false} assume { :end_inline_sign } true;assume { :begin_inline_outgoing__wrappee__AddressBook } true;outgoing__wrappee__AddressBook_#in~client#1, outgoing__wrappee__AddressBook_#in~msg#1 := ~client#1, ~msg#1;havoc outgoing__wrappee__AddressBook_#t~ret71#1, outgoing__wrappee__AddressBook_#t~ret72#1, outgoing__wrappee__AddressBook_#t~ret73#1, outgoing__wrappee__AddressBook_#t~ret74#1, outgoing__wrappee__AddressBook_#t~ret75#1, outgoing__wrappee__AddressBook_#t~ret76#1, outgoing__wrappee__AddressBook_~client#1, outgoing__wrappee__AddressBook_~msg#1, outgoing__wrappee__AddressBook_~size~0#1, outgoing__wrappee__AddressBook_~tmp~13#1, outgoing__wrappee__AddressBook_~receiver~1#1, outgoing__wrappee__AddressBook_~tmp___0~5#1, outgoing__wrappee__AddressBook_~second~0#1, outgoing__wrappee__AddressBook_~tmp___1~2#1, outgoing__wrappee__AddressBook_~tmp___2~2#1;outgoing__wrappee__AddressBook_~client#1 := outgoing__wrappee__AddressBook_#in~client#1;outgoing__wrappee__AddressBook_~msg#1 := outgoing__wrappee__AddressBook_#in~msg#1;havoc outgoing__wrappee__AddressBook_~size~0#1;havoc outgoing__wrappee__AddressBook_~tmp~13#1;havoc outgoing__wrappee__AddressBook_~receiver~1#1;havoc outgoing__wrappee__AddressBook_~tmp___0~5#1;havoc outgoing__wrappee__AddressBook_~second~0#1;havoc outgoing__wrappee__AddressBook_~tmp___1~2#1;havoc outgoing__wrappee__AddressBook_~tmp___2~2#1; {3018#false} is VALID [2022-02-20 18:03:38,156 INFO L272 TraceCheckUtils]: 70: Hoare triple {3018#false} call outgoing__wrappee__AddressBook_#t~ret71#1 := getClientAddressBookSize(outgoing__wrappee__AddressBook_~client#1); {3018#false} is VALID [2022-02-20 18:03:38,156 INFO L290 TraceCheckUtils]: 71: Hoare triple {3018#false} ~handle := #in~handle;havoc ~retValue_acc~30; {3018#false} is VALID [2022-02-20 18:03:38,156 INFO L290 TraceCheckUtils]: 72: Hoare triple {3018#false} assume 1 == ~handle;~retValue_acc~30 := ~__ste_ClientAddressBook_size0~0;#res := ~retValue_acc~30; {3018#false} is VALID [2022-02-20 18:03:38,156 INFO L290 TraceCheckUtils]: 73: Hoare triple {3018#false} assume true; {3018#false} is VALID [2022-02-20 18:03:38,156 INFO L284 TraceCheckUtils]: 74: Hoare quadruple {3018#false} {3018#false} #1152#return; {3018#false} is VALID [2022-02-20 18:03:38,156 INFO L290 TraceCheckUtils]: 75: Hoare triple {3018#false} assume -2147483648 <= outgoing__wrappee__AddressBook_#t~ret71#1 && outgoing__wrappee__AddressBook_#t~ret71#1 <= 2147483647;outgoing__wrappee__AddressBook_~tmp~13#1 := outgoing__wrappee__AddressBook_#t~ret71#1;havoc outgoing__wrappee__AddressBook_#t~ret71#1;outgoing__wrappee__AddressBook_~size~0#1 := outgoing__wrappee__AddressBook_~tmp~13#1; {3018#false} is VALID [2022-02-20 18:03:38,156 INFO L290 TraceCheckUtils]: 76: Hoare triple {3018#false} assume !(0 != outgoing__wrappee__AddressBook_~size~0#1); {3018#false} is VALID [2022-02-20 18:03:38,156 INFO L272 TraceCheckUtils]: 77: Hoare triple {3018#false} call outgoing__wrappee__Encrypt(outgoing__wrappee__AddressBook_~client#1, outgoing__wrappee__AddressBook_~msg#1); {3018#false} is VALID [2022-02-20 18:03:38,156 INFO L290 TraceCheckUtils]: 78: Hoare triple {3018#false} ~client#1 := #in~client#1;~msg#1 := #in~msg#1;havoc ~receiver~0#1;havoc ~tmp~12#1;havoc ~pubkey~0#1;havoc ~tmp___0~4#1; {3018#false} is VALID [2022-02-20 18:03:38,156 INFO L272 TraceCheckUtils]: 79: Hoare triple {3018#false} call #t~ret69#1 := getEmailTo(~msg#1); {3018#false} is VALID [2022-02-20 18:03:38,157 INFO L290 TraceCheckUtils]: 80: Hoare triple {3018#false} ~handle := #in~handle;havoc ~retValue_acc~3; {3018#false} is VALID [2022-02-20 18:03:38,157 INFO L290 TraceCheckUtils]: 81: Hoare triple {3018#false} assume 1 == ~handle;~retValue_acc~3 := ~__ste_email_to0~0;#res := ~retValue_acc~3; {3018#false} is VALID [2022-02-20 18:03:38,157 INFO L290 TraceCheckUtils]: 82: Hoare triple {3018#false} assume true; {3018#false} is VALID [2022-02-20 18:03:38,157 INFO L284 TraceCheckUtils]: 83: Hoare quadruple {3018#false} {3018#false} #1170#return; {3018#false} is VALID [2022-02-20 18:03:38,157 INFO L290 TraceCheckUtils]: 84: Hoare triple {3018#false} assume -2147483648 <= #t~ret69#1 && #t~ret69#1 <= 2147483647;~tmp~12#1 := #t~ret69#1;havoc #t~ret69#1;~receiver~0#1 := ~tmp~12#1; {3018#false} is VALID [2022-02-20 18:03:38,157 INFO L272 TraceCheckUtils]: 85: Hoare triple {3018#false} call #t~ret70#1 := findPublicKey(~client#1, ~receiver~0#1); {3018#false} is VALID [2022-02-20 18:03:38,157 INFO L290 TraceCheckUtils]: 86: Hoare triple {3018#false} ~handle := #in~handle;~userid := #in~userid;havoc ~retValue_acc~41; {3018#false} is VALID [2022-02-20 18:03:38,157 INFO L290 TraceCheckUtils]: 87: Hoare triple {3018#false} assume 1 == ~handle; {3018#false} is VALID [2022-02-20 18:03:38,157 INFO L290 TraceCheckUtils]: 88: Hoare triple {3018#false} assume ~userid == ~__ste_Client_Keyring0_User0~0;~retValue_acc~41 := ~__ste_Client_Keyring0_PublicKey0~0;#res := ~retValue_acc~41; {3018#false} is VALID [2022-02-20 18:03:38,157 INFO L290 TraceCheckUtils]: 89: Hoare triple {3018#false} assume true; {3018#false} is VALID [2022-02-20 18:03:38,157 INFO L284 TraceCheckUtils]: 90: Hoare quadruple {3018#false} {3018#false} #1172#return; {3018#false} is VALID [2022-02-20 18:03:38,158 INFO L290 TraceCheckUtils]: 91: Hoare triple {3018#false} assume -2147483648 <= #t~ret70#1 && #t~ret70#1 <= 2147483647;~tmp___0~4#1 := #t~ret70#1;havoc #t~ret70#1;~pubkey~0#1 := ~tmp___0~4#1; {3018#false} is VALID [2022-02-20 18:03:38,158 INFO L290 TraceCheckUtils]: 92: Hoare triple {3018#false} assume !(0 != ~pubkey~0#1); {3018#false} is VALID [2022-02-20 18:03:38,158 INFO L290 TraceCheckUtils]: 93: Hoare triple {3018#false} assume { :begin_inline_outgoing__wrappee__Keys } true;outgoing__wrappee__Keys_#in~client#1, outgoing__wrappee__Keys_#in~msg#1 := ~client#1, ~msg#1;havoc outgoing__wrappee__Keys_#t~ret68#1, outgoing__wrappee__Keys_~client#1, outgoing__wrappee__Keys_~msg#1, outgoing__wrappee__Keys_~tmp~11#1;outgoing__wrappee__Keys_~client#1 := outgoing__wrappee__Keys_#in~client#1;outgoing__wrappee__Keys_~msg#1 := outgoing__wrappee__Keys_#in~msg#1;havoc outgoing__wrappee__Keys_~tmp~11#1;assume { :begin_inline_getClientId } true;getClientId_#in~handle#1 := outgoing__wrappee__Keys_~client#1;havoc getClientId_#res#1;havoc getClientId_~handle#1, getClientId_~retValue_acc~43#1;getClientId_~handle#1 := getClientId_#in~handle#1;havoc getClientId_~retValue_acc~43#1; {3018#false} is VALID [2022-02-20 18:03:38,158 INFO L290 TraceCheckUtils]: 94: Hoare triple {3018#false} assume 1 == getClientId_~handle#1;getClientId_~retValue_acc~43#1 := ~__ste_client_idCounter0~0;getClientId_#res#1 := getClientId_~retValue_acc~43#1; {3018#false} is VALID [2022-02-20 18:03:38,158 INFO L290 TraceCheckUtils]: 95: Hoare triple {3018#false} outgoing__wrappee__Keys_#t~ret68#1 := getClientId_#res#1;assume { :end_inline_getClientId } true;assume -2147483648 <= outgoing__wrappee__Keys_#t~ret68#1 && outgoing__wrappee__Keys_#t~ret68#1 <= 2147483647;outgoing__wrappee__Keys_~tmp~11#1 := outgoing__wrappee__Keys_#t~ret68#1;havoc outgoing__wrappee__Keys_#t~ret68#1; {3018#false} is VALID [2022-02-20 18:03:38,158 INFO L272 TraceCheckUtils]: 96: Hoare triple {3018#false} call setEmailFrom(outgoing__wrappee__Keys_~msg#1, outgoing__wrappee__Keys_~tmp~11#1); {3018#false} is VALID [2022-02-20 18:03:38,158 INFO L290 TraceCheckUtils]: 97: Hoare triple {3018#false} ~handle := #in~handle;~value := #in~value; {3018#false} is VALID [2022-02-20 18:03:38,158 INFO L290 TraceCheckUtils]: 98: Hoare triple {3018#false} assume 1 == ~handle;~__ste_email_from0~0 := ~value; {3018#false} is VALID [2022-02-20 18:03:38,158 INFO L290 TraceCheckUtils]: 99: Hoare triple {3018#false} assume true; {3018#false} is VALID [2022-02-20 18:03:38,158 INFO L284 TraceCheckUtils]: 100: Hoare quadruple {3018#false} {3018#false} #1178#return; {3018#false} is VALID [2022-02-20 18:03:38,158 INFO L290 TraceCheckUtils]: 101: Hoare triple {3018#false} assume { :begin_inline_mail } true;mail_#in~client#1, mail_#in~msg#1 := outgoing__wrappee__Keys_~client#1, outgoing__wrappee__Keys_~msg#1;havoc mail_#t~ret66#1, mail_#t~ret67#1, mail_~client#1, mail_~msg#1, mail_~__utac__ad__arg1~0#1, mail_~tmp~10#1;mail_~client#1 := mail_#in~client#1;mail_~msg#1 := mail_#in~msg#1;havoc mail_~__utac__ad__arg1~0#1;havoc mail_~tmp~10#1;mail_~__utac__ad__arg1~0#1 := mail_~msg#1;assume { :begin_inline___utac_acc__EncryptAutoResponder_spec__2 } true;__utac_acc__EncryptAutoResponder_spec__2_#in~msg#1 := mail_~__utac__ad__arg1~0#1;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1, __utac_acc__EncryptAutoResponder_spec__2_#t~nondet29#1, __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1, __utac_acc__EncryptAutoResponder_spec__2_~msg#1, __utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.base, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.offset;__utac_acc__EncryptAutoResponder_spec__2_~msg#1 := __utac_acc__EncryptAutoResponder_spec__2_#in~msg#1;havoc __utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1;havoc __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.base, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.offset;call __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1 := puts(15, 0);assume -2147483648 <= __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1 && __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1 <= 2147483647;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1;__utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.base, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.offset := 16, 0;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~nondet29#1; {3018#false} is VALID [2022-02-20 18:03:38,158 INFO L290 TraceCheckUtils]: 102: Hoare triple {3018#false} assume 0 != ~in_encrypted~0; {3018#false} is VALID [2022-02-20 18:03:38,159 INFO L272 TraceCheckUtils]: 103: Hoare triple {3018#false} call __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1 := isEncrypted(__utac_acc__EncryptAutoResponder_spec__2_~msg#1); {3018#false} is VALID [2022-02-20 18:03:38,159 INFO L290 TraceCheckUtils]: 104: Hoare triple {3018#false} ~handle := #in~handle;havoc ~retValue_acc~6; {3018#false} is VALID [2022-02-20 18:03:38,159 INFO L290 TraceCheckUtils]: 105: Hoare triple {3018#false} assume 1 == ~handle;~retValue_acc~6 := ~__ste_email_isEncrypted0~0;#res := ~retValue_acc~6; {3018#false} is VALID [2022-02-20 18:03:38,159 INFO L290 TraceCheckUtils]: 106: Hoare triple {3018#false} assume true; {3018#false} is VALID [2022-02-20 18:03:38,159 INFO L284 TraceCheckUtils]: 107: Hoare quadruple {3018#false} {3018#false} #1180#return; {3018#false} is VALID [2022-02-20 18:03:38,159 INFO L290 TraceCheckUtils]: 108: Hoare triple {3018#false} assume -2147483648 <= __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1 && __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1 <= 2147483647;__utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1 := __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1; {3018#false} is VALID [2022-02-20 18:03:38,159 INFO L290 TraceCheckUtils]: 109: Hoare triple {3018#false} assume !(0 != __utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1);assume { :begin_inline___automaton_fail } true; {3018#false} is VALID [2022-02-20 18:03:38,159 INFO L290 TraceCheckUtils]: 110: Hoare triple {3018#false} assume !false; {3018#false} is VALID [2022-02-20 18:03:38,160 INFO L134 CoverageAnalysis]: Checked inductivity of 28 backedges. 0 proven. 0 refuted. 0 times theorem prover too weak. 28 trivial. 0 not checked. [2022-02-20 18:03:38,160 INFO L324 TraceCheckSpWp]: Omiting computation of backward sequence because forward sequence was already perfect [2022-02-20 18:03:38,160 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleZ3 [1554473942] provided 1 perfect and 0 imperfect interpolant sequences [2022-02-20 18:03:38,160 INFO L191 FreeRefinementEngine]: Found 1 perfect and 1 imperfect interpolant sequences. [2022-02-20 18:03:38,160 INFO L204 FreeRefinementEngine]: Number of different interpolants: perfect sequences [3] imperfect sequences [9] total 10 [2022-02-20 18:03:38,160 INFO L118 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [1825206123] [2022-02-20 18:03:38,160 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-02-20 18:03:38,167 INFO L78 Accepts]: Start accepts. Automaton has has 3 states, 3 states have (on average 21.666666666666668) internal successors, (65), 3 states have internal predecessors, (65), 2 states have call successors, (17), 2 states have call predecessors, (17), 2 states have return successors, (14), 2 states have call predecessors, (14), 2 states have call successors, (14) Word has length 111 [2022-02-20 18:03:38,168 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-02-20 18:03:38,168 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with has 3 states, 3 states have (on average 21.666666666666668) internal successors, (65), 3 states have internal predecessors, (65), 2 states have call successors, (17), 2 states have call predecessors, (17), 2 states have return successors, (14), 2 states have call predecessors, (14), 2 states have call successors, (14) [2022-02-20 18:03:38,239 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 96 edges. 96 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 18:03:38,239 INFO L546 AbstractCegarLoop]: INTERPOLANT automaton has 3 states [2022-02-20 18:03:38,239 INFO L108 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2022-02-20 18:03:38,240 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 3 interpolants. [2022-02-20 18:03:38,240 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=17, Invalid=73, Unknown=0, NotChecked=0, Total=90 [2022-02-20 18:03:38,240 INFO L87 Difference]: Start difference. First operand 402 states and 605 transitions. Second operand has 3 states, 3 states have (on average 21.666666666666668) internal successors, (65), 3 states have internal predecessors, (65), 2 states have call successors, (17), 2 states have call predecessors, (17), 2 states have return successors, (14), 2 states have call predecessors, (14), 2 states have call successors, (14) [2022-02-20 18:03:38,762 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 18:03:38,762 INFO L93 Difference]: Finished difference Result 620 states and 910 transitions. [2022-02-20 18:03:38,762 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 3 states. [2022-02-20 18:03:38,764 INFO L78 Accepts]: Start accepts. Automaton has has 3 states, 3 states have (on average 21.666666666666668) internal successors, (65), 3 states have internal predecessors, (65), 2 states have call successors, (17), 2 states have call predecessors, (17), 2 states have return successors, (14), 2 states have call predecessors, (14), 2 states have call successors, (14) Word has length 111 [2022-02-20 18:03:38,764 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-02-20 18:03:38,765 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 3 states, 3 states have (on average 21.666666666666668) internal successors, (65), 3 states have internal predecessors, (65), 2 states have call successors, (17), 2 states have call predecessors, (17), 2 states have return successors, (14), 2 states have call predecessors, (14), 2 states have call successors, (14) [2022-02-20 18:03:38,779 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 3 states to 3 states and 910 transitions. [2022-02-20 18:03:38,779 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 3 states, 3 states have (on average 21.666666666666668) internal successors, (65), 3 states have internal predecessors, (65), 2 states have call successors, (17), 2 states have call predecessors, (17), 2 states have return successors, (14), 2 states have call predecessors, (14), 2 states have call successors, (14) [2022-02-20 18:03:38,799 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 3 states to 3 states and 910 transitions. [2022-02-20 18:03:38,803 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with 3 states and 910 transitions. [2022-02-20 18:03:39,380 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 910 edges. 910 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 18:03:39,391 INFO L225 Difference]: With dead ends: 620 [2022-02-20 18:03:39,391 INFO L226 Difference]: Without dead ends: 405 [2022-02-20 18:03:39,392 INFO L932 BasicCegarLoop]: 0 DeclaredPredicates, 142 GetRequests, 134 SyntacticMatches, 0 SemanticMatches, 8 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 0 ImplicationChecksByTransitivity, 0.0s TimeCoverageRelationStatistics Valid=17, Invalid=73, Unknown=0, NotChecked=0, Total=90 [2022-02-20 18:03:39,394 INFO L933 BasicCegarLoop]: 603 mSDtfsCounter, 1 mSDsluCounter, 601 mSDsCounter, 0 mSdLazyCounter, 5 mSolverCounterSat, 0 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.0s Time, 0 mProtectedPredicate, 0 mProtectedAction, 1 SdHoareTripleChecker+Valid, 1204 SdHoareTripleChecker+Invalid, 5 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 0 IncrementalHoareTripleChecker+Valid, 5 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.0s IncrementalHoareTripleChecker+Time [2022-02-20 18:03:39,395 INFO L934 BasicCegarLoop]: SdHoareTripleChecker [1 Valid, 1204 Invalid, 5 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [0 Valid, 5 Invalid, 0 Unknown, 0 Unchecked, 0.0s Time] [2022-02-20 18:03:39,397 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 405 states. [2022-02-20 18:03:39,425 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 405 to 404. [2022-02-20 18:03:39,426 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-02-20 18:03:39,427 INFO L82 GeneralOperation]: Start isEquivalent. First operand 405 states. Second operand has 404 states, 312 states have (on average 1.544871794871795) internal successors, (482), 316 states have internal predecessors, (482), 63 states have call successors, (63), 28 states have call predecessors, (63), 28 states have return successors, (62), 61 states have call predecessors, (62), 62 states have call successors, (62) [2022-02-20 18:03:39,428 INFO L74 IsIncluded]: Start isIncluded. First operand 405 states. Second operand has 404 states, 312 states have (on average 1.544871794871795) internal successors, (482), 316 states have internal predecessors, (482), 63 states have call successors, (63), 28 states have call predecessors, (63), 28 states have return successors, (62), 61 states have call predecessors, (62), 62 states have call successors, (62) [2022-02-20 18:03:39,428 INFO L87 Difference]: Start difference. First operand 405 states. Second operand has 404 states, 312 states have (on average 1.544871794871795) internal successors, (482), 316 states have internal predecessors, (482), 63 states have call successors, (63), 28 states have call predecessors, (63), 28 states have return successors, (62), 61 states have call predecessors, (62), 62 states have call successors, (62) [2022-02-20 18:03:39,455 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 18:03:39,455 INFO L93 Difference]: Finished difference Result 405 states and 608 transitions. [2022-02-20 18:03:39,455 INFO L276 IsEmpty]: Start isEmpty. Operand 405 states and 608 transitions. [2022-02-20 18:03:39,456 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 18:03:39,457 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 18:03:39,458 INFO L74 IsIncluded]: Start isIncluded. First operand has 404 states, 312 states have (on average 1.544871794871795) internal successors, (482), 316 states have internal predecessors, (482), 63 states have call successors, (63), 28 states have call predecessors, (63), 28 states have return successors, (62), 61 states have call predecessors, (62), 62 states have call successors, (62) Second operand 405 states. [2022-02-20 18:03:39,460 INFO L87 Difference]: Start difference. First operand has 404 states, 312 states have (on average 1.544871794871795) internal successors, (482), 316 states have internal predecessors, (482), 63 states have call successors, (63), 28 states have call predecessors, (63), 28 states have return successors, (62), 61 states have call predecessors, (62), 62 states have call successors, (62) Second operand 405 states. [2022-02-20 18:03:39,472 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 18:03:39,472 INFO L93 Difference]: Finished difference Result 405 states and 608 transitions. [2022-02-20 18:03:39,472 INFO L276 IsEmpty]: Start isEmpty. Operand 405 states and 608 transitions. [2022-02-20 18:03:39,474 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 18:03:39,475 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 18:03:39,475 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-02-20 18:03:39,475 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-02-20 18:03:39,476 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 404 states, 312 states have (on average 1.544871794871795) internal successors, (482), 316 states have internal predecessors, (482), 63 states have call successors, (63), 28 states have call predecessors, (63), 28 states have return successors, (62), 61 states have call predecessors, (62), 62 states have call successors, (62) [2022-02-20 18:03:39,512 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 404 states to 404 states and 607 transitions. [2022-02-20 18:03:39,513 INFO L78 Accepts]: Start accepts. Automaton has 404 states and 607 transitions. Word has length 111 [2022-02-20 18:03:39,514 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-02-20 18:03:39,515 INFO L470 AbstractCegarLoop]: Abstraction has 404 states and 607 transitions. [2022-02-20 18:03:39,515 INFO L471 AbstractCegarLoop]: INTERPOLANT automaton has has 3 states, 3 states have (on average 21.666666666666668) internal successors, (65), 3 states have internal predecessors, (65), 2 states have call successors, (17), 2 states have call predecessors, (17), 2 states have return successors, (14), 2 states have call predecessors, (14), 2 states have call successors, (14) [2022-02-20 18:03:39,515 INFO L276 IsEmpty]: Start isEmpty. Operand 404 states and 607 transitions. [2022-02-20 18:03:39,517 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 118 [2022-02-20 18:03:39,518 INFO L506 BasicCegarLoop]: Found error trace [2022-02-20 18:03:39,518 INFO L514 BasicCegarLoop]: trace histogram [3, 3, 3, 3, 3, 3, 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] [2022-02-20 18:03:39,541 INFO L540 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (3)] Forceful destruction successful, exit code 0 [2022-02-20 18:03:39,741 WARN L452 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: 3 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true,SelfDestructingSolverStorable1 [2022-02-20 18:03:39,742 INFO L402 AbstractCegarLoop]: === Iteration 3 === Targeting outgoing__wrappee__EncryptErr0ASSERT_VIOLATIONERROR_FUNCTION === [outgoing__wrappee__EncryptErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-02-20 18:03:39,742 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-02-20 18:03:39,742 INFO L85 PathProgramCache]: Analyzing trace with hash 31342431, now seen corresponding path program 1 times [2022-02-20 18:03:39,743 INFO L126 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-02-20 18:03:39,743 INFO L338 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [1918465512] [2022-02-20 18:03:39,743 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 18:03:39,743 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-02-20 18:03:39,775 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:39,806 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 6 [2022-02-20 18:03:39,808 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:39,811 INFO L290 TraceCheckUtils]: 0: Hoare triple {5679#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {5619#true} is VALID [2022-02-20 18:03:39,811 INFO L290 TraceCheckUtils]: 1: Hoare triple {5619#true} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {5619#true} is VALID [2022-02-20 18:03:39,811 INFO L290 TraceCheckUtils]: 2: Hoare triple {5619#true} assume true; {5619#true} is VALID [2022-02-20 18:03:39,811 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {5619#true} {5619#true} #1224#return; {5619#true} is VALID [2022-02-20 18:03:39,817 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 12 [2022-02-20 18:03:39,819 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:39,822 INFO L290 TraceCheckUtils]: 0: Hoare triple {5680#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {5619#true} is VALID [2022-02-20 18:03:39,822 INFO L290 TraceCheckUtils]: 1: Hoare triple {5619#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {5619#true} is VALID [2022-02-20 18:03:39,822 INFO L290 TraceCheckUtils]: 2: Hoare triple {5619#true} assume true; {5619#true} is VALID [2022-02-20 18:03:39,822 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {5619#true} {5619#true} #1226#return; {5619#true} is VALID [2022-02-20 18:03:39,822 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 18 [2022-02-20 18:03:39,825 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:39,839 INFO L290 TraceCheckUtils]: 0: Hoare triple {5679#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {5681#(= setClientId_~handle |setClientId_#in~handle|)} is VALID [2022-02-20 18:03:39,839 INFO L290 TraceCheckUtils]: 1: Hoare triple {5681#(= setClientId_~handle |setClientId_#in~handle|)} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {5682#(= |setClientId_#in~handle| 1)} is VALID [2022-02-20 18:03:39,840 INFO L290 TraceCheckUtils]: 2: Hoare triple {5682#(= |setClientId_#in~handle| 1)} assume true; {5682#(= |setClientId_#in~handle| 1)} is VALID [2022-02-20 18:03:39,840 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {5682#(= |setClientId_#in~handle| 1)} {5629#(= |ULTIMATE.start_setup_rjh__wrappee__Base_~rjh___0#1| 2)} #1228#return; {5620#false} is VALID [2022-02-20 18:03:39,841 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 24 [2022-02-20 18:03:39,843 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:39,845 INFO L290 TraceCheckUtils]: 0: Hoare triple {5680#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {5619#true} is VALID [2022-02-20 18:03:39,846 INFO L290 TraceCheckUtils]: 1: Hoare triple {5619#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {5619#true} is VALID [2022-02-20 18:03:39,846 INFO L290 TraceCheckUtils]: 2: Hoare triple {5619#true} assume true; {5619#true} is VALID [2022-02-20 18:03:39,846 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {5619#true} {5620#false} #1230#return; {5620#false} is VALID [2022-02-20 18:03:39,846 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 30 [2022-02-20 18:03:39,849 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:39,852 INFO L290 TraceCheckUtils]: 0: Hoare triple {5679#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {5619#true} is VALID [2022-02-20 18:03:39,852 INFO L290 TraceCheckUtils]: 1: Hoare triple {5619#true} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {5619#true} is VALID [2022-02-20 18:03:39,852 INFO L290 TraceCheckUtils]: 2: Hoare triple {5619#true} assume true; {5619#true} is VALID [2022-02-20 18:03:39,852 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {5619#true} {5620#false} #1232#return; {5620#false} is VALID [2022-02-20 18:03:39,852 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 36 [2022-02-20 18:03:39,854 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:39,857 INFO L290 TraceCheckUtils]: 0: Hoare triple {5680#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {5619#true} is VALID [2022-02-20 18:03:39,857 INFO L290 TraceCheckUtils]: 1: Hoare triple {5619#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {5619#true} is VALID [2022-02-20 18:03:39,857 INFO L290 TraceCheckUtils]: 2: Hoare triple {5619#true} assume true; {5619#true} is VALID [2022-02-20 18:03:39,857 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {5619#true} {5620#false} #1234#return; {5620#false} is VALID [2022-02-20 18:03:39,864 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 54 [2022-02-20 18:03:39,866 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:39,868 INFO L290 TraceCheckUtils]: 0: Hoare triple {5683#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} ~handle := #in~handle;~value := #in~value; {5619#true} is VALID [2022-02-20 18:03:39,868 INFO L290 TraceCheckUtils]: 1: Hoare triple {5619#true} assume 1 == ~handle;~__ste_email_from0~0 := ~value; {5619#true} is VALID [2022-02-20 18:03:39,869 INFO L290 TraceCheckUtils]: 2: Hoare triple {5619#true} assume true; {5619#true} is VALID [2022-02-20 18:03:39,869 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {5619#true} {5620#false} #1210#return; {5620#false} is VALID [2022-02-20 18:03:39,876 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 59 [2022-02-20 18:03:39,877 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:39,880 INFO L290 TraceCheckUtils]: 0: Hoare triple {5684#(and (= ~__ste_email_to0~0 |old(~__ste_email_to0~0)|) (= ~__ste_email_to1~0 |old(~__ste_email_to1~0)|))} ~handle := #in~handle;~value := #in~value; {5619#true} is VALID [2022-02-20 18:03:39,880 INFO L290 TraceCheckUtils]: 1: Hoare triple {5619#true} assume 1 == ~handle;~__ste_email_to0~0 := ~value; {5619#true} is VALID [2022-02-20 18:03:39,880 INFO L290 TraceCheckUtils]: 2: Hoare triple {5619#true} assume true; {5619#true} is VALID [2022-02-20 18:03:39,880 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {5619#true} {5620#false} #1212#return; {5620#false} is VALID [2022-02-20 18:03:39,880 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 68 [2022-02-20 18:03:39,881 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:39,883 INFO L290 TraceCheckUtils]: 0: Hoare triple {5619#true} ~handle := #in~handle;havoc ~retValue_acc~36; {5619#true} is VALID [2022-02-20 18:03:39,884 INFO L290 TraceCheckUtils]: 1: Hoare triple {5619#true} assume 1 == ~handle;~retValue_acc~36 := ~__ste_client_privateKey0~0;#res := ~retValue_acc~36; {5619#true} is VALID [2022-02-20 18:03:39,884 INFO L290 TraceCheckUtils]: 2: Hoare triple {5619#true} assume true; {5619#true} is VALID [2022-02-20 18:03:39,884 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {5619#true} {5620#false} #1150#return; {5620#false} is VALID [2022-02-20 18:03:39,884 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 76 [2022-02-20 18:03:39,885 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:39,887 INFO L290 TraceCheckUtils]: 0: Hoare triple {5619#true} ~handle := #in~handle;havoc ~retValue_acc~30; {5619#true} is VALID [2022-02-20 18:03:39,887 INFO L290 TraceCheckUtils]: 1: Hoare triple {5619#true} assume 1 == ~handle;~retValue_acc~30 := ~__ste_ClientAddressBook_size0~0;#res := ~retValue_acc~30; {5619#true} is VALID [2022-02-20 18:03:39,888 INFO L290 TraceCheckUtils]: 2: Hoare triple {5619#true} assume true; {5619#true} is VALID [2022-02-20 18:03:39,888 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {5619#true} {5620#false} #1152#return; {5620#false} is VALID [2022-02-20 18:03:39,888 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 85 [2022-02-20 18:03:39,889 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:39,891 INFO L290 TraceCheckUtils]: 0: Hoare triple {5619#true} ~handle := #in~handle;havoc ~retValue_acc~3; {5619#true} is VALID [2022-02-20 18:03:39,891 INFO L290 TraceCheckUtils]: 1: Hoare triple {5619#true} assume 1 == ~handle;~retValue_acc~3 := ~__ste_email_to0~0;#res := ~retValue_acc~3; {5619#true} is VALID [2022-02-20 18:03:39,891 INFO L290 TraceCheckUtils]: 2: Hoare triple {5619#true} assume true; {5619#true} is VALID [2022-02-20 18:03:39,891 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {5619#true} {5620#false} #1170#return; {5620#false} is VALID [2022-02-20 18:03:39,892 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 91 [2022-02-20 18:03:39,893 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:39,895 INFO L290 TraceCheckUtils]: 0: Hoare triple {5619#true} ~handle := #in~handle;~userid := #in~userid;havoc ~retValue_acc~41; {5619#true} is VALID [2022-02-20 18:03:39,895 INFO L290 TraceCheckUtils]: 1: Hoare triple {5619#true} assume 1 == ~handle; {5619#true} is VALID [2022-02-20 18:03:39,895 INFO L290 TraceCheckUtils]: 2: Hoare triple {5619#true} assume ~userid == ~__ste_Client_Keyring0_User0~0;~retValue_acc~41 := ~__ste_Client_Keyring0_PublicKey0~0;#res := ~retValue_acc~41; {5619#true} is VALID [2022-02-20 18:03:39,895 INFO L290 TraceCheckUtils]: 3: Hoare triple {5619#true} assume true; {5619#true} is VALID [2022-02-20 18:03:39,895 INFO L284 TraceCheckUtils]: 4: Hoare quadruple {5619#true} {5620#false} #1172#return; {5620#false} is VALID [2022-02-20 18:03:39,895 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 102 [2022-02-20 18:03:39,896 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:39,898 INFO L290 TraceCheckUtils]: 0: Hoare triple {5683#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} ~handle := #in~handle;~value := #in~value; {5619#true} is VALID [2022-02-20 18:03:39,898 INFO L290 TraceCheckUtils]: 1: Hoare triple {5619#true} assume 1 == ~handle;~__ste_email_from0~0 := ~value; {5619#true} is VALID [2022-02-20 18:03:39,899 INFO L290 TraceCheckUtils]: 2: Hoare triple {5619#true} assume true; {5619#true} is VALID [2022-02-20 18:03:39,899 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {5619#true} {5620#false} #1178#return; {5620#false} is VALID [2022-02-20 18:03:39,899 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 109 [2022-02-20 18:03:39,900 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:39,902 INFO L290 TraceCheckUtils]: 0: Hoare triple {5619#true} ~handle := #in~handle;havoc ~retValue_acc~6; {5619#true} is VALID [2022-02-20 18:03:39,902 INFO L290 TraceCheckUtils]: 1: Hoare triple {5619#true} assume 1 == ~handle;~retValue_acc~6 := ~__ste_email_isEncrypted0~0;#res := ~retValue_acc~6; {5619#true} is VALID [2022-02-20 18:03:39,902 INFO L290 TraceCheckUtils]: 2: Hoare triple {5619#true} assume true; {5619#true} is VALID [2022-02-20 18:03:39,902 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {5619#true} {5620#false} #1180#return; {5620#false} is VALID [2022-02-20 18:03:39,902 INFO L290 TraceCheckUtils]: 0: Hoare triple {5619#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(28, 2);call #Ultimate.allocInit(12, 3);call #Ultimate.allocInit(10, 4);call #Ultimate.allocInit(12, 5);call #Ultimate.allocInit(10, 6);call #Ultimate.allocInit(18, 7);call #Ultimate.allocInit(16, 8);call #Ultimate.allocInit(21, 9);call #Ultimate.allocInit(13, 10);call #Ultimate.allocInit(16, 11);call #Ultimate.allocInit(25, 12);call #Ultimate.allocInit(17, 13);call #Ultimate.allocInit(17, 14);call #Ultimate.allocInit(13, 15);call #Ultimate.allocInit(17, 16);call #Ultimate.allocInit(30, 17);call #Ultimate.allocInit(9, 18);call #Ultimate.allocInit(21, 19);call #Ultimate.allocInit(30, 20);call #Ultimate.allocInit(9, 21);call #Ultimate.allocInit(21, 22);call #Ultimate.allocInit(30, 23);call #Ultimate.allocInit(9, 24);call #Ultimate.allocInit(25, 25);call #Ultimate.allocInit(30, 26);call #Ultimate.allocInit(9, 27);call #Ultimate.allocInit(25, 28);call #Ultimate.allocInit(4, 29);call write~init~int(37, 29, 0, 1);call write~init~int(115, 29, 1, 1);call write~init~int(10, 29, 2, 1);call write~init~int(0, 29, 3, 1);call #Ultimate.allocInit(10, 30);call #Ultimate.allocInit(34, 31);call #Ultimate.allocInit(30, 32);call #Ultimate.allocInit(16, 33);call #Ultimate.allocInit(20, 34);call #Ultimate.allocInit(44, 35);call #Ultimate.allocInit(44, 36);call #Ultimate.allocInit(9, 37);call #Ultimate.allocInit(9, 38);call #Ultimate.allocInit(11, 39);call #Ultimate.allocInit(19, 40);call #Ultimate.allocInit(4, 41);call write~init~int(37, 41, 0, 1);call write~init~int(100, 41, 1, 1);call write~init~int(10, 41, 2, 1);call write~init~int(0, 41, 3, 1);call #Ultimate.allocInit(4, 42);call write~init~int(37, 42, 0, 1);call write~init~int(100, 42, 1, 1);call write~init~int(10, 42, 2, 1);call write~init~int(0, 42, 3, 1);~__ste_Email_counter~0 := 0;~__ste_email_id0~0 := 0;~__ste_email_id1~0 := 0;~__ste_email_from0~0 := 0;~__ste_email_from1~0 := 0;~__ste_email_to0~0 := 0;~__ste_email_to1~0 := 0;~__ste_email_subject0~0.base, ~__ste_email_subject0~0.offset := 0, 0;~__ste_email_subject1~0.base, ~__ste_email_subject1~0.offset := 0, 0;~__ste_email_body0~0.base, ~__ste_email_body0~0.offset := 0, 0;~__ste_email_body1~0.base, ~__ste_email_body1~0.offset := 0, 0;~__ste_email_isEncrypted0~0 := 0;~__ste_email_isEncrypted1~0 := 0;~__ste_email_encryptionKey0~0 := 0;~__ste_email_encryptionKey1~0 := 0;~__ste_email_isSigned0~0 := 0;~__ste_email_isSigned1~0 := 0;~__ste_email_signKey0~0 := 0;~__ste_email_signKey1~0 := 0;~__ste_email_isSignatureVerified0~0 := 0;~__ste_email_isSignatureVerified1~0 := 0;~__SELECTED_FEATURE_Base~0 := 0;~__SELECTED_FEATURE_Keys~0 := 0;~__SELECTED_FEATURE_Encrypt~0 := 0;~__SELECTED_FEATURE_AutoResponder~0 := 0;~__SELECTED_FEATURE_AddressBook~0 := 0;~__SELECTED_FEATURE_Sign~0 := 0;~__SELECTED_FEATURE_Forward~0 := 0;~__SELECTED_FEATURE_Verify~0 := 0;~__SELECTED_FEATURE_Decrypt~0 := 0;~__GUIDSL_ROOT_PRODUCTION~0 := 0;~__GUIDSL_NON_TERMINAL_main~0 := 0;~in_encrypted~0 := 0;~head~0.base, ~head~0.offset := 0, 0;~queue_empty~0 := 1;~queued_message~0 := 0;~queued_client~0 := 0;~bob~0 := 0;~rjh~0 := 0;~chuck~0 := 0;~__ste_Client_counter~0 := 0;~__ste_client_name0~0.base, ~__ste_client_name0~0.offset := 0, 0;~__ste_client_name1~0.base, ~__ste_client_name1~0.offset := 0, 0;~__ste_client_name2~0.base, ~__ste_client_name2~0.offset := 0, 0;~__ste_client_outbuffer0~0 := 0;~__ste_client_outbuffer1~0 := 0;~__ste_client_outbuffer2~0 := 0;~__ste_client_outbuffer3~0 := 0;~__ste_ClientAddressBook_size0~0 := 0;~__ste_ClientAddressBook_size1~0 := 0;~__ste_ClientAddressBook_size2~0 := 0;~__ste_Client_AddressBook0_Alias0~0 := 0;~__ste_Client_AddressBook0_Alias1~0 := 0;~__ste_Client_AddressBook0_Alias2~0 := 0;~__ste_Client_AddressBook1_Alias0~0 := 0;~__ste_Client_AddressBook1_Alias1~0 := 0;~__ste_Client_AddressBook1_Alias2~0 := 0;~__ste_Client_AddressBook2_Alias0~0 := 0;~__ste_Client_AddressBook2_Alias1~0 := 0;~__ste_Client_AddressBook2_Alias2~0 := 0;~__ste_Client_AddressBook0_Address0~0 := 0;~__ste_Client_AddressBook0_Address1~0 := 0;~__ste_Client_AddressBook0_Address2~0 := 0;~__ste_Client_AddressBook1_Address0~0 := 0;~__ste_Client_AddressBook1_Address1~0 := 0;~__ste_Client_AddressBook1_Address2~0 := 0;~__ste_Client_AddressBook2_Address0~0 := 0;~__ste_Client_AddressBook2_Address1~0 := 0;~__ste_Client_AddressBook2_Address2~0 := 0;~__ste_client_autoResponse0~0 := 0;~__ste_client_autoResponse1~0 := 0;~__ste_client_autoResponse2~0 := 0;~__ste_client_privateKey0~0 := 0;~__ste_client_privateKey1~0 := 0;~__ste_client_privateKey2~0 := 0;~__ste_ClientKeyring_size0~0 := 0;~__ste_ClientKeyring_size1~0 := 0;~__ste_ClientKeyring_size2~0 := 0;~__ste_Client_Keyring0_User0~0 := 0;~__ste_Client_Keyring0_User1~0 := 0;~__ste_Client_Keyring0_User2~0 := 0;~__ste_Client_Keyring1_User0~0 := 0;~__ste_Client_Keyring1_User1~0 := 0;~__ste_Client_Keyring1_User2~0 := 0;~__ste_Client_Keyring2_User0~0 := 0;~__ste_Client_Keyring2_User1~0 := 0;~__ste_Client_Keyring2_User2~0 := 0;~__ste_Client_Keyring0_PublicKey0~0 := 0;~__ste_Client_Keyring0_PublicKey1~0 := 0;~__ste_Client_Keyring0_PublicKey2~0 := 0;~__ste_Client_Keyring1_PublicKey0~0 := 0;~__ste_Client_Keyring1_PublicKey1~0 := 0;~__ste_Client_Keyring1_PublicKey2~0 := 0;~__ste_Client_Keyring2_PublicKey0~0 := 0;~__ste_Client_Keyring2_PublicKey1~0 := 0;~__ste_Client_Keyring2_PublicKey2~0 := 0;~__ste_client_forwardReceiver0~0 := 0;~__ste_client_forwardReceiver1~0 := 0;~__ste_client_forwardReceiver2~0 := 0;~__ste_client_forwardReceiver3~0 := 0;~__ste_client_idCounter0~0 := 0;~__ste_client_idCounter1~0 := 0;~__ste_client_idCounter2~0 := 0; {5619#true} is VALID [2022-02-20 18:03:39,902 INFO L290 TraceCheckUtils]: 1: Hoare triple {5619#true} assume { :end_inline_ULTIMATE.init } true;assume { :begin_inline_main } true;havoc main_#res#1;havoc main_#t~nondet100#1, main_#t~ret101#1, main_~retValue_acc~26#1, main_~tmp~20#1;assume -2147483648 <= main_#t~nondet100#1 && main_#t~nondet100#1 <= 2147483647;main_~retValue_acc~26#1 := main_#t~nondet100#1;havoc main_#t~nondet100#1;havoc main_~tmp~20#1;assume { :begin_inline_select_helpers } true; {5619#true} is VALID [2022-02-20 18:03:39,902 INFO L290 TraceCheckUtils]: 2: Hoare triple {5619#true} assume { :end_inline_select_helpers } true;assume { :begin_inline_select_features } true; {5619#true} is VALID [2022-02-20 18:03:39,903 INFO L290 TraceCheckUtils]: 3: Hoare triple {5619#true} assume { :end_inline_select_features } true;assume { :begin_inline_valid_product } true;havoc valid_product_#res#1;havoc valid_product_~retValue_acc~12#1;havoc valid_product_~retValue_acc~12#1;valid_product_~retValue_acc~12#1 := 1;valid_product_#res#1 := valid_product_~retValue_acc~12#1; {5619#true} is VALID [2022-02-20 18:03:39,903 INFO L290 TraceCheckUtils]: 4: Hoare triple {5619#true} main_#t~ret101#1 := valid_product_#res#1;assume { :end_inline_valid_product } true;assume -2147483648 <= main_#t~ret101#1 && main_#t~ret101#1 <= 2147483647;main_~tmp~20#1 := main_#t~ret101#1;havoc main_#t~ret101#1; {5619#true} is VALID [2022-02-20 18:03:39,903 INFO L290 TraceCheckUtils]: 5: Hoare triple {5619#true} assume 0 != main_~tmp~20#1;assume { :begin_inline_setup } true;havoc setup_#t~nondet97#1, setup_#t~nondet98#1, setup_#t~nondet99#1, setup_~__cil_tmp1~0#1.base, setup_~__cil_tmp1~0#1.offset, setup_~__cil_tmp2~1#1.base, setup_~__cil_tmp2~1#1.offset, setup_~__cil_tmp3~4#1.base, setup_~__cil_tmp3~4#1.offset;havoc setup_~__cil_tmp1~0#1.base, setup_~__cil_tmp1~0#1.offset;havoc setup_~__cil_tmp2~1#1.base, setup_~__cil_tmp2~1#1.offset;havoc setup_~__cil_tmp3~4#1.base, setup_~__cil_tmp3~4#1.offset;~bob~0 := 1;assume { :begin_inline_setup_bob } true;setup_bob_#in~bob___0#1 := ~bob~0;havoc setup_bob_~bob___0#1;setup_bob_~bob___0#1 := setup_bob_#in~bob___0#1;assume { :begin_inline_setup_bob__wrappee__Base } true;setup_bob__wrappee__Base_#in~bob___0#1 := setup_bob_~bob___0#1;havoc setup_bob__wrappee__Base_~bob___0#1;setup_bob__wrappee__Base_~bob___0#1 := setup_bob__wrappee__Base_#in~bob___0#1; {5619#true} is VALID [2022-02-20 18:03:39,904 INFO L272 TraceCheckUtils]: 6: Hoare triple {5619#true} call setClientId(setup_bob__wrappee__Base_~bob___0#1, setup_bob__wrappee__Base_~bob___0#1); {5679#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} is VALID [2022-02-20 18:03:39,904 INFO L290 TraceCheckUtils]: 7: Hoare triple {5679#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {5619#true} is VALID [2022-02-20 18:03:39,904 INFO L290 TraceCheckUtils]: 8: Hoare triple {5619#true} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {5619#true} is VALID [2022-02-20 18:03:39,904 INFO L290 TraceCheckUtils]: 9: Hoare triple {5619#true} assume true; {5619#true} is VALID [2022-02-20 18:03:39,904 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {5619#true} {5619#true} #1224#return; {5619#true} is VALID [2022-02-20 18:03:39,904 INFO L290 TraceCheckUtils]: 11: Hoare triple {5619#true} assume { :end_inline_setup_bob__wrappee__Base } true; {5619#true} is VALID [2022-02-20 18:03:39,905 INFO L272 TraceCheckUtils]: 12: Hoare triple {5619#true} call setClientPrivateKey(setup_bob_~bob___0#1, 123); {5680#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} is VALID [2022-02-20 18:03:39,905 INFO L290 TraceCheckUtils]: 13: Hoare triple {5680#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {5619#true} is VALID [2022-02-20 18:03:39,905 INFO L290 TraceCheckUtils]: 14: Hoare triple {5619#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {5619#true} is VALID [2022-02-20 18:03:39,905 INFO L290 TraceCheckUtils]: 15: Hoare triple {5619#true} assume true; {5619#true} is VALID [2022-02-20 18:03:39,905 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {5619#true} {5619#true} #1226#return; {5619#true} is VALID [2022-02-20 18:03:39,905 INFO L290 TraceCheckUtils]: 17: Hoare triple {5619#true} assume { :end_inline_setup_bob } true;setup_~__cil_tmp1~0#1.base, setup_~__cil_tmp1~0#1.offset := 37, 0;havoc setup_#t~nondet97#1;~rjh~0 := 2;assume { :begin_inline_setup_rjh } true;setup_rjh_#in~rjh___0#1 := ~rjh~0;havoc setup_rjh_~rjh___0#1;setup_rjh_~rjh___0#1 := setup_rjh_#in~rjh___0#1;assume { :begin_inline_setup_rjh__wrappee__Base } true;setup_rjh__wrappee__Base_#in~rjh___0#1 := setup_rjh_~rjh___0#1;havoc setup_rjh__wrappee__Base_~rjh___0#1;setup_rjh__wrappee__Base_~rjh___0#1 := setup_rjh__wrappee__Base_#in~rjh___0#1; {5629#(= |ULTIMATE.start_setup_rjh__wrappee__Base_~rjh___0#1| 2)} is VALID [2022-02-20 18:03:39,906 INFO L272 TraceCheckUtils]: 18: Hoare triple {5629#(= |ULTIMATE.start_setup_rjh__wrappee__Base_~rjh___0#1| 2)} call setClientId(setup_rjh__wrappee__Base_~rjh___0#1, setup_rjh__wrappee__Base_~rjh___0#1); {5679#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} is VALID [2022-02-20 18:03:39,906 INFO L290 TraceCheckUtils]: 19: Hoare triple {5679#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {5681#(= setClientId_~handle |setClientId_#in~handle|)} is VALID [2022-02-20 18:03:39,907 INFO L290 TraceCheckUtils]: 20: Hoare triple {5681#(= setClientId_~handle |setClientId_#in~handle|)} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {5682#(= |setClientId_#in~handle| 1)} is VALID [2022-02-20 18:03:39,907 INFO L290 TraceCheckUtils]: 21: Hoare triple {5682#(= |setClientId_#in~handle| 1)} assume true; {5682#(= |setClientId_#in~handle| 1)} is VALID [2022-02-20 18:03:39,908 INFO L284 TraceCheckUtils]: 22: Hoare quadruple {5682#(= |setClientId_#in~handle| 1)} {5629#(= |ULTIMATE.start_setup_rjh__wrappee__Base_~rjh___0#1| 2)} #1228#return; {5620#false} is VALID [2022-02-20 18:03:39,908 INFO L290 TraceCheckUtils]: 23: Hoare triple {5620#false} assume { :end_inline_setup_rjh__wrappee__Base } true; {5620#false} is VALID [2022-02-20 18:03:39,908 INFO L272 TraceCheckUtils]: 24: Hoare triple {5620#false} call setClientPrivateKey(setup_rjh_~rjh___0#1, 456); {5680#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} is VALID [2022-02-20 18:03:39,908 INFO L290 TraceCheckUtils]: 25: Hoare triple {5680#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {5619#true} is VALID [2022-02-20 18:03:39,908 INFO L290 TraceCheckUtils]: 26: Hoare triple {5619#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {5619#true} is VALID [2022-02-20 18:03:39,908 INFO L290 TraceCheckUtils]: 27: Hoare triple {5619#true} assume true; {5619#true} is VALID [2022-02-20 18:03:39,908 INFO L284 TraceCheckUtils]: 28: Hoare quadruple {5619#true} {5620#false} #1230#return; {5620#false} is VALID [2022-02-20 18:03:39,908 INFO L290 TraceCheckUtils]: 29: Hoare triple {5620#false} assume { :end_inline_setup_rjh } true;setup_~__cil_tmp2~1#1.base, setup_~__cil_tmp2~1#1.offset := 38, 0;havoc setup_#t~nondet98#1;~chuck~0 := 3;assume { :begin_inline_setup_chuck } true;setup_chuck_#in~chuck___0#1 := ~chuck~0;havoc setup_chuck_~chuck___0#1;setup_chuck_~chuck___0#1 := setup_chuck_#in~chuck___0#1;assume { :begin_inline_setup_chuck__wrappee__Base } true;setup_chuck__wrappee__Base_#in~chuck___0#1 := setup_chuck_~chuck___0#1;havoc setup_chuck__wrappee__Base_~chuck___0#1;setup_chuck__wrappee__Base_~chuck___0#1 := setup_chuck__wrappee__Base_#in~chuck___0#1; {5620#false} is VALID [2022-02-20 18:03:39,908 INFO L272 TraceCheckUtils]: 30: Hoare triple {5620#false} call setClientId(setup_chuck__wrappee__Base_~chuck___0#1, setup_chuck__wrappee__Base_~chuck___0#1); {5679#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} is VALID [2022-02-20 18:03:39,908 INFO L290 TraceCheckUtils]: 31: Hoare triple {5679#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {5619#true} is VALID [2022-02-20 18:03:39,908 INFO L290 TraceCheckUtils]: 32: Hoare triple {5619#true} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {5619#true} is VALID [2022-02-20 18:03:39,908 INFO L290 TraceCheckUtils]: 33: Hoare triple {5619#true} assume true; {5619#true} is VALID [2022-02-20 18:03:39,908 INFO L284 TraceCheckUtils]: 34: Hoare quadruple {5619#true} {5620#false} #1232#return; {5620#false} is VALID [2022-02-20 18:03:39,909 INFO L290 TraceCheckUtils]: 35: Hoare triple {5620#false} assume { :end_inline_setup_chuck__wrappee__Base } true; {5620#false} is VALID [2022-02-20 18:03:39,909 INFO L272 TraceCheckUtils]: 36: Hoare triple {5620#false} call setClientPrivateKey(setup_chuck_~chuck___0#1, 789); {5680#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} is VALID [2022-02-20 18:03:39,909 INFO L290 TraceCheckUtils]: 37: Hoare triple {5680#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {5619#true} is VALID [2022-02-20 18:03:39,909 INFO L290 TraceCheckUtils]: 38: Hoare triple {5619#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {5619#true} is VALID [2022-02-20 18:03:39,911 INFO L290 TraceCheckUtils]: 39: Hoare triple {5619#true} assume true; {5619#true} is VALID [2022-02-20 18:03:39,911 INFO L284 TraceCheckUtils]: 40: Hoare quadruple {5619#true} {5620#false} #1234#return; {5620#false} is VALID [2022-02-20 18:03:39,912 INFO L290 TraceCheckUtils]: 41: Hoare triple {5620#false} assume { :end_inline_setup_chuck } true;setup_~__cil_tmp3~4#1.base, setup_~__cil_tmp3~4#1.offset := 39, 0;havoc setup_#t~nondet99#1; {5620#false} is VALID [2022-02-20 18:03:39,912 INFO L290 TraceCheckUtils]: 42: Hoare triple {5620#false} assume { :end_inline_setup } true;assume { :begin_inline_test } true;havoc test_#t~nondet55#1, test_#t~nondet56#1, test_#t~nondet57#1, test_#t~nondet58#1, test_#t~nondet59#1, test_#t~nondet60#1, test_#t~nondet61#1, test_#t~nondet62#1, test_#t~nondet63#1, test_#t~nondet64#1, test_#t~nondet65#1, test_~op1~0#1, test_~op2~0#1, test_~op3~0#1, test_~op4~0#1, test_~op5~0#1, test_~op6~0#1, test_~op7~0#1, test_~op8~0#1, test_~op9~0#1, test_~op10~0#1, test_~op11~0#1, test_~splverifierCounter~0#1, test_~tmp~9#1, test_~tmp___0~3#1, test_~tmp___1~1#1, test_~tmp___2~1#1, test_~tmp___3~0#1, test_~tmp___4~0#1, test_~tmp___5~0#1, test_~tmp___6~0#1, test_~tmp___7~0#1, test_~tmp___8~0#1, test_~tmp___9~0#1;havoc test_~op1~0#1;havoc test_~op2~0#1;havoc test_~op3~0#1;havoc test_~op4~0#1;havoc test_~op5~0#1;havoc test_~op6~0#1;havoc test_~op7~0#1;havoc test_~op8~0#1;havoc test_~op9~0#1;havoc test_~op10~0#1;havoc test_~op11~0#1;havoc test_~splverifierCounter~0#1;havoc test_~tmp~9#1;havoc test_~tmp___0~3#1;havoc test_~tmp___1~1#1;havoc test_~tmp___2~1#1;havoc test_~tmp___3~0#1;havoc test_~tmp___4~0#1;havoc test_~tmp___5~0#1;havoc test_~tmp___6~0#1;havoc test_~tmp___7~0#1;havoc test_~tmp___8~0#1;havoc test_~tmp___9~0#1;test_~op1~0#1 := 0;test_~op2~0#1 := 0;test_~op3~0#1 := 0;test_~op4~0#1 := 0;test_~op5~0#1 := 0;test_~op6~0#1 := 0;test_~op7~0#1 := 0;test_~op8~0#1 := 0;test_~op9~0#1 := 0;test_~op10~0#1 := 0;test_~op11~0#1 := 0;test_~splverifierCounter~0#1 := 0; {5620#false} is VALID [2022-02-20 18:03:39,912 INFO L290 TraceCheckUtils]: 43: Hoare triple {5620#false} assume !false; {5620#false} is VALID [2022-02-20 18:03:39,912 INFO L290 TraceCheckUtils]: 44: Hoare triple {5620#false} assume test_~splverifierCounter~0#1 < 4; {5620#false} is VALID [2022-02-20 18:03:39,912 INFO L290 TraceCheckUtils]: 45: Hoare triple {5620#false} test_~splverifierCounter~0#1 := 1 + test_~splverifierCounter~0#1; {5620#false} is VALID [2022-02-20 18:03:39,915 INFO L290 TraceCheckUtils]: 46: Hoare triple {5620#false} assume !(0 == test_~op1~0#1); {5620#false} is VALID [2022-02-20 18:03:39,915 INFO L290 TraceCheckUtils]: 47: Hoare triple {5620#false} assume 0 == test_~op2~0#1;assume -2147483648 <= test_#t~nondet56#1 && test_#t~nondet56#1 <= 2147483647;test_~tmp___8~0#1 := test_#t~nondet56#1;havoc test_#t~nondet56#1; {5620#false} is VALID [2022-02-20 18:03:39,915 INFO L290 TraceCheckUtils]: 48: Hoare triple {5620#false} assume 0 != test_~tmp___8~0#1;test_~op2~0#1 := 1; {5620#false} is VALID [2022-02-20 18:03:39,915 INFO L290 TraceCheckUtils]: 49: Hoare triple {5620#false} assume !false; {5620#false} is VALID [2022-02-20 18:03:39,916 INFO L290 TraceCheckUtils]: 50: Hoare triple {5620#false} assume !(test_~splverifierCounter~0#1 < 4); {5620#false} is VALID [2022-02-20 18:03:39,916 INFO L290 TraceCheckUtils]: 51: Hoare triple {5620#false} assume { :begin_inline_bobToRjh } true;havoc bobToRjh_#t~ret92#1, bobToRjh_#t~ret93#1, bobToRjh_#t~ret94#1, bobToRjh_#t~ret95#1, bobToRjh_~tmp~19#1, bobToRjh_~tmp___0~8#1, bobToRjh_~tmp___1~5#1;havoc bobToRjh_~tmp~19#1;havoc bobToRjh_~tmp___0~8#1;havoc bobToRjh_~tmp___1~5#1;call bobToRjh_#t~ret92#1 := puts(35, 0);assume -2147483648 <= bobToRjh_#t~ret92#1 && bobToRjh_#t~ret92#1 <= 2147483647;havoc bobToRjh_#t~ret92#1; {5620#false} is VALID [2022-02-20 18:03:39,916 INFO L272 TraceCheckUtils]: 52: Hoare triple {5620#false} call sendEmail(~bob~0, ~rjh~0); {5620#false} is VALID [2022-02-20 18:03:39,916 INFO L290 TraceCheckUtils]: 53: Hoare triple {5620#false} ~sender#1 := #in~sender#1;~receiver#1 := #in~receiver#1;havoc ~email~0#1;havoc ~tmp~16#1;assume { :begin_inline_createEmail } true;createEmail_#in~from#1, createEmail_#in~to#1 := 0, ~receiver#1;havoc createEmail_#res#1;havoc createEmail_~from#1, createEmail_~to#1, createEmail_~retValue_acc~16#1, createEmail_~msg~0#1;createEmail_~from#1 := createEmail_#in~from#1;createEmail_~to#1 := createEmail_#in~to#1;havoc createEmail_~retValue_acc~16#1;havoc createEmail_~msg~0#1;createEmail_~msg~0#1 := 1; {5620#false} is VALID [2022-02-20 18:03:39,916 INFO L272 TraceCheckUtils]: 54: Hoare triple {5620#false} call setEmailFrom(createEmail_~msg~0#1, createEmail_~from#1); {5683#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} is VALID [2022-02-20 18:03:39,916 INFO L290 TraceCheckUtils]: 55: Hoare triple {5683#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} ~handle := #in~handle;~value := #in~value; {5619#true} is VALID [2022-02-20 18:03:39,916 INFO L290 TraceCheckUtils]: 56: Hoare triple {5619#true} assume 1 == ~handle;~__ste_email_from0~0 := ~value; {5619#true} is VALID [2022-02-20 18:03:39,917 INFO L290 TraceCheckUtils]: 57: Hoare triple {5619#true} assume true; {5619#true} is VALID [2022-02-20 18:03:39,917 INFO L284 TraceCheckUtils]: 58: Hoare quadruple {5619#true} {5620#false} #1210#return; {5620#false} is VALID [2022-02-20 18:03:39,917 INFO L272 TraceCheckUtils]: 59: Hoare triple {5620#false} call setEmailTo(createEmail_~msg~0#1, createEmail_~to#1); {5684#(and (= ~__ste_email_to0~0 |old(~__ste_email_to0~0)|) (= ~__ste_email_to1~0 |old(~__ste_email_to1~0)|))} is VALID [2022-02-20 18:03:39,917 INFO L290 TraceCheckUtils]: 60: Hoare triple {5684#(and (= ~__ste_email_to0~0 |old(~__ste_email_to0~0)|) (= ~__ste_email_to1~0 |old(~__ste_email_to1~0)|))} ~handle := #in~handle;~value := #in~value; {5619#true} is VALID [2022-02-20 18:03:39,917 INFO L290 TraceCheckUtils]: 61: Hoare triple {5619#true} assume 1 == ~handle;~__ste_email_to0~0 := ~value; {5619#true} is VALID [2022-02-20 18:03:39,917 INFO L290 TraceCheckUtils]: 62: Hoare triple {5619#true} assume true; {5619#true} is VALID [2022-02-20 18:03:39,917 INFO L284 TraceCheckUtils]: 63: Hoare quadruple {5619#true} {5620#false} #1212#return; {5620#false} is VALID [2022-02-20 18:03:39,918 INFO L290 TraceCheckUtils]: 64: Hoare triple {5620#false} createEmail_~retValue_acc~16#1 := createEmail_~msg~0#1;createEmail_#res#1 := createEmail_~retValue_acc~16#1; {5620#false} is VALID [2022-02-20 18:03:39,918 INFO L290 TraceCheckUtils]: 65: Hoare triple {5620#false} #t~ret83#1 := createEmail_#res#1;assume { :end_inline_createEmail } true;assume -2147483648 <= #t~ret83#1 && #t~ret83#1 <= 2147483647;~tmp~16#1 := #t~ret83#1;havoc #t~ret83#1;~email~0#1 := ~tmp~16#1; {5620#false} is VALID [2022-02-20 18:03:39,918 INFO L272 TraceCheckUtils]: 66: Hoare triple {5620#false} call outgoing(~sender#1, ~email~0#1); {5620#false} is VALID [2022-02-20 18:03:39,918 INFO L290 TraceCheckUtils]: 67: Hoare triple {5620#false} ~client#1 := #in~client#1;~msg#1 := #in~msg#1;assume { :begin_inline_sign } true;sign_#in~client#1, sign_#in~msg#1 := ~client#1, ~msg#1;havoc sign_#t~ret85#1, sign_~client#1, sign_~msg#1, sign_~privkey~1#1, sign_~tmp~17#1;sign_~client#1 := sign_#in~client#1;sign_~msg#1 := sign_#in~msg#1;havoc sign_~privkey~1#1;havoc sign_~tmp~17#1; {5620#false} is VALID [2022-02-20 18:03:39,918 INFO L272 TraceCheckUtils]: 68: Hoare triple {5620#false} call sign_#t~ret85#1 := getClientPrivateKey(sign_~client#1); {5619#true} is VALID [2022-02-20 18:03:39,918 INFO L290 TraceCheckUtils]: 69: Hoare triple {5619#true} ~handle := #in~handle;havoc ~retValue_acc~36; {5619#true} is VALID [2022-02-20 18:03:39,918 INFO L290 TraceCheckUtils]: 70: Hoare triple {5619#true} assume 1 == ~handle;~retValue_acc~36 := ~__ste_client_privateKey0~0;#res := ~retValue_acc~36; {5619#true} is VALID [2022-02-20 18:03:39,919 INFO L290 TraceCheckUtils]: 71: Hoare triple {5619#true} assume true; {5619#true} is VALID [2022-02-20 18:03:39,919 INFO L284 TraceCheckUtils]: 72: Hoare quadruple {5619#true} {5620#false} #1150#return; {5620#false} is VALID [2022-02-20 18:03:39,919 INFO L290 TraceCheckUtils]: 73: Hoare triple {5620#false} assume -2147483648 <= sign_#t~ret85#1 && sign_#t~ret85#1 <= 2147483647;sign_~tmp~17#1 := sign_#t~ret85#1;havoc sign_#t~ret85#1;sign_~privkey~1#1 := sign_~tmp~17#1; {5620#false} is VALID [2022-02-20 18:03:39,919 INFO L290 TraceCheckUtils]: 74: Hoare triple {5620#false} assume 0 == sign_~privkey~1#1; {5620#false} is VALID [2022-02-20 18:03:39,919 INFO L290 TraceCheckUtils]: 75: Hoare triple {5620#false} assume { :end_inline_sign } true;assume { :begin_inline_outgoing__wrappee__AddressBook } true;outgoing__wrappee__AddressBook_#in~client#1, outgoing__wrappee__AddressBook_#in~msg#1 := ~client#1, ~msg#1;havoc outgoing__wrappee__AddressBook_#t~ret71#1, outgoing__wrappee__AddressBook_#t~ret72#1, outgoing__wrappee__AddressBook_#t~ret73#1, outgoing__wrappee__AddressBook_#t~ret74#1, outgoing__wrappee__AddressBook_#t~ret75#1, outgoing__wrappee__AddressBook_#t~ret76#1, outgoing__wrappee__AddressBook_~client#1, outgoing__wrappee__AddressBook_~msg#1, outgoing__wrappee__AddressBook_~size~0#1, outgoing__wrappee__AddressBook_~tmp~13#1, outgoing__wrappee__AddressBook_~receiver~1#1, outgoing__wrappee__AddressBook_~tmp___0~5#1, outgoing__wrappee__AddressBook_~second~0#1, outgoing__wrappee__AddressBook_~tmp___1~2#1, outgoing__wrappee__AddressBook_~tmp___2~2#1;outgoing__wrappee__AddressBook_~client#1 := outgoing__wrappee__AddressBook_#in~client#1;outgoing__wrappee__AddressBook_~msg#1 := outgoing__wrappee__AddressBook_#in~msg#1;havoc outgoing__wrappee__AddressBook_~size~0#1;havoc outgoing__wrappee__AddressBook_~tmp~13#1;havoc outgoing__wrappee__AddressBook_~receiver~1#1;havoc outgoing__wrappee__AddressBook_~tmp___0~5#1;havoc outgoing__wrappee__AddressBook_~second~0#1;havoc outgoing__wrappee__AddressBook_~tmp___1~2#1;havoc outgoing__wrappee__AddressBook_~tmp___2~2#1; {5620#false} is VALID [2022-02-20 18:03:39,919 INFO L272 TraceCheckUtils]: 76: Hoare triple {5620#false} call outgoing__wrappee__AddressBook_#t~ret71#1 := getClientAddressBookSize(outgoing__wrappee__AddressBook_~client#1); {5619#true} is VALID [2022-02-20 18:03:39,919 INFO L290 TraceCheckUtils]: 77: Hoare triple {5619#true} ~handle := #in~handle;havoc ~retValue_acc~30; {5619#true} is VALID [2022-02-20 18:03:39,919 INFO L290 TraceCheckUtils]: 78: Hoare triple {5619#true} assume 1 == ~handle;~retValue_acc~30 := ~__ste_ClientAddressBook_size0~0;#res := ~retValue_acc~30; {5619#true} is VALID [2022-02-20 18:03:39,920 INFO L290 TraceCheckUtils]: 79: Hoare triple {5619#true} assume true; {5619#true} is VALID [2022-02-20 18:03:39,920 INFO L284 TraceCheckUtils]: 80: Hoare quadruple {5619#true} {5620#false} #1152#return; {5620#false} is VALID [2022-02-20 18:03:39,920 INFO L290 TraceCheckUtils]: 81: Hoare triple {5620#false} assume -2147483648 <= outgoing__wrappee__AddressBook_#t~ret71#1 && outgoing__wrappee__AddressBook_#t~ret71#1 <= 2147483647;outgoing__wrappee__AddressBook_~tmp~13#1 := outgoing__wrappee__AddressBook_#t~ret71#1;havoc outgoing__wrappee__AddressBook_#t~ret71#1;outgoing__wrappee__AddressBook_~size~0#1 := outgoing__wrappee__AddressBook_~tmp~13#1; {5620#false} is VALID [2022-02-20 18:03:39,920 INFO L290 TraceCheckUtils]: 82: Hoare triple {5620#false} assume !(0 != outgoing__wrappee__AddressBook_~size~0#1); {5620#false} is VALID [2022-02-20 18:03:39,920 INFO L272 TraceCheckUtils]: 83: Hoare triple {5620#false} call outgoing__wrappee__Encrypt(outgoing__wrappee__AddressBook_~client#1, outgoing__wrappee__AddressBook_~msg#1); {5620#false} is VALID [2022-02-20 18:03:39,920 INFO L290 TraceCheckUtils]: 84: Hoare triple {5620#false} ~client#1 := #in~client#1;~msg#1 := #in~msg#1;havoc ~receiver~0#1;havoc ~tmp~12#1;havoc ~pubkey~0#1;havoc ~tmp___0~4#1; {5620#false} is VALID [2022-02-20 18:03:39,920 INFO L272 TraceCheckUtils]: 85: Hoare triple {5620#false} call #t~ret69#1 := getEmailTo(~msg#1); {5619#true} is VALID [2022-02-20 18:03:39,921 INFO L290 TraceCheckUtils]: 86: Hoare triple {5619#true} ~handle := #in~handle;havoc ~retValue_acc~3; {5619#true} is VALID [2022-02-20 18:03:39,921 INFO L290 TraceCheckUtils]: 87: Hoare triple {5619#true} assume 1 == ~handle;~retValue_acc~3 := ~__ste_email_to0~0;#res := ~retValue_acc~3; {5619#true} is VALID [2022-02-20 18:03:39,921 INFO L290 TraceCheckUtils]: 88: Hoare triple {5619#true} assume true; {5619#true} is VALID [2022-02-20 18:03:39,921 INFO L284 TraceCheckUtils]: 89: Hoare quadruple {5619#true} {5620#false} #1170#return; {5620#false} is VALID [2022-02-20 18:03:39,921 INFO L290 TraceCheckUtils]: 90: Hoare triple {5620#false} assume -2147483648 <= #t~ret69#1 && #t~ret69#1 <= 2147483647;~tmp~12#1 := #t~ret69#1;havoc #t~ret69#1;~receiver~0#1 := ~tmp~12#1; {5620#false} is VALID [2022-02-20 18:03:39,921 INFO L272 TraceCheckUtils]: 91: Hoare triple {5620#false} call #t~ret70#1 := findPublicKey(~client#1, ~receiver~0#1); {5619#true} is VALID [2022-02-20 18:03:39,922 INFO L290 TraceCheckUtils]: 92: Hoare triple {5619#true} ~handle := #in~handle;~userid := #in~userid;havoc ~retValue_acc~41; {5619#true} is VALID [2022-02-20 18:03:39,922 INFO L290 TraceCheckUtils]: 93: Hoare triple {5619#true} assume 1 == ~handle; {5619#true} is VALID [2022-02-20 18:03:39,922 INFO L290 TraceCheckUtils]: 94: Hoare triple {5619#true} assume ~userid == ~__ste_Client_Keyring0_User0~0;~retValue_acc~41 := ~__ste_Client_Keyring0_PublicKey0~0;#res := ~retValue_acc~41; {5619#true} is VALID [2022-02-20 18:03:39,922 INFO L290 TraceCheckUtils]: 95: Hoare triple {5619#true} assume true; {5619#true} is VALID [2022-02-20 18:03:39,922 INFO L284 TraceCheckUtils]: 96: Hoare quadruple {5619#true} {5620#false} #1172#return; {5620#false} is VALID [2022-02-20 18:03:39,922 INFO L290 TraceCheckUtils]: 97: Hoare triple {5620#false} assume -2147483648 <= #t~ret70#1 && #t~ret70#1 <= 2147483647;~tmp___0~4#1 := #t~ret70#1;havoc #t~ret70#1;~pubkey~0#1 := ~tmp___0~4#1; {5620#false} is VALID [2022-02-20 18:03:39,922 INFO L290 TraceCheckUtils]: 98: Hoare triple {5620#false} assume !(0 != ~pubkey~0#1); {5620#false} is VALID [2022-02-20 18:03:39,923 INFO L290 TraceCheckUtils]: 99: Hoare triple {5620#false} assume { :begin_inline_outgoing__wrappee__Keys } true;outgoing__wrappee__Keys_#in~client#1, outgoing__wrappee__Keys_#in~msg#1 := ~client#1, ~msg#1;havoc outgoing__wrappee__Keys_#t~ret68#1, outgoing__wrappee__Keys_~client#1, outgoing__wrappee__Keys_~msg#1, outgoing__wrappee__Keys_~tmp~11#1;outgoing__wrappee__Keys_~client#1 := outgoing__wrappee__Keys_#in~client#1;outgoing__wrappee__Keys_~msg#1 := outgoing__wrappee__Keys_#in~msg#1;havoc outgoing__wrappee__Keys_~tmp~11#1;assume { :begin_inline_getClientId } true;getClientId_#in~handle#1 := outgoing__wrappee__Keys_~client#1;havoc getClientId_#res#1;havoc getClientId_~handle#1, getClientId_~retValue_acc~43#1;getClientId_~handle#1 := getClientId_#in~handle#1;havoc getClientId_~retValue_acc~43#1; {5620#false} is VALID [2022-02-20 18:03:39,923 INFO L290 TraceCheckUtils]: 100: Hoare triple {5620#false} assume 1 == getClientId_~handle#1;getClientId_~retValue_acc~43#1 := ~__ste_client_idCounter0~0;getClientId_#res#1 := getClientId_~retValue_acc~43#1; {5620#false} is VALID [2022-02-20 18:03:39,923 INFO L290 TraceCheckUtils]: 101: Hoare triple {5620#false} outgoing__wrappee__Keys_#t~ret68#1 := getClientId_#res#1;assume { :end_inline_getClientId } true;assume -2147483648 <= outgoing__wrappee__Keys_#t~ret68#1 && outgoing__wrappee__Keys_#t~ret68#1 <= 2147483647;outgoing__wrappee__Keys_~tmp~11#1 := outgoing__wrappee__Keys_#t~ret68#1;havoc outgoing__wrappee__Keys_#t~ret68#1; {5620#false} is VALID [2022-02-20 18:03:39,923 INFO L272 TraceCheckUtils]: 102: Hoare triple {5620#false} call setEmailFrom(outgoing__wrappee__Keys_~msg#1, outgoing__wrappee__Keys_~tmp~11#1); {5683#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} is VALID [2022-02-20 18:03:39,923 INFO L290 TraceCheckUtils]: 103: Hoare triple {5683#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} ~handle := #in~handle;~value := #in~value; {5619#true} is VALID [2022-02-20 18:03:39,923 INFO L290 TraceCheckUtils]: 104: Hoare triple {5619#true} assume 1 == ~handle;~__ste_email_from0~0 := ~value; {5619#true} is VALID [2022-02-20 18:03:39,923 INFO L290 TraceCheckUtils]: 105: Hoare triple {5619#true} assume true; {5619#true} is VALID [2022-02-20 18:03:39,924 INFO L284 TraceCheckUtils]: 106: Hoare quadruple {5619#true} {5620#false} #1178#return; {5620#false} is VALID [2022-02-20 18:03:39,924 INFO L290 TraceCheckUtils]: 107: Hoare triple {5620#false} assume { :begin_inline_mail } true;mail_#in~client#1, mail_#in~msg#1 := outgoing__wrappee__Keys_~client#1, outgoing__wrappee__Keys_~msg#1;havoc mail_#t~ret66#1, mail_#t~ret67#1, mail_~client#1, mail_~msg#1, mail_~__utac__ad__arg1~0#1, mail_~tmp~10#1;mail_~client#1 := mail_#in~client#1;mail_~msg#1 := mail_#in~msg#1;havoc mail_~__utac__ad__arg1~0#1;havoc mail_~tmp~10#1;mail_~__utac__ad__arg1~0#1 := mail_~msg#1;assume { :begin_inline___utac_acc__EncryptAutoResponder_spec__2 } true;__utac_acc__EncryptAutoResponder_spec__2_#in~msg#1 := mail_~__utac__ad__arg1~0#1;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1, __utac_acc__EncryptAutoResponder_spec__2_#t~nondet29#1, __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1, __utac_acc__EncryptAutoResponder_spec__2_~msg#1, __utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.base, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.offset;__utac_acc__EncryptAutoResponder_spec__2_~msg#1 := __utac_acc__EncryptAutoResponder_spec__2_#in~msg#1;havoc __utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1;havoc __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.base, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.offset;call __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1 := puts(15, 0);assume -2147483648 <= __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1 && __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1 <= 2147483647;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1;__utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.base, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.offset := 16, 0;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~nondet29#1; {5620#false} is VALID [2022-02-20 18:03:39,924 INFO L290 TraceCheckUtils]: 108: Hoare triple {5620#false} assume 0 != ~in_encrypted~0; {5620#false} is VALID [2022-02-20 18:03:39,924 INFO L272 TraceCheckUtils]: 109: Hoare triple {5620#false} call __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1 := isEncrypted(__utac_acc__EncryptAutoResponder_spec__2_~msg#1); {5619#true} is VALID [2022-02-20 18:03:39,924 INFO L290 TraceCheckUtils]: 110: Hoare triple {5619#true} ~handle := #in~handle;havoc ~retValue_acc~6; {5619#true} is VALID [2022-02-20 18:03:39,924 INFO L290 TraceCheckUtils]: 111: Hoare triple {5619#true} assume 1 == ~handle;~retValue_acc~6 := ~__ste_email_isEncrypted0~0;#res := ~retValue_acc~6; {5619#true} is VALID [2022-02-20 18:03:39,924 INFO L290 TraceCheckUtils]: 112: Hoare triple {5619#true} assume true; {5619#true} is VALID [2022-02-20 18:03:39,925 INFO L284 TraceCheckUtils]: 113: Hoare quadruple {5619#true} {5620#false} #1180#return; {5620#false} is VALID [2022-02-20 18:03:39,925 INFO L290 TraceCheckUtils]: 114: Hoare triple {5620#false} assume -2147483648 <= __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1 && __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1 <= 2147483647;__utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1 := __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1; {5620#false} is VALID [2022-02-20 18:03:39,925 INFO L290 TraceCheckUtils]: 115: Hoare triple {5620#false} assume !(0 != __utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1);assume { :begin_inline___automaton_fail } true; {5620#false} is VALID [2022-02-20 18:03:39,925 INFO L290 TraceCheckUtils]: 116: Hoare triple {5620#false} assume !false; {5620#false} is VALID [2022-02-20 18:03:39,926 INFO L134 CoverageAnalysis]: Checked inductivity of 30 backedges. 3 proven. 3 refuted. 0 times theorem prover too weak. 24 trivial. 0 not checked. [2022-02-20 18:03:39,927 INFO L144 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-02-20 18:03:39,927 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [1918465512] [2022-02-20 18:03:39,928 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleSmtInterpolCraig [1918465512] provided 0 perfect and 1 imperfect interpolant sequences [2022-02-20 18:03:39,928 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [615637377] [2022-02-20 18:03:39,928 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 18:03:39,928 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-02-20 18:03:39,929 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-02-20 18:03:39,944 INFO L229 MonitoredProcess]: Starting monitored process 4 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2022-02-20 18:03:39,945 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (4)] Waiting until timeout for monitored process [2022-02-20 18:03:40,198 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:40,203 INFO L263 TraceCheckSpWp]: Trace formula consists of 1125 conjuncts, 3 conjunts are in the unsatisfiable core [2022-02-20 18:03:40,246 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:40,248 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-02-20 18:03:40,458 INFO L290 TraceCheckUtils]: 0: Hoare triple {5619#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(28, 2);call #Ultimate.allocInit(12, 3);call #Ultimate.allocInit(10, 4);call #Ultimate.allocInit(12, 5);call #Ultimate.allocInit(10, 6);call #Ultimate.allocInit(18, 7);call #Ultimate.allocInit(16, 8);call #Ultimate.allocInit(21, 9);call #Ultimate.allocInit(13, 10);call #Ultimate.allocInit(16, 11);call #Ultimate.allocInit(25, 12);call #Ultimate.allocInit(17, 13);call #Ultimate.allocInit(17, 14);call #Ultimate.allocInit(13, 15);call #Ultimate.allocInit(17, 16);call #Ultimate.allocInit(30, 17);call #Ultimate.allocInit(9, 18);call #Ultimate.allocInit(21, 19);call #Ultimate.allocInit(30, 20);call #Ultimate.allocInit(9, 21);call #Ultimate.allocInit(21, 22);call #Ultimate.allocInit(30, 23);call #Ultimate.allocInit(9, 24);call #Ultimate.allocInit(25, 25);call #Ultimate.allocInit(30, 26);call #Ultimate.allocInit(9, 27);call #Ultimate.allocInit(25, 28);call #Ultimate.allocInit(4, 29);call write~init~int(37, 29, 0, 1);call write~init~int(115, 29, 1, 1);call write~init~int(10, 29, 2, 1);call write~init~int(0, 29, 3, 1);call #Ultimate.allocInit(10, 30);call #Ultimate.allocInit(34, 31);call #Ultimate.allocInit(30, 32);call #Ultimate.allocInit(16, 33);call #Ultimate.allocInit(20, 34);call #Ultimate.allocInit(44, 35);call #Ultimate.allocInit(44, 36);call #Ultimate.allocInit(9, 37);call #Ultimate.allocInit(9, 38);call #Ultimate.allocInit(11, 39);call #Ultimate.allocInit(19, 40);call #Ultimate.allocInit(4, 41);call write~init~int(37, 41, 0, 1);call write~init~int(100, 41, 1, 1);call write~init~int(10, 41, 2, 1);call write~init~int(0, 41, 3, 1);call #Ultimate.allocInit(4, 42);call write~init~int(37, 42, 0, 1);call write~init~int(100, 42, 1, 1);call write~init~int(10, 42, 2, 1);call write~init~int(0, 42, 3, 1);~__ste_Email_counter~0 := 0;~__ste_email_id0~0 := 0;~__ste_email_id1~0 := 0;~__ste_email_from0~0 := 0;~__ste_email_from1~0 := 0;~__ste_email_to0~0 := 0;~__ste_email_to1~0 := 0;~__ste_email_subject0~0.base, ~__ste_email_subject0~0.offset := 0, 0;~__ste_email_subject1~0.base, ~__ste_email_subject1~0.offset := 0, 0;~__ste_email_body0~0.base, ~__ste_email_body0~0.offset := 0, 0;~__ste_email_body1~0.base, ~__ste_email_body1~0.offset := 0, 0;~__ste_email_isEncrypted0~0 := 0;~__ste_email_isEncrypted1~0 := 0;~__ste_email_encryptionKey0~0 := 0;~__ste_email_encryptionKey1~0 := 0;~__ste_email_isSigned0~0 := 0;~__ste_email_isSigned1~0 := 0;~__ste_email_signKey0~0 := 0;~__ste_email_signKey1~0 := 0;~__ste_email_isSignatureVerified0~0 := 0;~__ste_email_isSignatureVerified1~0 := 0;~__SELECTED_FEATURE_Base~0 := 0;~__SELECTED_FEATURE_Keys~0 := 0;~__SELECTED_FEATURE_Encrypt~0 := 0;~__SELECTED_FEATURE_AutoResponder~0 := 0;~__SELECTED_FEATURE_AddressBook~0 := 0;~__SELECTED_FEATURE_Sign~0 := 0;~__SELECTED_FEATURE_Forward~0 := 0;~__SELECTED_FEATURE_Verify~0 := 0;~__SELECTED_FEATURE_Decrypt~0 := 0;~__GUIDSL_ROOT_PRODUCTION~0 := 0;~__GUIDSL_NON_TERMINAL_main~0 := 0;~in_encrypted~0 := 0;~head~0.base, ~head~0.offset := 0, 0;~queue_empty~0 := 1;~queued_message~0 := 0;~queued_client~0 := 0;~bob~0 := 0;~rjh~0 := 0;~chuck~0 := 0;~__ste_Client_counter~0 := 0;~__ste_client_name0~0.base, ~__ste_client_name0~0.offset := 0, 0;~__ste_client_name1~0.base, ~__ste_client_name1~0.offset := 0, 0;~__ste_client_name2~0.base, ~__ste_client_name2~0.offset := 0, 0;~__ste_client_outbuffer0~0 := 0;~__ste_client_outbuffer1~0 := 0;~__ste_client_outbuffer2~0 := 0;~__ste_client_outbuffer3~0 := 0;~__ste_ClientAddressBook_size0~0 := 0;~__ste_ClientAddressBook_size1~0 := 0;~__ste_ClientAddressBook_size2~0 := 0;~__ste_Client_AddressBook0_Alias0~0 := 0;~__ste_Client_AddressBook0_Alias1~0 := 0;~__ste_Client_AddressBook0_Alias2~0 := 0;~__ste_Client_AddressBook1_Alias0~0 := 0;~__ste_Client_AddressBook1_Alias1~0 := 0;~__ste_Client_AddressBook1_Alias2~0 := 0;~__ste_Client_AddressBook2_Alias0~0 := 0;~__ste_Client_AddressBook2_Alias1~0 := 0;~__ste_Client_AddressBook2_Alias2~0 := 0;~__ste_Client_AddressBook0_Address0~0 := 0;~__ste_Client_AddressBook0_Address1~0 := 0;~__ste_Client_AddressBook0_Address2~0 := 0;~__ste_Client_AddressBook1_Address0~0 := 0;~__ste_Client_AddressBook1_Address1~0 := 0;~__ste_Client_AddressBook1_Address2~0 := 0;~__ste_Client_AddressBook2_Address0~0 := 0;~__ste_Client_AddressBook2_Address1~0 := 0;~__ste_Client_AddressBook2_Address2~0 := 0;~__ste_client_autoResponse0~0 := 0;~__ste_client_autoResponse1~0 := 0;~__ste_client_autoResponse2~0 := 0;~__ste_client_privateKey0~0 := 0;~__ste_client_privateKey1~0 := 0;~__ste_client_privateKey2~0 := 0;~__ste_ClientKeyring_size0~0 := 0;~__ste_ClientKeyring_size1~0 := 0;~__ste_ClientKeyring_size2~0 := 0;~__ste_Client_Keyring0_User0~0 := 0;~__ste_Client_Keyring0_User1~0 := 0;~__ste_Client_Keyring0_User2~0 := 0;~__ste_Client_Keyring1_User0~0 := 0;~__ste_Client_Keyring1_User1~0 := 0;~__ste_Client_Keyring1_User2~0 := 0;~__ste_Client_Keyring2_User0~0 := 0;~__ste_Client_Keyring2_User1~0 := 0;~__ste_Client_Keyring2_User2~0 := 0;~__ste_Client_Keyring0_PublicKey0~0 := 0;~__ste_Client_Keyring0_PublicKey1~0 := 0;~__ste_Client_Keyring0_PublicKey2~0 := 0;~__ste_Client_Keyring1_PublicKey0~0 := 0;~__ste_Client_Keyring1_PublicKey1~0 := 0;~__ste_Client_Keyring1_PublicKey2~0 := 0;~__ste_Client_Keyring2_PublicKey0~0 := 0;~__ste_Client_Keyring2_PublicKey1~0 := 0;~__ste_Client_Keyring2_PublicKey2~0 := 0;~__ste_client_forwardReceiver0~0 := 0;~__ste_client_forwardReceiver1~0 := 0;~__ste_client_forwardReceiver2~0 := 0;~__ste_client_forwardReceiver3~0 := 0;~__ste_client_idCounter0~0 := 0;~__ste_client_idCounter1~0 := 0;~__ste_client_idCounter2~0 := 0; {5619#true} is VALID [2022-02-20 18:03:40,459 INFO L290 TraceCheckUtils]: 1: Hoare triple {5619#true} assume { :end_inline_ULTIMATE.init } true;assume { :begin_inline_main } true;havoc main_#res#1;havoc main_#t~nondet100#1, main_#t~ret101#1, main_~retValue_acc~26#1, main_~tmp~20#1;assume -2147483648 <= main_#t~nondet100#1 && main_#t~nondet100#1 <= 2147483647;main_~retValue_acc~26#1 := main_#t~nondet100#1;havoc main_#t~nondet100#1;havoc main_~tmp~20#1;assume { :begin_inline_select_helpers } true; {5619#true} is VALID [2022-02-20 18:03:40,459 INFO L290 TraceCheckUtils]: 2: Hoare triple {5619#true} assume { :end_inline_select_helpers } true;assume { :begin_inline_select_features } true; {5619#true} is VALID [2022-02-20 18:03:40,459 INFO L290 TraceCheckUtils]: 3: Hoare triple {5619#true} assume { :end_inline_select_features } true;assume { :begin_inline_valid_product } true;havoc valid_product_#res#1;havoc valid_product_~retValue_acc~12#1;havoc valid_product_~retValue_acc~12#1;valid_product_~retValue_acc~12#1 := 1;valid_product_#res#1 := valid_product_~retValue_acc~12#1; {5619#true} is VALID [2022-02-20 18:03:40,459 INFO L290 TraceCheckUtils]: 4: Hoare triple {5619#true} main_#t~ret101#1 := valid_product_#res#1;assume { :end_inline_valid_product } true;assume -2147483648 <= main_#t~ret101#1 && main_#t~ret101#1 <= 2147483647;main_~tmp~20#1 := main_#t~ret101#1;havoc main_#t~ret101#1; {5619#true} is VALID [2022-02-20 18:03:40,459 INFO L290 TraceCheckUtils]: 5: Hoare triple {5619#true} assume 0 != main_~tmp~20#1;assume { :begin_inline_setup } true;havoc setup_#t~nondet97#1, setup_#t~nondet98#1, setup_#t~nondet99#1, setup_~__cil_tmp1~0#1.base, setup_~__cil_tmp1~0#1.offset, setup_~__cil_tmp2~1#1.base, setup_~__cil_tmp2~1#1.offset, setup_~__cil_tmp3~4#1.base, setup_~__cil_tmp3~4#1.offset;havoc setup_~__cil_tmp1~0#1.base, setup_~__cil_tmp1~0#1.offset;havoc setup_~__cil_tmp2~1#1.base, setup_~__cil_tmp2~1#1.offset;havoc setup_~__cil_tmp3~4#1.base, setup_~__cil_tmp3~4#1.offset;~bob~0 := 1;assume { :begin_inline_setup_bob } true;setup_bob_#in~bob___0#1 := ~bob~0;havoc setup_bob_~bob___0#1;setup_bob_~bob___0#1 := setup_bob_#in~bob___0#1;assume { :begin_inline_setup_bob__wrappee__Base } true;setup_bob__wrappee__Base_#in~bob___0#1 := setup_bob_~bob___0#1;havoc setup_bob__wrappee__Base_~bob___0#1;setup_bob__wrappee__Base_~bob___0#1 := setup_bob__wrappee__Base_#in~bob___0#1; {5619#true} is VALID [2022-02-20 18:03:40,459 INFO L272 TraceCheckUtils]: 6: Hoare triple {5619#true} call setClientId(setup_bob__wrappee__Base_~bob___0#1, setup_bob__wrappee__Base_~bob___0#1); {5619#true} is VALID [2022-02-20 18:03:40,459 INFO L290 TraceCheckUtils]: 7: Hoare triple {5619#true} ~handle := #in~handle;~value := #in~value; {5619#true} is VALID [2022-02-20 18:03:40,459 INFO L290 TraceCheckUtils]: 8: Hoare triple {5619#true} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {5619#true} is VALID [2022-02-20 18:03:40,459 INFO L290 TraceCheckUtils]: 9: Hoare triple {5619#true} assume true; {5619#true} is VALID [2022-02-20 18:03:40,459 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {5619#true} {5619#true} #1224#return; {5619#true} is VALID [2022-02-20 18:03:40,459 INFO L290 TraceCheckUtils]: 11: Hoare triple {5619#true} assume { :end_inline_setup_bob__wrappee__Base } true; {5619#true} is VALID [2022-02-20 18:03:40,459 INFO L272 TraceCheckUtils]: 12: Hoare triple {5619#true} call setClientPrivateKey(setup_bob_~bob___0#1, 123); {5619#true} is VALID [2022-02-20 18:03:40,460 INFO L290 TraceCheckUtils]: 13: Hoare triple {5619#true} ~handle := #in~handle;~value := #in~value; {5619#true} is VALID [2022-02-20 18:03:40,460 INFO L290 TraceCheckUtils]: 14: Hoare triple {5619#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {5619#true} is VALID [2022-02-20 18:03:40,460 INFO L290 TraceCheckUtils]: 15: Hoare triple {5619#true} assume true; {5619#true} is VALID [2022-02-20 18:03:40,460 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {5619#true} {5619#true} #1226#return; {5619#true} is VALID [2022-02-20 18:03:40,460 INFO L290 TraceCheckUtils]: 17: Hoare triple {5619#true} assume { :end_inline_setup_bob } true;setup_~__cil_tmp1~0#1.base, setup_~__cil_tmp1~0#1.offset := 37, 0;havoc setup_#t~nondet97#1;~rjh~0 := 2;assume { :begin_inline_setup_rjh } true;setup_rjh_#in~rjh___0#1 := ~rjh~0;havoc setup_rjh_~rjh___0#1;setup_rjh_~rjh___0#1 := setup_rjh_#in~rjh___0#1;assume { :begin_inline_setup_rjh__wrappee__Base } true;setup_rjh__wrappee__Base_#in~rjh___0#1 := setup_rjh_~rjh___0#1;havoc setup_rjh__wrappee__Base_~rjh___0#1;setup_rjh__wrappee__Base_~rjh___0#1 := setup_rjh__wrappee__Base_#in~rjh___0#1; {5619#true} is VALID [2022-02-20 18:03:40,460 INFO L272 TraceCheckUtils]: 18: Hoare triple {5619#true} call setClientId(setup_rjh__wrappee__Base_~rjh___0#1, setup_rjh__wrappee__Base_~rjh___0#1); {5619#true} is VALID [2022-02-20 18:03:40,460 INFO L290 TraceCheckUtils]: 19: Hoare triple {5619#true} ~handle := #in~handle;~value := #in~value; {5619#true} is VALID [2022-02-20 18:03:40,460 INFO L290 TraceCheckUtils]: 20: Hoare triple {5619#true} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {5619#true} is VALID [2022-02-20 18:03:40,460 INFO L290 TraceCheckUtils]: 21: Hoare triple {5619#true} assume true; {5619#true} is VALID [2022-02-20 18:03:40,460 INFO L284 TraceCheckUtils]: 22: Hoare quadruple {5619#true} {5619#true} #1228#return; {5619#true} is VALID [2022-02-20 18:03:40,460 INFO L290 TraceCheckUtils]: 23: Hoare triple {5619#true} assume { :end_inline_setup_rjh__wrappee__Base } true; {5619#true} is VALID [2022-02-20 18:03:40,460 INFO L272 TraceCheckUtils]: 24: Hoare triple {5619#true} call setClientPrivateKey(setup_rjh_~rjh___0#1, 456); {5619#true} is VALID [2022-02-20 18:03:40,460 INFO L290 TraceCheckUtils]: 25: Hoare triple {5619#true} ~handle := #in~handle;~value := #in~value; {5619#true} is VALID [2022-02-20 18:03:40,460 INFO L290 TraceCheckUtils]: 26: Hoare triple {5619#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {5619#true} is VALID [2022-02-20 18:03:40,460 INFO L290 TraceCheckUtils]: 27: Hoare triple {5619#true} assume true; {5619#true} is VALID [2022-02-20 18:03:40,461 INFO L284 TraceCheckUtils]: 28: Hoare quadruple {5619#true} {5619#true} #1230#return; {5619#true} is VALID [2022-02-20 18:03:40,461 INFO L290 TraceCheckUtils]: 29: Hoare triple {5619#true} assume { :end_inline_setup_rjh } true;setup_~__cil_tmp2~1#1.base, setup_~__cil_tmp2~1#1.offset := 38, 0;havoc setup_#t~nondet98#1;~chuck~0 := 3;assume { :begin_inline_setup_chuck } true;setup_chuck_#in~chuck___0#1 := ~chuck~0;havoc setup_chuck_~chuck___0#1;setup_chuck_~chuck___0#1 := setup_chuck_#in~chuck___0#1;assume { :begin_inline_setup_chuck__wrappee__Base } true;setup_chuck__wrappee__Base_#in~chuck___0#1 := setup_chuck_~chuck___0#1;havoc setup_chuck__wrappee__Base_~chuck___0#1;setup_chuck__wrappee__Base_~chuck___0#1 := setup_chuck__wrappee__Base_#in~chuck___0#1; {5619#true} is VALID [2022-02-20 18:03:40,461 INFO L272 TraceCheckUtils]: 30: Hoare triple {5619#true} call setClientId(setup_chuck__wrappee__Base_~chuck___0#1, setup_chuck__wrappee__Base_~chuck___0#1); {5619#true} is VALID [2022-02-20 18:03:40,461 INFO L290 TraceCheckUtils]: 31: Hoare triple {5619#true} ~handle := #in~handle;~value := #in~value; {5619#true} is VALID [2022-02-20 18:03:40,461 INFO L290 TraceCheckUtils]: 32: Hoare triple {5619#true} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {5619#true} is VALID [2022-02-20 18:03:40,461 INFO L290 TraceCheckUtils]: 33: Hoare triple {5619#true} assume true; {5619#true} is VALID [2022-02-20 18:03:40,461 INFO L284 TraceCheckUtils]: 34: Hoare quadruple {5619#true} {5619#true} #1232#return; {5619#true} is VALID [2022-02-20 18:03:40,461 INFO L290 TraceCheckUtils]: 35: Hoare triple {5619#true} assume { :end_inline_setup_chuck__wrappee__Base } true; {5619#true} is VALID [2022-02-20 18:03:40,461 INFO L272 TraceCheckUtils]: 36: Hoare triple {5619#true} call setClientPrivateKey(setup_chuck_~chuck___0#1, 789); {5619#true} is VALID [2022-02-20 18:03:40,461 INFO L290 TraceCheckUtils]: 37: Hoare triple {5619#true} ~handle := #in~handle;~value := #in~value; {5619#true} is VALID [2022-02-20 18:03:40,461 INFO L290 TraceCheckUtils]: 38: Hoare triple {5619#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {5619#true} is VALID [2022-02-20 18:03:40,461 INFO L290 TraceCheckUtils]: 39: Hoare triple {5619#true} assume true; {5619#true} is VALID [2022-02-20 18:03:40,461 INFO L284 TraceCheckUtils]: 40: Hoare quadruple {5619#true} {5619#true} #1234#return; {5619#true} is VALID [2022-02-20 18:03:40,461 INFO L290 TraceCheckUtils]: 41: Hoare triple {5619#true} assume { :end_inline_setup_chuck } true;setup_~__cil_tmp3~4#1.base, setup_~__cil_tmp3~4#1.offset := 39, 0;havoc setup_#t~nondet99#1; {5619#true} is VALID [2022-02-20 18:03:40,462 INFO L290 TraceCheckUtils]: 42: Hoare triple {5619#true} assume { :end_inline_setup } true;assume { :begin_inline_test } true;havoc test_#t~nondet55#1, test_#t~nondet56#1, test_#t~nondet57#1, test_#t~nondet58#1, test_#t~nondet59#1, test_#t~nondet60#1, test_#t~nondet61#1, test_#t~nondet62#1, test_#t~nondet63#1, test_#t~nondet64#1, test_#t~nondet65#1, test_~op1~0#1, test_~op2~0#1, test_~op3~0#1, test_~op4~0#1, test_~op5~0#1, test_~op6~0#1, test_~op7~0#1, test_~op8~0#1, test_~op9~0#1, test_~op10~0#1, test_~op11~0#1, test_~splverifierCounter~0#1, test_~tmp~9#1, test_~tmp___0~3#1, test_~tmp___1~1#1, test_~tmp___2~1#1, test_~tmp___3~0#1, test_~tmp___4~0#1, test_~tmp___5~0#1, test_~tmp___6~0#1, test_~tmp___7~0#1, test_~tmp___8~0#1, test_~tmp___9~0#1;havoc test_~op1~0#1;havoc test_~op2~0#1;havoc test_~op3~0#1;havoc test_~op4~0#1;havoc test_~op5~0#1;havoc test_~op6~0#1;havoc test_~op7~0#1;havoc test_~op8~0#1;havoc test_~op9~0#1;havoc test_~op10~0#1;havoc test_~op11~0#1;havoc test_~splverifierCounter~0#1;havoc test_~tmp~9#1;havoc test_~tmp___0~3#1;havoc test_~tmp___1~1#1;havoc test_~tmp___2~1#1;havoc test_~tmp___3~0#1;havoc test_~tmp___4~0#1;havoc test_~tmp___5~0#1;havoc test_~tmp___6~0#1;havoc test_~tmp___7~0#1;havoc test_~tmp___8~0#1;havoc test_~tmp___9~0#1;test_~op1~0#1 := 0;test_~op2~0#1 := 0;test_~op3~0#1 := 0;test_~op4~0#1 := 0;test_~op5~0#1 := 0;test_~op6~0#1 := 0;test_~op7~0#1 := 0;test_~op8~0#1 := 0;test_~op9~0#1 := 0;test_~op10~0#1 := 0;test_~op11~0#1 := 0;test_~splverifierCounter~0#1 := 0; {5814#(= |ULTIMATE.start_test_~op1~0#1| 0)} is VALID [2022-02-20 18:03:40,462 INFO L290 TraceCheckUtils]: 43: Hoare triple {5814#(= |ULTIMATE.start_test_~op1~0#1| 0)} assume !false; {5814#(= |ULTIMATE.start_test_~op1~0#1| 0)} is VALID [2022-02-20 18:03:40,463 INFO L290 TraceCheckUtils]: 44: Hoare triple {5814#(= |ULTIMATE.start_test_~op1~0#1| 0)} assume test_~splverifierCounter~0#1 < 4; {5814#(= |ULTIMATE.start_test_~op1~0#1| 0)} is VALID [2022-02-20 18:03:40,463 INFO L290 TraceCheckUtils]: 45: Hoare triple {5814#(= |ULTIMATE.start_test_~op1~0#1| 0)} test_~splverifierCounter~0#1 := 1 + test_~splverifierCounter~0#1; {5814#(= |ULTIMATE.start_test_~op1~0#1| 0)} is VALID [2022-02-20 18:03:40,463 INFO L290 TraceCheckUtils]: 46: Hoare triple {5814#(= |ULTIMATE.start_test_~op1~0#1| 0)} assume !(0 == test_~op1~0#1); {5620#false} is VALID [2022-02-20 18:03:40,463 INFO L290 TraceCheckUtils]: 47: Hoare triple {5620#false} assume 0 == test_~op2~0#1;assume -2147483648 <= test_#t~nondet56#1 && test_#t~nondet56#1 <= 2147483647;test_~tmp___8~0#1 := test_#t~nondet56#1;havoc test_#t~nondet56#1; {5620#false} is VALID [2022-02-20 18:03:40,463 INFO L290 TraceCheckUtils]: 48: Hoare triple {5620#false} assume 0 != test_~tmp___8~0#1;test_~op2~0#1 := 1; {5620#false} is VALID [2022-02-20 18:03:40,463 INFO L290 TraceCheckUtils]: 49: Hoare triple {5620#false} assume !false; {5620#false} is VALID [2022-02-20 18:03:40,463 INFO L290 TraceCheckUtils]: 50: Hoare triple {5620#false} assume !(test_~splverifierCounter~0#1 < 4); {5620#false} is VALID [2022-02-20 18:03:40,464 INFO L290 TraceCheckUtils]: 51: Hoare triple {5620#false} assume { :begin_inline_bobToRjh } true;havoc bobToRjh_#t~ret92#1, bobToRjh_#t~ret93#1, bobToRjh_#t~ret94#1, bobToRjh_#t~ret95#1, bobToRjh_~tmp~19#1, bobToRjh_~tmp___0~8#1, bobToRjh_~tmp___1~5#1;havoc bobToRjh_~tmp~19#1;havoc bobToRjh_~tmp___0~8#1;havoc bobToRjh_~tmp___1~5#1;call bobToRjh_#t~ret92#1 := puts(35, 0);assume -2147483648 <= bobToRjh_#t~ret92#1 && bobToRjh_#t~ret92#1 <= 2147483647;havoc bobToRjh_#t~ret92#1; {5620#false} is VALID [2022-02-20 18:03:40,464 INFO L272 TraceCheckUtils]: 52: Hoare triple {5620#false} call sendEmail(~bob~0, ~rjh~0); {5620#false} is VALID [2022-02-20 18:03:40,464 INFO L290 TraceCheckUtils]: 53: Hoare triple {5620#false} ~sender#1 := #in~sender#1;~receiver#1 := #in~receiver#1;havoc ~email~0#1;havoc ~tmp~16#1;assume { :begin_inline_createEmail } true;createEmail_#in~from#1, createEmail_#in~to#1 := 0, ~receiver#1;havoc createEmail_#res#1;havoc createEmail_~from#1, createEmail_~to#1, createEmail_~retValue_acc~16#1, createEmail_~msg~0#1;createEmail_~from#1 := createEmail_#in~from#1;createEmail_~to#1 := createEmail_#in~to#1;havoc createEmail_~retValue_acc~16#1;havoc createEmail_~msg~0#1;createEmail_~msg~0#1 := 1; {5620#false} is VALID [2022-02-20 18:03:40,464 INFO L272 TraceCheckUtils]: 54: Hoare triple {5620#false} call setEmailFrom(createEmail_~msg~0#1, createEmail_~from#1); {5620#false} is VALID [2022-02-20 18:03:40,464 INFO L290 TraceCheckUtils]: 55: Hoare triple {5620#false} ~handle := #in~handle;~value := #in~value; {5620#false} is VALID [2022-02-20 18:03:40,464 INFO L290 TraceCheckUtils]: 56: Hoare triple {5620#false} assume 1 == ~handle;~__ste_email_from0~0 := ~value; {5620#false} is VALID [2022-02-20 18:03:40,464 INFO L290 TraceCheckUtils]: 57: Hoare triple {5620#false} assume true; {5620#false} is VALID [2022-02-20 18:03:40,464 INFO L284 TraceCheckUtils]: 58: Hoare quadruple {5620#false} {5620#false} #1210#return; {5620#false} is VALID [2022-02-20 18:03:40,464 INFO L272 TraceCheckUtils]: 59: Hoare triple {5620#false} call setEmailTo(createEmail_~msg~0#1, createEmail_~to#1); {5620#false} is VALID [2022-02-20 18:03:40,464 INFO L290 TraceCheckUtils]: 60: Hoare triple {5620#false} ~handle := #in~handle;~value := #in~value; {5620#false} is VALID [2022-02-20 18:03:40,464 INFO L290 TraceCheckUtils]: 61: Hoare triple {5620#false} assume 1 == ~handle;~__ste_email_to0~0 := ~value; {5620#false} is VALID [2022-02-20 18:03:40,464 INFO L290 TraceCheckUtils]: 62: Hoare triple {5620#false} assume true; {5620#false} is VALID [2022-02-20 18:03:40,477 INFO L284 TraceCheckUtils]: 63: Hoare quadruple {5620#false} {5620#false} #1212#return; {5620#false} is VALID [2022-02-20 18:03:40,477 INFO L290 TraceCheckUtils]: 64: Hoare triple {5620#false} createEmail_~retValue_acc~16#1 := createEmail_~msg~0#1;createEmail_#res#1 := createEmail_~retValue_acc~16#1; {5620#false} is VALID [2022-02-20 18:03:40,478 INFO L290 TraceCheckUtils]: 65: Hoare triple {5620#false} #t~ret83#1 := createEmail_#res#1;assume { :end_inline_createEmail } true;assume -2147483648 <= #t~ret83#1 && #t~ret83#1 <= 2147483647;~tmp~16#1 := #t~ret83#1;havoc #t~ret83#1;~email~0#1 := ~tmp~16#1; {5620#false} is VALID [2022-02-20 18:03:40,478 INFO L272 TraceCheckUtils]: 66: Hoare triple {5620#false} call outgoing(~sender#1, ~email~0#1); {5620#false} is VALID [2022-02-20 18:03:40,478 INFO L290 TraceCheckUtils]: 67: Hoare triple {5620#false} ~client#1 := #in~client#1;~msg#1 := #in~msg#1;assume { :begin_inline_sign } true;sign_#in~client#1, sign_#in~msg#1 := ~client#1, ~msg#1;havoc sign_#t~ret85#1, sign_~client#1, sign_~msg#1, sign_~privkey~1#1, sign_~tmp~17#1;sign_~client#1 := sign_#in~client#1;sign_~msg#1 := sign_#in~msg#1;havoc sign_~privkey~1#1;havoc sign_~tmp~17#1; {5620#false} is VALID [2022-02-20 18:03:40,478 INFO L272 TraceCheckUtils]: 68: Hoare triple {5620#false} call sign_#t~ret85#1 := getClientPrivateKey(sign_~client#1); {5620#false} is VALID [2022-02-20 18:03:40,478 INFO L290 TraceCheckUtils]: 69: Hoare triple {5620#false} ~handle := #in~handle;havoc ~retValue_acc~36; {5620#false} is VALID [2022-02-20 18:03:40,478 INFO L290 TraceCheckUtils]: 70: Hoare triple {5620#false} assume 1 == ~handle;~retValue_acc~36 := ~__ste_client_privateKey0~0;#res := ~retValue_acc~36; {5620#false} is VALID [2022-02-20 18:03:40,478 INFO L290 TraceCheckUtils]: 71: Hoare triple {5620#false} assume true; {5620#false} is VALID [2022-02-20 18:03:40,478 INFO L284 TraceCheckUtils]: 72: Hoare quadruple {5620#false} {5620#false} #1150#return; {5620#false} is VALID [2022-02-20 18:03:40,478 INFO L290 TraceCheckUtils]: 73: Hoare triple {5620#false} assume -2147483648 <= sign_#t~ret85#1 && sign_#t~ret85#1 <= 2147483647;sign_~tmp~17#1 := sign_#t~ret85#1;havoc sign_#t~ret85#1;sign_~privkey~1#1 := sign_~tmp~17#1; {5620#false} is VALID [2022-02-20 18:03:40,478 INFO L290 TraceCheckUtils]: 74: Hoare triple {5620#false} assume 0 == sign_~privkey~1#1; {5620#false} is VALID [2022-02-20 18:03:40,479 INFO L290 TraceCheckUtils]: 75: Hoare triple {5620#false} assume { :end_inline_sign } true;assume { :begin_inline_outgoing__wrappee__AddressBook } true;outgoing__wrappee__AddressBook_#in~client#1, outgoing__wrappee__AddressBook_#in~msg#1 := ~client#1, ~msg#1;havoc outgoing__wrappee__AddressBook_#t~ret71#1, outgoing__wrappee__AddressBook_#t~ret72#1, outgoing__wrappee__AddressBook_#t~ret73#1, outgoing__wrappee__AddressBook_#t~ret74#1, outgoing__wrappee__AddressBook_#t~ret75#1, outgoing__wrappee__AddressBook_#t~ret76#1, outgoing__wrappee__AddressBook_~client#1, outgoing__wrappee__AddressBook_~msg#1, outgoing__wrappee__AddressBook_~size~0#1, outgoing__wrappee__AddressBook_~tmp~13#1, outgoing__wrappee__AddressBook_~receiver~1#1, outgoing__wrappee__AddressBook_~tmp___0~5#1, outgoing__wrappee__AddressBook_~second~0#1, outgoing__wrappee__AddressBook_~tmp___1~2#1, outgoing__wrappee__AddressBook_~tmp___2~2#1;outgoing__wrappee__AddressBook_~client#1 := outgoing__wrappee__AddressBook_#in~client#1;outgoing__wrappee__AddressBook_~msg#1 := outgoing__wrappee__AddressBook_#in~msg#1;havoc outgoing__wrappee__AddressBook_~size~0#1;havoc outgoing__wrappee__AddressBook_~tmp~13#1;havoc outgoing__wrappee__AddressBook_~receiver~1#1;havoc outgoing__wrappee__AddressBook_~tmp___0~5#1;havoc outgoing__wrappee__AddressBook_~second~0#1;havoc outgoing__wrappee__AddressBook_~tmp___1~2#1;havoc outgoing__wrappee__AddressBook_~tmp___2~2#1; {5620#false} is VALID [2022-02-20 18:03:40,479 INFO L272 TraceCheckUtils]: 76: Hoare triple {5620#false} call outgoing__wrappee__AddressBook_#t~ret71#1 := getClientAddressBookSize(outgoing__wrappee__AddressBook_~client#1); {5620#false} is VALID [2022-02-20 18:03:40,479 INFO L290 TraceCheckUtils]: 77: Hoare triple {5620#false} ~handle := #in~handle;havoc ~retValue_acc~30; {5620#false} is VALID [2022-02-20 18:03:40,479 INFO L290 TraceCheckUtils]: 78: Hoare triple {5620#false} assume 1 == ~handle;~retValue_acc~30 := ~__ste_ClientAddressBook_size0~0;#res := ~retValue_acc~30; {5620#false} is VALID [2022-02-20 18:03:40,479 INFO L290 TraceCheckUtils]: 79: Hoare triple {5620#false} assume true; {5620#false} is VALID [2022-02-20 18:03:40,479 INFO L284 TraceCheckUtils]: 80: Hoare quadruple {5620#false} {5620#false} #1152#return; {5620#false} is VALID [2022-02-20 18:03:40,479 INFO L290 TraceCheckUtils]: 81: Hoare triple {5620#false} assume -2147483648 <= outgoing__wrappee__AddressBook_#t~ret71#1 && outgoing__wrappee__AddressBook_#t~ret71#1 <= 2147483647;outgoing__wrappee__AddressBook_~tmp~13#1 := outgoing__wrappee__AddressBook_#t~ret71#1;havoc outgoing__wrappee__AddressBook_#t~ret71#1;outgoing__wrappee__AddressBook_~size~0#1 := outgoing__wrappee__AddressBook_~tmp~13#1; {5620#false} is VALID [2022-02-20 18:03:40,479 INFO L290 TraceCheckUtils]: 82: Hoare triple {5620#false} assume !(0 != outgoing__wrappee__AddressBook_~size~0#1); {5620#false} is VALID [2022-02-20 18:03:40,479 INFO L272 TraceCheckUtils]: 83: Hoare triple {5620#false} call outgoing__wrappee__Encrypt(outgoing__wrappee__AddressBook_~client#1, outgoing__wrappee__AddressBook_~msg#1); {5620#false} is VALID [2022-02-20 18:03:40,479 INFO L290 TraceCheckUtils]: 84: Hoare triple {5620#false} ~client#1 := #in~client#1;~msg#1 := #in~msg#1;havoc ~receiver~0#1;havoc ~tmp~12#1;havoc ~pubkey~0#1;havoc ~tmp___0~4#1; {5620#false} is VALID [2022-02-20 18:03:40,480 INFO L272 TraceCheckUtils]: 85: Hoare triple {5620#false} call #t~ret69#1 := getEmailTo(~msg#1); {5620#false} is VALID [2022-02-20 18:03:40,480 INFO L290 TraceCheckUtils]: 86: Hoare triple {5620#false} ~handle := #in~handle;havoc ~retValue_acc~3; {5620#false} is VALID [2022-02-20 18:03:40,480 INFO L290 TraceCheckUtils]: 87: Hoare triple {5620#false} assume 1 == ~handle;~retValue_acc~3 := ~__ste_email_to0~0;#res := ~retValue_acc~3; {5620#false} is VALID [2022-02-20 18:03:40,480 INFO L290 TraceCheckUtils]: 88: Hoare triple {5620#false} assume true; {5620#false} is VALID [2022-02-20 18:03:40,480 INFO L284 TraceCheckUtils]: 89: Hoare quadruple {5620#false} {5620#false} #1170#return; {5620#false} is VALID [2022-02-20 18:03:40,480 INFO L290 TraceCheckUtils]: 90: Hoare triple {5620#false} assume -2147483648 <= #t~ret69#1 && #t~ret69#1 <= 2147483647;~tmp~12#1 := #t~ret69#1;havoc #t~ret69#1;~receiver~0#1 := ~tmp~12#1; {5620#false} is VALID [2022-02-20 18:03:40,480 INFO L272 TraceCheckUtils]: 91: Hoare triple {5620#false} call #t~ret70#1 := findPublicKey(~client#1, ~receiver~0#1); {5620#false} is VALID [2022-02-20 18:03:40,480 INFO L290 TraceCheckUtils]: 92: Hoare triple {5620#false} ~handle := #in~handle;~userid := #in~userid;havoc ~retValue_acc~41; {5620#false} is VALID [2022-02-20 18:03:40,480 INFO L290 TraceCheckUtils]: 93: Hoare triple {5620#false} assume 1 == ~handle; {5620#false} is VALID [2022-02-20 18:03:40,480 INFO L290 TraceCheckUtils]: 94: Hoare triple {5620#false} assume ~userid == ~__ste_Client_Keyring0_User0~0;~retValue_acc~41 := ~__ste_Client_Keyring0_PublicKey0~0;#res := ~retValue_acc~41; {5620#false} is VALID [2022-02-20 18:03:40,480 INFO L290 TraceCheckUtils]: 95: Hoare triple {5620#false} assume true; {5620#false} is VALID [2022-02-20 18:03:40,481 INFO L284 TraceCheckUtils]: 96: Hoare quadruple {5620#false} {5620#false} #1172#return; {5620#false} is VALID [2022-02-20 18:03:40,481 INFO L290 TraceCheckUtils]: 97: Hoare triple {5620#false} assume -2147483648 <= #t~ret70#1 && #t~ret70#1 <= 2147483647;~tmp___0~4#1 := #t~ret70#1;havoc #t~ret70#1;~pubkey~0#1 := ~tmp___0~4#1; {5620#false} is VALID [2022-02-20 18:03:40,481 INFO L290 TraceCheckUtils]: 98: Hoare triple {5620#false} assume !(0 != ~pubkey~0#1); {5620#false} is VALID [2022-02-20 18:03:40,481 INFO L290 TraceCheckUtils]: 99: Hoare triple {5620#false} assume { :begin_inline_outgoing__wrappee__Keys } true;outgoing__wrappee__Keys_#in~client#1, outgoing__wrappee__Keys_#in~msg#1 := ~client#1, ~msg#1;havoc outgoing__wrappee__Keys_#t~ret68#1, outgoing__wrappee__Keys_~client#1, outgoing__wrappee__Keys_~msg#1, outgoing__wrappee__Keys_~tmp~11#1;outgoing__wrappee__Keys_~client#1 := outgoing__wrappee__Keys_#in~client#1;outgoing__wrappee__Keys_~msg#1 := outgoing__wrappee__Keys_#in~msg#1;havoc outgoing__wrappee__Keys_~tmp~11#1;assume { :begin_inline_getClientId } true;getClientId_#in~handle#1 := outgoing__wrappee__Keys_~client#1;havoc getClientId_#res#1;havoc getClientId_~handle#1, getClientId_~retValue_acc~43#1;getClientId_~handle#1 := getClientId_#in~handle#1;havoc getClientId_~retValue_acc~43#1; {5620#false} is VALID [2022-02-20 18:03:40,481 INFO L290 TraceCheckUtils]: 100: Hoare triple {5620#false} assume 1 == getClientId_~handle#1;getClientId_~retValue_acc~43#1 := ~__ste_client_idCounter0~0;getClientId_#res#1 := getClientId_~retValue_acc~43#1; {5620#false} is VALID [2022-02-20 18:03:40,481 INFO L290 TraceCheckUtils]: 101: Hoare triple {5620#false} outgoing__wrappee__Keys_#t~ret68#1 := getClientId_#res#1;assume { :end_inline_getClientId } true;assume -2147483648 <= outgoing__wrappee__Keys_#t~ret68#1 && outgoing__wrappee__Keys_#t~ret68#1 <= 2147483647;outgoing__wrappee__Keys_~tmp~11#1 := outgoing__wrappee__Keys_#t~ret68#1;havoc outgoing__wrappee__Keys_#t~ret68#1; {5620#false} is VALID [2022-02-20 18:03:40,481 INFO L272 TraceCheckUtils]: 102: Hoare triple {5620#false} call setEmailFrom(outgoing__wrappee__Keys_~msg#1, outgoing__wrappee__Keys_~tmp~11#1); {5620#false} is VALID [2022-02-20 18:03:40,481 INFO L290 TraceCheckUtils]: 103: Hoare triple {5620#false} ~handle := #in~handle;~value := #in~value; {5620#false} is VALID [2022-02-20 18:03:40,481 INFO L290 TraceCheckUtils]: 104: Hoare triple {5620#false} assume 1 == ~handle;~__ste_email_from0~0 := ~value; {5620#false} is VALID [2022-02-20 18:03:40,481 INFO L290 TraceCheckUtils]: 105: Hoare triple {5620#false} assume true; {5620#false} is VALID [2022-02-20 18:03:40,482 INFO L284 TraceCheckUtils]: 106: Hoare quadruple {5620#false} {5620#false} #1178#return; {5620#false} is VALID [2022-02-20 18:03:40,482 INFO L290 TraceCheckUtils]: 107: Hoare triple {5620#false} assume { :begin_inline_mail } true;mail_#in~client#1, mail_#in~msg#1 := outgoing__wrappee__Keys_~client#1, outgoing__wrappee__Keys_~msg#1;havoc mail_#t~ret66#1, mail_#t~ret67#1, mail_~client#1, mail_~msg#1, mail_~__utac__ad__arg1~0#1, mail_~tmp~10#1;mail_~client#1 := mail_#in~client#1;mail_~msg#1 := mail_#in~msg#1;havoc mail_~__utac__ad__arg1~0#1;havoc mail_~tmp~10#1;mail_~__utac__ad__arg1~0#1 := mail_~msg#1;assume { :begin_inline___utac_acc__EncryptAutoResponder_spec__2 } true;__utac_acc__EncryptAutoResponder_spec__2_#in~msg#1 := mail_~__utac__ad__arg1~0#1;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1, __utac_acc__EncryptAutoResponder_spec__2_#t~nondet29#1, __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1, __utac_acc__EncryptAutoResponder_spec__2_~msg#1, __utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.base, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.offset;__utac_acc__EncryptAutoResponder_spec__2_~msg#1 := __utac_acc__EncryptAutoResponder_spec__2_#in~msg#1;havoc __utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1;havoc __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.base, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.offset;call __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1 := puts(15, 0);assume -2147483648 <= __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1 && __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1 <= 2147483647;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1;__utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.base, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.offset := 16, 0;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~nondet29#1; {5620#false} is VALID [2022-02-20 18:03:40,482 INFO L290 TraceCheckUtils]: 108: Hoare triple {5620#false} assume 0 != ~in_encrypted~0; {5620#false} is VALID [2022-02-20 18:03:40,482 INFO L272 TraceCheckUtils]: 109: Hoare triple {5620#false} call __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1 := isEncrypted(__utac_acc__EncryptAutoResponder_spec__2_~msg#1); {5620#false} is VALID [2022-02-20 18:03:40,482 INFO L290 TraceCheckUtils]: 110: Hoare triple {5620#false} ~handle := #in~handle;havoc ~retValue_acc~6; {5620#false} is VALID [2022-02-20 18:03:40,482 INFO L290 TraceCheckUtils]: 111: Hoare triple {5620#false} assume 1 == ~handle;~retValue_acc~6 := ~__ste_email_isEncrypted0~0;#res := ~retValue_acc~6; {5620#false} is VALID [2022-02-20 18:03:40,482 INFO L290 TraceCheckUtils]: 112: Hoare triple {5620#false} assume true; {5620#false} is VALID [2022-02-20 18:03:40,484 INFO L284 TraceCheckUtils]: 113: Hoare quadruple {5620#false} {5620#false} #1180#return; {5620#false} is VALID [2022-02-20 18:03:40,484 INFO L290 TraceCheckUtils]: 114: Hoare triple {5620#false} assume -2147483648 <= __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1 && __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1 <= 2147483647;__utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1 := __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1; {5620#false} is VALID [2022-02-20 18:03:40,484 INFO L290 TraceCheckUtils]: 115: Hoare triple {5620#false} assume !(0 != __utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1);assume { :begin_inline___automaton_fail } true; {5620#false} is VALID [2022-02-20 18:03:40,485 INFO L290 TraceCheckUtils]: 116: Hoare triple {5620#false} assume !false; {5620#false} is VALID [2022-02-20 18:03:40,485 INFO L134 CoverageAnalysis]: Checked inductivity of 30 backedges. 2 proven. 0 refuted. 0 times theorem prover too weak. 28 trivial. 0 not checked. [2022-02-20 18:03:40,485 INFO L324 TraceCheckSpWp]: Omiting computation of backward sequence because forward sequence was already perfect [2022-02-20 18:03:40,486 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleZ3 [615637377] provided 1 perfect and 0 imperfect interpolant sequences [2022-02-20 18:03:40,486 INFO L191 FreeRefinementEngine]: Found 1 perfect and 1 imperfect interpolant sequences. [2022-02-20 18:03:40,486 INFO L204 FreeRefinementEngine]: Number of different interpolants: perfect sequences [3] imperfect sequences [9] total 10 [2022-02-20 18:03:40,486 INFO L118 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [392279216] [2022-02-20 18:03:40,486 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-02-20 18:03:40,487 INFO L78 Accepts]: Start accepts. Automaton has has 3 states, 3 states have (on average 23.666666666666668) internal successors, (71), 3 states have internal predecessors, (71), 2 states have call successors, (17), 2 states have call predecessors, (17), 2 states have return successors, (14), 2 states have call predecessors, (14), 2 states have call successors, (14) Word has length 117 [2022-02-20 18:03:40,488 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-02-20 18:03:40,488 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with has 3 states, 3 states have (on average 23.666666666666668) internal successors, (71), 3 states have internal predecessors, (71), 2 states have call successors, (17), 2 states have call predecessors, (17), 2 states have return successors, (14), 2 states have call predecessors, (14), 2 states have call successors, (14) [2022-02-20 18:03:40,597 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 102 edges. 102 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 18:03:40,598 INFO L546 AbstractCegarLoop]: INTERPOLANT automaton has 3 states [2022-02-20 18:03:40,598 INFO L108 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2022-02-20 18:03:40,598 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 3 interpolants. [2022-02-20 18:03:40,598 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=17, Invalid=73, Unknown=0, NotChecked=0, Total=90 [2022-02-20 18:03:40,599 INFO L87 Difference]: Start difference. First operand 404 states and 607 transitions. Second operand has 3 states, 3 states have (on average 23.666666666666668) internal successors, (71), 3 states have internal predecessors, (71), 2 states have call successors, (17), 2 states have call predecessors, (17), 2 states have return successors, (14), 2 states have call predecessors, (14), 2 states have call successors, (14) [2022-02-20 18:03:41,301 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 18:03:41,302 INFO L93 Difference]: Finished difference Result 851 states and 1298 transitions. [2022-02-20 18:03:41,302 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 3 states. [2022-02-20 18:03:41,302 INFO L78 Accepts]: Start accepts. Automaton has has 3 states, 3 states have (on average 23.666666666666668) internal successors, (71), 3 states have internal predecessors, (71), 2 states have call successors, (17), 2 states have call predecessors, (17), 2 states have return successors, (14), 2 states have call predecessors, (14), 2 states have call successors, (14) Word has length 117 [2022-02-20 18:03:41,302 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-02-20 18:03:41,303 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 3 states, 3 states have (on average 23.666666666666668) internal successors, (71), 3 states have internal predecessors, (71), 2 states have call successors, (17), 2 states have call predecessors, (17), 2 states have return successors, (14), 2 states have call predecessors, (14), 2 states have call successors, (14) [2022-02-20 18:03:41,317 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 3 states to 3 states and 1296 transitions. [2022-02-20 18:03:41,318 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 3 states, 3 states have (on average 23.666666666666668) internal successors, (71), 3 states have internal predecessors, (71), 2 states have call successors, (17), 2 states have call predecessors, (17), 2 states have return successors, (14), 2 states have call predecessors, (14), 2 states have call successors, (14) [2022-02-20 18:03:41,332 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 3 states to 3 states and 1296 transitions. [2022-02-20 18:03:41,332 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with 3 states and 1296 transitions. [2022-02-20 18:03:42,274 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 1296 edges. 1296 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 18:03:42,311 INFO L225 Difference]: With dead ends: 851 [2022-02-20 18:03:42,312 INFO L226 Difference]: Without dead ends: 474 [2022-02-20 18:03:42,313 INFO L932 BasicCegarLoop]: 0 DeclaredPredicates, 148 GetRequests, 140 SyntacticMatches, 0 SemanticMatches, 8 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 0 ImplicationChecksByTransitivity, 0.0s TimeCoverageRelationStatistics Valid=17, Invalid=73, Unknown=0, NotChecked=0, Total=90 [2022-02-20 18:03:42,314 INFO L933 BasicCegarLoop]: 633 mSDtfsCounter, 126 mSDsluCounter, 561 mSDsCounter, 0 mSdLazyCounter, 3 mSolverCounterSat, 1 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.0s Time, 0 mProtectedPredicate, 0 mProtectedAction, 144 SdHoareTripleChecker+Valid, 1194 SdHoareTripleChecker+Invalid, 4 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 1 IncrementalHoareTripleChecker+Valid, 3 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.0s IncrementalHoareTripleChecker+Time [2022-02-20 18:03:42,314 INFO L934 BasicCegarLoop]: SdHoareTripleChecker [144 Valid, 1194 Invalid, 4 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [1 Valid, 3 Invalid, 0 Unknown, 0 Unchecked, 0.0s Time] [2022-02-20 18:03:42,315 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 474 states. [2022-02-20 18:03:42,329 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 474 to 466. [2022-02-20 18:03:42,329 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-02-20 18:03:42,330 INFO L82 GeneralOperation]: Start isEquivalent. First operand 474 states. Second operand has 466 states, 360 states have (on average 1.5638888888888889) internal successors, (563), 364 states have internal predecessors, (563), 77 states have call successors, (77), 28 states have call predecessors, (77), 28 states have return successors, (76), 75 states have call predecessors, (76), 76 states have call successors, (76) [2022-02-20 18:03:42,331 INFO L74 IsIncluded]: Start isIncluded. First operand 474 states. Second operand has 466 states, 360 states have (on average 1.5638888888888889) internal successors, (563), 364 states have internal predecessors, (563), 77 states have call successors, (77), 28 states have call predecessors, (77), 28 states have return successors, (76), 75 states have call predecessors, (76), 76 states have call successors, (76) [2022-02-20 18:03:42,333 INFO L87 Difference]: Start difference. First operand 474 states. Second operand has 466 states, 360 states have (on average 1.5638888888888889) internal successors, (563), 364 states have internal predecessors, (563), 77 states have call successors, (77), 28 states have call predecessors, (77), 28 states have return successors, (76), 75 states have call predecessors, (76), 76 states have call successors, (76) [2022-02-20 18:03:42,349 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 18:03:42,349 INFO L93 Difference]: Finished difference Result 474 states and 725 transitions. [2022-02-20 18:03:42,349 INFO L276 IsEmpty]: Start isEmpty. Operand 474 states and 725 transitions. [2022-02-20 18:03:42,351 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 18:03:42,351 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 18:03:42,353 INFO L74 IsIncluded]: Start isIncluded. First operand has 466 states, 360 states have (on average 1.5638888888888889) internal successors, (563), 364 states have internal predecessors, (563), 77 states have call successors, (77), 28 states have call predecessors, (77), 28 states have return successors, (76), 75 states have call predecessors, (76), 76 states have call successors, (76) Second operand 474 states. [2022-02-20 18:03:42,354 INFO L87 Difference]: Start difference. First operand has 466 states, 360 states have (on average 1.5638888888888889) internal successors, (563), 364 states have internal predecessors, (563), 77 states have call successors, (77), 28 states have call predecessors, (77), 28 states have return successors, (76), 75 states have call predecessors, (76), 76 states have call successors, (76) Second operand 474 states. [2022-02-20 18:03:42,371 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 18:03:42,371 INFO L93 Difference]: Finished difference Result 474 states and 725 transitions. [2022-02-20 18:03:42,371 INFO L276 IsEmpty]: Start isEmpty. Operand 474 states and 725 transitions. [2022-02-20 18:03:42,373 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 18:03:42,374 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 18:03:42,374 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-02-20 18:03:42,374 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-02-20 18:03:42,375 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 466 states, 360 states have (on average 1.5638888888888889) internal successors, (563), 364 states have internal predecessors, (563), 77 states have call successors, (77), 28 states have call predecessors, (77), 28 states have return successors, (76), 75 states have call predecessors, (76), 76 states have call successors, (76) [2022-02-20 18:03:42,391 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 466 states to 466 states and 716 transitions. [2022-02-20 18:03:42,391 INFO L78 Accepts]: Start accepts. Automaton has 466 states and 716 transitions. Word has length 117 [2022-02-20 18:03:42,391 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-02-20 18:03:42,391 INFO L470 AbstractCegarLoop]: Abstraction has 466 states and 716 transitions. [2022-02-20 18:03:42,392 INFO L471 AbstractCegarLoop]: INTERPOLANT automaton has has 3 states, 3 states have (on average 23.666666666666668) internal successors, (71), 3 states have internal predecessors, (71), 2 states have call successors, (17), 2 states have call predecessors, (17), 2 states have return successors, (14), 2 states have call predecessors, (14), 2 states have call successors, (14) [2022-02-20 18:03:42,392 INFO L276 IsEmpty]: Start isEmpty. Operand 466 states and 716 transitions. [2022-02-20 18:03:42,394 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 119 [2022-02-20 18:03:42,394 INFO L506 BasicCegarLoop]: Found error trace [2022-02-20 18:03:42,394 INFO L514 BasicCegarLoop]: trace histogram [3, 3, 3, 3, 3, 3, 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] [2022-02-20 18:03:42,435 INFO L552 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (4)] Ended with exit code 0 [2022-02-20 18:03:42,635 WARN L452 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable2,4 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-02-20 18:03:42,636 INFO L402 AbstractCegarLoop]: === Iteration 4 === Targeting outgoing__wrappee__EncryptErr0ASSERT_VIOLATIONERROR_FUNCTION === [outgoing__wrappee__EncryptErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-02-20 18:03:42,636 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-02-20 18:03:42,636 INFO L85 PathProgramCache]: Analyzing trace with hash -966711120, now seen corresponding path program 1 times [2022-02-20 18:03:42,637 INFO L126 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-02-20 18:03:42,637 INFO L338 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [1994563648] [2022-02-20 18:03:42,637 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 18:03:42,637 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-02-20 18:03:42,674 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:42,742 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 6 [2022-02-20 18:03:42,744 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:42,754 INFO L290 TraceCheckUtils]: 0: Hoare triple {8851#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {8791#true} is VALID [2022-02-20 18:03:42,755 INFO L290 TraceCheckUtils]: 1: Hoare triple {8791#true} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {8791#true} is VALID [2022-02-20 18:03:42,755 INFO L290 TraceCheckUtils]: 2: Hoare triple {8791#true} assume true; {8791#true} is VALID [2022-02-20 18:03:42,755 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {8791#true} {8791#true} #1224#return; {8791#true} is VALID [2022-02-20 18:03:42,760 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 12 [2022-02-20 18:03:42,762 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:42,765 INFO L290 TraceCheckUtils]: 0: Hoare triple {8852#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {8791#true} is VALID [2022-02-20 18:03:42,765 INFO L290 TraceCheckUtils]: 1: Hoare triple {8791#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {8791#true} is VALID [2022-02-20 18:03:42,765 INFO L290 TraceCheckUtils]: 2: Hoare triple {8791#true} assume true; {8791#true} is VALID [2022-02-20 18:03:42,765 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {8791#true} {8791#true} #1226#return; {8791#true} is VALID [2022-02-20 18:03:42,765 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 18 [2022-02-20 18:03:42,768 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:42,782 INFO L290 TraceCheckUtils]: 0: Hoare triple {8851#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {8853#(= setClientId_~handle |setClientId_#in~handle|)} is VALID [2022-02-20 18:03:42,782 INFO L290 TraceCheckUtils]: 1: Hoare triple {8853#(= setClientId_~handle |setClientId_#in~handle|)} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {8854#(= |setClientId_#in~handle| 1)} is VALID [2022-02-20 18:03:42,783 INFO L290 TraceCheckUtils]: 2: Hoare triple {8854#(= |setClientId_#in~handle| 1)} assume true; {8854#(= |setClientId_#in~handle| 1)} is VALID [2022-02-20 18:03:42,783 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {8854#(= |setClientId_#in~handle| 1)} {8801#(= |ULTIMATE.start_setup_rjh__wrappee__Base_~rjh___0#1| 2)} #1228#return; {8792#false} is VALID [2022-02-20 18:03:42,783 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 24 [2022-02-20 18:03:42,785 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:42,788 INFO L290 TraceCheckUtils]: 0: Hoare triple {8852#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {8791#true} is VALID [2022-02-20 18:03:42,788 INFO L290 TraceCheckUtils]: 1: Hoare triple {8791#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {8791#true} is VALID [2022-02-20 18:03:42,788 INFO L290 TraceCheckUtils]: 2: Hoare triple {8791#true} assume true; {8791#true} is VALID [2022-02-20 18:03:42,788 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {8791#true} {8792#false} #1230#return; {8792#false} is VALID [2022-02-20 18:03:42,789 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 30 [2022-02-20 18:03:42,793 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:42,795 INFO L290 TraceCheckUtils]: 0: Hoare triple {8851#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {8791#true} is VALID [2022-02-20 18:03:42,795 INFO L290 TraceCheckUtils]: 1: Hoare triple {8791#true} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {8791#true} is VALID [2022-02-20 18:03:42,795 INFO L290 TraceCheckUtils]: 2: Hoare triple {8791#true} assume true; {8791#true} is VALID [2022-02-20 18:03:42,795 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {8791#true} {8792#false} #1232#return; {8792#false} is VALID [2022-02-20 18:03:42,795 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 36 [2022-02-20 18:03:42,796 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:42,798 INFO L290 TraceCheckUtils]: 0: Hoare triple {8852#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {8791#true} is VALID [2022-02-20 18:03:42,798 INFO L290 TraceCheckUtils]: 1: Hoare triple {8791#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {8791#true} is VALID [2022-02-20 18:03:42,798 INFO L290 TraceCheckUtils]: 2: Hoare triple {8791#true} assume true; {8791#true} is VALID [2022-02-20 18:03:42,799 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {8791#true} {8792#false} #1234#return; {8792#false} is VALID [2022-02-20 18:03:42,804 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 55 [2022-02-20 18:03:42,805 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:42,807 INFO L290 TraceCheckUtils]: 0: Hoare triple {8855#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} ~handle := #in~handle;~value := #in~value; {8791#true} is VALID [2022-02-20 18:03:42,807 INFO L290 TraceCheckUtils]: 1: Hoare triple {8791#true} assume 1 == ~handle;~__ste_email_from0~0 := ~value; {8791#true} is VALID [2022-02-20 18:03:42,807 INFO L290 TraceCheckUtils]: 2: Hoare triple {8791#true} assume true; {8791#true} is VALID [2022-02-20 18:03:42,807 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {8791#true} {8792#false} #1210#return; {8792#false} is VALID [2022-02-20 18:03:42,814 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 60 [2022-02-20 18:03:42,815 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:42,817 INFO L290 TraceCheckUtils]: 0: Hoare triple {8856#(and (= ~__ste_email_to0~0 |old(~__ste_email_to0~0)|) (= ~__ste_email_to1~0 |old(~__ste_email_to1~0)|))} ~handle := #in~handle;~value := #in~value; {8791#true} is VALID [2022-02-20 18:03:42,817 INFO L290 TraceCheckUtils]: 1: Hoare triple {8791#true} assume 1 == ~handle;~__ste_email_to0~0 := ~value; {8791#true} is VALID [2022-02-20 18:03:42,817 INFO L290 TraceCheckUtils]: 2: Hoare triple {8791#true} assume true; {8791#true} is VALID [2022-02-20 18:03:42,817 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {8791#true} {8792#false} #1212#return; {8792#false} is VALID [2022-02-20 18:03:42,818 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 69 [2022-02-20 18:03:42,818 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:42,820 INFO L290 TraceCheckUtils]: 0: Hoare triple {8791#true} ~handle := #in~handle;havoc ~retValue_acc~36; {8791#true} is VALID [2022-02-20 18:03:42,820 INFO L290 TraceCheckUtils]: 1: Hoare triple {8791#true} assume 1 == ~handle;~retValue_acc~36 := ~__ste_client_privateKey0~0;#res := ~retValue_acc~36; {8791#true} is VALID [2022-02-20 18:03:42,820 INFO L290 TraceCheckUtils]: 2: Hoare triple {8791#true} assume true; {8791#true} is VALID [2022-02-20 18:03:42,820 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {8791#true} {8792#false} #1150#return; {8792#false} is VALID [2022-02-20 18:03:42,821 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 77 [2022-02-20 18:03:42,821 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:42,823 INFO L290 TraceCheckUtils]: 0: Hoare triple {8791#true} ~handle := #in~handle;havoc ~retValue_acc~30; {8791#true} is VALID [2022-02-20 18:03:42,823 INFO L290 TraceCheckUtils]: 1: Hoare triple {8791#true} assume 1 == ~handle;~retValue_acc~30 := ~__ste_ClientAddressBook_size0~0;#res := ~retValue_acc~30; {8791#true} is VALID [2022-02-20 18:03:42,823 INFO L290 TraceCheckUtils]: 2: Hoare triple {8791#true} assume true; {8791#true} is VALID [2022-02-20 18:03:42,823 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {8791#true} {8792#false} #1152#return; {8792#false} is VALID [2022-02-20 18:03:42,823 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 86 [2022-02-20 18:03:42,824 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:42,826 INFO L290 TraceCheckUtils]: 0: Hoare triple {8791#true} ~handle := #in~handle;havoc ~retValue_acc~3; {8791#true} is VALID [2022-02-20 18:03:42,826 INFO L290 TraceCheckUtils]: 1: Hoare triple {8791#true} assume 1 == ~handle;~retValue_acc~3 := ~__ste_email_to0~0;#res := ~retValue_acc~3; {8791#true} is VALID [2022-02-20 18:03:42,826 INFO L290 TraceCheckUtils]: 2: Hoare triple {8791#true} assume true; {8791#true} is VALID [2022-02-20 18:03:42,826 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {8791#true} {8792#false} #1170#return; {8792#false} is VALID [2022-02-20 18:03:42,826 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 92 [2022-02-20 18:03:42,827 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:42,829 INFO L290 TraceCheckUtils]: 0: Hoare triple {8791#true} ~handle := #in~handle;~userid := #in~userid;havoc ~retValue_acc~41; {8791#true} is VALID [2022-02-20 18:03:42,829 INFO L290 TraceCheckUtils]: 1: Hoare triple {8791#true} assume 1 == ~handle; {8791#true} is VALID [2022-02-20 18:03:42,829 INFO L290 TraceCheckUtils]: 2: Hoare triple {8791#true} assume ~userid == ~__ste_Client_Keyring0_User0~0;~retValue_acc~41 := ~__ste_Client_Keyring0_PublicKey0~0;#res := ~retValue_acc~41; {8791#true} is VALID [2022-02-20 18:03:42,829 INFO L290 TraceCheckUtils]: 3: Hoare triple {8791#true} assume true; {8791#true} is VALID [2022-02-20 18:03:42,829 INFO L284 TraceCheckUtils]: 4: Hoare quadruple {8791#true} {8792#false} #1172#return; {8792#false} is VALID [2022-02-20 18:03:42,829 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 103 [2022-02-20 18:03:42,830 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:42,832 INFO L290 TraceCheckUtils]: 0: Hoare triple {8855#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} ~handle := #in~handle;~value := #in~value; {8791#true} is VALID [2022-02-20 18:03:42,832 INFO L290 TraceCheckUtils]: 1: Hoare triple {8791#true} assume 1 == ~handle;~__ste_email_from0~0 := ~value; {8791#true} is VALID [2022-02-20 18:03:42,832 INFO L290 TraceCheckUtils]: 2: Hoare triple {8791#true} assume true; {8791#true} is VALID [2022-02-20 18:03:42,832 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {8791#true} {8792#false} #1178#return; {8792#false} is VALID [2022-02-20 18:03:42,832 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 110 [2022-02-20 18:03:42,834 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:42,836 INFO L290 TraceCheckUtils]: 0: Hoare triple {8791#true} ~handle := #in~handle;havoc ~retValue_acc~6; {8791#true} is VALID [2022-02-20 18:03:42,836 INFO L290 TraceCheckUtils]: 1: Hoare triple {8791#true} assume 1 == ~handle;~retValue_acc~6 := ~__ste_email_isEncrypted0~0;#res := ~retValue_acc~6; {8791#true} is VALID [2022-02-20 18:03:42,836 INFO L290 TraceCheckUtils]: 2: Hoare triple {8791#true} assume true; {8791#true} is VALID [2022-02-20 18:03:42,836 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {8791#true} {8792#false} #1180#return; {8792#false} is VALID [2022-02-20 18:03:42,836 INFO L290 TraceCheckUtils]: 0: Hoare triple {8791#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(28, 2);call #Ultimate.allocInit(12, 3);call #Ultimate.allocInit(10, 4);call #Ultimate.allocInit(12, 5);call #Ultimate.allocInit(10, 6);call #Ultimate.allocInit(18, 7);call #Ultimate.allocInit(16, 8);call #Ultimate.allocInit(21, 9);call #Ultimate.allocInit(13, 10);call #Ultimate.allocInit(16, 11);call #Ultimate.allocInit(25, 12);call #Ultimate.allocInit(17, 13);call #Ultimate.allocInit(17, 14);call #Ultimate.allocInit(13, 15);call #Ultimate.allocInit(17, 16);call #Ultimate.allocInit(30, 17);call #Ultimate.allocInit(9, 18);call #Ultimate.allocInit(21, 19);call #Ultimate.allocInit(30, 20);call #Ultimate.allocInit(9, 21);call #Ultimate.allocInit(21, 22);call #Ultimate.allocInit(30, 23);call #Ultimate.allocInit(9, 24);call #Ultimate.allocInit(25, 25);call #Ultimate.allocInit(30, 26);call #Ultimate.allocInit(9, 27);call #Ultimate.allocInit(25, 28);call #Ultimate.allocInit(4, 29);call write~init~int(37, 29, 0, 1);call write~init~int(115, 29, 1, 1);call write~init~int(10, 29, 2, 1);call write~init~int(0, 29, 3, 1);call #Ultimate.allocInit(10, 30);call #Ultimate.allocInit(34, 31);call #Ultimate.allocInit(30, 32);call #Ultimate.allocInit(16, 33);call #Ultimate.allocInit(20, 34);call #Ultimate.allocInit(44, 35);call #Ultimate.allocInit(44, 36);call #Ultimate.allocInit(9, 37);call #Ultimate.allocInit(9, 38);call #Ultimate.allocInit(11, 39);call #Ultimate.allocInit(19, 40);call #Ultimate.allocInit(4, 41);call write~init~int(37, 41, 0, 1);call write~init~int(100, 41, 1, 1);call write~init~int(10, 41, 2, 1);call write~init~int(0, 41, 3, 1);call #Ultimate.allocInit(4, 42);call write~init~int(37, 42, 0, 1);call write~init~int(100, 42, 1, 1);call write~init~int(10, 42, 2, 1);call write~init~int(0, 42, 3, 1);~__ste_Email_counter~0 := 0;~__ste_email_id0~0 := 0;~__ste_email_id1~0 := 0;~__ste_email_from0~0 := 0;~__ste_email_from1~0 := 0;~__ste_email_to0~0 := 0;~__ste_email_to1~0 := 0;~__ste_email_subject0~0.base, ~__ste_email_subject0~0.offset := 0, 0;~__ste_email_subject1~0.base, ~__ste_email_subject1~0.offset := 0, 0;~__ste_email_body0~0.base, ~__ste_email_body0~0.offset := 0, 0;~__ste_email_body1~0.base, ~__ste_email_body1~0.offset := 0, 0;~__ste_email_isEncrypted0~0 := 0;~__ste_email_isEncrypted1~0 := 0;~__ste_email_encryptionKey0~0 := 0;~__ste_email_encryptionKey1~0 := 0;~__ste_email_isSigned0~0 := 0;~__ste_email_isSigned1~0 := 0;~__ste_email_signKey0~0 := 0;~__ste_email_signKey1~0 := 0;~__ste_email_isSignatureVerified0~0 := 0;~__ste_email_isSignatureVerified1~0 := 0;~__SELECTED_FEATURE_Base~0 := 0;~__SELECTED_FEATURE_Keys~0 := 0;~__SELECTED_FEATURE_Encrypt~0 := 0;~__SELECTED_FEATURE_AutoResponder~0 := 0;~__SELECTED_FEATURE_AddressBook~0 := 0;~__SELECTED_FEATURE_Sign~0 := 0;~__SELECTED_FEATURE_Forward~0 := 0;~__SELECTED_FEATURE_Verify~0 := 0;~__SELECTED_FEATURE_Decrypt~0 := 0;~__GUIDSL_ROOT_PRODUCTION~0 := 0;~__GUIDSL_NON_TERMINAL_main~0 := 0;~in_encrypted~0 := 0;~head~0.base, ~head~0.offset := 0, 0;~queue_empty~0 := 1;~queued_message~0 := 0;~queued_client~0 := 0;~bob~0 := 0;~rjh~0 := 0;~chuck~0 := 0;~__ste_Client_counter~0 := 0;~__ste_client_name0~0.base, ~__ste_client_name0~0.offset := 0, 0;~__ste_client_name1~0.base, ~__ste_client_name1~0.offset := 0, 0;~__ste_client_name2~0.base, ~__ste_client_name2~0.offset := 0, 0;~__ste_client_outbuffer0~0 := 0;~__ste_client_outbuffer1~0 := 0;~__ste_client_outbuffer2~0 := 0;~__ste_client_outbuffer3~0 := 0;~__ste_ClientAddressBook_size0~0 := 0;~__ste_ClientAddressBook_size1~0 := 0;~__ste_ClientAddressBook_size2~0 := 0;~__ste_Client_AddressBook0_Alias0~0 := 0;~__ste_Client_AddressBook0_Alias1~0 := 0;~__ste_Client_AddressBook0_Alias2~0 := 0;~__ste_Client_AddressBook1_Alias0~0 := 0;~__ste_Client_AddressBook1_Alias1~0 := 0;~__ste_Client_AddressBook1_Alias2~0 := 0;~__ste_Client_AddressBook2_Alias0~0 := 0;~__ste_Client_AddressBook2_Alias1~0 := 0;~__ste_Client_AddressBook2_Alias2~0 := 0;~__ste_Client_AddressBook0_Address0~0 := 0;~__ste_Client_AddressBook0_Address1~0 := 0;~__ste_Client_AddressBook0_Address2~0 := 0;~__ste_Client_AddressBook1_Address0~0 := 0;~__ste_Client_AddressBook1_Address1~0 := 0;~__ste_Client_AddressBook1_Address2~0 := 0;~__ste_Client_AddressBook2_Address0~0 := 0;~__ste_Client_AddressBook2_Address1~0 := 0;~__ste_Client_AddressBook2_Address2~0 := 0;~__ste_client_autoResponse0~0 := 0;~__ste_client_autoResponse1~0 := 0;~__ste_client_autoResponse2~0 := 0;~__ste_client_privateKey0~0 := 0;~__ste_client_privateKey1~0 := 0;~__ste_client_privateKey2~0 := 0;~__ste_ClientKeyring_size0~0 := 0;~__ste_ClientKeyring_size1~0 := 0;~__ste_ClientKeyring_size2~0 := 0;~__ste_Client_Keyring0_User0~0 := 0;~__ste_Client_Keyring0_User1~0 := 0;~__ste_Client_Keyring0_User2~0 := 0;~__ste_Client_Keyring1_User0~0 := 0;~__ste_Client_Keyring1_User1~0 := 0;~__ste_Client_Keyring1_User2~0 := 0;~__ste_Client_Keyring2_User0~0 := 0;~__ste_Client_Keyring2_User1~0 := 0;~__ste_Client_Keyring2_User2~0 := 0;~__ste_Client_Keyring0_PublicKey0~0 := 0;~__ste_Client_Keyring0_PublicKey1~0 := 0;~__ste_Client_Keyring0_PublicKey2~0 := 0;~__ste_Client_Keyring1_PublicKey0~0 := 0;~__ste_Client_Keyring1_PublicKey1~0 := 0;~__ste_Client_Keyring1_PublicKey2~0 := 0;~__ste_Client_Keyring2_PublicKey0~0 := 0;~__ste_Client_Keyring2_PublicKey1~0 := 0;~__ste_Client_Keyring2_PublicKey2~0 := 0;~__ste_client_forwardReceiver0~0 := 0;~__ste_client_forwardReceiver1~0 := 0;~__ste_client_forwardReceiver2~0 := 0;~__ste_client_forwardReceiver3~0 := 0;~__ste_client_idCounter0~0 := 0;~__ste_client_idCounter1~0 := 0;~__ste_client_idCounter2~0 := 0; {8791#true} is VALID [2022-02-20 18:03:42,837 INFO L290 TraceCheckUtils]: 1: Hoare triple {8791#true} assume { :end_inline_ULTIMATE.init } true;assume { :begin_inline_main } true;havoc main_#res#1;havoc main_#t~nondet100#1, main_#t~ret101#1, main_~retValue_acc~26#1, main_~tmp~20#1;assume -2147483648 <= main_#t~nondet100#1 && main_#t~nondet100#1 <= 2147483647;main_~retValue_acc~26#1 := main_#t~nondet100#1;havoc main_#t~nondet100#1;havoc main_~tmp~20#1;assume { :begin_inline_select_helpers } true; {8791#true} is VALID [2022-02-20 18:03:42,837 INFO L290 TraceCheckUtils]: 2: Hoare triple {8791#true} assume { :end_inline_select_helpers } true;assume { :begin_inline_select_features } true; {8791#true} is VALID [2022-02-20 18:03:42,837 INFO L290 TraceCheckUtils]: 3: Hoare triple {8791#true} assume { :end_inline_select_features } true;assume { :begin_inline_valid_product } true;havoc valid_product_#res#1;havoc valid_product_~retValue_acc~12#1;havoc valid_product_~retValue_acc~12#1;valid_product_~retValue_acc~12#1 := 1;valid_product_#res#1 := valid_product_~retValue_acc~12#1; {8791#true} is VALID [2022-02-20 18:03:42,837 INFO L290 TraceCheckUtils]: 4: Hoare triple {8791#true} main_#t~ret101#1 := valid_product_#res#1;assume { :end_inline_valid_product } true;assume -2147483648 <= main_#t~ret101#1 && main_#t~ret101#1 <= 2147483647;main_~tmp~20#1 := main_#t~ret101#1;havoc main_#t~ret101#1; {8791#true} is VALID [2022-02-20 18:03:42,837 INFO L290 TraceCheckUtils]: 5: Hoare triple {8791#true} assume 0 != main_~tmp~20#1;assume { :begin_inline_setup } true;havoc setup_#t~nondet97#1, setup_#t~nondet98#1, setup_#t~nondet99#1, setup_~__cil_tmp1~0#1.base, setup_~__cil_tmp1~0#1.offset, setup_~__cil_tmp2~1#1.base, setup_~__cil_tmp2~1#1.offset, setup_~__cil_tmp3~4#1.base, setup_~__cil_tmp3~4#1.offset;havoc setup_~__cil_tmp1~0#1.base, setup_~__cil_tmp1~0#1.offset;havoc setup_~__cil_tmp2~1#1.base, setup_~__cil_tmp2~1#1.offset;havoc setup_~__cil_tmp3~4#1.base, setup_~__cil_tmp3~4#1.offset;~bob~0 := 1;assume { :begin_inline_setup_bob } true;setup_bob_#in~bob___0#1 := ~bob~0;havoc setup_bob_~bob___0#1;setup_bob_~bob___0#1 := setup_bob_#in~bob___0#1;assume { :begin_inline_setup_bob__wrappee__Base } true;setup_bob__wrappee__Base_#in~bob___0#1 := setup_bob_~bob___0#1;havoc setup_bob__wrappee__Base_~bob___0#1;setup_bob__wrappee__Base_~bob___0#1 := setup_bob__wrappee__Base_#in~bob___0#1; {8791#true} is VALID [2022-02-20 18:03:42,837 INFO L272 TraceCheckUtils]: 6: Hoare triple {8791#true} call setClientId(setup_bob__wrappee__Base_~bob___0#1, setup_bob__wrappee__Base_~bob___0#1); {8851#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} is VALID [2022-02-20 18:03:42,837 INFO L290 TraceCheckUtils]: 7: Hoare triple {8851#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {8791#true} is VALID [2022-02-20 18:03:42,837 INFO L290 TraceCheckUtils]: 8: Hoare triple {8791#true} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {8791#true} is VALID [2022-02-20 18:03:42,838 INFO L290 TraceCheckUtils]: 9: Hoare triple {8791#true} assume true; {8791#true} is VALID [2022-02-20 18:03:42,838 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {8791#true} {8791#true} #1224#return; {8791#true} is VALID [2022-02-20 18:03:42,838 INFO L290 TraceCheckUtils]: 11: Hoare triple {8791#true} assume { :end_inline_setup_bob__wrappee__Base } true; {8791#true} is VALID [2022-02-20 18:03:42,838 INFO L272 TraceCheckUtils]: 12: Hoare triple {8791#true} call setClientPrivateKey(setup_bob_~bob___0#1, 123); {8852#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} is VALID [2022-02-20 18:03:42,838 INFO L290 TraceCheckUtils]: 13: Hoare triple {8852#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {8791#true} is VALID [2022-02-20 18:03:42,838 INFO L290 TraceCheckUtils]: 14: Hoare triple {8791#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {8791#true} is VALID [2022-02-20 18:03:42,838 INFO L290 TraceCheckUtils]: 15: Hoare triple {8791#true} assume true; {8791#true} is VALID [2022-02-20 18:03:42,838 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {8791#true} {8791#true} #1226#return; {8791#true} is VALID [2022-02-20 18:03:42,839 INFO L290 TraceCheckUtils]: 17: Hoare triple {8791#true} assume { :end_inline_setup_bob } true;setup_~__cil_tmp1~0#1.base, setup_~__cil_tmp1~0#1.offset := 37, 0;havoc setup_#t~nondet97#1;~rjh~0 := 2;assume { :begin_inline_setup_rjh } true;setup_rjh_#in~rjh___0#1 := ~rjh~0;havoc setup_rjh_~rjh___0#1;setup_rjh_~rjh___0#1 := setup_rjh_#in~rjh___0#1;assume { :begin_inline_setup_rjh__wrappee__Base } true;setup_rjh__wrappee__Base_#in~rjh___0#1 := setup_rjh_~rjh___0#1;havoc setup_rjh__wrappee__Base_~rjh___0#1;setup_rjh__wrappee__Base_~rjh___0#1 := setup_rjh__wrappee__Base_#in~rjh___0#1; {8801#(= |ULTIMATE.start_setup_rjh__wrappee__Base_~rjh___0#1| 2)} is VALID [2022-02-20 18:03:42,839 INFO L272 TraceCheckUtils]: 18: Hoare triple {8801#(= |ULTIMATE.start_setup_rjh__wrappee__Base_~rjh___0#1| 2)} call setClientId(setup_rjh__wrappee__Base_~rjh___0#1, setup_rjh__wrappee__Base_~rjh___0#1); {8851#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} is VALID [2022-02-20 18:03:42,840 INFO L290 TraceCheckUtils]: 19: Hoare triple {8851#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {8853#(= setClientId_~handle |setClientId_#in~handle|)} is VALID [2022-02-20 18:03:42,840 INFO L290 TraceCheckUtils]: 20: Hoare triple {8853#(= setClientId_~handle |setClientId_#in~handle|)} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {8854#(= |setClientId_#in~handle| 1)} is VALID [2022-02-20 18:03:42,840 INFO L290 TraceCheckUtils]: 21: Hoare triple {8854#(= |setClientId_#in~handle| 1)} assume true; {8854#(= |setClientId_#in~handle| 1)} is VALID [2022-02-20 18:03:42,841 INFO L284 TraceCheckUtils]: 22: Hoare quadruple {8854#(= |setClientId_#in~handle| 1)} {8801#(= |ULTIMATE.start_setup_rjh__wrappee__Base_~rjh___0#1| 2)} #1228#return; {8792#false} is VALID [2022-02-20 18:03:42,841 INFO L290 TraceCheckUtils]: 23: Hoare triple {8792#false} assume { :end_inline_setup_rjh__wrappee__Base } true; {8792#false} is VALID [2022-02-20 18:03:42,841 INFO L272 TraceCheckUtils]: 24: Hoare triple {8792#false} call setClientPrivateKey(setup_rjh_~rjh___0#1, 456); {8852#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} is VALID [2022-02-20 18:03:42,841 INFO L290 TraceCheckUtils]: 25: Hoare triple {8852#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {8791#true} is VALID [2022-02-20 18:03:42,841 INFO L290 TraceCheckUtils]: 26: Hoare triple {8791#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {8791#true} is VALID [2022-02-20 18:03:42,841 INFO L290 TraceCheckUtils]: 27: Hoare triple {8791#true} assume true; {8791#true} is VALID [2022-02-20 18:03:42,841 INFO L284 TraceCheckUtils]: 28: Hoare quadruple {8791#true} {8792#false} #1230#return; {8792#false} is VALID [2022-02-20 18:03:42,841 INFO L290 TraceCheckUtils]: 29: Hoare triple {8792#false} assume { :end_inline_setup_rjh } true;setup_~__cil_tmp2~1#1.base, setup_~__cil_tmp2~1#1.offset := 38, 0;havoc setup_#t~nondet98#1;~chuck~0 := 3;assume { :begin_inline_setup_chuck } true;setup_chuck_#in~chuck___0#1 := ~chuck~0;havoc setup_chuck_~chuck___0#1;setup_chuck_~chuck___0#1 := setup_chuck_#in~chuck___0#1;assume { :begin_inline_setup_chuck__wrappee__Base } true;setup_chuck__wrappee__Base_#in~chuck___0#1 := setup_chuck_~chuck___0#1;havoc setup_chuck__wrappee__Base_~chuck___0#1;setup_chuck__wrappee__Base_~chuck___0#1 := setup_chuck__wrappee__Base_#in~chuck___0#1; {8792#false} is VALID [2022-02-20 18:03:42,841 INFO L272 TraceCheckUtils]: 30: Hoare triple {8792#false} call setClientId(setup_chuck__wrappee__Base_~chuck___0#1, setup_chuck__wrappee__Base_~chuck___0#1); {8851#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} is VALID [2022-02-20 18:03:42,841 INFO L290 TraceCheckUtils]: 31: Hoare triple {8851#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {8791#true} is VALID [2022-02-20 18:03:42,841 INFO L290 TraceCheckUtils]: 32: Hoare triple {8791#true} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {8791#true} is VALID [2022-02-20 18:03:42,841 INFO L290 TraceCheckUtils]: 33: Hoare triple {8791#true} assume true; {8791#true} is VALID [2022-02-20 18:03:42,841 INFO L284 TraceCheckUtils]: 34: Hoare quadruple {8791#true} {8792#false} #1232#return; {8792#false} is VALID [2022-02-20 18:03:42,841 INFO L290 TraceCheckUtils]: 35: Hoare triple {8792#false} assume { :end_inline_setup_chuck__wrappee__Base } true; {8792#false} is VALID [2022-02-20 18:03:42,841 INFO L272 TraceCheckUtils]: 36: Hoare triple {8792#false} call setClientPrivateKey(setup_chuck_~chuck___0#1, 789); {8852#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} is VALID [2022-02-20 18:03:42,841 INFO L290 TraceCheckUtils]: 37: Hoare triple {8852#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {8791#true} is VALID [2022-02-20 18:03:42,841 INFO L290 TraceCheckUtils]: 38: Hoare triple {8791#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {8791#true} is VALID [2022-02-20 18:03:42,841 INFO L290 TraceCheckUtils]: 39: Hoare triple {8791#true} assume true; {8791#true} is VALID [2022-02-20 18:03:42,841 INFO L284 TraceCheckUtils]: 40: Hoare quadruple {8791#true} {8792#false} #1234#return; {8792#false} is VALID [2022-02-20 18:03:42,842 INFO L290 TraceCheckUtils]: 41: Hoare triple {8792#false} assume { :end_inline_setup_chuck } true;setup_~__cil_tmp3~4#1.base, setup_~__cil_tmp3~4#1.offset := 39, 0;havoc setup_#t~nondet99#1; {8792#false} is VALID [2022-02-20 18:03:42,842 INFO L290 TraceCheckUtils]: 42: Hoare triple {8792#false} assume { :end_inline_setup } true;assume { :begin_inline_test } true;havoc test_#t~nondet55#1, test_#t~nondet56#1, test_#t~nondet57#1, test_#t~nondet58#1, test_#t~nondet59#1, test_#t~nondet60#1, test_#t~nondet61#1, test_#t~nondet62#1, test_#t~nondet63#1, test_#t~nondet64#1, test_#t~nondet65#1, test_~op1~0#1, test_~op2~0#1, test_~op3~0#1, test_~op4~0#1, test_~op5~0#1, test_~op6~0#1, test_~op7~0#1, test_~op8~0#1, test_~op9~0#1, test_~op10~0#1, test_~op11~0#1, test_~splverifierCounter~0#1, test_~tmp~9#1, test_~tmp___0~3#1, test_~tmp___1~1#1, test_~tmp___2~1#1, test_~tmp___3~0#1, test_~tmp___4~0#1, test_~tmp___5~0#1, test_~tmp___6~0#1, test_~tmp___7~0#1, test_~tmp___8~0#1, test_~tmp___9~0#1;havoc test_~op1~0#1;havoc test_~op2~0#1;havoc test_~op3~0#1;havoc test_~op4~0#1;havoc test_~op5~0#1;havoc test_~op6~0#1;havoc test_~op7~0#1;havoc test_~op8~0#1;havoc test_~op9~0#1;havoc test_~op10~0#1;havoc test_~op11~0#1;havoc test_~splverifierCounter~0#1;havoc test_~tmp~9#1;havoc test_~tmp___0~3#1;havoc test_~tmp___1~1#1;havoc test_~tmp___2~1#1;havoc test_~tmp___3~0#1;havoc test_~tmp___4~0#1;havoc test_~tmp___5~0#1;havoc test_~tmp___6~0#1;havoc test_~tmp___7~0#1;havoc test_~tmp___8~0#1;havoc test_~tmp___9~0#1;test_~op1~0#1 := 0;test_~op2~0#1 := 0;test_~op3~0#1 := 0;test_~op4~0#1 := 0;test_~op5~0#1 := 0;test_~op6~0#1 := 0;test_~op7~0#1 := 0;test_~op8~0#1 := 0;test_~op9~0#1 := 0;test_~op10~0#1 := 0;test_~op11~0#1 := 0;test_~splverifierCounter~0#1 := 0; {8792#false} is VALID [2022-02-20 18:03:42,842 INFO L290 TraceCheckUtils]: 43: Hoare triple {8792#false} assume !false; {8792#false} is VALID [2022-02-20 18:03:42,842 INFO L290 TraceCheckUtils]: 44: Hoare triple {8792#false} assume test_~splverifierCounter~0#1 < 4; {8792#false} is VALID [2022-02-20 18:03:42,842 INFO L290 TraceCheckUtils]: 45: Hoare triple {8792#false} test_~splverifierCounter~0#1 := 1 + test_~splverifierCounter~0#1; {8792#false} is VALID [2022-02-20 18:03:42,842 INFO L290 TraceCheckUtils]: 46: Hoare triple {8792#false} assume 0 == test_~op1~0#1;assume -2147483648 <= test_#t~nondet55#1 && test_#t~nondet55#1 <= 2147483647;test_~tmp___9~0#1 := test_#t~nondet55#1;havoc test_#t~nondet55#1; {8792#false} is VALID [2022-02-20 18:03:42,842 INFO L290 TraceCheckUtils]: 47: Hoare triple {8792#false} assume !(0 != test_~tmp___9~0#1); {8792#false} is VALID [2022-02-20 18:03:42,842 INFO L290 TraceCheckUtils]: 48: Hoare triple {8792#false} assume 0 == test_~op2~0#1;assume -2147483648 <= test_#t~nondet56#1 && test_#t~nondet56#1 <= 2147483647;test_~tmp___8~0#1 := test_#t~nondet56#1;havoc test_#t~nondet56#1; {8792#false} is VALID [2022-02-20 18:03:42,842 INFO L290 TraceCheckUtils]: 49: Hoare triple {8792#false} assume 0 != test_~tmp___8~0#1;test_~op2~0#1 := 1; {8792#false} is VALID [2022-02-20 18:03:42,842 INFO L290 TraceCheckUtils]: 50: Hoare triple {8792#false} assume !false; {8792#false} is VALID [2022-02-20 18:03:42,842 INFO L290 TraceCheckUtils]: 51: Hoare triple {8792#false} assume !(test_~splverifierCounter~0#1 < 4); {8792#false} is VALID [2022-02-20 18:03:42,842 INFO L290 TraceCheckUtils]: 52: Hoare triple {8792#false} assume { :begin_inline_bobToRjh } true;havoc bobToRjh_#t~ret92#1, bobToRjh_#t~ret93#1, bobToRjh_#t~ret94#1, bobToRjh_#t~ret95#1, bobToRjh_~tmp~19#1, bobToRjh_~tmp___0~8#1, bobToRjh_~tmp___1~5#1;havoc bobToRjh_~tmp~19#1;havoc bobToRjh_~tmp___0~8#1;havoc bobToRjh_~tmp___1~5#1;call bobToRjh_#t~ret92#1 := puts(35, 0);assume -2147483648 <= bobToRjh_#t~ret92#1 && bobToRjh_#t~ret92#1 <= 2147483647;havoc bobToRjh_#t~ret92#1; {8792#false} is VALID [2022-02-20 18:03:42,842 INFO L272 TraceCheckUtils]: 53: Hoare triple {8792#false} call sendEmail(~bob~0, ~rjh~0); {8792#false} is VALID [2022-02-20 18:03:42,842 INFO L290 TraceCheckUtils]: 54: Hoare triple {8792#false} ~sender#1 := #in~sender#1;~receiver#1 := #in~receiver#1;havoc ~email~0#1;havoc ~tmp~16#1;assume { :begin_inline_createEmail } true;createEmail_#in~from#1, createEmail_#in~to#1 := 0, ~receiver#1;havoc createEmail_#res#1;havoc createEmail_~from#1, createEmail_~to#1, createEmail_~retValue_acc~16#1, createEmail_~msg~0#1;createEmail_~from#1 := createEmail_#in~from#1;createEmail_~to#1 := createEmail_#in~to#1;havoc createEmail_~retValue_acc~16#1;havoc createEmail_~msg~0#1;createEmail_~msg~0#1 := 1; {8792#false} is VALID [2022-02-20 18:03:42,842 INFO L272 TraceCheckUtils]: 55: Hoare triple {8792#false} call setEmailFrom(createEmail_~msg~0#1, createEmail_~from#1); {8855#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} is VALID [2022-02-20 18:03:42,842 INFO L290 TraceCheckUtils]: 56: Hoare triple {8855#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} ~handle := #in~handle;~value := #in~value; {8791#true} is VALID [2022-02-20 18:03:42,842 INFO L290 TraceCheckUtils]: 57: Hoare triple {8791#true} assume 1 == ~handle;~__ste_email_from0~0 := ~value; {8791#true} is VALID [2022-02-20 18:03:42,842 INFO L290 TraceCheckUtils]: 58: Hoare triple {8791#true} assume true; {8791#true} is VALID [2022-02-20 18:03:42,842 INFO L284 TraceCheckUtils]: 59: Hoare quadruple {8791#true} {8792#false} #1210#return; {8792#false} is VALID [2022-02-20 18:03:42,843 INFO L272 TraceCheckUtils]: 60: Hoare triple {8792#false} call setEmailTo(createEmail_~msg~0#1, createEmail_~to#1); {8856#(and (= ~__ste_email_to0~0 |old(~__ste_email_to0~0)|) (= ~__ste_email_to1~0 |old(~__ste_email_to1~0)|))} is VALID [2022-02-20 18:03:42,843 INFO L290 TraceCheckUtils]: 61: Hoare triple {8856#(and (= ~__ste_email_to0~0 |old(~__ste_email_to0~0)|) (= ~__ste_email_to1~0 |old(~__ste_email_to1~0)|))} ~handle := #in~handle;~value := #in~value; {8791#true} is VALID [2022-02-20 18:03:42,843 INFO L290 TraceCheckUtils]: 62: Hoare triple {8791#true} assume 1 == ~handle;~__ste_email_to0~0 := ~value; {8791#true} is VALID [2022-02-20 18:03:42,843 INFO L290 TraceCheckUtils]: 63: Hoare triple {8791#true} assume true; {8791#true} is VALID [2022-02-20 18:03:42,843 INFO L284 TraceCheckUtils]: 64: Hoare quadruple {8791#true} {8792#false} #1212#return; {8792#false} is VALID [2022-02-20 18:03:42,843 INFO L290 TraceCheckUtils]: 65: Hoare triple {8792#false} createEmail_~retValue_acc~16#1 := createEmail_~msg~0#1;createEmail_#res#1 := createEmail_~retValue_acc~16#1; {8792#false} is VALID [2022-02-20 18:03:42,843 INFO L290 TraceCheckUtils]: 66: Hoare triple {8792#false} #t~ret83#1 := createEmail_#res#1;assume { :end_inline_createEmail } true;assume -2147483648 <= #t~ret83#1 && #t~ret83#1 <= 2147483647;~tmp~16#1 := #t~ret83#1;havoc #t~ret83#1;~email~0#1 := ~tmp~16#1; {8792#false} is VALID [2022-02-20 18:03:42,843 INFO L272 TraceCheckUtils]: 67: Hoare triple {8792#false} call outgoing(~sender#1, ~email~0#1); {8792#false} is VALID [2022-02-20 18:03:42,843 INFO L290 TraceCheckUtils]: 68: Hoare triple {8792#false} ~client#1 := #in~client#1;~msg#1 := #in~msg#1;assume { :begin_inline_sign } true;sign_#in~client#1, sign_#in~msg#1 := ~client#1, ~msg#1;havoc sign_#t~ret85#1, sign_~client#1, sign_~msg#1, sign_~privkey~1#1, sign_~tmp~17#1;sign_~client#1 := sign_#in~client#1;sign_~msg#1 := sign_#in~msg#1;havoc sign_~privkey~1#1;havoc sign_~tmp~17#1; {8792#false} is VALID [2022-02-20 18:03:42,843 INFO L272 TraceCheckUtils]: 69: Hoare triple {8792#false} call sign_#t~ret85#1 := getClientPrivateKey(sign_~client#1); {8791#true} is VALID [2022-02-20 18:03:42,843 INFO L290 TraceCheckUtils]: 70: Hoare triple {8791#true} ~handle := #in~handle;havoc ~retValue_acc~36; {8791#true} is VALID [2022-02-20 18:03:42,843 INFO L290 TraceCheckUtils]: 71: Hoare triple {8791#true} assume 1 == ~handle;~retValue_acc~36 := ~__ste_client_privateKey0~0;#res := ~retValue_acc~36; {8791#true} is VALID [2022-02-20 18:03:42,843 INFO L290 TraceCheckUtils]: 72: Hoare triple {8791#true} assume true; {8791#true} is VALID [2022-02-20 18:03:42,843 INFO L284 TraceCheckUtils]: 73: Hoare quadruple {8791#true} {8792#false} #1150#return; {8792#false} is VALID [2022-02-20 18:03:42,843 INFO L290 TraceCheckUtils]: 74: Hoare triple {8792#false} assume -2147483648 <= sign_#t~ret85#1 && sign_#t~ret85#1 <= 2147483647;sign_~tmp~17#1 := sign_#t~ret85#1;havoc sign_#t~ret85#1;sign_~privkey~1#1 := sign_~tmp~17#1; {8792#false} is VALID [2022-02-20 18:03:42,843 INFO L290 TraceCheckUtils]: 75: Hoare triple {8792#false} assume 0 == sign_~privkey~1#1; {8792#false} is VALID [2022-02-20 18:03:42,843 INFO L290 TraceCheckUtils]: 76: Hoare triple {8792#false} assume { :end_inline_sign } true;assume { :begin_inline_outgoing__wrappee__AddressBook } true;outgoing__wrappee__AddressBook_#in~client#1, outgoing__wrappee__AddressBook_#in~msg#1 := ~client#1, ~msg#1;havoc outgoing__wrappee__AddressBook_#t~ret71#1, outgoing__wrappee__AddressBook_#t~ret72#1, outgoing__wrappee__AddressBook_#t~ret73#1, outgoing__wrappee__AddressBook_#t~ret74#1, outgoing__wrappee__AddressBook_#t~ret75#1, outgoing__wrappee__AddressBook_#t~ret76#1, outgoing__wrappee__AddressBook_~client#1, outgoing__wrappee__AddressBook_~msg#1, outgoing__wrappee__AddressBook_~size~0#1, outgoing__wrappee__AddressBook_~tmp~13#1, outgoing__wrappee__AddressBook_~receiver~1#1, outgoing__wrappee__AddressBook_~tmp___0~5#1, outgoing__wrappee__AddressBook_~second~0#1, outgoing__wrappee__AddressBook_~tmp___1~2#1, outgoing__wrappee__AddressBook_~tmp___2~2#1;outgoing__wrappee__AddressBook_~client#1 := outgoing__wrappee__AddressBook_#in~client#1;outgoing__wrappee__AddressBook_~msg#1 := outgoing__wrappee__AddressBook_#in~msg#1;havoc outgoing__wrappee__AddressBook_~size~0#1;havoc outgoing__wrappee__AddressBook_~tmp~13#1;havoc outgoing__wrappee__AddressBook_~receiver~1#1;havoc outgoing__wrappee__AddressBook_~tmp___0~5#1;havoc outgoing__wrappee__AddressBook_~second~0#1;havoc outgoing__wrappee__AddressBook_~tmp___1~2#1;havoc outgoing__wrappee__AddressBook_~tmp___2~2#1; {8792#false} is VALID [2022-02-20 18:03:42,843 INFO L272 TraceCheckUtils]: 77: Hoare triple {8792#false} call outgoing__wrappee__AddressBook_#t~ret71#1 := getClientAddressBookSize(outgoing__wrappee__AddressBook_~client#1); {8791#true} is VALID [2022-02-20 18:03:42,843 INFO L290 TraceCheckUtils]: 78: Hoare triple {8791#true} ~handle := #in~handle;havoc ~retValue_acc~30; {8791#true} is VALID [2022-02-20 18:03:42,843 INFO L290 TraceCheckUtils]: 79: Hoare triple {8791#true} assume 1 == ~handle;~retValue_acc~30 := ~__ste_ClientAddressBook_size0~0;#res := ~retValue_acc~30; {8791#true} is VALID [2022-02-20 18:03:42,844 INFO L290 TraceCheckUtils]: 80: Hoare triple {8791#true} assume true; {8791#true} is VALID [2022-02-20 18:03:42,844 INFO L284 TraceCheckUtils]: 81: Hoare quadruple {8791#true} {8792#false} #1152#return; {8792#false} is VALID [2022-02-20 18:03:42,844 INFO L290 TraceCheckUtils]: 82: Hoare triple {8792#false} assume -2147483648 <= outgoing__wrappee__AddressBook_#t~ret71#1 && outgoing__wrappee__AddressBook_#t~ret71#1 <= 2147483647;outgoing__wrappee__AddressBook_~tmp~13#1 := outgoing__wrappee__AddressBook_#t~ret71#1;havoc outgoing__wrappee__AddressBook_#t~ret71#1;outgoing__wrappee__AddressBook_~size~0#1 := outgoing__wrappee__AddressBook_~tmp~13#1; {8792#false} is VALID [2022-02-20 18:03:42,844 INFO L290 TraceCheckUtils]: 83: Hoare triple {8792#false} assume !(0 != outgoing__wrappee__AddressBook_~size~0#1); {8792#false} is VALID [2022-02-20 18:03:42,844 INFO L272 TraceCheckUtils]: 84: Hoare triple {8792#false} call outgoing__wrappee__Encrypt(outgoing__wrappee__AddressBook_~client#1, outgoing__wrappee__AddressBook_~msg#1); {8792#false} is VALID [2022-02-20 18:03:42,844 INFO L290 TraceCheckUtils]: 85: Hoare triple {8792#false} ~client#1 := #in~client#1;~msg#1 := #in~msg#1;havoc ~receiver~0#1;havoc ~tmp~12#1;havoc ~pubkey~0#1;havoc ~tmp___0~4#1; {8792#false} is VALID [2022-02-20 18:03:42,844 INFO L272 TraceCheckUtils]: 86: Hoare triple {8792#false} call #t~ret69#1 := getEmailTo(~msg#1); {8791#true} is VALID [2022-02-20 18:03:42,844 INFO L290 TraceCheckUtils]: 87: Hoare triple {8791#true} ~handle := #in~handle;havoc ~retValue_acc~3; {8791#true} is VALID [2022-02-20 18:03:42,844 INFO L290 TraceCheckUtils]: 88: Hoare triple {8791#true} assume 1 == ~handle;~retValue_acc~3 := ~__ste_email_to0~0;#res := ~retValue_acc~3; {8791#true} is VALID [2022-02-20 18:03:42,844 INFO L290 TraceCheckUtils]: 89: Hoare triple {8791#true} assume true; {8791#true} is VALID [2022-02-20 18:03:42,844 INFO L284 TraceCheckUtils]: 90: Hoare quadruple {8791#true} {8792#false} #1170#return; {8792#false} is VALID [2022-02-20 18:03:42,844 INFO L290 TraceCheckUtils]: 91: Hoare triple {8792#false} assume -2147483648 <= #t~ret69#1 && #t~ret69#1 <= 2147483647;~tmp~12#1 := #t~ret69#1;havoc #t~ret69#1;~receiver~0#1 := ~tmp~12#1; {8792#false} is VALID [2022-02-20 18:03:42,844 INFO L272 TraceCheckUtils]: 92: Hoare triple {8792#false} call #t~ret70#1 := findPublicKey(~client#1, ~receiver~0#1); {8791#true} is VALID [2022-02-20 18:03:42,844 INFO L290 TraceCheckUtils]: 93: Hoare triple {8791#true} ~handle := #in~handle;~userid := #in~userid;havoc ~retValue_acc~41; {8791#true} is VALID [2022-02-20 18:03:42,844 INFO L290 TraceCheckUtils]: 94: Hoare triple {8791#true} assume 1 == ~handle; {8791#true} is VALID [2022-02-20 18:03:42,844 INFO L290 TraceCheckUtils]: 95: Hoare triple {8791#true} assume ~userid == ~__ste_Client_Keyring0_User0~0;~retValue_acc~41 := ~__ste_Client_Keyring0_PublicKey0~0;#res := ~retValue_acc~41; {8791#true} is VALID [2022-02-20 18:03:42,844 INFO L290 TraceCheckUtils]: 96: Hoare triple {8791#true} assume true; {8791#true} is VALID [2022-02-20 18:03:42,844 INFO L284 TraceCheckUtils]: 97: Hoare quadruple {8791#true} {8792#false} #1172#return; {8792#false} is VALID [2022-02-20 18:03:42,844 INFO L290 TraceCheckUtils]: 98: Hoare triple {8792#false} assume -2147483648 <= #t~ret70#1 && #t~ret70#1 <= 2147483647;~tmp___0~4#1 := #t~ret70#1;havoc #t~ret70#1;~pubkey~0#1 := ~tmp___0~4#1; {8792#false} is VALID [2022-02-20 18:03:42,844 INFO L290 TraceCheckUtils]: 99: Hoare triple {8792#false} assume !(0 != ~pubkey~0#1); {8792#false} is VALID [2022-02-20 18:03:42,844 INFO L290 TraceCheckUtils]: 100: Hoare triple {8792#false} assume { :begin_inline_outgoing__wrappee__Keys } true;outgoing__wrappee__Keys_#in~client#1, outgoing__wrappee__Keys_#in~msg#1 := ~client#1, ~msg#1;havoc outgoing__wrappee__Keys_#t~ret68#1, outgoing__wrappee__Keys_~client#1, outgoing__wrappee__Keys_~msg#1, outgoing__wrappee__Keys_~tmp~11#1;outgoing__wrappee__Keys_~client#1 := outgoing__wrappee__Keys_#in~client#1;outgoing__wrappee__Keys_~msg#1 := outgoing__wrappee__Keys_#in~msg#1;havoc outgoing__wrappee__Keys_~tmp~11#1;assume { :begin_inline_getClientId } true;getClientId_#in~handle#1 := outgoing__wrappee__Keys_~client#1;havoc getClientId_#res#1;havoc getClientId_~handle#1, getClientId_~retValue_acc~43#1;getClientId_~handle#1 := getClientId_#in~handle#1;havoc getClientId_~retValue_acc~43#1; {8792#false} is VALID [2022-02-20 18:03:42,845 INFO L290 TraceCheckUtils]: 101: Hoare triple {8792#false} assume 1 == getClientId_~handle#1;getClientId_~retValue_acc~43#1 := ~__ste_client_idCounter0~0;getClientId_#res#1 := getClientId_~retValue_acc~43#1; {8792#false} is VALID [2022-02-20 18:03:42,845 INFO L290 TraceCheckUtils]: 102: Hoare triple {8792#false} outgoing__wrappee__Keys_#t~ret68#1 := getClientId_#res#1;assume { :end_inline_getClientId } true;assume -2147483648 <= outgoing__wrappee__Keys_#t~ret68#1 && outgoing__wrappee__Keys_#t~ret68#1 <= 2147483647;outgoing__wrappee__Keys_~tmp~11#1 := outgoing__wrappee__Keys_#t~ret68#1;havoc outgoing__wrappee__Keys_#t~ret68#1; {8792#false} is VALID [2022-02-20 18:03:42,845 INFO L272 TraceCheckUtils]: 103: Hoare triple {8792#false} call setEmailFrom(outgoing__wrappee__Keys_~msg#1, outgoing__wrappee__Keys_~tmp~11#1); {8855#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} is VALID [2022-02-20 18:03:42,845 INFO L290 TraceCheckUtils]: 104: Hoare triple {8855#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} ~handle := #in~handle;~value := #in~value; {8791#true} is VALID [2022-02-20 18:03:42,845 INFO L290 TraceCheckUtils]: 105: Hoare triple {8791#true} assume 1 == ~handle;~__ste_email_from0~0 := ~value; {8791#true} is VALID [2022-02-20 18:03:42,845 INFO L290 TraceCheckUtils]: 106: Hoare triple {8791#true} assume true; {8791#true} is VALID [2022-02-20 18:03:42,845 INFO L284 TraceCheckUtils]: 107: Hoare quadruple {8791#true} {8792#false} #1178#return; {8792#false} is VALID [2022-02-20 18:03:42,845 INFO L290 TraceCheckUtils]: 108: Hoare triple {8792#false} assume { :begin_inline_mail } true;mail_#in~client#1, mail_#in~msg#1 := outgoing__wrappee__Keys_~client#1, outgoing__wrappee__Keys_~msg#1;havoc mail_#t~ret66#1, mail_#t~ret67#1, mail_~client#1, mail_~msg#1, mail_~__utac__ad__arg1~0#1, mail_~tmp~10#1;mail_~client#1 := mail_#in~client#1;mail_~msg#1 := mail_#in~msg#1;havoc mail_~__utac__ad__arg1~0#1;havoc mail_~tmp~10#1;mail_~__utac__ad__arg1~0#1 := mail_~msg#1;assume { :begin_inline___utac_acc__EncryptAutoResponder_spec__2 } true;__utac_acc__EncryptAutoResponder_spec__2_#in~msg#1 := mail_~__utac__ad__arg1~0#1;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1, __utac_acc__EncryptAutoResponder_spec__2_#t~nondet29#1, __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1, __utac_acc__EncryptAutoResponder_spec__2_~msg#1, __utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.base, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.offset;__utac_acc__EncryptAutoResponder_spec__2_~msg#1 := __utac_acc__EncryptAutoResponder_spec__2_#in~msg#1;havoc __utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1;havoc __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.base, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.offset;call __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1 := puts(15, 0);assume -2147483648 <= __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1 && __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1 <= 2147483647;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1;__utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.base, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.offset := 16, 0;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~nondet29#1; {8792#false} is VALID [2022-02-20 18:03:42,845 INFO L290 TraceCheckUtils]: 109: Hoare triple {8792#false} assume 0 != ~in_encrypted~0; {8792#false} is VALID [2022-02-20 18:03:42,845 INFO L272 TraceCheckUtils]: 110: Hoare triple {8792#false} call __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1 := isEncrypted(__utac_acc__EncryptAutoResponder_spec__2_~msg#1); {8791#true} is VALID [2022-02-20 18:03:42,845 INFO L290 TraceCheckUtils]: 111: Hoare triple {8791#true} ~handle := #in~handle;havoc ~retValue_acc~6; {8791#true} is VALID [2022-02-20 18:03:42,845 INFO L290 TraceCheckUtils]: 112: Hoare triple {8791#true} assume 1 == ~handle;~retValue_acc~6 := ~__ste_email_isEncrypted0~0;#res := ~retValue_acc~6; {8791#true} is VALID [2022-02-20 18:03:42,845 INFO L290 TraceCheckUtils]: 113: Hoare triple {8791#true} assume true; {8791#true} is VALID [2022-02-20 18:03:42,845 INFO L284 TraceCheckUtils]: 114: Hoare quadruple {8791#true} {8792#false} #1180#return; {8792#false} is VALID [2022-02-20 18:03:42,845 INFO L290 TraceCheckUtils]: 115: Hoare triple {8792#false} assume -2147483648 <= __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1 && __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1 <= 2147483647;__utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1 := __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1; {8792#false} is VALID [2022-02-20 18:03:42,845 INFO L290 TraceCheckUtils]: 116: Hoare triple {8792#false} assume !(0 != __utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1);assume { :begin_inline___automaton_fail } true; {8792#false} is VALID [2022-02-20 18:03:42,845 INFO L290 TraceCheckUtils]: 117: Hoare triple {8792#false} assume !false; {8792#false} is VALID [2022-02-20 18:03:42,846 INFO L134 CoverageAnalysis]: Checked inductivity of 30 backedges. 3 proven. 3 refuted. 0 times theorem prover too weak. 24 trivial. 0 not checked. [2022-02-20 18:03:42,848 INFO L144 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-02-20 18:03:42,848 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [1994563648] [2022-02-20 18:03:42,848 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleSmtInterpolCraig [1994563648] provided 0 perfect and 1 imperfect interpolant sequences [2022-02-20 18:03:42,848 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [643494915] [2022-02-20 18:03:42,848 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 18:03:42,848 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-02-20 18:03:42,848 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-02-20 18:03:42,855 INFO L229 MonitoredProcess]: Starting monitored process 5 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2022-02-20 18:03:42,859 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (5)] Waiting until timeout for monitored process [2022-02-20 18:03:43,079 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:43,083 INFO L263 TraceCheckSpWp]: Trace formula consists of 1132 conjuncts, 8 conjunts are in the unsatisfiable core [2022-02-20 18:03:43,123 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:43,131 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-02-20 18:03:43,412 INFO L290 TraceCheckUtils]: 0: Hoare triple {8791#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(28, 2);call #Ultimate.allocInit(12, 3);call #Ultimate.allocInit(10, 4);call #Ultimate.allocInit(12, 5);call #Ultimate.allocInit(10, 6);call #Ultimate.allocInit(18, 7);call #Ultimate.allocInit(16, 8);call #Ultimate.allocInit(21, 9);call #Ultimate.allocInit(13, 10);call #Ultimate.allocInit(16, 11);call #Ultimate.allocInit(25, 12);call #Ultimate.allocInit(17, 13);call #Ultimate.allocInit(17, 14);call #Ultimate.allocInit(13, 15);call #Ultimate.allocInit(17, 16);call #Ultimate.allocInit(30, 17);call #Ultimate.allocInit(9, 18);call #Ultimate.allocInit(21, 19);call #Ultimate.allocInit(30, 20);call #Ultimate.allocInit(9, 21);call #Ultimate.allocInit(21, 22);call #Ultimate.allocInit(30, 23);call #Ultimate.allocInit(9, 24);call #Ultimate.allocInit(25, 25);call #Ultimate.allocInit(30, 26);call #Ultimate.allocInit(9, 27);call #Ultimate.allocInit(25, 28);call #Ultimate.allocInit(4, 29);call write~init~int(37, 29, 0, 1);call write~init~int(115, 29, 1, 1);call write~init~int(10, 29, 2, 1);call write~init~int(0, 29, 3, 1);call #Ultimate.allocInit(10, 30);call #Ultimate.allocInit(34, 31);call #Ultimate.allocInit(30, 32);call #Ultimate.allocInit(16, 33);call #Ultimate.allocInit(20, 34);call #Ultimate.allocInit(44, 35);call #Ultimate.allocInit(44, 36);call #Ultimate.allocInit(9, 37);call #Ultimate.allocInit(9, 38);call #Ultimate.allocInit(11, 39);call #Ultimate.allocInit(19, 40);call #Ultimate.allocInit(4, 41);call write~init~int(37, 41, 0, 1);call write~init~int(100, 41, 1, 1);call write~init~int(10, 41, 2, 1);call write~init~int(0, 41, 3, 1);call #Ultimate.allocInit(4, 42);call write~init~int(37, 42, 0, 1);call write~init~int(100, 42, 1, 1);call write~init~int(10, 42, 2, 1);call write~init~int(0, 42, 3, 1);~__ste_Email_counter~0 := 0;~__ste_email_id0~0 := 0;~__ste_email_id1~0 := 0;~__ste_email_from0~0 := 0;~__ste_email_from1~0 := 0;~__ste_email_to0~0 := 0;~__ste_email_to1~0 := 0;~__ste_email_subject0~0.base, ~__ste_email_subject0~0.offset := 0, 0;~__ste_email_subject1~0.base, ~__ste_email_subject1~0.offset := 0, 0;~__ste_email_body0~0.base, ~__ste_email_body0~0.offset := 0, 0;~__ste_email_body1~0.base, ~__ste_email_body1~0.offset := 0, 0;~__ste_email_isEncrypted0~0 := 0;~__ste_email_isEncrypted1~0 := 0;~__ste_email_encryptionKey0~0 := 0;~__ste_email_encryptionKey1~0 := 0;~__ste_email_isSigned0~0 := 0;~__ste_email_isSigned1~0 := 0;~__ste_email_signKey0~0 := 0;~__ste_email_signKey1~0 := 0;~__ste_email_isSignatureVerified0~0 := 0;~__ste_email_isSignatureVerified1~0 := 0;~__SELECTED_FEATURE_Base~0 := 0;~__SELECTED_FEATURE_Keys~0 := 0;~__SELECTED_FEATURE_Encrypt~0 := 0;~__SELECTED_FEATURE_AutoResponder~0 := 0;~__SELECTED_FEATURE_AddressBook~0 := 0;~__SELECTED_FEATURE_Sign~0 := 0;~__SELECTED_FEATURE_Forward~0 := 0;~__SELECTED_FEATURE_Verify~0 := 0;~__SELECTED_FEATURE_Decrypt~0 := 0;~__GUIDSL_ROOT_PRODUCTION~0 := 0;~__GUIDSL_NON_TERMINAL_main~0 := 0;~in_encrypted~0 := 0;~head~0.base, ~head~0.offset := 0, 0;~queue_empty~0 := 1;~queued_message~0 := 0;~queued_client~0 := 0;~bob~0 := 0;~rjh~0 := 0;~chuck~0 := 0;~__ste_Client_counter~0 := 0;~__ste_client_name0~0.base, ~__ste_client_name0~0.offset := 0, 0;~__ste_client_name1~0.base, ~__ste_client_name1~0.offset := 0, 0;~__ste_client_name2~0.base, ~__ste_client_name2~0.offset := 0, 0;~__ste_client_outbuffer0~0 := 0;~__ste_client_outbuffer1~0 := 0;~__ste_client_outbuffer2~0 := 0;~__ste_client_outbuffer3~0 := 0;~__ste_ClientAddressBook_size0~0 := 0;~__ste_ClientAddressBook_size1~0 := 0;~__ste_ClientAddressBook_size2~0 := 0;~__ste_Client_AddressBook0_Alias0~0 := 0;~__ste_Client_AddressBook0_Alias1~0 := 0;~__ste_Client_AddressBook0_Alias2~0 := 0;~__ste_Client_AddressBook1_Alias0~0 := 0;~__ste_Client_AddressBook1_Alias1~0 := 0;~__ste_Client_AddressBook1_Alias2~0 := 0;~__ste_Client_AddressBook2_Alias0~0 := 0;~__ste_Client_AddressBook2_Alias1~0 := 0;~__ste_Client_AddressBook2_Alias2~0 := 0;~__ste_Client_AddressBook0_Address0~0 := 0;~__ste_Client_AddressBook0_Address1~0 := 0;~__ste_Client_AddressBook0_Address2~0 := 0;~__ste_Client_AddressBook1_Address0~0 := 0;~__ste_Client_AddressBook1_Address1~0 := 0;~__ste_Client_AddressBook1_Address2~0 := 0;~__ste_Client_AddressBook2_Address0~0 := 0;~__ste_Client_AddressBook2_Address1~0 := 0;~__ste_Client_AddressBook2_Address2~0 := 0;~__ste_client_autoResponse0~0 := 0;~__ste_client_autoResponse1~0 := 0;~__ste_client_autoResponse2~0 := 0;~__ste_client_privateKey0~0 := 0;~__ste_client_privateKey1~0 := 0;~__ste_client_privateKey2~0 := 0;~__ste_ClientKeyring_size0~0 := 0;~__ste_ClientKeyring_size1~0 := 0;~__ste_ClientKeyring_size2~0 := 0;~__ste_Client_Keyring0_User0~0 := 0;~__ste_Client_Keyring0_User1~0 := 0;~__ste_Client_Keyring0_User2~0 := 0;~__ste_Client_Keyring1_User0~0 := 0;~__ste_Client_Keyring1_User1~0 := 0;~__ste_Client_Keyring1_User2~0 := 0;~__ste_Client_Keyring2_User0~0 := 0;~__ste_Client_Keyring2_User1~0 := 0;~__ste_Client_Keyring2_User2~0 := 0;~__ste_Client_Keyring0_PublicKey0~0 := 0;~__ste_Client_Keyring0_PublicKey1~0 := 0;~__ste_Client_Keyring0_PublicKey2~0 := 0;~__ste_Client_Keyring1_PublicKey0~0 := 0;~__ste_Client_Keyring1_PublicKey1~0 := 0;~__ste_Client_Keyring1_PublicKey2~0 := 0;~__ste_Client_Keyring2_PublicKey0~0 := 0;~__ste_Client_Keyring2_PublicKey1~0 := 0;~__ste_Client_Keyring2_PublicKey2~0 := 0;~__ste_client_forwardReceiver0~0 := 0;~__ste_client_forwardReceiver1~0 := 0;~__ste_client_forwardReceiver2~0 := 0;~__ste_client_forwardReceiver3~0 := 0;~__ste_client_idCounter0~0 := 0;~__ste_client_idCounter1~0 := 0;~__ste_client_idCounter2~0 := 0; {8791#true} is VALID [2022-02-20 18:03:43,412 INFO L290 TraceCheckUtils]: 1: Hoare triple {8791#true} assume { :end_inline_ULTIMATE.init } true;assume { :begin_inline_main } true;havoc main_#res#1;havoc main_#t~nondet100#1, main_#t~ret101#1, main_~retValue_acc~26#1, main_~tmp~20#1;assume -2147483648 <= main_#t~nondet100#1 && main_#t~nondet100#1 <= 2147483647;main_~retValue_acc~26#1 := main_#t~nondet100#1;havoc main_#t~nondet100#1;havoc main_~tmp~20#1;assume { :begin_inline_select_helpers } true; {8791#true} is VALID [2022-02-20 18:03:43,412 INFO L290 TraceCheckUtils]: 2: Hoare triple {8791#true} assume { :end_inline_select_helpers } true;assume { :begin_inline_select_features } true; {8791#true} is VALID [2022-02-20 18:03:43,412 INFO L290 TraceCheckUtils]: 3: Hoare triple {8791#true} assume { :end_inline_select_features } true;assume { :begin_inline_valid_product } true;havoc valid_product_#res#1;havoc valid_product_~retValue_acc~12#1;havoc valid_product_~retValue_acc~12#1;valid_product_~retValue_acc~12#1 := 1;valid_product_#res#1 := valid_product_~retValue_acc~12#1; {8791#true} is VALID [2022-02-20 18:03:43,412 INFO L290 TraceCheckUtils]: 4: Hoare triple {8791#true} main_#t~ret101#1 := valid_product_#res#1;assume { :end_inline_valid_product } true;assume -2147483648 <= main_#t~ret101#1 && main_#t~ret101#1 <= 2147483647;main_~tmp~20#1 := main_#t~ret101#1;havoc main_#t~ret101#1; {8791#true} is VALID [2022-02-20 18:03:43,412 INFO L290 TraceCheckUtils]: 5: Hoare triple {8791#true} assume 0 != main_~tmp~20#1;assume { :begin_inline_setup } true;havoc setup_#t~nondet97#1, setup_#t~nondet98#1, setup_#t~nondet99#1, setup_~__cil_tmp1~0#1.base, setup_~__cil_tmp1~0#1.offset, setup_~__cil_tmp2~1#1.base, setup_~__cil_tmp2~1#1.offset, setup_~__cil_tmp3~4#1.base, setup_~__cil_tmp3~4#1.offset;havoc setup_~__cil_tmp1~0#1.base, setup_~__cil_tmp1~0#1.offset;havoc setup_~__cil_tmp2~1#1.base, setup_~__cil_tmp2~1#1.offset;havoc setup_~__cil_tmp3~4#1.base, setup_~__cil_tmp3~4#1.offset;~bob~0 := 1;assume { :begin_inline_setup_bob } true;setup_bob_#in~bob___0#1 := ~bob~0;havoc setup_bob_~bob___0#1;setup_bob_~bob___0#1 := setup_bob_#in~bob___0#1;assume { :begin_inline_setup_bob__wrappee__Base } true;setup_bob__wrappee__Base_#in~bob___0#1 := setup_bob_~bob___0#1;havoc setup_bob__wrappee__Base_~bob___0#1;setup_bob__wrappee__Base_~bob___0#1 := setup_bob__wrappee__Base_#in~bob___0#1; {8791#true} is VALID [2022-02-20 18:03:43,412 INFO L272 TraceCheckUtils]: 6: Hoare triple {8791#true} call setClientId(setup_bob__wrappee__Base_~bob___0#1, setup_bob__wrappee__Base_~bob___0#1); {8791#true} is VALID [2022-02-20 18:03:43,413 INFO L290 TraceCheckUtils]: 7: Hoare triple {8791#true} ~handle := #in~handle;~value := #in~value; {8791#true} is VALID [2022-02-20 18:03:43,413 INFO L290 TraceCheckUtils]: 8: Hoare triple {8791#true} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {8791#true} is VALID [2022-02-20 18:03:43,413 INFO L290 TraceCheckUtils]: 9: Hoare triple {8791#true} assume true; {8791#true} is VALID [2022-02-20 18:03:43,413 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {8791#true} {8791#true} #1224#return; {8791#true} is VALID [2022-02-20 18:03:43,413 INFO L290 TraceCheckUtils]: 11: Hoare triple {8791#true} assume { :end_inline_setup_bob__wrappee__Base } true; {8791#true} is VALID [2022-02-20 18:03:43,413 INFO L272 TraceCheckUtils]: 12: Hoare triple {8791#true} call setClientPrivateKey(setup_bob_~bob___0#1, 123); {8791#true} is VALID [2022-02-20 18:03:43,413 INFO L290 TraceCheckUtils]: 13: Hoare triple {8791#true} ~handle := #in~handle;~value := #in~value; {8791#true} is VALID [2022-02-20 18:03:43,413 INFO L290 TraceCheckUtils]: 14: Hoare triple {8791#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {8791#true} is VALID [2022-02-20 18:03:43,414 INFO L290 TraceCheckUtils]: 15: Hoare triple {8791#true} assume true; {8791#true} is VALID [2022-02-20 18:03:43,414 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {8791#true} {8791#true} #1226#return; {8791#true} is VALID [2022-02-20 18:03:43,421 INFO L290 TraceCheckUtils]: 17: Hoare triple {8791#true} assume { :end_inline_setup_bob } true;setup_~__cil_tmp1~0#1.base, setup_~__cil_tmp1~0#1.offset := 37, 0;havoc setup_#t~nondet97#1;~rjh~0 := 2;assume { :begin_inline_setup_rjh } true;setup_rjh_#in~rjh___0#1 := ~rjh~0;havoc setup_rjh_~rjh___0#1;setup_rjh_~rjh___0#1 := setup_rjh_#in~rjh___0#1;assume { :begin_inline_setup_rjh__wrappee__Base } true;setup_rjh__wrappee__Base_#in~rjh___0#1 := setup_rjh_~rjh___0#1;havoc setup_rjh__wrappee__Base_~rjh___0#1;setup_rjh__wrappee__Base_~rjh___0#1 := setup_rjh__wrappee__Base_#in~rjh___0#1; {8911#(<= 2 |ULTIMATE.start_setup_rjh__wrappee__Base_~rjh___0#1|)} is VALID [2022-02-20 18:03:43,421 INFO L272 TraceCheckUtils]: 18: Hoare triple {8911#(<= 2 |ULTIMATE.start_setup_rjh__wrappee__Base_~rjh___0#1|)} call setClientId(setup_rjh__wrappee__Base_~rjh___0#1, setup_rjh__wrappee__Base_~rjh___0#1); {8791#true} is VALID [2022-02-20 18:03:43,426 INFO L290 TraceCheckUtils]: 19: Hoare triple {8791#true} ~handle := #in~handle;~value := #in~value; {8918#(<= |setClientId_#in~handle| setClientId_~handle)} is VALID [2022-02-20 18:03:43,426 INFO L290 TraceCheckUtils]: 20: Hoare triple {8918#(<= |setClientId_#in~handle| setClientId_~handle)} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {8922#(<= |setClientId_#in~handle| 1)} is VALID [2022-02-20 18:03:43,426 INFO L290 TraceCheckUtils]: 21: Hoare triple {8922#(<= |setClientId_#in~handle| 1)} assume true; {8922#(<= |setClientId_#in~handle| 1)} is VALID [2022-02-20 18:03:43,427 INFO L284 TraceCheckUtils]: 22: Hoare quadruple {8922#(<= |setClientId_#in~handle| 1)} {8911#(<= 2 |ULTIMATE.start_setup_rjh__wrappee__Base_~rjh___0#1|)} #1228#return; {8792#false} is VALID [2022-02-20 18:03:43,427 INFO L290 TraceCheckUtils]: 23: Hoare triple {8792#false} assume { :end_inline_setup_rjh__wrappee__Base } true; {8792#false} is VALID [2022-02-20 18:03:43,427 INFO L272 TraceCheckUtils]: 24: Hoare triple {8792#false} call setClientPrivateKey(setup_rjh_~rjh___0#1, 456); {8792#false} is VALID [2022-02-20 18:03:43,427 INFO L290 TraceCheckUtils]: 25: Hoare triple {8792#false} ~handle := #in~handle;~value := #in~value; {8792#false} is VALID [2022-02-20 18:03:43,427 INFO L290 TraceCheckUtils]: 26: Hoare triple {8792#false} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {8792#false} is VALID [2022-02-20 18:03:43,427 INFO L290 TraceCheckUtils]: 27: Hoare triple {8792#false} assume true; {8792#false} is VALID [2022-02-20 18:03:43,427 INFO L284 TraceCheckUtils]: 28: Hoare quadruple {8792#false} {8792#false} #1230#return; {8792#false} is VALID [2022-02-20 18:03:43,427 INFO L290 TraceCheckUtils]: 29: Hoare triple {8792#false} assume { :end_inline_setup_rjh } true;setup_~__cil_tmp2~1#1.base, setup_~__cil_tmp2~1#1.offset := 38, 0;havoc setup_#t~nondet98#1;~chuck~0 := 3;assume { :begin_inline_setup_chuck } true;setup_chuck_#in~chuck___0#1 := ~chuck~0;havoc setup_chuck_~chuck___0#1;setup_chuck_~chuck___0#1 := setup_chuck_#in~chuck___0#1;assume { :begin_inline_setup_chuck__wrappee__Base } true;setup_chuck__wrappee__Base_#in~chuck___0#1 := setup_chuck_~chuck___0#1;havoc setup_chuck__wrappee__Base_~chuck___0#1;setup_chuck__wrappee__Base_~chuck___0#1 := setup_chuck__wrappee__Base_#in~chuck___0#1; {8792#false} is VALID [2022-02-20 18:03:43,427 INFO L272 TraceCheckUtils]: 30: Hoare triple {8792#false} call setClientId(setup_chuck__wrappee__Base_~chuck___0#1, setup_chuck__wrappee__Base_~chuck___0#1); {8792#false} is VALID [2022-02-20 18:03:43,427 INFO L290 TraceCheckUtils]: 31: Hoare triple {8792#false} ~handle := #in~handle;~value := #in~value; {8792#false} is VALID [2022-02-20 18:03:43,428 INFO L290 TraceCheckUtils]: 32: Hoare triple {8792#false} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {8792#false} is VALID [2022-02-20 18:03:43,428 INFO L290 TraceCheckUtils]: 33: Hoare triple {8792#false} assume true; {8792#false} is VALID [2022-02-20 18:03:43,428 INFO L284 TraceCheckUtils]: 34: Hoare quadruple {8792#false} {8792#false} #1232#return; {8792#false} is VALID [2022-02-20 18:03:43,428 INFO L290 TraceCheckUtils]: 35: Hoare triple {8792#false} assume { :end_inline_setup_chuck__wrappee__Base } true; {8792#false} is VALID [2022-02-20 18:03:43,428 INFO L272 TraceCheckUtils]: 36: Hoare triple {8792#false} call setClientPrivateKey(setup_chuck_~chuck___0#1, 789); {8792#false} is VALID [2022-02-20 18:03:43,428 INFO L290 TraceCheckUtils]: 37: Hoare triple {8792#false} ~handle := #in~handle;~value := #in~value; {8792#false} is VALID [2022-02-20 18:03:43,428 INFO L290 TraceCheckUtils]: 38: Hoare triple {8792#false} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {8792#false} is VALID [2022-02-20 18:03:43,428 INFO L290 TraceCheckUtils]: 39: Hoare triple {8792#false} assume true; {8792#false} is VALID [2022-02-20 18:03:43,428 INFO L284 TraceCheckUtils]: 40: Hoare quadruple {8792#false} {8792#false} #1234#return; {8792#false} is VALID [2022-02-20 18:03:43,429 INFO L290 TraceCheckUtils]: 41: Hoare triple {8792#false} assume { :end_inline_setup_chuck } true;setup_~__cil_tmp3~4#1.base, setup_~__cil_tmp3~4#1.offset := 39, 0;havoc setup_#t~nondet99#1; {8792#false} is VALID [2022-02-20 18:03:43,429 INFO L290 TraceCheckUtils]: 42: Hoare triple {8792#false} assume { :end_inline_setup } true;assume { :begin_inline_test } true;havoc test_#t~nondet55#1, test_#t~nondet56#1, test_#t~nondet57#1, test_#t~nondet58#1, test_#t~nondet59#1, test_#t~nondet60#1, test_#t~nondet61#1, test_#t~nondet62#1, test_#t~nondet63#1, test_#t~nondet64#1, test_#t~nondet65#1, test_~op1~0#1, test_~op2~0#1, test_~op3~0#1, test_~op4~0#1, test_~op5~0#1, test_~op6~0#1, test_~op7~0#1, test_~op8~0#1, test_~op9~0#1, test_~op10~0#1, test_~op11~0#1, test_~splverifierCounter~0#1, test_~tmp~9#1, test_~tmp___0~3#1, test_~tmp___1~1#1, test_~tmp___2~1#1, test_~tmp___3~0#1, test_~tmp___4~0#1, test_~tmp___5~0#1, test_~tmp___6~0#1, test_~tmp___7~0#1, test_~tmp___8~0#1, test_~tmp___9~0#1;havoc test_~op1~0#1;havoc test_~op2~0#1;havoc test_~op3~0#1;havoc test_~op4~0#1;havoc test_~op5~0#1;havoc test_~op6~0#1;havoc test_~op7~0#1;havoc test_~op8~0#1;havoc test_~op9~0#1;havoc test_~op10~0#1;havoc test_~op11~0#1;havoc test_~splverifierCounter~0#1;havoc test_~tmp~9#1;havoc test_~tmp___0~3#1;havoc test_~tmp___1~1#1;havoc test_~tmp___2~1#1;havoc test_~tmp___3~0#1;havoc test_~tmp___4~0#1;havoc test_~tmp___5~0#1;havoc test_~tmp___6~0#1;havoc test_~tmp___7~0#1;havoc test_~tmp___8~0#1;havoc test_~tmp___9~0#1;test_~op1~0#1 := 0;test_~op2~0#1 := 0;test_~op3~0#1 := 0;test_~op4~0#1 := 0;test_~op5~0#1 := 0;test_~op6~0#1 := 0;test_~op7~0#1 := 0;test_~op8~0#1 := 0;test_~op9~0#1 := 0;test_~op10~0#1 := 0;test_~op11~0#1 := 0;test_~splverifierCounter~0#1 := 0; {8792#false} is VALID [2022-02-20 18:03:43,429 INFO L290 TraceCheckUtils]: 43: Hoare triple {8792#false} assume !false; {8792#false} is VALID [2022-02-20 18:03:43,429 INFO L290 TraceCheckUtils]: 44: Hoare triple {8792#false} assume test_~splverifierCounter~0#1 < 4; {8792#false} is VALID [2022-02-20 18:03:43,429 INFO L290 TraceCheckUtils]: 45: Hoare triple {8792#false} test_~splverifierCounter~0#1 := 1 + test_~splverifierCounter~0#1; {8792#false} is VALID [2022-02-20 18:03:43,429 INFO L290 TraceCheckUtils]: 46: Hoare triple {8792#false} assume 0 == test_~op1~0#1;assume -2147483648 <= test_#t~nondet55#1 && test_#t~nondet55#1 <= 2147483647;test_~tmp___9~0#1 := test_#t~nondet55#1;havoc test_#t~nondet55#1; {8792#false} is VALID [2022-02-20 18:03:43,429 INFO L290 TraceCheckUtils]: 47: Hoare triple {8792#false} assume !(0 != test_~tmp___9~0#1); {8792#false} is VALID [2022-02-20 18:03:43,429 INFO L290 TraceCheckUtils]: 48: Hoare triple {8792#false} assume 0 == test_~op2~0#1;assume -2147483648 <= test_#t~nondet56#1 && test_#t~nondet56#1 <= 2147483647;test_~tmp___8~0#1 := test_#t~nondet56#1;havoc test_#t~nondet56#1; {8792#false} is VALID [2022-02-20 18:03:43,429 INFO L290 TraceCheckUtils]: 49: Hoare triple {8792#false} assume 0 != test_~tmp___8~0#1;test_~op2~0#1 := 1; {8792#false} is VALID [2022-02-20 18:03:43,430 INFO L290 TraceCheckUtils]: 50: Hoare triple {8792#false} assume !false; {8792#false} is VALID [2022-02-20 18:03:43,430 INFO L290 TraceCheckUtils]: 51: Hoare triple {8792#false} assume !(test_~splverifierCounter~0#1 < 4); {8792#false} is VALID [2022-02-20 18:03:43,430 INFO L290 TraceCheckUtils]: 52: Hoare triple {8792#false} assume { :begin_inline_bobToRjh } true;havoc bobToRjh_#t~ret92#1, bobToRjh_#t~ret93#1, bobToRjh_#t~ret94#1, bobToRjh_#t~ret95#1, bobToRjh_~tmp~19#1, bobToRjh_~tmp___0~8#1, bobToRjh_~tmp___1~5#1;havoc bobToRjh_~tmp~19#1;havoc bobToRjh_~tmp___0~8#1;havoc bobToRjh_~tmp___1~5#1;call bobToRjh_#t~ret92#1 := puts(35, 0);assume -2147483648 <= bobToRjh_#t~ret92#1 && bobToRjh_#t~ret92#1 <= 2147483647;havoc bobToRjh_#t~ret92#1; {8792#false} is VALID [2022-02-20 18:03:43,430 INFO L272 TraceCheckUtils]: 53: Hoare triple {8792#false} call sendEmail(~bob~0, ~rjh~0); {8792#false} is VALID [2022-02-20 18:03:43,430 INFO L290 TraceCheckUtils]: 54: Hoare triple {8792#false} ~sender#1 := #in~sender#1;~receiver#1 := #in~receiver#1;havoc ~email~0#1;havoc ~tmp~16#1;assume { :begin_inline_createEmail } true;createEmail_#in~from#1, createEmail_#in~to#1 := 0, ~receiver#1;havoc createEmail_#res#1;havoc createEmail_~from#1, createEmail_~to#1, createEmail_~retValue_acc~16#1, createEmail_~msg~0#1;createEmail_~from#1 := createEmail_#in~from#1;createEmail_~to#1 := createEmail_#in~to#1;havoc createEmail_~retValue_acc~16#1;havoc createEmail_~msg~0#1;createEmail_~msg~0#1 := 1; {8792#false} is VALID [2022-02-20 18:03:43,430 INFO L272 TraceCheckUtils]: 55: Hoare triple {8792#false} call setEmailFrom(createEmail_~msg~0#1, createEmail_~from#1); {8792#false} is VALID [2022-02-20 18:03:43,430 INFO L290 TraceCheckUtils]: 56: Hoare triple {8792#false} ~handle := #in~handle;~value := #in~value; {8792#false} is VALID [2022-02-20 18:03:43,430 INFO L290 TraceCheckUtils]: 57: Hoare triple {8792#false} assume 1 == ~handle;~__ste_email_from0~0 := ~value; {8792#false} is VALID [2022-02-20 18:03:43,430 INFO L290 TraceCheckUtils]: 58: Hoare triple {8792#false} assume true; {8792#false} is VALID [2022-02-20 18:03:43,431 INFO L284 TraceCheckUtils]: 59: Hoare quadruple {8792#false} {8792#false} #1210#return; {8792#false} is VALID [2022-02-20 18:03:43,431 INFO L272 TraceCheckUtils]: 60: Hoare triple {8792#false} call setEmailTo(createEmail_~msg~0#1, createEmail_~to#1); {8792#false} is VALID [2022-02-20 18:03:43,431 INFO L290 TraceCheckUtils]: 61: Hoare triple {8792#false} ~handle := #in~handle;~value := #in~value; {8792#false} is VALID [2022-02-20 18:03:43,431 INFO L290 TraceCheckUtils]: 62: Hoare triple {8792#false} assume 1 == ~handle;~__ste_email_to0~0 := ~value; {8792#false} is VALID [2022-02-20 18:03:43,431 INFO L290 TraceCheckUtils]: 63: Hoare triple {8792#false} assume true; {8792#false} is VALID [2022-02-20 18:03:43,431 INFO L284 TraceCheckUtils]: 64: Hoare quadruple {8792#false} {8792#false} #1212#return; {8792#false} is VALID [2022-02-20 18:03:43,431 INFO L290 TraceCheckUtils]: 65: Hoare triple {8792#false} createEmail_~retValue_acc~16#1 := createEmail_~msg~0#1;createEmail_#res#1 := createEmail_~retValue_acc~16#1; {8792#false} is VALID [2022-02-20 18:03:43,431 INFO L290 TraceCheckUtils]: 66: Hoare triple {8792#false} #t~ret83#1 := createEmail_#res#1;assume { :end_inline_createEmail } true;assume -2147483648 <= #t~ret83#1 && #t~ret83#1 <= 2147483647;~tmp~16#1 := #t~ret83#1;havoc #t~ret83#1;~email~0#1 := ~tmp~16#1; {8792#false} is VALID [2022-02-20 18:03:43,431 INFO L272 TraceCheckUtils]: 67: Hoare triple {8792#false} call outgoing(~sender#1, ~email~0#1); {8792#false} is VALID [2022-02-20 18:03:43,432 INFO L290 TraceCheckUtils]: 68: Hoare triple {8792#false} ~client#1 := #in~client#1;~msg#1 := #in~msg#1;assume { :begin_inline_sign } true;sign_#in~client#1, sign_#in~msg#1 := ~client#1, ~msg#1;havoc sign_#t~ret85#1, sign_~client#1, sign_~msg#1, sign_~privkey~1#1, sign_~tmp~17#1;sign_~client#1 := sign_#in~client#1;sign_~msg#1 := sign_#in~msg#1;havoc sign_~privkey~1#1;havoc sign_~tmp~17#1; {8792#false} is VALID [2022-02-20 18:03:43,432 INFO L272 TraceCheckUtils]: 69: Hoare triple {8792#false} call sign_#t~ret85#1 := getClientPrivateKey(sign_~client#1); {8792#false} is VALID [2022-02-20 18:03:43,432 INFO L290 TraceCheckUtils]: 70: Hoare triple {8792#false} ~handle := #in~handle;havoc ~retValue_acc~36; {8792#false} is VALID [2022-02-20 18:03:43,432 INFO L290 TraceCheckUtils]: 71: Hoare triple {8792#false} assume 1 == ~handle;~retValue_acc~36 := ~__ste_client_privateKey0~0;#res := ~retValue_acc~36; {8792#false} is VALID [2022-02-20 18:03:43,432 INFO L290 TraceCheckUtils]: 72: Hoare triple {8792#false} assume true; {8792#false} is VALID [2022-02-20 18:03:43,432 INFO L284 TraceCheckUtils]: 73: Hoare quadruple {8792#false} {8792#false} #1150#return; {8792#false} is VALID [2022-02-20 18:03:43,432 INFO L290 TraceCheckUtils]: 74: Hoare triple {8792#false} assume -2147483648 <= sign_#t~ret85#1 && sign_#t~ret85#1 <= 2147483647;sign_~tmp~17#1 := sign_#t~ret85#1;havoc sign_#t~ret85#1;sign_~privkey~1#1 := sign_~tmp~17#1; {8792#false} is VALID [2022-02-20 18:03:43,432 INFO L290 TraceCheckUtils]: 75: Hoare triple {8792#false} assume 0 == sign_~privkey~1#1; {8792#false} is VALID [2022-02-20 18:03:43,432 INFO L290 TraceCheckUtils]: 76: Hoare triple {8792#false} assume { :end_inline_sign } true;assume { :begin_inline_outgoing__wrappee__AddressBook } true;outgoing__wrappee__AddressBook_#in~client#1, outgoing__wrappee__AddressBook_#in~msg#1 := ~client#1, ~msg#1;havoc outgoing__wrappee__AddressBook_#t~ret71#1, outgoing__wrappee__AddressBook_#t~ret72#1, outgoing__wrappee__AddressBook_#t~ret73#1, outgoing__wrappee__AddressBook_#t~ret74#1, outgoing__wrappee__AddressBook_#t~ret75#1, outgoing__wrappee__AddressBook_#t~ret76#1, outgoing__wrappee__AddressBook_~client#1, outgoing__wrappee__AddressBook_~msg#1, outgoing__wrappee__AddressBook_~size~0#1, outgoing__wrappee__AddressBook_~tmp~13#1, outgoing__wrappee__AddressBook_~receiver~1#1, outgoing__wrappee__AddressBook_~tmp___0~5#1, outgoing__wrappee__AddressBook_~second~0#1, outgoing__wrappee__AddressBook_~tmp___1~2#1, outgoing__wrappee__AddressBook_~tmp___2~2#1;outgoing__wrappee__AddressBook_~client#1 := outgoing__wrappee__AddressBook_#in~client#1;outgoing__wrappee__AddressBook_~msg#1 := outgoing__wrappee__AddressBook_#in~msg#1;havoc outgoing__wrappee__AddressBook_~size~0#1;havoc outgoing__wrappee__AddressBook_~tmp~13#1;havoc outgoing__wrappee__AddressBook_~receiver~1#1;havoc outgoing__wrappee__AddressBook_~tmp___0~5#1;havoc outgoing__wrappee__AddressBook_~second~0#1;havoc outgoing__wrappee__AddressBook_~tmp___1~2#1;havoc outgoing__wrappee__AddressBook_~tmp___2~2#1; {8792#false} is VALID [2022-02-20 18:03:43,432 INFO L272 TraceCheckUtils]: 77: Hoare triple {8792#false} call outgoing__wrappee__AddressBook_#t~ret71#1 := getClientAddressBookSize(outgoing__wrappee__AddressBook_~client#1); {8792#false} is VALID [2022-02-20 18:03:43,433 INFO L290 TraceCheckUtils]: 78: Hoare triple {8792#false} ~handle := #in~handle;havoc ~retValue_acc~30; {8792#false} is VALID [2022-02-20 18:03:43,433 INFO L290 TraceCheckUtils]: 79: Hoare triple {8792#false} assume 1 == ~handle;~retValue_acc~30 := ~__ste_ClientAddressBook_size0~0;#res := ~retValue_acc~30; {8792#false} is VALID [2022-02-20 18:03:43,433 INFO L290 TraceCheckUtils]: 80: Hoare triple {8792#false} assume true; {8792#false} is VALID [2022-02-20 18:03:43,433 INFO L284 TraceCheckUtils]: 81: Hoare quadruple {8792#false} {8792#false} #1152#return; {8792#false} is VALID [2022-02-20 18:03:43,433 INFO L290 TraceCheckUtils]: 82: Hoare triple {8792#false} assume -2147483648 <= outgoing__wrappee__AddressBook_#t~ret71#1 && outgoing__wrappee__AddressBook_#t~ret71#1 <= 2147483647;outgoing__wrappee__AddressBook_~tmp~13#1 := outgoing__wrappee__AddressBook_#t~ret71#1;havoc outgoing__wrappee__AddressBook_#t~ret71#1;outgoing__wrappee__AddressBook_~size~0#1 := outgoing__wrappee__AddressBook_~tmp~13#1; {8792#false} is VALID [2022-02-20 18:03:43,433 INFO L290 TraceCheckUtils]: 83: Hoare triple {8792#false} assume !(0 != outgoing__wrappee__AddressBook_~size~0#1); {8792#false} is VALID [2022-02-20 18:03:43,433 INFO L272 TraceCheckUtils]: 84: Hoare triple {8792#false} call outgoing__wrappee__Encrypt(outgoing__wrappee__AddressBook_~client#1, outgoing__wrappee__AddressBook_~msg#1); {8792#false} is VALID [2022-02-20 18:03:43,433 INFO L290 TraceCheckUtils]: 85: Hoare triple {8792#false} ~client#1 := #in~client#1;~msg#1 := #in~msg#1;havoc ~receiver~0#1;havoc ~tmp~12#1;havoc ~pubkey~0#1;havoc ~tmp___0~4#1; {8792#false} is VALID [2022-02-20 18:03:43,433 INFO L272 TraceCheckUtils]: 86: Hoare triple {8792#false} call #t~ret69#1 := getEmailTo(~msg#1); {8792#false} is VALID [2022-02-20 18:03:43,434 INFO L290 TraceCheckUtils]: 87: Hoare triple {8792#false} ~handle := #in~handle;havoc ~retValue_acc~3; {8792#false} is VALID [2022-02-20 18:03:43,434 INFO L290 TraceCheckUtils]: 88: Hoare triple {8792#false} assume 1 == ~handle;~retValue_acc~3 := ~__ste_email_to0~0;#res := ~retValue_acc~3; {8792#false} is VALID [2022-02-20 18:03:43,434 INFO L290 TraceCheckUtils]: 89: Hoare triple {8792#false} assume true; {8792#false} is VALID [2022-02-20 18:03:43,434 INFO L284 TraceCheckUtils]: 90: Hoare quadruple {8792#false} {8792#false} #1170#return; {8792#false} is VALID [2022-02-20 18:03:43,434 INFO L290 TraceCheckUtils]: 91: Hoare triple {8792#false} assume -2147483648 <= #t~ret69#1 && #t~ret69#1 <= 2147483647;~tmp~12#1 := #t~ret69#1;havoc #t~ret69#1;~receiver~0#1 := ~tmp~12#1; {8792#false} is VALID [2022-02-20 18:03:43,434 INFO L272 TraceCheckUtils]: 92: Hoare triple {8792#false} call #t~ret70#1 := findPublicKey(~client#1, ~receiver~0#1); {8792#false} is VALID [2022-02-20 18:03:43,434 INFO L290 TraceCheckUtils]: 93: Hoare triple {8792#false} ~handle := #in~handle;~userid := #in~userid;havoc ~retValue_acc~41; {8792#false} is VALID [2022-02-20 18:03:43,434 INFO L290 TraceCheckUtils]: 94: Hoare triple {8792#false} assume 1 == ~handle; {8792#false} is VALID [2022-02-20 18:03:43,434 INFO L290 TraceCheckUtils]: 95: Hoare triple {8792#false} assume ~userid == ~__ste_Client_Keyring0_User0~0;~retValue_acc~41 := ~__ste_Client_Keyring0_PublicKey0~0;#res := ~retValue_acc~41; {8792#false} is VALID [2022-02-20 18:03:43,435 INFO L290 TraceCheckUtils]: 96: Hoare triple {8792#false} assume true; {8792#false} is VALID [2022-02-20 18:03:43,435 INFO L284 TraceCheckUtils]: 97: Hoare quadruple {8792#false} {8792#false} #1172#return; {8792#false} is VALID [2022-02-20 18:03:43,435 INFO L290 TraceCheckUtils]: 98: Hoare triple {8792#false} assume -2147483648 <= #t~ret70#1 && #t~ret70#1 <= 2147483647;~tmp___0~4#1 := #t~ret70#1;havoc #t~ret70#1;~pubkey~0#1 := ~tmp___0~4#1; {8792#false} is VALID [2022-02-20 18:03:43,435 INFO L290 TraceCheckUtils]: 99: Hoare triple {8792#false} assume !(0 != ~pubkey~0#1); {8792#false} is VALID [2022-02-20 18:03:43,435 INFO L290 TraceCheckUtils]: 100: Hoare triple {8792#false} assume { :begin_inline_outgoing__wrappee__Keys } true;outgoing__wrappee__Keys_#in~client#1, outgoing__wrappee__Keys_#in~msg#1 := ~client#1, ~msg#1;havoc outgoing__wrappee__Keys_#t~ret68#1, outgoing__wrappee__Keys_~client#1, outgoing__wrappee__Keys_~msg#1, outgoing__wrappee__Keys_~tmp~11#1;outgoing__wrappee__Keys_~client#1 := outgoing__wrappee__Keys_#in~client#1;outgoing__wrappee__Keys_~msg#1 := outgoing__wrappee__Keys_#in~msg#1;havoc outgoing__wrappee__Keys_~tmp~11#1;assume { :begin_inline_getClientId } true;getClientId_#in~handle#1 := outgoing__wrappee__Keys_~client#1;havoc getClientId_#res#1;havoc getClientId_~handle#1, getClientId_~retValue_acc~43#1;getClientId_~handle#1 := getClientId_#in~handle#1;havoc getClientId_~retValue_acc~43#1; {8792#false} is VALID [2022-02-20 18:03:43,435 INFO L290 TraceCheckUtils]: 101: Hoare triple {8792#false} assume 1 == getClientId_~handle#1;getClientId_~retValue_acc~43#1 := ~__ste_client_idCounter0~0;getClientId_#res#1 := getClientId_~retValue_acc~43#1; {8792#false} is VALID [2022-02-20 18:03:43,435 INFO L290 TraceCheckUtils]: 102: Hoare triple {8792#false} outgoing__wrappee__Keys_#t~ret68#1 := getClientId_#res#1;assume { :end_inline_getClientId } true;assume -2147483648 <= outgoing__wrappee__Keys_#t~ret68#1 && outgoing__wrappee__Keys_#t~ret68#1 <= 2147483647;outgoing__wrappee__Keys_~tmp~11#1 := outgoing__wrappee__Keys_#t~ret68#1;havoc outgoing__wrappee__Keys_#t~ret68#1; {8792#false} is VALID [2022-02-20 18:03:43,435 INFO L272 TraceCheckUtils]: 103: Hoare triple {8792#false} call setEmailFrom(outgoing__wrappee__Keys_~msg#1, outgoing__wrappee__Keys_~tmp~11#1); {8792#false} is VALID [2022-02-20 18:03:43,435 INFO L290 TraceCheckUtils]: 104: Hoare triple {8792#false} ~handle := #in~handle;~value := #in~value; {8792#false} is VALID [2022-02-20 18:03:43,436 INFO L290 TraceCheckUtils]: 105: Hoare triple {8792#false} assume 1 == ~handle;~__ste_email_from0~0 := ~value; {8792#false} is VALID [2022-02-20 18:03:43,436 INFO L290 TraceCheckUtils]: 106: Hoare triple {8792#false} assume true; {8792#false} is VALID [2022-02-20 18:03:43,436 INFO L284 TraceCheckUtils]: 107: Hoare quadruple {8792#false} {8792#false} #1178#return; {8792#false} is VALID [2022-02-20 18:03:43,436 INFO L290 TraceCheckUtils]: 108: Hoare triple {8792#false} assume { :begin_inline_mail } true;mail_#in~client#1, mail_#in~msg#1 := outgoing__wrappee__Keys_~client#1, outgoing__wrappee__Keys_~msg#1;havoc mail_#t~ret66#1, mail_#t~ret67#1, mail_~client#1, mail_~msg#1, mail_~__utac__ad__arg1~0#1, mail_~tmp~10#1;mail_~client#1 := mail_#in~client#1;mail_~msg#1 := mail_#in~msg#1;havoc mail_~__utac__ad__arg1~0#1;havoc mail_~tmp~10#1;mail_~__utac__ad__arg1~0#1 := mail_~msg#1;assume { :begin_inline___utac_acc__EncryptAutoResponder_spec__2 } true;__utac_acc__EncryptAutoResponder_spec__2_#in~msg#1 := mail_~__utac__ad__arg1~0#1;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1, __utac_acc__EncryptAutoResponder_spec__2_#t~nondet29#1, __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1, __utac_acc__EncryptAutoResponder_spec__2_~msg#1, __utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.base, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.offset;__utac_acc__EncryptAutoResponder_spec__2_~msg#1 := __utac_acc__EncryptAutoResponder_spec__2_#in~msg#1;havoc __utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1;havoc __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.base, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.offset;call __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1 := puts(15, 0);assume -2147483648 <= __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1 && __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1 <= 2147483647;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1;__utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.base, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.offset := 16, 0;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~nondet29#1; {8792#false} is VALID [2022-02-20 18:03:43,436 INFO L290 TraceCheckUtils]: 109: Hoare triple {8792#false} assume 0 != ~in_encrypted~0; {8792#false} is VALID [2022-02-20 18:03:43,436 INFO L272 TraceCheckUtils]: 110: Hoare triple {8792#false} call __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1 := isEncrypted(__utac_acc__EncryptAutoResponder_spec__2_~msg#1); {8792#false} is VALID [2022-02-20 18:03:43,436 INFO L290 TraceCheckUtils]: 111: Hoare triple {8792#false} ~handle := #in~handle;havoc ~retValue_acc~6; {8792#false} is VALID [2022-02-20 18:03:43,436 INFO L290 TraceCheckUtils]: 112: Hoare triple {8792#false} assume 1 == ~handle;~retValue_acc~6 := ~__ste_email_isEncrypted0~0;#res := ~retValue_acc~6; {8792#false} is VALID [2022-02-20 18:03:43,436 INFO L290 TraceCheckUtils]: 113: Hoare triple {8792#false} assume true; {8792#false} is VALID [2022-02-20 18:03:43,437 INFO L284 TraceCheckUtils]: 114: Hoare quadruple {8792#false} {8792#false} #1180#return; {8792#false} is VALID [2022-02-20 18:03:43,437 INFO L290 TraceCheckUtils]: 115: Hoare triple {8792#false} assume -2147483648 <= __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1 && __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1 <= 2147483647;__utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1 := __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1; {8792#false} is VALID [2022-02-20 18:03:43,437 INFO L290 TraceCheckUtils]: 116: Hoare triple {8792#false} assume !(0 != __utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1);assume { :begin_inline___automaton_fail } true; {8792#false} is VALID [2022-02-20 18:03:43,437 INFO L290 TraceCheckUtils]: 117: Hoare triple {8792#false} assume !false; {8792#false} is VALID [2022-02-20 18:03:43,437 INFO L134 CoverageAnalysis]: Checked inductivity of 30 backedges. 19 proven. 0 refuted. 0 times theorem prover too weak. 11 trivial. 0 not checked. [2022-02-20 18:03:43,437 INFO L324 TraceCheckSpWp]: Omiting computation of backward sequence because forward sequence was already perfect [2022-02-20 18:03:43,437 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleZ3 [643494915] provided 1 perfect and 0 imperfect interpolant sequences [2022-02-20 18:03:43,438 INFO L191 FreeRefinementEngine]: Found 1 perfect and 1 imperfect interpolant sequences. [2022-02-20 18:03:43,438 INFO L204 FreeRefinementEngine]: Number of different interpolants: perfect sequences [5] imperfect sequences [9] total 12 [2022-02-20 18:03:43,438 INFO L118 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [227072630] [2022-02-20 18:03:43,438 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-02-20 18:03:43,439 INFO L78 Accepts]: Start accepts. Automaton has has 5 states, 4 states have (on average 20.0) internal successors, (80), 5 states have internal predecessors, (80), 3 states have call successors, (17), 2 states have call predecessors, (17), 3 states have return successors, (14), 2 states have call predecessors, (14), 3 states have call successors, (14) Word has length 118 [2022-02-20 18:03:43,439 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-02-20 18:03:43,439 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with has 5 states, 4 states have (on average 20.0) internal successors, (80), 5 states have internal predecessors, (80), 3 states have call successors, (17), 2 states have call predecessors, (17), 3 states have return successors, (14), 2 states have call predecessors, (14), 3 states have call successors, (14) [2022-02-20 18:03:43,510 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 111 edges. 111 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 18:03:43,510 INFO L546 AbstractCegarLoop]: INTERPOLANT automaton has 5 states [2022-02-20 18:03:43,511 INFO L108 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2022-02-20 18:03:43,511 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 5 interpolants. [2022-02-20 18:03:43,511 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=24, Invalid=108, Unknown=0, NotChecked=0, Total=132 [2022-02-20 18:03:43,512 INFO L87 Difference]: Start difference. First operand 466 states and 716 transitions. Second operand has 5 states, 4 states have (on average 20.0) internal successors, (80), 5 states have internal predecessors, (80), 3 states have call successors, (17), 2 states have call predecessors, (17), 3 states have return successors, (14), 2 states have call predecessors, (14), 3 states have call successors, (14) [2022-02-20 18:03:44,517 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 18:03:44,518 INFO L93 Difference]: Finished difference Result 923 states and 1422 transitions. [2022-02-20 18:03:44,518 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 5 states. [2022-02-20 18:03:44,518 INFO L78 Accepts]: Start accepts. Automaton has has 5 states, 4 states have (on average 20.0) internal successors, (80), 5 states have internal predecessors, (80), 3 states have call successors, (17), 2 states have call predecessors, (17), 3 states have return successors, (14), 2 states have call predecessors, (14), 3 states have call successors, (14) Word has length 118 [2022-02-20 18:03:44,518 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-02-20 18:03:44,518 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 5 states, 4 states have (on average 20.0) internal successors, (80), 5 states have internal predecessors, (80), 3 states have call successors, (17), 2 states have call predecessors, (17), 3 states have return successors, (14), 2 states have call predecessors, (14), 3 states have call successors, (14) [2022-02-20 18:03:44,527 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 5 states to 5 states and 1200 transitions. [2022-02-20 18:03:44,527 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 5 states, 4 states have (on average 20.0) internal successors, (80), 5 states have internal predecessors, (80), 3 states have call successors, (17), 2 states have call predecessors, (17), 3 states have return successors, (14), 2 states have call predecessors, (14), 3 states have call successors, (14) [2022-02-20 18:03:44,535 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 5 states to 5 states and 1200 transitions. [2022-02-20 18:03:44,536 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with 5 states and 1200 transitions. [2022-02-20 18:03:45,297 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 1200 edges. 1200 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 18:03:45,311 INFO L225 Difference]: With dead ends: 923 [2022-02-20 18:03:45,311 INFO L226 Difference]: Without dead ends: 468 [2022-02-20 18:03:45,315 INFO L932 BasicCegarLoop]: 0 DeclaredPredicates, 150 GetRequests, 139 SyntacticMatches, 0 SemanticMatches, 11 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 3 ImplicationChecksByTransitivity, 0.1s TimeCoverageRelationStatistics Valid=28, Invalid=128, Unknown=0, NotChecked=0, Total=156 [2022-02-20 18:03:45,317 INFO L933 BasicCegarLoop]: 596 mSDtfsCounter, 144 mSDsluCounter, 1622 mSDsCounter, 0 mSdLazyCounter, 34 mSolverCounterSat, 0 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.0s Time, 0 mProtectedPredicate, 0 mProtectedAction, 167 SdHoareTripleChecker+Valid, 2218 SdHoareTripleChecker+Invalid, 34 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 0 IncrementalHoareTripleChecker+Valid, 34 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.0s IncrementalHoareTripleChecker+Time [2022-02-20 18:03:45,317 INFO L934 BasicCegarLoop]: SdHoareTripleChecker [167 Valid, 2218 Invalid, 34 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [0 Valid, 34 Invalid, 0 Unknown, 0 Unchecked, 0.0s Time] [2022-02-20 18:03:45,319 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 468 states. [2022-02-20 18:03:45,368 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 468 to 468. [2022-02-20 18:03:45,369 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-02-20 18:03:45,370 INFO L82 GeneralOperation]: Start isEquivalent. First operand 468 states. Second operand has 468 states, 361 states have (on average 1.5623268698060941) internal successors, (564), 366 states have internal predecessors, (564), 77 states have call successors, (77), 28 states have call predecessors, (77), 29 states have return successors, (78), 75 states have call predecessors, (78), 76 states have call successors, (78) [2022-02-20 18:03:45,371 INFO L74 IsIncluded]: Start isIncluded. First operand 468 states. Second operand has 468 states, 361 states have (on average 1.5623268698060941) internal successors, (564), 366 states have internal predecessors, (564), 77 states have call successors, (77), 28 states have call predecessors, (77), 29 states have return successors, (78), 75 states have call predecessors, (78), 76 states have call successors, (78) [2022-02-20 18:03:45,372 INFO L87 Difference]: Start difference. First operand 468 states. Second operand has 468 states, 361 states have (on average 1.5623268698060941) internal successors, (564), 366 states have internal predecessors, (564), 77 states have call successors, (77), 28 states have call predecessors, (77), 29 states have return successors, (78), 75 states have call predecessors, (78), 76 states have call successors, (78) [2022-02-20 18:03:45,384 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 18:03:45,385 INFO L93 Difference]: Finished difference Result 468 states and 719 transitions. [2022-02-20 18:03:45,385 INFO L276 IsEmpty]: Start isEmpty. Operand 468 states and 719 transitions. [2022-02-20 18:03:45,386 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 18:03:45,386 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 18:03:45,388 INFO L74 IsIncluded]: Start isIncluded. First operand has 468 states, 361 states have (on average 1.5623268698060941) internal successors, (564), 366 states have internal predecessors, (564), 77 states have call successors, (77), 28 states have call predecessors, (77), 29 states have return successors, (78), 75 states have call predecessors, (78), 76 states have call successors, (78) Second operand 468 states. [2022-02-20 18:03:45,388 INFO L87 Difference]: Start difference. First operand has 468 states, 361 states have (on average 1.5623268698060941) internal successors, (564), 366 states have internal predecessors, (564), 77 states have call successors, (77), 28 states have call predecessors, (77), 29 states have return successors, (78), 75 states have call predecessors, (78), 76 states have call successors, (78) Second operand 468 states. [2022-02-20 18:03:45,401 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 18:03:45,402 INFO L93 Difference]: Finished difference Result 468 states and 719 transitions. [2022-02-20 18:03:45,402 INFO L276 IsEmpty]: Start isEmpty. Operand 468 states and 719 transitions. [2022-02-20 18:03:45,403 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 18:03:45,403 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 18:03:45,403 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-02-20 18:03:45,404 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-02-20 18:03:45,405 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 468 states, 361 states have (on average 1.5623268698060941) internal successors, (564), 366 states have internal predecessors, (564), 77 states have call successors, (77), 28 states have call predecessors, (77), 29 states have return successors, (78), 75 states have call predecessors, (78), 76 states have call successors, (78) [2022-02-20 18:03:45,418 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 468 states to 468 states and 719 transitions. [2022-02-20 18:03:45,419 INFO L78 Accepts]: Start accepts. Automaton has 468 states and 719 transitions. Word has length 118 [2022-02-20 18:03:45,419 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-02-20 18:03:45,419 INFO L470 AbstractCegarLoop]: Abstraction has 468 states and 719 transitions. [2022-02-20 18:03:45,419 INFO L471 AbstractCegarLoop]: INTERPOLANT automaton has has 5 states, 4 states have (on average 20.0) internal successors, (80), 5 states have internal predecessors, (80), 3 states have call successors, (17), 2 states have call predecessors, (17), 3 states have return successors, (14), 2 states have call predecessors, (14), 3 states have call successors, (14) [2022-02-20 18:03:45,420 INFO L276 IsEmpty]: Start isEmpty. Operand 468 states and 719 transitions. [2022-02-20 18:03:45,421 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 120 [2022-02-20 18:03:45,421 INFO L506 BasicCegarLoop]: Found error trace [2022-02-20 18:03:45,422 INFO L514 BasicCegarLoop]: trace histogram [3, 3, 3, 3, 3, 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] [2022-02-20 18:03:45,449 INFO L540 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (5)] Forceful destruction successful, exit code 0 [2022-02-20 18:03:45,631 WARN L452 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable3,5 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-02-20 18:03:45,631 INFO L402 AbstractCegarLoop]: === Iteration 5 === Targeting outgoing__wrappee__EncryptErr0ASSERT_VIOLATIONERROR_FUNCTION === [outgoing__wrappee__EncryptErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-02-20 18:03:45,632 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-02-20 18:03:45,632 INFO L85 PathProgramCache]: Analyzing trace with hash -919767989, now seen corresponding path program 1 times [2022-02-20 18:03:45,632 INFO L126 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-02-20 18:03:45,632 INFO L338 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [985324451] [2022-02-20 18:03:45,632 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 18:03:45,632 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-02-20 18:03:45,662 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:45,693 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 6 [2022-02-20 18:03:45,694 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:45,696 INFO L290 TraceCheckUtils]: 0: Hoare triple {12130#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {12068#true} is VALID [2022-02-20 18:03:45,696 INFO L290 TraceCheckUtils]: 1: Hoare triple {12068#true} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {12068#true} is VALID [2022-02-20 18:03:45,696 INFO L290 TraceCheckUtils]: 2: Hoare triple {12068#true} assume true; {12068#true} is VALID [2022-02-20 18:03:45,696 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {12068#true} {12068#true} #1224#return; {12068#true} is VALID [2022-02-20 18:03:45,701 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 12 [2022-02-20 18:03:45,702 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:45,705 INFO L290 TraceCheckUtils]: 0: Hoare triple {12131#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {12068#true} is VALID [2022-02-20 18:03:45,705 INFO L290 TraceCheckUtils]: 1: Hoare triple {12068#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {12068#true} is VALID [2022-02-20 18:03:45,706 INFO L290 TraceCheckUtils]: 2: Hoare triple {12068#true} assume true; {12068#true} is VALID [2022-02-20 18:03:45,706 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {12068#true} {12068#true} #1226#return; {12068#true} is VALID [2022-02-20 18:03:45,706 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 18 [2022-02-20 18:03:45,708 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:45,719 INFO L290 TraceCheckUtils]: 0: Hoare triple {12130#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {12132#(= setClientId_~handle |setClientId_#in~handle|)} is VALID [2022-02-20 18:03:45,720 INFO L290 TraceCheckUtils]: 1: Hoare triple {12132#(= setClientId_~handle |setClientId_#in~handle|)} assume !(1 == ~handle); {12132#(= setClientId_~handle |setClientId_#in~handle|)} is VALID [2022-02-20 18:03:45,720 INFO L290 TraceCheckUtils]: 2: Hoare triple {12132#(= setClientId_~handle |setClientId_#in~handle|)} assume 2 == ~handle;~__ste_client_idCounter1~0 := ~value; {12133#(= 2 |setClientId_#in~handle|)} is VALID [2022-02-20 18:03:45,720 INFO L290 TraceCheckUtils]: 3: Hoare triple {12133#(= 2 |setClientId_#in~handle|)} assume true; {12133#(= 2 |setClientId_#in~handle|)} is VALID [2022-02-20 18:03:45,721 INFO L284 TraceCheckUtils]: 4: Hoare quadruple {12133#(= 2 |setClientId_#in~handle|)} {12078#(= |ULTIMATE.start_setup_rjh_~rjh___0#1| |ULTIMATE.start_setup_rjh__wrappee__Base_~rjh___0#1|)} #1228#return; {12084#(not (= |ULTIMATE.start_setup_rjh_~rjh___0#1| 1))} is VALID [2022-02-20 18:03:45,721 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 25 [2022-02-20 18:03:45,724 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:45,737 INFO L290 TraceCheckUtils]: 0: Hoare triple {12131#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {12134#(= setClientPrivateKey_~handle |setClientPrivateKey_#in~handle|)} is VALID [2022-02-20 18:03:45,737 INFO L290 TraceCheckUtils]: 1: Hoare triple {12134#(= setClientPrivateKey_~handle |setClientPrivateKey_#in~handle|)} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {12135#(= |setClientPrivateKey_#in~handle| 1)} is VALID [2022-02-20 18:03:45,737 INFO L290 TraceCheckUtils]: 2: Hoare triple {12135#(= |setClientPrivateKey_#in~handle| 1)} assume true; {12135#(= |setClientPrivateKey_#in~handle| 1)} is VALID [2022-02-20 18:03:45,738 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {12135#(= |setClientPrivateKey_#in~handle| 1)} {12084#(not (= |ULTIMATE.start_setup_rjh_~rjh___0#1| 1))} #1230#return; {12069#false} is VALID [2022-02-20 18:03:45,738 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 31 [2022-02-20 18:03:45,739 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:45,741 INFO L290 TraceCheckUtils]: 0: Hoare triple {12130#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {12068#true} is VALID [2022-02-20 18:03:45,741 INFO L290 TraceCheckUtils]: 1: Hoare triple {12068#true} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {12068#true} is VALID [2022-02-20 18:03:45,741 INFO L290 TraceCheckUtils]: 2: Hoare triple {12068#true} assume true; {12068#true} is VALID [2022-02-20 18:03:45,741 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {12068#true} {12069#false} #1232#return; {12069#false} is VALID [2022-02-20 18:03:45,742 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 37 [2022-02-20 18:03:45,743 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:45,744 INFO L290 TraceCheckUtils]: 0: Hoare triple {12131#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {12068#true} is VALID [2022-02-20 18:03:45,744 INFO L290 TraceCheckUtils]: 1: Hoare triple {12068#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {12068#true} is VALID [2022-02-20 18:03:45,744 INFO L290 TraceCheckUtils]: 2: Hoare triple {12068#true} assume true; {12068#true} is VALID [2022-02-20 18:03:45,745 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {12068#true} {12069#false} #1234#return; {12069#false} is VALID [2022-02-20 18:03:45,752 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 56 [2022-02-20 18:03:45,753 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:45,755 INFO L290 TraceCheckUtils]: 0: Hoare triple {12136#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} ~handle := #in~handle;~value := #in~value; {12068#true} is VALID [2022-02-20 18:03:45,755 INFO L290 TraceCheckUtils]: 1: Hoare triple {12068#true} assume 1 == ~handle;~__ste_email_from0~0 := ~value; {12068#true} is VALID [2022-02-20 18:03:45,755 INFO L290 TraceCheckUtils]: 2: Hoare triple {12068#true} assume true; {12068#true} is VALID [2022-02-20 18:03:45,755 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {12068#true} {12069#false} #1210#return; {12069#false} is VALID [2022-02-20 18:03:45,763 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 61 [2022-02-20 18:03:45,765 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:45,768 INFO L290 TraceCheckUtils]: 0: Hoare triple {12137#(and (= ~__ste_email_to0~0 |old(~__ste_email_to0~0)|) (= ~__ste_email_to1~0 |old(~__ste_email_to1~0)|))} ~handle := #in~handle;~value := #in~value; {12068#true} is VALID [2022-02-20 18:03:45,768 INFO L290 TraceCheckUtils]: 1: Hoare triple {12068#true} assume 1 == ~handle;~__ste_email_to0~0 := ~value; {12068#true} is VALID [2022-02-20 18:03:45,768 INFO L290 TraceCheckUtils]: 2: Hoare triple {12068#true} assume true; {12068#true} is VALID [2022-02-20 18:03:45,768 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {12068#true} {12069#false} #1212#return; {12069#false} is VALID [2022-02-20 18:03:45,769 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 70 [2022-02-20 18:03:45,770 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:45,772 INFO L290 TraceCheckUtils]: 0: Hoare triple {12068#true} ~handle := #in~handle;havoc ~retValue_acc~36; {12068#true} is VALID [2022-02-20 18:03:45,772 INFO L290 TraceCheckUtils]: 1: Hoare triple {12068#true} assume 1 == ~handle;~retValue_acc~36 := ~__ste_client_privateKey0~0;#res := ~retValue_acc~36; {12068#true} is VALID [2022-02-20 18:03:45,772 INFO L290 TraceCheckUtils]: 2: Hoare triple {12068#true} assume true; {12068#true} is VALID [2022-02-20 18:03:45,772 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {12068#true} {12069#false} #1150#return; {12069#false} is VALID [2022-02-20 18:03:45,773 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 78 [2022-02-20 18:03:45,774 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:45,776 INFO L290 TraceCheckUtils]: 0: Hoare triple {12068#true} ~handle := #in~handle;havoc ~retValue_acc~30; {12068#true} is VALID [2022-02-20 18:03:45,776 INFO L290 TraceCheckUtils]: 1: Hoare triple {12068#true} assume 1 == ~handle;~retValue_acc~30 := ~__ste_ClientAddressBook_size0~0;#res := ~retValue_acc~30; {12068#true} is VALID [2022-02-20 18:03:45,776 INFO L290 TraceCheckUtils]: 2: Hoare triple {12068#true} assume true; {12068#true} is VALID [2022-02-20 18:03:45,776 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {12068#true} {12069#false} #1152#return; {12069#false} is VALID [2022-02-20 18:03:45,776 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 87 [2022-02-20 18:03:45,777 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:45,779 INFO L290 TraceCheckUtils]: 0: Hoare triple {12068#true} ~handle := #in~handle;havoc ~retValue_acc~3; {12068#true} is VALID [2022-02-20 18:03:45,779 INFO L290 TraceCheckUtils]: 1: Hoare triple {12068#true} assume 1 == ~handle;~retValue_acc~3 := ~__ste_email_to0~0;#res := ~retValue_acc~3; {12068#true} is VALID [2022-02-20 18:03:45,779 INFO L290 TraceCheckUtils]: 2: Hoare triple {12068#true} assume true; {12068#true} is VALID [2022-02-20 18:03:45,780 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {12068#true} {12069#false} #1170#return; {12069#false} is VALID [2022-02-20 18:03:45,780 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 93 [2022-02-20 18:03:45,781 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:45,791 INFO L290 TraceCheckUtils]: 0: Hoare triple {12068#true} ~handle := #in~handle;~userid := #in~userid;havoc ~retValue_acc~41; {12068#true} is VALID [2022-02-20 18:03:45,791 INFO L290 TraceCheckUtils]: 1: Hoare triple {12068#true} assume 1 == ~handle; {12068#true} is VALID [2022-02-20 18:03:45,791 INFO L290 TraceCheckUtils]: 2: Hoare triple {12068#true} assume ~userid == ~__ste_Client_Keyring0_User0~0;~retValue_acc~41 := ~__ste_Client_Keyring0_PublicKey0~0;#res := ~retValue_acc~41; {12068#true} is VALID [2022-02-20 18:03:45,791 INFO L290 TraceCheckUtils]: 3: Hoare triple {12068#true} assume true; {12068#true} is VALID [2022-02-20 18:03:45,791 INFO L284 TraceCheckUtils]: 4: Hoare quadruple {12068#true} {12069#false} #1172#return; {12069#false} is VALID [2022-02-20 18:03:45,791 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 104 [2022-02-20 18:03:45,792 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:45,794 INFO L290 TraceCheckUtils]: 0: Hoare triple {12136#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} ~handle := #in~handle;~value := #in~value; {12068#true} is VALID [2022-02-20 18:03:45,794 INFO L290 TraceCheckUtils]: 1: Hoare triple {12068#true} assume 1 == ~handle;~__ste_email_from0~0 := ~value; {12068#true} is VALID [2022-02-20 18:03:45,794 INFO L290 TraceCheckUtils]: 2: Hoare triple {12068#true} assume true; {12068#true} is VALID [2022-02-20 18:03:45,794 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {12068#true} {12069#false} #1178#return; {12069#false} is VALID [2022-02-20 18:03:45,794 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 111 [2022-02-20 18:03:45,795 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:45,797 INFO L290 TraceCheckUtils]: 0: Hoare triple {12068#true} ~handle := #in~handle;havoc ~retValue_acc~6; {12068#true} is VALID [2022-02-20 18:03:45,798 INFO L290 TraceCheckUtils]: 1: Hoare triple {12068#true} assume 1 == ~handle;~retValue_acc~6 := ~__ste_email_isEncrypted0~0;#res := ~retValue_acc~6; {12068#true} is VALID [2022-02-20 18:03:45,798 INFO L290 TraceCheckUtils]: 2: Hoare triple {12068#true} assume true; {12068#true} is VALID [2022-02-20 18:03:45,798 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {12068#true} {12069#false} #1180#return; {12069#false} is VALID [2022-02-20 18:03:45,798 INFO L290 TraceCheckUtils]: 0: Hoare triple {12068#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(28, 2);call #Ultimate.allocInit(12, 3);call #Ultimate.allocInit(10, 4);call #Ultimate.allocInit(12, 5);call #Ultimate.allocInit(10, 6);call #Ultimate.allocInit(18, 7);call #Ultimate.allocInit(16, 8);call #Ultimate.allocInit(21, 9);call #Ultimate.allocInit(13, 10);call #Ultimate.allocInit(16, 11);call #Ultimate.allocInit(25, 12);call #Ultimate.allocInit(17, 13);call #Ultimate.allocInit(17, 14);call #Ultimate.allocInit(13, 15);call #Ultimate.allocInit(17, 16);call #Ultimate.allocInit(30, 17);call #Ultimate.allocInit(9, 18);call #Ultimate.allocInit(21, 19);call #Ultimate.allocInit(30, 20);call #Ultimate.allocInit(9, 21);call #Ultimate.allocInit(21, 22);call #Ultimate.allocInit(30, 23);call #Ultimate.allocInit(9, 24);call #Ultimate.allocInit(25, 25);call #Ultimate.allocInit(30, 26);call #Ultimate.allocInit(9, 27);call #Ultimate.allocInit(25, 28);call #Ultimate.allocInit(4, 29);call write~init~int(37, 29, 0, 1);call write~init~int(115, 29, 1, 1);call write~init~int(10, 29, 2, 1);call write~init~int(0, 29, 3, 1);call #Ultimate.allocInit(10, 30);call #Ultimate.allocInit(34, 31);call #Ultimate.allocInit(30, 32);call #Ultimate.allocInit(16, 33);call #Ultimate.allocInit(20, 34);call #Ultimate.allocInit(44, 35);call #Ultimate.allocInit(44, 36);call #Ultimate.allocInit(9, 37);call #Ultimate.allocInit(9, 38);call #Ultimate.allocInit(11, 39);call #Ultimate.allocInit(19, 40);call #Ultimate.allocInit(4, 41);call write~init~int(37, 41, 0, 1);call write~init~int(100, 41, 1, 1);call write~init~int(10, 41, 2, 1);call write~init~int(0, 41, 3, 1);call #Ultimate.allocInit(4, 42);call write~init~int(37, 42, 0, 1);call write~init~int(100, 42, 1, 1);call write~init~int(10, 42, 2, 1);call write~init~int(0, 42, 3, 1);~__ste_Email_counter~0 := 0;~__ste_email_id0~0 := 0;~__ste_email_id1~0 := 0;~__ste_email_from0~0 := 0;~__ste_email_from1~0 := 0;~__ste_email_to0~0 := 0;~__ste_email_to1~0 := 0;~__ste_email_subject0~0.base, ~__ste_email_subject0~0.offset := 0, 0;~__ste_email_subject1~0.base, ~__ste_email_subject1~0.offset := 0, 0;~__ste_email_body0~0.base, ~__ste_email_body0~0.offset := 0, 0;~__ste_email_body1~0.base, ~__ste_email_body1~0.offset := 0, 0;~__ste_email_isEncrypted0~0 := 0;~__ste_email_isEncrypted1~0 := 0;~__ste_email_encryptionKey0~0 := 0;~__ste_email_encryptionKey1~0 := 0;~__ste_email_isSigned0~0 := 0;~__ste_email_isSigned1~0 := 0;~__ste_email_signKey0~0 := 0;~__ste_email_signKey1~0 := 0;~__ste_email_isSignatureVerified0~0 := 0;~__ste_email_isSignatureVerified1~0 := 0;~__SELECTED_FEATURE_Base~0 := 0;~__SELECTED_FEATURE_Keys~0 := 0;~__SELECTED_FEATURE_Encrypt~0 := 0;~__SELECTED_FEATURE_AutoResponder~0 := 0;~__SELECTED_FEATURE_AddressBook~0 := 0;~__SELECTED_FEATURE_Sign~0 := 0;~__SELECTED_FEATURE_Forward~0 := 0;~__SELECTED_FEATURE_Verify~0 := 0;~__SELECTED_FEATURE_Decrypt~0 := 0;~__GUIDSL_ROOT_PRODUCTION~0 := 0;~__GUIDSL_NON_TERMINAL_main~0 := 0;~in_encrypted~0 := 0;~head~0.base, ~head~0.offset := 0, 0;~queue_empty~0 := 1;~queued_message~0 := 0;~queued_client~0 := 0;~bob~0 := 0;~rjh~0 := 0;~chuck~0 := 0;~__ste_Client_counter~0 := 0;~__ste_client_name0~0.base, ~__ste_client_name0~0.offset := 0, 0;~__ste_client_name1~0.base, ~__ste_client_name1~0.offset := 0, 0;~__ste_client_name2~0.base, ~__ste_client_name2~0.offset := 0, 0;~__ste_client_outbuffer0~0 := 0;~__ste_client_outbuffer1~0 := 0;~__ste_client_outbuffer2~0 := 0;~__ste_client_outbuffer3~0 := 0;~__ste_ClientAddressBook_size0~0 := 0;~__ste_ClientAddressBook_size1~0 := 0;~__ste_ClientAddressBook_size2~0 := 0;~__ste_Client_AddressBook0_Alias0~0 := 0;~__ste_Client_AddressBook0_Alias1~0 := 0;~__ste_Client_AddressBook0_Alias2~0 := 0;~__ste_Client_AddressBook1_Alias0~0 := 0;~__ste_Client_AddressBook1_Alias1~0 := 0;~__ste_Client_AddressBook1_Alias2~0 := 0;~__ste_Client_AddressBook2_Alias0~0 := 0;~__ste_Client_AddressBook2_Alias1~0 := 0;~__ste_Client_AddressBook2_Alias2~0 := 0;~__ste_Client_AddressBook0_Address0~0 := 0;~__ste_Client_AddressBook0_Address1~0 := 0;~__ste_Client_AddressBook0_Address2~0 := 0;~__ste_Client_AddressBook1_Address0~0 := 0;~__ste_Client_AddressBook1_Address1~0 := 0;~__ste_Client_AddressBook1_Address2~0 := 0;~__ste_Client_AddressBook2_Address0~0 := 0;~__ste_Client_AddressBook2_Address1~0 := 0;~__ste_Client_AddressBook2_Address2~0 := 0;~__ste_client_autoResponse0~0 := 0;~__ste_client_autoResponse1~0 := 0;~__ste_client_autoResponse2~0 := 0;~__ste_client_privateKey0~0 := 0;~__ste_client_privateKey1~0 := 0;~__ste_client_privateKey2~0 := 0;~__ste_ClientKeyring_size0~0 := 0;~__ste_ClientKeyring_size1~0 := 0;~__ste_ClientKeyring_size2~0 := 0;~__ste_Client_Keyring0_User0~0 := 0;~__ste_Client_Keyring0_User1~0 := 0;~__ste_Client_Keyring0_User2~0 := 0;~__ste_Client_Keyring1_User0~0 := 0;~__ste_Client_Keyring1_User1~0 := 0;~__ste_Client_Keyring1_User2~0 := 0;~__ste_Client_Keyring2_User0~0 := 0;~__ste_Client_Keyring2_User1~0 := 0;~__ste_Client_Keyring2_User2~0 := 0;~__ste_Client_Keyring0_PublicKey0~0 := 0;~__ste_Client_Keyring0_PublicKey1~0 := 0;~__ste_Client_Keyring0_PublicKey2~0 := 0;~__ste_Client_Keyring1_PublicKey0~0 := 0;~__ste_Client_Keyring1_PublicKey1~0 := 0;~__ste_Client_Keyring1_PublicKey2~0 := 0;~__ste_Client_Keyring2_PublicKey0~0 := 0;~__ste_Client_Keyring2_PublicKey1~0 := 0;~__ste_Client_Keyring2_PublicKey2~0 := 0;~__ste_client_forwardReceiver0~0 := 0;~__ste_client_forwardReceiver1~0 := 0;~__ste_client_forwardReceiver2~0 := 0;~__ste_client_forwardReceiver3~0 := 0;~__ste_client_idCounter0~0 := 0;~__ste_client_idCounter1~0 := 0;~__ste_client_idCounter2~0 := 0; {12068#true} is VALID [2022-02-20 18:03:45,798 INFO L290 TraceCheckUtils]: 1: Hoare triple {12068#true} assume { :end_inline_ULTIMATE.init } true;assume { :begin_inline_main } true;havoc main_#res#1;havoc main_#t~nondet100#1, main_#t~ret101#1, main_~retValue_acc~26#1, main_~tmp~20#1;assume -2147483648 <= main_#t~nondet100#1 && main_#t~nondet100#1 <= 2147483647;main_~retValue_acc~26#1 := main_#t~nondet100#1;havoc main_#t~nondet100#1;havoc main_~tmp~20#1;assume { :begin_inline_select_helpers } true; {12068#true} is VALID [2022-02-20 18:03:45,798 INFO L290 TraceCheckUtils]: 2: Hoare triple {12068#true} assume { :end_inline_select_helpers } true;assume { :begin_inline_select_features } true; {12068#true} is VALID [2022-02-20 18:03:45,798 INFO L290 TraceCheckUtils]: 3: Hoare triple {12068#true} assume { :end_inline_select_features } true;assume { :begin_inline_valid_product } true;havoc valid_product_#res#1;havoc valid_product_~retValue_acc~12#1;havoc valid_product_~retValue_acc~12#1;valid_product_~retValue_acc~12#1 := 1;valid_product_#res#1 := valid_product_~retValue_acc~12#1; {12068#true} is VALID [2022-02-20 18:03:45,799 INFO L290 TraceCheckUtils]: 4: Hoare triple {12068#true} main_#t~ret101#1 := valid_product_#res#1;assume { :end_inline_valid_product } true;assume -2147483648 <= main_#t~ret101#1 && main_#t~ret101#1 <= 2147483647;main_~tmp~20#1 := main_#t~ret101#1;havoc main_#t~ret101#1; {12068#true} is VALID [2022-02-20 18:03:45,799 INFO L290 TraceCheckUtils]: 5: Hoare triple {12068#true} assume 0 != main_~tmp~20#1;assume { :begin_inline_setup } true;havoc setup_#t~nondet97#1, setup_#t~nondet98#1, setup_#t~nondet99#1, setup_~__cil_tmp1~0#1.base, setup_~__cil_tmp1~0#1.offset, setup_~__cil_tmp2~1#1.base, setup_~__cil_tmp2~1#1.offset, setup_~__cil_tmp3~4#1.base, setup_~__cil_tmp3~4#1.offset;havoc setup_~__cil_tmp1~0#1.base, setup_~__cil_tmp1~0#1.offset;havoc setup_~__cil_tmp2~1#1.base, setup_~__cil_tmp2~1#1.offset;havoc setup_~__cil_tmp3~4#1.base, setup_~__cil_tmp3~4#1.offset;~bob~0 := 1;assume { :begin_inline_setup_bob } true;setup_bob_#in~bob___0#1 := ~bob~0;havoc setup_bob_~bob___0#1;setup_bob_~bob___0#1 := setup_bob_#in~bob___0#1;assume { :begin_inline_setup_bob__wrappee__Base } true;setup_bob__wrappee__Base_#in~bob___0#1 := setup_bob_~bob___0#1;havoc setup_bob__wrappee__Base_~bob___0#1;setup_bob__wrappee__Base_~bob___0#1 := setup_bob__wrappee__Base_#in~bob___0#1; {12068#true} is VALID [2022-02-20 18:03:45,799 INFO L272 TraceCheckUtils]: 6: Hoare triple {12068#true} call setClientId(setup_bob__wrappee__Base_~bob___0#1, setup_bob__wrappee__Base_~bob___0#1); {12130#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} is VALID [2022-02-20 18:03:45,799 INFO L290 TraceCheckUtils]: 7: Hoare triple {12130#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {12068#true} is VALID [2022-02-20 18:03:45,800 INFO L290 TraceCheckUtils]: 8: Hoare triple {12068#true} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {12068#true} is VALID [2022-02-20 18:03:45,800 INFO L290 TraceCheckUtils]: 9: Hoare triple {12068#true} assume true; {12068#true} is VALID [2022-02-20 18:03:45,800 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {12068#true} {12068#true} #1224#return; {12068#true} is VALID [2022-02-20 18:03:45,800 INFO L290 TraceCheckUtils]: 11: Hoare triple {12068#true} assume { :end_inline_setup_bob__wrappee__Base } true; {12068#true} is VALID [2022-02-20 18:03:45,800 INFO L272 TraceCheckUtils]: 12: Hoare triple {12068#true} call setClientPrivateKey(setup_bob_~bob___0#1, 123); {12131#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} is VALID [2022-02-20 18:03:45,800 INFO L290 TraceCheckUtils]: 13: Hoare triple {12131#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {12068#true} is VALID [2022-02-20 18:03:45,801 INFO L290 TraceCheckUtils]: 14: Hoare triple {12068#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {12068#true} is VALID [2022-02-20 18:03:45,801 INFO L290 TraceCheckUtils]: 15: Hoare triple {12068#true} assume true; {12068#true} is VALID [2022-02-20 18:03:45,801 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {12068#true} {12068#true} #1226#return; {12068#true} is VALID [2022-02-20 18:03:45,801 INFO L290 TraceCheckUtils]: 17: Hoare triple {12068#true} assume { :end_inline_setup_bob } true;setup_~__cil_tmp1~0#1.base, setup_~__cil_tmp1~0#1.offset := 37, 0;havoc setup_#t~nondet97#1;~rjh~0 := 2;assume { :begin_inline_setup_rjh } true;setup_rjh_#in~rjh___0#1 := ~rjh~0;havoc setup_rjh_~rjh___0#1;setup_rjh_~rjh___0#1 := setup_rjh_#in~rjh___0#1;assume { :begin_inline_setup_rjh__wrappee__Base } true;setup_rjh__wrappee__Base_#in~rjh___0#1 := setup_rjh_~rjh___0#1;havoc setup_rjh__wrappee__Base_~rjh___0#1;setup_rjh__wrappee__Base_~rjh___0#1 := setup_rjh__wrappee__Base_#in~rjh___0#1; {12078#(= |ULTIMATE.start_setup_rjh_~rjh___0#1| |ULTIMATE.start_setup_rjh__wrappee__Base_~rjh___0#1|)} is VALID [2022-02-20 18:03:45,802 INFO L272 TraceCheckUtils]: 18: Hoare triple {12078#(= |ULTIMATE.start_setup_rjh_~rjh___0#1| |ULTIMATE.start_setup_rjh__wrappee__Base_~rjh___0#1|)} call setClientId(setup_rjh__wrappee__Base_~rjh___0#1, setup_rjh__wrappee__Base_~rjh___0#1); {12130#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} is VALID [2022-02-20 18:03:45,802 INFO L290 TraceCheckUtils]: 19: Hoare triple {12130#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {12132#(= setClientId_~handle |setClientId_#in~handle|)} is VALID [2022-02-20 18:03:45,802 INFO L290 TraceCheckUtils]: 20: Hoare triple {12132#(= setClientId_~handle |setClientId_#in~handle|)} assume !(1 == ~handle); {12132#(= setClientId_~handle |setClientId_#in~handle|)} is VALID [2022-02-20 18:03:45,803 INFO L290 TraceCheckUtils]: 21: Hoare triple {12132#(= setClientId_~handle |setClientId_#in~handle|)} assume 2 == ~handle;~__ste_client_idCounter1~0 := ~value; {12133#(= 2 |setClientId_#in~handle|)} is VALID [2022-02-20 18:03:45,803 INFO L290 TraceCheckUtils]: 22: Hoare triple {12133#(= 2 |setClientId_#in~handle|)} assume true; {12133#(= 2 |setClientId_#in~handle|)} is VALID [2022-02-20 18:03:45,803 INFO L284 TraceCheckUtils]: 23: Hoare quadruple {12133#(= 2 |setClientId_#in~handle|)} {12078#(= |ULTIMATE.start_setup_rjh_~rjh___0#1| |ULTIMATE.start_setup_rjh__wrappee__Base_~rjh___0#1|)} #1228#return; {12084#(not (= |ULTIMATE.start_setup_rjh_~rjh___0#1| 1))} is VALID [2022-02-20 18:03:45,804 INFO L290 TraceCheckUtils]: 24: Hoare triple {12084#(not (= |ULTIMATE.start_setup_rjh_~rjh___0#1| 1))} assume { :end_inline_setup_rjh__wrappee__Base } true; {12084#(not (= |ULTIMATE.start_setup_rjh_~rjh___0#1| 1))} is VALID [2022-02-20 18:03:45,804 INFO L272 TraceCheckUtils]: 25: Hoare triple {12084#(not (= |ULTIMATE.start_setup_rjh_~rjh___0#1| 1))} call setClientPrivateKey(setup_rjh_~rjh___0#1, 456); {12131#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} is VALID [2022-02-20 18:03:45,804 INFO L290 TraceCheckUtils]: 26: Hoare triple {12131#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {12134#(= setClientPrivateKey_~handle |setClientPrivateKey_#in~handle|)} is VALID [2022-02-20 18:03:45,805 INFO L290 TraceCheckUtils]: 27: Hoare triple {12134#(= setClientPrivateKey_~handle |setClientPrivateKey_#in~handle|)} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {12135#(= |setClientPrivateKey_#in~handle| 1)} is VALID [2022-02-20 18:03:45,805 INFO L290 TraceCheckUtils]: 28: Hoare triple {12135#(= |setClientPrivateKey_#in~handle| 1)} assume true; {12135#(= |setClientPrivateKey_#in~handle| 1)} is VALID [2022-02-20 18:03:45,808 INFO L284 TraceCheckUtils]: 29: Hoare quadruple {12135#(= |setClientPrivateKey_#in~handle| 1)} {12084#(not (= |ULTIMATE.start_setup_rjh_~rjh___0#1| 1))} #1230#return; {12069#false} is VALID [2022-02-20 18:03:45,809 INFO L290 TraceCheckUtils]: 30: Hoare triple {12069#false} assume { :end_inline_setup_rjh } true;setup_~__cil_tmp2~1#1.base, setup_~__cil_tmp2~1#1.offset := 38, 0;havoc setup_#t~nondet98#1;~chuck~0 := 3;assume { :begin_inline_setup_chuck } true;setup_chuck_#in~chuck___0#1 := ~chuck~0;havoc setup_chuck_~chuck___0#1;setup_chuck_~chuck___0#1 := setup_chuck_#in~chuck___0#1;assume { :begin_inline_setup_chuck__wrappee__Base } true;setup_chuck__wrappee__Base_#in~chuck___0#1 := setup_chuck_~chuck___0#1;havoc setup_chuck__wrappee__Base_~chuck___0#1;setup_chuck__wrappee__Base_~chuck___0#1 := setup_chuck__wrappee__Base_#in~chuck___0#1; {12069#false} is VALID [2022-02-20 18:03:45,809 INFO L272 TraceCheckUtils]: 31: Hoare triple {12069#false} call setClientId(setup_chuck__wrappee__Base_~chuck___0#1, setup_chuck__wrappee__Base_~chuck___0#1); {12130#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} is VALID [2022-02-20 18:03:45,809 INFO L290 TraceCheckUtils]: 32: Hoare triple {12130#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {12068#true} is VALID [2022-02-20 18:03:45,809 INFO L290 TraceCheckUtils]: 33: Hoare triple {12068#true} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {12068#true} is VALID [2022-02-20 18:03:45,809 INFO L290 TraceCheckUtils]: 34: Hoare triple {12068#true} assume true; {12068#true} is VALID [2022-02-20 18:03:45,809 INFO L284 TraceCheckUtils]: 35: Hoare quadruple {12068#true} {12069#false} #1232#return; {12069#false} is VALID [2022-02-20 18:03:45,809 INFO L290 TraceCheckUtils]: 36: Hoare triple {12069#false} assume { :end_inline_setup_chuck__wrappee__Base } true; {12069#false} is VALID [2022-02-20 18:03:45,809 INFO L272 TraceCheckUtils]: 37: Hoare triple {12069#false} call setClientPrivateKey(setup_chuck_~chuck___0#1, 789); {12131#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} is VALID [2022-02-20 18:03:45,809 INFO L290 TraceCheckUtils]: 38: Hoare triple {12131#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {12068#true} is VALID [2022-02-20 18:03:45,810 INFO L290 TraceCheckUtils]: 39: Hoare triple {12068#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {12068#true} is VALID [2022-02-20 18:03:45,810 INFO L290 TraceCheckUtils]: 40: Hoare triple {12068#true} assume true; {12068#true} is VALID [2022-02-20 18:03:45,810 INFO L284 TraceCheckUtils]: 41: Hoare quadruple {12068#true} {12069#false} #1234#return; {12069#false} is VALID [2022-02-20 18:03:45,810 INFO L290 TraceCheckUtils]: 42: Hoare triple {12069#false} assume { :end_inline_setup_chuck } true;setup_~__cil_tmp3~4#1.base, setup_~__cil_tmp3~4#1.offset := 39, 0;havoc setup_#t~nondet99#1; {12069#false} is VALID [2022-02-20 18:03:45,810 INFO L290 TraceCheckUtils]: 43: Hoare triple {12069#false} assume { :end_inline_setup } true;assume { :begin_inline_test } true;havoc test_#t~nondet55#1, test_#t~nondet56#1, test_#t~nondet57#1, test_#t~nondet58#1, test_#t~nondet59#1, test_#t~nondet60#1, test_#t~nondet61#1, test_#t~nondet62#1, test_#t~nondet63#1, test_#t~nondet64#1, test_#t~nondet65#1, test_~op1~0#1, test_~op2~0#1, test_~op3~0#1, test_~op4~0#1, test_~op5~0#1, test_~op6~0#1, test_~op7~0#1, test_~op8~0#1, test_~op9~0#1, test_~op10~0#1, test_~op11~0#1, test_~splverifierCounter~0#1, test_~tmp~9#1, test_~tmp___0~3#1, test_~tmp___1~1#1, test_~tmp___2~1#1, test_~tmp___3~0#1, test_~tmp___4~0#1, test_~tmp___5~0#1, test_~tmp___6~0#1, test_~tmp___7~0#1, test_~tmp___8~0#1, test_~tmp___9~0#1;havoc test_~op1~0#1;havoc test_~op2~0#1;havoc test_~op3~0#1;havoc test_~op4~0#1;havoc test_~op5~0#1;havoc test_~op6~0#1;havoc test_~op7~0#1;havoc test_~op8~0#1;havoc test_~op9~0#1;havoc test_~op10~0#1;havoc test_~op11~0#1;havoc test_~splverifierCounter~0#1;havoc test_~tmp~9#1;havoc test_~tmp___0~3#1;havoc test_~tmp___1~1#1;havoc test_~tmp___2~1#1;havoc test_~tmp___3~0#1;havoc test_~tmp___4~0#1;havoc test_~tmp___5~0#1;havoc test_~tmp___6~0#1;havoc test_~tmp___7~0#1;havoc test_~tmp___8~0#1;havoc test_~tmp___9~0#1;test_~op1~0#1 := 0;test_~op2~0#1 := 0;test_~op3~0#1 := 0;test_~op4~0#1 := 0;test_~op5~0#1 := 0;test_~op6~0#1 := 0;test_~op7~0#1 := 0;test_~op8~0#1 := 0;test_~op9~0#1 := 0;test_~op10~0#1 := 0;test_~op11~0#1 := 0;test_~splverifierCounter~0#1 := 0; {12069#false} is VALID [2022-02-20 18:03:45,810 INFO L290 TraceCheckUtils]: 44: Hoare triple {12069#false} assume !false; {12069#false} is VALID [2022-02-20 18:03:45,810 INFO L290 TraceCheckUtils]: 45: Hoare triple {12069#false} assume test_~splverifierCounter~0#1 < 4; {12069#false} is VALID [2022-02-20 18:03:45,810 INFO L290 TraceCheckUtils]: 46: Hoare triple {12069#false} test_~splverifierCounter~0#1 := 1 + test_~splverifierCounter~0#1; {12069#false} is VALID [2022-02-20 18:03:45,810 INFO L290 TraceCheckUtils]: 47: Hoare triple {12069#false} assume 0 == test_~op1~0#1;assume -2147483648 <= test_#t~nondet55#1 && test_#t~nondet55#1 <= 2147483647;test_~tmp___9~0#1 := test_#t~nondet55#1;havoc test_#t~nondet55#1; {12069#false} is VALID [2022-02-20 18:03:45,811 INFO L290 TraceCheckUtils]: 48: Hoare triple {12069#false} assume !(0 != test_~tmp___9~0#1); {12069#false} is VALID [2022-02-20 18:03:45,811 INFO L290 TraceCheckUtils]: 49: Hoare triple {12069#false} assume 0 == test_~op2~0#1;assume -2147483648 <= test_#t~nondet56#1 && test_#t~nondet56#1 <= 2147483647;test_~tmp___8~0#1 := test_#t~nondet56#1;havoc test_#t~nondet56#1; {12069#false} is VALID [2022-02-20 18:03:45,811 INFO L290 TraceCheckUtils]: 50: Hoare triple {12069#false} assume 0 != test_~tmp___8~0#1;test_~op2~0#1 := 1; {12069#false} is VALID [2022-02-20 18:03:45,811 INFO L290 TraceCheckUtils]: 51: Hoare triple {12069#false} assume !false; {12069#false} is VALID [2022-02-20 18:03:45,811 INFO L290 TraceCheckUtils]: 52: Hoare triple {12069#false} assume !(test_~splverifierCounter~0#1 < 4); {12069#false} is VALID [2022-02-20 18:03:45,811 INFO L290 TraceCheckUtils]: 53: Hoare triple {12069#false} assume { :begin_inline_bobToRjh } true;havoc bobToRjh_#t~ret92#1, bobToRjh_#t~ret93#1, bobToRjh_#t~ret94#1, bobToRjh_#t~ret95#1, bobToRjh_~tmp~19#1, bobToRjh_~tmp___0~8#1, bobToRjh_~tmp___1~5#1;havoc bobToRjh_~tmp~19#1;havoc bobToRjh_~tmp___0~8#1;havoc bobToRjh_~tmp___1~5#1;call bobToRjh_#t~ret92#1 := puts(35, 0);assume -2147483648 <= bobToRjh_#t~ret92#1 && bobToRjh_#t~ret92#1 <= 2147483647;havoc bobToRjh_#t~ret92#1; {12069#false} is VALID [2022-02-20 18:03:45,811 INFO L272 TraceCheckUtils]: 54: Hoare triple {12069#false} call sendEmail(~bob~0, ~rjh~0); {12069#false} is VALID [2022-02-20 18:03:45,811 INFO L290 TraceCheckUtils]: 55: Hoare triple {12069#false} ~sender#1 := #in~sender#1;~receiver#1 := #in~receiver#1;havoc ~email~0#1;havoc ~tmp~16#1;assume { :begin_inline_createEmail } true;createEmail_#in~from#1, createEmail_#in~to#1 := 0, ~receiver#1;havoc createEmail_#res#1;havoc createEmail_~from#1, createEmail_~to#1, createEmail_~retValue_acc~16#1, createEmail_~msg~0#1;createEmail_~from#1 := createEmail_#in~from#1;createEmail_~to#1 := createEmail_#in~to#1;havoc createEmail_~retValue_acc~16#1;havoc createEmail_~msg~0#1;createEmail_~msg~0#1 := 1; {12069#false} is VALID [2022-02-20 18:03:45,811 INFO L272 TraceCheckUtils]: 56: Hoare triple {12069#false} call setEmailFrom(createEmail_~msg~0#1, createEmail_~from#1); {12136#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} is VALID [2022-02-20 18:03:45,812 INFO L290 TraceCheckUtils]: 57: Hoare triple {12136#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} ~handle := #in~handle;~value := #in~value; {12068#true} is VALID [2022-02-20 18:03:45,812 INFO L290 TraceCheckUtils]: 58: Hoare triple {12068#true} assume 1 == ~handle;~__ste_email_from0~0 := ~value; {12068#true} is VALID [2022-02-20 18:03:45,812 INFO L290 TraceCheckUtils]: 59: Hoare triple {12068#true} assume true; {12068#true} is VALID [2022-02-20 18:03:45,812 INFO L284 TraceCheckUtils]: 60: Hoare quadruple {12068#true} {12069#false} #1210#return; {12069#false} is VALID [2022-02-20 18:03:45,812 INFO L272 TraceCheckUtils]: 61: Hoare triple {12069#false} call setEmailTo(createEmail_~msg~0#1, createEmail_~to#1); {12137#(and (= ~__ste_email_to0~0 |old(~__ste_email_to0~0)|) (= ~__ste_email_to1~0 |old(~__ste_email_to1~0)|))} is VALID [2022-02-20 18:03:45,812 INFO L290 TraceCheckUtils]: 62: Hoare triple {12137#(and (= ~__ste_email_to0~0 |old(~__ste_email_to0~0)|) (= ~__ste_email_to1~0 |old(~__ste_email_to1~0)|))} ~handle := #in~handle;~value := #in~value; {12068#true} is VALID [2022-02-20 18:03:45,812 INFO L290 TraceCheckUtils]: 63: Hoare triple {12068#true} assume 1 == ~handle;~__ste_email_to0~0 := ~value; {12068#true} is VALID [2022-02-20 18:03:45,812 INFO L290 TraceCheckUtils]: 64: Hoare triple {12068#true} assume true; {12068#true} is VALID [2022-02-20 18:03:45,812 INFO L284 TraceCheckUtils]: 65: Hoare quadruple {12068#true} {12069#false} #1212#return; {12069#false} is VALID [2022-02-20 18:03:45,813 INFO L290 TraceCheckUtils]: 66: Hoare triple {12069#false} createEmail_~retValue_acc~16#1 := createEmail_~msg~0#1;createEmail_#res#1 := createEmail_~retValue_acc~16#1; {12069#false} is VALID [2022-02-20 18:03:45,813 INFO L290 TraceCheckUtils]: 67: Hoare triple {12069#false} #t~ret83#1 := createEmail_#res#1;assume { :end_inline_createEmail } true;assume -2147483648 <= #t~ret83#1 && #t~ret83#1 <= 2147483647;~tmp~16#1 := #t~ret83#1;havoc #t~ret83#1;~email~0#1 := ~tmp~16#1; {12069#false} is VALID [2022-02-20 18:03:45,813 INFO L272 TraceCheckUtils]: 68: Hoare triple {12069#false} call outgoing(~sender#1, ~email~0#1); {12069#false} is VALID [2022-02-20 18:03:45,813 INFO L290 TraceCheckUtils]: 69: Hoare triple {12069#false} ~client#1 := #in~client#1;~msg#1 := #in~msg#1;assume { :begin_inline_sign } true;sign_#in~client#1, sign_#in~msg#1 := ~client#1, ~msg#1;havoc sign_#t~ret85#1, sign_~client#1, sign_~msg#1, sign_~privkey~1#1, sign_~tmp~17#1;sign_~client#1 := sign_#in~client#1;sign_~msg#1 := sign_#in~msg#1;havoc sign_~privkey~1#1;havoc sign_~tmp~17#1; {12069#false} is VALID [2022-02-20 18:03:45,813 INFO L272 TraceCheckUtils]: 70: Hoare triple {12069#false} call sign_#t~ret85#1 := getClientPrivateKey(sign_~client#1); {12068#true} is VALID [2022-02-20 18:03:45,813 INFO L290 TraceCheckUtils]: 71: Hoare triple {12068#true} ~handle := #in~handle;havoc ~retValue_acc~36; {12068#true} is VALID [2022-02-20 18:03:45,813 INFO L290 TraceCheckUtils]: 72: Hoare triple {12068#true} assume 1 == ~handle;~retValue_acc~36 := ~__ste_client_privateKey0~0;#res := ~retValue_acc~36; {12068#true} is VALID [2022-02-20 18:03:45,813 INFO L290 TraceCheckUtils]: 73: Hoare triple {12068#true} assume true; {12068#true} is VALID [2022-02-20 18:03:45,813 INFO L284 TraceCheckUtils]: 74: Hoare quadruple {12068#true} {12069#false} #1150#return; {12069#false} is VALID [2022-02-20 18:03:45,814 INFO L290 TraceCheckUtils]: 75: Hoare triple {12069#false} assume -2147483648 <= sign_#t~ret85#1 && sign_#t~ret85#1 <= 2147483647;sign_~tmp~17#1 := sign_#t~ret85#1;havoc sign_#t~ret85#1;sign_~privkey~1#1 := sign_~tmp~17#1; {12069#false} is VALID [2022-02-20 18:03:45,814 INFO L290 TraceCheckUtils]: 76: Hoare triple {12069#false} assume 0 == sign_~privkey~1#1; {12069#false} is VALID [2022-02-20 18:03:45,814 INFO L290 TraceCheckUtils]: 77: Hoare triple {12069#false} assume { :end_inline_sign } true;assume { :begin_inline_outgoing__wrappee__AddressBook } true;outgoing__wrappee__AddressBook_#in~client#1, outgoing__wrappee__AddressBook_#in~msg#1 := ~client#1, ~msg#1;havoc outgoing__wrappee__AddressBook_#t~ret71#1, outgoing__wrappee__AddressBook_#t~ret72#1, outgoing__wrappee__AddressBook_#t~ret73#1, outgoing__wrappee__AddressBook_#t~ret74#1, outgoing__wrappee__AddressBook_#t~ret75#1, outgoing__wrappee__AddressBook_#t~ret76#1, outgoing__wrappee__AddressBook_~client#1, outgoing__wrappee__AddressBook_~msg#1, outgoing__wrappee__AddressBook_~size~0#1, outgoing__wrappee__AddressBook_~tmp~13#1, outgoing__wrappee__AddressBook_~receiver~1#1, outgoing__wrappee__AddressBook_~tmp___0~5#1, outgoing__wrappee__AddressBook_~second~0#1, outgoing__wrappee__AddressBook_~tmp___1~2#1, outgoing__wrappee__AddressBook_~tmp___2~2#1;outgoing__wrappee__AddressBook_~client#1 := outgoing__wrappee__AddressBook_#in~client#1;outgoing__wrappee__AddressBook_~msg#1 := outgoing__wrappee__AddressBook_#in~msg#1;havoc outgoing__wrappee__AddressBook_~size~0#1;havoc outgoing__wrappee__AddressBook_~tmp~13#1;havoc outgoing__wrappee__AddressBook_~receiver~1#1;havoc outgoing__wrappee__AddressBook_~tmp___0~5#1;havoc outgoing__wrappee__AddressBook_~second~0#1;havoc outgoing__wrappee__AddressBook_~tmp___1~2#1;havoc outgoing__wrappee__AddressBook_~tmp___2~2#1; {12069#false} is VALID [2022-02-20 18:03:45,814 INFO L272 TraceCheckUtils]: 78: Hoare triple {12069#false} call outgoing__wrappee__AddressBook_#t~ret71#1 := getClientAddressBookSize(outgoing__wrappee__AddressBook_~client#1); {12068#true} is VALID [2022-02-20 18:03:45,814 INFO L290 TraceCheckUtils]: 79: Hoare triple {12068#true} ~handle := #in~handle;havoc ~retValue_acc~30; {12068#true} is VALID [2022-02-20 18:03:45,814 INFO L290 TraceCheckUtils]: 80: Hoare triple {12068#true} assume 1 == ~handle;~retValue_acc~30 := ~__ste_ClientAddressBook_size0~0;#res := ~retValue_acc~30; {12068#true} is VALID [2022-02-20 18:03:45,814 INFO L290 TraceCheckUtils]: 81: Hoare triple {12068#true} assume true; {12068#true} is VALID [2022-02-20 18:03:45,814 INFO L284 TraceCheckUtils]: 82: Hoare quadruple {12068#true} {12069#false} #1152#return; {12069#false} is VALID [2022-02-20 18:03:45,814 INFO L290 TraceCheckUtils]: 83: Hoare triple {12069#false} assume -2147483648 <= outgoing__wrappee__AddressBook_#t~ret71#1 && outgoing__wrappee__AddressBook_#t~ret71#1 <= 2147483647;outgoing__wrappee__AddressBook_~tmp~13#1 := outgoing__wrappee__AddressBook_#t~ret71#1;havoc outgoing__wrappee__AddressBook_#t~ret71#1;outgoing__wrappee__AddressBook_~size~0#1 := outgoing__wrappee__AddressBook_~tmp~13#1; {12069#false} is VALID [2022-02-20 18:03:45,815 INFO L290 TraceCheckUtils]: 84: Hoare triple {12069#false} assume !(0 != outgoing__wrappee__AddressBook_~size~0#1); {12069#false} is VALID [2022-02-20 18:03:45,815 INFO L272 TraceCheckUtils]: 85: Hoare triple {12069#false} call outgoing__wrappee__Encrypt(outgoing__wrappee__AddressBook_~client#1, outgoing__wrappee__AddressBook_~msg#1); {12069#false} is VALID [2022-02-20 18:03:45,815 INFO L290 TraceCheckUtils]: 86: Hoare triple {12069#false} ~client#1 := #in~client#1;~msg#1 := #in~msg#1;havoc ~receiver~0#1;havoc ~tmp~12#1;havoc ~pubkey~0#1;havoc ~tmp___0~4#1; {12069#false} is VALID [2022-02-20 18:03:45,815 INFO L272 TraceCheckUtils]: 87: Hoare triple {12069#false} call #t~ret69#1 := getEmailTo(~msg#1); {12068#true} is VALID [2022-02-20 18:03:45,815 INFO L290 TraceCheckUtils]: 88: Hoare triple {12068#true} ~handle := #in~handle;havoc ~retValue_acc~3; {12068#true} is VALID [2022-02-20 18:03:45,815 INFO L290 TraceCheckUtils]: 89: Hoare triple {12068#true} assume 1 == ~handle;~retValue_acc~3 := ~__ste_email_to0~0;#res := ~retValue_acc~3; {12068#true} is VALID [2022-02-20 18:03:45,815 INFO L290 TraceCheckUtils]: 90: Hoare triple {12068#true} assume true; {12068#true} is VALID [2022-02-20 18:03:45,815 INFO L284 TraceCheckUtils]: 91: Hoare quadruple {12068#true} {12069#false} #1170#return; {12069#false} is VALID [2022-02-20 18:03:45,815 INFO L290 TraceCheckUtils]: 92: Hoare triple {12069#false} assume -2147483648 <= #t~ret69#1 && #t~ret69#1 <= 2147483647;~tmp~12#1 := #t~ret69#1;havoc #t~ret69#1;~receiver~0#1 := ~tmp~12#1; {12069#false} is VALID [2022-02-20 18:03:45,816 INFO L272 TraceCheckUtils]: 93: Hoare triple {12069#false} call #t~ret70#1 := findPublicKey(~client#1, ~receiver~0#1); {12068#true} is VALID [2022-02-20 18:03:45,816 INFO L290 TraceCheckUtils]: 94: Hoare triple {12068#true} ~handle := #in~handle;~userid := #in~userid;havoc ~retValue_acc~41; {12068#true} is VALID [2022-02-20 18:03:45,816 INFO L290 TraceCheckUtils]: 95: Hoare triple {12068#true} assume 1 == ~handle; {12068#true} is VALID [2022-02-20 18:03:45,816 INFO L290 TraceCheckUtils]: 96: Hoare triple {12068#true} assume ~userid == ~__ste_Client_Keyring0_User0~0;~retValue_acc~41 := ~__ste_Client_Keyring0_PublicKey0~0;#res := ~retValue_acc~41; {12068#true} is VALID [2022-02-20 18:03:45,816 INFO L290 TraceCheckUtils]: 97: Hoare triple {12068#true} assume true; {12068#true} is VALID [2022-02-20 18:03:45,816 INFO L284 TraceCheckUtils]: 98: Hoare quadruple {12068#true} {12069#false} #1172#return; {12069#false} is VALID [2022-02-20 18:03:45,816 INFO L290 TraceCheckUtils]: 99: Hoare triple {12069#false} assume -2147483648 <= #t~ret70#1 && #t~ret70#1 <= 2147483647;~tmp___0~4#1 := #t~ret70#1;havoc #t~ret70#1;~pubkey~0#1 := ~tmp___0~4#1; {12069#false} is VALID [2022-02-20 18:03:45,816 INFO L290 TraceCheckUtils]: 100: Hoare triple {12069#false} assume !(0 != ~pubkey~0#1); {12069#false} is VALID [2022-02-20 18:03:45,816 INFO L290 TraceCheckUtils]: 101: Hoare triple {12069#false} assume { :begin_inline_outgoing__wrappee__Keys } true;outgoing__wrappee__Keys_#in~client#1, outgoing__wrappee__Keys_#in~msg#1 := ~client#1, ~msg#1;havoc outgoing__wrappee__Keys_#t~ret68#1, outgoing__wrappee__Keys_~client#1, outgoing__wrappee__Keys_~msg#1, outgoing__wrappee__Keys_~tmp~11#1;outgoing__wrappee__Keys_~client#1 := outgoing__wrappee__Keys_#in~client#1;outgoing__wrappee__Keys_~msg#1 := outgoing__wrappee__Keys_#in~msg#1;havoc outgoing__wrappee__Keys_~tmp~11#1;assume { :begin_inline_getClientId } true;getClientId_#in~handle#1 := outgoing__wrappee__Keys_~client#1;havoc getClientId_#res#1;havoc getClientId_~handle#1, getClientId_~retValue_acc~43#1;getClientId_~handle#1 := getClientId_#in~handle#1;havoc getClientId_~retValue_acc~43#1; {12069#false} is VALID [2022-02-20 18:03:45,816 INFO L290 TraceCheckUtils]: 102: Hoare triple {12069#false} assume 1 == getClientId_~handle#1;getClientId_~retValue_acc~43#1 := ~__ste_client_idCounter0~0;getClientId_#res#1 := getClientId_~retValue_acc~43#1; {12069#false} is VALID [2022-02-20 18:03:45,817 INFO L290 TraceCheckUtils]: 103: Hoare triple {12069#false} outgoing__wrappee__Keys_#t~ret68#1 := getClientId_#res#1;assume { :end_inline_getClientId } true;assume -2147483648 <= outgoing__wrappee__Keys_#t~ret68#1 && outgoing__wrappee__Keys_#t~ret68#1 <= 2147483647;outgoing__wrappee__Keys_~tmp~11#1 := outgoing__wrappee__Keys_#t~ret68#1;havoc outgoing__wrappee__Keys_#t~ret68#1; {12069#false} is VALID [2022-02-20 18:03:45,817 INFO L272 TraceCheckUtils]: 104: Hoare triple {12069#false} call setEmailFrom(outgoing__wrappee__Keys_~msg#1, outgoing__wrappee__Keys_~tmp~11#1); {12136#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} is VALID [2022-02-20 18:03:45,817 INFO L290 TraceCheckUtils]: 105: Hoare triple {12136#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} ~handle := #in~handle;~value := #in~value; {12068#true} is VALID [2022-02-20 18:03:45,817 INFO L290 TraceCheckUtils]: 106: Hoare triple {12068#true} assume 1 == ~handle;~__ste_email_from0~0 := ~value; {12068#true} is VALID [2022-02-20 18:03:45,817 INFO L290 TraceCheckUtils]: 107: Hoare triple {12068#true} assume true; {12068#true} is VALID [2022-02-20 18:03:45,817 INFO L284 TraceCheckUtils]: 108: Hoare quadruple {12068#true} {12069#false} #1178#return; {12069#false} is VALID [2022-02-20 18:03:45,817 INFO L290 TraceCheckUtils]: 109: Hoare triple {12069#false} assume { :begin_inline_mail } true;mail_#in~client#1, mail_#in~msg#1 := outgoing__wrappee__Keys_~client#1, outgoing__wrappee__Keys_~msg#1;havoc mail_#t~ret66#1, mail_#t~ret67#1, mail_~client#1, mail_~msg#1, mail_~__utac__ad__arg1~0#1, mail_~tmp~10#1;mail_~client#1 := mail_#in~client#1;mail_~msg#1 := mail_#in~msg#1;havoc mail_~__utac__ad__arg1~0#1;havoc mail_~tmp~10#1;mail_~__utac__ad__arg1~0#1 := mail_~msg#1;assume { :begin_inline___utac_acc__EncryptAutoResponder_spec__2 } true;__utac_acc__EncryptAutoResponder_spec__2_#in~msg#1 := mail_~__utac__ad__arg1~0#1;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1, __utac_acc__EncryptAutoResponder_spec__2_#t~nondet29#1, __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1, __utac_acc__EncryptAutoResponder_spec__2_~msg#1, __utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.base, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.offset;__utac_acc__EncryptAutoResponder_spec__2_~msg#1 := __utac_acc__EncryptAutoResponder_spec__2_#in~msg#1;havoc __utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1;havoc __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.base, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.offset;call __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1 := puts(15, 0);assume -2147483648 <= __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1 && __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1 <= 2147483647;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1;__utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.base, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.offset := 16, 0;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~nondet29#1; {12069#false} is VALID [2022-02-20 18:03:45,817 INFO L290 TraceCheckUtils]: 110: Hoare triple {12069#false} assume 0 != ~in_encrypted~0; {12069#false} is VALID [2022-02-20 18:03:45,817 INFO L272 TraceCheckUtils]: 111: Hoare triple {12069#false} call __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1 := isEncrypted(__utac_acc__EncryptAutoResponder_spec__2_~msg#1); {12068#true} is VALID [2022-02-20 18:03:45,818 INFO L290 TraceCheckUtils]: 112: Hoare triple {12068#true} ~handle := #in~handle;havoc ~retValue_acc~6; {12068#true} is VALID [2022-02-20 18:03:45,818 INFO L290 TraceCheckUtils]: 113: Hoare triple {12068#true} assume 1 == ~handle;~retValue_acc~6 := ~__ste_email_isEncrypted0~0;#res := ~retValue_acc~6; {12068#true} is VALID [2022-02-20 18:03:45,818 INFO L290 TraceCheckUtils]: 114: Hoare triple {12068#true} assume true; {12068#true} is VALID [2022-02-20 18:03:45,818 INFO L284 TraceCheckUtils]: 115: Hoare quadruple {12068#true} {12069#false} #1180#return; {12069#false} is VALID [2022-02-20 18:03:45,818 INFO L290 TraceCheckUtils]: 116: Hoare triple {12069#false} assume -2147483648 <= __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1 && __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1 <= 2147483647;__utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1 := __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1; {12069#false} is VALID [2022-02-20 18:03:45,818 INFO L290 TraceCheckUtils]: 117: Hoare triple {12069#false} assume !(0 != __utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1);assume { :begin_inline___automaton_fail } true; {12069#false} is VALID [2022-02-20 18:03:45,818 INFO L290 TraceCheckUtils]: 118: Hoare triple {12069#false} assume !false; {12069#false} is VALID [2022-02-20 18:03:45,819 INFO L134 CoverageAnalysis]: Checked inductivity of 30 backedges. 6 proven. 6 refuted. 0 times theorem prover too weak. 18 trivial. 0 not checked. [2022-02-20 18:03:45,819 INFO L144 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-02-20 18:03:45,819 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [985324451] [2022-02-20 18:03:45,819 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleSmtInterpolCraig [985324451] provided 0 perfect and 1 imperfect interpolant sequences [2022-02-20 18:03:45,819 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [1368426072] [2022-02-20 18:03:45,819 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 18:03:45,819 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-02-20 18:03:45,820 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-02-20 18:03:45,836 INFO L229 MonitoredProcess]: Starting monitored process 6 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2022-02-20 18:03:45,836 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (6)] Waiting until timeout for monitored process [2022-02-20 18:03:46,028 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:46,031 INFO L263 TraceCheckSpWp]: Trace formula consists of 1133 conjuncts, 6 conjunts are in the unsatisfiable core [2022-02-20 18:03:46,077 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:46,078 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-02-20 18:03:46,394 INFO L290 TraceCheckUtils]: 0: Hoare triple {12068#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(28, 2);call #Ultimate.allocInit(12, 3);call #Ultimate.allocInit(10, 4);call #Ultimate.allocInit(12, 5);call #Ultimate.allocInit(10, 6);call #Ultimate.allocInit(18, 7);call #Ultimate.allocInit(16, 8);call #Ultimate.allocInit(21, 9);call #Ultimate.allocInit(13, 10);call #Ultimate.allocInit(16, 11);call #Ultimate.allocInit(25, 12);call #Ultimate.allocInit(17, 13);call #Ultimate.allocInit(17, 14);call #Ultimate.allocInit(13, 15);call #Ultimate.allocInit(17, 16);call #Ultimate.allocInit(30, 17);call #Ultimate.allocInit(9, 18);call #Ultimate.allocInit(21, 19);call #Ultimate.allocInit(30, 20);call #Ultimate.allocInit(9, 21);call #Ultimate.allocInit(21, 22);call #Ultimate.allocInit(30, 23);call #Ultimate.allocInit(9, 24);call #Ultimate.allocInit(25, 25);call #Ultimate.allocInit(30, 26);call #Ultimate.allocInit(9, 27);call #Ultimate.allocInit(25, 28);call #Ultimate.allocInit(4, 29);call write~init~int(37, 29, 0, 1);call write~init~int(115, 29, 1, 1);call write~init~int(10, 29, 2, 1);call write~init~int(0, 29, 3, 1);call #Ultimate.allocInit(10, 30);call #Ultimate.allocInit(34, 31);call #Ultimate.allocInit(30, 32);call #Ultimate.allocInit(16, 33);call #Ultimate.allocInit(20, 34);call #Ultimate.allocInit(44, 35);call #Ultimate.allocInit(44, 36);call #Ultimate.allocInit(9, 37);call #Ultimate.allocInit(9, 38);call #Ultimate.allocInit(11, 39);call #Ultimate.allocInit(19, 40);call #Ultimate.allocInit(4, 41);call write~init~int(37, 41, 0, 1);call write~init~int(100, 41, 1, 1);call write~init~int(10, 41, 2, 1);call write~init~int(0, 41, 3, 1);call #Ultimate.allocInit(4, 42);call write~init~int(37, 42, 0, 1);call write~init~int(100, 42, 1, 1);call write~init~int(10, 42, 2, 1);call write~init~int(0, 42, 3, 1);~__ste_Email_counter~0 := 0;~__ste_email_id0~0 := 0;~__ste_email_id1~0 := 0;~__ste_email_from0~0 := 0;~__ste_email_from1~0 := 0;~__ste_email_to0~0 := 0;~__ste_email_to1~0 := 0;~__ste_email_subject0~0.base, ~__ste_email_subject0~0.offset := 0, 0;~__ste_email_subject1~0.base, ~__ste_email_subject1~0.offset := 0, 0;~__ste_email_body0~0.base, ~__ste_email_body0~0.offset := 0, 0;~__ste_email_body1~0.base, ~__ste_email_body1~0.offset := 0, 0;~__ste_email_isEncrypted0~0 := 0;~__ste_email_isEncrypted1~0 := 0;~__ste_email_encryptionKey0~0 := 0;~__ste_email_encryptionKey1~0 := 0;~__ste_email_isSigned0~0 := 0;~__ste_email_isSigned1~0 := 0;~__ste_email_signKey0~0 := 0;~__ste_email_signKey1~0 := 0;~__ste_email_isSignatureVerified0~0 := 0;~__ste_email_isSignatureVerified1~0 := 0;~__SELECTED_FEATURE_Base~0 := 0;~__SELECTED_FEATURE_Keys~0 := 0;~__SELECTED_FEATURE_Encrypt~0 := 0;~__SELECTED_FEATURE_AutoResponder~0 := 0;~__SELECTED_FEATURE_AddressBook~0 := 0;~__SELECTED_FEATURE_Sign~0 := 0;~__SELECTED_FEATURE_Forward~0 := 0;~__SELECTED_FEATURE_Verify~0 := 0;~__SELECTED_FEATURE_Decrypt~0 := 0;~__GUIDSL_ROOT_PRODUCTION~0 := 0;~__GUIDSL_NON_TERMINAL_main~0 := 0;~in_encrypted~0 := 0;~head~0.base, ~head~0.offset := 0, 0;~queue_empty~0 := 1;~queued_message~0 := 0;~queued_client~0 := 0;~bob~0 := 0;~rjh~0 := 0;~chuck~0 := 0;~__ste_Client_counter~0 := 0;~__ste_client_name0~0.base, ~__ste_client_name0~0.offset := 0, 0;~__ste_client_name1~0.base, ~__ste_client_name1~0.offset := 0, 0;~__ste_client_name2~0.base, ~__ste_client_name2~0.offset := 0, 0;~__ste_client_outbuffer0~0 := 0;~__ste_client_outbuffer1~0 := 0;~__ste_client_outbuffer2~0 := 0;~__ste_client_outbuffer3~0 := 0;~__ste_ClientAddressBook_size0~0 := 0;~__ste_ClientAddressBook_size1~0 := 0;~__ste_ClientAddressBook_size2~0 := 0;~__ste_Client_AddressBook0_Alias0~0 := 0;~__ste_Client_AddressBook0_Alias1~0 := 0;~__ste_Client_AddressBook0_Alias2~0 := 0;~__ste_Client_AddressBook1_Alias0~0 := 0;~__ste_Client_AddressBook1_Alias1~0 := 0;~__ste_Client_AddressBook1_Alias2~0 := 0;~__ste_Client_AddressBook2_Alias0~0 := 0;~__ste_Client_AddressBook2_Alias1~0 := 0;~__ste_Client_AddressBook2_Alias2~0 := 0;~__ste_Client_AddressBook0_Address0~0 := 0;~__ste_Client_AddressBook0_Address1~0 := 0;~__ste_Client_AddressBook0_Address2~0 := 0;~__ste_Client_AddressBook1_Address0~0 := 0;~__ste_Client_AddressBook1_Address1~0 := 0;~__ste_Client_AddressBook1_Address2~0 := 0;~__ste_Client_AddressBook2_Address0~0 := 0;~__ste_Client_AddressBook2_Address1~0 := 0;~__ste_Client_AddressBook2_Address2~0 := 0;~__ste_client_autoResponse0~0 := 0;~__ste_client_autoResponse1~0 := 0;~__ste_client_autoResponse2~0 := 0;~__ste_client_privateKey0~0 := 0;~__ste_client_privateKey1~0 := 0;~__ste_client_privateKey2~0 := 0;~__ste_ClientKeyring_size0~0 := 0;~__ste_ClientKeyring_size1~0 := 0;~__ste_ClientKeyring_size2~0 := 0;~__ste_Client_Keyring0_User0~0 := 0;~__ste_Client_Keyring0_User1~0 := 0;~__ste_Client_Keyring0_User2~0 := 0;~__ste_Client_Keyring1_User0~0 := 0;~__ste_Client_Keyring1_User1~0 := 0;~__ste_Client_Keyring1_User2~0 := 0;~__ste_Client_Keyring2_User0~0 := 0;~__ste_Client_Keyring2_User1~0 := 0;~__ste_Client_Keyring2_User2~0 := 0;~__ste_Client_Keyring0_PublicKey0~0 := 0;~__ste_Client_Keyring0_PublicKey1~0 := 0;~__ste_Client_Keyring0_PublicKey2~0 := 0;~__ste_Client_Keyring1_PublicKey0~0 := 0;~__ste_Client_Keyring1_PublicKey1~0 := 0;~__ste_Client_Keyring1_PublicKey2~0 := 0;~__ste_Client_Keyring2_PublicKey0~0 := 0;~__ste_Client_Keyring2_PublicKey1~0 := 0;~__ste_Client_Keyring2_PublicKey2~0 := 0;~__ste_client_forwardReceiver0~0 := 0;~__ste_client_forwardReceiver1~0 := 0;~__ste_client_forwardReceiver2~0 := 0;~__ste_client_forwardReceiver3~0 := 0;~__ste_client_idCounter0~0 := 0;~__ste_client_idCounter1~0 := 0;~__ste_client_idCounter2~0 := 0; {12068#true} is VALID [2022-02-20 18:03:46,394 INFO L290 TraceCheckUtils]: 1: Hoare triple {12068#true} assume { :end_inline_ULTIMATE.init } true;assume { :begin_inline_main } true;havoc main_#res#1;havoc main_#t~nondet100#1, main_#t~ret101#1, main_~retValue_acc~26#1, main_~tmp~20#1;assume -2147483648 <= main_#t~nondet100#1 && main_#t~nondet100#1 <= 2147483647;main_~retValue_acc~26#1 := main_#t~nondet100#1;havoc main_#t~nondet100#1;havoc main_~tmp~20#1;assume { :begin_inline_select_helpers } true; {12068#true} is VALID [2022-02-20 18:03:46,394 INFO L290 TraceCheckUtils]: 2: Hoare triple {12068#true} assume { :end_inline_select_helpers } true;assume { :begin_inline_select_features } true; {12068#true} is VALID [2022-02-20 18:03:46,395 INFO L290 TraceCheckUtils]: 3: Hoare triple {12068#true} assume { :end_inline_select_features } true;assume { :begin_inline_valid_product } true;havoc valid_product_#res#1;havoc valid_product_~retValue_acc~12#1;havoc valid_product_~retValue_acc~12#1;valid_product_~retValue_acc~12#1 := 1;valid_product_#res#1 := valid_product_~retValue_acc~12#1; {12068#true} is VALID [2022-02-20 18:03:46,395 INFO L290 TraceCheckUtils]: 4: Hoare triple {12068#true} main_#t~ret101#1 := valid_product_#res#1;assume { :end_inline_valid_product } true;assume -2147483648 <= main_#t~ret101#1 && main_#t~ret101#1 <= 2147483647;main_~tmp~20#1 := main_#t~ret101#1;havoc main_#t~ret101#1; {12068#true} is VALID [2022-02-20 18:03:46,395 INFO L290 TraceCheckUtils]: 5: Hoare triple {12068#true} assume 0 != main_~tmp~20#1;assume { :begin_inline_setup } true;havoc setup_#t~nondet97#1, setup_#t~nondet98#1, setup_#t~nondet99#1, setup_~__cil_tmp1~0#1.base, setup_~__cil_tmp1~0#1.offset, setup_~__cil_tmp2~1#1.base, setup_~__cil_tmp2~1#1.offset, setup_~__cil_tmp3~4#1.base, setup_~__cil_tmp3~4#1.offset;havoc setup_~__cil_tmp1~0#1.base, setup_~__cil_tmp1~0#1.offset;havoc setup_~__cil_tmp2~1#1.base, setup_~__cil_tmp2~1#1.offset;havoc setup_~__cil_tmp3~4#1.base, setup_~__cil_tmp3~4#1.offset;~bob~0 := 1;assume { :begin_inline_setup_bob } true;setup_bob_#in~bob___0#1 := ~bob~0;havoc setup_bob_~bob___0#1;setup_bob_~bob___0#1 := setup_bob_#in~bob___0#1;assume { :begin_inline_setup_bob__wrappee__Base } true;setup_bob__wrappee__Base_#in~bob___0#1 := setup_bob_~bob___0#1;havoc setup_bob__wrappee__Base_~bob___0#1;setup_bob__wrappee__Base_~bob___0#1 := setup_bob__wrappee__Base_#in~bob___0#1; {12068#true} is VALID [2022-02-20 18:03:46,395 INFO L272 TraceCheckUtils]: 6: Hoare triple {12068#true} call setClientId(setup_bob__wrappee__Base_~bob___0#1, setup_bob__wrappee__Base_~bob___0#1); {12068#true} is VALID [2022-02-20 18:03:46,395 INFO L290 TraceCheckUtils]: 7: Hoare triple {12068#true} ~handle := #in~handle;~value := #in~value; {12068#true} is VALID [2022-02-20 18:03:46,395 INFO L290 TraceCheckUtils]: 8: Hoare triple {12068#true} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {12068#true} is VALID [2022-02-20 18:03:46,396 INFO L290 TraceCheckUtils]: 9: Hoare triple {12068#true} assume true; {12068#true} is VALID [2022-02-20 18:03:46,396 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {12068#true} {12068#true} #1224#return; {12068#true} is VALID [2022-02-20 18:03:46,396 INFO L290 TraceCheckUtils]: 11: Hoare triple {12068#true} assume { :end_inline_setup_bob__wrappee__Base } true; {12068#true} is VALID [2022-02-20 18:03:46,396 INFO L272 TraceCheckUtils]: 12: Hoare triple {12068#true} call setClientPrivateKey(setup_bob_~bob___0#1, 123); {12068#true} is VALID [2022-02-20 18:03:46,396 INFO L290 TraceCheckUtils]: 13: Hoare triple {12068#true} ~handle := #in~handle;~value := #in~value; {12068#true} is VALID [2022-02-20 18:03:46,396 INFO L290 TraceCheckUtils]: 14: Hoare triple {12068#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {12068#true} is VALID [2022-02-20 18:03:46,396 INFO L290 TraceCheckUtils]: 15: Hoare triple {12068#true} assume true; {12068#true} is VALID [2022-02-20 18:03:46,396 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {12068#true} {12068#true} #1226#return; {12068#true} is VALID [2022-02-20 18:03:46,399 INFO L290 TraceCheckUtils]: 17: Hoare triple {12068#true} assume { :end_inline_setup_bob } true;setup_~__cil_tmp1~0#1.base, setup_~__cil_tmp1~0#1.offset := 37, 0;havoc setup_#t~nondet97#1;~rjh~0 := 2;assume { :begin_inline_setup_rjh } true;setup_rjh_#in~rjh___0#1 := ~rjh~0;havoc setup_rjh_~rjh___0#1;setup_rjh_~rjh___0#1 := setup_rjh_#in~rjh___0#1;assume { :begin_inline_setup_rjh__wrappee__Base } true;setup_rjh__wrappee__Base_#in~rjh___0#1 := setup_rjh_~rjh___0#1;havoc setup_rjh__wrappee__Base_~rjh___0#1;setup_rjh__wrappee__Base_~rjh___0#1 := setup_rjh__wrappee__Base_#in~rjh___0#1; {12192#(<= 2 |ULTIMATE.start_setup_rjh_~rjh___0#1|)} is VALID [2022-02-20 18:03:46,400 INFO L272 TraceCheckUtils]: 18: Hoare triple {12192#(<= 2 |ULTIMATE.start_setup_rjh_~rjh___0#1|)} call setClientId(setup_rjh__wrappee__Base_~rjh___0#1, setup_rjh__wrappee__Base_~rjh___0#1); {12068#true} is VALID [2022-02-20 18:03:46,400 INFO L290 TraceCheckUtils]: 19: Hoare triple {12068#true} ~handle := #in~handle;~value := #in~value; {12068#true} is VALID [2022-02-20 18:03:46,400 INFO L290 TraceCheckUtils]: 20: Hoare triple {12068#true} assume !(1 == ~handle); {12068#true} is VALID [2022-02-20 18:03:46,400 INFO L290 TraceCheckUtils]: 21: Hoare triple {12068#true} assume 2 == ~handle;~__ste_client_idCounter1~0 := ~value; {12068#true} is VALID [2022-02-20 18:03:46,400 INFO L290 TraceCheckUtils]: 22: Hoare triple {12068#true} assume true; {12068#true} is VALID [2022-02-20 18:03:46,401 INFO L284 TraceCheckUtils]: 23: Hoare quadruple {12068#true} {12192#(<= 2 |ULTIMATE.start_setup_rjh_~rjh___0#1|)} #1228#return; {12192#(<= 2 |ULTIMATE.start_setup_rjh_~rjh___0#1|)} is VALID [2022-02-20 18:03:46,401 INFO L290 TraceCheckUtils]: 24: Hoare triple {12192#(<= 2 |ULTIMATE.start_setup_rjh_~rjh___0#1|)} assume { :end_inline_setup_rjh__wrappee__Base } true; {12192#(<= 2 |ULTIMATE.start_setup_rjh_~rjh___0#1|)} is VALID [2022-02-20 18:03:46,401 INFO L272 TraceCheckUtils]: 25: Hoare triple {12192#(<= 2 |ULTIMATE.start_setup_rjh_~rjh___0#1|)} call setClientPrivateKey(setup_rjh_~rjh___0#1, 456); {12068#true} is VALID [2022-02-20 18:03:46,401 INFO L290 TraceCheckUtils]: 26: Hoare triple {12068#true} ~handle := #in~handle;~value := #in~value; {12220#(<= |setClientPrivateKey_#in~handle| setClientPrivateKey_~handle)} is VALID [2022-02-20 18:03:46,402 INFO L290 TraceCheckUtils]: 27: Hoare triple {12220#(<= |setClientPrivateKey_#in~handle| setClientPrivateKey_~handle)} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {12224#(<= |setClientPrivateKey_#in~handle| 1)} is VALID [2022-02-20 18:03:46,402 INFO L290 TraceCheckUtils]: 28: Hoare triple {12224#(<= |setClientPrivateKey_#in~handle| 1)} assume true; {12224#(<= |setClientPrivateKey_#in~handle| 1)} is VALID [2022-02-20 18:03:46,403 INFO L284 TraceCheckUtils]: 29: Hoare quadruple {12224#(<= |setClientPrivateKey_#in~handle| 1)} {12192#(<= 2 |ULTIMATE.start_setup_rjh_~rjh___0#1|)} #1230#return; {12069#false} is VALID [2022-02-20 18:03:46,403 INFO L290 TraceCheckUtils]: 30: Hoare triple {12069#false} assume { :end_inline_setup_rjh } true;setup_~__cil_tmp2~1#1.base, setup_~__cil_tmp2~1#1.offset := 38, 0;havoc setup_#t~nondet98#1;~chuck~0 := 3;assume { :begin_inline_setup_chuck } true;setup_chuck_#in~chuck___0#1 := ~chuck~0;havoc setup_chuck_~chuck___0#1;setup_chuck_~chuck___0#1 := setup_chuck_#in~chuck___0#1;assume { :begin_inline_setup_chuck__wrappee__Base } true;setup_chuck__wrappee__Base_#in~chuck___0#1 := setup_chuck_~chuck___0#1;havoc setup_chuck__wrappee__Base_~chuck___0#1;setup_chuck__wrappee__Base_~chuck___0#1 := setup_chuck__wrappee__Base_#in~chuck___0#1; {12069#false} is VALID [2022-02-20 18:03:46,403 INFO L272 TraceCheckUtils]: 31: Hoare triple {12069#false} call setClientId(setup_chuck__wrappee__Base_~chuck___0#1, setup_chuck__wrappee__Base_~chuck___0#1); {12069#false} is VALID [2022-02-20 18:03:46,403 INFO L290 TraceCheckUtils]: 32: Hoare triple {12069#false} ~handle := #in~handle;~value := #in~value; {12069#false} is VALID [2022-02-20 18:03:46,403 INFO L290 TraceCheckUtils]: 33: Hoare triple {12069#false} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {12069#false} is VALID [2022-02-20 18:03:46,403 INFO L290 TraceCheckUtils]: 34: Hoare triple {12069#false} assume true; {12069#false} is VALID [2022-02-20 18:03:46,403 INFO L284 TraceCheckUtils]: 35: Hoare quadruple {12069#false} {12069#false} #1232#return; {12069#false} is VALID [2022-02-20 18:03:46,403 INFO L290 TraceCheckUtils]: 36: Hoare triple {12069#false} assume { :end_inline_setup_chuck__wrappee__Base } true; {12069#false} is VALID [2022-02-20 18:03:46,403 INFO L272 TraceCheckUtils]: 37: Hoare triple {12069#false} call setClientPrivateKey(setup_chuck_~chuck___0#1, 789); {12069#false} is VALID [2022-02-20 18:03:46,403 INFO L290 TraceCheckUtils]: 38: Hoare triple {12069#false} ~handle := #in~handle;~value := #in~value; {12069#false} is VALID [2022-02-20 18:03:46,403 INFO L290 TraceCheckUtils]: 39: Hoare triple {12069#false} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {12069#false} is VALID [2022-02-20 18:03:46,403 INFO L290 TraceCheckUtils]: 40: Hoare triple {12069#false} assume true; {12069#false} is VALID [2022-02-20 18:03:46,403 INFO L284 TraceCheckUtils]: 41: Hoare quadruple {12069#false} {12069#false} #1234#return; {12069#false} is VALID [2022-02-20 18:03:46,403 INFO L290 TraceCheckUtils]: 42: Hoare triple {12069#false} assume { :end_inline_setup_chuck } true;setup_~__cil_tmp3~4#1.base, setup_~__cil_tmp3~4#1.offset := 39, 0;havoc setup_#t~nondet99#1; {12069#false} is VALID [2022-02-20 18:03:46,403 INFO L290 TraceCheckUtils]: 43: Hoare triple {12069#false} assume { :end_inline_setup } true;assume { :begin_inline_test } true;havoc test_#t~nondet55#1, test_#t~nondet56#1, test_#t~nondet57#1, test_#t~nondet58#1, test_#t~nondet59#1, test_#t~nondet60#1, test_#t~nondet61#1, test_#t~nondet62#1, test_#t~nondet63#1, test_#t~nondet64#1, test_#t~nondet65#1, test_~op1~0#1, test_~op2~0#1, test_~op3~0#1, test_~op4~0#1, test_~op5~0#1, test_~op6~0#1, test_~op7~0#1, test_~op8~0#1, test_~op9~0#1, test_~op10~0#1, test_~op11~0#1, test_~splverifierCounter~0#1, test_~tmp~9#1, test_~tmp___0~3#1, test_~tmp___1~1#1, test_~tmp___2~1#1, test_~tmp___3~0#1, test_~tmp___4~0#1, test_~tmp___5~0#1, test_~tmp___6~0#1, test_~tmp___7~0#1, test_~tmp___8~0#1, test_~tmp___9~0#1;havoc test_~op1~0#1;havoc test_~op2~0#1;havoc test_~op3~0#1;havoc test_~op4~0#1;havoc test_~op5~0#1;havoc test_~op6~0#1;havoc test_~op7~0#1;havoc test_~op8~0#1;havoc test_~op9~0#1;havoc test_~op10~0#1;havoc test_~op11~0#1;havoc test_~splverifierCounter~0#1;havoc test_~tmp~9#1;havoc test_~tmp___0~3#1;havoc test_~tmp___1~1#1;havoc test_~tmp___2~1#1;havoc test_~tmp___3~0#1;havoc test_~tmp___4~0#1;havoc test_~tmp___5~0#1;havoc test_~tmp___6~0#1;havoc test_~tmp___7~0#1;havoc test_~tmp___8~0#1;havoc test_~tmp___9~0#1;test_~op1~0#1 := 0;test_~op2~0#1 := 0;test_~op3~0#1 := 0;test_~op4~0#1 := 0;test_~op5~0#1 := 0;test_~op6~0#1 := 0;test_~op7~0#1 := 0;test_~op8~0#1 := 0;test_~op9~0#1 := 0;test_~op10~0#1 := 0;test_~op11~0#1 := 0;test_~splverifierCounter~0#1 := 0; {12069#false} is VALID [2022-02-20 18:03:46,403 INFO L290 TraceCheckUtils]: 44: Hoare triple {12069#false} assume !false; {12069#false} is VALID [2022-02-20 18:03:46,404 INFO L290 TraceCheckUtils]: 45: Hoare triple {12069#false} assume test_~splverifierCounter~0#1 < 4; {12069#false} is VALID [2022-02-20 18:03:46,404 INFO L290 TraceCheckUtils]: 46: Hoare triple {12069#false} test_~splverifierCounter~0#1 := 1 + test_~splverifierCounter~0#1; {12069#false} is VALID [2022-02-20 18:03:46,404 INFO L290 TraceCheckUtils]: 47: Hoare triple {12069#false} assume 0 == test_~op1~0#1;assume -2147483648 <= test_#t~nondet55#1 && test_#t~nondet55#1 <= 2147483647;test_~tmp___9~0#1 := test_#t~nondet55#1;havoc test_#t~nondet55#1; {12069#false} is VALID [2022-02-20 18:03:46,404 INFO L290 TraceCheckUtils]: 48: Hoare triple {12069#false} assume !(0 != test_~tmp___9~0#1); {12069#false} is VALID [2022-02-20 18:03:46,404 INFO L290 TraceCheckUtils]: 49: Hoare triple {12069#false} assume 0 == test_~op2~0#1;assume -2147483648 <= test_#t~nondet56#1 && test_#t~nondet56#1 <= 2147483647;test_~tmp___8~0#1 := test_#t~nondet56#1;havoc test_#t~nondet56#1; {12069#false} is VALID [2022-02-20 18:03:46,404 INFO L290 TraceCheckUtils]: 50: Hoare triple {12069#false} assume 0 != test_~tmp___8~0#1;test_~op2~0#1 := 1; {12069#false} is VALID [2022-02-20 18:03:46,404 INFO L290 TraceCheckUtils]: 51: Hoare triple {12069#false} assume !false; {12069#false} is VALID [2022-02-20 18:03:46,404 INFO L290 TraceCheckUtils]: 52: Hoare triple {12069#false} assume !(test_~splverifierCounter~0#1 < 4); {12069#false} is VALID [2022-02-20 18:03:46,404 INFO L290 TraceCheckUtils]: 53: Hoare triple {12069#false} assume { :begin_inline_bobToRjh } true;havoc bobToRjh_#t~ret92#1, bobToRjh_#t~ret93#1, bobToRjh_#t~ret94#1, bobToRjh_#t~ret95#1, bobToRjh_~tmp~19#1, bobToRjh_~tmp___0~8#1, bobToRjh_~tmp___1~5#1;havoc bobToRjh_~tmp~19#1;havoc bobToRjh_~tmp___0~8#1;havoc bobToRjh_~tmp___1~5#1;call bobToRjh_#t~ret92#1 := puts(35, 0);assume -2147483648 <= bobToRjh_#t~ret92#1 && bobToRjh_#t~ret92#1 <= 2147483647;havoc bobToRjh_#t~ret92#1; {12069#false} is VALID [2022-02-20 18:03:46,404 INFO L272 TraceCheckUtils]: 54: Hoare triple {12069#false} call sendEmail(~bob~0, ~rjh~0); {12069#false} is VALID [2022-02-20 18:03:46,404 INFO L290 TraceCheckUtils]: 55: Hoare triple {12069#false} ~sender#1 := #in~sender#1;~receiver#1 := #in~receiver#1;havoc ~email~0#1;havoc ~tmp~16#1;assume { :begin_inline_createEmail } true;createEmail_#in~from#1, createEmail_#in~to#1 := 0, ~receiver#1;havoc createEmail_#res#1;havoc createEmail_~from#1, createEmail_~to#1, createEmail_~retValue_acc~16#1, createEmail_~msg~0#1;createEmail_~from#1 := createEmail_#in~from#1;createEmail_~to#1 := createEmail_#in~to#1;havoc createEmail_~retValue_acc~16#1;havoc createEmail_~msg~0#1;createEmail_~msg~0#1 := 1; {12069#false} is VALID [2022-02-20 18:03:46,404 INFO L272 TraceCheckUtils]: 56: Hoare triple {12069#false} call setEmailFrom(createEmail_~msg~0#1, createEmail_~from#1); {12069#false} is VALID [2022-02-20 18:03:46,404 INFO L290 TraceCheckUtils]: 57: Hoare triple {12069#false} ~handle := #in~handle;~value := #in~value; {12069#false} is VALID [2022-02-20 18:03:46,404 INFO L290 TraceCheckUtils]: 58: Hoare triple {12069#false} assume 1 == ~handle;~__ste_email_from0~0 := ~value; {12069#false} is VALID [2022-02-20 18:03:46,404 INFO L290 TraceCheckUtils]: 59: Hoare triple {12069#false} assume true; {12069#false} is VALID [2022-02-20 18:03:46,404 INFO L284 TraceCheckUtils]: 60: Hoare quadruple {12069#false} {12069#false} #1210#return; {12069#false} is VALID [2022-02-20 18:03:46,404 INFO L272 TraceCheckUtils]: 61: Hoare triple {12069#false} call setEmailTo(createEmail_~msg~0#1, createEmail_~to#1); {12069#false} is VALID [2022-02-20 18:03:46,405 INFO L290 TraceCheckUtils]: 62: Hoare triple {12069#false} ~handle := #in~handle;~value := #in~value; {12069#false} is VALID [2022-02-20 18:03:46,405 INFO L290 TraceCheckUtils]: 63: Hoare triple {12069#false} assume 1 == ~handle;~__ste_email_to0~0 := ~value; {12069#false} is VALID [2022-02-20 18:03:46,405 INFO L290 TraceCheckUtils]: 64: Hoare triple {12069#false} assume true; {12069#false} is VALID [2022-02-20 18:03:46,405 INFO L284 TraceCheckUtils]: 65: Hoare quadruple {12069#false} {12069#false} #1212#return; {12069#false} is VALID [2022-02-20 18:03:46,405 INFO L290 TraceCheckUtils]: 66: Hoare triple {12069#false} createEmail_~retValue_acc~16#1 := createEmail_~msg~0#1;createEmail_#res#1 := createEmail_~retValue_acc~16#1; {12069#false} is VALID [2022-02-20 18:03:46,405 INFO L290 TraceCheckUtils]: 67: Hoare triple {12069#false} #t~ret83#1 := createEmail_#res#1;assume { :end_inline_createEmail } true;assume -2147483648 <= #t~ret83#1 && #t~ret83#1 <= 2147483647;~tmp~16#1 := #t~ret83#1;havoc #t~ret83#1;~email~0#1 := ~tmp~16#1; {12069#false} is VALID [2022-02-20 18:03:46,405 INFO L272 TraceCheckUtils]: 68: Hoare triple {12069#false} call outgoing(~sender#1, ~email~0#1); {12069#false} is VALID [2022-02-20 18:03:46,405 INFO L290 TraceCheckUtils]: 69: Hoare triple {12069#false} ~client#1 := #in~client#1;~msg#1 := #in~msg#1;assume { :begin_inline_sign } true;sign_#in~client#1, sign_#in~msg#1 := ~client#1, ~msg#1;havoc sign_#t~ret85#1, sign_~client#1, sign_~msg#1, sign_~privkey~1#1, sign_~tmp~17#1;sign_~client#1 := sign_#in~client#1;sign_~msg#1 := sign_#in~msg#1;havoc sign_~privkey~1#1;havoc sign_~tmp~17#1; {12069#false} is VALID [2022-02-20 18:03:46,405 INFO L272 TraceCheckUtils]: 70: Hoare triple {12069#false} call sign_#t~ret85#1 := getClientPrivateKey(sign_~client#1); {12069#false} is VALID [2022-02-20 18:03:46,405 INFO L290 TraceCheckUtils]: 71: Hoare triple {12069#false} ~handle := #in~handle;havoc ~retValue_acc~36; {12069#false} is VALID [2022-02-20 18:03:46,405 INFO L290 TraceCheckUtils]: 72: Hoare triple {12069#false} assume 1 == ~handle;~retValue_acc~36 := ~__ste_client_privateKey0~0;#res := ~retValue_acc~36; {12069#false} is VALID [2022-02-20 18:03:46,405 INFO L290 TraceCheckUtils]: 73: Hoare triple {12069#false} assume true; {12069#false} is VALID [2022-02-20 18:03:46,405 INFO L284 TraceCheckUtils]: 74: Hoare quadruple {12069#false} {12069#false} #1150#return; {12069#false} is VALID [2022-02-20 18:03:46,405 INFO L290 TraceCheckUtils]: 75: Hoare triple {12069#false} assume -2147483648 <= sign_#t~ret85#1 && sign_#t~ret85#1 <= 2147483647;sign_~tmp~17#1 := sign_#t~ret85#1;havoc sign_#t~ret85#1;sign_~privkey~1#1 := sign_~tmp~17#1; {12069#false} is VALID [2022-02-20 18:03:46,406 INFO L290 TraceCheckUtils]: 76: Hoare triple {12069#false} assume 0 == sign_~privkey~1#1; {12069#false} is VALID [2022-02-20 18:03:46,406 INFO L290 TraceCheckUtils]: 77: Hoare triple {12069#false} assume { :end_inline_sign } true;assume { :begin_inline_outgoing__wrappee__AddressBook } true;outgoing__wrappee__AddressBook_#in~client#1, outgoing__wrappee__AddressBook_#in~msg#1 := ~client#1, ~msg#1;havoc outgoing__wrappee__AddressBook_#t~ret71#1, outgoing__wrappee__AddressBook_#t~ret72#1, outgoing__wrappee__AddressBook_#t~ret73#1, outgoing__wrappee__AddressBook_#t~ret74#1, outgoing__wrappee__AddressBook_#t~ret75#1, outgoing__wrappee__AddressBook_#t~ret76#1, outgoing__wrappee__AddressBook_~client#1, outgoing__wrappee__AddressBook_~msg#1, outgoing__wrappee__AddressBook_~size~0#1, outgoing__wrappee__AddressBook_~tmp~13#1, outgoing__wrappee__AddressBook_~receiver~1#1, outgoing__wrappee__AddressBook_~tmp___0~5#1, outgoing__wrappee__AddressBook_~second~0#1, outgoing__wrappee__AddressBook_~tmp___1~2#1, outgoing__wrappee__AddressBook_~tmp___2~2#1;outgoing__wrappee__AddressBook_~client#1 := outgoing__wrappee__AddressBook_#in~client#1;outgoing__wrappee__AddressBook_~msg#1 := outgoing__wrappee__AddressBook_#in~msg#1;havoc outgoing__wrappee__AddressBook_~size~0#1;havoc outgoing__wrappee__AddressBook_~tmp~13#1;havoc outgoing__wrappee__AddressBook_~receiver~1#1;havoc outgoing__wrappee__AddressBook_~tmp___0~5#1;havoc outgoing__wrappee__AddressBook_~second~0#1;havoc outgoing__wrappee__AddressBook_~tmp___1~2#1;havoc outgoing__wrappee__AddressBook_~tmp___2~2#1; {12069#false} is VALID [2022-02-20 18:03:46,406 INFO L272 TraceCheckUtils]: 78: Hoare triple {12069#false} call outgoing__wrappee__AddressBook_#t~ret71#1 := getClientAddressBookSize(outgoing__wrappee__AddressBook_~client#1); {12069#false} is VALID [2022-02-20 18:03:46,406 INFO L290 TraceCheckUtils]: 79: Hoare triple {12069#false} ~handle := #in~handle;havoc ~retValue_acc~30; {12069#false} is VALID [2022-02-20 18:03:46,406 INFO L290 TraceCheckUtils]: 80: Hoare triple {12069#false} assume 1 == ~handle;~retValue_acc~30 := ~__ste_ClientAddressBook_size0~0;#res := ~retValue_acc~30; {12069#false} is VALID [2022-02-20 18:03:46,406 INFO L290 TraceCheckUtils]: 81: Hoare triple {12069#false} assume true; {12069#false} is VALID [2022-02-20 18:03:46,406 INFO L284 TraceCheckUtils]: 82: Hoare quadruple {12069#false} {12069#false} #1152#return; {12069#false} is VALID [2022-02-20 18:03:46,406 INFO L290 TraceCheckUtils]: 83: Hoare triple {12069#false} assume -2147483648 <= outgoing__wrappee__AddressBook_#t~ret71#1 && outgoing__wrappee__AddressBook_#t~ret71#1 <= 2147483647;outgoing__wrappee__AddressBook_~tmp~13#1 := outgoing__wrappee__AddressBook_#t~ret71#1;havoc outgoing__wrappee__AddressBook_#t~ret71#1;outgoing__wrappee__AddressBook_~size~0#1 := outgoing__wrappee__AddressBook_~tmp~13#1; {12069#false} is VALID [2022-02-20 18:03:46,406 INFO L290 TraceCheckUtils]: 84: Hoare triple {12069#false} assume !(0 != outgoing__wrappee__AddressBook_~size~0#1); {12069#false} is VALID [2022-02-20 18:03:46,406 INFO L272 TraceCheckUtils]: 85: Hoare triple {12069#false} call outgoing__wrappee__Encrypt(outgoing__wrappee__AddressBook_~client#1, outgoing__wrappee__AddressBook_~msg#1); {12069#false} is VALID [2022-02-20 18:03:46,406 INFO L290 TraceCheckUtils]: 86: Hoare triple {12069#false} ~client#1 := #in~client#1;~msg#1 := #in~msg#1;havoc ~receiver~0#1;havoc ~tmp~12#1;havoc ~pubkey~0#1;havoc ~tmp___0~4#1; {12069#false} is VALID [2022-02-20 18:03:46,406 INFO L272 TraceCheckUtils]: 87: Hoare triple {12069#false} call #t~ret69#1 := getEmailTo(~msg#1); {12069#false} is VALID [2022-02-20 18:03:46,406 INFO L290 TraceCheckUtils]: 88: Hoare triple {12069#false} ~handle := #in~handle;havoc ~retValue_acc~3; {12069#false} is VALID [2022-02-20 18:03:46,406 INFO L290 TraceCheckUtils]: 89: Hoare triple {12069#false} assume 1 == ~handle;~retValue_acc~3 := ~__ste_email_to0~0;#res := ~retValue_acc~3; {12069#false} is VALID [2022-02-20 18:03:46,406 INFO L290 TraceCheckUtils]: 90: Hoare triple {12069#false} assume true; {12069#false} is VALID [2022-02-20 18:03:46,406 INFO L284 TraceCheckUtils]: 91: Hoare quadruple {12069#false} {12069#false} #1170#return; {12069#false} is VALID [2022-02-20 18:03:46,406 INFO L290 TraceCheckUtils]: 92: Hoare triple {12069#false} assume -2147483648 <= #t~ret69#1 && #t~ret69#1 <= 2147483647;~tmp~12#1 := #t~ret69#1;havoc #t~ret69#1;~receiver~0#1 := ~tmp~12#1; {12069#false} is VALID [2022-02-20 18:03:46,407 INFO L272 TraceCheckUtils]: 93: Hoare triple {12069#false} call #t~ret70#1 := findPublicKey(~client#1, ~receiver~0#1); {12069#false} is VALID [2022-02-20 18:03:46,407 INFO L290 TraceCheckUtils]: 94: Hoare triple {12069#false} ~handle := #in~handle;~userid := #in~userid;havoc ~retValue_acc~41; {12069#false} is VALID [2022-02-20 18:03:46,407 INFO L290 TraceCheckUtils]: 95: Hoare triple {12069#false} assume 1 == ~handle; {12069#false} is VALID [2022-02-20 18:03:46,407 INFO L290 TraceCheckUtils]: 96: Hoare triple {12069#false} assume ~userid == ~__ste_Client_Keyring0_User0~0;~retValue_acc~41 := ~__ste_Client_Keyring0_PublicKey0~0;#res := ~retValue_acc~41; {12069#false} is VALID [2022-02-20 18:03:46,407 INFO L290 TraceCheckUtils]: 97: Hoare triple {12069#false} assume true; {12069#false} is VALID [2022-02-20 18:03:46,407 INFO L284 TraceCheckUtils]: 98: Hoare quadruple {12069#false} {12069#false} #1172#return; {12069#false} is VALID [2022-02-20 18:03:46,407 INFO L290 TraceCheckUtils]: 99: Hoare triple {12069#false} assume -2147483648 <= #t~ret70#1 && #t~ret70#1 <= 2147483647;~tmp___0~4#1 := #t~ret70#1;havoc #t~ret70#1;~pubkey~0#1 := ~tmp___0~4#1; {12069#false} is VALID [2022-02-20 18:03:46,407 INFO L290 TraceCheckUtils]: 100: Hoare triple {12069#false} assume !(0 != ~pubkey~0#1); {12069#false} is VALID [2022-02-20 18:03:46,407 INFO L290 TraceCheckUtils]: 101: Hoare triple {12069#false} assume { :begin_inline_outgoing__wrappee__Keys } true;outgoing__wrappee__Keys_#in~client#1, outgoing__wrappee__Keys_#in~msg#1 := ~client#1, ~msg#1;havoc outgoing__wrappee__Keys_#t~ret68#1, outgoing__wrappee__Keys_~client#1, outgoing__wrappee__Keys_~msg#1, outgoing__wrappee__Keys_~tmp~11#1;outgoing__wrappee__Keys_~client#1 := outgoing__wrappee__Keys_#in~client#1;outgoing__wrappee__Keys_~msg#1 := outgoing__wrappee__Keys_#in~msg#1;havoc outgoing__wrappee__Keys_~tmp~11#1;assume { :begin_inline_getClientId } true;getClientId_#in~handle#1 := outgoing__wrappee__Keys_~client#1;havoc getClientId_#res#1;havoc getClientId_~handle#1, getClientId_~retValue_acc~43#1;getClientId_~handle#1 := getClientId_#in~handle#1;havoc getClientId_~retValue_acc~43#1; {12069#false} is VALID [2022-02-20 18:03:46,408 INFO L290 TraceCheckUtils]: 102: Hoare triple {12069#false} assume 1 == getClientId_~handle#1;getClientId_~retValue_acc~43#1 := ~__ste_client_idCounter0~0;getClientId_#res#1 := getClientId_~retValue_acc~43#1; {12069#false} is VALID [2022-02-20 18:03:46,408 INFO L290 TraceCheckUtils]: 103: Hoare triple {12069#false} outgoing__wrappee__Keys_#t~ret68#1 := getClientId_#res#1;assume { :end_inline_getClientId } true;assume -2147483648 <= outgoing__wrappee__Keys_#t~ret68#1 && outgoing__wrappee__Keys_#t~ret68#1 <= 2147483647;outgoing__wrappee__Keys_~tmp~11#1 := outgoing__wrappee__Keys_#t~ret68#1;havoc outgoing__wrappee__Keys_#t~ret68#1; {12069#false} is VALID [2022-02-20 18:03:46,408 INFO L272 TraceCheckUtils]: 104: Hoare triple {12069#false} call setEmailFrom(outgoing__wrappee__Keys_~msg#1, outgoing__wrappee__Keys_~tmp~11#1); {12069#false} is VALID [2022-02-20 18:03:46,408 INFO L290 TraceCheckUtils]: 105: Hoare triple {12069#false} ~handle := #in~handle;~value := #in~value; {12069#false} is VALID [2022-02-20 18:03:46,408 INFO L290 TraceCheckUtils]: 106: Hoare triple {12069#false} assume 1 == ~handle;~__ste_email_from0~0 := ~value; {12069#false} is VALID [2022-02-20 18:03:46,408 INFO L290 TraceCheckUtils]: 107: Hoare triple {12069#false} assume true; {12069#false} is VALID [2022-02-20 18:03:46,408 INFO L284 TraceCheckUtils]: 108: Hoare quadruple {12069#false} {12069#false} #1178#return; {12069#false} is VALID [2022-02-20 18:03:46,408 INFO L290 TraceCheckUtils]: 109: Hoare triple {12069#false} assume { :begin_inline_mail } true;mail_#in~client#1, mail_#in~msg#1 := outgoing__wrappee__Keys_~client#1, outgoing__wrappee__Keys_~msg#1;havoc mail_#t~ret66#1, mail_#t~ret67#1, mail_~client#1, mail_~msg#1, mail_~__utac__ad__arg1~0#1, mail_~tmp~10#1;mail_~client#1 := mail_#in~client#1;mail_~msg#1 := mail_#in~msg#1;havoc mail_~__utac__ad__arg1~0#1;havoc mail_~tmp~10#1;mail_~__utac__ad__arg1~0#1 := mail_~msg#1;assume { :begin_inline___utac_acc__EncryptAutoResponder_spec__2 } true;__utac_acc__EncryptAutoResponder_spec__2_#in~msg#1 := mail_~__utac__ad__arg1~0#1;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1, __utac_acc__EncryptAutoResponder_spec__2_#t~nondet29#1, __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1, __utac_acc__EncryptAutoResponder_spec__2_~msg#1, __utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.base, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.offset;__utac_acc__EncryptAutoResponder_spec__2_~msg#1 := __utac_acc__EncryptAutoResponder_spec__2_#in~msg#1;havoc __utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1;havoc __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.base, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.offset;call __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1 := puts(15, 0);assume -2147483648 <= __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1 && __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1 <= 2147483647;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1;__utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.base, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.offset := 16, 0;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~nondet29#1; {12069#false} is VALID [2022-02-20 18:03:46,408 INFO L290 TraceCheckUtils]: 110: Hoare triple {12069#false} assume 0 != ~in_encrypted~0; {12069#false} is VALID [2022-02-20 18:03:46,409 INFO L272 TraceCheckUtils]: 111: Hoare triple {12069#false} call __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1 := isEncrypted(__utac_acc__EncryptAutoResponder_spec__2_~msg#1); {12069#false} is VALID [2022-02-20 18:03:46,409 INFO L290 TraceCheckUtils]: 112: Hoare triple {12069#false} ~handle := #in~handle;havoc ~retValue_acc~6; {12069#false} is VALID [2022-02-20 18:03:46,409 INFO L290 TraceCheckUtils]: 113: Hoare triple {12069#false} assume 1 == ~handle;~retValue_acc~6 := ~__ste_email_isEncrypted0~0;#res := ~retValue_acc~6; {12069#false} is VALID [2022-02-20 18:03:46,409 INFO L290 TraceCheckUtils]: 114: Hoare triple {12069#false} assume true; {12069#false} is VALID [2022-02-20 18:03:46,409 INFO L284 TraceCheckUtils]: 115: Hoare quadruple {12069#false} {12069#false} #1180#return; {12069#false} is VALID [2022-02-20 18:03:46,409 INFO L290 TraceCheckUtils]: 116: Hoare triple {12069#false} assume -2147483648 <= __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1 && __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1 <= 2147483647;__utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1 := __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1; {12069#false} is VALID [2022-02-20 18:03:46,409 INFO L290 TraceCheckUtils]: 117: Hoare triple {12069#false} assume !(0 != __utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1);assume { :begin_inline___automaton_fail } true; {12069#false} is VALID [2022-02-20 18:03:46,409 INFO L290 TraceCheckUtils]: 118: Hoare triple {12069#false} assume !false; {12069#false} is VALID [2022-02-20 18:03:46,410 INFO L134 CoverageAnalysis]: Checked inductivity of 30 backedges. 19 proven. 0 refuted. 0 times theorem prover too weak. 11 trivial. 0 not checked. [2022-02-20 18:03:46,410 INFO L324 TraceCheckSpWp]: Omiting computation of backward sequence because forward sequence was already perfect [2022-02-20 18:03:46,410 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleZ3 [1368426072] provided 1 perfect and 0 imperfect interpolant sequences [2022-02-20 18:03:46,410 INFO L191 FreeRefinementEngine]: Found 1 perfect and 1 imperfect interpolant sequences. [2022-02-20 18:03:46,410 INFO L204 FreeRefinementEngine]: Number of different interpolants: perfect sequences [5] imperfect sequences [12] total 15 [2022-02-20 18:03:46,410 INFO L118 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [1394750974] [2022-02-20 18:03:46,410 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-02-20 18:03:46,412 INFO L78 Accepts]: Start accepts. Automaton has has 5 states, 5 states have (on average 16.4) internal successors, (82), 5 states have internal predecessors, (82), 3 states have call successors, (17), 2 states have call predecessors, (17), 3 states have return successors, (14), 3 states have call predecessors, (14), 3 states have call successors, (14) Word has length 119 [2022-02-20 18:03:46,412 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-02-20 18:03:46,412 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with has 5 states, 5 states have (on average 16.4) internal successors, (82), 5 states have internal predecessors, (82), 3 states have call successors, (17), 2 states have call predecessors, (17), 3 states have return successors, (14), 3 states have call predecessors, (14), 3 states have call successors, (14) [2022-02-20 18:03:46,478 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 113 edges. 113 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 18:03:46,478 INFO L546 AbstractCegarLoop]: INTERPOLANT automaton has 5 states [2022-02-20 18:03:46,478 INFO L108 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2022-02-20 18:03:46,479 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 5 interpolants. [2022-02-20 18:03:46,479 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=30, Invalid=180, Unknown=0, NotChecked=0, Total=210 [2022-02-20 18:03:46,479 INFO L87 Difference]: Start difference. First operand 468 states and 719 transitions. Second operand has 5 states, 5 states have (on average 16.4) internal successors, (82), 5 states have internal predecessors, (82), 3 states have call successors, (17), 2 states have call predecessors, (17), 3 states have return successors, (14), 3 states have call predecessors, (14), 3 states have call successors, (14) [2022-02-20 18:03:47,519 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 18:03:47,520 INFO L93 Difference]: Finished difference Result 925 states and 1427 transitions. [2022-02-20 18:03:47,520 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 5 states. [2022-02-20 18:03:47,520 INFO L78 Accepts]: Start accepts. Automaton has has 5 states, 5 states have (on average 16.4) internal successors, (82), 5 states have internal predecessors, (82), 3 states have call successors, (17), 2 states have call predecessors, (17), 3 states have return successors, (14), 3 states have call predecessors, (14), 3 states have call successors, (14) Word has length 119 [2022-02-20 18:03:47,520 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-02-20 18:03:47,520 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 5 states, 5 states have (on average 16.4) internal successors, (82), 5 states have internal predecessors, (82), 3 states have call successors, (17), 2 states have call predecessors, (17), 3 states have return successors, (14), 3 states have call predecessors, (14), 3 states have call successors, (14) [2022-02-20 18:03:47,529 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 5 states to 5 states and 1199 transitions. [2022-02-20 18:03:47,529 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 5 states, 5 states have (on average 16.4) internal successors, (82), 5 states have internal predecessors, (82), 3 states have call successors, (17), 2 states have call predecessors, (17), 3 states have return successors, (14), 3 states have call predecessors, (14), 3 states have call successors, (14) [2022-02-20 18:03:47,551 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 5 states to 5 states and 1199 transitions. [2022-02-20 18:03:47,552 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with 5 states and 1199 transitions. [2022-02-20 18:03:48,369 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 1199 edges. 1199 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 18:03:48,385 INFO L225 Difference]: With dead ends: 925 [2022-02-20 18:03:48,385 INFO L226 Difference]: Without dead ends: 470 [2022-02-20 18:03:48,387 INFO L932 BasicCegarLoop]: 0 DeclaredPredicates, 153 GetRequests, 139 SyntacticMatches, 0 SemanticMatches, 14 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 4 ImplicationChecksByTransitivity, 0.1s TimeCoverageRelationStatistics Valid=34, Invalid=206, Unknown=0, NotChecked=0, Total=240 [2022-02-20 18:03:48,387 INFO L933 BasicCegarLoop]: 594 mSDtfsCounter, 143 mSDsluCounter, 1613 mSDsCounter, 0 mSdLazyCounter, 45 mSolverCounterSat, 0 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.0s Time, 0 mProtectedPredicate, 0 mProtectedAction, 166 SdHoareTripleChecker+Valid, 2207 SdHoareTripleChecker+Invalid, 45 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 0 IncrementalHoareTripleChecker+Valid, 45 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.0s IncrementalHoareTripleChecker+Time [2022-02-20 18:03:48,388 INFO L934 BasicCegarLoop]: SdHoareTripleChecker [166 Valid, 2207 Invalid, 45 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [0 Valid, 45 Invalid, 0 Unknown, 0 Unchecked, 0.0s Time] [2022-02-20 18:03:48,388 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 470 states. [2022-02-20 18:03:48,491 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 470 to 470. [2022-02-20 18:03:48,492 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-02-20 18:03:48,493 INFO L82 GeneralOperation]: Start isEquivalent. First operand 470 states. Second operand has 470 states, 362 states have (on average 1.5607734806629834) internal successors, (565), 368 states have internal predecessors, (565), 77 states have call successors, (77), 28 states have call predecessors, (77), 30 states have return successors, (83), 75 states have call predecessors, (83), 76 states have call successors, (83) [2022-02-20 18:03:48,494 INFO L74 IsIncluded]: Start isIncluded. First operand 470 states. Second operand has 470 states, 362 states have (on average 1.5607734806629834) internal successors, (565), 368 states have internal predecessors, (565), 77 states have call successors, (77), 28 states have call predecessors, (77), 30 states have return successors, (83), 75 states have call predecessors, (83), 76 states have call successors, (83) [2022-02-20 18:03:48,495 INFO L87 Difference]: Start difference. First operand 470 states. Second operand has 470 states, 362 states have (on average 1.5607734806629834) internal successors, (565), 368 states have internal predecessors, (565), 77 states have call successors, (77), 28 states have call predecessors, (77), 30 states have return successors, (83), 75 states have call predecessors, (83), 76 states have call successors, (83) [2022-02-20 18:03:48,512 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 18:03:48,512 INFO L93 Difference]: Finished difference Result 470 states and 725 transitions. [2022-02-20 18:03:48,512 INFO L276 IsEmpty]: Start isEmpty. Operand 470 states and 725 transitions. [2022-02-20 18:03:48,515 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 18:03:48,515 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 18:03:48,517 INFO L74 IsIncluded]: Start isIncluded. First operand has 470 states, 362 states have (on average 1.5607734806629834) internal successors, (565), 368 states have internal predecessors, (565), 77 states have call successors, (77), 28 states have call predecessors, (77), 30 states have return successors, (83), 75 states have call predecessors, (83), 76 states have call successors, (83) Second operand 470 states. [2022-02-20 18:03:48,518 INFO L87 Difference]: Start difference. First operand has 470 states, 362 states have (on average 1.5607734806629834) internal successors, (565), 368 states have internal predecessors, (565), 77 states have call successors, (77), 28 states have call predecessors, (77), 30 states have return successors, (83), 75 states have call predecessors, (83), 76 states have call successors, (83) Second operand 470 states. [2022-02-20 18:03:48,533 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 18:03:48,533 INFO L93 Difference]: Finished difference Result 470 states and 725 transitions. [2022-02-20 18:03:48,533 INFO L276 IsEmpty]: Start isEmpty. Operand 470 states and 725 transitions. [2022-02-20 18:03:48,535 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 18:03:48,535 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 18:03:48,536 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-02-20 18:03:48,536 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-02-20 18:03:48,537 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 470 states, 362 states have (on average 1.5607734806629834) internal successors, (565), 368 states have internal predecessors, (565), 77 states have call successors, (77), 28 states have call predecessors, (77), 30 states have return successors, (83), 75 states have call predecessors, (83), 76 states have call successors, (83) [2022-02-20 18:03:48,554 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 470 states to 470 states and 725 transitions. [2022-02-20 18:03:48,555 INFO L78 Accepts]: Start accepts. Automaton has 470 states and 725 transitions. Word has length 119 [2022-02-20 18:03:48,556 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-02-20 18:03:48,556 INFO L470 AbstractCegarLoop]: Abstraction has 470 states and 725 transitions. [2022-02-20 18:03:48,556 INFO L471 AbstractCegarLoop]: INTERPOLANT automaton has has 5 states, 5 states have (on average 16.4) internal successors, (82), 5 states have internal predecessors, (82), 3 states have call successors, (17), 2 states have call predecessors, (17), 3 states have return successors, (14), 3 states have call predecessors, (14), 3 states have call successors, (14) [2022-02-20 18:03:48,556 INFO L276 IsEmpty]: Start isEmpty. Operand 470 states and 725 transitions. [2022-02-20 18:03:48,558 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 121 [2022-02-20 18:03:48,558 INFO L506 BasicCegarLoop]: Found error trace [2022-02-20 18:03:48,559 INFO L514 BasicCegarLoop]: trace histogram [3, 3, 3, 3, 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] [2022-02-20 18:03:48,588 INFO L540 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (6)] Forceful destruction successful, exit code 0 [2022-02-20 18:03:48,785 WARN L452 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable4,6 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-02-20 18:03:48,785 INFO L402 AbstractCegarLoop]: === Iteration 6 === Targeting outgoing__wrappee__EncryptErr0ASSERT_VIOLATIONERROR_FUNCTION === [outgoing__wrappee__EncryptErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-02-20 18:03:48,786 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-02-20 18:03:48,786 INFO L85 PathProgramCache]: Analyzing trace with hash -1604266393, now seen corresponding path program 1 times [2022-02-20 18:03:48,786 INFO L126 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-02-20 18:03:48,786 INFO L338 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [786783840] [2022-02-20 18:03:48,786 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 18:03:48,786 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-02-20 18:03:48,818 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:48,850 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 6 [2022-02-20 18:03:48,852 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:48,855 INFO L290 TraceCheckUtils]: 0: Hoare triple {15420#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {15358#true} is VALID [2022-02-20 18:03:48,855 INFO L290 TraceCheckUtils]: 1: Hoare triple {15358#true} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {15358#true} is VALID [2022-02-20 18:03:48,855 INFO L290 TraceCheckUtils]: 2: Hoare triple {15358#true} assume true; {15358#true} is VALID [2022-02-20 18:03:48,855 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {15358#true} {15358#true} #1224#return; {15358#true} is VALID [2022-02-20 18:03:48,861 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 12 [2022-02-20 18:03:48,864 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:48,867 INFO L290 TraceCheckUtils]: 0: Hoare triple {15421#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {15358#true} is VALID [2022-02-20 18:03:48,867 INFO L290 TraceCheckUtils]: 1: Hoare triple {15358#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {15358#true} is VALID [2022-02-20 18:03:48,867 INFO L290 TraceCheckUtils]: 2: Hoare triple {15358#true} assume true; {15358#true} is VALID [2022-02-20 18:03:48,867 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {15358#true} {15358#true} #1226#return; {15358#true} is VALID [2022-02-20 18:03:48,868 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 18 [2022-02-20 18:03:48,869 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:48,873 INFO L290 TraceCheckUtils]: 0: Hoare triple {15420#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {15358#true} is VALID [2022-02-20 18:03:48,874 INFO L290 TraceCheckUtils]: 1: Hoare triple {15358#true} assume !(1 == ~handle); {15358#true} is VALID [2022-02-20 18:03:48,874 INFO L290 TraceCheckUtils]: 2: Hoare triple {15358#true} assume 2 == ~handle;~__ste_client_idCounter1~0 := ~value; {15358#true} is VALID [2022-02-20 18:03:48,874 INFO L290 TraceCheckUtils]: 3: Hoare triple {15358#true} assume true; {15358#true} is VALID [2022-02-20 18:03:48,874 INFO L284 TraceCheckUtils]: 4: Hoare quadruple {15358#true} {15358#true} #1228#return; {15358#true} is VALID [2022-02-20 18:03:48,874 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 25 [2022-02-20 18:03:48,877 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:48,880 INFO L290 TraceCheckUtils]: 0: Hoare triple {15421#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {15358#true} is VALID [2022-02-20 18:03:48,880 INFO L290 TraceCheckUtils]: 1: Hoare triple {15358#true} assume !(1 == ~handle); {15358#true} is VALID [2022-02-20 18:03:48,881 INFO L290 TraceCheckUtils]: 2: Hoare triple {15358#true} assume 2 == ~handle;~__ste_client_privateKey1~0 := ~value; {15358#true} is VALID [2022-02-20 18:03:48,881 INFO L290 TraceCheckUtils]: 3: Hoare triple {15358#true} assume true; {15358#true} is VALID [2022-02-20 18:03:48,881 INFO L284 TraceCheckUtils]: 4: Hoare quadruple {15358#true} {15358#true} #1230#return; {15358#true} is VALID [2022-02-20 18:03:48,881 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 32 [2022-02-20 18:03:48,885 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:48,899 INFO L290 TraceCheckUtils]: 0: Hoare triple {15420#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {15422#(= setClientId_~handle |setClientId_#in~handle|)} is VALID [2022-02-20 18:03:48,900 INFO L290 TraceCheckUtils]: 1: Hoare triple {15422#(= setClientId_~handle |setClientId_#in~handle|)} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {15423#(= |setClientId_#in~handle| 1)} is VALID [2022-02-20 18:03:48,900 INFO L290 TraceCheckUtils]: 2: Hoare triple {15423#(= |setClientId_#in~handle| 1)} assume true; {15423#(= |setClientId_#in~handle| 1)} is VALID [2022-02-20 18:03:48,901 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {15423#(= |setClientId_#in~handle| 1)} {15378#(= 3 |ULTIMATE.start_setup_chuck__wrappee__Base_~chuck___0#1|)} #1232#return; {15359#false} is VALID [2022-02-20 18:03:48,901 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 38 [2022-02-20 18:03:48,903 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:48,906 INFO L290 TraceCheckUtils]: 0: Hoare triple {15421#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {15358#true} is VALID [2022-02-20 18:03:48,906 INFO L290 TraceCheckUtils]: 1: Hoare triple {15358#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {15358#true} is VALID [2022-02-20 18:03:48,906 INFO L290 TraceCheckUtils]: 2: Hoare triple {15358#true} assume true; {15358#true} is VALID [2022-02-20 18:03:48,906 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {15358#true} {15359#false} #1234#return; {15359#false} is VALID [2022-02-20 18:03:48,912 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 57 [2022-02-20 18:03:48,914 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:48,917 INFO L290 TraceCheckUtils]: 0: Hoare triple {15424#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} ~handle := #in~handle;~value := #in~value; {15358#true} is VALID [2022-02-20 18:03:48,917 INFO L290 TraceCheckUtils]: 1: Hoare triple {15358#true} assume 1 == ~handle;~__ste_email_from0~0 := ~value; {15358#true} is VALID [2022-02-20 18:03:48,917 INFO L290 TraceCheckUtils]: 2: Hoare triple {15358#true} assume true; {15358#true} is VALID [2022-02-20 18:03:48,917 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {15358#true} {15359#false} #1210#return; {15359#false} is VALID [2022-02-20 18:03:48,924 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 62 [2022-02-20 18:03:48,925 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:48,927 INFO L290 TraceCheckUtils]: 0: Hoare triple {15425#(and (= ~__ste_email_to0~0 |old(~__ste_email_to0~0)|) (= ~__ste_email_to1~0 |old(~__ste_email_to1~0)|))} ~handle := #in~handle;~value := #in~value; {15358#true} is VALID [2022-02-20 18:03:48,928 INFO L290 TraceCheckUtils]: 1: Hoare triple {15358#true} assume 1 == ~handle;~__ste_email_to0~0 := ~value; {15358#true} is VALID [2022-02-20 18:03:48,928 INFO L290 TraceCheckUtils]: 2: Hoare triple {15358#true} assume true; {15358#true} is VALID [2022-02-20 18:03:48,928 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {15358#true} {15359#false} #1212#return; {15359#false} is VALID [2022-02-20 18:03:48,928 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 71 [2022-02-20 18:03:48,930 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:48,934 INFO L290 TraceCheckUtils]: 0: Hoare triple {15358#true} ~handle := #in~handle;havoc ~retValue_acc~36; {15358#true} is VALID [2022-02-20 18:03:48,935 INFO L290 TraceCheckUtils]: 1: Hoare triple {15358#true} assume 1 == ~handle;~retValue_acc~36 := ~__ste_client_privateKey0~0;#res := ~retValue_acc~36; {15358#true} is VALID [2022-02-20 18:03:48,935 INFO L290 TraceCheckUtils]: 2: Hoare triple {15358#true} assume true; {15358#true} is VALID [2022-02-20 18:03:48,935 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {15358#true} {15359#false} #1150#return; {15359#false} is VALID [2022-02-20 18:03:48,935 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 79 [2022-02-20 18:03:48,936 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:48,938 INFO L290 TraceCheckUtils]: 0: Hoare triple {15358#true} ~handle := #in~handle;havoc ~retValue_acc~30; {15358#true} is VALID [2022-02-20 18:03:48,938 INFO L290 TraceCheckUtils]: 1: Hoare triple {15358#true} assume 1 == ~handle;~retValue_acc~30 := ~__ste_ClientAddressBook_size0~0;#res := ~retValue_acc~30; {15358#true} is VALID [2022-02-20 18:03:48,938 INFO L290 TraceCheckUtils]: 2: Hoare triple {15358#true} assume true; {15358#true} is VALID [2022-02-20 18:03:48,939 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {15358#true} {15359#false} #1152#return; {15359#false} is VALID [2022-02-20 18:03:48,939 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 88 [2022-02-20 18:03:48,941 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:48,943 INFO L290 TraceCheckUtils]: 0: Hoare triple {15358#true} ~handle := #in~handle;havoc ~retValue_acc~3; {15358#true} is VALID [2022-02-20 18:03:48,943 INFO L290 TraceCheckUtils]: 1: Hoare triple {15358#true} assume 1 == ~handle;~retValue_acc~3 := ~__ste_email_to0~0;#res := ~retValue_acc~3; {15358#true} is VALID [2022-02-20 18:03:48,943 INFO L290 TraceCheckUtils]: 2: Hoare triple {15358#true} assume true; {15358#true} is VALID [2022-02-20 18:03:48,943 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {15358#true} {15359#false} #1170#return; {15359#false} is VALID [2022-02-20 18:03:48,943 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 94 [2022-02-20 18:03:48,944 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:48,947 INFO L290 TraceCheckUtils]: 0: Hoare triple {15358#true} ~handle := #in~handle;~userid := #in~userid;havoc ~retValue_acc~41; {15358#true} is VALID [2022-02-20 18:03:48,947 INFO L290 TraceCheckUtils]: 1: Hoare triple {15358#true} assume 1 == ~handle; {15358#true} is VALID [2022-02-20 18:03:48,947 INFO L290 TraceCheckUtils]: 2: Hoare triple {15358#true} assume ~userid == ~__ste_Client_Keyring0_User0~0;~retValue_acc~41 := ~__ste_Client_Keyring0_PublicKey0~0;#res := ~retValue_acc~41; {15358#true} is VALID [2022-02-20 18:03:48,947 INFO L290 TraceCheckUtils]: 3: Hoare triple {15358#true} assume true; {15358#true} is VALID [2022-02-20 18:03:48,947 INFO L284 TraceCheckUtils]: 4: Hoare quadruple {15358#true} {15359#false} #1172#return; {15359#false} is VALID [2022-02-20 18:03:48,948 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 105 [2022-02-20 18:03:48,949 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:48,950 INFO L290 TraceCheckUtils]: 0: Hoare triple {15424#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} ~handle := #in~handle;~value := #in~value; {15358#true} is VALID [2022-02-20 18:03:48,951 INFO L290 TraceCheckUtils]: 1: Hoare triple {15358#true} assume 1 == ~handle;~__ste_email_from0~0 := ~value; {15358#true} is VALID [2022-02-20 18:03:48,951 INFO L290 TraceCheckUtils]: 2: Hoare triple {15358#true} assume true; {15358#true} is VALID [2022-02-20 18:03:48,951 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {15358#true} {15359#false} #1178#return; {15359#false} is VALID [2022-02-20 18:03:48,951 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 112 [2022-02-20 18:03:48,952 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:48,954 INFO L290 TraceCheckUtils]: 0: Hoare triple {15358#true} ~handle := #in~handle;havoc ~retValue_acc~6; {15358#true} is VALID [2022-02-20 18:03:48,954 INFO L290 TraceCheckUtils]: 1: Hoare triple {15358#true} assume 1 == ~handle;~retValue_acc~6 := ~__ste_email_isEncrypted0~0;#res := ~retValue_acc~6; {15358#true} is VALID [2022-02-20 18:03:48,954 INFO L290 TraceCheckUtils]: 2: Hoare triple {15358#true} assume true; {15358#true} is VALID [2022-02-20 18:03:48,955 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {15358#true} {15359#false} #1180#return; {15359#false} is VALID [2022-02-20 18:03:48,955 INFO L290 TraceCheckUtils]: 0: Hoare triple {15358#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(28, 2);call #Ultimate.allocInit(12, 3);call #Ultimate.allocInit(10, 4);call #Ultimate.allocInit(12, 5);call #Ultimate.allocInit(10, 6);call #Ultimate.allocInit(18, 7);call #Ultimate.allocInit(16, 8);call #Ultimate.allocInit(21, 9);call #Ultimate.allocInit(13, 10);call #Ultimate.allocInit(16, 11);call #Ultimate.allocInit(25, 12);call #Ultimate.allocInit(17, 13);call #Ultimate.allocInit(17, 14);call #Ultimate.allocInit(13, 15);call #Ultimate.allocInit(17, 16);call #Ultimate.allocInit(30, 17);call #Ultimate.allocInit(9, 18);call #Ultimate.allocInit(21, 19);call #Ultimate.allocInit(30, 20);call #Ultimate.allocInit(9, 21);call #Ultimate.allocInit(21, 22);call #Ultimate.allocInit(30, 23);call #Ultimate.allocInit(9, 24);call #Ultimate.allocInit(25, 25);call #Ultimate.allocInit(30, 26);call #Ultimate.allocInit(9, 27);call #Ultimate.allocInit(25, 28);call #Ultimate.allocInit(4, 29);call write~init~int(37, 29, 0, 1);call write~init~int(115, 29, 1, 1);call write~init~int(10, 29, 2, 1);call write~init~int(0, 29, 3, 1);call #Ultimate.allocInit(10, 30);call #Ultimate.allocInit(34, 31);call #Ultimate.allocInit(30, 32);call #Ultimate.allocInit(16, 33);call #Ultimate.allocInit(20, 34);call #Ultimate.allocInit(44, 35);call #Ultimate.allocInit(44, 36);call #Ultimate.allocInit(9, 37);call #Ultimate.allocInit(9, 38);call #Ultimate.allocInit(11, 39);call #Ultimate.allocInit(19, 40);call #Ultimate.allocInit(4, 41);call write~init~int(37, 41, 0, 1);call write~init~int(100, 41, 1, 1);call write~init~int(10, 41, 2, 1);call write~init~int(0, 41, 3, 1);call #Ultimate.allocInit(4, 42);call write~init~int(37, 42, 0, 1);call write~init~int(100, 42, 1, 1);call write~init~int(10, 42, 2, 1);call write~init~int(0, 42, 3, 1);~__ste_Email_counter~0 := 0;~__ste_email_id0~0 := 0;~__ste_email_id1~0 := 0;~__ste_email_from0~0 := 0;~__ste_email_from1~0 := 0;~__ste_email_to0~0 := 0;~__ste_email_to1~0 := 0;~__ste_email_subject0~0.base, ~__ste_email_subject0~0.offset := 0, 0;~__ste_email_subject1~0.base, ~__ste_email_subject1~0.offset := 0, 0;~__ste_email_body0~0.base, ~__ste_email_body0~0.offset := 0, 0;~__ste_email_body1~0.base, ~__ste_email_body1~0.offset := 0, 0;~__ste_email_isEncrypted0~0 := 0;~__ste_email_isEncrypted1~0 := 0;~__ste_email_encryptionKey0~0 := 0;~__ste_email_encryptionKey1~0 := 0;~__ste_email_isSigned0~0 := 0;~__ste_email_isSigned1~0 := 0;~__ste_email_signKey0~0 := 0;~__ste_email_signKey1~0 := 0;~__ste_email_isSignatureVerified0~0 := 0;~__ste_email_isSignatureVerified1~0 := 0;~__SELECTED_FEATURE_Base~0 := 0;~__SELECTED_FEATURE_Keys~0 := 0;~__SELECTED_FEATURE_Encrypt~0 := 0;~__SELECTED_FEATURE_AutoResponder~0 := 0;~__SELECTED_FEATURE_AddressBook~0 := 0;~__SELECTED_FEATURE_Sign~0 := 0;~__SELECTED_FEATURE_Forward~0 := 0;~__SELECTED_FEATURE_Verify~0 := 0;~__SELECTED_FEATURE_Decrypt~0 := 0;~__GUIDSL_ROOT_PRODUCTION~0 := 0;~__GUIDSL_NON_TERMINAL_main~0 := 0;~in_encrypted~0 := 0;~head~0.base, ~head~0.offset := 0, 0;~queue_empty~0 := 1;~queued_message~0 := 0;~queued_client~0 := 0;~bob~0 := 0;~rjh~0 := 0;~chuck~0 := 0;~__ste_Client_counter~0 := 0;~__ste_client_name0~0.base, ~__ste_client_name0~0.offset := 0, 0;~__ste_client_name1~0.base, ~__ste_client_name1~0.offset := 0, 0;~__ste_client_name2~0.base, ~__ste_client_name2~0.offset := 0, 0;~__ste_client_outbuffer0~0 := 0;~__ste_client_outbuffer1~0 := 0;~__ste_client_outbuffer2~0 := 0;~__ste_client_outbuffer3~0 := 0;~__ste_ClientAddressBook_size0~0 := 0;~__ste_ClientAddressBook_size1~0 := 0;~__ste_ClientAddressBook_size2~0 := 0;~__ste_Client_AddressBook0_Alias0~0 := 0;~__ste_Client_AddressBook0_Alias1~0 := 0;~__ste_Client_AddressBook0_Alias2~0 := 0;~__ste_Client_AddressBook1_Alias0~0 := 0;~__ste_Client_AddressBook1_Alias1~0 := 0;~__ste_Client_AddressBook1_Alias2~0 := 0;~__ste_Client_AddressBook2_Alias0~0 := 0;~__ste_Client_AddressBook2_Alias1~0 := 0;~__ste_Client_AddressBook2_Alias2~0 := 0;~__ste_Client_AddressBook0_Address0~0 := 0;~__ste_Client_AddressBook0_Address1~0 := 0;~__ste_Client_AddressBook0_Address2~0 := 0;~__ste_Client_AddressBook1_Address0~0 := 0;~__ste_Client_AddressBook1_Address1~0 := 0;~__ste_Client_AddressBook1_Address2~0 := 0;~__ste_Client_AddressBook2_Address0~0 := 0;~__ste_Client_AddressBook2_Address1~0 := 0;~__ste_Client_AddressBook2_Address2~0 := 0;~__ste_client_autoResponse0~0 := 0;~__ste_client_autoResponse1~0 := 0;~__ste_client_autoResponse2~0 := 0;~__ste_client_privateKey0~0 := 0;~__ste_client_privateKey1~0 := 0;~__ste_client_privateKey2~0 := 0;~__ste_ClientKeyring_size0~0 := 0;~__ste_ClientKeyring_size1~0 := 0;~__ste_ClientKeyring_size2~0 := 0;~__ste_Client_Keyring0_User0~0 := 0;~__ste_Client_Keyring0_User1~0 := 0;~__ste_Client_Keyring0_User2~0 := 0;~__ste_Client_Keyring1_User0~0 := 0;~__ste_Client_Keyring1_User1~0 := 0;~__ste_Client_Keyring1_User2~0 := 0;~__ste_Client_Keyring2_User0~0 := 0;~__ste_Client_Keyring2_User1~0 := 0;~__ste_Client_Keyring2_User2~0 := 0;~__ste_Client_Keyring0_PublicKey0~0 := 0;~__ste_Client_Keyring0_PublicKey1~0 := 0;~__ste_Client_Keyring0_PublicKey2~0 := 0;~__ste_Client_Keyring1_PublicKey0~0 := 0;~__ste_Client_Keyring1_PublicKey1~0 := 0;~__ste_Client_Keyring1_PublicKey2~0 := 0;~__ste_Client_Keyring2_PublicKey0~0 := 0;~__ste_Client_Keyring2_PublicKey1~0 := 0;~__ste_Client_Keyring2_PublicKey2~0 := 0;~__ste_client_forwardReceiver0~0 := 0;~__ste_client_forwardReceiver1~0 := 0;~__ste_client_forwardReceiver2~0 := 0;~__ste_client_forwardReceiver3~0 := 0;~__ste_client_idCounter0~0 := 0;~__ste_client_idCounter1~0 := 0;~__ste_client_idCounter2~0 := 0; {15358#true} is VALID [2022-02-20 18:03:48,955 INFO L290 TraceCheckUtils]: 1: Hoare triple {15358#true} assume { :end_inline_ULTIMATE.init } true;assume { :begin_inline_main } true;havoc main_#res#1;havoc main_#t~nondet100#1, main_#t~ret101#1, main_~retValue_acc~26#1, main_~tmp~20#1;assume -2147483648 <= main_#t~nondet100#1 && main_#t~nondet100#1 <= 2147483647;main_~retValue_acc~26#1 := main_#t~nondet100#1;havoc main_#t~nondet100#1;havoc main_~tmp~20#1;assume { :begin_inline_select_helpers } true; {15358#true} is VALID [2022-02-20 18:03:48,955 INFO L290 TraceCheckUtils]: 2: Hoare triple {15358#true} assume { :end_inline_select_helpers } true;assume { :begin_inline_select_features } true; {15358#true} is VALID [2022-02-20 18:03:48,955 INFO L290 TraceCheckUtils]: 3: Hoare triple {15358#true} assume { :end_inline_select_features } true;assume { :begin_inline_valid_product } true;havoc valid_product_#res#1;havoc valid_product_~retValue_acc~12#1;havoc valid_product_~retValue_acc~12#1;valid_product_~retValue_acc~12#1 := 1;valid_product_#res#1 := valid_product_~retValue_acc~12#1; {15358#true} is VALID [2022-02-20 18:03:48,955 INFO L290 TraceCheckUtils]: 4: Hoare triple {15358#true} main_#t~ret101#1 := valid_product_#res#1;assume { :end_inline_valid_product } true;assume -2147483648 <= main_#t~ret101#1 && main_#t~ret101#1 <= 2147483647;main_~tmp~20#1 := main_#t~ret101#1;havoc main_#t~ret101#1; {15358#true} is VALID [2022-02-20 18:03:48,956 INFO L290 TraceCheckUtils]: 5: Hoare triple {15358#true} assume 0 != main_~tmp~20#1;assume { :begin_inline_setup } true;havoc setup_#t~nondet97#1, setup_#t~nondet98#1, setup_#t~nondet99#1, setup_~__cil_tmp1~0#1.base, setup_~__cil_tmp1~0#1.offset, setup_~__cil_tmp2~1#1.base, setup_~__cil_tmp2~1#1.offset, setup_~__cil_tmp3~4#1.base, setup_~__cil_tmp3~4#1.offset;havoc setup_~__cil_tmp1~0#1.base, setup_~__cil_tmp1~0#1.offset;havoc setup_~__cil_tmp2~1#1.base, setup_~__cil_tmp2~1#1.offset;havoc setup_~__cil_tmp3~4#1.base, setup_~__cil_tmp3~4#1.offset;~bob~0 := 1;assume { :begin_inline_setup_bob } true;setup_bob_#in~bob___0#1 := ~bob~0;havoc setup_bob_~bob___0#1;setup_bob_~bob___0#1 := setup_bob_#in~bob___0#1;assume { :begin_inline_setup_bob__wrappee__Base } true;setup_bob__wrappee__Base_#in~bob___0#1 := setup_bob_~bob___0#1;havoc setup_bob__wrappee__Base_~bob___0#1;setup_bob__wrappee__Base_~bob___0#1 := setup_bob__wrappee__Base_#in~bob___0#1; {15358#true} is VALID [2022-02-20 18:03:48,956 INFO L272 TraceCheckUtils]: 6: Hoare triple {15358#true} call setClientId(setup_bob__wrappee__Base_~bob___0#1, setup_bob__wrappee__Base_~bob___0#1); {15420#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} is VALID [2022-02-20 18:03:48,956 INFO L290 TraceCheckUtils]: 7: Hoare triple {15420#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {15358#true} is VALID [2022-02-20 18:03:48,957 INFO L290 TraceCheckUtils]: 8: Hoare triple {15358#true} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {15358#true} is VALID [2022-02-20 18:03:48,957 INFO L290 TraceCheckUtils]: 9: Hoare triple {15358#true} assume true; {15358#true} is VALID [2022-02-20 18:03:48,957 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {15358#true} {15358#true} #1224#return; {15358#true} is VALID [2022-02-20 18:03:48,957 INFO L290 TraceCheckUtils]: 11: Hoare triple {15358#true} assume { :end_inline_setup_bob__wrappee__Base } true; {15358#true} is VALID [2022-02-20 18:03:48,958 INFO L272 TraceCheckUtils]: 12: Hoare triple {15358#true} call setClientPrivateKey(setup_bob_~bob___0#1, 123); {15421#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} is VALID [2022-02-20 18:03:48,958 INFO L290 TraceCheckUtils]: 13: Hoare triple {15421#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {15358#true} is VALID [2022-02-20 18:03:48,958 INFO L290 TraceCheckUtils]: 14: Hoare triple {15358#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {15358#true} is VALID [2022-02-20 18:03:48,958 INFO L290 TraceCheckUtils]: 15: Hoare triple {15358#true} assume true; {15358#true} is VALID [2022-02-20 18:03:48,958 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {15358#true} {15358#true} #1226#return; {15358#true} is VALID [2022-02-20 18:03:48,958 INFO L290 TraceCheckUtils]: 17: Hoare triple {15358#true} assume { :end_inline_setup_bob } true;setup_~__cil_tmp1~0#1.base, setup_~__cil_tmp1~0#1.offset := 37, 0;havoc setup_#t~nondet97#1;~rjh~0 := 2;assume { :begin_inline_setup_rjh } true;setup_rjh_#in~rjh___0#1 := ~rjh~0;havoc setup_rjh_~rjh___0#1;setup_rjh_~rjh___0#1 := setup_rjh_#in~rjh___0#1;assume { :begin_inline_setup_rjh__wrappee__Base } true;setup_rjh__wrappee__Base_#in~rjh___0#1 := setup_rjh_~rjh___0#1;havoc setup_rjh__wrappee__Base_~rjh___0#1;setup_rjh__wrappee__Base_~rjh___0#1 := setup_rjh__wrappee__Base_#in~rjh___0#1; {15358#true} is VALID [2022-02-20 18:03:48,959 INFO L272 TraceCheckUtils]: 18: Hoare triple {15358#true} call setClientId(setup_rjh__wrappee__Base_~rjh___0#1, setup_rjh__wrappee__Base_~rjh___0#1); {15420#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} is VALID [2022-02-20 18:03:48,959 INFO L290 TraceCheckUtils]: 19: Hoare triple {15420#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {15358#true} is VALID [2022-02-20 18:03:48,959 INFO L290 TraceCheckUtils]: 20: Hoare triple {15358#true} assume !(1 == ~handle); {15358#true} is VALID [2022-02-20 18:03:48,959 INFO L290 TraceCheckUtils]: 21: Hoare triple {15358#true} assume 2 == ~handle;~__ste_client_idCounter1~0 := ~value; {15358#true} is VALID [2022-02-20 18:03:48,959 INFO L290 TraceCheckUtils]: 22: Hoare triple {15358#true} assume true; {15358#true} is VALID [2022-02-20 18:03:48,960 INFO L284 TraceCheckUtils]: 23: Hoare quadruple {15358#true} {15358#true} #1228#return; {15358#true} is VALID [2022-02-20 18:03:48,960 INFO L290 TraceCheckUtils]: 24: Hoare triple {15358#true} assume { :end_inline_setup_rjh__wrappee__Base } true; {15358#true} is VALID [2022-02-20 18:03:48,960 INFO L272 TraceCheckUtils]: 25: Hoare triple {15358#true} call setClientPrivateKey(setup_rjh_~rjh___0#1, 456); {15421#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} is VALID [2022-02-20 18:03:48,960 INFO L290 TraceCheckUtils]: 26: Hoare triple {15421#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {15358#true} is VALID [2022-02-20 18:03:48,961 INFO L290 TraceCheckUtils]: 27: Hoare triple {15358#true} assume !(1 == ~handle); {15358#true} is VALID [2022-02-20 18:03:48,961 INFO L290 TraceCheckUtils]: 28: Hoare triple {15358#true} assume 2 == ~handle;~__ste_client_privateKey1~0 := ~value; {15358#true} is VALID [2022-02-20 18:03:48,961 INFO L290 TraceCheckUtils]: 29: Hoare triple {15358#true} assume true; {15358#true} is VALID [2022-02-20 18:03:48,961 INFO L284 TraceCheckUtils]: 30: Hoare quadruple {15358#true} {15358#true} #1230#return; {15358#true} is VALID [2022-02-20 18:03:48,961 INFO L290 TraceCheckUtils]: 31: Hoare triple {15358#true} assume { :end_inline_setup_rjh } true;setup_~__cil_tmp2~1#1.base, setup_~__cil_tmp2~1#1.offset := 38, 0;havoc setup_#t~nondet98#1;~chuck~0 := 3;assume { :begin_inline_setup_chuck } true;setup_chuck_#in~chuck___0#1 := ~chuck~0;havoc setup_chuck_~chuck___0#1;setup_chuck_~chuck___0#1 := setup_chuck_#in~chuck___0#1;assume { :begin_inline_setup_chuck__wrappee__Base } true;setup_chuck__wrappee__Base_#in~chuck___0#1 := setup_chuck_~chuck___0#1;havoc setup_chuck__wrappee__Base_~chuck___0#1;setup_chuck__wrappee__Base_~chuck___0#1 := setup_chuck__wrappee__Base_#in~chuck___0#1; {15378#(= 3 |ULTIMATE.start_setup_chuck__wrappee__Base_~chuck___0#1|)} is VALID [2022-02-20 18:03:48,962 INFO L272 TraceCheckUtils]: 32: Hoare triple {15378#(= 3 |ULTIMATE.start_setup_chuck__wrappee__Base_~chuck___0#1|)} call setClientId(setup_chuck__wrappee__Base_~chuck___0#1, setup_chuck__wrappee__Base_~chuck___0#1); {15420#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} is VALID [2022-02-20 18:03:48,962 INFO L290 TraceCheckUtils]: 33: Hoare triple {15420#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {15422#(= setClientId_~handle |setClientId_#in~handle|)} is VALID [2022-02-20 18:03:48,963 INFO L290 TraceCheckUtils]: 34: Hoare triple {15422#(= setClientId_~handle |setClientId_#in~handle|)} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {15423#(= |setClientId_#in~handle| 1)} is VALID [2022-02-20 18:03:48,963 INFO L290 TraceCheckUtils]: 35: Hoare triple {15423#(= |setClientId_#in~handle| 1)} assume true; {15423#(= |setClientId_#in~handle| 1)} is VALID [2022-02-20 18:03:48,964 INFO L284 TraceCheckUtils]: 36: Hoare quadruple {15423#(= |setClientId_#in~handle| 1)} {15378#(= 3 |ULTIMATE.start_setup_chuck__wrappee__Base_~chuck___0#1|)} #1232#return; {15359#false} is VALID [2022-02-20 18:03:48,964 INFO L290 TraceCheckUtils]: 37: Hoare triple {15359#false} assume { :end_inline_setup_chuck__wrappee__Base } true; {15359#false} is VALID [2022-02-20 18:03:48,964 INFO L272 TraceCheckUtils]: 38: Hoare triple {15359#false} call setClientPrivateKey(setup_chuck_~chuck___0#1, 789); {15421#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} is VALID [2022-02-20 18:03:48,964 INFO L290 TraceCheckUtils]: 39: Hoare triple {15421#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {15358#true} is VALID [2022-02-20 18:03:48,964 INFO L290 TraceCheckUtils]: 40: Hoare triple {15358#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {15358#true} is VALID [2022-02-20 18:03:48,964 INFO L290 TraceCheckUtils]: 41: Hoare triple {15358#true} assume true; {15358#true} is VALID [2022-02-20 18:03:48,964 INFO L284 TraceCheckUtils]: 42: Hoare quadruple {15358#true} {15359#false} #1234#return; {15359#false} is VALID [2022-02-20 18:03:48,965 INFO L290 TraceCheckUtils]: 43: Hoare triple {15359#false} assume { :end_inline_setup_chuck } true;setup_~__cil_tmp3~4#1.base, setup_~__cil_tmp3~4#1.offset := 39, 0;havoc setup_#t~nondet99#1; {15359#false} is VALID [2022-02-20 18:03:48,965 INFO L290 TraceCheckUtils]: 44: Hoare triple {15359#false} assume { :end_inline_setup } true;assume { :begin_inline_test } true;havoc test_#t~nondet55#1, test_#t~nondet56#1, test_#t~nondet57#1, test_#t~nondet58#1, test_#t~nondet59#1, test_#t~nondet60#1, test_#t~nondet61#1, test_#t~nondet62#1, test_#t~nondet63#1, test_#t~nondet64#1, test_#t~nondet65#1, test_~op1~0#1, test_~op2~0#1, test_~op3~0#1, test_~op4~0#1, test_~op5~0#1, test_~op6~0#1, test_~op7~0#1, test_~op8~0#1, test_~op9~0#1, test_~op10~0#1, test_~op11~0#1, test_~splverifierCounter~0#1, test_~tmp~9#1, test_~tmp___0~3#1, test_~tmp___1~1#1, test_~tmp___2~1#1, test_~tmp___3~0#1, test_~tmp___4~0#1, test_~tmp___5~0#1, test_~tmp___6~0#1, test_~tmp___7~0#1, test_~tmp___8~0#1, test_~tmp___9~0#1;havoc test_~op1~0#1;havoc test_~op2~0#1;havoc test_~op3~0#1;havoc test_~op4~0#1;havoc test_~op5~0#1;havoc test_~op6~0#1;havoc test_~op7~0#1;havoc test_~op8~0#1;havoc test_~op9~0#1;havoc test_~op10~0#1;havoc test_~op11~0#1;havoc test_~splverifierCounter~0#1;havoc test_~tmp~9#1;havoc test_~tmp___0~3#1;havoc test_~tmp___1~1#1;havoc test_~tmp___2~1#1;havoc test_~tmp___3~0#1;havoc test_~tmp___4~0#1;havoc test_~tmp___5~0#1;havoc test_~tmp___6~0#1;havoc test_~tmp___7~0#1;havoc test_~tmp___8~0#1;havoc test_~tmp___9~0#1;test_~op1~0#1 := 0;test_~op2~0#1 := 0;test_~op3~0#1 := 0;test_~op4~0#1 := 0;test_~op5~0#1 := 0;test_~op6~0#1 := 0;test_~op7~0#1 := 0;test_~op8~0#1 := 0;test_~op9~0#1 := 0;test_~op10~0#1 := 0;test_~op11~0#1 := 0;test_~splverifierCounter~0#1 := 0; {15359#false} is VALID [2022-02-20 18:03:48,965 INFO L290 TraceCheckUtils]: 45: Hoare triple {15359#false} assume !false; {15359#false} is VALID [2022-02-20 18:03:48,965 INFO L290 TraceCheckUtils]: 46: Hoare triple {15359#false} assume test_~splverifierCounter~0#1 < 4; {15359#false} is VALID [2022-02-20 18:03:48,965 INFO L290 TraceCheckUtils]: 47: Hoare triple {15359#false} test_~splverifierCounter~0#1 := 1 + test_~splverifierCounter~0#1; {15359#false} is VALID [2022-02-20 18:03:48,965 INFO L290 TraceCheckUtils]: 48: Hoare triple {15359#false} assume 0 == test_~op1~0#1;assume -2147483648 <= test_#t~nondet55#1 && test_#t~nondet55#1 <= 2147483647;test_~tmp___9~0#1 := test_#t~nondet55#1;havoc test_#t~nondet55#1; {15359#false} is VALID [2022-02-20 18:03:48,965 INFO L290 TraceCheckUtils]: 49: Hoare triple {15359#false} assume !(0 != test_~tmp___9~0#1); {15359#false} is VALID [2022-02-20 18:03:48,965 INFO L290 TraceCheckUtils]: 50: Hoare triple {15359#false} assume 0 == test_~op2~0#1;assume -2147483648 <= test_#t~nondet56#1 && test_#t~nondet56#1 <= 2147483647;test_~tmp___8~0#1 := test_#t~nondet56#1;havoc test_#t~nondet56#1; {15359#false} is VALID [2022-02-20 18:03:48,966 INFO L290 TraceCheckUtils]: 51: Hoare triple {15359#false} assume 0 != test_~tmp___8~0#1;test_~op2~0#1 := 1; {15359#false} is VALID [2022-02-20 18:03:48,966 INFO L290 TraceCheckUtils]: 52: Hoare triple {15359#false} assume !false; {15359#false} is VALID [2022-02-20 18:03:48,966 INFO L290 TraceCheckUtils]: 53: Hoare triple {15359#false} assume !(test_~splverifierCounter~0#1 < 4); {15359#false} is VALID [2022-02-20 18:03:48,966 INFO L290 TraceCheckUtils]: 54: Hoare triple {15359#false} assume { :begin_inline_bobToRjh } true;havoc bobToRjh_#t~ret92#1, bobToRjh_#t~ret93#1, bobToRjh_#t~ret94#1, bobToRjh_#t~ret95#1, bobToRjh_~tmp~19#1, bobToRjh_~tmp___0~8#1, bobToRjh_~tmp___1~5#1;havoc bobToRjh_~tmp~19#1;havoc bobToRjh_~tmp___0~8#1;havoc bobToRjh_~tmp___1~5#1;call bobToRjh_#t~ret92#1 := puts(35, 0);assume -2147483648 <= bobToRjh_#t~ret92#1 && bobToRjh_#t~ret92#1 <= 2147483647;havoc bobToRjh_#t~ret92#1; {15359#false} is VALID [2022-02-20 18:03:48,966 INFO L272 TraceCheckUtils]: 55: Hoare triple {15359#false} call sendEmail(~bob~0, ~rjh~0); {15359#false} is VALID [2022-02-20 18:03:48,966 INFO L290 TraceCheckUtils]: 56: Hoare triple {15359#false} ~sender#1 := #in~sender#1;~receiver#1 := #in~receiver#1;havoc ~email~0#1;havoc ~tmp~16#1;assume { :begin_inline_createEmail } true;createEmail_#in~from#1, createEmail_#in~to#1 := 0, ~receiver#1;havoc createEmail_#res#1;havoc createEmail_~from#1, createEmail_~to#1, createEmail_~retValue_acc~16#1, createEmail_~msg~0#1;createEmail_~from#1 := createEmail_#in~from#1;createEmail_~to#1 := createEmail_#in~to#1;havoc createEmail_~retValue_acc~16#1;havoc createEmail_~msg~0#1;createEmail_~msg~0#1 := 1; {15359#false} is VALID [2022-02-20 18:03:48,966 INFO L272 TraceCheckUtils]: 57: Hoare triple {15359#false} call setEmailFrom(createEmail_~msg~0#1, createEmail_~from#1); {15424#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} is VALID [2022-02-20 18:03:48,967 INFO L290 TraceCheckUtils]: 58: Hoare triple {15424#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} ~handle := #in~handle;~value := #in~value; {15358#true} is VALID [2022-02-20 18:03:48,967 INFO L290 TraceCheckUtils]: 59: Hoare triple {15358#true} assume 1 == ~handle;~__ste_email_from0~0 := ~value; {15358#true} is VALID [2022-02-20 18:03:48,967 INFO L290 TraceCheckUtils]: 60: Hoare triple {15358#true} assume true; {15358#true} is VALID [2022-02-20 18:03:48,967 INFO L284 TraceCheckUtils]: 61: Hoare quadruple {15358#true} {15359#false} #1210#return; {15359#false} is VALID [2022-02-20 18:03:48,967 INFO L272 TraceCheckUtils]: 62: Hoare triple {15359#false} call setEmailTo(createEmail_~msg~0#1, createEmail_~to#1); {15425#(and (= ~__ste_email_to0~0 |old(~__ste_email_to0~0)|) (= ~__ste_email_to1~0 |old(~__ste_email_to1~0)|))} is VALID [2022-02-20 18:03:48,967 INFO L290 TraceCheckUtils]: 63: Hoare triple {15425#(and (= ~__ste_email_to0~0 |old(~__ste_email_to0~0)|) (= ~__ste_email_to1~0 |old(~__ste_email_to1~0)|))} ~handle := #in~handle;~value := #in~value; {15358#true} is VALID [2022-02-20 18:03:48,967 INFO L290 TraceCheckUtils]: 64: Hoare triple {15358#true} assume 1 == ~handle;~__ste_email_to0~0 := ~value; {15358#true} is VALID [2022-02-20 18:03:48,967 INFO L290 TraceCheckUtils]: 65: Hoare triple {15358#true} assume true; {15358#true} is VALID [2022-02-20 18:03:48,968 INFO L284 TraceCheckUtils]: 66: Hoare quadruple {15358#true} {15359#false} #1212#return; {15359#false} is VALID [2022-02-20 18:03:48,968 INFO L290 TraceCheckUtils]: 67: Hoare triple {15359#false} createEmail_~retValue_acc~16#1 := createEmail_~msg~0#1;createEmail_#res#1 := createEmail_~retValue_acc~16#1; {15359#false} is VALID [2022-02-20 18:03:48,968 INFO L290 TraceCheckUtils]: 68: Hoare triple {15359#false} #t~ret83#1 := createEmail_#res#1;assume { :end_inline_createEmail } true;assume -2147483648 <= #t~ret83#1 && #t~ret83#1 <= 2147483647;~tmp~16#1 := #t~ret83#1;havoc #t~ret83#1;~email~0#1 := ~tmp~16#1; {15359#false} is VALID [2022-02-20 18:03:48,968 INFO L272 TraceCheckUtils]: 69: Hoare triple {15359#false} call outgoing(~sender#1, ~email~0#1); {15359#false} is VALID [2022-02-20 18:03:48,968 INFO L290 TraceCheckUtils]: 70: Hoare triple {15359#false} ~client#1 := #in~client#1;~msg#1 := #in~msg#1;assume { :begin_inline_sign } true;sign_#in~client#1, sign_#in~msg#1 := ~client#1, ~msg#1;havoc sign_#t~ret85#1, sign_~client#1, sign_~msg#1, sign_~privkey~1#1, sign_~tmp~17#1;sign_~client#1 := sign_#in~client#1;sign_~msg#1 := sign_#in~msg#1;havoc sign_~privkey~1#1;havoc sign_~tmp~17#1; {15359#false} is VALID [2022-02-20 18:03:48,968 INFO L272 TraceCheckUtils]: 71: Hoare triple {15359#false} call sign_#t~ret85#1 := getClientPrivateKey(sign_~client#1); {15358#true} is VALID [2022-02-20 18:03:48,969 INFO L290 TraceCheckUtils]: 72: Hoare triple {15358#true} ~handle := #in~handle;havoc ~retValue_acc~36; {15358#true} is VALID [2022-02-20 18:03:48,969 INFO L290 TraceCheckUtils]: 73: Hoare triple {15358#true} assume 1 == ~handle;~retValue_acc~36 := ~__ste_client_privateKey0~0;#res := ~retValue_acc~36; {15358#true} is VALID [2022-02-20 18:03:48,969 INFO L290 TraceCheckUtils]: 74: Hoare triple {15358#true} assume true; {15358#true} is VALID [2022-02-20 18:03:48,969 INFO L284 TraceCheckUtils]: 75: Hoare quadruple {15358#true} {15359#false} #1150#return; {15359#false} is VALID [2022-02-20 18:03:48,969 INFO L290 TraceCheckUtils]: 76: Hoare triple {15359#false} assume -2147483648 <= sign_#t~ret85#1 && sign_#t~ret85#1 <= 2147483647;sign_~tmp~17#1 := sign_#t~ret85#1;havoc sign_#t~ret85#1;sign_~privkey~1#1 := sign_~tmp~17#1; {15359#false} is VALID [2022-02-20 18:03:48,969 INFO L290 TraceCheckUtils]: 77: Hoare triple {15359#false} assume 0 == sign_~privkey~1#1; {15359#false} is VALID [2022-02-20 18:03:48,969 INFO L290 TraceCheckUtils]: 78: Hoare triple {15359#false} assume { :end_inline_sign } true;assume { :begin_inline_outgoing__wrappee__AddressBook } true;outgoing__wrappee__AddressBook_#in~client#1, outgoing__wrappee__AddressBook_#in~msg#1 := ~client#1, ~msg#1;havoc outgoing__wrappee__AddressBook_#t~ret71#1, outgoing__wrappee__AddressBook_#t~ret72#1, outgoing__wrappee__AddressBook_#t~ret73#1, outgoing__wrappee__AddressBook_#t~ret74#1, outgoing__wrappee__AddressBook_#t~ret75#1, outgoing__wrappee__AddressBook_#t~ret76#1, outgoing__wrappee__AddressBook_~client#1, outgoing__wrappee__AddressBook_~msg#1, outgoing__wrappee__AddressBook_~size~0#1, outgoing__wrappee__AddressBook_~tmp~13#1, outgoing__wrappee__AddressBook_~receiver~1#1, outgoing__wrappee__AddressBook_~tmp___0~5#1, outgoing__wrappee__AddressBook_~second~0#1, outgoing__wrappee__AddressBook_~tmp___1~2#1, outgoing__wrappee__AddressBook_~tmp___2~2#1;outgoing__wrappee__AddressBook_~client#1 := outgoing__wrappee__AddressBook_#in~client#1;outgoing__wrappee__AddressBook_~msg#1 := outgoing__wrappee__AddressBook_#in~msg#1;havoc outgoing__wrappee__AddressBook_~size~0#1;havoc outgoing__wrappee__AddressBook_~tmp~13#1;havoc outgoing__wrappee__AddressBook_~receiver~1#1;havoc outgoing__wrappee__AddressBook_~tmp___0~5#1;havoc outgoing__wrappee__AddressBook_~second~0#1;havoc outgoing__wrappee__AddressBook_~tmp___1~2#1;havoc outgoing__wrappee__AddressBook_~tmp___2~2#1; {15359#false} is VALID [2022-02-20 18:03:48,969 INFO L272 TraceCheckUtils]: 79: Hoare triple {15359#false} call outgoing__wrappee__AddressBook_#t~ret71#1 := getClientAddressBookSize(outgoing__wrappee__AddressBook_~client#1); {15358#true} is VALID [2022-02-20 18:03:48,970 INFO L290 TraceCheckUtils]: 80: Hoare triple {15358#true} ~handle := #in~handle;havoc ~retValue_acc~30; {15358#true} is VALID [2022-02-20 18:03:48,970 INFO L290 TraceCheckUtils]: 81: Hoare triple {15358#true} assume 1 == ~handle;~retValue_acc~30 := ~__ste_ClientAddressBook_size0~0;#res := ~retValue_acc~30; {15358#true} is VALID [2022-02-20 18:03:48,970 INFO L290 TraceCheckUtils]: 82: Hoare triple {15358#true} assume true; {15358#true} is VALID [2022-02-20 18:03:48,970 INFO L284 TraceCheckUtils]: 83: Hoare quadruple {15358#true} {15359#false} #1152#return; {15359#false} is VALID [2022-02-20 18:03:48,970 INFO L290 TraceCheckUtils]: 84: Hoare triple {15359#false} assume -2147483648 <= outgoing__wrappee__AddressBook_#t~ret71#1 && outgoing__wrappee__AddressBook_#t~ret71#1 <= 2147483647;outgoing__wrappee__AddressBook_~tmp~13#1 := outgoing__wrappee__AddressBook_#t~ret71#1;havoc outgoing__wrappee__AddressBook_#t~ret71#1;outgoing__wrappee__AddressBook_~size~0#1 := outgoing__wrappee__AddressBook_~tmp~13#1; {15359#false} is VALID [2022-02-20 18:03:48,970 INFO L290 TraceCheckUtils]: 85: Hoare triple {15359#false} assume !(0 != outgoing__wrappee__AddressBook_~size~0#1); {15359#false} is VALID [2022-02-20 18:03:48,970 INFO L272 TraceCheckUtils]: 86: Hoare triple {15359#false} call outgoing__wrappee__Encrypt(outgoing__wrappee__AddressBook_~client#1, outgoing__wrappee__AddressBook_~msg#1); {15359#false} is VALID [2022-02-20 18:03:48,971 INFO L290 TraceCheckUtils]: 87: Hoare triple {15359#false} ~client#1 := #in~client#1;~msg#1 := #in~msg#1;havoc ~receiver~0#1;havoc ~tmp~12#1;havoc ~pubkey~0#1;havoc ~tmp___0~4#1; {15359#false} is VALID [2022-02-20 18:03:48,971 INFO L272 TraceCheckUtils]: 88: Hoare triple {15359#false} call #t~ret69#1 := getEmailTo(~msg#1); {15358#true} is VALID [2022-02-20 18:03:48,971 INFO L290 TraceCheckUtils]: 89: Hoare triple {15358#true} ~handle := #in~handle;havoc ~retValue_acc~3; {15358#true} is VALID [2022-02-20 18:03:48,971 INFO L290 TraceCheckUtils]: 90: Hoare triple {15358#true} assume 1 == ~handle;~retValue_acc~3 := ~__ste_email_to0~0;#res := ~retValue_acc~3; {15358#true} is VALID [2022-02-20 18:03:48,971 INFO L290 TraceCheckUtils]: 91: Hoare triple {15358#true} assume true; {15358#true} is VALID [2022-02-20 18:03:48,971 INFO L284 TraceCheckUtils]: 92: Hoare quadruple {15358#true} {15359#false} #1170#return; {15359#false} is VALID [2022-02-20 18:03:48,971 INFO L290 TraceCheckUtils]: 93: Hoare triple {15359#false} assume -2147483648 <= #t~ret69#1 && #t~ret69#1 <= 2147483647;~tmp~12#1 := #t~ret69#1;havoc #t~ret69#1;~receiver~0#1 := ~tmp~12#1; {15359#false} is VALID [2022-02-20 18:03:48,971 INFO L272 TraceCheckUtils]: 94: Hoare triple {15359#false} call #t~ret70#1 := findPublicKey(~client#1, ~receiver~0#1); {15358#true} is VALID [2022-02-20 18:03:48,972 INFO L290 TraceCheckUtils]: 95: Hoare triple {15358#true} ~handle := #in~handle;~userid := #in~userid;havoc ~retValue_acc~41; {15358#true} is VALID [2022-02-20 18:03:48,972 INFO L290 TraceCheckUtils]: 96: Hoare triple {15358#true} assume 1 == ~handle; {15358#true} is VALID [2022-02-20 18:03:48,972 INFO L290 TraceCheckUtils]: 97: Hoare triple {15358#true} assume ~userid == ~__ste_Client_Keyring0_User0~0;~retValue_acc~41 := ~__ste_Client_Keyring0_PublicKey0~0;#res := ~retValue_acc~41; {15358#true} is VALID [2022-02-20 18:03:48,972 INFO L290 TraceCheckUtils]: 98: Hoare triple {15358#true} assume true; {15358#true} is VALID [2022-02-20 18:03:48,972 INFO L284 TraceCheckUtils]: 99: Hoare quadruple {15358#true} {15359#false} #1172#return; {15359#false} is VALID [2022-02-20 18:03:48,972 INFO L290 TraceCheckUtils]: 100: Hoare triple {15359#false} assume -2147483648 <= #t~ret70#1 && #t~ret70#1 <= 2147483647;~tmp___0~4#1 := #t~ret70#1;havoc #t~ret70#1;~pubkey~0#1 := ~tmp___0~4#1; {15359#false} is VALID [2022-02-20 18:03:48,972 INFO L290 TraceCheckUtils]: 101: Hoare triple {15359#false} assume !(0 != ~pubkey~0#1); {15359#false} is VALID [2022-02-20 18:03:48,972 INFO L290 TraceCheckUtils]: 102: Hoare triple {15359#false} assume { :begin_inline_outgoing__wrappee__Keys } true;outgoing__wrappee__Keys_#in~client#1, outgoing__wrappee__Keys_#in~msg#1 := ~client#1, ~msg#1;havoc outgoing__wrappee__Keys_#t~ret68#1, outgoing__wrappee__Keys_~client#1, outgoing__wrappee__Keys_~msg#1, outgoing__wrappee__Keys_~tmp~11#1;outgoing__wrappee__Keys_~client#1 := outgoing__wrappee__Keys_#in~client#1;outgoing__wrappee__Keys_~msg#1 := outgoing__wrappee__Keys_#in~msg#1;havoc outgoing__wrappee__Keys_~tmp~11#1;assume { :begin_inline_getClientId } true;getClientId_#in~handle#1 := outgoing__wrappee__Keys_~client#1;havoc getClientId_#res#1;havoc getClientId_~handle#1, getClientId_~retValue_acc~43#1;getClientId_~handle#1 := getClientId_#in~handle#1;havoc getClientId_~retValue_acc~43#1; {15359#false} is VALID [2022-02-20 18:03:48,972 INFO L290 TraceCheckUtils]: 103: Hoare triple {15359#false} assume 1 == getClientId_~handle#1;getClientId_~retValue_acc~43#1 := ~__ste_client_idCounter0~0;getClientId_#res#1 := getClientId_~retValue_acc~43#1; {15359#false} is VALID [2022-02-20 18:03:48,973 INFO L290 TraceCheckUtils]: 104: Hoare triple {15359#false} outgoing__wrappee__Keys_#t~ret68#1 := getClientId_#res#1;assume { :end_inline_getClientId } true;assume -2147483648 <= outgoing__wrappee__Keys_#t~ret68#1 && outgoing__wrappee__Keys_#t~ret68#1 <= 2147483647;outgoing__wrappee__Keys_~tmp~11#1 := outgoing__wrappee__Keys_#t~ret68#1;havoc outgoing__wrappee__Keys_#t~ret68#1; {15359#false} is VALID [2022-02-20 18:03:48,973 INFO L272 TraceCheckUtils]: 105: Hoare triple {15359#false} call setEmailFrom(outgoing__wrappee__Keys_~msg#1, outgoing__wrappee__Keys_~tmp~11#1); {15424#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} is VALID [2022-02-20 18:03:48,973 INFO L290 TraceCheckUtils]: 106: Hoare triple {15424#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} ~handle := #in~handle;~value := #in~value; {15358#true} is VALID [2022-02-20 18:03:48,973 INFO L290 TraceCheckUtils]: 107: Hoare triple {15358#true} assume 1 == ~handle;~__ste_email_from0~0 := ~value; {15358#true} is VALID [2022-02-20 18:03:48,973 INFO L290 TraceCheckUtils]: 108: Hoare triple {15358#true} assume true; {15358#true} is VALID [2022-02-20 18:03:48,973 INFO L284 TraceCheckUtils]: 109: Hoare quadruple {15358#true} {15359#false} #1178#return; {15359#false} is VALID [2022-02-20 18:03:48,973 INFO L290 TraceCheckUtils]: 110: Hoare triple {15359#false} assume { :begin_inline_mail } true;mail_#in~client#1, mail_#in~msg#1 := outgoing__wrappee__Keys_~client#1, outgoing__wrappee__Keys_~msg#1;havoc mail_#t~ret66#1, mail_#t~ret67#1, mail_~client#1, mail_~msg#1, mail_~__utac__ad__arg1~0#1, mail_~tmp~10#1;mail_~client#1 := mail_#in~client#1;mail_~msg#1 := mail_#in~msg#1;havoc mail_~__utac__ad__arg1~0#1;havoc mail_~tmp~10#1;mail_~__utac__ad__arg1~0#1 := mail_~msg#1;assume { :begin_inline___utac_acc__EncryptAutoResponder_spec__2 } true;__utac_acc__EncryptAutoResponder_spec__2_#in~msg#1 := mail_~__utac__ad__arg1~0#1;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1, __utac_acc__EncryptAutoResponder_spec__2_#t~nondet29#1, __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1, __utac_acc__EncryptAutoResponder_spec__2_~msg#1, __utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.base, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.offset;__utac_acc__EncryptAutoResponder_spec__2_~msg#1 := __utac_acc__EncryptAutoResponder_spec__2_#in~msg#1;havoc __utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1;havoc __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.base, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.offset;call __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1 := puts(15, 0);assume -2147483648 <= __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1 && __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1 <= 2147483647;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1;__utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.base, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.offset := 16, 0;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~nondet29#1; {15359#false} is VALID [2022-02-20 18:03:48,973 INFO L290 TraceCheckUtils]: 111: Hoare triple {15359#false} assume 0 != ~in_encrypted~0; {15359#false} is VALID [2022-02-20 18:03:48,973 INFO L272 TraceCheckUtils]: 112: Hoare triple {15359#false} call __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1 := isEncrypted(__utac_acc__EncryptAutoResponder_spec__2_~msg#1); {15358#true} is VALID [2022-02-20 18:03:48,974 INFO L290 TraceCheckUtils]: 113: Hoare triple {15358#true} ~handle := #in~handle;havoc ~retValue_acc~6; {15358#true} is VALID [2022-02-20 18:03:48,974 INFO L290 TraceCheckUtils]: 114: Hoare triple {15358#true} assume 1 == ~handle;~retValue_acc~6 := ~__ste_email_isEncrypted0~0;#res := ~retValue_acc~6; {15358#true} is VALID [2022-02-20 18:03:48,974 INFO L290 TraceCheckUtils]: 115: Hoare triple {15358#true} assume true; {15358#true} is VALID [2022-02-20 18:03:48,974 INFO L284 TraceCheckUtils]: 116: Hoare quadruple {15358#true} {15359#false} #1180#return; {15359#false} is VALID [2022-02-20 18:03:48,974 INFO L290 TraceCheckUtils]: 117: Hoare triple {15359#false} assume -2147483648 <= __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1 && __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1 <= 2147483647;__utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1 := __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1; {15359#false} is VALID [2022-02-20 18:03:48,974 INFO L290 TraceCheckUtils]: 118: Hoare triple {15359#false} assume !(0 != __utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1);assume { :begin_inline___automaton_fail } true; {15359#false} is VALID [2022-02-20 18:03:48,974 INFO L290 TraceCheckUtils]: 119: Hoare triple {15359#false} assume !false; {15359#false} is VALID [2022-02-20 18:03:48,975 INFO L134 CoverageAnalysis]: Checked inductivity of 30 backedges. 6 proven. 0 refuted. 0 times theorem prover too weak. 24 trivial. 0 not checked. [2022-02-20 18:03:48,975 INFO L144 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-02-20 18:03:48,975 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [786783840] [2022-02-20 18:03:48,975 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleSmtInterpolCraig [786783840] provided 1 perfect and 0 imperfect interpolant sequences [2022-02-20 18:03:48,975 INFO L191 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-02-20 18:03:48,975 INFO L204 FreeRefinementEngine]: Number of different interpolants: perfect sequences [9] imperfect sequences [] total 9 [2022-02-20 18:03:48,975 INFO L118 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [584971599] [2022-02-20 18:03:48,975 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-02-20 18:03:48,976 INFO L78 Accepts]: Start accepts. Automaton has has 9 states, 8 states have (on average 9.75) internal successors, (78), 5 states have internal predecessors, (78), 3 states have call successors, (17), 6 states have call predecessors, (17), 2 states have return successors, (14), 2 states have call predecessors, (14), 3 states have call successors, (14) Word has length 120 [2022-02-20 18:03:48,976 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-02-20 18:03:48,976 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with has 9 states, 8 states have (on average 9.75) internal successors, (78), 5 states have internal predecessors, (78), 3 states have call successors, (17), 6 states have call predecessors, (17), 2 states have return successors, (14), 2 states have call predecessors, (14), 3 states have call successors, (14) [2022-02-20 18:03:49,054 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 109 edges. 109 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 18:03:49,054 INFO L546 AbstractCegarLoop]: INTERPOLANT automaton has 9 states [2022-02-20 18:03:49,054 INFO L108 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2022-02-20 18:03:49,055 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 9 interpolants. [2022-02-20 18:03:49,055 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=15, Invalid=57, Unknown=0, NotChecked=0, Total=72 [2022-02-20 18:03:49,056 INFO L87 Difference]: Start difference. First operand 470 states and 725 transitions. Second operand has 9 states, 8 states have (on average 9.75) internal successors, (78), 5 states have internal predecessors, (78), 3 states have call successors, (17), 6 states have call predecessors, (17), 2 states have return successors, (14), 2 states have call predecessors, (14), 3 states have call successors, (14) [2022-02-20 18:03:56,811 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 18:03:56,811 INFO L93 Difference]: Finished difference Result 1020 states and 1592 transitions. [2022-02-20 18:03:56,812 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 11 states. [2022-02-20 18:03:56,812 INFO L78 Accepts]: Start accepts. Automaton has has 9 states, 8 states have (on average 9.75) internal successors, (78), 5 states have internal predecessors, (78), 3 states have call successors, (17), 6 states have call predecessors, (17), 2 states have return successors, (14), 2 states have call predecessors, (14), 3 states have call successors, (14) Word has length 120 [2022-02-20 18:03:56,813 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-02-20 18:03:56,813 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 9 states, 8 states have (on average 9.75) internal successors, (78), 5 states have internal predecessors, (78), 3 states have call successors, (17), 6 states have call predecessors, (17), 2 states have return successors, (14), 2 states have call predecessors, (14), 3 states have call successors, (14) [2022-02-20 18:03:56,828 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 11 states to 11 states and 1356 transitions. [2022-02-20 18:03:56,828 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 9 states, 8 states have (on average 9.75) internal successors, (78), 5 states have internal predecessors, (78), 3 states have call successors, (17), 6 states have call predecessors, (17), 2 states have return successors, (14), 2 states have call predecessors, (14), 3 states have call successors, (14) [2022-02-20 18:03:56,841 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 11 states to 11 states and 1356 transitions. [2022-02-20 18:03:56,841 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with 11 states and 1356 transitions. [2022-02-20 18:03:58,081 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 1356 edges. 1356 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 18:03:58,098 INFO L225 Difference]: With dead ends: 1020 [2022-02-20 18:03:58,098 INFO L226 Difference]: Without dead ends: 573 [2022-02-20 18:03:58,099 INFO L932 BasicCegarLoop]: 0 DeclaredPredicates, 46 GetRequests, 31 SyntacticMatches, 0 SemanticMatches, 15 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 31 ImplicationChecksByTransitivity, 0.1s TimeCoverageRelationStatistics Valid=73, Invalid=199, Unknown=0, NotChecked=0, Total=272 [2022-02-20 18:03:58,099 INFO L933 BasicCegarLoop]: 621 mSDtfsCounter, 1552 mSDsluCounter, 938 mSDsCounter, 0 mSdLazyCounter, 2011 mSolverCounterSat, 554 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 3.3s Time, 0 mProtectedPredicate, 0 mProtectedAction, 1572 SdHoareTripleChecker+Valid, 1559 SdHoareTripleChecker+Invalid, 2565 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 554 IncrementalHoareTripleChecker+Valid, 2011 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 3.4s IncrementalHoareTripleChecker+Time [2022-02-20 18:03:58,100 INFO L934 BasicCegarLoop]: SdHoareTripleChecker [1572 Valid, 1559 Invalid, 2565 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [554 Valid, 2011 Invalid, 0 Unknown, 0 Unchecked, 3.4s Time] [2022-02-20 18:03:58,100 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 573 states. [2022-02-20 18:03:58,193 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 573 to 470. [2022-02-20 18:03:58,193 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-02-20 18:03:58,194 INFO L82 GeneralOperation]: Start isEquivalent. First operand 573 states. Second operand has 470 states, 362 states have (on average 1.5607734806629834) internal successors, (565), 368 states have internal predecessors, (565), 77 states have call successors, (77), 28 states have call predecessors, (77), 30 states have return successors, (82), 75 states have call predecessors, (82), 76 states have call successors, (82) [2022-02-20 18:03:58,195 INFO L74 IsIncluded]: Start isIncluded. First operand 573 states. Second operand has 470 states, 362 states have (on average 1.5607734806629834) internal successors, (565), 368 states have internal predecessors, (565), 77 states have call successors, (77), 28 states have call predecessors, (77), 30 states have return successors, (82), 75 states have call predecessors, (82), 76 states have call successors, (82) [2022-02-20 18:03:58,196 INFO L87 Difference]: Start difference. First operand 573 states. Second operand has 470 states, 362 states have (on average 1.5607734806629834) internal successors, (565), 368 states have internal predecessors, (565), 77 states have call successors, (77), 28 states have call predecessors, (77), 30 states have return successors, (82), 75 states have call predecessors, (82), 76 states have call successors, (82) [2022-02-20 18:03:58,212 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 18:03:58,212 INFO L93 Difference]: Finished difference Result 573 states and 898 transitions. [2022-02-20 18:03:58,212 INFO L276 IsEmpty]: Start isEmpty. Operand 573 states and 898 transitions. [2022-02-20 18:03:58,215 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 18:03:58,215 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 18:03:58,216 INFO L74 IsIncluded]: Start isIncluded. First operand has 470 states, 362 states have (on average 1.5607734806629834) internal successors, (565), 368 states have internal predecessors, (565), 77 states have call successors, (77), 28 states have call predecessors, (77), 30 states have return successors, (82), 75 states have call predecessors, (82), 76 states have call successors, (82) Second operand 573 states. [2022-02-20 18:03:58,217 INFO L87 Difference]: Start difference. First operand has 470 states, 362 states have (on average 1.5607734806629834) internal successors, (565), 368 states have internal predecessors, (565), 77 states have call successors, (77), 28 states have call predecessors, (77), 30 states have return successors, (82), 75 states have call predecessors, (82), 76 states have call successors, (82) Second operand 573 states. [2022-02-20 18:03:58,233 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 18:03:58,233 INFO L93 Difference]: Finished difference Result 573 states and 898 transitions. [2022-02-20 18:03:58,233 INFO L276 IsEmpty]: Start isEmpty. Operand 573 states and 898 transitions. [2022-02-20 18:03:58,236 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 18:03:58,236 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 18:03:58,236 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-02-20 18:03:58,236 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-02-20 18:03:58,237 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 470 states, 362 states have (on average 1.5607734806629834) internal successors, (565), 368 states have internal predecessors, (565), 77 states have call successors, (77), 28 states have call predecessors, (77), 30 states have return successors, (82), 75 states have call predecessors, (82), 76 states have call successors, (82) [2022-02-20 18:03:58,250 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 470 states to 470 states and 724 transitions. [2022-02-20 18:03:58,250 INFO L78 Accepts]: Start accepts. Automaton has 470 states and 724 transitions. Word has length 120 [2022-02-20 18:03:58,250 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-02-20 18:03:58,250 INFO L470 AbstractCegarLoop]: Abstraction has 470 states and 724 transitions. [2022-02-20 18:03:58,251 INFO L471 AbstractCegarLoop]: INTERPOLANT automaton has has 9 states, 8 states have (on average 9.75) internal successors, (78), 5 states have internal predecessors, (78), 3 states have call successors, (17), 6 states have call predecessors, (17), 2 states have return successors, (14), 2 states have call predecessors, (14), 3 states have call successors, (14) [2022-02-20 18:03:58,251 INFO L276 IsEmpty]: Start isEmpty. Operand 470 states and 724 transitions. [2022-02-20 18:03:58,252 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 122 [2022-02-20 18:03:58,252 INFO L506 BasicCegarLoop]: Found error trace [2022-02-20 18:03:58,253 INFO L514 BasicCegarLoop]: trace histogram [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] [2022-02-20 18:03:58,253 WARN L452 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable5 [2022-02-20 18:03:58,253 INFO L402 AbstractCegarLoop]: === Iteration 7 === Targeting outgoing__wrappee__EncryptErr0ASSERT_VIOLATIONERROR_FUNCTION === [outgoing__wrappee__EncryptErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-02-20 18:03:58,253 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-02-20 18:03:58,253 INFO L85 PathProgramCache]: Analyzing trace with hash -1575919260, now seen corresponding path program 2 times [2022-02-20 18:03:58,254 INFO L126 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-02-20 18:03:58,254 INFO L338 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [1210420723] [2022-02-20 18:03:58,254 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 18:03:58,254 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-02-20 18:03:58,285 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:58,308 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 6 [2022-02-20 18:03:58,309 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:58,312 INFO L290 TraceCheckUtils]: 0: Hoare triple {18715#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {18652#true} is VALID [2022-02-20 18:03:58,312 INFO L290 TraceCheckUtils]: 1: Hoare triple {18652#true} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {18652#true} is VALID [2022-02-20 18:03:58,312 INFO L290 TraceCheckUtils]: 2: Hoare triple {18652#true} assume true; {18652#true} is VALID [2022-02-20 18:03:58,312 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {18652#true} {18652#true} #1224#return; {18652#true} is VALID [2022-02-20 18:03:58,317 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 12 [2022-02-20 18:03:58,318 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:58,320 INFO L290 TraceCheckUtils]: 0: Hoare triple {18716#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {18652#true} is VALID [2022-02-20 18:03:58,320 INFO L290 TraceCheckUtils]: 1: Hoare triple {18652#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {18652#true} is VALID [2022-02-20 18:03:58,320 INFO L290 TraceCheckUtils]: 2: Hoare triple {18652#true} assume true; {18652#true} is VALID [2022-02-20 18:03:58,320 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {18652#true} {18652#true} #1226#return; {18652#true} is VALID [2022-02-20 18:03:58,320 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 18 [2022-02-20 18:03:58,321 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:58,323 INFO L290 TraceCheckUtils]: 0: Hoare triple {18715#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {18652#true} is VALID [2022-02-20 18:03:58,323 INFO L290 TraceCheckUtils]: 1: Hoare triple {18652#true} assume !(1 == ~handle); {18652#true} is VALID [2022-02-20 18:03:58,323 INFO L290 TraceCheckUtils]: 2: Hoare triple {18652#true} assume 2 == ~handle;~__ste_client_idCounter1~0 := ~value; {18652#true} is VALID [2022-02-20 18:03:58,323 INFO L290 TraceCheckUtils]: 3: Hoare triple {18652#true} assume true; {18652#true} is VALID [2022-02-20 18:03:58,323 INFO L284 TraceCheckUtils]: 4: Hoare quadruple {18652#true} {18652#true} #1228#return; {18652#true} is VALID [2022-02-20 18:03:58,324 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 25 [2022-02-20 18:03:58,325 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:58,327 INFO L290 TraceCheckUtils]: 0: Hoare triple {18716#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {18652#true} is VALID [2022-02-20 18:03:58,327 INFO L290 TraceCheckUtils]: 1: Hoare triple {18652#true} assume !(1 == ~handle); {18652#true} is VALID [2022-02-20 18:03:58,327 INFO L290 TraceCheckUtils]: 2: Hoare triple {18652#true} assume 2 == ~handle;~__ste_client_privateKey1~0 := ~value; {18652#true} is VALID [2022-02-20 18:03:58,327 INFO L290 TraceCheckUtils]: 3: Hoare triple {18652#true} assume true; {18652#true} is VALID [2022-02-20 18:03:58,327 INFO L284 TraceCheckUtils]: 4: Hoare quadruple {18652#true} {18652#true} #1230#return; {18652#true} is VALID [2022-02-20 18:03:58,327 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 32 [2022-02-20 18:03:58,329 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:58,342 INFO L290 TraceCheckUtils]: 0: Hoare triple {18715#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {18717#(= setClientId_~handle |setClientId_#in~handle|)} is VALID [2022-02-20 18:03:58,343 INFO L290 TraceCheckUtils]: 1: Hoare triple {18717#(= setClientId_~handle |setClientId_#in~handle|)} assume !(1 == ~handle); {18717#(= setClientId_~handle |setClientId_#in~handle|)} is VALID [2022-02-20 18:03:58,343 INFO L290 TraceCheckUtils]: 2: Hoare triple {18717#(= setClientId_~handle |setClientId_#in~handle|)} assume 2 == ~handle;~__ste_client_idCounter1~0 := ~value; {18718#(= 2 |setClientId_#in~handle|)} is VALID [2022-02-20 18:03:58,343 INFO L290 TraceCheckUtils]: 3: Hoare triple {18718#(= 2 |setClientId_#in~handle|)} assume true; {18718#(= 2 |setClientId_#in~handle|)} is VALID [2022-02-20 18:03:58,344 INFO L284 TraceCheckUtils]: 4: Hoare quadruple {18718#(= 2 |setClientId_#in~handle|)} {18672#(= 3 |ULTIMATE.start_setup_chuck__wrappee__Base_~chuck___0#1|)} #1232#return; {18653#false} is VALID [2022-02-20 18:03:58,344 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 39 [2022-02-20 18:03:58,346 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:58,348 INFO L290 TraceCheckUtils]: 0: Hoare triple {18716#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {18652#true} is VALID [2022-02-20 18:03:58,348 INFO L290 TraceCheckUtils]: 1: Hoare triple {18652#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {18652#true} is VALID [2022-02-20 18:03:58,348 INFO L290 TraceCheckUtils]: 2: Hoare triple {18652#true} assume true; {18652#true} is VALID [2022-02-20 18:03:58,348 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {18652#true} {18653#false} #1234#return; {18653#false} is VALID [2022-02-20 18:03:58,353 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 58 [2022-02-20 18:03:58,354 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:58,356 INFO L290 TraceCheckUtils]: 0: Hoare triple {18719#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} ~handle := #in~handle;~value := #in~value; {18652#true} is VALID [2022-02-20 18:03:58,357 INFO L290 TraceCheckUtils]: 1: Hoare triple {18652#true} assume 1 == ~handle;~__ste_email_from0~0 := ~value; {18652#true} is VALID [2022-02-20 18:03:58,357 INFO L290 TraceCheckUtils]: 2: Hoare triple {18652#true} assume true; {18652#true} is VALID [2022-02-20 18:03:58,357 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {18652#true} {18653#false} #1210#return; {18653#false} is VALID [2022-02-20 18:03:58,363 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 63 [2022-02-20 18:03:58,364 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:58,367 INFO L290 TraceCheckUtils]: 0: Hoare triple {18720#(and (= ~__ste_email_to0~0 |old(~__ste_email_to0~0)|) (= ~__ste_email_to1~0 |old(~__ste_email_to1~0)|))} ~handle := #in~handle;~value := #in~value; {18652#true} is VALID [2022-02-20 18:03:58,367 INFO L290 TraceCheckUtils]: 1: Hoare triple {18652#true} assume 1 == ~handle;~__ste_email_to0~0 := ~value; {18652#true} is VALID [2022-02-20 18:03:58,367 INFO L290 TraceCheckUtils]: 2: Hoare triple {18652#true} assume true; {18652#true} is VALID [2022-02-20 18:03:58,367 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {18652#true} {18653#false} #1212#return; {18653#false} is VALID [2022-02-20 18:03:58,368 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 72 [2022-02-20 18:03:58,369 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:58,376 INFO L290 TraceCheckUtils]: 0: Hoare triple {18652#true} ~handle := #in~handle;havoc ~retValue_acc~36; {18652#true} is VALID [2022-02-20 18:03:58,377 INFO L290 TraceCheckUtils]: 1: Hoare triple {18652#true} assume 1 == ~handle;~retValue_acc~36 := ~__ste_client_privateKey0~0;#res := ~retValue_acc~36; {18652#true} is VALID [2022-02-20 18:03:58,377 INFO L290 TraceCheckUtils]: 2: Hoare triple {18652#true} assume true; {18652#true} is VALID [2022-02-20 18:03:58,377 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {18652#true} {18653#false} #1150#return; {18653#false} is VALID [2022-02-20 18:03:58,377 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 80 [2022-02-20 18:03:58,378 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:58,380 INFO L290 TraceCheckUtils]: 0: Hoare triple {18652#true} ~handle := #in~handle;havoc ~retValue_acc~30; {18652#true} is VALID [2022-02-20 18:03:58,380 INFO L290 TraceCheckUtils]: 1: Hoare triple {18652#true} assume 1 == ~handle;~retValue_acc~30 := ~__ste_ClientAddressBook_size0~0;#res := ~retValue_acc~30; {18652#true} is VALID [2022-02-20 18:03:58,380 INFO L290 TraceCheckUtils]: 2: Hoare triple {18652#true} assume true; {18652#true} is VALID [2022-02-20 18:03:58,380 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {18652#true} {18653#false} #1152#return; {18653#false} is VALID [2022-02-20 18:03:58,380 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 89 [2022-02-20 18:03:58,381 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:58,383 INFO L290 TraceCheckUtils]: 0: Hoare triple {18652#true} ~handle := #in~handle;havoc ~retValue_acc~3; {18652#true} is VALID [2022-02-20 18:03:58,383 INFO L290 TraceCheckUtils]: 1: Hoare triple {18652#true} assume 1 == ~handle;~retValue_acc~3 := ~__ste_email_to0~0;#res := ~retValue_acc~3; {18652#true} is VALID [2022-02-20 18:03:58,383 INFO L290 TraceCheckUtils]: 2: Hoare triple {18652#true} assume true; {18652#true} is VALID [2022-02-20 18:03:58,383 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {18652#true} {18653#false} #1170#return; {18653#false} is VALID [2022-02-20 18:03:58,383 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 95 [2022-02-20 18:03:58,384 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:58,385 INFO L290 TraceCheckUtils]: 0: Hoare triple {18652#true} ~handle := #in~handle;~userid := #in~userid;havoc ~retValue_acc~41; {18652#true} is VALID [2022-02-20 18:03:58,385 INFO L290 TraceCheckUtils]: 1: Hoare triple {18652#true} assume 1 == ~handle; {18652#true} is VALID [2022-02-20 18:03:58,385 INFO L290 TraceCheckUtils]: 2: Hoare triple {18652#true} assume ~userid == ~__ste_Client_Keyring0_User0~0;~retValue_acc~41 := ~__ste_Client_Keyring0_PublicKey0~0;#res := ~retValue_acc~41; {18652#true} is VALID [2022-02-20 18:03:58,385 INFO L290 TraceCheckUtils]: 3: Hoare triple {18652#true} assume true; {18652#true} is VALID [2022-02-20 18:03:58,385 INFO L284 TraceCheckUtils]: 4: Hoare quadruple {18652#true} {18653#false} #1172#return; {18653#false} is VALID [2022-02-20 18:03:58,385 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 106 [2022-02-20 18:03:58,386 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:58,387 INFO L290 TraceCheckUtils]: 0: Hoare triple {18719#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} ~handle := #in~handle;~value := #in~value; {18652#true} is VALID [2022-02-20 18:03:58,387 INFO L290 TraceCheckUtils]: 1: Hoare triple {18652#true} assume 1 == ~handle;~__ste_email_from0~0 := ~value; {18652#true} is VALID [2022-02-20 18:03:58,387 INFO L290 TraceCheckUtils]: 2: Hoare triple {18652#true} assume true; {18652#true} is VALID [2022-02-20 18:03:58,388 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {18652#true} {18653#false} #1178#return; {18653#false} is VALID [2022-02-20 18:03:58,388 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 113 [2022-02-20 18:03:58,388 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:03:58,389 INFO L290 TraceCheckUtils]: 0: Hoare triple {18652#true} ~handle := #in~handle;havoc ~retValue_acc~6; {18652#true} is VALID [2022-02-20 18:03:58,389 INFO L290 TraceCheckUtils]: 1: Hoare triple {18652#true} assume 1 == ~handle;~retValue_acc~6 := ~__ste_email_isEncrypted0~0;#res := ~retValue_acc~6; {18652#true} is VALID [2022-02-20 18:03:58,390 INFO L290 TraceCheckUtils]: 2: Hoare triple {18652#true} assume true; {18652#true} is VALID [2022-02-20 18:03:58,390 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {18652#true} {18653#false} #1180#return; {18653#false} is VALID [2022-02-20 18:03:58,390 INFO L290 TraceCheckUtils]: 0: Hoare triple {18652#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(28, 2);call #Ultimate.allocInit(12, 3);call #Ultimate.allocInit(10, 4);call #Ultimate.allocInit(12, 5);call #Ultimate.allocInit(10, 6);call #Ultimate.allocInit(18, 7);call #Ultimate.allocInit(16, 8);call #Ultimate.allocInit(21, 9);call #Ultimate.allocInit(13, 10);call #Ultimate.allocInit(16, 11);call #Ultimate.allocInit(25, 12);call #Ultimate.allocInit(17, 13);call #Ultimate.allocInit(17, 14);call #Ultimate.allocInit(13, 15);call #Ultimate.allocInit(17, 16);call #Ultimate.allocInit(30, 17);call #Ultimate.allocInit(9, 18);call #Ultimate.allocInit(21, 19);call #Ultimate.allocInit(30, 20);call #Ultimate.allocInit(9, 21);call #Ultimate.allocInit(21, 22);call #Ultimate.allocInit(30, 23);call #Ultimate.allocInit(9, 24);call #Ultimate.allocInit(25, 25);call #Ultimate.allocInit(30, 26);call #Ultimate.allocInit(9, 27);call #Ultimate.allocInit(25, 28);call #Ultimate.allocInit(4, 29);call write~init~int(37, 29, 0, 1);call write~init~int(115, 29, 1, 1);call write~init~int(10, 29, 2, 1);call write~init~int(0, 29, 3, 1);call #Ultimate.allocInit(10, 30);call #Ultimate.allocInit(34, 31);call #Ultimate.allocInit(30, 32);call #Ultimate.allocInit(16, 33);call #Ultimate.allocInit(20, 34);call #Ultimate.allocInit(44, 35);call #Ultimate.allocInit(44, 36);call #Ultimate.allocInit(9, 37);call #Ultimate.allocInit(9, 38);call #Ultimate.allocInit(11, 39);call #Ultimate.allocInit(19, 40);call #Ultimate.allocInit(4, 41);call write~init~int(37, 41, 0, 1);call write~init~int(100, 41, 1, 1);call write~init~int(10, 41, 2, 1);call write~init~int(0, 41, 3, 1);call #Ultimate.allocInit(4, 42);call write~init~int(37, 42, 0, 1);call write~init~int(100, 42, 1, 1);call write~init~int(10, 42, 2, 1);call write~init~int(0, 42, 3, 1);~__ste_Email_counter~0 := 0;~__ste_email_id0~0 := 0;~__ste_email_id1~0 := 0;~__ste_email_from0~0 := 0;~__ste_email_from1~0 := 0;~__ste_email_to0~0 := 0;~__ste_email_to1~0 := 0;~__ste_email_subject0~0.base, ~__ste_email_subject0~0.offset := 0, 0;~__ste_email_subject1~0.base, ~__ste_email_subject1~0.offset := 0, 0;~__ste_email_body0~0.base, ~__ste_email_body0~0.offset := 0, 0;~__ste_email_body1~0.base, ~__ste_email_body1~0.offset := 0, 0;~__ste_email_isEncrypted0~0 := 0;~__ste_email_isEncrypted1~0 := 0;~__ste_email_encryptionKey0~0 := 0;~__ste_email_encryptionKey1~0 := 0;~__ste_email_isSigned0~0 := 0;~__ste_email_isSigned1~0 := 0;~__ste_email_signKey0~0 := 0;~__ste_email_signKey1~0 := 0;~__ste_email_isSignatureVerified0~0 := 0;~__ste_email_isSignatureVerified1~0 := 0;~__SELECTED_FEATURE_Base~0 := 0;~__SELECTED_FEATURE_Keys~0 := 0;~__SELECTED_FEATURE_Encrypt~0 := 0;~__SELECTED_FEATURE_AutoResponder~0 := 0;~__SELECTED_FEATURE_AddressBook~0 := 0;~__SELECTED_FEATURE_Sign~0 := 0;~__SELECTED_FEATURE_Forward~0 := 0;~__SELECTED_FEATURE_Verify~0 := 0;~__SELECTED_FEATURE_Decrypt~0 := 0;~__GUIDSL_ROOT_PRODUCTION~0 := 0;~__GUIDSL_NON_TERMINAL_main~0 := 0;~in_encrypted~0 := 0;~head~0.base, ~head~0.offset := 0, 0;~queue_empty~0 := 1;~queued_message~0 := 0;~queued_client~0 := 0;~bob~0 := 0;~rjh~0 := 0;~chuck~0 := 0;~__ste_Client_counter~0 := 0;~__ste_client_name0~0.base, ~__ste_client_name0~0.offset := 0, 0;~__ste_client_name1~0.base, ~__ste_client_name1~0.offset := 0, 0;~__ste_client_name2~0.base, ~__ste_client_name2~0.offset := 0, 0;~__ste_client_outbuffer0~0 := 0;~__ste_client_outbuffer1~0 := 0;~__ste_client_outbuffer2~0 := 0;~__ste_client_outbuffer3~0 := 0;~__ste_ClientAddressBook_size0~0 := 0;~__ste_ClientAddressBook_size1~0 := 0;~__ste_ClientAddressBook_size2~0 := 0;~__ste_Client_AddressBook0_Alias0~0 := 0;~__ste_Client_AddressBook0_Alias1~0 := 0;~__ste_Client_AddressBook0_Alias2~0 := 0;~__ste_Client_AddressBook1_Alias0~0 := 0;~__ste_Client_AddressBook1_Alias1~0 := 0;~__ste_Client_AddressBook1_Alias2~0 := 0;~__ste_Client_AddressBook2_Alias0~0 := 0;~__ste_Client_AddressBook2_Alias1~0 := 0;~__ste_Client_AddressBook2_Alias2~0 := 0;~__ste_Client_AddressBook0_Address0~0 := 0;~__ste_Client_AddressBook0_Address1~0 := 0;~__ste_Client_AddressBook0_Address2~0 := 0;~__ste_Client_AddressBook1_Address0~0 := 0;~__ste_Client_AddressBook1_Address1~0 := 0;~__ste_Client_AddressBook1_Address2~0 := 0;~__ste_Client_AddressBook2_Address0~0 := 0;~__ste_Client_AddressBook2_Address1~0 := 0;~__ste_Client_AddressBook2_Address2~0 := 0;~__ste_client_autoResponse0~0 := 0;~__ste_client_autoResponse1~0 := 0;~__ste_client_autoResponse2~0 := 0;~__ste_client_privateKey0~0 := 0;~__ste_client_privateKey1~0 := 0;~__ste_client_privateKey2~0 := 0;~__ste_ClientKeyring_size0~0 := 0;~__ste_ClientKeyring_size1~0 := 0;~__ste_ClientKeyring_size2~0 := 0;~__ste_Client_Keyring0_User0~0 := 0;~__ste_Client_Keyring0_User1~0 := 0;~__ste_Client_Keyring0_User2~0 := 0;~__ste_Client_Keyring1_User0~0 := 0;~__ste_Client_Keyring1_User1~0 := 0;~__ste_Client_Keyring1_User2~0 := 0;~__ste_Client_Keyring2_User0~0 := 0;~__ste_Client_Keyring2_User1~0 := 0;~__ste_Client_Keyring2_User2~0 := 0;~__ste_Client_Keyring0_PublicKey0~0 := 0;~__ste_Client_Keyring0_PublicKey1~0 := 0;~__ste_Client_Keyring0_PublicKey2~0 := 0;~__ste_Client_Keyring1_PublicKey0~0 := 0;~__ste_Client_Keyring1_PublicKey1~0 := 0;~__ste_Client_Keyring1_PublicKey2~0 := 0;~__ste_Client_Keyring2_PublicKey0~0 := 0;~__ste_Client_Keyring2_PublicKey1~0 := 0;~__ste_Client_Keyring2_PublicKey2~0 := 0;~__ste_client_forwardReceiver0~0 := 0;~__ste_client_forwardReceiver1~0 := 0;~__ste_client_forwardReceiver2~0 := 0;~__ste_client_forwardReceiver3~0 := 0;~__ste_client_idCounter0~0 := 0;~__ste_client_idCounter1~0 := 0;~__ste_client_idCounter2~0 := 0; {18652#true} is VALID [2022-02-20 18:03:58,390 INFO L290 TraceCheckUtils]: 1: Hoare triple {18652#true} assume { :end_inline_ULTIMATE.init } true;assume { :begin_inline_main } true;havoc main_#res#1;havoc main_#t~nondet100#1, main_#t~ret101#1, main_~retValue_acc~26#1, main_~tmp~20#1;assume -2147483648 <= main_#t~nondet100#1 && main_#t~nondet100#1 <= 2147483647;main_~retValue_acc~26#1 := main_#t~nondet100#1;havoc main_#t~nondet100#1;havoc main_~tmp~20#1;assume { :begin_inline_select_helpers } true; {18652#true} is VALID [2022-02-20 18:03:58,390 INFO L290 TraceCheckUtils]: 2: Hoare triple {18652#true} assume { :end_inline_select_helpers } true;assume { :begin_inline_select_features } true; {18652#true} is VALID [2022-02-20 18:03:58,390 INFO L290 TraceCheckUtils]: 3: Hoare triple {18652#true} assume { :end_inline_select_features } true;assume { :begin_inline_valid_product } true;havoc valid_product_#res#1;havoc valid_product_~retValue_acc~12#1;havoc valid_product_~retValue_acc~12#1;valid_product_~retValue_acc~12#1 := 1;valid_product_#res#1 := valid_product_~retValue_acc~12#1; {18652#true} is VALID [2022-02-20 18:03:58,390 INFO L290 TraceCheckUtils]: 4: Hoare triple {18652#true} main_#t~ret101#1 := valid_product_#res#1;assume { :end_inline_valid_product } true;assume -2147483648 <= main_#t~ret101#1 && main_#t~ret101#1 <= 2147483647;main_~tmp~20#1 := main_#t~ret101#1;havoc main_#t~ret101#1; {18652#true} is VALID [2022-02-20 18:03:58,390 INFO L290 TraceCheckUtils]: 5: Hoare triple {18652#true} assume 0 != main_~tmp~20#1;assume { :begin_inline_setup } true;havoc setup_#t~nondet97#1, setup_#t~nondet98#1, setup_#t~nondet99#1, setup_~__cil_tmp1~0#1.base, setup_~__cil_tmp1~0#1.offset, setup_~__cil_tmp2~1#1.base, setup_~__cil_tmp2~1#1.offset, setup_~__cil_tmp3~4#1.base, setup_~__cil_tmp3~4#1.offset;havoc setup_~__cil_tmp1~0#1.base, setup_~__cil_tmp1~0#1.offset;havoc setup_~__cil_tmp2~1#1.base, setup_~__cil_tmp2~1#1.offset;havoc setup_~__cil_tmp3~4#1.base, setup_~__cil_tmp3~4#1.offset;~bob~0 := 1;assume { :begin_inline_setup_bob } true;setup_bob_#in~bob___0#1 := ~bob~0;havoc setup_bob_~bob___0#1;setup_bob_~bob___0#1 := setup_bob_#in~bob___0#1;assume { :begin_inline_setup_bob__wrappee__Base } true;setup_bob__wrappee__Base_#in~bob___0#1 := setup_bob_~bob___0#1;havoc setup_bob__wrappee__Base_~bob___0#1;setup_bob__wrappee__Base_~bob___0#1 := setup_bob__wrappee__Base_#in~bob___0#1; {18652#true} is VALID [2022-02-20 18:03:58,391 INFO L272 TraceCheckUtils]: 6: Hoare triple {18652#true} call setClientId(setup_bob__wrappee__Base_~bob___0#1, setup_bob__wrappee__Base_~bob___0#1); {18715#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} is VALID [2022-02-20 18:03:58,391 INFO L290 TraceCheckUtils]: 7: Hoare triple {18715#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {18652#true} is VALID [2022-02-20 18:03:58,391 INFO L290 TraceCheckUtils]: 8: Hoare triple {18652#true} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {18652#true} is VALID [2022-02-20 18:03:58,391 INFO L290 TraceCheckUtils]: 9: Hoare triple {18652#true} assume true; {18652#true} is VALID [2022-02-20 18:03:58,391 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {18652#true} {18652#true} #1224#return; {18652#true} is VALID [2022-02-20 18:03:58,392 INFO L290 TraceCheckUtils]: 11: Hoare triple {18652#true} assume { :end_inline_setup_bob__wrappee__Base } true; {18652#true} is VALID [2022-02-20 18:03:58,392 INFO L272 TraceCheckUtils]: 12: Hoare triple {18652#true} call setClientPrivateKey(setup_bob_~bob___0#1, 123); {18716#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} is VALID [2022-02-20 18:03:58,392 INFO L290 TraceCheckUtils]: 13: Hoare triple {18716#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {18652#true} is VALID [2022-02-20 18:03:58,392 INFO L290 TraceCheckUtils]: 14: Hoare triple {18652#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {18652#true} is VALID [2022-02-20 18:03:58,392 INFO L290 TraceCheckUtils]: 15: Hoare triple {18652#true} assume true; {18652#true} is VALID [2022-02-20 18:03:58,392 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {18652#true} {18652#true} #1226#return; {18652#true} is VALID [2022-02-20 18:03:58,393 INFO L290 TraceCheckUtils]: 17: Hoare triple {18652#true} assume { :end_inline_setup_bob } true;setup_~__cil_tmp1~0#1.base, setup_~__cil_tmp1~0#1.offset := 37, 0;havoc setup_#t~nondet97#1;~rjh~0 := 2;assume { :begin_inline_setup_rjh } true;setup_rjh_#in~rjh___0#1 := ~rjh~0;havoc setup_rjh_~rjh___0#1;setup_rjh_~rjh___0#1 := setup_rjh_#in~rjh___0#1;assume { :begin_inline_setup_rjh__wrappee__Base } true;setup_rjh__wrappee__Base_#in~rjh___0#1 := setup_rjh_~rjh___0#1;havoc setup_rjh__wrappee__Base_~rjh___0#1;setup_rjh__wrappee__Base_~rjh___0#1 := setup_rjh__wrappee__Base_#in~rjh___0#1; {18652#true} is VALID [2022-02-20 18:03:58,393 INFO L272 TraceCheckUtils]: 18: Hoare triple {18652#true} call setClientId(setup_rjh__wrappee__Base_~rjh___0#1, setup_rjh__wrappee__Base_~rjh___0#1); {18715#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} is VALID [2022-02-20 18:03:58,393 INFO L290 TraceCheckUtils]: 19: Hoare triple {18715#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {18652#true} is VALID [2022-02-20 18:03:58,393 INFO L290 TraceCheckUtils]: 20: Hoare triple {18652#true} assume !(1 == ~handle); {18652#true} is VALID [2022-02-20 18:03:58,393 INFO L290 TraceCheckUtils]: 21: Hoare triple {18652#true} assume 2 == ~handle;~__ste_client_idCounter1~0 := ~value; {18652#true} is VALID [2022-02-20 18:03:58,394 INFO L290 TraceCheckUtils]: 22: Hoare triple {18652#true} assume true; {18652#true} is VALID [2022-02-20 18:03:58,394 INFO L284 TraceCheckUtils]: 23: Hoare quadruple {18652#true} {18652#true} #1228#return; {18652#true} is VALID [2022-02-20 18:03:58,394 INFO L290 TraceCheckUtils]: 24: Hoare triple {18652#true} assume { :end_inline_setup_rjh__wrappee__Base } true; {18652#true} is VALID [2022-02-20 18:03:58,394 INFO L272 TraceCheckUtils]: 25: Hoare triple {18652#true} call setClientPrivateKey(setup_rjh_~rjh___0#1, 456); {18716#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} is VALID [2022-02-20 18:03:58,394 INFO L290 TraceCheckUtils]: 26: Hoare triple {18716#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {18652#true} is VALID [2022-02-20 18:03:58,394 INFO L290 TraceCheckUtils]: 27: Hoare triple {18652#true} assume !(1 == ~handle); {18652#true} is VALID [2022-02-20 18:03:58,395 INFO L290 TraceCheckUtils]: 28: Hoare triple {18652#true} assume 2 == ~handle;~__ste_client_privateKey1~0 := ~value; {18652#true} is VALID [2022-02-20 18:03:58,395 INFO L290 TraceCheckUtils]: 29: Hoare triple {18652#true} assume true; {18652#true} is VALID [2022-02-20 18:03:58,395 INFO L284 TraceCheckUtils]: 30: Hoare quadruple {18652#true} {18652#true} #1230#return; {18652#true} is VALID [2022-02-20 18:03:58,396 INFO L290 TraceCheckUtils]: 31: Hoare triple {18652#true} assume { :end_inline_setup_rjh } true;setup_~__cil_tmp2~1#1.base, setup_~__cil_tmp2~1#1.offset := 38, 0;havoc setup_#t~nondet98#1;~chuck~0 := 3;assume { :begin_inline_setup_chuck } true;setup_chuck_#in~chuck___0#1 := ~chuck~0;havoc setup_chuck_~chuck___0#1;setup_chuck_~chuck___0#1 := setup_chuck_#in~chuck___0#1;assume { :begin_inline_setup_chuck__wrappee__Base } true;setup_chuck__wrappee__Base_#in~chuck___0#1 := setup_chuck_~chuck___0#1;havoc setup_chuck__wrappee__Base_~chuck___0#1;setup_chuck__wrappee__Base_~chuck___0#1 := setup_chuck__wrappee__Base_#in~chuck___0#1; {18672#(= 3 |ULTIMATE.start_setup_chuck__wrappee__Base_~chuck___0#1|)} is VALID [2022-02-20 18:03:58,396 INFO L272 TraceCheckUtils]: 32: Hoare triple {18672#(= 3 |ULTIMATE.start_setup_chuck__wrappee__Base_~chuck___0#1|)} call setClientId(setup_chuck__wrappee__Base_~chuck___0#1, setup_chuck__wrappee__Base_~chuck___0#1); {18715#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} is VALID [2022-02-20 18:03:58,397 INFO L290 TraceCheckUtils]: 33: Hoare triple {18715#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {18717#(= setClientId_~handle |setClientId_#in~handle|)} is VALID [2022-02-20 18:03:58,397 INFO L290 TraceCheckUtils]: 34: Hoare triple {18717#(= setClientId_~handle |setClientId_#in~handle|)} assume !(1 == ~handle); {18717#(= setClientId_~handle |setClientId_#in~handle|)} is VALID [2022-02-20 18:03:58,397 INFO L290 TraceCheckUtils]: 35: Hoare triple {18717#(= setClientId_~handle |setClientId_#in~handle|)} assume 2 == ~handle;~__ste_client_idCounter1~0 := ~value; {18718#(= 2 |setClientId_#in~handle|)} is VALID [2022-02-20 18:03:58,398 INFO L290 TraceCheckUtils]: 36: Hoare triple {18718#(= 2 |setClientId_#in~handle|)} assume true; {18718#(= 2 |setClientId_#in~handle|)} is VALID [2022-02-20 18:03:58,398 INFO L284 TraceCheckUtils]: 37: Hoare quadruple {18718#(= 2 |setClientId_#in~handle|)} {18672#(= 3 |ULTIMATE.start_setup_chuck__wrappee__Base_~chuck___0#1|)} #1232#return; {18653#false} is VALID [2022-02-20 18:03:58,398 INFO L290 TraceCheckUtils]: 38: Hoare triple {18653#false} assume { :end_inline_setup_chuck__wrappee__Base } true; {18653#false} is VALID [2022-02-20 18:03:58,398 INFO L272 TraceCheckUtils]: 39: Hoare triple {18653#false} call setClientPrivateKey(setup_chuck_~chuck___0#1, 789); {18716#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} is VALID [2022-02-20 18:03:58,398 INFO L290 TraceCheckUtils]: 40: Hoare triple {18716#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {18652#true} is VALID [2022-02-20 18:03:58,398 INFO L290 TraceCheckUtils]: 41: Hoare triple {18652#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {18652#true} is VALID [2022-02-20 18:03:58,399 INFO L290 TraceCheckUtils]: 42: Hoare triple {18652#true} assume true; {18652#true} is VALID [2022-02-20 18:03:58,399 INFO L284 TraceCheckUtils]: 43: Hoare quadruple {18652#true} {18653#false} #1234#return; {18653#false} is VALID [2022-02-20 18:03:58,399 INFO L290 TraceCheckUtils]: 44: Hoare triple {18653#false} assume { :end_inline_setup_chuck } true;setup_~__cil_tmp3~4#1.base, setup_~__cil_tmp3~4#1.offset := 39, 0;havoc setup_#t~nondet99#1; {18653#false} is VALID [2022-02-20 18:03:58,399 INFO L290 TraceCheckUtils]: 45: Hoare triple {18653#false} assume { :end_inline_setup } true;assume { :begin_inline_test } true;havoc test_#t~nondet55#1, test_#t~nondet56#1, test_#t~nondet57#1, test_#t~nondet58#1, test_#t~nondet59#1, test_#t~nondet60#1, test_#t~nondet61#1, test_#t~nondet62#1, test_#t~nondet63#1, test_#t~nondet64#1, test_#t~nondet65#1, test_~op1~0#1, test_~op2~0#1, test_~op3~0#1, test_~op4~0#1, test_~op5~0#1, test_~op6~0#1, test_~op7~0#1, test_~op8~0#1, test_~op9~0#1, test_~op10~0#1, test_~op11~0#1, test_~splverifierCounter~0#1, test_~tmp~9#1, test_~tmp___0~3#1, test_~tmp___1~1#1, test_~tmp___2~1#1, test_~tmp___3~0#1, test_~tmp___4~0#1, test_~tmp___5~0#1, test_~tmp___6~0#1, test_~tmp___7~0#1, test_~tmp___8~0#1, test_~tmp___9~0#1;havoc test_~op1~0#1;havoc test_~op2~0#1;havoc test_~op3~0#1;havoc test_~op4~0#1;havoc test_~op5~0#1;havoc test_~op6~0#1;havoc test_~op7~0#1;havoc test_~op8~0#1;havoc test_~op9~0#1;havoc test_~op10~0#1;havoc test_~op11~0#1;havoc test_~splverifierCounter~0#1;havoc test_~tmp~9#1;havoc test_~tmp___0~3#1;havoc test_~tmp___1~1#1;havoc test_~tmp___2~1#1;havoc test_~tmp___3~0#1;havoc test_~tmp___4~0#1;havoc test_~tmp___5~0#1;havoc test_~tmp___6~0#1;havoc test_~tmp___7~0#1;havoc test_~tmp___8~0#1;havoc test_~tmp___9~0#1;test_~op1~0#1 := 0;test_~op2~0#1 := 0;test_~op3~0#1 := 0;test_~op4~0#1 := 0;test_~op5~0#1 := 0;test_~op6~0#1 := 0;test_~op7~0#1 := 0;test_~op8~0#1 := 0;test_~op9~0#1 := 0;test_~op10~0#1 := 0;test_~op11~0#1 := 0;test_~splverifierCounter~0#1 := 0; {18653#false} is VALID [2022-02-20 18:03:58,399 INFO L290 TraceCheckUtils]: 46: Hoare triple {18653#false} assume !false; {18653#false} is VALID [2022-02-20 18:03:58,399 INFO L290 TraceCheckUtils]: 47: Hoare triple {18653#false} assume test_~splverifierCounter~0#1 < 4; {18653#false} is VALID [2022-02-20 18:03:58,399 INFO L290 TraceCheckUtils]: 48: Hoare triple {18653#false} test_~splverifierCounter~0#1 := 1 + test_~splverifierCounter~0#1; {18653#false} is VALID [2022-02-20 18:03:58,399 INFO L290 TraceCheckUtils]: 49: Hoare triple {18653#false} assume 0 == test_~op1~0#1;assume -2147483648 <= test_#t~nondet55#1 && test_#t~nondet55#1 <= 2147483647;test_~tmp___9~0#1 := test_#t~nondet55#1;havoc test_#t~nondet55#1; {18653#false} is VALID [2022-02-20 18:03:58,399 INFO L290 TraceCheckUtils]: 50: Hoare triple {18653#false} assume !(0 != test_~tmp___9~0#1); {18653#false} is VALID [2022-02-20 18:03:58,400 INFO L290 TraceCheckUtils]: 51: Hoare triple {18653#false} assume 0 == test_~op2~0#1;assume -2147483648 <= test_#t~nondet56#1 && test_#t~nondet56#1 <= 2147483647;test_~tmp___8~0#1 := test_#t~nondet56#1;havoc test_#t~nondet56#1; {18653#false} is VALID [2022-02-20 18:03:58,400 INFO L290 TraceCheckUtils]: 52: Hoare triple {18653#false} assume 0 != test_~tmp___8~0#1;test_~op2~0#1 := 1; {18653#false} is VALID [2022-02-20 18:03:58,400 INFO L290 TraceCheckUtils]: 53: Hoare triple {18653#false} assume !false; {18653#false} is VALID [2022-02-20 18:03:58,400 INFO L290 TraceCheckUtils]: 54: Hoare triple {18653#false} assume !(test_~splverifierCounter~0#1 < 4); {18653#false} is VALID [2022-02-20 18:03:58,400 INFO L290 TraceCheckUtils]: 55: Hoare triple {18653#false} assume { :begin_inline_bobToRjh } true;havoc bobToRjh_#t~ret92#1, bobToRjh_#t~ret93#1, bobToRjh_#t~ret94#1, bobToRjh_#t~ret95#1, bobToRjh_~tmp~19#1, bobToRjh_~tmp___0~8#1, bobToRjh_~tmp___1~5#1;havoc bobToRjh_~tmp~19#1;havoc bobToRjh_~tmp___0~8#1;havoc bobToRjh_~tmp___1~5#1;call bobToRjh_#t~ret92#1 := puts(35, 0);assume -2147483648 <= bobToRjh_#t~ret92#1 && bobToRjh_#t~ret92#1 <= 2147483647;havoc bobToRjh_#t~ret92#1; {18653#false} is VALID [2022-02-20 18:03:58,400 INFO L272 TraceCheckUtils]: 56: Hoare triple {18653#false} call sendEmail(~bob~0, ~rjh~0); {18653#false} is VALID [2022-02-20 18:03:58,400 INFO L290 TraceCheckUtils]: 57: Hoare triple {18653#false} ~sender#1 := #in~sender#1;~receiver#1 := #in~receiver#1;havoc ~email~0#1;havoc ~tmp~16#1;assume { :begin_inline_createEmail } true;createEmail_#in~from#1, createEmail_#in~to#1 := 0, ~receiver#1;havoc createEmail_#res#1;havoc createEmail_~from#1, createEmail_~to#1, createEmail_~retValue_acc~16#1, createEmail_~msg~0#1;createEmail_~from#1 := createEmail_#in~from#1;createEmail_~to#1 := createEmail_#in~to#1;havoc createEmail_~retValue_acc~16#1;havoc createEmail_~msg~0#1;createEmail_~msg~0#1 := 1; {18653#false} is VALID [2022-02-20 18:03:58,400 INFO L272 TraceCheckUtils]: 58: Hoare triple {18653#false} call setEmailFrom(createEmail_~msg~0#1, createEmail_~from#1); {18719#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} is VALID [2022-02-20 18:03:58,400 INFO L290 TraceCheckUtils]: 59: Hoare triple {18719#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} ~handle := #in~handle;~value := #in~value; {18652#true} is VALID [2022-02-20 18:03:58,401 INFO L290 TraceCheckUtils]: 60: Hoare triple {18652#true} assume 1 == ~handle;~__ste_email_from0~0 := ~value; {18652#true} is VALID [2022-02-20 18:03:58,401 INFO L290 TraceCheckUtils]: 61: Hoare triple {18652#true} assume true; {18652#true} is VALID [2022-02-20 18:03:58,401 INFO L284 TraceCheckUtils]: 62: Hoare quadruple {18652#true} {18653#false} #1210#return; {18653#false} is VALID [2022-02-20 18:03:58,401 INFO L272 TraceCheckUtils]: 63: Hoare triple {18653#false} call setEmailTo(createEmail_~msg~0#1, createEmail_~to#1); {18720#(and (= ~__ste_email_to0~0 |old(~__ste_email_to0~0)|) (= ~__ste_email_to1~0 |old(~__ste_email_to1~0)|))} is VALID [2022-02-20 18:03:58,401 INFO L290 TraceCheckUtils]: 64: Hoare triple {18720#(and (= ~__ste_email_to0~0 |old(~__ste_email_to0~0)|) (= ~__ste_email_to1~0 |old(~__ste_email_to1~0)|))} ~handle := #in~handle;~value := #in~value; {18652#true} is VALID [2022-02-20 18:03:58,401 INFO L290 TraceCheckUtils]: 65: Hoare triple {18652#true} assume 1 == ~handle;~__ste_email_to0~0 := ~value; {18652#true} is VALID [2022-02-20 18:03:58,401 INFO L290 TraceCheckUtils]: 66: Hoare triple {18652#true} assume true; {18652#true} is VALID [2022-02-20 18:03:58,401 INFO L284 TraceCheckUtils]: 67: Hoare quadruple {18652#true} {18653#false} #1212#return; {18653#false} is VALID [2022-02-20 18:03:58,401 INFO L290 TraceCheckUtils]: 68: Hoare triple {18653#false} createEmail_~retValue_acc~16#1 := createEmail_~msg~0#1;createEmail_#res#1 := createEmail_~retValue_acc~16#1; {18653#false} is VALID [2022-02-20 18:03:58,402 INFO L290 TraceCheckUtils]: 69: Hoare triple {18653#false} #t~ret83#1 := createEmail_#res#1;assume { :end_inline_createEmail } true;assume -2147483648 <= #t~ret83#1 && #t~ret83#1 <= 2147483647;~tmp~16#1 := #t~ret83#1;havoc #t~ret83#1;~email~0#1 := ~tmp~16#1; {18653#false} is VALID [2022-02-20 18:03:58,402 INFO L272 TraceCheckUtils]: 70: Hoare triple {18653#false} call outgoing(~sender#1, ~email~0#1); {18653#false} is VALID [2022-02-20 18:03:58,402 INFO L290 TraceCheckUtils]: 71: Hoare triple {18653#false} ~client#1 := #in~client#1;~msg#1 := #in~msg#1;assume { :begin_inline_sign } true;sign_#in~client#1, sign_#in~msg#1 := ~client#1, ~msg#1;havoc sign_#t~ret85#1, sign_~client#1, sign_~msg#1, sign_~privkey~1#1, sign_~tmp~17#1;sign_~client#1 := sign_#in~client#1;sign_~msg#1 := sign_#in~msg#1;havoc sign_~privkey~1#1;havoc sign_~tmp~17#1; {18653#false} is VALID [2022-02-20 18:03:58,402 INFO L272 TraceCheckUtils]: 72: Hoare triple {18653#false} call sign_#t~ret85#1 := getClientPrivateKey(sign_~client#1); {18652#true} is VALID [2022-02-20 18:03:58,402 INFO L290 TraceCheckUtils]: 73: Hoare triple {18652#true} ~handle := #in~handle;havoc ~retValue_acc~36; {18652#true} is VALID [2022-02-20 18:03:58,402 INFO L290 TraceCheckUtils]: 74: Hoare triple {18652#true} assume 1 == ~handle;~retValue_acc~36 := ~__ste_client_privateKey0~0;#res := ~retValue_acc~36; {18652#true} is VALID [2022-02-20 18:03:58,402 INFO L290 TraceCheckUtils]: 75: Hoare triple {18652#true} assume true; {18652#true} is VALID [2022-02-20 18:03:58,402 INFO L284 TraceCheckUtils]: 76: Hoare quadruple {18652#true} {18653#false} #1150#return; {18653#false} is VALID [2022-02-20 18:03:58,402 INFO L290 TraceCheckUtils]: 77: Hoare triple {18653#false} assume -2147483648 <= sign_#t~ret85#1 && sign_#t~ret85#1 <= 2147483647;sign_~tmp~17#1 := sign_#t~ret85#1;havoc sign_#t~ret85#1;sign_~privkey~1#1 := sign_~tmp~17#1; {18653#false} is VALID [2022-02-20 18:03:58,403 INFO L290 TraceCheckUtils]: 78: Hoare triple {18653#false} assume 0 == sign_~privkey~1#1; {18653#false} is VALID [2022-02-20 18:03:58,403 INFO L290 TraceCheckUtils]: 79: Hoare triple {18653#false} assume { :end_inline_sign } true;assume { :begin_inline_outgoing__wrappee__AddressBook } true;outgoing__wrappee__AddressBook_#in~client#1, outgoing__wrappee__AddressBook_#in~msg#1 := ~client#1, ~msg#1;havoc outgoing__wrappee__AddressBook_#t~ret71#1, outgoing__wrappee__AddressBook_#t~ret72#1, outgoing__wrappee__AddressBook_#t~ret73#1, outgoing__wrappee__AddressBook_#t~ret74#1, outgoing__wrappee__AddressBook_#t~ret75#1, outgoing__wrappee__AddressBook_#t~ret76#1, outgoing__wrappee__AddressBook_~client#1, outgoing__wrappee__AddressBook_~msg#1, outgoing__wrappee__AddressBook_~size~0#1, outgoing__wrappee__AddressBook_~tmp~13#1, outgoing__wrappee__AddressBook_~receiver~1#1, outgoing__wrappee__AddressBook_~tmp___0~5#1, outgoing__wrappee__AddressBook_~second~0#1, outgoing__wrappee__AddressBook_~tmp___1~2#1, outgoing__wrappee__AddressBook_~tmp___2~2#1;outgoing__wrappee__AddressBook_~client#1 := outgoing__wrappee__AddressBook_#in~client#1;outgoing__wrappee__AddressBook_~msg#1 := outgoing__wrappee__AddressBook_#in~msg#1;havoc outgoing__wrappee__AddressBook_~size~0#1;havoc outgoing__wrappee__AddressBook_~tmp~13#1;havoc outgoing__wrappee__AddressBook_~receiver~1#1;havoc outgoing__wrappee__AddressBook_~tmp___0~5#1;havoc outgoing__wrappee__AddressBook_~second~0#1;havoc outgoing__wrappee__AddressBook_~tmp___1~2#1;havoc outgoing__wrappee__AddressBook_~tmp___2~2#1; {18653#false} is VALID [2022-02-20 18:03:58,403 INFO L272 TraceCheckUtils]: 80: Hoare triple {18653#false} call outgoing__wrappee__AddressBook_#t~ret71#1 := getClientAddressBookSize(outgoing__wrappee__AddressBook_~client#1); {18652#true} is VALID [2022-02-20 18:03:58,403 INFO L290 TraceCheckUtils]: 81: Hoare triple {18652#true} ~handle := #in~handle;havoc ~retValue_acc~30; {18652#true} is VALID [2022-02-20 18:03:58,403 INFO L290 TraceCheckUtils]: 82: Hoare triple {18652#true} assume 1 == ~handle;~retValue_acc~30 := ~__ste_ClientAddressBook_size0~0;#res := ~retValue_acc~30; {18652#true} is VALID [2022-02-20 18:03:58,403 INFO L290 TraceCheckUtils]: 83: Hoare triple {18652#true} assume true; {18652#true} is VALID [2022-02-20 18:03:58,403 INFO L284 TraceCheckUtils]: 84: Hoare quadruple {18652#true} {18653#false} #1152#return; {18653#false} is VALID [2022-02-20 18:03:58,403 INFO L290 TraceCheckUtils]: 85: Hoare triple {18653#false} assume -2147483648 <= outgoing__wrappee__AddressBook_#t~ret71#1 && outgoing__wrappee__AddressBook_#t~ret71#1 <= 2147483647;outgoing__wrappee__AddressBook_~tmp~13#1 := outgoing__wrappee__AddressBook_#t~ret71#1;havoc outgoing__wrappee__AddressBook_#t~ret71#1;outgoing__wrappee__AddressBook_~size~0#1 := outgoing__wrappee__AddressBook_~tmp~13#1; {18653#false} is VALID [2022-02-20 18:03:58,403 INFO L290 TraceCheckUtils]: 86: Hoare triple {18653#false} assume !(0 != outgoing__wrappee__AddressBook_~size~0#1); {18653#false} is VALID [2022-02-20 18:03:58,404 INFO L272 TraceCheckUtils]: 87: Hoare triple {18653#false} call outgoing__wrappee__Encrypt(outgoing__wrappee__AddressBook_~client#1, outgoing__wrappee__AddressBook_~msg#1); {18653#false} is VALID [2022-02-20 18:03:58,404 INFO L290 TraceCheckUtils]: 88: Hoare triple {18653#false} ~client#1 := #in~client#1;~msg#1 := #in~msg#1;havoc ~receiver~0#1;havoc ~tmp~12#1;havoc ~pubkey~0#1;havoc ~tmp___0~4#1; {18653#false} is VALID [2022-02-20 18:03:58,404 INFO L272 TraceCheckUtils]: 89: Hoare triple {18653#false} call #t~ret69#1 := getEmailTo(~msg#1); {18652#true} is VALID [2022-02-20 18:03:58,404 INFO L290 TraceCheckUtils]: 90: Hoare triple {18652#true} ~handle := #in~handle;havoc ~retValue_acc~3; {18652#true} is VALID [2022-02-20 18:03:58,404 INFO L290 TraceCheckUtils]: 91: Hoare triple {18652#true} assume 1 == ~handle;~retValue_acc~3 := ~__ste_email_to0~0;#res := ~retValue_acc~3; {18652#true} is VALID [2022-02-20 18:03:58,404 INFO L290 TraceCheckUtils]: 92: Hoare triple {18652#true} assume true; {18652#true} is VALID [2022-02-20 18:03:58,404 INFO L284 TraceCheckUtils]: 93: Hoare quadruple {18652#true} {18653#false} #1170#return; {18653#false} is VALID [2022-02-20 18:03:58,404 INFO L290 TraceCheckUtils]: 94: Hoare triple {18653#false} assume -2147483648 <= #t~ret69#1 && #t~ret69#1 <= 2147483647;~tmp~12#1 := #t~ret69#1;havoc #t~ret69#1;~receiver~0#1 := ~tmp~12#1; {18653#false} is VALID [2022-02-20 18:03:58,404 INFO L272 TraceCheckUtils]: 95: Hoare triple {18653#false} call #t~ret70#1 := findPublicKey(~client#1, ~receiver~0#1); {18652#true} is VALID [2022-02-20 18:03:58,405 INFO L290 TraceCheckUtils]: 96: Hoare triple {18652#true} ~handle := #in~handle;~userid := #in~userid;havoc ~retValue_acc~41; {18652#true} is VALID [2022-02-20 18:03:58,405 INFO L290 TraceCheckUtils]: 97: Hoare triple {18652#true} assume 1 == ~handle; {18652#true} is VALID [2022-02-20 18:03:58,405 INFO L290 TraceCheckUtils]: 98: Hoare triple {18652#true} assume ~userid == ~__ste_Client_Keyring0_User0~0;~retValue_acc~41 := ~__ste_Client_Keyring0_PublicKey0~0;#res := ~retValue_acc~41; {18652#true} is VALID [2022-02-20 18:03:58,405 INFO L290 TraceCheckUtils]: 99: Hoare triple {18652#true} assume true; {18652#true} is VALID [2022-02-20 18:03:58,405 INFO L284 TraceCheckUtils]: 100: Hoare quadruple {18652#true} {18653#false} #1172#return; {18653#false} is VALID [2022-02-20 18:03:58,405 INFO L290 TraceCheckUtils]: 101: Hoare triple {18653#false} assume -2147483648 <= #t~ret70#1 && #t~ret70#1 <= 2147483647;~tmp___0~4#1 := #t~ret70#1;havoc #t~ret70#1;~pubkey~0#1 := ~tmp___0~4#1; {18653#false} is VALID [2022-02-20 18:03:58,405 INFO L290 TraceCheckUtils]: 102: Hoare triple {18653#false} assume !(0 != ~pubkey~0#1); {18653#false} is VALID [2022-02-20 18:03:58,405 INFO L290 TraceCheckUtils]: 103: Hoare triple {18653#false} assume { :begin_inline_outgoing__wrappee__Keys } true;outgoing__wrappee__Keys_#in~client#1, outgoing__wrappee__Keys_#in~msg#1 := ~client#1, ~msg#1;havoc outgoing__wrappee__Keys_#t~ret68#1, outgoing__wrappee__Keys_~client#1, outgoing__wrappee__Keys_~msg#1, outgoing__wrappee__Keys_~tmp~11#1;outgoing__wrappee__Keys_~client#1 := outgoing__wrappee__Keys_#in~client#1;outgoing__wrappee__Keys_~msg#1 := outgoing__wrappee__Keys_#in~msg#1;havoc outgoing__wrappee__Keys_~tmp~11#1;assume { :begin_inline_getClientId } true;getClientId_#in~handle#1 := outgoing__wrappee__Keys_~client#1;havoc getClientId_#res#1;havoc getClientId_~handle#1, getClientId_~retValue_acc~43#1;getClientId_~handle#1 := getClientId_#in~handle#1;havoc getClientId_~retValue_acc~43#1; {18653#false} is VALID [2022-02-20 18:03:58,405 INFO L290 TraceCheckUtils]: 104: Hoare triple {18653#false} assume 1 == getClientId_~handle#1;getClientId_~retValue_acc~43#1 := ~__ste_client_idCounter0~0;getClientId_#res#1 := getClientId_~retValue_acc~43#1; {18653#false} is VALID [2022-02-20 18:03:58,406 INFO L290 TraceCheckUtils]: 105: Hoare triple {18653#false} outgoing__wrappee__Keys_#t~ret68#1 := getClientId_#res#1;assume { :end_inline_getClientId } true;assume -2147483648 <= outgoing__wrappee__Keys_#t~ret68#1 && outgoing__wrappee__Keys_#t~ret68#1 <= 2147483647;outgoing__wrappee__Keys_~tmp~11#1 := outgoing__wrappee__Keys_#t~ret68#1;havoc outgoing__wrappee__Keys_#t~ret68#1; {18653#false} is VALID [2022-02-20 18:03:58,406 INFO L272 TraceCheckUtils]: 106: Hoare triple {18653#false} call setEmailFrom(outgoing__wrappee__Keys_~msg#1, outgoing__wrappee__Keys_~tmp~11#1); {18719#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} is VALID [2022-02-20 18:03:58,406 INFO L290 TraceCheckUtils]: 107: Hoare triple {18719#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} ~handle := #in~handle;~value := #in~value; {18652#true} is VALID [2022-02-20 18:03:58,406 INFO L290 TraceCheckUtils]: 108: Hoare triple {18652#true} assume 1 == ~handle;~__ste_email_from0~0 := ~value; {18652#true} is VALID [2022-02-20 18:03:58,406 INFO L290 TraceCheckUtils]: 109: Hoare triple {18652#true} assume true; {18652#true} is VALID [2022-02-20 18:03:58,406 INFO L284 TraceCheckUtils]: 110: Hoare quadruple {18652#true} {18653#false} #1178#return; {18653#false} is VALID [2022-02-20 18:03:58,406 INFO L290 TraceCheckUtils]: 111: Hoare triple {18653#false} assume { :begin_inline_mail } true;mail_#in~client#1, mail_#in~msg#1 := outgoing__wrappee__Keys_~client#1, outgoing__wrappee__Keys_~msg#1;havoc mail_#t~ret66#1, mail_#t~ret67#1, mail_~client#1, mail_~msg#1, mail_~__utac__ad__arg1~0#1, mail_~tmp~10#1;mail_~client#1 := mail_#in~client#1;mail_~msg#1 := mail_#in~msg#1;havoc mail_~__utac__ad__arg1~0#1;havoc mail_~tmp~10#1;mail_~__utac__ad__arg1~0#1 := mail_~msg#1;assume { :begin_inline___utac_acc__EncryptAutoResponder_spec__2 } true;__utac_acc__EncryptAutoResponder_spec__2_#in~msg#1 := mail_~__utac__ad__arg1~0#1;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1, __utac_acc__EncryptAutoResponder_spec__2_#t~nondet29#1, __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1, __utac_acc__EncryptAutoResponder_spec__2_~msg#1, __utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.base, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.offset;__utac_acc__EncryptAutoResponder_spec__2_~msg#1 := __utac_acc__EncryptAutoResponder_spec__2_#in~msg#1;havoc __utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1;havoc __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.base, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.offset;call __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1 := puts(15, 0);assume -2147483648 <= __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1 && __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1 <= 2147483647;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1;__utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.base, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.offset := 16, 0;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~nondet29#1; {18653#false} is VALID [2022-02-20 18:03:58,406 INFO L290 TraceCheckUtils]: 112: Hoare triple {18653#false} assume 0 != ~in_encrypted~0; {18653#false} is VALID [2022-02-20 18:03:58,406 INFO L272 TraceCheckUtils]: 113: Hoare triple {18653#false} call __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1 := isEncrypted(__utac_acc__EncryptAutoResponder_spec__2_~msg#1); {18652#true} is VALID [2022-02-20 18:03:58,407 INFO L290 TraceCheckUtils]: 114: Hoare triple {18652#true} ~handle := #in~handle;havoc ~retValue_acc~6; {18652#true} is VALID [2022-02-20 18:03:58,407 INFO L290 TraceCheckUtils]: 115: Hoare triple {18652#true} assume 1 == ~handle;~retValue_acc~6 := ~__ste_email_isEncrypted0~0;#res := ~retValue_acc~6; {18652#true} is VALID [2022-02-20 18:03:58,407 INFO L290 TraceCheckUtils]: 116: Hoare triple {18652#true} assume true; {18652#true} is VALID [2022-02-20 18:03:58,407 INFO L284 TraceCheckUtils]: 117: Hoare quadruple {18652#true} {18653#false} #1180#return; {18653#false} is VALID [2022-02-20 18:03:58,407 INFO L290 TraceCheckUtils]: 118: Hoare triple {18653#false} assume -2147483648 <= __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1 && __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1 <= 2147483647;__utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1 := __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1; {18653#false} is VALID [2022-02-20 18:03:58,407 INFO L290 TraceCheckUtils]: 119: Hoare triple {18653#false} assume !(0 != __utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1);assume { :begin_inline___automaton_fail } true; {18653#false} is VALID [2022-02-20 18:03:58,407 INFO L290 TraceCheckUtils]: 120: Hoare triple {18653#false} assume !false; {18653#false} is VALID [2022-02-20 18:03:58,407 INFO L134 CoverageAnalysis]: Checked inductivity of 31 backedges. 7 proven. 0 refuted. 0 times theorem prover too weak. 24 trivial. 0 not checked. [2022-02-20 18:03:58,408 INFO L144 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-02-20 18:03:58,408 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [1210420723] [2022-02-20 18:03:58,408 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleSmtInterpolCraig [1210420723] provided 1 perfect and 0 imperfect interpolant sequences [2022-02-20 18:03:58,408 INFO L191 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-02-20 18:03:58,408 INFO L204 FreeRefinementEngine]: Number of different interpolants: perfect sequences [9] imperfect sequences [] total 9 [2022-02-20 18:03:58,408 INFO L118 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [1482221443] [2022-02-20 18:03:58,408 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-02-20 18:03:58,409 INFO L78 Accepts]: Start accepts. Automaton has has 9 states, 8 states have (on average 9.875) internal successors, (79), 5 states have internal predecessors, (79), 3 states have call successors, (17), 6 states have call predecessors, (17), 2 states have return successors, (14), 2 states have call predecessors, (14), 3 states have call successors, (14) Word has length 121 [2022-02-20 18:03:58,409 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-02-20 18:03:58,410 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with has 9 states, 8 states have (on average 9.875) internal successors, (79), 5 states have internal predecessors, (79), 3 states have call successors, (17), 6 states have call predecessors, (17), 2 states have return successors, (14), 2 states have call predecessors, (14), 3 states have call successors, (14) [2022-02-20 18:03:58,472 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 110 edges. 110 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 18:03:58,472 INFO L546 AbstractCegarLoop]: INTERPOLANT automaton has 9 states [2022-02-20 18:03:58,472 INFO L108 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2022-02-20 18:03:58,472 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 9 interpolants. [2022-02-20 18:03:58,473 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=15, Invalid=57, Unknown=0, NotChecked=0, Total=72 [2022-02-20 18:03:58,473 INFO L87 Difference]: Start difference. First operand 470 states and 724 transitions. Second operand has 9 states, 8 states have (on average 9.875) internal successors, (79), 5 states have internal predecessors, (79), 3 states have call successors, (17), 6 states have call predecessors, (17), 2 states have return successors, (14), 2 states have call predecessors, (14), 3 states have call successors, (14) [2022-02-20 18:04:06,205 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 18:04:06,206 INFO L93 Difference]: Finished difference Result 1022 states and 1595 transitions. [2022-02-20 18:04:06,206 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 11 states. [2022-02-20 18:04:06,206 INFO L78 Accepts]: Start accepts. Automaton has has 9 states, 8 states have (on average 9.875) internal successors, (79), 5 states have internal predecessors, (79), 3 states have call successors, (17), 6 states have call predecessors, (17), 2 states have return successors, (14), 2 states have call predecessors, (14), 3 states have call successors, (14) Word has length 121 [2022-02-20 18:04:06,206 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-02-20 18:04:06,207 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 9 states, 8 states have (on average 9.875) internal successors, (79), 5 states have internal predecessors, (79), 3 states have call successors, (17), 6 states have call predecessors, (17), 2 states have return successors, (14), 2 states have call predecessors, (14), 3 states have call successors, (14) [2022-02-20 18:04:06,221 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 11 states to 11 states and 1357 transitions. [2022-02-20 18:04:06,222 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 9 states, 8 states have (on average 9.875) internal successors, (79), 5 states have internal predecessors, (79), 3 states have call successors, (17), 6 states have call predecessors, (17), 2 states have return successors, (14), 2 states have call predecessors, (14), 3 states have call successors, (14) [2022-02-20 18:04:06,238 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 11 states to 11 states and 1357 transitions. [2022-02-20 18:04:06,238 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with 11 states and 1357 transitions. [2022-02-20 18:04:07,435 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 1357 edges. 1357 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 18:04:07,452 INFO L225 Difference]: With dead ends: 1022 [2022-02-20 18:04:07,452 INFO L226 Difference]: Without dead ends: 575 [2022-02-20 18:04:07,454 INFO L932 BasicCegarLoop]: 0 DeclaredPredicates, 46 GetRequests, 31 SyntacticMatches, 0 SemanticMatches, 15 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 30 ImplicationChecksByTransitivity, 0.1s TimeCoverageRelationStatistics Valid=73, Invalid=199, Unknown=0, NotChecked=0, Total=272 [2022-02-20 18:04:07,455 INFO L933 BasicCegarLoop]: 635 mSDtfsCounter, 1509 mSDsluCounter, 938 mSDsCounter, 0 mSdLazyCounter, 2087 mSolverCounterSat, 527 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 3.3s Time, 0 mProtectedPredicate, 0 mProtectedAction, 1530 SdHoareTripleChecker+Valid, 1573 SdHoareTripleChecker+Invalid, 2614 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 527 IncrementalHoareTripleChecker+Valid, 2087 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 3.4s IncrementalHoareTripleChecker+Time [2022-02-20 18:04:07,455 INFO L934 BasicCegarLoop]: SdHoareTripleChecker [1530 Valid, 1573 Invalid, 2614 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [527 Valid, 2087 Invalid, 0 Unknown, 0 Unchecked, 3.4s Time] [2022-02-20 18:04:07,456 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 575 states. [2022-02-20 18:04:07,540 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 575 to 472. [2022-02-20 18:04:07,540 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-02-20 18:04:07,541 INFO L82 GeneralOperation]: Start isEquivalent. First operand 575 states. Second operand has 472 states, 363 states have (on average 1.559228650137741) internal successors, (566), 370 states have internal predecessors, (566), 77 states have call successors, (77), 28 states have call predecessors, (77), 31 states have return successors, (84), 75 states have call predecessors, (84), 76 states have call successors, (84) [2022-02-20 18:04:07,542 INFO L74 IsIncluded]: Start isIncluded. First operand 575 states. Second operand has 472 states, 363 states have (on average 1.559228650137741) internal successors, (566), 370 states have internal predecessors, (566), 77 states have call successors, (77), 28 states have call predecessors, (77), 31 states have return successors, (84), 75 states have call predecessors, (84), 76 states have call successors, (84) [2022-02-20 18:04:07,543 INFO L87 Difference]: Start difference. First operand 575 states. Second operand has 472 states, 363 states have (on average 1.559228650137741) internal successors, (566), 370 states have internal predecessors, (566), 77 states have call successors, (77), 28 states have call predecessors, (77), 31 states have return successors, (84), 75 states have call predecessors, (84), 76 states have call successors, (84) [2022-02-20 18:04:07,559 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 18:04:07,559 INFO L93 Difference]: Finished difference Result 575 states and 901 transitions. [2022-02-20 18:04:07,559 INFO L276 IsEmpty]: Start isEmpty. Operand 575 states and 901 transitions. [2022-02-20 18:04:07,562 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 18:04:07,562 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 18:04:07,563 INFO L74 IsIncluded]: Start isIncluded. First operand has 472 states, 363 states have (on average 1.559228650137741) internal successors, (566), 370 states have internal predecessors, (566), 77 states have call successors, (77), 28 states have call predecessors, (77), 31 states have return successors, (84), 75 states have call predecessors, (84), 76 states have call successors, (84) Second operand 575 states. [2022-02-20 18:04:07,564 INFO L87 Difference]: Start difference. First operand has 472 states, 363 states have (on average 1.559228650137741) internal successors, (566), 370 states have internal predecessors, (566), 77 states have call successors, (77), 28 states have call predecessors, (77), 31 states have return successors, (84), 75 states have call predecessors, (84), 76 states have call successors, (84) Second operand 575 states. [2022-02-20 18:04:07,582 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 18:04:07,582 INFO L93 Difference]: Finished difference Result 575 states and 901 transitions. [2022-02-20 18:04:07,582 INFO L276 IsEmpty]: Start isEmpty. Operand 575 states and 901 transitions. [2022-02-20 18:04:07,586 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 18:04:07,586 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 18:04:07,586 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-02-20 18:04:07,586 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-02-20 18:04:07,587 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 472 states, 363 states have (on average 1.559228650137741) internal successors, (566), 370 states have internal predecessors, (566), 77 states have call successors, (77), 28 states have call predecessors, (77), 31 states have return successors, (84), 75 states have call predecessors, (84), 76 states have call successors, (84) [2022-02-20 18:04:07,600 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 472 states to 472 states and 727 transitions. [2022-02-20 18:04:07,601 INFO L78 Accepts]: Start accepts. Automaton has 472 states and 727 transitions. Word has length 121 [2022-02-20 18:04:07,601 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-02-20 18:04:07,601 INFO L470 AbstractCegarLoop]: Abstraction has 472 states and 727 transitions. [2022-02-20 18:04:07,601 INFO L471 AbstractCegarLoop]: INTERPOLANT automaton has has 9 states, 8 states have (on average 9.875) internal successors, (79), 5 states have internal predecessors, (79), 3 states have call successors, (17), 6 states have call predecessors, (17), 2 states have return successors, (14), 2 states have call predecessors, (14), 3 states have call successors, (14) [2022-02-20 18:04:07,601 INFO L276 IsEmpty]: Start isEmpty. Operand 472 states and 727 transitions. [2022-02-20 18:04:07,603 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 123 [2022-02-20 18:04:07,603 INFO L506 BasicCegarLoop]: Found error trace [2022-02-20 18:04:07,603 INFO L514 BasicCegarLoop]: trace histogram [3, 3, 3, 3, 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] [2022-02-20 18:04:07,603 WARN L452 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable6 [2022-02-20 18:04:07,604 INFO L402 AbstractCegarLoop]: === Iteration 8 === Targeting outgoing__wrappee__EncryptErr0ASSERT_VIOLATIONERROR_FUNCTION === [outgoing__wrappee__EncryptErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-02-20 18:04:07,604 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-02-20 18:04:07,604 INFO L85 PathProgramCache]: Analyzing trace with hash 848855842, now seen corresponding path program 1 times [2022-02-20 18:04:07,604 INFO L126 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-02-20 18:04:07,604 INFO L338 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [723440617] [2022-02-20 18:04:07,604 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 18:04:07,605 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-02-20 18:04:07,628 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:04:07,652 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 6 [2022-02-20 18:04:07,654 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:04:07,656 INFO L290 TraceCheckUtils]: 0: Hoare triple {22020#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {21955#true} is VALID [2022-02-20 18:04:07,656 INFO L290 TraceCheckUtils]: 1: Hoare triple {21955#true} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {21955#true} is VALID [2022-02-20 18:04:07,656 INFO L290 TraceCheckUtils]: 2: Hoare triple {21955#true} assume true; {21955#true} is VALID [2022-02-20 18:04:07,656 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {21955#true} {21955#true} #1224#return; {21955#true} is VALID [2022-02-20 18:04:07,661 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 12 [2022-02-20 18:04:07,662 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:04:07,665 INFO L290 TraceCheckUtils]: 0: Hoare triple {22021#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {21955#true} is VALID [2022-02-20 18:04:07,665 INFO L290 TraceCheckUtils]: 1: Hoare triple {21955#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {21955#true} is VALID [2022-02-20 18:04:07,665 INFO L290 TraceCheckUtils]: 2: Hoare triple {21955#true} assume true; {21955#true} is VALID [2022-02-20 18:04:07,665 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {21955#true} {21955#true} #1226#return; {21955#true} is VALID [2022-02-20 18:04:07,665 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 18 [2022-02-20 18:04:07,666 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:04:07,668 INFO L290 TraceCheckUtils]: 0: Hoare triple {22020#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {21955#true} is VALID [2022-02-20 18:04:07,668 INFO L290 TraceCheckUtils]: 1: Hoare triple {21955#true} assume !(1 == ~handle); {21955#true} is VALID [2022-02-20 18:04:07,668 INFO L290 TraceCheckUtils]: 2: Hoare triple {21955#true} assume 2 == ~handle;~__ste_client_idCounter1~0 := ~value; {21955#true} is VALID [2022-02-20 18:04:07,669 INFO L290 TraceCheckUtils]: 3: Hoare triple {21955#true} assume true; {21955#true} is VALID [2022-02-20 18:04:07,669 INFO L284 TraceCheckUtils]: 4: Hoare quadruple {21955#true} {21955#true} #1228#return; {21955#true} is VALID [2022-02-20 18:04:07,669 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 25 [2022-02-20 18:04:07,670 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:04:07,672 INFO L290 TraceCheckUtils]: 0: Hoare triple {22021#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {21955#true} is VALID [2022-02-20 18:04:07,672 INFO L290 TraceCheckUtils]: 1: Hoare triple {21955#true} assume !(1 == ~handle); {21955#true} is VALID [2022-02-20 18:04:07,672 INFO L290 TraceCheckUtils]: 2: Hoare triple {21955#true} assume 2 == ~handle;~__ste_client_privateKey1~0 := ~value; {21955#true} is VALID [2022-02-20 18:04:07,673 INFO L290 TraceCheckUtils]: 3: Hoare triple {21955#true} assume true; {21955#true} is VALID [2022-02-20 18:04:07,673 INFO L284 TraceCheckUtils]: 4: Hoare quadruple {21955#true} {21955#true} #1230#return; {21955#true} is VALID [2022-02-20 18:04:07,673 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 32 [2022-02-20 18:04:07,674 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:04:07,686 INFO L290 TraceCheckUtils]: 0: Hoare triple {22020#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {22022#(= setClientId_~handle |setClientId_#in~handle|)} is VALID [2022-02-20 18:04:07,686 INFO L290 TraceCheckUtils]: 1: Hoare triple {22022#(= setClientId_~handle |setClientId_#in~handle|)} assume !(1 == ~handle); {22022#(= setClientId_~handle |setClientId_#in~handle|)} is VALID [2022-02-20 18:04:07,686 INFO L290 TraceCheckUtils]: 2: Hoare triple {22022#(= setClientId_~handle |setClientId_#in~handle|)} assume !(2 == ~handle); {22022#(= setClientId_~handle |setClientId_#in~handle|)} is VALID [2022-02-20 18:04:07,687 INFO L290 TraceCheckUtils]: 3: Hoare triple {22022#(= setClientId_~handle |setClientId_#in~handle|)} assume 3 == ~handle;~__ste_client_idCounter2~0 := ~value; {22023#(= 3 |setClientId_#in~handle|)} is VALID [2022-02-20 18:04:07,687 INFO L290 TraceCheckUtils]: 4: Hoare triple {22023#(= 3 |setClientId_#in~handle|)} assume true; {22023#(= 3 |setClientId_#in~handle|)} is VALID [2022-02-20 18:04:07,687 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {22023#(= 3 |setClientId_#in~handle|)} {21975#(= |ULTIMATE.start_setup_chuck_~chuck___0#1| |ULTIMATE.start_setup_chuck__wrappee__Base_~chuck___0#1|)} #1232#return; {21982#(not (= |ULTIMATE.start_setup_chuck_~chuck___0#1| 1))} is VALID [2022-02-20 18:04:07,688 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 40 [2022-02-20 18:04:07,689 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:04:07,704 INFO L290 TraceCheckUtils]: 0: Hoare triple {22021#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {22024#(= setClientPrivateKey_~handle |setClientPrivateKey_#in~handle|)} is VALID [2022-02-20 18:04:07,704 INFO L290 TraceCheckUtils]: 1: Hoare triple {22024#(= setClientPrivateKey_~handle |setClientPrivateKey_#in~handle|)} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {22025#(= |setClientPrivateKey_#in~handle| 1)} is VALID [2022-02-20 18:04:07,704 INFO L290 TraceCheckUtils]: 2: Hoare triple {22025#(= |setClientPrivateKey_#in~handle| 1)} assume true; {22025#(= |setClientPrivateKey_#in~handle| 1)} is VALID [2022-02-20 18:04:07,705 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {22025#(= |setClientPrivateKey_#in~handle| 1)} {21982#(not (= |ULTIMATE.start_setup_chuck_~chuck___0#1| 1))} #1234#return; {21956#false} is VALID [2022-02-20 18:04:07,712 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 59 [2022-02-20 18:04:07,713 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:04:07,717 INFO L290 TraceCheckUtils]: 0: Hoare triple {22026#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} ~handle := #in~handle;~value := #in~value; {21955#true} is VALID [2022-02-20 18:04:07,717 INFO L290 TraceCheckUtils]: 1: Hoare triple {21955#true} assume 1 == ~handle;~__ste_email_from0~0 := ~value; {21955#true} is VALID [2022-02-20 18:04:07,717 INFO L290 TraceCheckUtils]: 2: Hoare triple {21955#true} assume true; {21955#true} is VALID [2022-02-20 18:04:07,718 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {21955#true} {21956#false} #1210#return; {21956#false} is VALID [2022-02-20 18:04:07,725 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 64 [2022-02-20 18:04:07,726 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:04:07,728 INFO L290 TraceCheckUtils]: 0: Hoare triple {22027#(and (= ~__ste_email_to0~0 |old(~__ste_email_to0~0)|) (= ~__ste_email_to1~0 |old(~__ste_email_to1~0)|))} ~handle := #in~handle;~value := #in~value; {21955#true} is VALID [2022-02-20 18:04:07,728 INFO L290 TraceCheckUtils]: 1: Hoare triple {21955#true} assume 1 == ~handle;~__ste_email_to0~0 := ~value; {21955#true} is VALID [2022-02-20 18:04:07,728 INFO L290 TraceCheckUtils]: 2: Hoare triple {21955#true} assume true; {21955#true} is VALID [2022-02-20 18:04:07,729 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {21955#true} {21956#false} #1212#return; {21956#false} is VALID [2022-02-20 18:04:07,729 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 73 [2022-02-20 18:04:07,729 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:04:07,731 INFO L290 TraceCheckUtils]: 0: Hoare triple {21955#true} ~handle := #in~handle;havoc ~retValue_acc~36; {21955#true} is VALID [2022-02-20 18:04:07,731 INFO L290 TraceCheckUtils]: 1: Hoare triple {21955#true} assume 1 == ~handle;~retValue_acc~36 := ~__ste_client_privateKey0~0;#res := ~retValue_acc~36; {21955#true} is VALID [2022-02-20 18:04:07,731 INFO L290 TraceCheckUtils]: 2: Hoare triple {21955#true} assume true; {21955#true} is VALID [2022-02-20 18:04:07,731 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {21955#true} {21956#false} #1150#return; {21956#false} is VALID [2022-02-20 18:04:07,731 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 81 [2022-02-20 18:04:07,732 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:04:07,734 INFO L290 TraceCheckUtils]: 0: Hoare triple {21955#true} ~handle := #in~handle;havoc ~retValue_acc~30; {21955#true} is VALID [2022-02-20 18:04:07,734 INFO L290 TraceCheckUtils]: 1: Hoare triple {21955#true} assume 1 == ~handle;~retValue_acc~30 := ~__ste_ClientAddressBook_size0~0;#res := ~retValue_acc~30; {21955#true} is VALID [2022-02-20 18:04:07,734 INFO L290 TraceCheckUtils]: 2: Hoare triple {21955#true} assume true; {21955#true} is VALID [2022-02-20 18:04:07,734 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {21955#true} {21956#false} #1152#return; {21956#false} is VALID [2022-02-20 18:04:07,735 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 90 [2022-02-20 18:04:07,735 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:04:07,737 INFO L290 TraceCheckUtils]: 0: Hoare triple {21955#true} ~handle := #in~handle;havoc ~retValue_acc~3; {21955#true} is VALID [2022-02-20 18:04:07,737 INFO L290 TraceCheckUtils]: 1: Hoare triple {21955#true} assume 1 == ~handle;~retValue_acc~3 := ~__ste_email_to0~0;#res := ~retValue_acc~3; {21955#true} is VALID [2022-02-20 18:04:07,737 INFO L290 TraceCheckUtils]: 2: Hoare triple {21955#true} assume true; {21955#true} is VALID [2022-02-20 18:04:07,737 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {21955#true} {21956#false} #1170#return; {21956#false} is VALID [2022-02-20 18:04:07,737 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 96 [2022-02-20 18:04:07,746 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:04:07,748 INFO L290 TraceCheckUtils]: 0: Hoare triple {21955#true} ~handle := #in~handle;~userid := #in~userid;havoc ~retValue_acc~41; {21955#true} is VALID [2022-02-20 18:04:07,748 INFO L290 TraceCheckUtils]: 1: Hoare triple {21955#true} assume 1 == ~handle; {21955#true} is VALID [2022-02-20 18:04:07,749 INFO L290 TraceCheckUtils]: 2: Hoare triple {21955#true} assume ~userid == ~__ste_Client_Keyring0_User0~0;~retValue_acc~41 := ~__ste_Client_Keyring0_PublicKey0~0;#res := ~retValue_acc~41; {21955#true} is VALID [2022-02-20 18:04:07,749 INFO L290 TraceCheckUtils]: 3: Hoare triple {21955#true} assume true; {21955#true} is VALID [2022-02-20 18:04:07,749 INFO L284 TraceCheckUtils]: 4: Hoare quadruple {21955#true} {21956#false} #1172#return; {21956#false} is VALID [2022-02-20 18:04:07,749 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 107 [2022-02-20 18:04:07,750 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:04:07,752 INFO L290 TraceCheckUtils]: 0: Hoare triple {22026#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} ~handle := #in~handle;~value := #in~value; {21955#true} is VALID [2022-02-20 18:04:07,752 INFO L290 TraceCheckUtils]: 1: Hoare triple {21955#true} assume 1 == ~handle;~__ste_email_from0~0 := ~value; {21955#true} is VALID [2022-02-20 18:04:07,752 INFO L290 TraceCheckUtils]: 2: Hoare triple {21955#true} assume true; {21955#true} is VALID [2022-02-20 18:04:07,752 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {21955#true} {21956#false} #1178#return; {21956#false} is VALID [2022-02-20 18:04:07,752 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 114 [2022-02-20 18:04:07,753 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:04:07,756 INFO L290 TraceCheckUtils]: 0: Hoare triple {21955#true} ~handle := #in~handle;havoc ~retValue_acc~6; {21955#true} is VALID [2022-02-20 18:04:07,756 INFO L290 TraceCheckUtils]: 1: Hoare triple {21955#true} assume 1 == ~handle;~retValue_acc~6 := ~__ste_email_isEncrypted0~0;#res := ~retValue_acc~6; {21955#true} is VALID [2022-02-20 18:04:07,756 INFO L290 TraceCheckUtils]: 2: Hoare triple {21955#true} assume true; {21955#true} is VALID [2022-02-20 18:04:07,756 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {21955#true} {21956#false} #1180#return; {21956#false} is VALID [2022-02-20 18:04:07,756 INFO L290 TraceCheckUtils]: 0: Hoare triple {21955#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(28, 2);call #Ultimate.allocInit(12, 3);call #Ultimate.allocInit(10, 4);call #Ultimate.allocInit(12, 5);call #Ultimate.allocInit(10, 6);call #Ultimate.allocInit(18, 7);call #Ultimate.allocInit(16, 8);call #Ultimate.allocInit(21, 9);call #Ultimate.allocInit(13, 10);call #Ultimate.allocInit(16, 11);call #Ultimate.allocInit(25, 12);call #Ultimate.allocInit(17, 13);call #Ultimate.allocInit(17, 14);call #Ultimate.allocInit(13, 15);call #Ultimate.allocInit(17, 16);call #Ultimate.allocInit(30, 17);call #Ultimate.allocInit(9, 18);call #Ultimate.allocInit(21, 19);call #Ultimate.allocInit(30, 20);call #Ultimate.allocInit(9, 21);call #Ultimate.allocInit(21, 22);call #Ultimate.allocInit(30, 23);call #Ultimate.allocInit(9, 24);call #Ultimate.allocInit(25, 25);call #Ultimate.allocInit(30, 26);call #Ultimate.allocInit(9, 27);call #Ultimate.allocInit(25, 28);call #Ultimate.allocInit(4, 29);call write~init~int(37, 29, 0, 1);call write~init~int(115, 29, 1, 1);call write~init~int(10, 29, 2, 1);call write~init~int(0, 29, 3, 1);call #Ultimate.allocInit(10, 30);call #Ultimate.allocInit(34, 31);call #Ultimate.allocInit(30, 32);call #Ultimate.allocInit(16, 33);call #Ultimate.allocInit(20, 34);call #Ultimate.allocInit(44, 35);call #Ultimate.allocInit(44, 36);call #Ultimate.allocInit(9, 37);call #Ultimate.allocInit(9, 38);call #Ultimate.allocInit(11, 39);call #Ultimate.allocInit(19, 40);call #Ultimate.allocInit(4, 41);call write~init~int(37, 41, 0, 1);call write~init~int(100, 41, 1, 1);call write~init~int(10, 41, 2, 1);call write~init~int(0, 41, 3, 1);call #Ultimate.allocInit(4, 42);call write~init~int(37, 42, 0, 1);call write~init~int(100, 42, 1, 1);call write~init~int(10, 42, 2, 1);call write~init~int(0, 42, 3, 1);~__ste_Email_counter~0 := 0;~__ste_email_id0~0 := 0;~__ste_email_id1~0 := 0;~__ste_email_from0~0 := 0;~__ste_email_from1~0 := 0;~__ste_email_to0~0 := 0;~__ste_email_to1~0 := 0;~__ste_email_subject0~0.base, ~__ste_email_subject0~0.offset := 0, 0;~__ste_email_subject1~0.base, ~__ste_email_subject1~0.offset := 0, 0;~__ste_email_body0~0.base, ~__ste_email_body0~0.offset := 0, 0;~__ste_email_body1~0.base, ~__ste_email_body1~0.offset := 0, 0;~__ste_email_isEncrypted0~0 := 0;~__ste_email_isEncrypted1~0 := 0;~__ste_email_encryptionKey0~0 := 0;~__ste_email_encryptionKey1~0 := 0;~__ste_email_isSigned0~0 := 0;~__ste_email_isSigned1~0 := 0;~__ste_email_signKey0~0 := 0;~__ste_email_signKey1~0 := 0;~__ste_email_isSignatureVerified0~0 := 0;~__ste_email_isSignatureVerified1~0 := 0;~__SELECTED_FEATURE_Base~0 := 0;~__SELECTED_FEATURE_Keys~0 := 0;~__SELECTED_FEATURE_Encrypt~0 := 0;~__SELECTED_FEATURE_AutoResponder~0 := 0;~__SELECTED_FEATURE_AddressBook~0 := 0;~__SELECTED_FEATURE_Sign~0 := 0;~__SELECTED_FEATURE_Forward~0 := 0;~__SELECTED_FEATURE_Verify~0 := 0;~__SELECTED_FEATURE_Decrypt~0 := 0;~__GUIDSL_ROOT_PRODUCTION~0 := 0;~__GUIDSL_NON_TERMINAL_main~0 := 0;~in_encrypted~0 := 0;~head~0.base, ~head~0.offset := 0, 0;~queue_empty~0 := 1;~queued_message~0 := 0;~queued_client~0 := 0;~bob~0 := 0;~rjh~0 := 0;~chuck~0 := 0;~__ste_Client_counter~0 := 0;~__ste_client_name0~0.base, ~__ste_client_name0~0.offset := 0, 0;~__ste_client_name1~0.base, ~__ste_client_name1~0.offset := 0, 0;~__ste_client_name2~0.base, ~__ste_client_name2~0.offset := 0, 0;~__ste_client_outbuffer0~0 := 0;~__ste_client_outbuffer1~0 := 0;~__ste_client_outbuffer2~0 := 0;~__ste_client_outbuffer3~0 := 0;~__ste_ClientAddressBook_size0~0 := 0;~__ste_ClientAddressBook_size1~0 := 0;~__ste_ClientAddressBook_size2~0 := 0;~__ste_Client_AddressBook0_Alias0~0 := 0;~__ste_Client_AddressBook0_Alias1~0 := 0;~__ste_Client_AddressBook0_Alias2~0 := 0;~__ste_Client_AddressBook1_Alias0~0 := 0;~__ste_Client_AddressBook1_Alias1~0 := 0;~__ste_Client_AddressBook1_Alias2~0 := 0;~__ste_Client_AddressBook2_Alias0~0 := 0;~__ste_Client_AddressBook2_Alias1~0 := 0;~__ste_Client_AddressBook2_Alias2~0 := 0;~__ste_Client_AddressBook0_Address0~0 := 0;~__ste_Client_AddressBook0_Address1~0 := 0;~__ste_Client_AddressBook0_Address2~0 := 0;~__ste_Client_AddressBook1_Address0~0 := 0;~__ste_Client_AddressBook1_Address1~0 := 0;~__ste_Client_AddressBook1_Address2~0 := 0;~__ste_Client_AddressBook2_Address0~0 := 0;~__ste_Client_AddressBook2_Address1~0 := 0;~__ste_Client_AddressBook2_Address2~0 := 0;~__ste_client_autoResponse0~0 := 0;~__ste_client_autoResponse1~0 := 0;~__ste_client_autoResponse2~0 := 0;~__ste_client_privateKey0~0 := 0;~__ste_client_privateKey1~0 := 0;~__ste_client_privateKey2~0 := 0;~__ste_ClientKeyring_size0~0 := 0;~__ste_ClientKeyring_size1~0 := 0;~__ste_ClientKeyring_size2~0 := 0;~__ste_Client_Keyring0_User0~0 := 0;~__ste_Client_Keyring0_User1~0 := 0;~__ste_Client_Keyring0_User2~0 := 0;~__ste_Client_Keyring1_User0~0 := 0;~__ste_Client_Keyring1_User1~0 := 0;~__ste_Client_Keyring1_User2~0 := 0;~__ste_Client_Keyring2_User0~0 := 0;~__ste_Client_Keyring2_User1~0 := 0;~__ste_Client_Keyring2_User2~0 := 0;~__ste_Client_Keyring0_PublicKey0~0 := 0;~__ste_Client_Keyring0_PublicKey1~0 := 0;~__ste_Client_Keyring0_PublicKey2~0 := 0;~__ste_Client_Keyring1_PublicKey0~0 := 0;~__ste_Client_Keyring1_PublicKey1~0 := 0;~__ste_Client_Keyring1_PublicKey2~0 := 0;~__ste_Client_Keyring2_PublicKey0~0 := 0;~__ste_Client_Keyring2_PublicKey1~0 := 0;~__ste_Client_Keyring2_PublicKey2~0 := 0;~__ste_client_forwardReceiver0~0 := 0;~__ste_client_forwardReceiver1~0 := 0;~__ste_client_forwardReceiver2~0 := 0;~__ste_client_forwardReceiver3~0 := 0;~__ste_client_idCounter0~0 := 0;~__ste_client_idCounter1~0 := 0;~__ste_client_idCounter2~0 := 0; {21955#true} is VALID [2022-02-20 18:04:07,756 INFO L290 TraceCheckUtils]: 1: Hoare triple {21955#true} assume { :end_inline_ULTIMATE.init } true;assume { :begin_inline_main } true;havoc main_#res#1;havoc main_#t~nondet100#1, main_#t~ret101#1, main_~retValue_acc~26#1, main_~tmp~20#1;assume -2147483648 <= main_#t~nondet100#1 && main_#t~nondet100#1 <= 2147483647;main_~retValue_acc~26#1 := main_#t~nondet100#1;havoc main_#t~nondet100#1;havoc main_~tmp~20#1;assume { :begin_inline_select_helpers } true; {21955#true} is VALID [2022-02-20 18:04:07,757 INFO L290 TraceCheckUtils]: 2: Hoare triple {21955#true} assume { :end_inline_select_helpers } true;assume { :begin_inline_select_features } true; {21955#true} is VALID [2022-02-20 18:04:07,757 INFO L290 TraceCheckUtils]: 3: Hoare triple {21955#true} assume { :end_inline_select_features } true;assume { :begin_inline_valid_product } true;havoc valid_product_#res#1;havoc valid_product_~retValue_acc~12#1;havoc valid_product_~retValue_acc~12#1;valid_product_~retValue_acc~12#1 := 1;valid_product_#res#1 := valid_product_~retValue_acc~12#1; {21955#true} is VALID [2022-02-20 18:04:07,757 INFO L290 TraceCheckUtils]: 4: Hoare triple {21955#true} main_#t~ret101#1 := valid_product_#res#1;assume { :end_inline_valid_product } true;assume -2147483648 <= main_#t~ret101#1 && main_#t~ret101#1 <= 2147483647;main_~tmp~20#1 := main_#t~ret101#1;havoc main_#t~ret101#1; {21955#true} is VALID [2022-02-20 18:04:07,757 INFO L290 TraceCheckUtils]: 5: Hoare triple {21955#true} assume 0 != main_~tmp~20#1;assume { :begin_inline_setup } true;havoc setup_#t~nondet97#1, setup_#t~nondet98#1, setup_#t~nondet99#1, setup_~__cil_tmp1~0#1.base, setup_~__cil_tmp1~0#1.offset, setup_~__cil_tmp2~1#1.base, setup_~__cil_tmp2~1#1.offset, setup_~__cil_tmp3~4#1.base, setup_~__cil_tmp3~4#1.offset;havoc setup_~__cil_tmp1~0#1.base, setup_~__cil_tmp1~0#1.offset;havoc setup_~__cil_tmp2~1#1.base, setup_~__cil_tmp2~1#1.offset;havoc setup_~__cil_tmp3~4#1.base, setup_~__cil_tmp3~4#1.offset;~bob~0 := 1;assume { :begin_inline_setup_bob } true;setup_bob_#in~bob___0#1 := ~bob~0;havoc setup_bob_~bob___0#1;setup_bob_~bob___0#1 := setup_bob_#in~bob___0#1;assume { :begin_inline_setup_bob__wrappee__Base } true;setup_bob__wrappee__Base_#in~bob___0#1 := setup_bob_~bob___0#1;havoc setup_bob__wrappee__Base_~bob___0#1;setup_bob__wrappee__Base_~bob___0#1 := setup_bob__wrappee__Base_#in~bob___0#1; {21955#true} is VALID [2022-02-20 18:04:07,757 INFO L272 TraceCheckUtils]: 6: Hoare triple {21955#true} call setClientId(setup_bob__wrappee__Base_~bob___0#1, setup_bob__wrappee__Base_~bob___0#1); {22020#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} is VALID [2022-02-20 18:04:07,758 INFO L290 TraceCheckUtils]: 7: Hoare triple {22020#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {21955#true} is VALID [2022-02-20 18:04:07,758 INFO L290 TraceCheckUtils]: 8: Hoare triple {21955#true} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {21955#true} is VALID [2022-02-20 18:04:07,758 INFO L290 TraceCheckUtils]: 9: Hoare triple {21955#true} assume true; {21955#true} is VALID [2022-02-20 18:04:07,758 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {21955#true} {21955#true} #1224#return; {21955#true} is VALID [2022-02-20 18:04:07,758 INFO L290 TraceCheckUtils]: 11: Hoare triple {21955#true} assume { :end_inline_setup_bob__wrappee__Base } true; {21955#true} is VALID [2022-02-20 18:04:07,759 INFO L272 TraceCheckUtils]: 12: Hoare triple {21955#true} call setClientPrivateKey(setup_bob_~bob___0#1, 123); {22021#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} is VALID [2022-02-20 18:04:07,759 INFO L290 TraceCheckUtils]: 13: Hoare triple {22021#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {21955#true} is VALID [2022-02-20 18:04:07,759 INFO L290 TraceCheckUtils]: 14: Hoare triple {21955#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {21955#true} is VALID [2022-02-20 18:04:07,759 INFO L290 TraceCheckUtils]: 15: Hoare triple {21955#true} assume true; {21955#true} is VALID [2022-02-20 18:04:07,759 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {21955#true} {21955#true} #1226#return; {21955#true} is VALID [2022-02-20 18:04:07,759 INFO L290 TraceCheckUtils]: 17: Hoare triple {21955#true} assume { :end_inline_setup_bob } true;setup_~__cil_tmp1~0#1.base, setup_~__cil_tmp1~0#1.offset := 37, 0;havoc setup_#t~nondet97#1;~rjh~0 := 2;assume { :begin_inline_setup_rjh } true;setup_rjh_#in~rjh___0#1 := ~rjh~0;havoc setup_rjh_~rjh___0#1;setup_rjh_~rjh___0#1 := setup_rjh_#in~rjh___0#1;assume { :begin_inline_setup_rjh__wrappee__Base } true;setup_rjh__wrappee__Base_#in~rjh___0#1 := setup_rjh_~rjh___0#1;havoc setup_rjh__wrappee__Base_~rjh___0#1;setup_rjh__wrappee__Base_~rjh___0#1 := setup_rjh__wrappee__Base_#in~rjh___0#1; {21955#true} is VALID [2022-02-20 18:04:07,760 INFO L272 TraceCheckUtils]: 18: Hoare triple {21955#true} call setClientId(setup_rjh__wrappee__Base_~rjh___0#1, setup_rjh__wrappee__Base_~rjh___0#1); {22020#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} is VALID [2022-02-20 18:04:07,760 INFO L290 TraceCheckUtils]: 19: Hoare triple {22020#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {21955#true} is VALID [2022-02-20 18:04:07,760 INFO L290 TraceCheckUtils]: 20: Hoare triple {21955#true} assume !(1 == ~handle); {21955#true} is VALID [2022-02-20 18:04:07,760 INFO L290 TraceCheckUtils]: 21: Hoare triple {21955#true} assume 2 == ~handle;~__ste_client_idCounter1~0 := ~value; {21955#true} is VALID [2022-02-20 18:04:07,760 INFO L290 TraceCheckUtils]: 22: Hoare triple {21955#true} assume true; {21955#true} is VALID [2022-02-20 18:04:07,760 INFO L284 TraceCheckUtils]: 23: Hoare quadruple {21955#true} {21955#true} #1228#return; {21955#true} is VALID [2022-02-20 18:04:07,760 INFO L290 TraceCheckUtils]: 24: Hoare triple {21955#true} assume { :end_inline_setup_rjh__wrappee__Base } true; {21955#true} is VALID [2022-02-20 18:04:07,761 INFO L272 TraceCheckUtils]: 25: Hoare triple {21955#true} call setClientPrivateKey(setup_rjh_~rjh___0#1, 456); {22021#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} is VALID [2022-02-20 18:04:07,761 INFO L290 TraceCheckUtils]: 26: Hoare triple {22021#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {21955#true} is VALID [2022-02-20 18:04:07,761 INFO L290 TraceCheckUtils]: 27: Hoare triple {21955#true} assume !(1 == ~handle); {21955#true} is VALID [2022-02-20 18:04:07,761 INFO L290 TraceCheckUtils]: 28: Hoare triple {21955#true} assume 2 == ~handle;~__ste_client_privateKey1~0 := ~value; {21955#true} is VALID [2022-02-20 18:04:07,761 INFO L290 TraceCheckUtils]: 29: Hoare triple {21955#true} assume true; {21955#true} is VALID [2022-02-20 18:04:07,761 INFO L284 TraceCheckUtils]: 30: Hoare quadruple {21955#true} {21955#true} #1230#return; {21955#true} is VALID [2022-02-20 18:04:07,762 INFO L290 TraceCheckUtils]: 31: Hoare triple {21955#true} assume { :end_inline_setup_rjh } true;setup_~__cil_tmp2~1#1.base, setup_~__cil_tmp2~1#1.offset := 38, 0;havoc setup_#t~nondet98#1;~chuck~0 := 3;assume { :begin_inline_setup_chuck } true;setup_chuck_#in~chuck___0#1 := ~chuck~0;havoc setup_chuck_~chuck___0#1;setup_chuck_~chuck___0#1 := setup_chuck_#in~chuck___0#1;assume { :begin_inline_setup_chuck__wrappee__Base } true;setup_chuck__wrappee__Base_#in~chuck___0#1 := setup_chuck_~chuck___0#1;havoc setup_chuck__wrappee__Base_~chuck___0#1;setup_chuck__wrappee__Base_~chuck___0#1 := setup_chuck__wrappee__Base_#in~chuck___0#1; {21975#(= |ULTIMATE.start_setup_chuck_~chuck___0#1| |ULTIMATE.start_setup_chuck__wrappee__Base_~chuck___0#1|)} is VALID [2022-02-20 18:04:07,762 INFO L272 TraceCheckUtils]: 32: Hoare triple {21975#(= |ULTIMATE.start_setup_chuck_~chuck___0#1| |ULTIMATE.start_setup_chuck__wrappee__Base_~chuck___0#1|)} call setClientId(setup_chuck__wrappee__Base_~chuck___0#1, setup_chuck__wrappee__Base_~chuck___0#1); {22020#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} is VALID [2022-02-20 18:04:07,762 INFO L290 TraceCheckUtils]: 33: Hoare triple {22020#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {22022#(= setClientId_~handle |setClientId_#in~handle|)} is VALID [2022-02-20 18:04:07,763 INFO L290 TraceCheckUtils]: 34: Hoare triple {22022#(= setClientId_~handle |setClientId_#in~handle|)} assume !(1 == ~handle); {22022#(= setClientId_~handle |setClientId_#in~handle|)} is VALID [2022-02-20 18:04:07,763 INFO L290 TraceCheckUtils]: 35: Hoare triple {22022#(= setClientId_~handle |setClientId_#in~handle|)} assume !(2 == ~handle); {22022#(= setClientId_~handle |setClientId_#in~handle|)} is VALID [2022-02-20 18:04:07,763 INFO L290 TraceCheckUtils]: 36: Hoare triple {22022#(= setClientId_~handle |setClientId_#in~handle|)} assume 3 == ~handle;~__ste_client_idCounter2~0 := ~value; {22023#(= 3 |setClientId_#in~handle|)} is VALID [2022-02-20 18:04:07,764 INFO L290 TraceCheckUtils]: 37: Hoare triple {22023#(= 3 |setClientId_#in~handle|)} assume true; {22023#(= 3 |setClientId_#in~handle|)} is VALID [2022-02-20 18:04:07,764 INFO L284 TraceCheckUtils]: 38: Hoare quadruple {22023#(= 3 |setClientId_#in~handle|)} {21975#(= |ULTIMATE.start_setup_chuck_~chuck___0#1| |ULTIMATE.start_setup_chuck__wrappee__Base_~chuck___0#1|)} #1232#return; {21982#(not (= |ULTIMATE.start_setup_chuck_~chuck___0#1| 1))} is VALID [2022-02-20 18:04:07,764 INFO L290 TraceCheckUtils]: 39: Hoare triple {21982#(not (= |ULTIMATE.start_setup_chuck_~chuck___0#1| 1))} assume { :end_inline_setup_chuck__wrappee__Base } true; {21982#(not (= |ULTIMATE.start_setup_chuck_~chuck___0#1| 1))} is VALID [2022-02-20 18:04:07,765 INFO L272 TraceCheckUtils]: 40: Hoare triple {21982#(not (= |ULTIMATE.start_setup_chuck_~chuck___0#1| 1))} call setClientPrivateKey(setup_chuck_~chuck___0#1, 789); {22021#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} is VALID [2022-02-20 18:04:07,765 INFO L290 TraceCheckUtils]: 41: Hoare triple {22021#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {22024#(= setClientPrivateKey_~handle |setClientPrivateKey_#in~handle|)} is VALID [2022-02-20 18:04:07,765 INFO L290 TraceCheckUtils]: 42: Hoare triple {22024#(= setClientPrivateKey_~handle |setClientPrivateKey_#in~handle|)} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {22025#(= |setClientPrivateKey_#in~handle| 1)} is VALID [2022-02-20 18:04:07,766 INFO L290 TraceCheckUtils]: 43: Hoare triple {22025#(= |setClientPrivateKey_#in~handle| 1)} assume true; {22025#(= |setClientPrivateKey_#in~handle| 1)} is VALID [2022-02-20 18:04:07,766 INFO L284 TraceCheckUtils]: 44: Hoare quadruple {22025#(= |setClientPrivateKey_#in~handle| 1)} {21982#(not (= |ULTIMATE.start_setup_chuck_~chuck___0#1| 1))} #1234#return; {21956#false} is VALID [2022-02-20 18:04:07,766 INFO L290 TraceCheckUtils]: 45: Hoare triple {21956#false} assume { :end_inline_setup_chuck } true;setup_~__cil_tmp3~4#1.base, setup_~__cil_tmp3~4#1.offset := 39, 0;havoc setup_#t~nondet99#1; {21956#false} is VALID [2022-02-20 18:04:07,766 INFO L290 TraceCheckUtils]: 46: Hoare triple {21956#false} assume { :end_inline_setup } true;assume { :begin_inline_test } true;havoc test_#t~nondet55#1, test_#t~nondet56#1, test_#t~nondet57#1, test_#t~nondet58#1, test_#t~nondet59#1, test_#t~nondet60#1, test_#t~nondet61#1, test_#t~nondet62#1, test_#t~nondet63#1, test_#t~nondet64#1, test_#t~nondet65#1, test_~op1~0#1, test_~op2~0#1, test_~op3~0#1, test_~op4~0#1, test_~op5~0#1, test_~op6~0#1, test_~op7~0#1, test_~op8~0#1, test_~op9~0#1, test_~op10~0#1, test_~op11~0#1, test_~splverifierCounter~0#1, test_~tmp~9#1, test_~tmp___0~3#1, test_~tmp___1~1#1, test_~tmp___2~1#1, test_~tmp___3~0#1, test_~tmp___4~0#1, test_~tmp___5~0#1, test_~tmp___6~0#1, test_~tmp___7~0#1, test_~tmp___8~0#1, test_~tmp___9~0#1;havoc test_~op1~0#1;havoc test_~op2~0#1;havoc test_~op3~0#1;havoc test_~op4~0#1;havoc test_~op5~0#1;havoc test_~op6~0#1;havoc test_~op7~0#1;havoc test_~op8~0#1;havoc test_~op9~0#1;havoc test_~op10~0#1;havoc test_~op11~0#1;havoc test_~splverifierCounter~0#1;havoc test_~tmp~9#1;havoc test_~tmp___0~3#1;havoc test_~tmp___1~1#1;havoc test_~tmp___2~1#1;havoc test_~tmp___3~0#1;havoc test_~tmp___4~0#1;havoc test_~tmp___5~0#1;havoc test_~tmp___6~0#1;havoc test_~tmp___7~0#1;havoc test_~tmp___8~0#1;havoc test_~tmp___9~0#1;test_~op1~0#1 := 0;test_~op2~0#1 := 0;test_~op3~0#1 := 0;test_~op4~0#1 := 0;test_~op5~0#1 := 0;test_~op6~0#1 := 0;test_~op7~0#1 := 0;test_~op8~0#1 := 0;test_~op9~0#1 := 0;test_~op10~0#1 := 0;test_~op11~0#1 := 0;test_~splverifierCounter~0#1 := 0; {21956#false} is VALID [2022-02-20 18:04:07,766 INFO L290 TraceCheckUtils]: 47: Hoare triple {21956#false} assume !false; {21956#false} is VALID [2022-02-20 18:04:07,766 INFO L290 TraceCheckUtils]: 48: Hoare triple {21956#false} assume test_~splverifierCounter~0#1 < 4; {21956#false} is VALID [2022-02-20 18:04:07,767 INFO L290 TraceCheckUtils]: 49: Hoare triple {21956#false} test_~splverifierCounter~0#1 := 1 + test_~splverifierCounter~0#1; {21956#false} is VALID [2022-02-20 18:04:07,767 INFO L290 TraceCheckUtils]: 50: Hoare triple {21956#false} assume 0 == test_~op1~0#1;assume -2147483648 <= test_#t~nondet55#1 && test_#t~nondet55#1 <= 2147483647;test_~tmp___9~0#1 := test_#t~nondet55#1;havoc test_#t~nondet55#1; {21956#false} is VALID [2022-02-20 18:04:07,767 INFO L290 TraceCheckUtils]: 51: Hoare triple {21956#false} assume !(0 != test_~tmp___9~0#1); {21956#false} is VALID [2022-02-20 18:04:07,767 INFO L290 TraceCheckUtils]: 52: Hoare triple {21956#false} assume 0 == test_~op2~0#1;assume -2147483648 <= test_#t~nondet56#1 && test_#t~nondet56#1 <= 2147483647;test_~tmp___8~0#1 := test_#t~nondet56#1;havoc test_#t~nondet56#1; {21956#false} is VALID [2022-02-20 18:04:07,767 INFO L290 TraceCheckUtils]: 53: Hoare triple {21956#false} assume 0 != test_~tmp___8~0#1;test_~op2~0#1 := 1; {21956#false} is VALID [2022-02-20 18:04:07,767 INFO L290 TraceCheckUtils]: 54: Hoare triple {21956#false} assume !false; {21956#false} is VALID [2022-02-20 18:04:07,767 INFO L290 TraceCheckUtils]: 55: Hoare triple {21956#false} assume !(test_~splverifierCounter~0#1 < 4); {21956#false} is VALID [2022-02-20 18:04:07,767 INFO L290 TraceCheckUtils]: 56: Hoare triple {21956#false} assume { :begin_inline_bobToRjh } true;havoc bobToRjh_#t~ret92#1, bobToRjh_#t~ret93#1, bobToRjh_#t~ret94#1, bobToRjh_#t~ret95#1, bobToRjh_~tmp~19#1, bobToRjh_~tmp___0~8#1, bobToRjh_~tmp___1~5#1;havoc bobToRjh_~tmp~19#1;havoc bobToRjh_~tmp___0~8#1;havoc bobToRjh_~tmp___1~5#1;call bobToRjh_#t~ret92#1 := puts(35, 0);assume -2147483648 <= bobToRjh_#t~ret92#1 && bobToRjh_#t~ret92#1 <= 2147483647;havoc bobToRjh_#t~ret92#1; {21956#false} is VALID [2022-02-20 18:04:07,767 INFO L272 TraceCheckUtils]: 57: Hoare triple {21956#false} call sendEmail(~bob~0, ~rjh~0); {21956#false} is VALID [2022-02-20 18:04:07,768 INFO L290 TraceCheckUtils]: 58: Hoare triple {21956#false} ~sender#1 := #in~sender#1;~receiver#1 := #in~receiver#1;havoc ~email~0#1;havoc ~tmp~16#1;assume { :begin_inline_createEmail } true;createEmail_#in~from#1, createEmail_#in~to#1 := 0, ~receiver#1;havoc createEmail_#res#1;havoc createEmail_~from#1, createEmail_~to#1, createEmail_~retValue_acc~16#1, createEmail_~msg~0#1;createEmail_~from#1 := createEmail_#in~from#1;createEmail_~to#1 := createEmail_#in~to#1;havoc createEmail_~retValue_acc~16#1;havoc createEmail_~msg~0#1;createEmail_~msg~0#1 := 1; {21956#false} is VALID [2022-02-20 18:04:07,768 INFO L272 TraceCheckUtils]: 59: Hoare triple {21956#false} call setEmailFrom(createEmail_~msg~0#1, createEmail_~from#1); {22026#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} is VALID [2022-02-20 18:04:07,768 INFO L290 TraceCheckUtils]: 60: Hoare triple {22026#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} ~handle := #in~handle;~value := #in~value; {21955#true} is VALID [2022-02-20 18:04:07,768 INFO L290 TraceCheckUtils]: 61: Hoare triple {21955#true} assume 1 == ~handle;~__ste_email_from0~0 := ~value; {21955#true} is VALID [2022-02-20 18:04:07,768 INFO L290 TraceCheckUtils]: 62: Hoare triple {21955#true} assume true; {21955#true} is VALID [2022-02-20 18:04:07,768 INFO L284 TraceCheckUtils]: 63: Hoare quadruple {21955#true} {21956#false} #1210#return; {21956#false} is VALID [2022-02-20 18:04:07,768 INFO L272 TraceCheckUtils]: 64: Hoare triple {21956#false} call setEmailTo(createEmail_~msg~0#1, createEmail_~to#1); {22027#(and (= ~__ste_email_to0~0 |old(~__ste_email_to0~0)|) (= ~__ste_email_to1~0 |old(~__ste_email_to1~0)|))} is VALID [2022-02-20 18:04:07,768 INFO L290 TraceCheckUtils]: 65: Hoare triple {22027#(and (= ~__ste_email_to0~0 |old(~__ste_email_to0~0)|) (= ~__ste_email_to1~0 |old(~__ste_email_to1~0)|))} ~handle := #in~handle;~value := #in~value; {21955#true} is VALID [2022-02-20 18:04:07,768 INFO L290 TraceCheckUtils]: 66: Hoare triple {21955#true} assume 1 == ~handle;~__ste_email_to0~0 := ~value; {21955#true} is VALID [2022-02-20 18:04:07,769 INFO L290 TraceCheckUtils]: 67: Hoare triple {21955#true} assume true; {21955#true} is VALID [2022-02-20 18:04:07,769 INFO L284 TraceCheckUtils]: 68: Hoare quadruple {21955#true} {21956#false} #1212#return; {21956#false} is VALID [2022-02-20 18:04:07,769 INFO L290 TraceCheckUtils]: 69: Hoare triple {21956#false} createEmail_~retValue_acc~16#1 := createEmail_~msg~0#1;createEmail_#res#1 := createEmail_~retValue_acc~16#1; {21956#false} is VALID [2022-02-20 18:04:07,769 INFO L290 TraceCheckUtils]: 70: Hoare triple {21956#false} #t~ret83#1 := createEmail_#res#1;assume { :end_inline_createEmail } true;assume -2147483648 <= #t~ret83#1 && #t~ret83#1 <= 2147483647;~tmp~16#1 := #t~ret83#1;havoc #t~ret83#1;~email~0#1 := ~tmp~16#1; {21956#false} is VALID [2022-02-20 18:04:07,769 INFO L272 TraceCheckUtils]: 71: Hoare triple {21956#false} call outgoing(~sender#1, ~email~0#1); {21956#false} is VALID [2022-02-20 18:04:07,769 INFO L290 TraceCheckUtils]: 72: Hoare triple {21956#false} ~client#1 := #in~client#1;~msg#1 := #in~msg#1;assume { :begin_inline_sign } true;sign_#in~client#1, sign_#in~msg#1 := ~client#1, ~msg#1;havoc sign_#t~ret85#1, sign_~client#1, sign_~msg#1, sign_~privkey~1#1, sign_~tmp~17#1;sign_~client#1 := sign_#in~client#1;sign_~msg#1 := sign_#in~msg#1;havoc sign_~privkey~1#1;havoc sign_~tmp~17#1; {21956#false} is VALID [2022-02-20 18:04:07,769 INFO L272 TraceCheckUtils]: 73: Hoare triple {21956#false} call sign_#t~ret85#1 := getClientPrivateKey(sign_~client#1); {21955#true} is VALID [2022-02-20 18:04:07,769 INFO L290 TraceCheckUtils]: 74: Hoare triple {21955#true} ~handle := #in~handle;havoc ~retValue_acc~36; {21955#true} is VALID [2022-02-20 18:04:07,769 INFO L290 TraceCheckUtils]: 75: Hoare triple {21955#true} assume 1 == ~handle;~retValue_acc~36 := ~__ste_client_privateKey0~0;#res := ~retValue_acc~36; {21955#true} is VALID [2022-02-20 18:04:07,770 INFO L290 TraceCheckUtils]: 76: Hoare triple {21955#true} assume true; {21955#true} is VALID [2022-02-20 18:04:07,770 INFO L284 TraceCheckUtils]: 77: Hoare quadruple {21955#true} {21956#false} #1150#return; {21956#false} is VALID [2022-02-20 18:04:07,770 INFO L290 TraceCheckUtils]: 78: Hoare triple {21956#false} assume -2147483648 <= sign_#t~ret85#1 && sign_#t~ret85#1 <= 2147483647;sign_~tmp~17#1 := sign_#t~ret85#1;havoc sign_#t~ret85#1;sign_~privkey~1#1 := sign_~tmp~17#1; {21956#false} is VALID [2022-02-20 18:04:07,770 INFO L290 TraceCheckUtils]: 79: Hoare triple {21956#false} assume 0 == sign_~privkey~1#1; {21956#false} is VALID [2022-02-20 18:04:07,770 INFO L290 TraceCheckUtils]: 80: Hoare triple {21956#false} assume { :end_inline_sign } true;assume { :begin_inline_outgoing__wrappee__AddressBook } true;outgoing__wrappee__AddressBook_#in~client#1, outgoing__wrappee__AddressBook_#in~msg#1 := ~client#1, ~msg#1;havoc outgoing__wrappee__AddressBook_#t~ret71#1, outgoing__wrappee__AddressBook_#t~ret72#1, outgoing__wrappee__AddressBook_#t~ret73#1, outgoing__wrappee__AddressBook_#t~ret74#1, outgoing__wrappee__AddressBook_#t~ret75#1, outgoing__wrappee__AddressBook_#t~ret76#1, outgoing__wrappee__AddressBook_~client#1, outgoing__wrappee__AddressBook_~msg#1, outgoing__wrappee__AddressBook_~size~0#1, outgoing__wrappee__AddressBook_~tmp~13#1, outgoing__wrappee__AddressBook_~receiver~1#1, outgoing__wrappee__AddressBook_~tmp___0~5#1, outgoing__wrappee__AddressBook_~second~0#1, outgoing__wrappee__AddressBook_~tmp___1~2#1, outgoing__wrappee__AddressBook_~tmp___2~2#1;outgoing__wrappee__AddressBook_~client#1 := outgoing__wrappee__AddressBook_#in~client#1;outgoing__wrappee__AddressBook_~msg#1 := outgoing__wrappee__AddressBook_#in~msg#1;havoc outgoing__wrappee__AddressBook_~size~0#1;havoc outgoing__wrappee__AddressBook_~tmp~13#1;havoc outgoing__wrappee__AddressBook_~receiver~1#1;havoc outgoing__wrappee__AddressBook_~tmp___0~5#1;havoc outgoing__wrappee__AddressBook_~second~0#1;havoc outgoing__wrappee__AddressBook_~tmp___1~2#1;havoc outgoing__wrappee__AddressBook_~tmp___2~2#1; {21956#false} is VALID [2022-02-20 18:04:07,770 INFO L272 TraceCheckUtils]: 81: Hoare triple {21956#false} call outgoing__wrappee__AddressBook_#t~ret71#1 := getClientAddressBookSize(outgoing__wrappee__AddressBook_~client#1); {21955#true} is VALID [2022-02-20 18:04:07,770 INFO L290 TraceCheckUtils]: 82: Hoare triple {21955#true} ~handle := #in~handle;havoc ~retValue_acc~30; {21955#true} is VALID [2022-02-20 18:04:07,770 INFO L290 TraceCheckUtils]: 83: Hoare triple {21955#true} assume 1 == ~handle;~retValue_acc~30 := ~__ste_ClientAddressBook_size0~0;#res := ~retValue_acc~30; {21955#true} is VALID [2022-02-20 18:04:07,770 INFO L290 TraceCheckUtils]: 84: Hoare triple {21955#true} assume true; {21955#true} is VALID [2022-02-20 18:04:07,771 INFO L284 TraceCheckUtils]: 85: Hoare quadruple {21955#true} {21956#false} #1152#return; {21956#false} is VALID [2022-02-20 18:04:07,771 INFO L290 TraceCheckUtils]: 86: Hoare triple {21956#false} assume -2147483648 <= outgoing__wrappee__AddressBook_#t~ret71#1 && outgoing__wrappee__AddressBook_#t~ret71#1 <= 2147483647;outgoing__wrappee__AddressBook_~tmp~13#1 := outgoing__wrappee__AddressBook_#t~ret71#1;havoc outgoing__wrappee__AddressBook_#t~ret71#1;outgoing__wrappee__AddressBook_~size~0#1 := outgoing__wrappee__AddressBook_~tmp~13#1; {21956#false} is VALID [2022-02-20 18:04:07,771 INFO L290 TraceCheckUtils]: 87: Hoare triple {21956#false} assume !(0 != outgoing__wrappee__AddressBook_~size~0#1); {21956#false} is VALID [2022-02-20 18:04:07,771 INFO L272 TraceCheckUtils]: 88: Hoare triple {21956#false} call outgoing__wrappee__Encrypt(outgoing__wrappee__AddressBook_~client#1, outgoing__wrappee__AddressBook_~msg#1); {21956#false} is VALID [2022-02-20 18:04:07,771 INFO L290 TraceCheckUtils]: 89: Hoare triple {21956#false} ~client#1 := #in~client#1;~msg#1 := #in~msg#1;havoc ~receiver~0#1;havoc ~tmp~12#1;havoc ~pubkey~0#1;havoc ~tmp___0~4#1; {21956#false} is VALID [2022-02-20 18:04:07,771 INFO L272 TraceCheckUtils]: 90: Hoare triple {21956#false} call #t~ret69#1 := getEmailTo(~msg#1); {21955#true} is VALID [2022-02-20 18:04:07,771 INFO L290 TraceCheckUtils]: 91: Hoare triple {21955#true} ~handle := #in~handle;havoc ~retValue_acc~3; {21955#true} is VALID [2022-02-20 18:04:07,771 INFO L290 TraceCheckUtils]: 92: Hoare triple {21955#true} assume 1 == ~handle;~retValue_acc~3 := ~__ste_email_to0~0;#res := ~retValue_acc~3; {21955#true} is VALID [2022-02-20 18:04:07,771 INFO L290 TraceCheckUtils]: 93: Hoare triple {21955#true} assume true; {21955#true} is VALID [2022-02-20 18:04:07,772 INFO L284 TraceCheckUtils]: 94: Hoare quadruple {21955#true} {21956#false} #1170#return; {21956#false} is VALID [2022-02-20 18:04:07,772 INFO L290 TraceCheckUtils]: 95: Hoare triple {21956#false} assume -2147483648 <= #t~ret69#1 && #t~ret69#1 <= 2147483647;~tmp~12#1 := #t~ret69#1;havoc #t~ret69#1;~receiver~0#1 := ~tmp~12#1; {21956#false} is VALID [2022-02-20 18:04:07,772 INFO L272 TraceCheckUtils]: 96: Hoare triple {21956#false} call #t~ret70#1 := findPublicKey(~client#1, ~receiver~0#1); {21955#true} is VALID [2022-02-20 18:04:07,772 INFO L290 TraceCheckUtils]: 97: Hoare triple {21955#true} ~handle := #in~handle;~userid := #in~userid;havoc ~retValue_acc~41; {21955#true} is VALID [2022-02-20 18:04:07,772 INFO L290 TraceCheckUtils]: 98: Hoare triple {21955#true} assume 1 == ~handle; {21955#true} is VALID [2022-02-20 18:04:07,772 INFO L290 TraceCheckUtils]: 99: Hoare triple {21955#true} assume ~userid == ~__ste_Client_Keyring0_User0~0;~retValue_acc~41 := ~__ste_Client_Keyring0_PublicKey0~0;#res := ~retValue_acc~41; {21955#true} is VALID [2022-02-20 18:04:07,772 INFO L290 TraceCheckUtils]: 100: Hoare triple {21955#true} assume true; {21955#true} is VALID [2022-02-20 18:04:07,772 INFO L284 TraceCheckUtils]: 101: Hoare quadruple {21955#true} {21956#false} #1172#return; {21956#false} is VALID [2022-02-20 18:04:07,773 INFO L290 TraceCheckUtils]: 102: Hoare triple {21956#false} assume -2147483648 <= #t~ret70#1 && #t~ret70#1 <= 2147483647;~tmp___0~4#1 := #t~ret70#1;havoc #t~ret70#1;~pubkey~0#1 := ~tmp___0~4#1; {21956#false} is VALID [2022-02-20 18:04:07,773 INFO L290 TraceCheckUtils]: 103: Hoare triple {21956#false} assume !(0 != ~pubkey~0#1); {21956#false} is VALID [2022-02-20 18:04:07,773 INFO L290 TraceCheckUtils]: 104: Hoare triple {21956#false} assume { :begin_inline_outgoing__wrappee__Keys } true;outgoing__wrappee__Keys_#in~client#1, outgoing__wrappee__Keys_#in~msg#1 := ~client#1, ~msg#1;havoc outgoing__wrappee__Keys_#t~ret68#1, outgoing__wrappee__Keys_~client#1, outgoing__wrappee__Keys_~msg#1, outgoing__wrappee__Keys_~tmp~11#1;outgoing__wrappee__Keys_~client#1 := outgoing__wrappee__Keys_#in~client#1;outgoing__wrappee__Keys_~msg#1 := outgoing__wrappee__Keys_#in~msg#1;havoc outgoing__wrappee__Keys_~tmp~11#1;assume { :begin_inline_getClientId } true;getClientId_#in~handle#1 := outgoing__wrappee__Keys_~client#1;havoc getClientId_#res#1;havoc getClientId_~handle#1, getClientId_~retValue_acc~43#1;getClientId_~handle#1 := getClientId_#in~handle#1;havoc getClientId_~retValue_acc~43#1; {21956#false} is VALID [2022-02-20 18:04:07,773 INFO L290 TraceCheckUtils]: 105: Hoare triple {21956#false} assume 1 == getClientId_~handle#1;getClientId_~retValue_acc~43#1 := ~__ste_client_idCounter0~0;getClientId_#res#1 := getClientId_~retValue_acc~43#1; {21956#false} is VALID [2022-02-20 18:04:07,773 INFO L290 TraceCheckUtils]: 106: Hoare triple {21956#false} outgoing__wrappee__Keys_#t~ret68#1 := getClientId_#res#1;assume { :end_inline_getClientId } true;assume -2147483648 <= outgoing__wrappee__Keys_#t~ret68#1 && outgoing__wrappee__Keys_#t~ret68#1 <= 2147483647;outgoing__wrappee__Keys_~tmp~11#1 := outgoing__wrappee__Keys_#t~ret68#1;havoc outgoing__wrappee__Keys_#t~ret68#1; {21956#false} is VALID [2022-02-20 18:04:07,773 INFO L272 TraceCheckUtils]: 107: Hoare triple {21956#false} call setEmailFrom(outgoing__wrappee__Keys_~msg#1, outgoing__wrappee__Keys_~tmp~11#1); {22026#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} is VALID [2022-02-20 18:04:07,773 INFO L290 TraceCheckUtils]: 108: Hoare triple {22026#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} ~handle := #in~handle;~value := #in~value; {21955#true} is VALID [2022-02-20 18:04:07,773 INFO L290 TraceCheckUtils]: 109: Hoare triple {21955#true} assume 1 == ~handle;~__ste_email_from0~0 := ~value; {21955#true} is VALID [2022-02-20 18:04:07,773 INFO L290 TraceCheckUtils]: 110: Hoare triple {21955#true} assume true; {21955#true} is VALID [2022-02-20 18:04:07,774 INFO L284 TraceCheckUtils]: 111: Hoare quadruple {21955#true} {21956#false} #1178#return; {21956#false} is VALID [2022-02-20 18:04:07,774 INFO L290 TraceCheckUtils]: 112: Hoare triple {21956#false} assume { :begin_inline_mail } true;mail_#in~client#1, mail_#in~msg#1 := outgoing__wrappee__Keys_~client#1, outgoing__wrappee__Keys_~msg#1;havoc mail_#t~ret66#1, mail_#t~ret67#1, mail_~client#1, mail_~msg#1, mail_~__utac__ad__arg1~0#1, mail_~tmp~10#1;mail_~client#1 := mail_#in~client#1;mail_~msg#1 := mail_#in~msg#1;havoc mail_~__utac__ad__arg1~0#1;havoc mail_~tmp~10#1;mail_~__utac__ad__arg1~0#1 := mail_~msg#1;assume { :begin_inline___utac_acc__EncryptAutoResponder_spec__2 } true;__utac_acc__EncryptAutoResponder_spec__2_#in~msg#1 := mail_~__utac__ad__arg1~0#1;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1, __utac_acc__EncryptAutoResponder_spec__2_#t~nondet29#1, __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1, __utac_acc__EncryptAutoResponder_spec__2_~msg#1, __utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.base, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.offset;__utac_acc__EncryptAutoResponder_spec__2_~msg#1 := __utac_acc__EncryptAutoResponder_spec__2_#in~msg#1;havoc __utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1;havoc __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.base, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.offset;call __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1 := puts(15, 0);assume -2147483648 <= __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1 && __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1 <= 2147483647;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1;__utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.base, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.offset := 16, 0;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~nondet29#1; {21956#false} is VALID [2022-02-20 18:04:07,774 INFO L290 TraceCheckUtils]: 113: Hoare triple {21956#false} assume 0 != ~in_encrypted~0; {21956#false} is VALID [2022-02-20 18:04:07,774 INFO L272 TraceCheckUtils]: 114: Hoare triple {21956#false} call __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1 := isEncrypted(__utac_acc__EncryptAutoResponder_spec__2_~msg#1); {21955#true} is VALID [2022-02-20 18:04:07,774 INFO L290 TraceCheckUtils]: 115: Hoare triple {21955#true} ~handle := #in~handle;havoc ~retValue_acc~6; {21955#true} is VALID [2022-02-20 18:04:07,774 INFO L290 TraceCheckUtils]: 116: Hoare triple {21955#true} assume 1 == ~handle;~retValue_acc~6 := ~__ste_email_isEncrypted0~0;#res := ~retValue_acc~6; {21955#true} is VALID [2022-02-20 18:04:07,774 INFO L290 TraceCheckUtils]: 117: Hoare triple {21955#true} assume true; {21955#true} is VALID [2022-02-20 18:04:07,774 INFO L284 TraceCheckUtils]: 118: Hoare quadruple {21955#true} {21956#false} #1180#return; {21956#false} is VALID [2022-02-20 18:04:07,775 INFO L290 TraceCheckUtils]: 119: Hoare triple {21956#false} assume -2147483648 <= __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1 && __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1 <= 2147483647;__utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1 := __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1; {21956#false} is VALID [2022-02-20 18:04:07,775 INFO L290 TraceCheckUtils]: 120: Hoare triple {21956#false} assume !(0 != __utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1);assume { :begin_inline___automaton_fail } true; {21956#false} is VALID [2022-02-20 18:04:07,775 INFO L290 TraceCheckUtils]: 121: Hoare triple {21956#false} assume !false; {21956#false} is VALID [2022-02-20 18:04:07,775 INFO L134 CoverageAnalysis]: Checked inductivity of 31 backedges. 13 proven. 0 refuted. 0 times theorem prover too weak. 18 trivial. 0 not checked. [2022-02-20 18:04:07,775 INFO L144 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-02-20 18:04:07,775 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [723440617] [2022-02-20 18:04:07,775 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleSmtInterpolCraig [723440617] provided 1 perfect and 0 imperfect interpolant sequences [2022-02-20 18:04:07,776 INFO L191 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-02-20 18:04:07,776 INFO L204 FreeRefinementEngine]: Number of different interpolants: perfect sequences [12] imperfect sequences [] total 12 [2022-02-20 18:04:07,776 INFO L118 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [1644052249] [2022-02-20 18:04:07,776 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-02-20 18:04:07,776 INFO L78 Accepts]: Start accepts. Automaton has has 12 states, 11 states have (on average 7.545454545454546) internal successors, (83), 8 states have internal predecessors, (83), 4 states have call successors, (17), 6 states have call predecessors, (17), 3 states have return successors, (14), 3 states have call predecessors, (14), 4 states have call successors, (14) Word has length 122 [2022-02-20 18:04:07,777 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-02-20 18:04:07,777 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with has 12 states, 11 states have (on average 7.545454545454546) internal successors, (83), 8 states have internal predecessors, (83), 4 states have call successors, (17), 6 states have call predecessors, (17), 3 states have return successors, (14), 3 states have call predecessors, (14), 4 states have call successors, (14) [2022-02-20 18:04:07,852 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 114 edges. 114 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 18:04:07,852 INFO L546 AbstractCegarLoop]: INTERPOLANT automaton has 12 states [2022-02-20 18:04:07,853 INFO L108 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2022-02-20 18:04:07,853 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 12 interpolants. [2022-02-20 18:04:07,853 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=21, Invalid=111, Unknown=0, NotChecked=0, Total=132 [2022-02-20 18:04:07,854 INFO L87 Difference]: Start difference. First operand 472 states and 727 transitions. Second operand has 12 states, 11 states have (on average 7.545454545454546) internal successors, (83), 8 states have internal predecessors, (83), 4 states have call successors, (17), 6 states have call predecessors, (17), 3 states have return successors, (14), 3 states have call predecessors, (14), 4 states have call successors, (14) [2022-02-20 18:04:18,656 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 18:04:18,656 INFO L93 Difference]: Finished difference Result 1020 states and 1590 transitions. [2022-02-20 18:04:18,656 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 14 states. [2022-02-20 18:04:18,657 INFO L78 Accepts]: Start accepts. Automaton has has 12 states, 11 states have (on average 7.545454545454546) internal successors, (83), 8 states have internal predecessors, (83), 4 states have call successors, (17), 6 states have call predecessors, (17), 3 states have return successors, (14), 3 states have call predecessors, (14), 4 states have call successors, (14) Word has length 122 [2022-02-20 18:04:18,657 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-02-20 18:04:18,657 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 12 states, 11 states have (on average 7.545454545454546) internal successors, (83), 8 states have internal predecessors, (83), 4 states have call successors, (17), 6 states have call predecessors, (17), 3 states have return successors, (14), 3 states have call predecessors, (14), 4 states have call successors, (14) [2022-02-20 18:04:18,697 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 14 states to 14 states and 1358 transitions. [2022-02-20 18:04:18,698 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 12 states, 11 states have (on average 7.545454545454546) internal successors, (83), 8 states have internal predecessors, (83), 4 states have call successors, (17), 6 states have call predecessors, (17), 3 states have return successors, (14), 3 states have call predecessors, (14), 4 states have call successors, (14) [2022-02-20 18:04:18,714 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 14 states to 14 states and 1358 transitions. [2022-02-20 18:04:18,714 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with 14 states and 1358 transitions. [2022-02-20 18:04:19,874 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 1358 edges. 1358 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 18:04:19,905 INFO L225 Difference]: With dead ends: 1020 [2022-02-20 18:04:19,905 INFO L226 Difference]: Without dead ends: 575 [2022-02-20 18:04:19,907 INFO L932 BasicCegarLoop]: 0 DeclaredPredicates, 53 GetRequests, 31 SyntacticMatches, 0 SemanticMatches, 22 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 71 ImplicationChecksByTransitivity, 0.2s TimeCoverageRelationStatistics Valid=112, Invalid=440, Unknown=0, NotChecked=0, Total=552 [2022-02-20 18:04:19,908 INFO L933 BasicCegarLoop]: 621 mSDtfsCounter, 1625 mSDsluCounter, 1302 mSDsCounter, 0 mSdLazyCounter, 3820 mSolverCounterSat, 593 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 5.0s Time, 0 mProtectedPredicate, 0 mProtectedAction, 1625 SdHoareTripleChecker+Valid, 1923 SdHoareTripleChecker+Invalid, 4413 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 593 IncrementalHoareTripleChecker+Valid, 3820 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 5.1s IncrementalHoareTripleChecker+Time [2022-02-20 18:04:19,908 INFO L934 BasicCegarLoop]: SdHoareTripleChecker [1625 Valid, 1923 Invalid, 4413 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [593 Valid, 3820 Invalid, 0 Unknown, 0 Unchecked, 5.1s Time] [2022-02-20 18:04:19,909 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 575 states. [2022-02-20 18:04:20,028 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 575 to 472. [2022-02-20 18:04:20,028 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-02-20 18:04:20,030 INFO L82 GeneralOperation]: Start isEquivalent. First operand 575 states. Second operand has 472 states, 363 states have (on average 1.559228650137741) internal successors, (566), 370 states have internal predecessors, (566), 77 states have call successors, (77), 28 states have call predecessors, (77), 31 states have return successors, (83), 75 states have call predecessors, (83), 76 states have call successors, (83) [2022-02-20 18:04:20,030 INFO L74 IsIncluded]: Start isIncluded. First operand 575 states. Second operand has 472 states, 363 states have (on average 1.559228650137741) internal successors, (566), 370 states have internal predecessors, (566), 77 states have call successors, (77), 28 states have call predecessors, (77), 31 states have return successors, (83), 75 states have call predecessors, (83), 76 states have call successors, (83) [2022-02-20 18:04:20,040 INFO L87 Difference]: Start difference. First operand 575 states. Second operand has 472 states, 363 states have (on average 1.559228650137741) internal successors, (566), 370 states have internal predecessors, (566), 77 states have call successors, (77), 28 states have call predecessors, (77), 31 states have return successors, (83), 75 states have call predecessors, (83), 76 states have call successors, (83) [2022-02-20 18:04:20,057 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 18:04:20,058 INFO L93 Difference]: Finished difference Result 575 states and 900 transitions. [2022-02-20 18:04:20,058 INFO L276 IsEmpty]: Start isEmpty. Operand 575 states and 900 transitions. [2022-02-20 18:04:20,061 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 18:04:20,061 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 18:04:20,062 INFO L74 IsIncluded]: Start isIncluded. First operand has 472 states, 363 states have (on average 1.559228650137741) internal successors, (566), 370 states have internal predecessors, (566), 77 states have call successors, (77), 28 states have call predecessors, (77), 31 states have return successors, (83), 75 states have call predecessors, (83), 76 states have call successors, (83) Second operand 575 states. [2022-02-20 18:04:20,063 INFO L87 Difference]: Start difference. First operand has 472 states, 363 states have (on average 1.559228650137741) internal successors, (566), 370 states have internal predecessors, (566), 77 states have call successors, (77), 28 states have call predecessors, (77), 31 states have return successors, (83), 75 states have call predecessors, (83), 76 states have call successors, (83) Second operand 575 states. [2022-02-20 18:04:20,078 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 18:04:20,079 INFO L93 Difference]: Finished difference Result 575 states and 900 transitions. [2022-02-20 18:04:20,079 INFO L276 IsEmpty]: Start isEmpty. Operand 575 states and 900 transitions. [2022-02-20 18:04:20,081 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 18:04:20,081 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 18:04:20,082 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-02-20 18:04:20,082 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-02-20 18:04:20,083 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 472 states, 363 states have (on average 1.559228650137741) internal successors, (566), 370 states have internal predecessors, (566), 77 states have call successors, (77), 28 states have call predecessors, (77), 31 states have return successors, (83), 75 states have call predecessors, (83), 76 states have call successors, (83) [2022-02-20 18:04:20,094 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 472 states to 472 states and 726 transitions. [2022-02-20 18:04:20,095 INFO L78 Accepts]: Start accepts. Automaton has 472 states and 726 transitions. Word has length 122 [2022-02-20 18:04:20,095 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-02-20 18:04:20,095 INFO L470 AbstractCegarLoop]: Abstraction has 472 states and 726 transitions. [2022-02-20 18:04:20,095 INFO L471 AbstractCegarLoop]: INTERPOLANT automaton has has 12 states, 11 states have (on average 7.545454545454546) internal successors, (83), 8 states have internal predecessors, (83), 4 states have call successors, (17), 6 states have call predecessors, (17), 3 states have return successors, (14), 3 states have call predecessors, (14), 4 states have call successors, (14) [2022-02-20 18:04:20,096 INFO L276 IsEmpty]: Start isEmpty. Operand 472 states and 726 transitions. [2022-02-20 18:04:20,098 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 124 [2022-02-20 18:04:20,098 INFO L506 BasicCegarLoop]: Found error trace [2022-02-20 18:04:20,098 INFO L514 BasicCegarLoop]: trace histogram [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] [2022-02-20 18:04:20,098 WARN L452 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable7 [2022-02-20 18:04:20,098 INFO L402 AbstractCegarLoop]: === Iteration 9 === Targeting outgoing__wrappee__EncryptErr0ASSERT_VIOLATIONERROR_FUNCTION === [outgoing__wrappee__EncryptErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-02-20 18:04:20,098 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-02-20 18:04:20,099 INFO L85 PathProgramCache]: Analyzing trace with hash 2108958628, now seen corresponding path program 2 times [2022-02-20 18:04:20,099 INFO L126 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-02-20 18:04:20,099 INFO L338 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [180604461] [2022-02-20 18:04:20,099 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 18:04:20,099 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-02-20 18:04:20,121 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:04:20,151 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 6 [2022-02-20 18:04:20,153 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:04:20,155 INFO L290 TraceCheckUtils]: 0: Hoare triple {25333#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {25267#true} is VALID [2022-02-20 18:04:20,155 INFO L290 TraceCheckUtils]: 1: Hoare triple {25267#true} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {25267#true} is VALID [2022-02-20 18:04:20,155 INFO L290 TraceCheckUtils]: 2: Hoare triple {25267#true} assume true; {25267#true} is VALID [2022-02-20 18:04:20,155 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {25267#true} {25267#true} #1224#return; {25267#true} is VALID [2022-02-20 18:04:20,160 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 12 [2022-02-20 18:04:20,162 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:04:20,163 INFO L290 TraceCheckUtils]: 0: Hoare triple {25334#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {25267#true} is VALID [2022-02-20 18:04:20,164 INFO L290 TraceCheckUtils]: 1: Hoare triple {25267#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {25267#true} is VALID [2022-02-20 18:04:20,164 INFO L290 TraceCheckUtils]: 2: Hoare triple {25267#true} assume true; {25267#true} is VALID [2022-02-20 18:04:20,164 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {25267#true} {25267#true} #1226#return; {25267#true} is VALID [2022-02-20 18:04:20,164 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 18 [2022-02-20 18:04:20,165 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:04:20,167 INFO L290 TraceCheckUtils]: 0: Hoare triple {25333#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {25267#true} is VALID [2022-02-20 18:04:20,168 INFO L290 TraceCheckUtils]: 1: Hoare triple {25267#true} assume !(1 == ~handle); {25267#true} is VALID [2022-02-20 18:04:20,168 INFO L290 TraceCheckUtils]: 2: Hoare triple {25267#true} assume 2 == ~handle;~__ste_client_idCounter1~0 := ~value; {25267#true} is VALID [2022-02-20 18:04:20,168 INFO L290 TraceCheckUtils]: 3: Hoare triple {25267#true} assume true; {25267#true} is VALID [2022-02-20 18:04:20,168 INFO L284 TraceCheckUtils]: 4: Hoare quadruple {25267#true} {25267#true} #1228#return; {25267#true} is VALID [2022-02-20 18:04:20,168 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 25 [2022-02-20 18:04:20,170 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:04:20,172 INFO L290 TraceCheckUtils]: 0: Hoare triple {25334#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {25267#true} is VALID [2022-02-20 18:04:20,173 INFO L290 TraceCheckUtils]: 1: Hoare triple {25267#true} assume !(1 == ~handle); {25267#true} is VALID [2022-02-20 18:04:20,173 INFO L290 TraceCheckUtils]: 2: Hoare triple {25267#true} assume 2 == ~handle;~__ste_client_privateKey1~0 := ~value; {25267#true} is VALID [2022-02-20 18:04:20,173 INFO L290 TraceCheckUtils]: 3: Hoare triple {25267#true} assume true; {25267#true} is VALID [2022-02-20 18:04:20,173 INFO L284 TraceCheckUtils]: 4: Hoare quadruple {25267#true} {25267#true} #1230#return; {25267#true} is VALID [2022-02-20 18:04:20,173 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 32 [2022-02-20 18:04:20,175 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:04:20,189 INFO L290 TraceCheckUtils]: 0: Hoare triple {25333#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {25335#(= setClientId_~handle |setClientId_#in~handle|)} is VALID [2022-02-20 18:04:20,189 INFO L290 TraceCheckUtils]: 1: Hoare triple {25335#(= setClientId_~handle |setClientId_#in~handle|)} assume !(1 == ~handle); {25335#(= setClientId_~handle |setClientId_#in~handle|)} is VALID [2022-02-20 18:04:20,190 INFO L290 TraceCheckUtils]: 2: Hoare triple {25335#(= setClientId_~handle |setClientId_#in~handle|)} assume !(2 == ~handle); {25335#(= setClientId_~handle |setClientId_#in~handle|)} is VALID [2022-02-20 18:04:20,190 INFO L290 TraceCheckUtils]: 3: Hoare triple {25335#(= setClientId_~handle |setClientId_#in~handle|)} assume 3 == ~handle;~__ste_client_idCounter2~0 := ~value; {25336#(= 3 |setClientId_#in~handle|)} is VALID [2022-02-20 18:04:20,190 INFO L290 TraceCheckUtils]: 4: Hoare triple {25336#(= 3 |setClientId_#in~handle|)} assume true; {25336#(= 3 |setClientId_#in~handle|)} is VALID [2022-02-20 18:04:20,191 INFO L284 TraceCheckUtils]: 5: Hoare quadruple {25336#(= 3 |setClientId_#in~handle|)} {25287#(= |ULTIMATE.start_setup_chuck_~chuck___0#1| |ULTIMATE.start_setup_chuck__wrappee__Base_~chuck___0#1|)} #1232#return; {25294#(not (= |ULTIMATE.start_setup_chuck_~chuck___0#1| 2))} is VALID [2022-02-20 18:04:20,191 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 40 [2022-02-20 18:04:20,193 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:04:20,207 INFO L290 TraceCheckUtils]: 0: Hoare triple {25334#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {25337#(= setClientPrivateKey_~handle |setClientPrivateKey_#in~handle|)} is VALID [2022-02-20 18:04:20,208 INFO L290 TraceCheckUtils]: 1: Hoare triple {25337#(= setClientPrivateKey_~handle |setClientPrivateKey_#in~handle|)} assume !(1 == ~handle); {25337#(= setClientPrivateKey_~handle |setClientPrivateKey_#in~handle|)} is VALID [2022-02-20 18:04:20,208 INFO L290 TraceCheckUtils]: 2: Hoare triple {25337#(= setClientPrivateKey_~handle |setClientPrivateKey_#in~handle|)} assume 2 == ~handle;~__ste_client_privateKey1~0 := ~value; {25338#(= 2 |setClientPrivateKey_#in~handle|)} is VALID [2022-02-20 18:04:20,209 INFO L290 TraceCheckUtils]: 3: Hoare triple {25338#(= 2 |setClientPrivateKey_#in~handle|)} assume true; {25338#(= 2 |setClientPrivateKey_#in~handle|)} is VALID [2022-02-20 18:04:20,209 INFO L284 TraceCheckUtils]: 4: Hoare quadruple {25338#(= 2 |setClientPrivateKey_#in~handle|)} {25294#(not (= |ULTIMATE.start_setup_chuck_~chuck___0#1| 2))} #1234#return; {25268#false} is VALID [2022-02-20 18:04:20,217 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 60 [2022-02-20 18:04:20,218 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:04:20,220 INFO L290 TraceCheckUtils]: 0: Hoare triple {25339#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} ~handle := #in~handle;~value := #in~value; {25267#true} is VALID [2022-02-20 18:04:20,220 INFO L290 TraceCheckUtils]: 1: Hoare triple {25267#true} assume 1 == ~handle;~__ste_email_from0~0 := ~value; {25267#true} is VALID [2022-02-20 18:04:20,220 INFO L290 TraceCheckUtils]: 2: Hoare triple {25267#true} assume true; {25267#true} is VALID [2022-02-20 18:04:20,220 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {25267#true} {25268#false} #1210#return; {25268#false} is VALID [2022-02-20 18:04:20,228 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 65 [2022-02-20 18:04:20,229 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:04:20,231 INFO L290 TraceCheckUtils]: 0: Hoare triple {25340#(and (= ~__ste_email_to0~0 |old(~__ste_email_to0~0)|) (= ~__ste_email_to1~0 |old(~__ste_email_to1~0)|))} ~handle := #in~handle;~value := #in~value; {25267#true} is VALID [2022-02-20 18:04:20,231 INFO L290 TraceCheckUtils]: 1: Hoare triple {25267#true} assume 1 == ~handle;~__ste_email_to0~0 := ~value; {25267#true} is VALID [2022-02-20 18:04:20,231 INFO L290 TraceCheckUtils]: 2: Hoare triple {25267#true} assume true; {25267#true} is VALID [2022-02-20 18:04:20,232 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {25267#true} {25268#false} #1212#return; {25268#false} is VALID [2022-02-20 18:04:20,232 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 74 [2022-02-20 18:04:20,232 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:04:20,234 INFO L290 TraceCheckUtils]: 0: Hoare triple {25267#true} ~handle := #in~handle;havoc ~retValue_acc~36; {25267#true} is VALID [2022-02-20 18:04:20,234 INFO L290 TraceCheckUtils]: 1: Hoare triple {25267#true} assume 1 == ~handle;~retValue_acc~36 := ~__ste_client_privateKey0~0;#res := ~retValue_acc~36; {25267#true} is VALID [2022-02-20 18:04:20,234 INFO L290 TraceCheckUtils]: 2: Hoare triple {25267#true} assume true; {25267#true} is VALID [2022-02-20 18:04:20,234 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {25267#true} {25268#false} #1150#return; {25268#false} is VALID [2022-02-20 18:04:20,234 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 82 [2022-02-20 18:04:20,235 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:04:20,237 INFO L290 TraceCheckUtils]: 0: Hoare triple {25267#true} ~handle := #in~handle;havoc ~retValue_acc~30; {25267#true} is VALID [2022-02-20 18:04:20,237 INFO L290 TraceCheckUtils]: 1: Hoare triple {25267#true} assume 1 == ~handle;~retValue_acc~30 := ~__ste_ClientAddressBook_size0~0;#res := ~retValue_acc~30; {25267#true} is VALID [2022-02-20 18:04:20,237 INFO L290 TraceCheckUtils]: 2: Hoare triple {25267#true} assume true; {25267#true} is VALID [2022-02-20 18:04:20,237 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {25267#true} {25268#false} #1152#return; {25268#false} is VALID [2022-02-20 18:04:20,237 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 91 [2022-02-20 18:04:20,238 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:04:20,239 INFO L290 TraceCheckUtils]: 0: Hoare triple {25267#true} ~handle := #in~handle;havoc ~retValue_acc~3; {25267#true} is VALID [2022-02-20 18:04:20,240 INFO L290 TraceCheckUtils]: 1: Hoare triple {25267#true} assume 1 == ~handle;~retValue_acc~3 := ~__ste_email_to0~0;#res := ~retValue_acc~3; {25267#true} is VALID [2022-02-20 18:04:20,240 INFO L290 TraceCheckUtils]: 2: Hoare triple {25267#true} assume true; {25267#true} is VALID [2022-02-20 18:04:20,240 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {25267#true} {25268#false} #1170#return; {25268#false} is VALID [2022-02-20 18:04:20,240 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 97 [2022-02-20 18:04:20,241 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:04:20,243 INFO L290 TraceCheckUtils]: 0: Hoare triple {25267#true} ~handle := #in~handle;~userid := #in~userid;havoc ~retValue_acc~41; {25267#true} is VALID [2022-02-20 18:04:20,244 INFO L290 TraceCheckUtils]: 1: Hoare triple {25267#true} assume 1 == ~handle; {25267#true} is VALID [2022-02-20 18:04:20,244 INFO L290 TraceCheckUtils]: 2: Hoare triple {25267#true} assume ~userid == ~__ste_Client_Keyring0_User0~0;~retValue_acc~41 := ~__ste_Client_Keyring0_PublicKey0~0;#res := ~retValue_acc~41; {25267#true} is VALID [2022-02-20 18:04:20,244 INFO L290 TraceCheckUtils]: 3: Hoare triple {25267#true} assume true; {25267#true} is VALID [2022-02-20 18:04:20,244 INFO L284 TraceCheckUtils]: 4: Hoare quadruple {25267#true} {25268#false} #1172#return; {25268#false} is VALID [2022-02-20 18:04:20,244 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 108 [2022-02-20 18:04:20,245 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:04:20,247 INFO L290 TraceCheckUtils]: 0: Hoare triple {25339#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} ~handle := #in~handle;~value := #in~value; {25267#true} is VALID [2022-02-20 18:04:20,247 INFO L290 TraceCheckUtils]: 1: Hoare triple {25267#true} assume 1 == ~handle;~__ste_email_from0~0 := ~value; {25267#true} is VALID [2022-02-20 18:04:20,247 INFO L290 TraceCheckUtils]: 2: Hoare triple {25267#true} assume true; {25267#true} is VALID [2022-02-20 18:04:20,247 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {25267#true} {25268#false} #1178#return; {25268#false} is VALID [2022-02-20 18:04:20,247 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 115 [2022-02-20 18:04:20,248 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 18:04:20,251 INFO L290 TraceCheckUtils]: 0: Hoare triple {25267#true} ~handle := #in~handle;havoc ~retValue_acc~6; {25267#true} is VALID [2022-02-20 18:04:20,251 INFO L290 TraceCheckUtils]: 1: Hoare triple {25267#true} assume 1 == ~handle;~retValue_acc~6 := ~__ste_email_isEncrypted0~0;#res := ~retValue_acc~6; {25267#true} is VALID [2022-02-20 18:04:20,251 INFO L290 TraceCheckUtils]: 2: Hoare triple {25267#true} assume true; {25267#true} is VALID [2022-02-20 18:04:20,251 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {25267#true} {25268#false} #1180#return; {25268#false} is VALID [2022-02-20 18:04:20,252 INFO L290 TraceCheckUtils]: 0: Hoare triple {25267#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(28, 2);call #Ultimate.allocInit(12, 3);call #Ultimate.allocInit(10, 4);call #Ultimate.allocInit(12, 5);call #Ultimate.allocInit(10, 6);call #Ultimate.allocInit(18, 7);call #Ultimate.allocInit(16, 8);call #Ultimate.allocInit(21, 9);call #Ultimate.allocInit(13, 10);call #Ultimate.allocInit(16, 11);call #Ultimate.allocInit(25, 12);call #Ultimate.allocInit(17, 13);call #Ultimate.allocInit(17, 14);call #Ultimate.allocInit(13, 15);call #Ultimate.allocInit(17, 16);call #Ultimate.allocInit(30, 17);call #Ultimate.allocInit(9, 18);call #Ultimate.allocInit(21, 19);call #Ultimate.allocInit(30, 20);call #Ultimate.allocInit(9, 21);call #Ultimate.allocInit(21, 22);call #Ultimate.allocInit(30, 23);call #Ultimate.allocInit(9, 24);call #Ultimate.allocInit(25, 25);call #Ultimate.allocInit(30, 26);call #Ultimate.allocInit(9, 27);call #Ultimate.allocInit(25, 28);call #Ultimate.allocInit(4, 29);call write~init~int(37, 29, 0, 1);call write~init~int(115, 29, 1, 1);call write~init~int(10, 29, 2, 1);call write~init~int(0, 29, 3, 1);call #Ultimate.allocInit(10, 30);call #Ultimate.allocInit(34, 31);call #Ultimate.allocInit(30, 32);call #Ultimate.allocInit(16, 33);call #Ultimate.allocInit(20, 34);call #Ultimate.allocInit(44, 35);call #Ultimate.allocInit(44, 36);call #Ultimate.allocInit(9, 37);call #Ultimate.allocInit(9, 38);call #Ultimate.allocInit(11, 39);call #Ultimate.allocInit(19, 40);call #Ultimate.allocInit(4, 41);call write~init~int(37, 41, 0, 1);call write~init~int(100, 41, 1, 1);call write~init~int(10, 41, 2, 1);call write~init~int(0, 41, 3, 1);call #Ultimate.allocInit(4, 42);call write~init~int(37, 42, 0, 1);call write~init~int(100, 42, 1, 1);call write~init~int(10, 42, 2, 1);call write~init~int(0, 42, 3, 1);~__ste_Email_counter~0 := 0;~__ste_email_id0~0 := 0;~__ste_email_id1~0 := 0;~__ste_email_from0~0 := 0;~__ste_email_from1~0 := 0;~__ste_email_to0~0 := 0;~__ste_email_to1~0 := 0;~__ste_email_subject0~0.base, ~__ste_email_subject0~0.offset := 0, 0;~__ste_email_subject1~0.base, ~__ste_email_subject1~0.offset := 0, 0;~__ste_email_body0~0.base, ~__ste_email_body0~0.offset := 0, 0;~__ste_email_body1~0.base, ~__ste_email_body1~0.offset := 0, 0;~__ste_email_isEncrypted0~0 := 0;~__ste_email_isEncrypted1~0 := 0;~__ste_email_encryptionKey0~0 := 0;~__ste_email_encryptionKey1~0 := 0;~__ste_email_isSigned0~0 := 0;~__ste_email_isSigned1~0 := 0;~__ste_email_signKey0~0 := 0;~__ste_email_signKey1~0 := 0;~__ste_email_isSignatureVerified0~0 := 0;~__ste_email_isSignatureVerified1~0 := 0;~__SELECTED_FEATURE_Base~0 := 0;~__SELECTED_FEATURE_Keys~0 := 0;~__SELECTED_FEATURE_Encrypt~0 := 0;~__SELECTED_FEATURE_AutoResponder~0 := 0;~__SELECTED_FEATURE_AddressBook~0 := 0;~__SELECTED_FEATURE_Sign~0 := 0;~__SELECTED_FEATURE_Forward~0 := 0;~__SELECTED_FEATURE_Verify~0 := 0;~__SELECTED_FEATURE_Decrypt~0 := 0;~__GUIDSL_ROOT_PRODUCTION~0 := 0;~__GUIDSL_NON_TERMINAL_main~0 := 0;~in_encrypted~0 := 0;~head~0.base, ~head~0.offset := 0, 0;~queue_empty~0 := 1;~queued_message~0 := 0;~queued_client~0 := 0;~bob~0 := 0;~rjh~0 := 0;~chuck~0 := 0;~__ste_Client_counter~0 := 0;~__ste_client_name0~0.base, ~__ste_client_name0~0.offset := 0, 0;~__ste_client_name1~0.base, ~__ste_client_name1~0.offset := 0, 0;~__ste_client_name2~0.base, ~__ste_client_name2~0.offset := 0, 0;~__ste_client_outbuffer0~0 := 0;~__ste_client_outbuffer1~0 := 0;~__ste_client_outbuffer2~0 := 0;~__ste_client_outbuffer3~0 := 0;~__ste_ClientAddressBook_size0~0 := 0;~__ste_ClientAddressBook_size1~0 := 0;~__ste_ClientAddressBook_size2~0 := 0;~__ste_Client_AddressBook0_Alias0~0 := 0;~__ste_Client_AddressBook0_Alias1~0 := 0;~__ste_Client_AddressBook0_Alias2~0 := 0;~__ste_Client_AddressBook1_Alias0~0 := 0;~__ste_Client_AddressBook1_Alias1~0 := 0;~__ste_Client_AddressBook1_Alias2~0 := 0;~__ste_Client_AddressBook2_Alias0~0 := 0;~__ste_Client_AddressBook2_Alias1~0 := 0;~__ste_Client_AddressBook2_Alias2~0 := 0;~__ste_Client_AddressBook0_Address0~0 := 0;~__ste_Client_AddressBook0_Address1~0 := 0;~__ste_Client_AddressBook0_Address2~0 := 0;~__ste_Client_AddressBook1_Address0~0 := 0;~__ste_Client_AddressBook1_Address1~0 := 0;~__ste_Client_AddressBook1_Address2~0 := 0;~__ste_Client_AddressBook2_Address0~0 := 0;~__ste_Client_AddressBook2_Address1~0 := 0;~__ste_Client_AddressBook2_Address2~0 := 0;~__ste_client_autoResponse0~0 := 0;~__ste_client_autoResponse1~0 := 0;~__ste_client_autoResponse2~0 := 0;~__ste_client_privateKey0~0 := 0;~__ste_client_privateKey1~0 := 0;~__ste_client_privateKey2~0 := 0;~__ste_ClientKeyring_size0~0 := 0;~__ste_ClientKeyring_size1~0 := 0;~__ste_ClientKeyring_size2~0 := 0;~__ste_Client_Keyring0_User0~0 := 0;~__ste_Client_Keyring0_User1~0 := 0;~__ste_Client_Keyring0_User2~0 := 0;~__ste_Client_Keyring1_User0~0 := 0;~__ste_Client_Keyring1_User1~0 := 0;~__ste_Client_Keyring1_User2~0 := 0;~__ste_Client_Keyring2_User0~0 := 0;~__ste_Client_Keyring2_User1~0 := 0;~__ste_Client_Keyring2_User2~0 := 0;~__ste_Client_Keyring0_PublicKey0~0 := 0;~__ste_Client_Keyring0_PublicKey1~0 := 0;~__ste_Client_Keyring0_PublicKey2~0 := 0;~__ste_Client_Keyring1_PublicKey0~0 := 0;~__ste_Client_Keyring1_PublicKey1~0 := 0;~__ste_Client_Keyring1_PublicKey2~0 := 0;~__ste_Client_Keyring2_PublicKey0~0 := 0;~__ste_Client_Keyring2_PublicKey1~0 := 0;~__ste_Client_Keyring2_PublicKey2~0 := 0;~__ste_client_forwardReceiver0~0 := 0;~__ste_client_forwardReceiver1~0 := 0;~__ste_client_forwardReceiver2~0 := 0;~__ste_client_forwardReceiver3~0 := 0;~__ste_client_idCounter0~0 := 0;~__ste_client_idCounter1~0 := 0;~__ste_client_idCounter2~0 := 0; {25267#true} is VALID [2022-02-20 18:04:20,252 INFO L290 TraceCheckUtils]: 1: Hoare triple {25267#true} assume { :end_inline_ULTIMATE.init } true;assume { :begin_inline_main } true;havoc main_#res#1;havoc main_#t~nondet100#1, main_#t~ret101#1, main_~retValue_acc~26#1, main_~tmp~20#1;assume -2147483648 <= main_#t~nondet100#1 && main_#t~nondet100#1 <= 2147483647;main_~retValue_acc~26#1 := main_#t~nondet100#1;havoc main_#t~nondet100#1;havoc main_~tmp~20#1;assume { :begin_inline_select_helpers } true; {25267#true} is VALID [2022-02-20 18:04:20,252 INFO L290 TraceCheckUtils]: 2: Hoare triple {25267#true} assume { :end_inline_select_helpers } true;assume { :begin_inline_select_features } true; {25267#true} is VALID [2022-02-20 18:04:20,252 INFO L290 TraceCheckUtils]: 3: Hoare triple {25267#true} assume { :end_inline_select_features } true;assume { :begin_inline_valid_product } true;havoc valid_product_#res#1;havoc valid_product_~retValue_acc~12#1;havoc valid_product_~retValue_acc~12#1;valid_product_~retValue_acc~12#1 := 1;valid_product_#res#1 := valid_product_~retValue_acc~12#1; {25267#true} is VALID [2022-02-20 18:04:20,252 INFO L290 TraceCheckUtils]: 4: Hoare triple {25267#true} main_#t~ret101#1 := valid_product_#res#1;assume { :end_inline_valid_product } true;assume -2147483648 <= main_#t~ret101#1 && main_#t~ret101#1 <= 2147483647;main_~tmp~20#1 := main_#t~ret101#1;havoc main_#t~ret101#1; {25267#true} is VALID [2022-02-20 18:04:20,252 INFO L290 TraceCheckUtils]: 5: Hoare triple {25267#true} assume 0 != main_~tmp~20#1;assume { :begin_inline_setup } true;havoc setup_#t~nondet97#1, setup_#t~nondet98#1, setup_#t~nondet99#1, setup_~__cil_tmp1~0#1.base, setup_~__cil_tmp1~0#1.offset, setup_~__cil_tmp2~1#1.base, setup_~__cil_tmp2~1#1.offset, setup_~__cil_tmp3~4#1.base, setup_~__cil_tmp3~4#1.offset;havoc setup_~__cil_tmp1~0#1.base, setup_~__cil_tmp1~0#1.offset;havoc setup_~__cil_tmp2~1#1.base, setup_~__cil_tmp2~1#1.offset;havoc setup_~__cil_tmp3~4#1.base, setup_~__cil_tmp3~4#1.offset;~bob~0 := 1;assume { :begin_inline_setup_bob } true;setup_bob_#in~bob___0#1 := ~bob~0;havoc setup_bob_~bob___0#1;setup_bob_~bob___0#1 := setup_bob_#in~bob___0#1;assume { :begin_inline_setup_bob__wrappee__Base } true;setup_bob__wrappee__Base_#in~bob___0#1 := setup_bob_~bob___0#1;havoc setup_bob__wrappee__Base_~bob___0#1;setup_bob__wrappee__Base_~bob___0#1 := setup_bob__wrappee__Base_#in~bob___0#1; {25267#true} is VALID [2022-02-20 18:04:20,253 INFO L272 TraceCheckUtils]: 6: Hoare triple {25267#true} call setClientId(setup_bob__wrappee__Base_~bob___0#1, setup_bob__wrappee__Base_~bob___0#1); {25333#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} is VALID [2022-02-20 18:04:20,253 INFO L290 TraceCheckUtils]: 7: Hoare triple {25333#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {25267#true} is VALID [2022-02-20 18:04:20,253 INFO L290 TraceCheckUtils]: 8: Hoare triple {25267#true} assume 1 == ~handle;~__ste_client_idCounter0~0 := ~value; {25267#true} is VALID [2022-02-20 18:04:20,253 INFO L290 TraceCheckUtils]: 9: Hoare triple {25267#true} assume true; {25267#true} is VALID [2022-02-20 18:04:20,254 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {25267#true} {25267#true} #1224#return; {25267#true} is VALID [2022-02-20 18:04:20,254 INFO L290 TraceCheckUtils]: 11: Hoare triple {25267#true} assume { :end_inline_setup_bob__wrappee__Base } true; {25267#true} is VALID [2022-02-20 18:04:20,254 INFO L272 TraceCheckUtils]: 12: Hoare triple {25267#true} call setClientPrivateKey(setup_bob_~bob___0#1, 123); {25334#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} is VALID [2022-02-20 18:04:20,254 INFO L290 TraceCheckUtils]: 13: Hoare triple {25334#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {25267#true} is VALID [2022-02-20 18:04:20,255 INFO L290 TraceCheckUtils]: 14: Hoare triple {25267#true} assume 1 == ~handle;~__ste_client_privateKey0~0 := ~value; {25267#true} is VALID [2022-02-20 18:04:20,255 INFO L290 TraceCheckUtils]: 15: Hoare triple {25267#true} assume true; {25267#true} is VALID [2022-02-20 18:04:20,255 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {25267#true} {25267#true} #1226#return; {25267#true} is VALID [2022-02-20 18:04:20,255 INFO L290 TraceCheckUtils]: 17: Hoare triple {25267#true} assume { :end_inline_setup_bob } true;setup_~__cil_tmp1~0#1.base, setup_~__cil_tmp1~0#1.offset := 37, 0;havoc setup_#t~nondet97#1;~rjh~0 := 2;assume { :begin_inline_setup_rjh } true;setup_rjh_#in~rjh___0#1 := ~rjh~0;havoc setup_rjh_~rjh___0#1;setup_rjh_~rjh___0#1 := setup_rjh_#in~rjh___0#1;assume { :begin_inline_setup_rjh__wrappee__Base } true;setup_rjh__wrappee__Base_#in~rjh___0#1 := setup_rjh_~rjh___0#1;havoc setup_rjh__wrappee__Base_~rjh___0#1;setup_rjh__wrappee__Base_~rjh___0#1 := setup_rjh__wrappee__Base_#in~rjh___0#1; {25267#true} is VALID [2022-02-20 18:04:20,256 INFO L272 TraceCheckUtils]: 18: Hoare triple {25267#true} call setClientId(setup_rjh__wrappee__Base_~rjh___0#1, setup_rjh__wrappee__Base_~rjh___0#1); {25333#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} is VALID [2022-02-20 18:04:20,256 INFO L290 TraceCheckUtils]: 19: Hoare triple {25333#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {25267#true} is VALID [2022-02-20 18:04:20,256 INFO L290 TraceCheckUtils]: 20: Hoare triple {25267#true} assume !(1 == ~handle); {25267#true} is VALID [2022-02-20 18:04:20,256 INFO L290 TraceCheckUtils]: 21: Hoare triple {25267#true} assume 2 == ~handle;~__ste_client_idCounter1~0 := ~value; {25267#true} is VALID [2022-02-20 18:04:20,256 INFO L290 TraceCheckUtils]: 22: Hoare triple {25267#true} assume true; {25267#true} is VALID [2022-02-20 18:04:20,256 INFO L284 TraceCheckUtils]: 23: Hoare quadruple {25267#true} {25267#true} #1228#return; {25267#true} is VALID [2022-02-20 18:04:20,256 INFO L290 TraceCheckUtils]: 24: Hoare triple {25267#true} assume { :end_inline_setup_rjh__wrappee__Base } true; {25267#true} is VALID [2022-02-20 18:04:20,257 INFO L272 TraceCheckUtils]: 25: Hoare triple {25267#true} call setClientPrivateKey(setup_rjh_~rjh___0#1, 456); {25334#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} is VALID [2022-02-20 18:04:20,257 INFO L290 TraceCheckUtils]: 26: Hoare triple {25334#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {25267#true} is VALID [2022-02-20 18:04:20,257 INFO L290 TraceCheckUtils]: 27: Hoare triple {25267#true} assume !(1 == ~handle); {25267#true} is VALID [2022-02-20 18:04:20,257 INFO L290 TraceCheckUtils]: 28: Hoare triple {25267#true} assume 2 == ~handle;~__ste_client_privateKey1~0 := ~value; {25267#true} is VALID [2022-02-20 18:04:20,257 INFO L290 TraceCheckUtils]: 29: Hoare triple {25267#true} assume true; {25267#true} is VALID [2022-02-20 18:04:20,258 INFO L284 TraceCheckUtils]: 30: Hoare quadruple {25267#true} {25267#true} #1230#return; {25267#true} is VALID [2022-02-20 18:04:20,258 INFO L290 TraceCheckUtils]: 31: Hoare triple {25267#true} assume { :end_inline_setup_rjh } true;setup_~__cil_tmp2~1#1.base, setup_~__cil_tmp2~1#1.offset := 38, 0;havoc setup_#t~nondet98#1;~chuck~0 := 3;assume { :begin_inline_setup_chuck } true;setup_chuck_#in~chuck___0#1 := ~chuck~0;havoc setup_chuck_~chuck___0#1;setup_chuck_~chuck___0#1 := setup_chuck_#in~chuck___0#1;assume { :begin_inline_setup_chuck__wrappee__Base } true;setup_chuck__wrappee__Base_#in~chuck___0#1 := setup_chuck_~chuck___0#1;havoc setup_chuck__wrappee__Base_~chuck___0#1;setup_chuck__wrappee__Base_~chuck___0#1 := setup_chuck__wrappee__Base_#in~chuck___0#1; {25287#(= |ULTIMATE.start_setup_chuck_~chuck___0#1| |ULTIMATE.start_setup_chuck__wrappee__Base_~chuck___0#1|)} is VALID [2022-02-20 18:04:20,259 INFO L272 TraceCheckUtils]: 32: Hoare triple {25287#(= |ULTIMATE.start_setup_chuck_~chuck___0#1| |ULTIMATE.start_setup_chuck__wrappee__Base_~chuck___0#1|)} call setClientId(setup_chuck__wrappee__Base_~chuck___0#1, setup_chuck__wrappee__Base_~chuck___0#1); {25333#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} is VALID [2022-02-20 18:04:20,259 INFO L290 TraceCheckUtils]: 33: Hoare triple {25333#(and (= |old(~__ste_client_idCounter0~0)| ~__ste_client_idCounter0~0) (= |old(~__ste_client_idCounter1~0)| ~__ste_client_idCounter1~0) (= |old(~__ste_client_idCounter2~0)| ~__ste_client_idCounter2~0))} ~handle := #in~handle;~value := #in~value; {25335#(= setClientId_~handle |setClientId_#in~handle|)} is VALID [2022-02-20 18:04:20,259 INFO L290 TraceCheckUtils]: 34: Hoare triple {25335#(= setClientId_~handle |setClientId_#in~handle|)} assume !(1 == ~handle); {25335#(= setClientId_~handle |setClientId_#in~handle|)} is VALID [2022-02-20 18:04:20,260 INFO L290 TraceCheckUtils]: 35: Hoare triple {25335#(= setClientId_~handle |setClientId_#in~handle|)} assume !(2 == ~handle); {25335#(= setClientId_~handle |setClientId_#in~handle|)} is VALID [2022-02-20 18:04:20,260 INFO L290 TraceCheckUtils]: 36: Hoare triple {25335#(= setClientId_~handle |setClientId_#in~handle|)} assume 3 == ~handle;~__ste_client_idCounter2~0 := ~value; {25336#(= 3 |setClientId_#in~handle|)} is VALID [2022-02-20 18:04:20,260 INFO L290 TraceCheckUtils]: 37: Hoare triple {25336#(= 3 |setClientId_#in~handle|)} assume true; {25336#(= 3 |setClientId_#in~handle|)} is VALID [2022-02-20 18:04:20,261 INFO L284 TraceCheckUtils]: 38: Hoare quadruple {25336#(= 3 |setClientId_#in~handle|)} {25287#(= |ULTIMATE.start_setup_chuck_~chuck___0#1| |ULTIMATE.start_setup_chuck__wrappee__Base_~chuck___0#1|)} #1232#return; {25294#(not (= |ULTIMATE.start_setup_chuck_~chuck___0#1| 2))} is VALID [2022-02-20 18:04:20,261 INFO L290 TraceCheckUtils]: 39: Hoare triple {25294#(not (= |ULTIMATE.start_setup_chuck_~chuck___0#1| 2))} assume { :end_inline_setup_chuck__wrappee__Base } true; {25294#(not (= |ULTIMATE.start_setup_chuck_~chuck___0#1| 2))} is VALID [2022-02-20 18:04:20,262 INFO L272 TraceCheckUtils]: 40: Hoare triple {25294#(not (= |ULTIMATE.start_setup_chuck_~chuck___0#1| 2))} call setClientPrivateKey(setup_chuck_~chuck___0#1, 789); {25334#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} is VALID [2022-02-20 18:04:20,262 INFO L290 TraceCheckUtils]: 41: Hoare triple {25334#(and (= ~__ste_client_privateKey0~0 |old(~__ste_client_privateKey0~0)|) (= ~__ste_client_privateKey2~0 |old(~__ste_client_privateKey2~0)|) (= ~__ste_client_privateKey1~0 |old(~__ste_client_privateKey1~0)|))} ~handle := #in~handle;~value := #in~value; {25337#(= setClientPrivateKey_~handle |setClientPrivateKey_#in~handle|)} is VALID [2022-02-20 18:04:20,262 INFO L290 TraceCheckUtils]: 42: Hoare triple {25337#(= setClientPrivateKey_~handle |setClientPrivateKey_#in~handle|)} assume !(1 == ~handle); {25337#(= setClientPrivateKey_~handle |setClientPrivateKey_#in~handle|)} is VALID [2022-02-20 18:04:20,263 INFO L290 TraceCheckUtils]: 43: Hoare triple {25337#(= setClientPrivateKey_~handle |setClientPrivateKey_#in~handle|)} assume 2 == ~handle;~__ste_client_privateKey1~0 := ~value; {25338#(= 2 |setClientPrivateKey_#in~handle|)} is VALID [2022-02-20 18:04:20,263 INFO L290 TraceCheckUtils]: 44: Hoare triple {25338#(= 2 |setClientPrivateKey_#in~handle|)} assume true; {25338#(= 2 |setClientPrivateKey_#in~handle|)} is VALID [2022-02-20 18:04:20,263 INFO L284 TraceCheckUtils]: 45: Hoare quadruple {25338#(= 2 |setClientPrivateKey_#in~handle|)} {25294#(not (= |ULTIMATE.start_setup_chuck_~chuck___0#1| 2))} #1234#return; {25268#false} is VALID [2022-02-20 18:04:20,264 INFO L290 TraceCheckUtils]: 46: Hoare triple {25268#false} assume { :end_inline_setup_chuck } true;setup_~__cil_tmp3~4#1.base, setup_~__cil_tmp3~4#1.offset := 39, 0;havoc setup_#t~nondet99#1; {25268#false} is VALID [2022-02-20 18:04:20,264 INFO L290 TraceCheckUtils]: 47: Hoare triple {25268#false} assume { :end_inline_setup } true;assume { :begin_inline_test } true;havoc test_#t~nondet55#1, test_#t~nondet56#1, test_#t~nondet57#1, test_#t~nondet58#1, test_#t~nondet59#1, test_#t~nondet60#1, test_#t~nondet61#1, test_#t~nondet62#1, test_#t~nondet63#1, test_#t~nondet64#1, test_#t~nondet65#1, test_~op1~0#1, test_~op2~0#1, test_~op3~0#1, test_~op4~0#1, test_~op5~0#1, test_~op6~0#1, test_~op7~0#1, test_~op8~0#1, test_~op9~0#1, test_~op10~0#1, test_~op11~0#1, test_~splverifierCounter~0#1, test_~tmp~9#1, test_~tmp___0~3#1, test_~tmp___1~1#1, test_~tmp___2~1#1, test_~tmp___3~0#1, test_~tmp___4~0#1, test_~tmp___5~0#1, test_~tmp___6~0#1, test_~tmp___7~0#1, test_~tmp___8~0#1, test_~tmp___9~0#1;havoc test_~op1~0#1;havoc test_~op2~0#1;havoc test_~op3~0#1;havoc test_~op4~0#1;havoc test_~op5~0#1;havoc test_~op6~0#1;havoc test_~op7~0#1;havoc test_~op8~0#1;havoc test_~op9~0#1;havoc test_~op10~0#1;havoc test_~op11~0#1;havoc test_~splverifierCounter~0#1;havoc test_~tmp~9#1;havoc test_~tmp___0~3#1;havoc test_~tmp___1~1#1;havoc test_~tmp___2~1#1;havoc test_~tmp___3~0#1;havoc test_~tmp___4~0#1;havoc test_~tmp___5~0#1;havoc test_~tmp___6~0#1;havoc test_~tmp___7~0#1;havoc test_~tmp___8~0#1;havoc test_~tmp___9~0#1;test_~op1~0#1 := 0;test_~op2~0#1 := 0;test_~op3~0#1 := 0;test_~op4~0#1 := 0;test_~op5~0#1 := 0;test_~op6~0#1 := 0;test_~op7~0#1 := 0;test_~op8~0#1 := 0;test_~op9~0#1 := 0;test_~op10~0#1 := 0;test_~op11~0#1 := 0;test_~splverifierCounter~0#1 := 0; {25268#false} is VALID [2022-02-20 18:04:20,264 INFO L290 TraceCheckUtils]: 48: Hoare triple {25268#false} assume !false; {25268#false} is VALID [2022-02-20 18:04:20,264 INFO L290 TraceCheckUtils]: 49: Hoare triple {25268#false} assume test_~splverifierCounter~0#1 < 4; {25268#false} is VALID [2022-02-20 18:04:20,264 INFO L290 TraceCheckUtils]: 50: Hoare triple {25268#false} test_~splverifierCounter~0#1 := 1 + test_~splverifierCounter~0#1; {25268#false} is VALID [2022-02-20 18:04:20,264 INFO L290 TraceCheckUtils]: 51: Hoare triple {25268#false} assume 0 == test_~op1~0#1;assume -2147483648 <= test_#t~nondet55#1 && test_#t~nondet55#1 <= 2147483647;test_~tmp___9~0#1 := test_#t~nondet55#1;havoc test_#t~nondet55#1; {25268#false} is VALID [2022-02-20 18:04:20,264 INFO L290 TraceCheckUtils]: 52: Hoare triple {25268#false} assume !(0 != test_~tmp___9~0#1); {25268#false} is VALID [2022-02-20 18:04:20,265 INFO L290 TraceCheckUtils]: 53: Hoare triple {25268#false} assume 0 == test_~op2~0#1;assume -2147483648 <= test_#t~nondet56#1 && test_#t~nondet56#1 <= 2147483647;test_~tmp___8~0#1 := test_#t~nondet56#1;havoc test_#t~nondet56#1; {25268#false} is VALID [2022-02-20 18:04:20,265 INFO L290 TraceCheckUtils]: 54: Hoare triple {25268#false} assume 0 != test_~tmp___8~0#1;test_~op2~0#1 := 1; {25268#false} is VALID [2022-02-20 18:04:20,265 INFO L290 TraceCheckUtils]: 55: Hoare triple {25268#false} assume !false; {25268#false} is VALID [2022-02-20 18:04:20,265 INFO L290 TraceCheckUtils]: 56: Hoare triple {25268#false} assume !(test_~splverifierCounter~0#1 < 4); {25268#false} is VALID [2022-02-20 18:04:20,265 INFO L290 TraceCheckUtils]: 57: Hoare triple {25268#false} assume { :begin_inline_bobToRjh } true;havoc bobToRjh_#t~ret92#1, bobToRjh_#t~ret93#1, bobToRjh_#t~ret94#1, bobToRjh_#t~ret95#1, bobToRjh_~tmp~19#1, bobToRjh_~tmp___0~8#1, bobToRjh_~tmp___1~5#1;havoc bobToRjh_~tmp~19#1;havoc bobToRjh_~tmp___0~8#1;havoc bobToRjh_~tmp___1~5#1;call bobToRjh_#t~ret92#1 := puts(35, 0);assume -2147483648 <= bobToRjh_#t~ret92#1 && bobToRjh_#t~ret92#1 <= 2147483647;havoc bobToRjh_#t~ret92#1; {25268#false} is VALID [2022-02-20 18:04:20,265 INFO L272 TraceCheckUtils]: 58: Hoare triple {25268#false} call sendEmail(~bob~0, ~rjh~0); {25268#false} is VALID [2022-02-20 18:04:20,265 INFO L290 TraceCheckUtils]: 59: Hoare triple {25268#false} ~sender#1 := #in~sender#1;~receiver#1 := #in~receiver#1;havoc ~email~0#1;havoc ~tmp~16#1;assume { :begin_inline_createEmail } true;createEmail_#in~from#1, createEmail_#in~to#1 := 0, ~receiver#1;havoc createEmail_#res#1;havoc createEmail_~from#1, createEmail_~to#1, createEmail_~retValue_acc~16#1, createEmail_~msg~0#1;createEmail_~from#1 := createEmail_#in~from#1;createEmail_~to#1 := createEmail_#in~to#1;havoc createEmail_~retValue_acc~16#1;havoc createEmail_~msg~0#1;createEmail_~msg~0#1 := 1; {25268#false} is VALID [2022-02-20 18:04:20,266 INFO L272 TraceCheckUtils]: 60: Hoare triple {25268#false} call setEmailFrom(createEmail_~msg~0#1, createEmail_~from#1); {25339#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} is VALID [2022-02-20 18:04:20,266 INFO L290 TraceCheckUtils]: 61: Hoare triple {25339#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} ~handle := #in~handle;~value := #in~value; {25267#true} is VALID [2022-02-20 18:04:20,266 INFO L290 TraceCheckUtils]: 62: Hoare triple {25267#true} assume 1 == ~handle;~__ste_email_from0~0 := ~value; {25267#true} is VALID [2022-02-20 18:04:20,266 INFO L290 TraceCheckUtils]: 63: Hoare triple {25267#true} assume true; {25267#true} is VALID [2022-02-20 18:04:20,266 INFO L284 TraceCheckUtils]: 64: Hoare quadruple {25267#true} {25268#false} #1210#return; {25268#false} is VALID [2022-02-20 18:04:20,266 INFO L272 TraceCheckUtils]: 65: Hoare triple {25268#false} call setEmailTo(createEmail_~msg~0#1, createEmail_~to#1); {25340#(and (= ~__ste_email_to0~0 |old(~__ste_email_to0~0)|) (= ~__ste_email_to1~0 |old(~__ste_email_to1~0)|))} is VALID [2022-02-20 18:04:20,266 INFO L290 TraceCheckUtils]: 66: Hoare triple {25340#(and (= ~__ste_email_to0~0 |old(~__ste_email_to0~0)|) (= ~__ste_email_to1~0 |old(~__ste_email_to1~0)|))} ~handle := #in~handle;~value := #in~value; {25267#true} is VALID [2022-02-20 18:04:20,267 INFO L290 TraceCheckUtils]: 67: Hoare triple {25267#true} assume 1 == ~handle;~__ste_email_to0~0 := ~value; {25267#true} is VALID [2022-02-20 18:04:20,267 INFO L290 TraceCheckUtils]: 68: Hoare triple {25267#true} assume true; {25267#true} is VALID [2022-02-20 18:04:20,267 INFO L284 TraceCheckUtils]: 69: Hoare quadruple {25267#true} {25268#false} #1212#return; {25268#false} is VALID [2022-02-20 18:04:20,267 INFO L290 TraceCheckUtils]: 70: Hoare triple {25268#false} createEmail_~retValue_acc~16#1 := createEmail_~msg~0#1;createEmail_#res#1 := createEmail_~retValue_acc~16#1; {25268#false} is VALID [2022-02-20 18:04:20,267 INFO L290 TraceCheckUtils]: 71: Hoare triple {25268#false} #t~ret83#1 := createEmail_#res#1;assume { :end_inline_createEmail } true;assume -2147483648 <= #t~ret83#1 && #t~ret83#1 <= 2147483647;~tmp~16#1 := #t~ret83#1;havoc #t~ret83#1;~email~0#1 := ~tmp~16#1; {25268#false} is VALID [2022-02-20 18:04:20,267 INFO L272 TraceCheckUtils]: 72: Hoare triple {25268#false} call outgoing(~sender#1, ~email~0#1); {25268#false} is VALID [2022-02-20 18:04:20,267 INFO L290 TraceCheckUtils]: 73: Hoare triple {25268#false} ~client#1 := #in~client#1;~msg#1 := #in~msg#1;assume { :begin_inline_sign } true;sign_#in~client#1, sign_#in~msg#1 := ~client#1, ~msg#1;havoc sign_#t~ret85#1, sign_~client#1, sign_~msg#1, sign_~privkey~1#1, sign_~tmp~17#1;sign_~client#1 := sign_#in~client#1;sign_~msg#1 := sign_#in~msg#1;havoc sign_~privkey~1#1;havoc sign_~tmp~17#1; {25268#false} is VALID [2022-02-20 18:04:20,267 INFO L272 TraceCheckUtils]: 74: Hoare triple {25268#false} call sign_#t~ret85#1 := getClientPrivateKey(sign_~client#1); {25267#true} is VALID [2022-02-20 18:04:20,268 INFO L290 TraceCheckUtils]: 75: Hoare triple {25267#true} ~handle := #in~handle;havoc ~retValue_acc~36; {25267#true} is VALID [2022-02-20 18:04:20,268 INFO L290 TraceCheckUtils]: 76: Hoare triple {25267#true} assume 1 == ~handle;~retValue_acc~36 := ~__ste_client_privateKey0~0;#res := ~retValue_acc~36; {25267#true} is VALID [2022-02-20 18:04:20,268 INFO L290 TraceCheckUtils]: 77: Hoare triple {25267#true} assume true; {25267#true} is VALID [2022-02-20 18:04:20,268 INFO L284 TraceCheckUtils]: 78: Hoare quadruple {25267#true} {25268#false} #1150#return; {25268#false} is VALID [2022-02-20 18:04:20,268 INFO L290 TraceCheckUtils]: 79: Hoare triple {25268#false} assume -2147483648 <= sign_#t~ret85#1 && sign_#t~ret85#1 <= 2147483647;sign_~tmp~17#1 := sign_#t~ret85#1;havoc sign_#t~ret85#1;sign_~privkey~1#1 := sign_~tmp~17#1; {25268#false} is VALID [2022-02-20 18:04:20,268 INFO L290 TraceCheckUtils]: 80: Hoare triple {25268#false} assume 0 == sign_~privkey~1#1; {25268#false} is VALID [2022-02-20 18:04:20,268 INFO L290 TraceCheckUtils]: 81: Hoare triple {25268#false} assume { :end_inline_sign } true;assume { :begin_inline_outgoing__wrappee__AddressBook } true;outgoing__wrappee__AddressBook_#in~client#1, outgoing__wrappee__AddressBook_#in~msg#1 := ~client#1, ~msg#1;havoc outgoing__wrappee__AddressBook_#t~ret71#1, outgoing__wrappee__AddressBook_#t~ret72#1, outgoing__wrappee__AddressBook_#t~ret73#1, outgoing__wrappee__AddressBook_#t~ret74#1, outgoing__wrappee__AddressBook_#t~ret75#1, outgoing__wrappee__AddressBook_#t~ret76#1, outgoing__wrappee__AddressBook_~client#1, outgoing__wrappee__AddressBook_~msg#1, outgoing__wrappee__AddressBook_~size~0#1, outgoing__wrappee__AddressBook_~tmp~13#1, outgoing__wrappee__AddressBook_~receiver~1#1, outgoing__wrappee__AddressBook_~tmp___0~5#1, outgoing__wrappee__AddressBook_~second~0#1, outgoing__wrappee__AddressBook_~tmp___1~2#1, outgoing__wrappee__AddressBook_~tmp___2~2#1;outgoing__wrappee__AddressBook_~client#1 := outgoing__wrappee__AddressBook_#in~client#1;outgoing__wrappee__AddressBook_~msg#1 := outgoing__wrappee__AddressBook_#in~msg#1;havoc outgoing__wrappee__AddressBook_~size~0#1;havoc outgoing__wrappee__AddressBook_~tmp~13#1;havoc outgoing__wrappee__AddressBook_~receiver~1#1;havoc outgoing__wrappee__AddressBook_~tmp___0~5#1;havoc outgoing__wrappee__AddressBook_~second~0#1;havoc outgoing__wrappee__AddressBook_~tmp___1~2#1;havoc outgoing__wrappee__AddressBook_~tmp___2~2#1; {25268#false} is VALID [2022-02-20 18:04:20,269 INFO L272 TraceCheckUtils]: 82: Hoare triple {25268#false} call outgoing__wrappee__AddressBook_#t~ret71#1 := getClientAddressBookSize(outgoing__wrappee__AddressBook_~client#1); {25267#true} is VALID [2022-02-20 18:04:20,269 INFO L290 TraceCheckUtils]: 83: Hoare triple {25267#true} ~handle := #in~handle;havoc ~retValue_acc~30; {25267#true} is VALID [2022-02-20 18:04:20,269 INFO L290 TraceCheckUtils]: 84: Hoare triple {25267#true} assume 1 == ~handle;~retValue_acc~30 := ~__ste_ClientAddressBook_size0~0;#res := ~retValue_acc~30; {25267#true} is VALID [2022-02-20 18:04:20,269 INFO L290 TraceCheckUtils]: 85: Hoare triple {25267#true} assume true; {25267#true} is VALID [2022-02-20 18:04:20,269 INFO L284 TraceCheckUtils]: 86: Hoare quadruple {25267#true} {25268#false} #1152#return; {25268#false} is VALID [2022-02-20 18:04:20,269 INFO L290 TraceCheckUtils]: 87: Hoare triple {25268#false} assume -2147483648 <= outgoing__wrappee__AddressBook_#t~ret71#1 && outgoing__wrappee__AddressBook_#t~ret71#1 <= 2147483647;outgoing__wrappee__AddressBook_~tmp~13#1 := outgoing__wrappee__AddressBook_#t~ret71#1;havoc outgoing__wrappee__AddressBook_#t~ret71#1;outgoing__wrappee__AddressBook_~size~0#1 := outgoing__wrappee__AddressBook_~tmp~13#1; {25268#false} is VALID [2022-02-20 18:04:20,269 INFO L290 TraceCheckUtils]: 88: Hoare triple {25268#false} assume !(0 != outgoing__wrappee__AddressBook_~size~0#1); {25268#false} is VALID [2022-02-20 18:04:20,269 INFO L272 TraceCheckUtils]: 89: Hoare triple {25268#false} call outgoing__wrappee__Encrypt(outgoing__wrappee__AddressBook_~client#1, outgoing__wrappee__AddressBook_~msg#1); {25268#false} is VALID [2022-02-20 18:04:20,270 INFO L290 TraceCheckUtils]: 90: Hoare triple {25268#false} ~client#1 := #in~client#1;~msg#1 := #in~msg#1;havoc ~receiver~0#1;havoc ~tmp~12#1;havoc ~pubkey~0#1;havoc ~tmp___0~4#1; {25268#false} is VALID [2022-02-20 18:04:20,270 INFO L272 TraceCheckUtils]: 91: Hoare triple {25268#false} call #t~ret69#1 := getEmailTo(~msg#1); {25267#true} is VALID [2022-02-20 18:04:20,270 INFO L290 TraceCheckUtils]: 92: Hoare triple {25267#true} ~handle := #in~handle;havoc ~retValue_acc~3; {25267#true} is VALID [2022-02-20 18:04:20,270 INFO L290 TraceCheckUtils]: 93: Hoare triple {25267#true} assume 1 == ~handle;~retValue_acc~3 := ~__ste_email_to0~0;#res := ~retValue_acc~3; {25267#true} is VALID [2022-02-20 18:04:20,270 INFO L290 TraceCheckUtils]: 94: Hoare triple {25267#true} assume true; {25267#true} is VALID [2022-02-20 18:04:20,270 INFO L284 TraceCheckUtils]: 95: Hoare quadruple {25267#true} {25268#false} #1170#return; {25268#false} is VALID [2022-02-20 18:04:20,270 INFO L290 TraceCheckUtils]: 96: Hoare triple {25268#false} assume -2147483648 <= #t~ret69#1 && #t~ret69#1 <= 2147483647;~tmp~12#1 := #t~ret69#1;havoc #t~ret69#1;~receiver~0#1 := ~tmp~12#1; {25268#false} is VALID [2022-02-20 18:04:20,271 INFO L272 TraceCheckUtils]: 97: Hoare triple {25268#false} call #t~ret70#1 := findPublicKey(~client#1, ~receiver~0#1); {25267#true} is VALID [2022-02-20 18:04:20,271 INFO L290 TraceCheckUtils]: 98: Hoare triple {25267#true} ~handle := #in~handle;~userid := #in~userid;havoc ~retValue_acc~41; {25267#true} is VALID [2022-02-20 18:04:20,271 INFO L290 TraceCheckUtils]: 99: Hoare triple {25267#true} assume 1 == ~handle; {25267#true} is VALID [2022-02-20 18:04:20,271 INFO L290 TraceCheckUtils]: 100: Hoare triple {25267#true} assume ~userid == ~__ste_Client_Keyring0_User0~0;~retValue_acc~41 := ~__ste_Client_Keyring0_PublicKey0~0;#res := ~retValue_acc~41; {25267#true} is VALID [2022-02-20 18:04:20,271 INFO L290 TraceCheckUtils]: 101: Hoare triple {25267#true} assume true; {25267#true} is VALID [2022-02-20 18:04:20,271 INFO L284 TraceCheckUtils]: 102: Hoare quadruple {25267#true} {25268#false} #1172#return; {25268#false} is VALID [2022-02-20 18:04:20,271 INFO L290 TraceCheckUtils]: 103: Hoare triple {25268#false} assume -2147483648 <= #t~ret70#1 && #t~ret70#1 <= 2147483647;~tmp___0~4#1 := #t~ret70#1;havoc #t~ret70#1;~pubkey~0#1 := ~tmp___0~4#1; {25268#false} is VALID [2022-02-20 18:04:20,271 INFO L290 TraceCheckUtils]: 104: Hoare triple {25268#false} assume !(0 != ~pubkey~0#1); {25268#false} is VALID [2022-02-20 18:04:20,272 INFO L290 TraceCheckUtils]: 105: Hoare triple {25268#false} assume { :begin_inline_outgoing__wrappee__Keys } true;outgoing__wrappee__Keys_#in~client#1, outgoing__wrappee__Keys_#in~msg#1 := ~client#1, ~msg#1;havoc outgoing__wrappee__Keys_#t~ret68#1, outgoing__wrappee__Keys_~client#1, outgoing__wrappee__Keys_~msg#1, outgoing__wrappee__Keys_~tmp~11#1;outgoing__wrappee__Keys_~client#1 := outgoing__wrappee__Keys_#in~client#1;outgoing__wrappee__Keys_~msg#1 := outgoing__wrappee__Keys_#in~msg#1;havoc outgoing__wrappee__Keys_~tmp~11#1;assume { :begin_inline_getClientId } true;getClientId_#in~handle#1 := outgoing__wrappee__Keys_~client#1;havoc getClientId_#res#1;havoc getClientId_~handle#1, getClientId_~retValue_acc~43#1;getClientId_~handle#1 := getClientId_#in~handle#1;havoc getClientId_~retValue_acc~43#1; {25268#false} is VALID [2022-02-20 18:04:20,272 INFO L290 TraceCheckUtils]: 106: Hoare triple {25268#false} assume 1 == getClientId_~handle#1;getClientId_~retValue_acc~43#1 := ~__ste_client_idCounter0~0;getClientId_#res#1 := getClientId_~retValue_acc~43#1; {25268#false} is VALID [2022-02-20 18:04:20,272 INFO L290 TraceCheckUtils]: 107: Hoare triple {25268#false} outgoing__wrappee__Keys_#t~ret68#1 := getClientId_#res#1;assume { :end_inline_getClientId } true;assume -2147483648 <= outgoing__wrappee__Keys_#t~ret68#1 && outgoing__wrappee__Keys_#t~ret68#1 <= 2147483647;outgoing__wrappee__Keys_~tmp~11#1 := outgoing__wrappee__Keys_#t~ret68#1;havoc outgoing__wrappee__Keys_#t~ret68#1; {25268#false} is VALID [2022-02-20 18:04:20,272 INFO L272 TraceCheckUtils]: 108: Hoare triple {25268#false} call setEmailFrom(outgoing__wrappee__Keys_~msg#1, outgoing__wrappee__Keys_~tmp~11#1); {25339#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} is VALID [2022-02-20 18:04:20,272 INFO L290 TraceCheckUtils]: 109: Hoare triple {25339#(and (= |old(~__ste_email_from0~0)| ~__ste_email_from0~0) (= |old(~__ste_email_from1~0)| ~__ste_email_from1~0))} ~handle := #in~handle;~value := #in~value; {25267#true} is VALID [2022-02-20 18:04:20,272 INFO L290 TraceCheckUtils]: 110: Hoare triple {25267#true} assume 1 == ~handle;~__ste_email_from0~0 := ~value; {25267#true} is VALID [2022-02-20 18:04:20,273 INFO L290 TraceCheckUtils]: 111: Hoare triple {25267#true} assume true; {25267#true} is VALID [2022-02-20 18:04:20,273 INFO L284 TraceCheckUtils]: 112: Hoare quadruple {25267#true} {25268#false} #1178#return; {25268#false} is VALID [2022-02-20 18:04:20,273 INFO L290 TraceCheckUtils]: 113: Hoare triple {25268#false} assume { :begin_inline_mail } true;mail_#in~client#1, mail_#in~msg#1 := outgoing__wrappee__Keys_~client#1, outgoing__wrappee__Keys_~msg#1;havoc mail_#t~ret66#1, mail_#t~ret67#1, mail_~client#1, mail_~msg#1, mail_~__utac__ad__arg1~0#1, mail_~tmp~10#1;mail_~client#1 := mail_#in~client#1;mail_~msg#1 := mail_#in~msg#1;havoc mail_~__utac__ad__arg1~0#1;havoc mail_~tmp~10#1;mail_~__utac__ad__arg1~0#1 := mail_~msg#1;assume { :begin_inline___utac_acc__EncryptAutoResponder_spec__2 } true;__utac_acc__EncryptAutoResponder_spec__2_#in~msg#1 := mail_~__utac__ad__arg1~0#1;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1, __utac_acc__EncryptAutoResponder_spec__2_#t~nondet29#1, __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1, __utac_acc__EncryptAutoResponder_spec__2_~msg#1, __utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.base, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.offset;__utac_acc__EncryptAutoResponder_spec__2_~msg#1 := __utac_acc__EncryptAutoResponder_spec__2_#in~msg#1;havoc __utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1;havoc __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.base, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.offset;call __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1 := puts(15, 0);assume -2147483648 <= __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1 && __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1 <= 2147483647;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~ret28#1;__utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.base, __utac_acc__EncryptAutoResponder_spec__2_~__cil_tmp3~3#1.offset := 16, 0;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~nondet29#1; {25268#false} is VALID [2022-02-20 18:04:20,273 INFO L290 TraceCheckUtils]: 114: Hoare triple {25268#false} assume 0 != ~in_encrypted~0; {25268#false} is VALID [2022-02-20 18:04:20,273 INFO L272 TraceCheckUtils]: 115: Hoare triple {25268#false} call __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1 := isEncrypted(__utac_acc__EncryptAutoResponder_spec__2_~msg#1); {25267#true} is VALID [2022-02-20 18:04:20,273 INFO L290 TraceCheckUtils]: 116: Hoare triple {25267#true} ~handle := #in~handle;havoc ~retValue_acc~6; {25267#true} is VALID [2022-02-20 18:04:20,273 INFO L290 TraceCheckUtils]: 117: Hoare triple {25267#true} assume 1 == ~handle;~retValue_acc~6 := ~__ste_email_isEncrypted0~0;#res := ~retValue_acc~6; {25267#true} is VALID [2022-02-20 18:04:20,273 INFO L290 TraceCheckUtils]: 118: Hoare triple {25267#true} assume true; {25267#true} is VALID [2022-02-20 18:04:20,274 INFO L284 TraceCheckUtils]: 119: Hoare quadruple {25267#true} {25268#false} #1180#return; {25268#false} is VALID [2022-02-20 18:04:20,274 INFO L290 TraceCheckUtils]: 120: Hoare triple {25268#false} assume -2147483648 <= __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1 && __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1 <= 2147483647;__utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1 := __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1;havoc __utac_acc__EncryptAutoResponder_spec__2_#t~ret30#1; {25268#false} is VALID [2022-02-20 18:04:20,274 INFO L290 TraceCheckUtils]: 121: Hoare triple {25268#false} assume !(0 != __utac_acc__EncryptAutoResponder_spec__2_~tmp~5#1);assume { :begin_inline___automaton_fail } true; {25268#false} is VALID [2022-02-20 18:04:20,274 INFO L290 TraceCheckUtils]: 122: Hoare triple {25268#false} assume !false; {25268#false} is VALID [2022-02-20 18:04:20,274 INFO L134 CoverageAnalysis]: Checked inductivity of 32 backedges. 14 proven. 0 refuted. 0 times theorem prover too weak. 18 trivial. 0 not checked. [2022-02-20 18:04:20,275 INFO L144 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-02-20 18:04:20,275 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [180604461] [2022-02-20 18:04:20,275 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleSmtInterpolCraig [180604461] provided 1 perfect and 0 imperfect interpolant sequences [2022-02-20 18:04:20,275 INFO L191 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-02-20 18:04:20,275 INFO L204 FreeRefinementEngine]: Number of different interpolants: perfect sequences [12] imperfect sequences [] total 12 [2022-02-20 18:04:20,275 INFO L118 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [1933716526] [2022-02-20 18:04:20,275 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-02-20 18:04:20,276 INFO L78 Accepts]: Start accepts. Automaton has has 12 states, 11 states have (on average 7.636363636363637) internal successors, (84), 8 states have internal predecessors, (84), 4 states have call successors, (17), 6 states have call predecessors, (17), 3 states have return successors, (14), 3 states have call predecessors, (14), 4 states have call successors, (14) Word has length 123 [2022-02-20 18:04:20,276 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-02-20 18:04:20,277 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with has 12 states, 11 states have (on average 7.636363636363637) internal successors, (84), 8 states have internal predecessors, (84), 4 states have call successors, (17), 6 states have call predecessors, (17), 3 states have return successors, (14), 3 states have call predecessors, (14), 4 states have call successors, (14) [2022-02-20 18:04:20,348 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 18:04:20,348 INFO L546 AbstractCegarLoop]: INTERPOLANT automaton has 12 states [2022-02-20 18:04:20,348 INFO L108 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2022-02-20 18:04:20,348 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 12 interpolants. [2022-02-20 18:04:20,349 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=21, Invalid=111, Unknown=0, NotChecked=0, Total=132 [2022-02-20 18:04:20,349 INFO L87 Difference]: Start difference. First operand 472 states and 726 transitions. Second operand has 12 states, 11 states have (on average 7.636363636363637) internal successors, (84), 8 states have internal predecessors, (84), 4 states have call successors, (17), 6 states have call predecessors, (17), 3 states have return successors, (14), 3 states have call predecessors, (14), 4 states have call successors, (14)