[llvm] [BOLT][AArch64] Handle PAuth call instructions in isIndirectCall (PR #133227)
Anatoly Trosinenko via llvm-commits
llvm-commits at lists.llvm.org
Thu Mar 27 03:20:28 PDT 2025
https://github.com/atrosinenko created https://github.com/llvm/llvm-project/pull/133227
None
>From 71b8787e818820c016ba313fc077f0b9166d047e Mon Sep 17 00:00:00 2001
From: Anatoly Trosinenko <atrosinenko at accesssoftek.com>
Date: Wed, 26 Mar 2025 20:42:22 +0300
Subject: [PATCH] [BOLT][AArch64] Handle PAuth call instructions in
isIndirectCall
---
bolt/lib/Target/AArch64/AArch64MCPlusBuilder.cpp | 3 ++-
llvm/lib/Target/AArch64/AArch64InstrInfo.h | 13 +++++++++++++
2 files changed, 15 insertions(+), 1 deletion(-)
diff --git a/bolt/lib/Target/AArch64/AArch64MCPlusBuilder.cpp b/bolt/lib/Target/AArch64/AArch64MCPlusBuilder.cpp
index d238a1df5c7d7..5a2f8f6700b12 100644
--- a/bolt/lib/Target/AArch64/AArch64MCPlusBuilder.cpp
+++ b/bolt/lib/Target/AArch64/AArch64MCPlusBuilder.cpp
@@ -10,6 +10,7 @@
//
//===----------------------------------------------------------------------===//
+#include "AArch64InstrInfo.h"
#include "AArch64MCSymbolizer.h"
#include "MCTargetDesc/AArch64AddressingModes.h"
#include "MCTargetDesc/AArch64FixupKinds.h"
@@ -635,7 +636,7 @@ class AArch64MCPlusBuilder : public MCPlusBuilder {
}
bool isIndirectCall(const MCInst &Inst) const override {
- return Inst.getOpcode() == AArch64::BLR;
+ return isIndirectCallOpcode(Inst.getOpcode());
}
MCPhysReg getSpRegister(int Size) const {
diff --git a/llvm/lib/Target/AArch64/AArch64InstrInfo.h b/llvm/lib/Target/AArch64/AArch64InstrInfo.h
index b3d3ec1455c8b..0ffaca9af4006 100644
--- a/llvm/lib/Target/AArch64/AArch64InstrInfo.h
+++ b/llvm/lib/Target/AArch64/AArch64InstrInfo.h
@@ -726,6 +726,19 @@ static inline bool isIndirectBranchOpcode(int Opc) {
return false;
}
+static inline bool isIndirectCallOpcode(unsigned Opc) {
+ switch (Opc) {
+ case AArch64::BLR:
+ case AArch64::BLRAA:
+ case AArch64::BLRAB:
+ case AArch64::BLRAAZ:
+ case AArch64::BLRABZ:
+ return true;
+ default:
+ return false;
+ }
+}
+
static inline bool isPTrueOpcode(unsigned Opc) {
switch (Opc) {
case AArch64::PTRUE_B:
More information about the llvm-commits
mailing list