Home | History | Annotate | Line # | Download | only in sys
sbrk.S revision 1.7.2.1
      1  1.7.2.1  nathanw /*	$NetBSD: sbrk.S,v 1.7.2.1 2002/06/21 18:18:04 nathanw Exp $	*/
      2      1.1      eeh 
      3      1.1      eeh /*
      4      1.1      eeh  * Copyright (c) 1992, 1993
      5      1.1      eeh  *	The Regents of the University of California.  All rights reserved.
      6      1.1      eeh  *
      7      1.1      eeh  * This software was developed by the Computer Systems Engineering group
      8      1.1      eeh  * at Lawrence Berkeley Laboratory under DARPA contract BG 91-66 and
      9      1.1      eeh  * contributed to Berkeley.
     10      1.1      eeh  *
     11      1.1      eeh  * Redistribution and use in source and binary forms, with or without
     12      1.1      eeh  * modification, are permitted provided that the following conditions
     13      1.1      eeh  * are met:
     14      1.1      eeh  * 1. Redistributions of source code must retain the above copyright
     15      1.1      eeh  *    notice, this list of conditions and the following disclaimer.
     16      1.1      eeh  * 2. Redistributions in binary form must reproduce the above copyright
     17      1.1      eeh  *    notice, this list of conditions and the following disclaimer in the
     18      1.1      eeh  *    documentation and/or other materials provided with the distribution.
     19      1.1      eeh  * 3. All advertising materials mentioning features or use of this software
     20      1.1      eeh  *    must display the following acknowledgement:
     21      1.1      eeh  *	This product includes software developed by the University of
     22      1.1      eeh  *	California, Berkeley and its contributors.
     23      1.1      eeh  * 4. Neither the name of the University nor the names of its contributors
     24      1.1      eeh  *    may be used to endorse or promote products derived from this software
     25      1.1      eeh  *    without specific prior written permission.
     26      1.1      eeh  *
     27      1.1      eeh  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
     28      1.1      eeh  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
     29      1.1      eeh  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
     30      1.1      eeh  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
     31      1.1      eeh  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     32      1.1      eeh  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     33      1.1      eeh  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     34      1.1      eeh  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
     35      1.1      eeh  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     36      1.1      eeh  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     37      1.1      eeh  * SUCH DAMAGE.
     38      1.1      eeh  *
     39      1.1      eeh  * from: Header: sbrk.s,v 1.3 92/07/02 00:56:49 torek Exp
     40      1.1      eeh  */
     41      1.1      eeh 
     42      1.1      eeh #include <machine/asm.h>
     43      1.1      eeh #if defined(SYSLIBC_SCCS) && !defined(lint)
     44      1.1      eeh #if 0
     45      1.1      eeh 	.asciz "@(#)sbrk.s	8.1 (Berkeley) 6/4/93"
     46      1.1      eeh #else
     47  1.7.2.1  nathanw 	RCSID("$NetBSD: sbrk.S,v 1.7.2.1 2002/06/21 18:18:04 nathanw Exp $")
     48      1.1      eeh #endif
     49      1.1      eeh #endif /* SYSLIBC_SCCS and not lint */
     50      1.1      eeh 
     51      1.1      eeh #include "SYS.h"
     52      1.1      eeh 
     53      1.2   kleink 	.globl	_C_LABEL(__curbrk)
     54      1.3   kleink 	.globl	_C_LABEL(_end)
     55      1.1      eeh 
     56      1.4   kleink #ifdef WEAK_ALIAS
     57      1.4   kleink WEAK_ALIAS(sbrk, _sbrk)
     58      1.4   kleink #endif
     59      1.4   kleink 
     60      1.1      eeh 	.data
     61      1.6      eeh 	.align	8
     62      1.2   kleink _C_LABEL(__curbrk):
     63      1.6      eeh 	.xword	_C_LABEL(_end)
     64      1.1      eeh 	.text
     65      1.1      eeh 
     66      1.4   kleink ENTRY(_sbrk)
     67      1.1      eeh #ifdef PIC
     68  1.7.2.1  nathanw #ifdef BIGPIC
     69      1.1      eeh 	PIC_PROLOGUE(%o5,%o4)
     70      1.6      eeh 	set	_C_LABEL(__curbrk), %o3
     71      1.6      eeh 	ldx	[%o5 + %o3], %o2
     72      1.7  mycroft 	ldx	[%o2], %o3			/* %o3 = old break */
     73      1.7  mycroft 	add	%o3, %o0, %o4			/* %o4 = new break */
     74      1.7  mycroft 	mov	%o4, %o0			/* copy for syscall */
     75      1.1      eeh 	mov	SYS_break, %g1
     76      1.7  mycroft 	t	ST_SYSCALL			/* break(new_break) */
     77      1.7  mycroft 	bcc,a	1f				/* if success, */
     78      1.7  mycroft 	 mov	%o3, %o0			/*    set return value */
     79      1.1      eeh 	ERROR()
     80      1.1      eeh 1:
     81      1.7  mycroft 	retl					/* and update curbrk */
     82      1.6      eeh 	 stx	%o4, [%o2]
     83  1.7.2.1  nathanw #else
     84  1.7.2.1  nathanw 	PIC_PROLOGUE(%o5,%o4)
     85  1.7.2.1  nathanw 	ldx	[%o5 + _C_LABEL(__curbrk)], %o2
     86  1.7.2.1  nathanw 	ldx	[%o2], %o3			/* %o3 = old break */
     87  1.7.2.1  nathanw 	add	%o3, %o0, %o4			/* %o4 = new break */
     88  1.7.2.1  nathanw 	mov	%o4, %o0			/* copy for syscall */
     89  1.7.2.1  nathanw 	mov	SYS_break, %g1
     90  1.7.2.1  nathanw 	t	ST_SYSCALL			/* break(new_break) */
     91  1.7.2.1  nathanw 	bcc,a	1f				/* if success, */
     92  1.7.2.1  nathanw 	 mov	%o3, %o0			/*    set return value */
     93  1.7.2.1  nathanw 	ERROR()
     94  1.7.2.1  nathanw 1:
     95  1.7.2.1  nathanw 	retl					/* and update curbrk */
     96  1.7.2.1  nathanw 	 stx	%o4, [%o2]
     97  1.7.2.1  nathanw #endif
     98      1.1      eeh #else
     99      1.2   kleink 	sethi	%hi(_C_LABEL(__curbrk)), %o2
    100      1.7  mycroft 	ldx	[%o2 + %lo(_C_LABEL(__curbrk))], %o3	/* %o3 = old break */
    101      1.7  mycroft 	add	%o3, %o0, %o4			/* %o4 = new break */
    102      1.7  mycroft 	mov	%o4, %o0			/* copy for syscall */
    103      1.1      eeh 	mov	SYS_break, %g1
    104      1.7  mycroft 	t	ST_SYSCALL			/* break(new_break) */
    105      1.7  mycroft 	bcc,a	1f				/* if success, */
    106      1.7  mycroft 	 mov	%o3, %o0			/*    set return value */
    107      1.1      eeh 	ERROR()
    108      1.1      eeh 1:
    109      1.7  mycroft 	retl					/* and update curbrk */
    110      1.6      eeh 	 stx	%o4, [%o2 + %lo(_C_LABEL(__curbrk))]
    111      1.1      eeh #endif
    112