diff options
author | Oliver Stannard <oliver.stannard@arm.com> | 2024-06-07 10:58:10 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-06-07 10:58:10 +0100 |
commit | 1a5239251ead73ee57f4e2f7fc93433ac7cf18b1 (patch) | |
tree | a2c31e3c7dce81d19f390f97e9d9754b5dbeda81 /llvm/lib/CodeGen/CommandFlags.cpp | |
parent | b87a80d4ebca9e1c065f0d2762e500078c4badca (diff) | |
download | llvm-1a5239251ead73ee57f4e2f7fc93433ac7cf18b1.zip llvm-1a5239251ead73ee57f4e2f7fc93433ac7cf18b1.tar.gz llvm-1a5239251ead73ee57f4e2f7fc93433ac7cf18b1.tar.bz2 |
[ARM] r11 is reserved when using -mframe-chain=aapcs (#86951)
When using the -mframe-chain=aapcs or -mframe-chain=aapcs-leaf options,
we cannot use r11 as an allocatable register, even if
-fomit-frame-pointer is also used. This is so that r11 will always point
to a valid frame record, even if we don't create one in every function.
Diffstat (limited to 'llvm/lib/CodeGen/CommandFlags.cpp')
-rw-r--r-- | llvm/lib/CodeGen/CommandFlags.cpp | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/llvm/lib/CodeGen/CommandFlags.cpp b/llvm/lib/CodeGen/CommandFlags.cpp index 677460a..8fc65d7 100644 --- a/llvm/lib/CodeGen/CommandFlags.cpp +++ b/llvm/lib/CodeGen/CommandFlags.cpp @@ -211,6 +211,9 @@ codegen::RegisterCodeGenFlags::RegisterCodeGenFlags() { "Disable frame pointer elimination"), clEnumValN(FramePointerKind::NonLeaf, "non-leaf", "Disable frame pointer elimination for non-leaf frame"), + clEnumValN(FramePointerKind::Reserved, "reserved", + "Enable frame pointer elimination, but reserve the frame " + "pointer register"), clEnumValN(FramePointerKind::None, "none", "Enable frame pointer elimination"))); CGBINDOPT(FramePointerUsage); @@ -693,6 +696,8 @@ void codegen::setFunctionAttributes(StringRef CPU, StringRef Features, NewAttrs.addAttribute("frame-pointer", "all"); else if (getFramePointerUsage() == FramePointerKind::NonLeaf) NewAttrs.addAttribute("frame-pointer", "non-leaf"); + else if (getFramePointerUsage() == FramePointerKind::Reserved) + NewAttrs.addAttribute("frame-pointer", "reserved"); else if (getFramePointerUsage() == FramePointerKind::None) NewAttrs.addAttribute("frame-pointer", "none"); } |