perf.cpp 2.91 KB
Newer Older
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
/*
 * The MIT License (MIT)
 *
 * Copyright (c) 2015-2022 Advanced Micro Devices, Inc. All rights reserved.
 *
 * Permission is hereby granted, free of charge, to any person obtaining a copy
 * of this software and associated documentation files (the "Software"), to deal
 * in the Software without restriction, including without limitation the rights
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 * copies of the Software, and to permit persons to whom the Software is
 * furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in
 * all copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL THE
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
 * THE SOFTWARE.
 */
Paul's avatar
Paul committed
24
25
26
#include "perf.hpp"

#include <migraphx/generate.hpp>
27
#include <migraphx/register_target.hpp>
Paul's avatar
Paul committed
28
29
30
31
32
33
34
35
#ifdef HAVE_GPU
#include <migraphx/gpu/hip.hpp>
#endif

namespace migraphx {
namespace driver {
inline namespace MIGRAPHX_INLINE_NS {

36
37
38
39
40
41
template <class T>
auto get_hash(const T& x)
{
    return std::hash<T>{}(x);
}

42
43
44
45
parameter_map fill_param_map(parameter_map& m,
                             const std::unordered_map<std::string, shape>& param_shapes,
                             const target& t,
                             bool offload)
46
{
47
    for(auto&& x : param_shapes)
48
49
50
    {
        argument& arg = m[x.first];
        if(arg.empty())
51
52
        {
            assert(not x.second.dynamic());
53
            arg = generate_argument(x.second, get_hash(x.first));
54
        }
55
56
57
58
59
60
        if(not offload)
            arg = t.copy_to(arg);
    }
    return m;
}

61
parameter_map create_param_map(const program& p, const target& t, bool offload)
62
{
63
    parameter_map m;
64
65
66
67
68
69
70
71
72
73
74
    for(auto&& x : p.get_parameter_shapes())
    {
        auto arg = generate_argument(x.second, get_hash(x.first));
        if(offload)
            m[x.first] = arg;
        else
            m[x.first] = t.copy_to(arg);
    }
    return m;
}

75
parameter_map create_param_map(const program& p, bool gpu)
Paul's avatar
Paul committed
76
{
77
    parameter_map m;
Paul's avatar
Paul committed
78
79
80
81
    for(auto&& x : p.get_parameter_shapes())
    {
#ifdef HAVE_GPU
        if(gpu)
82
            m[x.first] = gpu::to_gpu(generate_argument(x.second, get_hash(x.first)));
Paul's avatar
Paul committed
83
        else
Paul's avatar
Paul committed
84
#else
Paul's avatar
Paul committed
85
        (void)gpu;
Paul's avatar
Paul committed
86
#endif
87
            m[x.first] = generate_argument(x.second, get_hash(x.first));
Paul's avatar
Paul committed
88
89
90
91
    }
    return m;
}

92
93
94
target get_target(bool gpu)
{
    if(gpu)
95
        return make_target("gpu");
96
    else
97
        return make_target("cpu");
98
99
}

100
} // namespace  MIGRAPHX_INLINE_NS
Paul's avatar
Paul committed
101
102
} // namespace driver
} // namespace migraphx