[PATCH] D124836: [AArch64] Add support for -fzero-call-used-regs

Bill Wendling via Phabricator via llvm-commits llvm-commits at lists.llvm.org
Wed May 4 15:42:24 PDT 2022


void added inline comments.


================
Comment at: llvm/lib/Target/AArch64/AArch64RegisterInfo.td:1398
+                                 (sequence "W%u", 0, 7))>;
+def FPR8_ARG : RegisterClass<"AArch64", [untyped], 8, (trunc FPR8, 7)> {
+  let Size = 8;
----------------
sdesmalen wrote:
> Should this feature/attribute work with other calling conventions? If so, then it's probably best not to hard-code these values here, but rather to get them from the chosen calling convention for that particular function. The supported calling conventions are defined in AArch64CallingConvention.td.
> 
> For example, you could iterate all registers in GPR64/FPR128/ZPR/PPR register classes and zero their values if they are not marked as callee saved. You can query this information from the call by looking at it's callee-saved regmask (see for example `CSR_AArch64_AAPCS_RegMask` to see how those are defined defined).
Ideally it could be retrieved from the `*CallingConvention.td` files, but in reality it's difficult because those files have a lot of `CCIf...<>` constructs in them, making a simple query complex.

I don't know about the `*_RegMask` thing. Could you explain what it is and how it works?


Repository:
  rG LLVM Github Monorepo

CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D124836/new/

https://reviews.llvm.org/D124836



More information about the llvm-commits mailing list