[llvm] [Hexagon] Use LiveRegUnits (PR #84112)
via llvm-commits
llvm-commits at lists.llvm.org
Thu Mar 7 16:39:02 PST 2024
https://github.com/AtariDreams updated https://github.com/llvm/llvm-project/pull/84112
>From 0a340b5b00d7ca5ce5b250bf9e7d5334ab133e99 Mon Sep 17 00:00:00 2001
From: Rose <gfunni234 at gmail.com>
Date: Tue, 5 Mar 2024 17:35:23 -0500
Subject: [PATCH] [Hexagon] Use LiveRegUnits
---
llvm/lib/Target/Hexagon/HexagonGenMux.cpp | 12 +++---------
1 file changed, 3 insertions(+), 9 deletions(-)
diff --git a/llvm/lib/Target/Hexagon/HexagonGenMux.cpp b/llvm/lib/Target/Hexagon/HexagonGenMux.cpp
index 509144ceb6a049..74ab58e0296616 100644
--- a/llvm/lib/Target/Hexagon/HexagonGenMux.cpp
+++ b/llvm/lib/Target/Hexagon/HexagonGenMux.cpp
@@ -26,7 +26,7 @@
#include "llvm/ADT/DenseMap.h"
#include "llvm/ADT/SmallVector.h"
#include "llvm/ADT/StringRef.h"
-#include "llvm/CodeGen/LivePhysRegs.h"
+#include "llvm/CodeGen/LiveRegUnits.h"
#include "llvm/CodeGen/MachineBasicBlock.h"
#include "llvm/CodeGen/MachineFunction.h"
#include "llvm/CodeGen/MachineFunctionPass.h"
@@ -346,14 +346,8 @@ bool HexagonGenMux::genMuxInBlock(MachineBasicBlock &B) {
// Fix up kill flags.
- LivePhysRegs LPR(*HRI);
+ LiveRegUnits LPR(*HRI);
LPR.addLiveOuts(B);
- auto IsLive = [&LPR, this](unsigned Reg) -> bool {
- for (MCPhysReg S : HRI->subregs_inclusive(Reg))
- if (LPR.contains(S))
- return true;
- return false;
- };
for (MachineInstr &I : llvm::reverse(B)) {
if (I.isDebugInstr())
continue;
@@ -365,7 +359,7 @@ bool HexagonGenMux::genMuxInBlock(MachineBasicBlock &B) {
if (!Op.isReg() || !Op.isUse())
continue;
assert(Op.getSubReg() == 0 && "Should have physical registers only");
- bool Live = IsLive(Op.getReg());
+ bool Live = !LPR.available(Op.getReg());
Op.setIsKill(!Live);
}
LPR.stepBackward(I);
More information about the llvm-commits
mailing list