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