diff options
| author | stevel@tonic-gate <none@none> | 2005-06-14 00:00:00 -0700 | 
|---|---|---|
| committer | stevel@tonic-gate <none@none> | 2005-06-14 00:00:00 -0700 | 
| commit | 7c478bd95313f5f23a4c958a745db2134aa03244 (patch) | |
| tree | c871e58545497667cbb4b0a4f2daf204743e1fe7 /usr/src/lib/libldap5/sources/pr/md | |
| download | illumos-joyent-7c478bd95313f5f23a4c958a745db2134aa03244.tar.gz | |
OpenSolaris Launch
Diffstat (limited to 'usr/src/lib/libldap5/sources/pr/md')
| -rw-r--r-- | usr/src/lib/libldap5/sources/pr/md/unix/os_SunOS_amd64.s | 242 | 
1 files changed, 242 insertions, 0 deletions
| diff --git a/usr/src/lib/libldap5/sources/pr/md/unix/os_SunOS_amd64.s b/usr/src/lib/libldap5/sources/pr/md/unix/os_SunOS_amd64.s new file mode 100644 index 0000000000..62a880445a --- /dev/null +++ b/usr/src/lib/libldap5/sources/pr/md/unix/os_SunOS_amd64.s @@ -0,0 +1,242 @@ +/ +/ Copyright 2004 Sun Microsystems, Inc.  All rights reserved. +/ Use is subject to license terms. +/ + +/ XX64 - fix me - this is a copy of the x86 version + +        .ident	"%Z%%M%	%I%	%E% SMI" + +/ -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 2 -*- +/  +/ The contents of this file are subject to the Mozilla Public +/ License Version 1.1 (the "License"); you may not use this file +/ except in compliance with the License. You may obtain a copy of +/ the License at http://www.mozilla.org/MPL/ +/  +/ Software distributed under the License is distributed on an "AS +/ IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or +/ implied. See the License for the specific language governing +/ rights and limitations under the License. +/  +/ The Original Code is the Netscape Portable Runtime (NSPR). +/  +/ The Initial Developer of the Original Code is Netscape +/ Communications Corporation.  Portions created by Netscape are  +/ Copyright (C) 1998-2000 Netscape Communications Corporation.  All +/ Rights Reserved. +/  +/ Contributor(s): +/  +/ Alternatively, the contents of this file may be used under the +/ terms of the GNU General Public License Version 2 or later (the +/ "GPL"), in which case the provisions of the GPL are applicable  +/ instead of those above.  If you wish to allow use of your  +/ version of this file only under the terms of the GPL and not to +/ allow others to use your version of this file under the MPL, +/ indicate your decision by deleting the provisions above and +/ replace them with the notice and other provisions required by +/ the GPL.  If you do not delete the provisions above, a recipient +/ may use your version of this file under either the MPL or the +/ GPL. +/  + +	.text + +	.globl	getedi +getedi: +	movl	%edi,%eax +	ret +	.type	getedi,@function +	.size	getedi,.-getedi +  +	.globl	setedi +setedi: +	movl	4(%rsp),%edi +	ret +	.type	setedi,@function +	.size	setedi,.-setedi + +	.globl	__MD_FlushRegisterWindows +	.globl _MD_FlushRegisterWindows + +__MD_FlushRegisterWindows: +_MD_FlushRegisterWindows: + +	ret + +/ +/ sol_getsp() +/ +/ Return the current sp (for debugging) +/ +	.globl sol_getsp +sol_getsp: +	movl	%esp, %eax +	ret + +/ +/ sol_curthread() +/ +/ Return a unique identifier for the currently active thread. +/ +	.globl sol_curthread +sol_curthread: +	movl	%ecx, %eax +	ret + +/ PRInt32 _MD_AtomicIncrement(PRInt32 *val) +/ +/ Atomically increment the integer pointed to by 'val' and return +/ the result of the increment. +/ +    .text +    .globl _MD_AtomicIncrement +    .align 4 +_MD_AtomicIncrement: +    movl 4(%rsp), %ecx +    movl $1, %eax +    lock +    xaddl %eax, (%rcx) +    incl %eax +    ret + +/ PRInt32 _MD_AtomicDecrement(PRInt32 *val) +/ +/ Atomically decrement the integer pointed to by 'val' and return +/ the result of the decrement. +/ +    .text +    .globl _MD_AtomicDecrement +    .align 4 +_MD_AtomicDecrement: +    movl 4(%rsp), %ecx +    movl $-1, %eax +    lock +    xaddl %eax, (%rcx) +    decl %eax +    ret + +/ PRInt32 _MD_AtomicSet(PRInt32 *val, PRInt32 newval) +/ +/ Atomically set the integer pointed to by 'val' to the new +/ value 'newval' and return the old value. +/ +/ An alternative implementation: +/   .text +/   .globl _MD_AtomicSet +/   .align 4 +/_MD_AtomicSet: +/   movl 4(%rsp), %ecx +/   movl 8(%rsp), %edx +/   movl (%rcx), %eax +/retry: +/   lock +/   cmpxchgl %edx, (%rcx) +/   jne retry +/   ret +/ +    .text +    .globl _MD_AtomicSet +    .align 4 +_MD_AtomicSet: +    movl 4(%rsp), %ecx +    movl 8(%rsp), %eax +    lock +    xchgl %eax, (%rcx) +    ret + +/ PRInt32 _MD_AtomicAdd(PRInt32 *ptr, PRInt32 val) +/ +/ Atomically add 'val' to the integer pointed to by 'ptr' +/ and return the result of the addition. +/ +    .text +    .globl _MD_AtomicAdd +    .align 4 +_MD_AtomicAdd: +    movl 4(%rsp), %ecx +    movl 8(%rsp), %eax +    movl %eax, %edx +    lock +    xaddl %eax, (%rcx) +    addl %edx, %eax +    ret + +/ +/ PR_StackPush(listp, elementp) +/ +/ Atomically push ElementP onto linked list ListP. +/ +	.text +	.globl	PR_StackPush +	.align	4 +PR_StackPush: +	movl	4(%rsp), %ecx +	movl	$-1,%eax +pulock: +/ Already locked? +	cmpl	%eax,(%rcx) +	je	pulock + +/ Attempt to lock it +	lock +	xchgl	%eax, (%rcx) + +/ Did we set the lock? +	cmpl	$-1, %eax +	je	pulock + +/ We now have the lock.  Update pointers +	movl	8(%rsp), %edx +	movl	%eax, (%rdx) +	movl	%edx, (%rcx) + +/ Done +	ret + + +/ +/ elementp = PR_StackPop(listp) +/ +/ Atomically pop ElementP off linked list ListP +/ +	.text +	.globl	PR_StackPop +	.align	4 +PR_StackPop: +	movl	4(%rsp), %ecx +	movl	$-1, %eax +polock: +/ Already locked? +	cmpl	%eax, (%rcx) +	je	polock + +/ Attempt to lock it +	lock +	xchgl	%eax, (%rcx) + +/ Did we set the lock? +	cmpl	$-1, %eax +	je	polock + +/ We set the lock so now update pointers + +/ Was it empty? +	movl	$0, %edx +	cmpl	%eax,%edx +	je	empty + +/ Get element "next" pointer +	movl	(%rax), %edx + +/ Write NULL to the element "next" pointer +	movl	$0, (%rax) + +empty: +/ Put elements previous "next" value into listp +/ NOTE: This also unlocks the listp +	movl	%edx, (%rcx) + +/ Return previous listp value (already in eax) +	ret | 
