mlibc: Cleanup.
[mes.git] / lib / libc+tcc-gcc.c
1 /* -*-comment-start: "//";comment-end:""-*-
2  * Mes --- Maxwell Equations of Software
3  * Copyright © 2017,2018 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-gcc.c>
33 #include <linux+tcc-gcc.c>
34 #include <libc+tcc.c>
35 #include <getopt.c>
36 #include <m4.c>
37
38 int errno;
39
40 void
41 longjmp (jmp_buf env, int val)
42 {
43   val = val == 0 ? 1 : val;
44   asm ("mov    0xc(%ebp),%eax\n\t"     // val
45        "mov    0x8(%ebp),%ebp\n\t"     // env*
46
47        "mov    0x4(%ebp),%ebx\n\t"     // env->__pc
48        "mov    0x8(%ebp),%esp\n\t"     // env->__sp
49        "mov    0x0(%ebp),%ebp\n\t"     // env->__bp
50        "jmp    *%ebx\n\t"              // jmp *PC
51        );
52   // not reached
53   exit (42);
54 }
55
56 #if 0
57 int
58 setjmp_debug (jmp_buf env, int val)
59 {
60   int i;
61 #if 1
62   i = env->__bp;
63   i = env->__pc;
64   i = env->__sp;
65 #else
66   i = env[0].__bp;
67   i = env[0].__pc;
68   i = env[0].__sp;
69 #endif
70   return val == 0 ? 1 : val;
71 }
72 #endif
73
74 int
75 setjmp (jmp_buf env)
76 {
77   int *p = (int*)&env;
78   env[0].__bp = p[-2];
79   env[0].__pc = p[-1];
80   env[0].__sp = (int)&env;
81   return 0;
82 }
83
84 unsigned long long
85 __udivdi3 (unsigned long long a, unsigned long long b)
86 {
87   int ai = a;
88   int bi = b;
89   return ai / bi;
90 }
91
92 unsigned long long
93 __umoddi3 (unsigned long long a, unsigned long long b)
94 {
95   int ai = a;
96   int bi = b;
97   return ai % bi;
98 }
99
100 unsigned long long
101 __lshrdi3 (unsigned long long a, int b)
102 {
103   return a >> b;
104 }
105
106 long long
107 __ashldi3 (long long a, int b)
108 {
109   return a << b;
110 }
111
112 long long
113 __ashrdi3 (long long a, int b)
114 {
115   return a >> b;
116 }
117
118 long double
119 __floatundixf (unsigned long long a)
120 {
121   eputs ("__floatundix stub\n");
122   return 0;
123 }
124
125 unsigned long long
126 __fixunsxfdi (double a1)
127 {
128   eputs ("__fixunsxfdi stub\n");
129   return 0;
130 }
131
132 unsigned long long
133 __fixdfdi (double a1)
134 {
135   eputs ("__fixdfdi stub\n");
136   return 0;
137 }
138
139 unsigned long long
140 __fixxfdi (double a1)
141 {
142   eputs ("__fixxfdi stub\n");
143   return 0;
144 }
145
146 unsigned long long
147 __fixsfdi (double a1)
148 {
149   eputs ("__fixsfdi stub\n");
150   return 0;
151 }