Home | History | Annotate | Line # | Download | only in sys
sbrk.S revision 1.9.62.1
      1  1.9.62.1      tls /*	$NetBSD: sbrk.S,v 1.9.62.1 2014/08/20 00:02:12 tls 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.9      agc  * 3. Neither the name of the University nor the names of its contributors
     20       1.1      eeh  *    may be used to endorse or promote products derived from this software
     21       1.1      eeh  *    without specific prior written permission.
     22       1.1      eeh  *
     23       1.1      eeh  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
     24       1.1      eeh  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
     25       1.1      eeh  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
     26       1.1      eeh  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
     27       1.1      eeh  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     28       1.1      eeh  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     29       1.1      eeh  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     30       1.1      eeh  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
     31       1.1      eeh  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     32       1.1      eeh  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     33       1.1      eeh  * SUCH DAMAGE.
     34       1.1      eeh  *
     35       1.1      eeh  * from: Header: sbrk.s,v 1.3 92/07/02 00:56:49 torek Exp
     36       1.1      eeh  */
     37       1.1      eeh 
     38       1.1      eeh #include <machine/asm.h>
     39       1.1      eeh #if defined(SYSLIBC_SCCS) && !defined(lint)
     40       1.1      eeh #if 0
     41       1.1      eeh 	.asciz "@(#)sbrk.s	8.1 (Berkeley) 6/4/93"
     42       1.1      eeh #else
     43  1.9.62.1      tls 	RCSID("$NetBSD: sbrk.S,v 1.9.62.1 2014/08/20 00:02:12 tls Exp $")
     44       1.1      eeh #endif
     45       1.1      eeh #endif /* SYSLIBC_SCCS and not lint */
     46       1.1      eeh 
     47       1.1      eeh #include "SYS.h"
     48       1.1      eeh 
     49       1.2   kleink 	.globl	_C_LABEL(__curbrk)
     50       1.3   kleink 	.globl	_C_LABEL(_end)
     51       1.1      eeh 
     52       1.4   kleink #ifdef WEAK_ALIAS
     53       1.4   kleink WEAK_ALIAS(sbrk, _sbrk)
     54       1.4   kleink #endif
     55       1.4   kleink 
     56       1.1      eeh 	.data
     57       1.6      eeh 	.align	8
     58       1.2   kleink _C_LABEL(__curbrk):
     59       1.6      eeh 	.xword	_C_LABEL(_end)
     60       1.1      eeh 	.text
     61       1.1      eeh 
     62  1.9.62.1      tls #if __PIC__ - 0 >= 2
     63  1.9.62.1      tls 
     64       1.4   kleink ENTRY(_sbrk)
     65       1.1      eeh 	PIC_PROLOGUE(%o5,%o4)
     66       1.6      eeh 	set	_C_LABEL(__curbrk), %o3
     67       1.6      eeh 	ldx	[%o5 + %o3], %o2
     68       1.7  mycroft 	ldx	[%o2], %o3			/* %o3 = old break */
     69       1.7  mycroft 	add	%o3, %o0, %o4			/* %o4 = new break */
     70       1.7  mycroft 	mov	%o4, %o0			/* copy for syscall */
     71       1.1      eeh 	mov	SYS_break, %g1
     72       1.7  mycroft 	t	ST_SYSCALL			/* break(new_break) */
     73       1.7  mycroft 	bcc,a	1f				/* if success, */
     74       1.7  mycroft 	 mov	%o3, %o0			/*    set return value */
     75       1.1      eeh 	ERROR()
     76       1.1      eeh 1:
     77       1.7  mycroft 	retl					/* and update curbrk */
     78       1.6      eeh 	 stx	%o4, [%o2]
     79  1.9.62.1      tls 
     80  1.9.62.1      tls #elif __PIC__ - 0 >= 1
     81  1.9.62.1      tls 
     82  1.9.62.1      tls ENTRY(_sbrk)
     83       1.8      eeh 	PIC_PROLOGUE(%o5,%o4)
     84       1.8      eeh 	ldx	[%o5 + _C_LABEL(__curbrk)], %o2
     85       1.8      eeh 	ldx	[%o2], %o3			/* %o3 = old break */
     86       1.8      eeh 	add	%o3, %o0, %o4			/* %o4 = new break */
     87       1.8      eeh 	mov	%o4, %o0			/* copy for syscall */
     88       1.8      eeh 	mov	SYS_break, %g1
     89       1.8      eeh 	t	ST_SYSCALL			/* break(new_break) */
     90       1.8      eeh 	bcc,a	1f				/* if success, */
     91       1.8      eeh 	 mov	%o3, %o0			/*    set return value */
     92       1.8      eeh 	ERROR()
     93       1.8      eeh 1:
     94       1.8      eeh 	retl					/* and update curbrk */
     95       1.8      eeh 	 stx	%o4, [%o2]
     96  1.9.62.1      tls 
     97       1.1      eeh #else
     98  1.9.62.1      tls 
     99  1.9.62.1      tls ENTRY(_sbrk)
    100       1.2   kleink 	sethi	%hi(_C_LABEL(__curbrk)), %o2
    101       1.7  mycroft 	ldx	[%o2 + %lo(_C_LABEL(__curbrk))], %o3	/* %o3 = old break */
    102       1.7  mycroft 	add	%o3, %o0, %o4			/* %o4 = new break */
    103       1.7  mycroft 	mov	%o4, %o0			/* copy for syscall */
    104       1.1      eeh 	mov	SYS_break, %g1
    105       1.7  mycroft 	t	ST_SYSCALL			/* break(new_break) */
    106       1.7  mycroft 	bcc,a	1f				/* if success, */
    107       1.7  mycroft 	 mov	%o3, %o0			/*    set return value */
    108       1.1      eeh 	ERROR()
    109       1.1      eeh 1:
    110       1.7  mycroft 	retl					/* and update curbrk */
    111       1.6      eeh 	 stx	%o4, [%o2 + %lo(_C_LABEL(__curbrk))]
    112  1.9.62.1      tls 
    113  1.9.62.1      tls #endif /* __PIC__ */
    114