xref: /aosp_15_r20/external/ComputeLibrary/src/graph/GraphManager.cpp (revision c217d954acce2dbc11938adb493fc0abd69584f3)
1*c217d954SCole Faust /*
2*c217d954SCole Faust  * Copyright (c) 2018-2021 Arm Limited.
3*c217d954SCole Faust  *
4*c217d954SCole Faust  * SPDX-License-Identifier: MIT
5*c217d954SCole Faust  *
6*c217d954SCole Faust  * Permission is hereby granted, free of charge, to any person obtaining a copy
7*c217d954SCole Faust  * of this software and associated documentation files (the "Software"), to
8*c217d954SCole Faust  * deal in the Software without restriction, including without limitation the
9*c217d954SCole Faust  * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
10*c217d954SCole Faust  * sell copies of the Software, and to permit persons to whom the Software is
11*c217d954SCole Faust  * furnished to do so, subject to the following conditions:
12*c217d954SCole Faust  *
13*c217d954SCole Faust  * The above copyright notice and this permission notice shall be included in all
14*c217d954SCole Faust  * copies or substantial portions of the Software.
15*c217d954SCole Faust  *
16*c217d954SCole Faust  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17*c217d954SCole Faust  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18*c217d954SCole Faust  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
19*c217d954SCole Faust  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20*c217d954SCole Faust  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
21*c217d954SCole Faust  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
22*c217d954SCole Faust  * SOFTWARE.
23*c217d954SCole Faust  */
24*c217d954SCole Faust #include "arm_compute/graph/GraphManager.h"
25*c217d954SCole Faust 
26*c217d954SCole Faust #include "arm_compute/graph/Graph.h"
27*c217d954SCole Faust #include "arm_compute/graph/GraphContext.h"
28*c217d954SCole Faust #include "arm_compute/graph/Logger.h"
29*c217d954SCole Faust #include "arm_compute/graph/PassManager.h"
30*c217d954SCole Faust #include "arm_compute/graph/TypePrinter.h"
31*c217d954SCole Faust #include "arm_compute/graph/Utils.h"
32*c217d954SCole Faust #include "arm_compute/graph/algorithms/TopologicalSort.h"
33*c217d954SCole Faust #include "arm_compute/graph/detail/CrossLayerMemoryManagerHelpers.h"
34*c217d954SCole Faust #include "arm_compute/graph/detail/ExecutionHelpers.h"
35*c217d954SCole Faust 
36*c217d954SCole Faust #include "src/common/utils/Log.h"
37*c217d954SCole Faust 
38*c217d954SCole Faust namespace arm_compute
39*c217d954SCole Faust {
40*c217d954SCole Faust namespace graph
41*c217d954SCole Faust {
GraphManager()42*c217d954SCole Faust GraphManager::GraphManager()
43*c217d954SCole Faust     : _workloads()
44*c217d954SCole Faust {
45*c217d954SCole Faust }
46*c217d954SCole Faust 
finalize_graph(Graph & graph,GraphContext & ctx,PassManager & pm,Target target)47*c217d954SCole Faust void GraphManager::finalize_graph(Graph &graph, GraphContext &ctx, PassManager &pm, Target target)
48*c217d954SCole Faust {
49*c217d954SCole Faust     ARM_COMPUTE_LOG_INFO_WITH_FUNCNAME_ACL("Initiate graph configuration!");
50*c217d954SCole Faust 
51*c217d954SCole Faust     // Check if graph has been registered
52*c217d954SCole Faust     if(_workloads.find(graph.id()) != std::end(_workloads))
53*c217d954SCole Faust     {
54*c217d954SCole Faust         ARM_COMPUTE_ERROR("Graph is already registered!");
55*c217d954SCole Faust     }
56*c217d954SCole Faust 
57*c217d954SCole Faust     // Apply IR mutating passes
58*c217d954SCole Faust     pm.run_type(graph, IGraphMutator::MutationType::IR);
59*c217d954SCole Faust 
60*c217d954SCole Faust     // Force target to all graph construct
61*c217d954SCole Faust     Target forced_target = target;
62*c217d954SCole Faust 
63*c217d954SCole Faust     // In case CLVK is selected, use the CL backend and
64*c217d954SCole Faust     // update config
65*c217d954SCole Faust     if(target == Target::CLVK)
66*c217d954SCole Faust     {
67*c217d954SCole Faust         forced_target       = Target::CL;
68*c217d954SCole Faust         GraphConfig config  = ctx.config();
69*c217d954SCole Faust         config.backend_type = CLBackendType::Clvk;
70*c217d954SCole Faust 
71*c217d954SCole Faust         ctx.set_config(config);
72*c217d954SCole Faust     }
73*c217d954SCole Faust 
74*c217d954SCole Faust     if(!is_target_supported(target))
75*c217d954SCole Faust     {
76*c217d954SCole Faust         forced_target = get_default_target();
77*c217d954SCole Faust         ARM_COMPUTE_LOG_GRAPH_INFO("Switching target from " << target << " to " << forced_target << std::endl);
78*c217d954SCole Faust     }
79*c217d954SCole Faust     force_target_to_graph(graph, forced_target);
80*c217d954SCole Faust 
81*c217d954SCole Faust     // Setup backend context
82*c217d954SCole Faust     setup_requested_backend_context(ctx, forced_target);
83*c217d954SCole Faust 
84*c217d954SCole Faust     // Configure all tensors
85*c217d954SCole Faust     detail::configure_all_tensors(graph);
86*c217d954SCole Faust 
87*c217d954SCole Faust     // Apply backend mutating passes
88*c217d954SCole Faust     pm.run_type(graph, IGraphMutator::MutationType::Backend);
89*c217d954SCole Faust 
90*c217d954SCole Faust     // Perform topological sort
91*c217d954SCole Faust     std::vector<NodeID> topological_sorted_nodes = dfs(graph);
92*c217d954SCole Faust 
93*c217d954SCole Faust     // Validate all nodes
94*c217d954SCole Faust     detail::validate_all_nodes(graph);
95*c217d954SCole Faust 
96*c217d954SCole Faust     // Configure all nodes
97*c217d954SCole Faust     auto workload = detail::configure_all_nodes(graph, ctx, topological_sorted_nodes);
98*c217d954SCole Faust     ARM_COMPUTE_ERROR_ON_MSG(workload.tasks.empty(), "Could not configure all nodes!");
99*c217d954SCole Faust 
100*c217d954SCole Faust     // Allocate const tensors and call accessors
101*c217d954SCole Faust     detail::allocate_const_tensors(graph);
102*c217d954SCole Faust     detail::call_all_const_node_accessors(graph);
103*c217d954SCole Faust 
104*c217d954SCole Faust     // Prepare graph
105*c217d954SCole Faust     detail::prepare_all_tasks(workload);
106*c217d954SCole Faust 
107*c217d954SCole Faust     // Setup tensor memory (Allocate all tensors or setup transition manager)
108*c217d954SCole Faust     if(ctx.config().use_transition_memory_manager)
109*c217d954SCole Faust     {
110*c217d954SCole Faust         detail::configure_transition_manager(graph, ctx, workload);
111*c217d954SCole Faust     }
112*c217d954SCole Faust     else
113*c217d954SCole Faust     {
114*c217d954SCole Faust         detail::allocate_all_tensors(graph);
115*c217d954SCole Faust     }
116*c217d954SCole Faust 
117*c217d954SCole Faust     // Finalize Graph context
118*c217d954SCole Faust     ctx.finalize();
119*c217d954SCole Faust 
120*c217d954SCole Faust     // Register graph
121*c217d954SCole Faust     _workloads.insert(std::make_pair(graph.id(), std::move(workload)));
122*c217d954SCole Faust     ARM_COMPUTE_LOG_GRAPH_VERBOSE("Created workload for graph with ID : " << graph.id() << std::endl);
123*c217d954SCole Faust }
124*c217d954SCole Faust 
execute_graph(Graph & graph)125*c217d954SCole Faust void GraphManager::execute_graph(Graph &graph)
126*c217d954SCole Faust {
127*c217d954SCole Faust     ARM_COMPUTE_LOG_INFO_WITH_FUNCNAME_ACL("Initiate graph execution!");
128*c217d954SCole Faust 
129*c217d954SCole Faust     // Check if graph is finalized
130*c217d954SCole Faust     auto it = _workloads.find(graph.id());
131*c217d954SCole Faust     ARM_COMPUTE_ERROR_ON_MSG(it == std::end(_workloads), "Graph is not registered!");
132*c217d954SCole Faust 
133*c217d954SCole Faust     while(true)
134*c217d954SCole Faust     {
135*c217d954SCole Faust         // Call input accessors
136*c217d954SCole Faust         if(!detail::call_all_input_node_accessors(it->second))
137*c217d954SCole Faust         {
138*c217d954SCole Faust             return;
139*c217d954SCole Faust         }
140*c217d954SCole Faust 
141*c217d954SCole Faust         // Run graph
142*c217d954SCole Faust         detail::call_all_tasks(it->second);
143*c217d954SCole Faust 
144*c217d954SCole Faust         // Call output accessors
145*c217d954SCole Faust         if(!detail::call_all_output_node_accessors(it->second))
146*c217d954SCole Faust         {
147*c217d954SCole Faust             return;
148*c217d954SCole Faust         }
149*c217d954SCole Faust     }
150*c217d954SCole Faust }
151*c217d954SCole Faust 
invalidate_graph(Graph & graph)152*c217d954SCole Faust void GraphManager::invalidate_graph(Graph &graph)
153*c217d954SCole Faust {
154*c217d954SCole Faust     auto it = _workloads.find(graph.id());
155*c217d954SCole Faust     ARM_COMPUTE_ERROR_ON_MSG(it == std::end(_workloads), "Graph is not registered!");
156*c217d954SCole Faust 
157*c217d954SCole Faust     _workloads.erase(it);
158*c217d954SCole Faust }
159*c217d954SCole Faust } // namespace graph
160*c217d954SCole Faust } // namespace arm_compute