From 8b98bcf6530c9940b0039290d2c490467b226b16 Mon Sep 17 00:00:00 2001 From: Lucas Steuernagel Date: Fri, 26 Jan 2024 14:16:10 -0300 Subject: [PATCH 1/4] Allocate call arguments on a fixed offset --- llvm/lib/Target/SBF/SBFISelLowering.cpp | 45 +++++++++++++++++++------ llvm/test/CodeGen/SBF/stack_args_v2.ll | 32 ++++++++++++++++++ 2 files changed, 67 insertions(+), 10 deletions(-) create mode 100644 llvm/test/CodeGen/SBF/stack_args_v2.ll diff --git a/llvm/lib/Target/SBF/SBFISelLowering.cpp b/llvm/lib/Target/SBF/SBFISelLowering.cpp index fc415d6231a115..77e7447c175ab3 100644 --- a/llvm/lib/Target/SBF/SBFISelLowering.cpp +++ b/llvm/lib/Target/SBF/SBFISelLowering.cpp @@ -11,11 +11,8 @@ // //===----------------------------------------------------------------------===// -#include "SBFISelLowering.h" -#include "SBF.h" #include "SBFRegisterInfo.h" #include "SBFSubtarget.h" -#include "SBFTargetMachine.h" #include "llvm/CodeGen/CallingConvLower.h" #include "llvm/CodeGen/MachineFrameInfo.h" #include "llvm/CodeGen/MachineFunction.h" @@ -26,7 +23,6 @@ #include "llvm/IR/DiagnosticInfo.h" #include "llvm/IR/DiagnosticPrinter.h" #include "llvm/IR/IntrinsicsBPF.h" // TODO: jle. -#include "llvm/Support/Debug.h" #include "llvm/Support/ErrorHandling.h" #include "llvm/Support/raw_ostream.h" using namespace llvm; @@ -466,10 +462,19 @@ SDValue SBFTargetLowering::LowerFormalArguments( EVT PtrVT = DAG.getTargetLoweringInfo().getPointerTy(DAG.getDataLayout()); EVT LocVT = VA.getLocVT(); + unsigned Offset; + if (Subtarget->getHasDynamicFrames()) { + // In SBFv2, the arguments are stored on the start of the frame. + Offset = VA.getLocMemOffset() + 8; + } else { + Offset = SBFRegisterInfo::FrameLength - VA.getLocMemOffset(); + } + // Arguments relative to SBF::R5 unsigned reg = MF.addLiveIn(SBF::R5, &SBF::GPRRegClass); - SDValue Const = DAG.getConstant(SBFRegisterInfo::FrameLength - VA.getLocMemOffset(), DL, MVT::i64); - SDValue SDV = DAG.getCopyFromReg(Chain, DL, reg, getPointerTy(MF.getDataLayout())); + SDValue Const = DAG.getConstant(Offset, DL, MVT::i64); + SDValue SDV = + DAG.getCopyFromReg(Chain, DL, reg, getPointerTy(MF.getDataLayout())); SDV = DAG.getNode(ISD::SUB, DL, PtrVT, SDV, Const); SDV = DAG.getLoad(LocVT, DL, Chain, SDV, MachinePointerInfo()); InVals.push_back(SDV); @@ -587,7 +592,10 @@ SDValue SBFTargetLowering::LowerCall(TargetLowering::CallLoweringInfo &CLI, SDValue InFlag; if (HasStackArgs) { - SDValue FramePtr = DAG.getCopyFromReg(Chain, CLI.DL, SBF::R10, getPointerTy(MF.getDataLayout())); + SDValue FramePtr = DAG.getCopyFromReg(Chain, + CLI.DL, + Subtarget->getRegisterInfo()->getFrameRegister(MF), + getPointerTy(MF.getDataLayout())); // Stack arguments have to be walked in reverse order by inserting // chained stores, this ensures their order is not changed by the scheduler @@ -601,9 +609,26 @@ SDValue SBFTargetLowering::LowerCall(TargetLowering::CallLoweringInfo &CLI, assert(VA.isMemLoc()); EVT PtrVT = DAG.getTargetLoweringInfo().getPointerTy(DAG.getDataLayout()); - SDValue Const = DAG.getConstant(SBFRegisterInfo::FrameLength - VA.getLocMemOffset(), CLI.DL, MVT::i64); - SDValue PtrOff = DAG.getNode(ISD::SUB, CLI.DL, PtrVT, FramePtr, Const); - Chain = DAG.getStore(Chain, CLI.DL, Arg, PtrOff, MachinePointerInfo()); + SDValue DstAddr; + MachinePointerInfo DstInfo; + if (Subtarget->getHasDynamicFrames()) { + // When dynamic frames are enable, the frame size is only calculated + // after lowering instructions, so we must place arguments at the start + // of the frame. + int64_t Offset = -(int64_t)VA.getLocMemOffset() - 8; + int FrameIndex = MF.getFrameInfo().CreateFixedObject( + VA.getLocVT().getFixedSizeInBits() / 8, Offset, false); + DstAddr = DAG.getFrameIndex(FrameIndex, PtrVT); + DstInfo = MachinePointerInfo::getFixedStack(MF, FrameIndex, Offset); + } else { + SDValue Const = + DAG.getConstant(SBFRegisterInfo::FrameLength - VA.getLocMemOffset(), + CLI.DL, MVT::i64); + DstAddr = DAG.getNode(ISD::SUB, CLI.DL, PtrVT, FramePtr, Const); + DstInfo = MachinePointerInfo(); + } + + Chain = DAG.getStore(Chain, CLI.DL, Arg, DstAddr, DstInfo); } // Pass the current stack frame pointer via SBF::R5, gluing the diff --git a/llvm/test/CodeGen/SBF/stack_args_v2.ll b/llvm/test/CodeGen/SBF/stack_args_v2.ll new file mode 100644 index 00000000000000..4a13de3771ecc7 --- /dev/null +++ b/llvm/test/CodeGen/SBF/stack_args_v2.ll @@ -0,0 +1,32 @@ +; RUN: llc -O2 -march=sbf -mcpu=sbfv2 < %s | FileCheck %s + +; Function Attrs: nounwind uwtable +define i32 @foo(i32 %a, i32 %b, i32 %c) #0 { +; CHECK-LABEL: foo: +; CHECK: mov64 r4, 2 +; CHECK: stxdw [r10 - 8], r4 +; CHECK: mov64 r4, 3 +; CHECK: stxdw [r10 - 16], r4 +; CHECK: mov64 r5, r10 +; CHECK: mov64 r4, 1 +; CHECK: call bar +entry: + %call = tail call i32 @bar(i32 %a, i32 %b, i32 %c, i32 1, i32 2, i32 3) #3 + ret i32 %call +} + +; Function Attrs: nounwind uwtable +define i32 @bar(i32 %a, i32 %b, i32 %c, i32 %d, i32 %e, i32 %f) #1 { +; CHECK-LABEL: bar: +; CHECK: ldxdw r1, [r5 - 8] +; CHECK: sub64 r0, r1 +; CHECK: ldxdw r1, [r5 - 16] +; CHECK: add64 r0, r1 +entry: + %g = add i32 %a, %b + %h = sub i32 %g, %c + %i = add i32 %h, %d + %j = sub i32 %i, %e + %k = add i32 %j, %f + ret i32 %k +} From f481447d84bb4693d372d8ffdf077e0473ee8c61 Mon Sep 17 00:00:00 2001 From: Lucas Steuernagel Date: Fri, 26 Jan 2024 17:01:40 -0300 Subject: [PATCH 2/4] Revert formatting --- llvm/lib/Target/SBF/SBFISelLowering.cpp | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/llvm/lib/Target/SBF/SBFISelLowering.cpp b/llvm/lib/Target/SBF/SBFISelLowering.cpp index 77e7447c175ab3..6e79e9679dad8e 100644 --- a/llvm/lib/Target/SBF/SBFISelLowering.cpp +++ b/llvm/lib/Target/SBF/SBFISelLowering.cpp @@ -473,8 +473,7 @@ SDValue SBFTargetLowering::LowerFormalArguments( // Arguments relative to SBF::R5 unsigned reg = MF.addLiveIn(SBF::R5, &SBF::GPRRegClass); SDValue Const = DAG.getConstant(Offset, DL, MVT::i64); - SDValue SDV = - DAG.getCopyFromReg(Chain, DL, reg, getPointerTy(MF.getDataLayout())); + SDValue SDV = DAG.getCopyFromReg(Chain, DL, reg, getPointerTy(MF.getDataLayout())); SDV = DAG.getNode(ISD::SUB, DL, PtrVT, SDV, Const); SDV = DAG.getLoad(LocVT, DL, Chain, SDV, MachinePointerInfo()); InVals.push_back(SDV); @@ -612,7 +611,7 @@ SDValue SBFTargetLowering::LowerCall(TargetLowering::CallLoweringInfo &CLI, SDValue DstAddr; MachinePointerInfo DstInfo; if (Subtarget->getHasDynamicFrames()) { - // When dynamic frames are enable, the frame size is only calculated + // When dynamic frames are enabled, the frame size is only calculated // after lowering instructions, so we must place arguments at the start // of the frame. int64_t Offset = -(int64_t)VA.getLocMemOffset() - 8; From 0f4d0dff1445714c9b5a8ad256b03de914b1ca14 Mon Sep 17 00:00:00 2001 From: Lucas Steuernagel Date: Mon, 29 Jan 2024 12:27:05 -0300 Subject: [PATCH 3/4] Use size of pointer for offset --- llvm/lib/Target/SBF/SBFISelLowering.cpp | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/llvm/lib/Target/SBF/SBFISelLowering.cpp b/llvm/lib/Target/SBF/SBFISelLowering.cpp index 6e79e9679dad8e..a297ff8c507a87 100644 --- a/llvm/lib/Target/SBF/SBFISelLowering.cpp +++ b/llvm/lib/Target/SBF/SBFISelLowering.cpp @@ -465,7 +465,7 @@ SDValue SBFTargetLowering::LowerFormalArguments( unsigned Offset; if (Subtarget->getHasDynamicFrames()) { // In SBFv2, the arguments are stored on the start of the frame. - Offset = VA.getLocMemOffset() + 8; + Offset = VA.getLocMemOffset() + PtrVT.getFixedSizeInBits() / 8; } else { Offset = SBFRegisterInfo::FrameLength - VA.getLocMemOffset(); } @@ -614,7 +614,8 @@ SDValue SBFTargetLowering::LowerCall(TargetLowering::CallLoweringInfo &CLI, // When dynamic frames are enabled, the frame size is only calculated // after lowering instructions, so we must place arguments at the start // of the frame. - int64_t Offset = -(int64_t)VA.getLocMemOffset() - 8; + int64_t Offset = + -(int64_t)VA.getLocMemOffset() - (PtrVT.getFixedSizeInBits() / 8); int FrameIndex = MF.getFrameInfo().CreateFixedObject( VA.getLocVT().getFixedSizeInBits() / 8, Offset, false); DstAddr = DAG.getFrameIndex(FrameIndex, PtrVT); From 52d4f84480d11f30c15f6cd55efb74c2cfbaeaea Mon Sep 17 00:00:00 2001 From: Lucas Steuernagel Date: Mon, 29 Jan 2024 18:50:54 -0300 Subject: [PATCH 4/4] Use static_cast --- llvm/lib/Target/SBF/SBFISelLowering.cpp | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/llvm/lib/Target/SBF/SBFISelLowering.cpp b/llvm/lib/Target/SBF/SBFISelLowering.cpp index a297ff8c507a87..e87262e1b993f1 100644 --- a/llvm/lib/Target/SBF/SBFISelLowering.cpp +++ b/llvm/lib/Target/SBF/SBFISelLowering.cpp @@ -614,8 +614,8 @@ SDValue SBFTargetLowering::LowerCall(TargetLowering::CallLoweringInfo &CLI, // When dynamic frames are enabled, the frame size is only calculated // after lowering instructions, so we must place arguments at the start // of the frame. - int64_t Offset = - -(int64_t)VA.getLocMemOffset() - (PtrVT.getFixedSizeInBits() / 8); + int64_t Offset = -static_cast(VA.getLocMemOffset() + + PtrVT.getFixedSizeInBits() / 8); int FrameIndex = MF.getFrameInfo().CreateFixedObject( VA.getLocVT().getFixedSizeInBits() / 8, Offset, false); DstAddr = DAG.getFrameIndex(FrameIndex, PtrVT);