aboutsummaryrefslogtreecommitdiff
path: root/unix/as.sunos/zsvjmp.s
diff options
context:
space:
mode:
authorJoe Hunkeler <jhunkeler@gmail.com>2015-08-11 16:51:37 -0400
committerJoe Hunkeler <jhunkeler@gmail.com>2015-08-11 16:51:37 -0400
commit40e5a5811c6ffce9b0974e93cdd927cbcf60c157 (patch)
tree4464880c571602d54f6ae114729bf62a89518057 /unix/as.sunos/zsvjmp.s
downloadiraf-osx-40e5a5811c6ffce9b0974e93cdd927cbcf60c157.tar.gz
Repatch (from linux) of OSX IRAF
Diffstat (limited to 'unix/as.sunos/zsvjmp.s')
-rw-r--r--unix/as.sunos/zsvjmp.s50
1 files changed, 50 insertions, 0 deletions
diff --git a/unix/as.sunos/zsvjmp.s b/unix/as.sunos/zsvjmp.s
new file mode 100644
index 00000000..0a345079
--- /dev/null
+++ b/unix/as.sunos/zsvjmp.s
@@ -0,0 +1,50 @@
+ .file "zsvjmp.s"
+
+/ 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.
+/
+/ zsvjmp (jmp_buf, status) (returns status)
+/ zdojmp (jmp_buf, status) (passes status to zsvjmp)
+/
+/ These routines are directly comparable to the UNIX setjmp/longjmp, except
+/ that they are Fortran callable kernel routines, i.e., trailing underscore,
+/ call by reference, and no function returns. ZSVJMP requires an assembler
+/ jacket routine to avoid modifying the call stack, but relies upon setjmp
+/ to do the real work. ZDOJMP is implemented as a portable C routine in OS,
+/ calling longjmp to do the restore. In these routines, JMP_BUF consists
+/ of one longword containing the address of the STATUS variable, followed
+/ by the "jmp_buf" used by setjmp/longjmp.
+/
+/ This file contains the Solaris x86 version of ZSVJMP.
+
+ .globl zsvjmp_
+ .globl mem_
+ .type mem_, @object
+ .size mem_, 0x8
+ mem_ = 0
+
+ / 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 VOS or Fortran 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 are likely to cause a
+ / memory violation.
+
+ / .data
+ / .globl mem_
+ / mem_ = 0
+
+ .text
+zsvjmp_:
+ movl 4(%esp), %ecx / &jmpbuf to ECX
+ movl 8(%esp), %eax / &status to EAX
+ movl %eax, (%ecx) / store &status in jmpbuf[0]
+ movl $0, (%eax) / zero the value of status
+ addl $4, %ecx / change stack to point to &jmpbuf[1]
+ movl %ecx, 4(%esp) / ...
+ jmp setjmp / let setjmp do the rest