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