annotate src/alloca.s @ 28285:c54d62415e91

Changed the type of parameter passed to the function defined by `quickurl-format-function'. Before only the text of the URL was passed. Now the whole URL structure is passed and the function is responsible for extracting the parts it requires. Changed the default of `quickurl-format-function' accordingly. (quickurl-insert): Changed the `funcall' of `quickurl-format-function' to match the above change. (quickurl-list-insert): Changed the `url' case so that it makes use of `quickurl-format-function', previous to this the format was hard wired.
author Gerd Moellmann <gerd@gnu.org>
date Thu, 23 Mar 2000 13:53:14 +0000
parents 6e7bb4bd5010
children 23a1cea22d13
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
6437
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1 /* `alloca' standard 4.2 subroutine for 68000's and 16000's and others.
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2 Also has _setjmp and _longjmp for pyramids.
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
3 Copyright (C) 1985, 1986, 1988 Free Software Foundation, Inc.
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
4
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
5 This program is free software; you can redistribute it and/or modify it
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
6 under the terms of the GNU General Public License as published by the
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
7 Free Software Foundation; either version 2, or (at your option) any
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
8 later version.
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
9
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
10 This program is distributed in the hope that it will be useful,
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
13 GNU General Public License for more details.
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
14
14414
6e7bb4bd5010 Update FSF address in comment.
Karl Heuer <kwzh@gnu.org>
parents: 13691
diff changeset
15 You should have received a copy of the GNU General Public License along
6e7bb4bd5010 Update FSF address in comment.
Karl Heuer <kwzh@gnu.org>
parents: 13691
diff changeset
16 with this program; if not, write to the Free Software Foundation, Inc.,
6e7bb4bd5010 Update FSF address in comment.
Karl Heuer <kwzh@gnu.org>
parents: 13691
diff changeset
17 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */
6437
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
18
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
19 /* Both 68000 systems I have run this on have had broken versions of alloca.
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
20 Also, I am told that non-berkeley systems do not have it at all.
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
21 So replace whatever system-provided alloca there may be
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
22 on all 68000 systems. */
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
23
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
24 #define NOT_C_CODE
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
25 #ifdef emacs
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
26 #include <config.h>
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
27 #else
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
28 #include "config.h"
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
29 #endif
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
30
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
31 #ifndef HAVE_ALLOCA /* define this to use system's alloca */
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
32
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
33 #ifndef hp9000s300
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
34 #ifndef m68k
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
35 #ifndef m68000
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
36 #ifndef WICAT
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
37 #ifndef ns32000
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
38 #ifndef ns16000
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
39 #ifndef sequent
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
40 #ifndef pyramid
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
41 #ifndef ATT3B5
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
42 #ifndef XENIX
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
43 you
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
44 lose!!
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
45 #endif /* XENIX */
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
46 #endif /* ATT3B5 */
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
47 #endif /* pyramid */
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
48 #endif /* sequent */
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
49 #endif /* ns16000 */
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
50 #endif /* ns32000 */
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
51 #endif /* WICAT */
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
52 #endif /* m68000 */
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
53 #endif /* m68k */
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
54 #endif /* hp9000s300 */
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
55
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
56
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
57 #ifdef hp9000s300
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
58 #ifdef OLD_HP_ASSEMBLER
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
59 data
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
60 text
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
61 globl _alloca
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
62 _alloca
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
63 move.l (sp)+,a0 ; pop return addr from top of stack
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
64 move.l (sp)+,d0 ; pop size in bytes from top of stack
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
65 add.l #ROUND,d0 ; round size up to long word
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
66 and.l #MASK,d0 ; mask out lower two bits of size
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
67 sub.l d0,sp ; allocate by moving stack pointer
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
68 tst.b PROBE(sp) ; stack probe to allocate pages
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
69 move.l sp,d0 ; return pointer
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
70 add.l #-4,sp ; new top of stack
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
71 jmp (a0) ; not a normal return
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
72 MASK equ -4 ; Longword alignment
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
73 ROUND equ 3 ; ditto
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
74 PROBE equ -128 ; safety buffer for C compiler scratch
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
75 data
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
76 #else /* new hp assembler syntax */
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
77 /*
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
78 The new compiler does "move.m <registers> (%sp)" to save registers,
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
79 so we must copy the saved registers when we mung the sp.
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
80 The old compiler did "move.m <register> <offset>(%a6)", which
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
81 gave us no trouble
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
82 */
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
83 text
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
84 set PROBE,-128 # safety for C frame temporaries
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
85 set MAXREG,22 # d2-d7, a2-a5, fp2-fp7 may have been saved
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
86 global _alloca
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
87 _alloca:
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
88 mov.l (%sp)+,%a0 # return address
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
89 mov.l (%sp)+,%d0 # number of bytes to allocate
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
90 mov.l %sp,%a1 # save old sp for register copy
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
91 mov.l %sp,%d1 # compute new sp
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
92 sub.l %d0,%d1 # space requested
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
93 and.l &-4,%d1 # round down to longword
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
94 sub.l &MAXREG*4,%d1 # space for saving registers
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
95 mov.l %d1,%sp # save new value of sp
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
96 tst.b PROBE(%sp) # create pages (sigh)
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
97 mov.l %a2,%d1 # save reg a2
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
98 mov.l %sp,%a2
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
99 move.w &MAXREG-1,%d0
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
100 copy_regs_loop: /* save caller's saved registers */
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
101 mov.l (%a1)+,(%a2)+
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
102 dbra %d0,copy_regs_loop
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
103 mov.l %a2,%d0 # return value
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
104 mov.l %d1,%a2 # restore a2
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
105 add.l &-4,%sp # adjust tos
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
106 jmp (%a0) # rts
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
107 #endif /* new hp assembler */
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
108 #else
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
109 #ifdef m68k /* SGS assembler totally different */
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
110 file "alloca.s"
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
111 global alloca
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
112 alloca:
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
113 #ifdef MOTOROLA_DELTA
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
114 /* slightly modified version of alloca to motorola sysV/68 pcc - based
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
115 compiler.
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
116 this compiler saves used registers relative to %sp instead of %fp.
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
117 alright, just make new copy of saved register set whenever we allocate
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
118 new space from stack..
6815
06174c615055 entered into RCS
Richard M. Stallman <rms@gnu.org>
parents: 6437
diff changeset
119 this is true at last until SVR3V7 . bug has reported to Motorola. */
6437
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
120 set MAXREG,10 # max no of registers to save (d2-d7, a2-a5)
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
121 mov.l (%sp)+,%a1 # pop return addr from top of stack
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
122 mov.l (%sp)+,%d0 # pop size in bytes from top of stack
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
123 mov.l %sp,%a0 # save stack pointer for register copy
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
124 addq.l &3,%d0 # round size up to long word
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
125 andi.l &-4,%d0 # mask out lower two bits of size
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
126 mov.l %sp,%d1 # compute new value of sp to d1
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
127 sub.l %d0,%d1 # pseudo-allocate by moving stack pointer
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
128 sub.l &MAXREG*4,%d1 # allocate more space for saved regs.
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
129 mov.l %d1,%sp # actual allocation.
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
130 move.w &MAXREG-1,%d0 # d0 counts saved regs.
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
131 mov.l %a2,%d1 # preserve a2.
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
132 mov.l %sp,%a2 # make pointer to new reg save area.
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
133 copy_regs_loop: # copy stuff from old save area.
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
134 mov.l (%a0)+,(%a2)+ # save saved register
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
135 dbra %d0,copy_regs_loop
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
136 mov.l %a2,%a0 # now a2 is start of allocated space.
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
137 mov.l %a2,%d0 # return it in both a0 and d0 to play safe.
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
138 mov.l %d1,%a2 # restore a2.
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
139 subq.l &4,%sp # new top of stack
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
140 jmp (%a1) # far below normal return
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
141 #else /* not MOTOROLA_DELTA */
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
142 mov.l (%sp)+,%a1 # pop return addr from top of stack
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
143 mov.l (%sp)+,%d0 # pop size in bytes from top of stack
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
144 add.l &R%1,%d0 # round size up to long word
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
145 and.l &-4,%d0 # mask out lower two bits of size
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
146 sub.l %d0,%sp # allocate by moving stack pointer
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
147 tst.b P%1(%sp) # stack probe to allocate pages
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
148 mov.l %sp,%a0 # return pointer as pointer
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
149 mov.l %sp,%d0 # return pointer as int to avoid disaster
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
150 add.l &-4,%sp # new top of stack
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
151 jmp (%a1) # not a normal return
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
152 set S%1,64 # safety factor for C compiler scratch
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
153 set R%1,3+S%1 # add to size for rounding
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
154 set P%1,-132 # probe this far below current top of stack
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
155 #endif /* not MOTOROLA_DELTA */
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
156
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
157 #else /* not m68k */
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
158
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
159 #ifdef m68000
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
160
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
161 #ifdef WICAT
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
162 /*
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
163 * Registers are saved after the corresponding link so we have to explicitly
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
164 * move them to the top of the stack where they are expected to be.
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
165 * Since we do not know how many registers were saved in the calling function
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
166 * we must assume the maximum possible (d2-d7,a2-a5). Hence, we end up
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
167 * wasting some space on the stack.
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
168 *
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
169 * The large probe (tst.b) attempts to make up for the fact that we have
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
170 * potentially used up the space that the caller probed for its own needs.
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
171 */
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
172 .procss m0
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
173 .config "68000 1"
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
174 .module _alloca
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
175 MAXREG: .const 10
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
176 .sect text
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
177 .global _alloca
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
178 _alloca:
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
179 move.l (sp)+,a1 ; pop return address
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
180 move.l (sp)+,d0 ; pop allocation size
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
181 move.l sp,d1 ; get current SP value
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
182 sub.l d0,d1 ; adjust to reflect required size...
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
183 sub.l #MAXREG*4,d1 ; ...and space needed for registers
13691
d1633aedb9bd Fix misspelled comment.
Paul Eggert <eggert@twinsun.com>
parents: 6815
diff changeset
184 and.l #-4,d1 ; backup to longword boundary
6437
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
185 move.l sp,a0 ; save old SP value for register copy
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
186 move.l d1,sp ; set the new SP value
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
187 tst.b -4096(sp) ; grab an extra page (to cover caller)
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
188 move.l a2,d1 ; save callers register
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
189 move.l sp,a2
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
190 move.w #MAXREG-1,d0 ; # of longwords to copy
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
191 loop: move.l (a0)+,(a2)+ ; copy registers...
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
192 dbra d0,loop ; ...til there are no more
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
193 move.l a2,d0 ; end of register area is addr for new space
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
194 move.l d1,a2 ; restore saved a2.
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
195 addq.l #4,sp ; caller will increment sp by 4 after return.
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
196 move.l d0,a0 ; return value in both a0 and d0.
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
197 jmp (a1)
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
198 .end _alloca
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
199 #else
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
200
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
201 /* Some systems want the _, some do not. Win with both kinds. */
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
202 .globl _alloca
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
203 _alloca:
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
204 .globl alloca
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
205 alloca:
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
206 movl sp@+,a0
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
207 movl a7,d0
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
208 subl sp@,d0
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
209 andl #~3,d0
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
210 movl d0,sp
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
211 tstb sp@(0) /* Make stack pages exist */
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
212 /* Needed on certain systems
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
213 that lack true demand paging */
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
214 addql #4,d0
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
215 jmp a0@
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
216
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
217 #endif /* not WICAT */
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
218 #endif /* m68000 */
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
219 #endif /* not m68k */
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
220 #endif /* not hp9000s300 */
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
221
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
222 #if defined (ns16000) || defined (ns32000)
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
223
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
224 .text
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
225 .align 2
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
226 /* Some systems want the _, some do not. Win with both kinds. */
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
227 .globl _alloca
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
228 _alloca:
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
229 .globl alloca
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
230 alloca:
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
231
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
232 /* Two different assembler syntaxes are used for the same code
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
233 on different systems. */
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
234
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
235 #ifdef sequent
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
236 #define IM
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
237 #define REGISTER(x) x
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
238 #else
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
239 #ifdef NS5 /* ns SysV assembler */
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
240 #define IM $
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
241 #define REGISTER(x) x
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
242 #else
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
243 #define IM $
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
244 #define REGISTER(x) 0(x)
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
245 #endif
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
246 #endif
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
247
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
248 /*
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
249 * The ns16000 is a little more difficult, need to copy regs.
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
250 * Also the code assumes direct linkage call sequence (no mod table crap).
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
251 * We have to copy registers, and therefore waste 32 bytes.
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
252 *
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
253 * Stack layout:
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
254 * new sp -> junk
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
255 * registers (copy)
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
256 * r0 -> new data
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
257 * | (orig retval)
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
258 * | (orig arg)
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
259 * old sp -> regs (orig)
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
260 * local data
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
261 * fp -> old fp
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
262 */
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
263
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
264 movd tos,r1 /* pop return addr */
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
265 negd tos,r0 /* pop amount to allocate */
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
266 sprd sp,r2
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
267 addd r2,r0
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
268 bicb IM/**/3,r0 /* 4-byte align */
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
269 lprd sp,r0
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
270 adjspb IM/**/36 /* space for regs, +4 for caller to pop */
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
271 movmd 0(r2),4(sp),IM/**/4 /* copy regs */
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
272 movmd 0x10(r2),0x14(sp),IM/**/4
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
273 jump REGISTER(r1) /* funky return */
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
274 #endif /* ns16000 or ns32000 */
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
275
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
276 #ifdef pyramid
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
277
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
278 .globl _alloca
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
279
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
280 _alloca: addw $3,pr0 # add 3 (dec) to first argument
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
281 bicw $3,pr0 # then clear its last 2 bits
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
282 subw pr0,sp # subtract from SP the val in PR0
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
283 andw $-32,sp # keep sp aligned on multiple of 32.
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
284 movw sp,pr0 # ret. current SP
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
285 ret
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
286
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
287 #ifdef PYRAMID_OLD /* This isn't needed in system version 4. */
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
288 .globl __longjmp
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
289 .globl _longjmp
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
290 .globl __setjmp
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
291 .globl _setjmp
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
292
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
293 __longjmp: jump _longjmp
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
294 __setjmp: jump _setjmp
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
295 #endif
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
296
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
297 #endif /* pyramid */
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
298
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
299 #ifdef ATT3B5
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
300
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
301 .align 4
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
302 .globl alloca
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
303
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
304 alloca:
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
305 movw %ap, %r8
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
306 subw2 $9*4, %r8
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
307 movw 0(%r8), %r1 /* pc */
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
308 movw 4(%r8), %fp
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
309 movw 8(%r8), %sp
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
310 addw2 %r0, %sp /* make room */
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
311 movw %sp, %r0 /* return value */
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
312 jmp (%r1) /* continue... */
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
313
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
314 #endif /* ATT3B5 */
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
315
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
316 #ifdef XENIX
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
317
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
318 .386
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
319
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
320 _TEXT segment dword use32 public 'CODE'
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
321 assume cs:_TEXT
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
322
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
323 ;-------------------------------------------------------------------------
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
324
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
325 public _alloca
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
326 _alloca proc near
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
327
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
328 pop ecx ; return address
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
329 pop eax ; amount to alloc
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
330 add eax,3 ; round it to 32-bit boundary
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
331 and al,11111100B ;
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
332 mov edx,esp ; current sp in edx
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
333 sub edx,eax ; lower the stack
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
334 xchg esp,edx ; start of allocation in esp, old sp in edx
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
335 mov eax,esp ; return ptr to base in eax
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
336 push [edx+8] ; save poss. stored reg. values (esi,edi,ebx)
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
337 push [edx+4] ; on lowered stack
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
338 push [edx] ;
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
339 sub esp,4 ; allow for 'add esp, 4'
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
340 jmp ecx ; jump to return address
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
341
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
342 _alloca endp
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
343
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
344 _TEXT ends
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
345
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
346 end
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
347
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
348 #endif /* XENIX */
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
349
f9920b777c65 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
350 #endif /* not HAVE_ALLOCA */