1 1.11 nakayama /* $NetBSD: sbrk.S,v 1.11 2013/09/14 05:38:00 nakayama 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.11 nakayama RCSID("$NetBSD: sbrk.S,v 1.11 2013/09/14 05:38:00 nakayama 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.10 joerg #if __PIC__ - 0 >= 2 63 1.10 joerg 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.10 joerg 80 1.11 nakayama #elif __PIC__ - 0 >= 1 81 1.10 joerg 82 1.10 joerg 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.10 joerg 97 1.1 eeh #else 98 1.10 joerg 99 1.10 joerg 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.10 joerg 113 1.10 joerg #endif /* __PIC__ */ 114