Add support for nest attribute to AArch64 backend
authorRenato Golin <renato.golin@linaro.org>
Thu, 9 Jul 2015 10:18:02 +0000 (10:18 +0000)
committerRenato Golin <renato.golin@linaro.org>
Thu, 9 Jul 2015 10:18:02 +0000 (10:18 +0000)
commit17d4efe7c1a271ca216008fe0f6598e8f96dfe30
tree3eecaec0f2ec7620337ab08f8d761f355422d114
parentb6b0ddfc95f36aa6d511d9a6383c285fe369e808
Add support for nest attribute to AArch64 backend

The nest attribute is currently supported on the x86 (32-bit) and x86-64
backends, but not on ARM (32-bit) or AArch64. This patch adds support for
nest to the AArch64 backend.

Register x18 is used by GCC for this purpose and hence is used here.
As discussed on the GCC mailing list the register choice is an ABI issue
and so choosing the same register as GCC means __builtin_call_with_static_chain
is compatible.

Patch by Stephen Cross.

llvm-svn: 241794
llvm/lib/Target/AArch64/AArch64CallingConvention.td