PandA-2024.02
complete_call_graph.cpp
Go to the documentation of this file.
1 /*
2  *
3  * _/_/_/ _/_/ _/ _/ _/_/_/ _/_/
4  * _/ _/ _/ _/ _/_/ _/ _/ _/ _/ _/
5  * _/_/_/ _/_/_/_/ _/ _/_/ _/ _/ _/_/_/_/
6  * _/ _/ _/ _/ _/ _/ _/ _/ _/
7  * _/ _/ _/ _/ _/ _/_/_/ _/ _/
8  *
9  * ***********************************************
10  * PandA Project
11  * URL: http://panda.dei.polimi.it
12  * Politecnico di Milano - DEIB
13  * System Architectures Group
14  * ***********************************************
15  * Copyright (C) 2004-2024 Politecnico di Milano
16  *
17  * This file is part of the PandA framework.
18  *
19  * The PandA framework is free software; you can redistribute it and/or modify
20  * it under the terms of the GNU General Public License as published by
21  * the Free Software Foundation; either version 3 of the License, or
22  * (at your option) any later version.
23  *
24  * This program is distributed in the hope that it will be useful,
25  * but WITHOUT ANY WARRANTY; without even the implied warranty of
26  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
27  * GNU General Public License for more details.
28  *
29  * You should have received a copy of the GNU General Public License
30  * along with this program. If not, see <http://www.gnu.org/licenses/>.
31  *
32  */
40 #include "complete_call_graph.hpp"
41 
42 #include "config_HAVE_FROM_PRAGMA_BUILT.hpp" // for HAVE_FROM_PRAGMA_BUILT
43 
44 #include "Parameter.hpp" // for Parameter, OPT_hls_div
45 #include "exceptions.hpp" // for THROW_UNREACHABLE
46 #include "hash_helper.hpp" // for hash
47 #include "string_manipulation.hpp" // for GET_CLASS
48 #include <string> // for string, operator!=, bas...
49 
51  const DesignFlowManagerConstRef _design_flow_manager,
52  const ParameterConstRef _parameters)
53  : ApplicationFrontendFlowStep(_AppM, COMPLETE_CALL_GRAPH, _design_flow_manager, _parameters)
54 {
55  composed = true;
56  debug_level = parameters->get_class_debug_level(GET_CLASS(*this));
57 }
58 
60 
63 {
65  switch(relationship_type)
66  {
68  {
69  relationships.insert(std::make_pair(CALL_GRAPH_BUILTIN_CALL, ALL_FUNCTIONS));
70  relationships.insert(std::make_pair(COMPUTE_IMPLICIT_CALLS, ALL_FUNCTIONS));
71  relationships.insert(std::make_pair(DATAFLOW_CG_EXT, ALL_FUNCTIONS));
72  relationships.insert(std::make_pair(FUNCTION_ANALYSIS, WHOLE_APPLICATION));
73  if(parameters->isOption(OPT_hls_div) && parameters->getOption<std::string>(OPT_hls_div) != "none")
74  {
75  relationships.insert(std::make_pair(HLS_DIV_CG_EXT, ALL_FUNCTIONS));
76  }
77  if(parameters->isOption(OPT_soft_float) && parameters->getOption<bool>(OPT_soft_float))
78  {
79  relationships.insert(std::make_pair(SOFT_FLOAT_CG_EXT, ALL_FUNCTIONS));
80  }
81  relationships.insert(std::make_pair(UN_COMPARISON_LOWERING, ALL_FUNCTIONS));
82  break;
83  }
85  {
86  break;
87  }
89  {
90  break;
91  }
92  default:
93  THROW_UNREACHABLE("Relationship type does not exist");
94  }
95  return relationships;
96 }
97 
99 {
101 }
102 
104 {
105  return true;
106 }
#define GET_CLASS(obj)
Macro returning the actual type of an object.
RelationshipType
The relationship type.
Source must be executed to satisfy target.
const CustomUnorderedSet< std::pair< FrontendFlowStepType, FunctionRelationship > > ComputeFrontendRelationships(const DesignFlowStep::RelationshipType relationship_type) const override
Return the set of analyses in relationship with this design step.
exceptions managed by PandA
Auxiliary methods for manipulating string.
#define THROW_UNREACHABLE(str_expr)
helper function used to specify that some points should never be reached
Definition: exceptions.hpp:292
bool composed
True if this step represents a composition of design flow steps (e.g., a flow); must be set by specia...
This class models the ending of execution of all functions which can add a function to call graph...
const ParameterConstRef parameters
Set of input parameters.
DesignFlowStep_Status
The status of a step.
CompleteCallGraph(const application_managerRef AppM, const DesignFlowManagerConstRef design_flow_manager, const ParameterConstRef parameters)
Constructor.
DesignFlowStep_Status Exec() override
Execute this step.
This file collects some hash functors.
Template borrowed from the ANTLR library by Terence Parr (http://www.jGuru.com - Software rights: htt...
Definition: refcount.hpp:94
this class is used to manage the command-line or XML options.
int debug_level
The debug level.
bool HasToBeExecuted() const override
Check if this step has actually to be executed.
~CompleteCallGraph() override
Destructor.

Generated on Mon Feb 12 2024 13:02:51 for PandA-2024.02 by doxygen 1.8.13