mescc: Support gcc-3.2: puts with newline.
[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   eputs ("__floatundix stub\n");
116   return 0;
117 }
118
119 unsigned long long
120 __fixunsxfdi (double a1)
121 {
122   eputs ("__fixunsxfdi stub\n");
123   return 0;
124 }
125
126 unsigned long long
127 __fixdfdi (double a1)
128 {
129   eputs ("__fixdfdi stub\n");
130   return 0;
131 }
132
133 unsigned long long
134 __fixxfdi (double a1)
135 {
136   eputs ("__fixxfdi stub\n");
137   return 0;
138 }
139
140 unsigned long long
141 __fixsfdi (double a1)
142 {
143   eputs ("__fixsfdi stub\n");
144   return 0;
145 }