xref: /freebsd/contrib/llvm-project/compiler-rt/lib/orc/macho_tlv.x86-64.S (revision 349cc55c9796c4596a5b9904cd3281af295f878f)
1fe6060f1SDimitry Andric//===-- orc_rt_macho_tlv.x86-64.s -------------------------------*- ASM -*-===//
2fe6060f1SDimitry Andric//
3fe6060f1SDimitry Andric// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4fe6060f1SDimitry Andric// See https://llvm.org/LICENSE.txt for license information.
5fe6060f1SDimitry Andric// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6fe6060f1SDimitry Andric//
7fe6060f1SDimitry Andric//===----------------------------------------------------------------------===//
8fe6060f1SDimitry Andric//
9fe6060f1SDimitry Andric// This file is a part of the ORC runtime support library.
10fe6060f1SDimitry Andric//
11fe6060f1SDimitry Andric//===----------------------------------------------------------------------===//
12fe6060f1SDimitry Andric
13*349cc55cSDimitry Andric// The content of this file is x86_64-only
14*349cc55cSDimitry Andric#if defined(__x86_64__)
15*349cc55cSDimitry Andric
16fe6060f1SDimitry Andric#define REGISTER_SAVE_SPACE_SIZE        512
17fe6060f1SDimitry Andric
18fe6060f1SDimitry Andric        .text
19fe6060f1SDimitry Andric
20fe6060f1SDimitry Andric	// returns address of TLV in %rax, all other registers preserved
21fe6060f1SDimitry Andric	.globl ___orc_rt_macho_tlv_get_addr
22fe6060f1SDimitry Andric___orc_rt_macho_tlv_get_addr:
23fe6060f1SDimitry Andric        pushq           %rbp
24fe6060f1SDimitry Andric        movq            %rsp,        %rbp
25fe6060f1SDimitry Andric        subq            $REGISTER_SAVE_SPACE_SIZE, %rsp
26fe6060f1SDimitry Andric        movq            %rbx,     -8(%rbp)
27fe6060f1SDimitry Andric        movq            %rcx,    -16(%rbp)
28fe6060f1SDimitry Andric        movq            %rdx,    -24(%rbp)
29fe6060f1SDimitry Andric        movq            %rsi,    -32(%rbp)
30fe6060f1SDimitry Andric        movq            %rdi,    -40(%rbp)
31fe6060f1SDimitry Andric        movq            %r8,     -48(%rbp)
32fe6060f1SDimitry Andric        movq            %r9,     -56(%rbp)
33fe6060f1SDimitry Andric        movq            %r10,    -64(%rbp)
34fe6060f1SDimitry Andric        movq            %r11,    -72(%rbp)
35fe6060f1SDimitry Andric        movq            %r12,    -80(%rbp)
36fe6060f1SDimitry Andric        movq            %r13,    -88(%rbp)
37fe6060f1SDimitry Andric        movq            %r14,    -96(%rbp)
38fe6060f1SDimitry Andric        movq            %r15,   -104(%rbp)
39fe6060f1SDimitry Andric	movdqa          %xmm0,  -128(%rbp)
40fe6060f1SDimitry Andric	movdqa          %xmm1,  -144(%rbp)
41fe6060f1SDimitry Andric	movdqa          %xmm2,  -160(%rbp)
42fe6060f1SDimitry Andric	movdqa          %xmm3,  -176(%rbp)
43fe6060f1SDimitry Andric	movdqa          %xmm4,  -192(%rbp)
44fe6060f1SDimitry Andric	movdqa          %xmm5,  -208(%rbp)
45fe6060f1SDimitry Andric	movdqa          %xmm6,  -224(%rbp)
46fe6060f1SDimitry Andric	movdqa          %xmm7,  -240(%rbp)
47fe6060f1SDimitry Andric        call            ___orc_rt_macho_tlv_get_addr_impl
48fe6060f1SDimitry Andric        movq            -8(%rbp),       %rbx
49fe6060f1SDimitry Andric        movq            -16(%rbp),      %rcx
50fe6060f1SDimitry Andric        movq            -24(%rbp),      %rdx
51fe6060f1SDimitry Andric        movq            -32(%rbp),      %rsi
52fe6060f1SDimitry Andric        movq            -40(%rbp),      %rdi
53fe6060f1SDimitry Andric        movq            -48(%rbp),      %r8
54fe6060f1SDimitry Andric        movq            -56(%rbp),      %r9
55fe6060f1SDimitry Andric        movq            -64(%rbp),      %r10
56fe6060f1SDimitry Andric        movq            -72(%rbp),      %r11
57fe6060f1SDimitry Andric        movq            -80(%rbp),      %r12
58fe6060f1SDimitry Andric        movq            -88(%rbp),      %r13
59fe6060f1SDimitry Andric        movq            -96(%rbp),      %r14
60fe6060f1SDimitry Andric        movq            -104(%rbp),     %r15
61fe6060f1SDimitry Andric        movdqa          -128(%rbp),     %xmm0
62fe6060f1SDimitry Andric	movdqa          -144(%rbp),     %xmm1
63fe6060f1SDimitry Andric	movdqa          -160(%rbp),     %xmm2
64fe6060f1SDimitry Andric	movdqa          -176(%rbp),     %xmm3
65fe6060f1SDimitry Andric	movdqa          -192(%rbp),     %xmm4
66fe6060f1SDimitry Andric	movdqa          -208(%rbp),     %xmm5
67fe6060f1SDimitry Andric	movdqa          -224(%rbp),     %xmm6
68fe6060f1SDimitry Andric	movdqa          -240(%rbp),     %xmm7
69fe6060f1SDimitry Andric        addq            $REGISTER_SAVE_SPACE_SIZE, %rsp
70fe6060f1SDimitry Andric        popq            %rbp
71fe6060f1SDimitry Andric        ret
72*349cc55cSDimitry Andric
73*349cc55cSDimitry Andric#endif // defined(__x86_64__)
74