"vscode:/vscode.git/clone" did not exist on "12e9c7d5d1052bde22017dfade1da61c9a27f18c"
eliminate_workspace.cpp 1.12 KB
Newer Older
1
2
3
4
5
6
7
8
#include <migraph/gpu/eliminate_workspace.hpp>
#include <migraph/gpu/hip.hpp>
#include <migraph/program.hpp>
#include <migraph/instruction.hpp>
#include <migraph/operators.hpp>
#include <migraph/iterator_for.hpp>
#include <migraph/ranges.hpp>
#include <migraph/stringutils.hpp>
mei-ye's avatar
mei-ye committed
9
#include <migraph/pass_config.hpp>
10
11
12
13
14
15

namespace migraph {
namespace gpu {

void eliminate_workspace::apply(program& p) const
{
mei-ye's avatar
mei-ye committed
16
    if(!enabled(MIGRAPH_DISABLE_MEMORY_COLORING{}))
mei-ye's avatar
mei-ye committed
17
        return;
mei-ye's avatar
mei-ye committed
18

19
20
21
22
    std::size_t n = 0;
    std::vector<instruction_ref> allocs;
    for(auto ins : iterator_for(p))
    {
Paul's avatar
Paul committed
23
        if(ins->outputs().size() != 1)
24
            continue;
Paul's avatar
Paul committed
25
        if(ins->name() != "hip::allocate")
26
            continue;
27
        auto&& a = any_cast<hip_allocate>(ins->get_operator());
Paul's avatar
Paul committed
28
        if(a.tag == "workspace")
29
30
31
32
33
34
        {
            n = std::max(n, ins->get_shape().bytes());
            allocs.push_back(ins);
        }
    }
    auto ws = p.add_parameter("workspace", shape{shape::int8_type, {n}});
Paul's avatar
Paul committed
35
    for(auto&& a : allocs)
36
37
38
39
40
41
42
    {
        p.replace_instruction(a, ws);
        p.remove_instruction(a);
    }
}
} // namespace gpu
} // namespace migraph