brk.S revision 1.12.62.1 1 1.12.62.1 tls /* $NetBSD: brk.S,v 1.12.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.11 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: brk.s,v 1.3 92/06/25 12:56:05 mccanne 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 "@(#)brk.s 8.1 (Berkeley) 6/4/93"
42 1.1 eeh #else
43 1.12.62.1 tls RCSID("$NetBSD: brk.S,v 1.12.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.2 kleink .globl _C_LABEL(__minbrk)
51 1.3 kleink .globl _C_LABEL(_end)
52 1.1 eeh
53 1.4 kleink #ifdef WEAK_ALIAS
54 1.4 kleink WEAK_ALIAS(brk, _brk)
55 1.4 kleink #endif
56 1.4 kleink
57 1.1 eeh .data
58 1.6 eeh .align 8
59 1.2 kleink _C_LABEL(__minbrk):
60 1.8 mycroft .xword _C_LABEL(_end) /* lower brk limit; also for gmon code */
61 1.1 eeh .text
62 1.1 eeh
63 1.12.62.1 tls #if __PIC__ - 0 >= 2
64 1.12.62.1 tls
65 1.4 kleink ENTRY(_brk)
66 1.1 eeh PIC_PROLOGUE(%o5,%o4)
67 1.7 eeh set _C_LABEL(__minbrk), %o4
68 1.7 eeh ldx [%o5 + %o4], %o4
69 1.8 mycroft ldx [%o4], %o1 /* %o1 = minbrk */
70 1.8 mycroft cmp %o1, %o0 /* if (minbrk > %o0) */
71 1.12 martin movgu %xcc, %o1, %o0 /* %o0 = minbrk */
72 1.8 mycroft mov %o0, %o2 /* save argument to syscall */
73 1.1 eeh mov SYS_break, %g1
74 1.1 eeh t ST_SYSCALL
75 1.6 eeh set _C_LABEL(__curbrk), %o3
76 1.7 eeh bcc,a,pt %icc, 1f
77 1.7 eeh ldx [%o5 + %o3], %o4
78 1.1 eeh ERROR()
79 1.1 eeh 1:
80 1.8 mycroft retl /* success, return 0 & record new break */
81 1.9 mycroft stx %o2, [%o4]
82 1.12.62.1 tls
83 1.12.62.1 tls #elif __PIC__ - 0 >= 1
84 1.12.62.1 tls
85 1.12.62.1 tls ENTRY(_brk)
86 1.10 eeh PIC_PROLOGUE(%o5,%o4)
87 1.10 eeh ldx [%o5 + _C_LABEL(__minbrk)], %o4
88 1.10 eeh ldx [%o4], %o1 /* %o1 = minbrk */
89 1.10 eeh cmp %o1, %o0 /* if (minbrk > %o0) */
90 1.12 martin movgu %xcc, %o1, %o0 /* %o0 = minbrk */
91 1.10 eeh mov %o0, %o2 /* save argument to syscall */
92 1.10 eeh mov SYS_break, %g1
93 1.10 eeh t ST_SYSCALL
94 1.10 eeh bcc,a,pt %icc, 1f
95 1.10 eeh ldx [%o5 + _C_LABEL(__curbrk)], %o4
96 1.10 eeh ERROR()
97 1.10 eeh 1:
98 1.10 eeh retl /* success, return 0 & record new break */
99 1.10 eeh stx %o2, [%o4]
100 1.12.62.1 tls
101 1.1 eeh #else
102 1.12.62.1 tls
103 1.12.62.1 tls ENTRY(_brk)
104 1.8 mycroft sethi %hi(_C_LABEL(__minbrk)), %o1 /* %o1 = minbrk */
105 1.6 eeh ldx [%o1 + %lo(_C_LABEL(__minbrk))], %o1
106 1.8 mycroft cmp %o1, %o0 /* if (minbrk > %o0) */
107 1.12 martin movgu %xcc, %o1, %o0 /* %o0 = minbrk */
108 1.8 mycroft mov %o0, %o2 /* save argument to syscall */
109 1.1 eeh mov SYS_break, %g1
110 1.1 eeh t ST_SYSCALL
111 1.7 eeh bcc,a,pt %icc,1f
112 1.2 kleink sethi %hi(_C_LABEL(__curbrk)), %g1
113 1.1 eeh ERROR()
114 1.1 eeh 1:
115 1.8 mycroft retl /* success, return 0 & record new break */
116 1.6 eeh stx %o2, [%g1 + %lo(_C_LABEL(__curbrk))]
117 1.12.62.1 tls
118 1.1 eeh #endif
119