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