2019-02-24 14:20:40 -05:00
|
|
|
#include "triton/codegen/vectorize.h"
|
|
|
|
#include "triton/codegen/tune.h"
|
|
|
|
#include "triton/ir/module.h"
|
|
|
|
#include "triton/ir/function.h"
|
|
|
|
#include "triton/ir/basic_block.h"
|
|
|
|
#include "triton/ir/instructions.h"
|
2019-02-12 11:47:52 -05:00
|
|
|
|
2019-02-24 14:22:44 -05:00
|
|
|
namespace triton {
|
2019-02-12 11:47:52 -05:00
|
|
|
|
|
|
|
namespace codegen{
|
|
|
|
|
|
|
|
void vectorize::run(ir::module &mod) {
|
|
|
|
ir::builder &builder = mod.get_builder();
|
|
|
|
for(ir::function *fn: mod.get_function_list())
|
|
|
|
for(ir::basic_block *block: fn->blocks())
|
|
|
|
for(ir::instruction *i: block->get_inst_list())
|
|
|
|
if(dynamic_cast<ir::copy_to_shared_inst*>(i)){
|
|
|
|
ir::value *x = i->get_operand(0);
|
2019-03-09 12:05:12 -05:00
|
|
|
if(params_->get_param(x, "p0.d0")->get_value() == 1)
|
2019-02-24 23:22:28 -05:00
|
|
|
continue;
|
|
|
|
builder.set_insert_point(i);
|
2019-02-12 11:47:52 -05:00
|
|
|
ir::instruction *rx = (ir::instruction*)builder.create_vectorize(x);
|
|
|
|
x->replace_all_uses_with(rx);
|
|
|
|
rx->set_operand(0, x);
|
|
|
|
params_->copy(rx, x);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|