mes: Add unfold.
[mes.git] / lib / libc+tcc-mes.c
1 /* -*-comment-start: "//";comment-end:""-*-
2  * Mes --- Maxwell Equations of Software
3  * Copyright © 2017 Jan (janneke) Nieuwenhuizen <janneke@gnu.org>
4  *
5  * This file is part of Mes.
6  *
7  * 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  * 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 Mes.  If not, see <http://www.gnu.org/licenses/>.
19  */
20
21 #include <setjmp.h>
22 #include <stdarg.h>
23 #include <stdio.h>
24 #include <stdlib.h>
25 #include <string.h>
26 #include <time.h>
27 #include <signal.h>
28 #include <sys/mman.h>
29 #include <sys/time.h>
30 #include <unistd.h>
31
32 #include <libc-mes.c>
33 #include <linux+tcc-mes.c>
34 #include <libc+tcc.c>
35 #include <getopt.c>
36
37 int errno;
38
39 void
40 longjmp (jmp_buf env, int val)
41 {
42   val = val == 0 ? 1 : val;
43   asm ("mov____0x8(%ebp),%eax !0x0c"); // val
44   asm ("mov____0x8(%ebp),%ebp !0x08"); // env*
45
46   asm ("mov____0x8(%ebp),%ebx !0x4");  // env.__pc
47   asm ("mov____0x8(%ebp),%esp !0x8");  // env.__sp
48   asm ("mov____0x8(%ebp),%ebp !0x0");  // env.__bp
49   asm ("jmp____*%ebx");
50   // not reached
51   exit (42);
52 }
53
54 #if 0
55 int
56 setjmp_debug (jmp_buf env, int val)
57 {
58   int i;
59 #if 1
60   i = env->__bp;
61   i = env->__pc;
62   i = env->__sp;
63 #else
64   i = env[0].__bp;
65   i = env[0].__pc;
66   i = env[0].__sp;
67 #endif
68   return val == 0 ? 1 : val;
69 }
70 #endif
71
72 int
73 setjmp (__jmp_buf *env)
74 {
75   int *p = (int*)&env;
76   env[0].__bp = p[-2];
77   env[0].__pc = p[-1];
78   env[0].__sp = (int)&env;
79   return 0;
80 }