1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59
|
/*========================== begin_copyright_notice ============================
Copyright (C) 2023 Intel Corporation
SPDX-License-Identifier: MIT
============================= end_copyright_notice ===========================*/
//
/// GenXLegalizeGVLoadUses
///
//===----------------------------------------------------------------------===//
#include "GenX.h"
#include "GenXUtil.h"
#include "llvm/IR/Module.h"
#include "llvm/InitializePasses.h"
#include "llvm/Pass.h"
#include "llvm/Support/Debug.h"
#include "GenXRegionUtils.h"
#define DEBUG_TYPE "GENX_LEGALIZE_GVLOAD_USES"
using namespace llvm;
class GenXLegalizeGVLoadUses : public ModulePass {
public:
static char ID;
explicit GenXLegalizeGVLoadUses() : ModulePass(ID) {}
llvm::StringRef getPassName() const override {
return "GenXLegalizeGVLoadUses";
}
bool runOnModule(Module &M) override;
};
bool GenXLegalizeGVLoadUses::runOnModule(Module &M) {
bool Changed = false;
for (auto &GV : M.globals()) {
if (!GV.hasAttribute(genx::FunctionMD::GenXVolatile))
continue;
for (auto UI = GV.user_begin(), E = GV.user_end(); UI != E;)
if (auto *I = dyn_cast<Instruction>(*UI++); I && genx::isAGVLoad(I))
Changed |= genx::legalizeGVLoadForbiddenUsers(I);
}
return Changed;
}
char GenXLegalizeGVLoadUses::ID = 0;
namespace llvm {
void initializeGenXLegalizeGVLoadUsesPass(PassRegistry &);
}
INITIALIZE_PASS_BEGIN(GenXLegalizeGVLoadUses, "GenXLegalizeGVLoadUses", "GenXLegalizeGVLoadUses", false, false)
INITIALIZE_PASS_END(GenXLegalizeGVLoadUses, "GenXLegalizeGVLoadUses", "GenXLegalizeGVLoadUses", false, false)
ModulePass *llvm::createGenXLegalizeGVLoadUsesPass() {
initializeGenXLegalizeGVLoadUsesPass(*PassRegistry::getPassRegistry());
return new GenXLegalizeGVLoadUses;
}
|