Skip to content

Commit

Permalink
MergeGepUse improvements (#4784)
Browse files Browse the repository at this point in the history
- Added a comment warning  about using MergeGepUse while iterating.
- Changed MergeGepUse to return bool for whether anything actually changed.
- Adding GEP's user to worklist, even when GEP and GEP's source pointer GEP cannot be merged.
  • Loading branch information
adam-yang authored Nov 10, 2022
1 parent 4349c3e commit 0392e60
Show file tree
Hide file tree
Showing 2 changed files with 18 additions and 3 deletions.
8 changes: 7 additions & 1 deletion include/dxc/DXIL/DxilUtil.h
Original file line number Diff line number Diff line change
Expand Up @@ -61,7 +61,13 @@ namespace dxilutil {
llvm::Type *Ty, DxilTypeSystem &typeSys);
llvm::Type *GetArrayEltTy(llvm::Type *Ty);
bool HasDynamicIndexing(llvm::Value *V);
void MergeGepUse(llvm::Value *V);

// Cleans up unnecessary chains of GEPs and bitcasts left over from certain
// optimizations. This function is NOT safe to call while iterating
// instructions either forward or backward. If V happens to be a GEP or
// bitcast, the function may delete V, instructions preceding V it, and
// instructions following V.
bool MergeGepUse(llvm::Value *V);

// Find alloca insertion point, given instruction
llvm::Instruction *FindAllocaInsertionPt(llvm::Instruction* I); // Considers entire parent function
Expand Down
13 changes: 11 additions & 2 deletions lib/DXIL/DxilUtilDbgInfoAndMisc.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -108,7 +108,8 @@ namespace hlsl {

namespace dxilutil {

void MergeGepUse(Value *V) {
bool MergeGepUse(Value *V) {
bool changed = false;
SmallVector<Value *, 16> worklist;
auto addUsersToWorklist = [&worklist](Value *V) {
if (!V->user_empty()) {
Expand All @@ -125,6 +126,7 @@ void MergeGepUse(Value *V) {
V = worklist.pop_back_val();
if (BitCastOperator *BCO = dyn_cast<BitCastOperator>(V)) {
if (Value *NewV = dxilutil::TryReplaceBaseCastWithGep(V)) {
changed = true;
worklist.push_back(NewV);
} else {
// merge any GEP users of the untranslated bitcast
Expand All @@ -137,15 +139,22 @@ void MergeGepUse(Value *V) {
if (Value *newGEP = MergeGEP(prevGEP, GEP)) {
worklist.push_back(newGEP);
// delete prevGEP if no more users
if (prevGEP->user_empty() && isa<GetElementPtrInst>(prevGEP))
if (prevGEP->user_empty() && isa<GetElementPtrInst>(prevGEP)) {
cast<GetElementPtrInst>(prevGEP)->eraseFromParent();
changed = true;
}
}
else {
addUsersToWorklist(GEP);
}
} else {
// nothing to merge yet, add GEP users
addUsersToWorklist(V);
}
}
}

return changed;
}

std::unique_ptr<llvm::Module> LoadModuleFromBitcode(llvm::MemoryBuffer *MB,
Expand Down

0 comments on commit 0392e60

Please sign in to comment.