blob: efebe43e71d266a64bf214354bb7c473fde6cd63 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
|
|# ZSVJMP, ZDOJMP -- Set up a jump (non-local goto) by saving the processor
|# registers in the buffer jmpbuf. A subsequent call to ZDOJMP restores
|# the registers, effecting a call in the context of the procedure which
|# originally called ZSVJMP, but with the new status code. These are Fortran
|# callable procedures.
|#
|# (SUN/UNIX MC68xxx version)
.text
.globl _zsvjmp_
|# The following has nothing to do with ZSVJMP, and is included here
|# only because this assembler module is loaded with every process.
|# This code sets the value of the symbol MEM (the Mem common) to zero,
|# setting the origin for IRAF pointers to zero rather than some
|# arbitrary value, and ensuring that the MEM common is aligned for
|# all datatypes as well as page aligned. A further advantage is that
|# references to NULL pointers will cause a memory violation.
.globl _mem_
_mem_ = 0
JMPBUF = 4
STATUS = 8
|# The strategy here is to build on the services provided by the C
|# setjmp/longjmp. Note that we cannot do this by writing a C function
|# which calls setjmp, because the procedure which calls setjmp cannot
|# return before the longjmp is executed.
_zsvjmp_: |# CALL ZSVJMP (JMPBUF, STATUS)
movl sp@(JMPBUF),a0 |# set A0 to point to jmp_buf
movl sp@(STATUS),a1 |# A1 = status variable
movl a1,a0@ |# JB[0] = addr of status variable
clrl a1@ |# return zero status
addql #4,sp@(JMPBUF) |# skip first cell of jmp_buf
jmp _setjmp |# let setjmp do the rest.
|