Fix dtoab.
[mes.git] / lib / x86_64-mes-mescc / setjmp.c
1 /* -*-comment-start: "//";comment-end:""-*-
2  * GNU Mes --- Maxwell Equations of Software
3  * Copyright © 2017,2018,2019 Jan (janneke) Nieuwenhuizen <janneke@gnu.org>
4  *
5  * This file is part of GNU Mes.
6  *
7  * GNU Mes is free software; you can redistribute it and/or modify it
8  * under the terms of the GNU General Public License as published by
9  * the Free Software Foundation; either version 3 of the License, or (at
10  * your option) any later version.
11  *
12  * GNU Mes is distributed in the hope that it will be useful, but
13  * WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15  * GNU General Public License for more details.
16  *
17  * You should have received a copy of the GNU General Public License
18  * along with GNU Mes.  If not, see <http://www.gnu.org/licenses/>.
19  */
20
21 #include <setjmp.h>
22 #include <stdlib.h>
23
24 void
25 longjmp (jmp_buf env, int val)
26 {
27 #if 0                           //MES_CCAMD64
28   asm ("push___%rdi");
29 #endif
30   val = val == 0 ? 1 : val;
31 #if 0                           //MES_CCAMD64
32   asm ("pop____%rdi");
33   asm ("mov____0x8(%rdi),%rbp !0x00");  // env->__bp
34   asm ("mov____0x8(%rdi),%rbx !0x08");  // env->__pc
35   asm ("mov____0x8(%rdi),%rsp !0x10");  // env->__sp
36   asm ("jmp____*%rbx");         // jmp *PC
37 #else
38   asm ("mov____0x8(%rbp),%rbp !0x10");  // env*
39
40   asm ("mov____0x8(%rbp),%rbx !0x08");  // env.__pc
41   asm ("mov____0x8(%rbp),%rsp !0x10");  // env.__sp
42   asm ("mov____0x8(%rbp),%rbp !0x00");  // env.__bp
43   asm ("jmp____*%rbx");
44 #endif
45   // not reached
46   exit (42);
47 }
48
49 int
50 setjmp (__jmp_buf * env)
51 {
52 #if 0                           //MES_CCAMD64
53   asm ("mov____%rbp,%rax");
54   asm ("add____$i32,%rax %0x80");
55
56   asm ("mov____0x8(%rax),%rsi !0x00");
57   asm ("mov____%rsi,0x8(%rdi) !0x00");
58
59   asm ("mov____0x8(%rax),%rsi !0x08");
60   asm ("mov____%rsi,0x8(%rdi) !0x08");
61
62   asm ("mov____%rax,%rsi");
63   asm ("add____$i32,%rsi %0x10");
64   asm ("mov____%rsi,0x8(%rdi) !0x10");
65 #else
66   long *p = (long *) &env;
67   env[0].__bp = p[-2];
68   env[0].__pc = p[-1];
69   env[0].__sp = (long) &env;
70 #endif
71   return 0;
72 }