diff options
author | wolfbeast <mcwerewolf@wolfbeast.com> | 2019-03-30 20:03:33 +0100 |
---|---|---|
committer | wolfbeast <mcwerewolf@wolfbeast.com> | 2019-03-30 20:03:33 +0100 |
commit | 6b968b13d9cab02d8634facc87ae39e51dee4020 (patch) | |
tree | b84b2c122ce39dedbd8286bb6c7aba3aca51b964 /xpcom/reflect/xptcall/md/unix/xptcinvoke_asm_sparc_solaris_GCC3.s | |
parent | 25779d371c571e4f51792af3e3c5588b3186e934 (diff) | |
download | UXP-6b968b13d9cab02d8634facc87ae39e51dee4020.tar UXP-6b968b13d9cab02d8634facc87ae39e51dee4020.tar.gz UXP-6b968b13d9cab02d8634facc87ae39e51dee4020.tar.lz UXP-6b968b13d9cab02d8634facc87ae39e51dee4020.tar.xz UXP-6b968b13d9cab02d8634facc87ae39e51dee4020.zip |
Issue #187: Remove solaris 1st party code OS checks.
Diffstat (limited to 'xpcom/reflect/xptcall/md/unix/xptcinvoke_asm_sparc_solaris_GCC3.s')
-rw-r--r-- | xpcom/reflect/xptcall/md/unix/xptcinvoke_asm_sparc_solaris_GCC3.s | 52 |
1 files changed, 0 insertions, 52 deletions
diff --git a/xpcom/reflect/xptcall/md/unix/xptcinvoke_asm_sparc_solaris_GCC3.s b/xpcom/reflect/xptcall/md/unix/xptcinvoke_asm_sparc_solaris_GCC3.s deleted file mode 100644 index 54adcd147..000000000 --- a/xpcom/reflect/xptcall/md/unix/xptcinvoke_asm_sparc_solaris_GCC3.s +++ /dev/null @@ -1,52 +0,0 @@ -/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 4 -*- - * - * This Source Code Form is subject to the terms of the Mozilla Public - * License, v. 2.0. If a copy of the MPL was not distributed with this - * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ - -/* - * Platform specific code to invoke XPCOM methods on native objects for - * solaris/sparc with gcc 3 ABI. - */ - .global NS_InvokeByIndex -/* - * NS_InvokeByIndex(nsISupports* that, uint32_t methodIndex, - * uint32_t paramCount, nsXPTCVariant* params); - */ -NS_InvokeByIndex: - save %sp,-(64 + 32),%sp ! room for the register window and - ! struct pointer, rounded up to 0 % 32 - mov %i2,%o0 ! paramCount - call invoke_count_words ! returns the required stack size in %o0 - mov %i3,%o1 ! params - - sll %o0,2,%l0 ! number of bytes - sub %sp,%l0,%sp ! create the additional stack space - - mov %sp,%o0 ! pointer for copied args - add %o0,72,%o0 ! step past the register window, the - ! struct result pointer and the 'this' slot - mov %i2,%o1 ! paramCount - call invoke_copy_to_stack - mov %i3,%o2 ! params -! -! calculate the target address from the vtable -! - ld [%i0],%l1 ! *that --> vTable - sll %i1,2,%i1 ! multiply index by 4 - add %i1,%l1,%l1 ! l1 now points to vTable entry - ld [%l1],%l0 ! target address - -.L5: ld [%sp + 88],%o5 -.L4: ld [%sp + 84],%o4 -.L3: ld [%sp + 80],%o3 -.L2: ld [%sp + 76],%o2 -.L1: ld [%sp + 72],%o1 -.L0: - jmpl %l0,%o7 ! call the routine -! always have a 'this', from the incoming 'that' - mov %i0,%o0 - - mov %o0,%i0 ! propagate return value - ret - restore |