This repository has been archived by the owner on Feb 11, 2021. It is now read-only.
/
SDL_stdlib.c
664 lines (649 loc) · 16.6 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
/*
SDL - Simple DirectMedia Layer
Copyright (C) 1997-2006 Sam Lantinga
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation; either
version 2.1 of the License, or (at your option) any later version.
This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public
License along with this library; if not, write to the Free Software
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
Sam Lantinga
slouken@libsdl.org
*/
22
#include "SDL_config.h"
23
24
25
/* This file contains portable stdlib functions for SDL */
26
#include "SDL_stdinc.h"
27
28
29
30
31
32
#ifndef HAVE_LIBC
/* These are some C runtime intrinsics that need to be defined */
#if defined(_MSC_VER)
33
34
35
#ifndef __FLTUSED__
#define __FLTUSED__
#ifdef __cplusplus
36
extern "C"
37
#endif
38
39
__declspec(selectany)
int _fltused = 1;
40
41
#endif
42
/* Float to long */
43
void __declspec(naked) _ftol()
44
{
45
46
47
48
49
50
51
52
53
54
55
56
57
58
/* *INDENT-OFF* */
__asm {
push ebp
mov ebp,esp
sub esp,20h
and esp,0FFFFFFF0h
fld st(0)
fst dword ptr [esp+18h]
fistp qword ptr [esp+10h]
fild qword ptr [esp+10h]
mov edx,dword ptr [esp+18h]
mov eax,dword ptr [esp+10h]
test eax,eax
je integer_QnaN_or_zero
59
arg_is_not_integer_QnaN:
60
61
62
63
64
65
66
67
68
69
70
fsubp st(1),st
test edx,edx
jns positive
fstp dword ptr [esp]
mov ecx,dword ptr [esp]
xor ecx,80000000h
add ecx,7FFFFFFFh
adc eax,0
mov edx,dword ptr [esp+14h]
adc edx,0
jmp localexit
71
positive:
72
73
74
75
76
77
78
fstp dword ptr [esp]
mov ecx,dword ptr [esp]
add ecx,7FFFFFFFh
sbb eax,0
mov edx,dword ptr [esp+14h]
sbb edx,0
jmp localexit
79
integer_QnaN_or_zero:
80
81
82
83
84
mov edx,dword ptr [esp+14h]
test edx,7FFFFFFFh
jne arg_is_not_integer_QnaN
fstp dword ptr [esp+18h]
fstp dword ptr [esp+18h]
85
localexit:
86
87
88
89
leave
ret
}
/* *INDENT-ON* */
90
}
91
92
93
94
void
__declspec(naked)
_ftol2_sse()
95
{
96
_ftol();
97
98
}
99
/* 64-bit math operators for 32-bit systems */
100
101
102
void
__declspec(naked)
_allmul()
103
{
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
/* *INDENT-OFF* */
__asm {
push ebp
mov ebp,esp
push edi
push esi
push ebx
sub esp,0Ch
mov eax,dword ptr [ebp+10h]
mov edi,dword ptr [ebp+8]
mov ebx,eax
mov esi,eax
sar esi,1Fh
mov eax,dword ptr [ebp+8]
mul ebx
imul edi,esi
mov ecx,edx
mov dword ptr [ebp-18h],eax
mov edx,dword ptr [ebp+0Ch]
add ecx,edi
imul ebx,edx
mov eax,dword ptr [ebp-18h]
lea ebx,[ebx+ecx]
mov dword ptr [ebp-14h],ebx
mov edx,dword ptr [ebp-14h]
add esp,0Ch
pop ebx
pop esi
pop edi
pop ebp
ret
}
/* *INDENT-ON* */
137
}
138
139
140
void
__declspec(naked)
_alldiv()
141
{
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
/* *INDENT-OFF* */
__asm {
push edi
push esi
push ebx
xor edi,edi
mov eax,dword ptr [esp+14h]
or eax,eax
jge L1
inc edi
mov edx,dword ptr [esp+10h]
neg eax
neg edx
sbb eax,0
mov dword ptr [esp+14h],eax
mov dword ptr [esp+10h],edx
158
L1:
159
160
161
162
163
164
165
166
167
168
mov eax,dword ptr [esp+1Ch]
or eax,eax
jge L2
inc edi
mov edx,dword ptr [esp+18h]
neg eax
neg edx
sbb eax,0
mov dword ptr [esp+1Ch],eax
mov dword ptr [esp+18h],edx
169
L2:
170
171
172
173
174
175
176
177
178
179
180
or eax,eax
jne L3
mov ecx,dword ptr [esp+18h]
mov eax,dword ptr [esp+14h]
xor edx,edx
div ecx
mov ebx,eax
mov eax,dword ptr [esp+10h]
div ecx
mov edx,ebx
jmp L4
181
L3:
182
183
184
185
mov ebx,eax
mov ecx,dword ptr [esp+18h]
mov edx,dword ptr [esp+14h]
mov eax,dword ptr [esp+10h]
186
L5:
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
shr ebx,1
rcr ecx,1
shr edx,1
rcr eax,1
or ebx,ebx
jne L5
div ecx
mov esi,eax
mul dword ptr [esp+1Ch]
mov ecx,eax
mov eax,dword ptr [esp+18h]
mul esi
add edx,ecx
jb L6
cmp edx,dword ptr [esp+14h]
ja L6
jb L7
cmp eax,dword ptr [esp+10h]
jbe L7
206
L6:
207
dec esi
208
L7:
209
210
xor edx,edx
mov eax,esi
211
L4:
212
213
214
215
216
dec edi
jne L8
neg edx
neg eax
sbb edx,0
217
L8:
218
219
220
221
222
223
pop ebx
pop esi
pop edi
ret 10h
}
/* *INDENT-ON* */
224
}
225
226
227
void
__declspec(naked)
_aulldiv()
228
{
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
/* *INDENT-OFF* */
__asm {
push ebx
push esi
mov eax,dword ptr [esp+18h]
or eax,eax
jne L1
mov ecx,dword ptr [esp+14h]
mov eax,dword ptr [esp+10h]
xor edx,edx
div ecx
mov ebx,eax
mov eax,dword ptr [esp+0Ch]
div ecx
mov edx,ebx
jmp L2
245
L1:
246
247
248
249
mov ecx,eax
mov ebx,dword ptr [esp+14h]
mov edx,dword ptr [esp+10h]
mov eax,dword ptr [esp+0Ch]
250
L3:
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
shr ecx,1
rcr ebx,1
shr edx,1
rcr eax,1
or ecx,ecx
jne L3
div ebx
mov esi,eax
mul dword ptr [esp+18h]
mov ecx,eax
mov eax,dword ptr [esp+14h]
mul esi
add edx,ecx
jb L4
cmp edx,dword ptr [esp+10h]
ja L4
jb L5
cmp eax,dword ptr [esp+0Ch]
jbe L5
270
L4:
271
dec esi
272
L5:
273
274
xor edx,edx
mov eax,esi
275
L2:
276
277
278
279
280
pop esi
pop ebx
ret 10h
}
/* *INDENT-ON* */
281
}
282
283
284
void
__declspec(naked)
_allrem()
285
{
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
/* *INDENT-OFF* */
__asm {
push ebx
push edi
xor edi,edi
mov eax,dword ptr [esp+10h]
or eax,eax
jge L1
inc edi
mov edx,dword ptr [esp+0Ch]
neg eax
neg edx
sbb eax,0
mov dword ptr [esp+10h],eax
mov dword ptr [esp+0Ch],edx
301
L1:
302
303
304
305
306
307
308
309
310
mov eax,dword ptr [esp+18h]
or eax,eax
jge L2
mov edx,dword ptr [esp+14h]
neg eax
neg edx
sbb eax,0
mov dword ptr [esp+18h],eax
mov dword ptr [esp+14h],edx
311
L2:
312
313
314
315
316
317
318
319
320
321
322
323
324
or eax,eax
jne L3
mov ecx,dword ptr [esp+14h]
mov eax,dword ptr [esp+10h]
xor edx,edx
div ecx
mov eax,dword ptr [esp+0Ch]
div ecx
mov eax,edx
xor edx,edx
dec edi
jns L4
jmp L8
325
L3:
326
327
328
329
mov ebx,eax
mov ecx,dword ptr [esp+14h]
mov edx,dword ptr [esp+10h]
mov eax,dword ptr [esp+0Ch]
330
L5:
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
shr ebx,1
rcr ecx,1
shr edx,1
rcr eax,1
or ebx,ebx
jne L5
div ecx
mov ecx,eax
mul dword ptr [esp+18h]
xchg eax,ecx
mul dword ptr [esp+14h]
add edx,ecx
jb L6
cmp edx,dword ptr [esp+10h]
ja L6
jb L7
cmp eax,dword ptr [esp+0Ch]
jbe L7
349
L6:
350
351
sub eax,dword ptr [esp+14h]
sbb edx,dword ptr [esp+18h]
352
L7:
353
354
355
356
sub eax,dword ptr [esp+0Ch]
sbb edx,dword ptr [esp+10h]
dec edi
jns L8
357
L4:
358
359
360
neg edx
neg eax
sbb edx,0
361
L8:
362
363
364
365
366
pop edi
pop ebx
ret 10h
}
/* *INDENT-ON* */
367
}
368
369
370
void
__declspec(naked)
_aullrem()
371
{
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
/* *INDENT-OFF* */
__asm {
push ebx
mov eax,dword ptr [esp+14h]
or eax,eax
jne L1
mov ecx,dword ptr [esp+10h]
mov eax,dword ptr [esp+0Ch]
xor edx,edx
div ecx
mov eax,dword ptr [esp+8]
div ecx
mov eax,edx
xor edx,edx
jmp L2
387
L1:
388
389
390
391
mov ecx,eax
mov ebx,dword ptr [esp+10h]
mov edx,dword ptr [esp+0Ch]
mov eax,dword ptr [esp+8]
392
L3:
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
shr ecx,1
rcr ebx,1
shr edx,1
rcr eax,1
or ecx,ecx
jne L3
div ebx
mov ecx,eax
mul dword ptr [esp+14h]
xchg eax,ecx
mul dword ptr [esp+10h]
add edx,ecx
jb L4
cmp edx,dword ptr [esp+0Ch]
ja L4
jb L5
cmp eax,dword ptr [esp+8]
jbe L5
411
L4:
412
413
sub eax,dword ptr [esp+10h]
sbb edx,dword ptr [esp+14h]
414
L5:
415
416
417
418
419
sub eax,dword ptr [esp+8]
sbb edx,dword ptr [esp+0Ch]
neg edx
neg eax
sbb edx,0
420
L2:
421
422
423
424
pop ebx
ret 10h
}
/* *INDENT-ON* */
425
}
426
427
428
void
__declspec(naked)
_alldvrm()
429
{
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
/* *INDENT-OFF* */
__asm {
push edi
push esi
push ebp
xor edi,edi
xor ebp,ebp
mov eax,dword ptr [esp+14h]
or eax,eax
jge L1
inc edi
inc ebp
mov edx,dword ptr [esp+10h]
neg eax
neg edx
sbb eax,0
mov dword ptr [esp+14h],eax
mov dword ptr [esp+10h],edx
448
L1:
449
450
451
452
453
454
455
456
457
458
mov eax,dword ptr [esp+1Ch]
or eax,eax
jge L2
inc edi
mov edx,dword ptr [esp+18h]
neg eax
neg edx
sbb eax,0
mov dword ptr [esp+1Ch],eax
mov dword ptr [esp+18h],edx
459
L2:
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
or eax,eax
jne L3
mov ecx,dword ptr [esp+18h]
mov eax,dword ptr [esp+14h]
xor edx,edx
div ecx
mov ebx,eax
mov eax,dword ptr [esp+10h]
div ecx
mov esi,eax
mov eax,ebx
mul dword ptr [esp+18h]
mov ecx,eax
mov eax,esi
mul dword ptr [esp+18h]
add edx,ecx
jmp L4
477
L3:
478
479
480
481
mov ebx,eax
mov ecx,dword ptr [esp+18h]
mov edx,dword ptr [esp+14h]
mov eax,dword ptr [esp+10h]
482
L5:
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
shr ebx,1
rcr ecx,1
shr edx,1
rcr eax,1
or ebx,ebx
jne L5
div ecx
mov esi,eax
mul dword ptr [esp+1Ch]
mov ecx,eax
mov eax,dword ptr [esp+18h]
mul esi
add edx,ecx
jb L6
cmp edx,dword ptr [esp+14h]
ja L6
jb L7
cmp eax,dword ptr [esp+10h]
jbe L7
502
L6:
503
504
505
dec esi
sub eax,dword ptr [esp+18h]
sbb edx,dword ptr [esp+1Ch]
506
L7:
507
xor ebx,ebx
508
L4:
509
510
511
512
513
514
515
sub eax,dword ptr [esp+10h]
sbb edx,dword ptr [esp+14h]
dec ebp
jns L9
neg edx
neg eax
sbb edx,0
516
L9:
517
518
519
520
521
522
523
524
525
526
mov ecx,edx
mov edx,ebx
mov ebx,ecx
mov ecx,eax
mov eax,esi
dec edi
jne L8
neg edx
neg eax
sbb edx,0
527
L8:
528
529
530
531
532
533
pop ebp
pop esi
pop edi
ret 10h
}
/* *INDENT-ON* */
534
}
535
536
537
void
__declspec(naked)
_aulldvrm()
538
{
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
/* *INDENT-OFF* */
__asm {
push esi
mov eax,dword ptr [esp+14h]
or eax,eax
jne L1
mov ecx,dword ptr [esp+10h]
mov eax,dword ptr [esp+0Ch]
xor edx,edx
div ecx
mov ebx,eax
mov eax,dword ptr [esp+8]
div ecx
mov esi,eax
mov eax,ebx
mul dword ptr [esp+10h]
mov ecx,eax
mov eax,esi
mul dword ptr [esp+10h]
add edx,ecx
jmp L2
560
L1:
561
562
563
564
mov ecx,eax
mov ebx,dword ptr [esp+10h]
mov edx,dword ptr [esp+0Ch]
mov eax,dword ptr [esp+8]
565
L3:
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
shr ecx,1
rcr ebx,1
shr edx,1
rcr eax,1
or ecx,ecx
jne L3
div ebx
mov esi,eax
mul dword ptr [esp+14h]
mov ecx,eax
mov eax,dword ptr [esp+10h]
mul esi
add edx,ecx
jb L4
cmp edx,dword ptr [esp+0Ch]
ja L4
jb L5
cmp eax,dword ptr [esp+8]
jbe L5
585
L4:
586
587
588
dec esi
sub eax,dword ptr [esp+10h]
sbb edx,dword ptr [esp+14h]
589
L5:
590
xor ebx,ebx
591
L2:
592
593
594
595
596
597
598
599
600
601
602
603
604
605
sub eax,dword ptr [esp+8]
sbb edx,dword ptr [esp+0Ch]
neg edx
neg eax
sbb edx,0
mov ecx,edx
mov edx,ebx
mov ebx,ecx
mov ecx,eax
mov eax,esi
pop esi
ret 10h
}
/* *INDENT-ON* */
606
}
607
608
609
void
__declspec(naked)
_allshl()
610
{
611
612
613
614
615
616
617
618
619
/* *INDENT-OFF* */
__asm {
cmp cl,40h
jae RETZERO
cmp cl,20h
jae MORE32
shld edx,eax,cl
shl eax,cl
ret
620
MORE32:
621
622
623
624
625
mov edx,eax
xor eax,eax
and cl,1Fh
shl edx,cl
ret
626
RETZERO:
627
628
629
630
631
xor eax,eax
xor edx,edx
ret
}
/* *INDENT-ON* */
632
}
633
634
635
void
__declspec(naked)
_aullshr()
636
{
637
638
639
640
641
642
643
644
645
/* *INDENT-OFF* */
__asm {
cmp cl,40h
jae RETZERO
cmp cl,20h
jae MORE32
shrd eax,edx,cl
shr edx,cl
ret
646
MORE32:
647
648
649
650
651
mov eax,edx
xor edx,edx
and cl,1Fh
shr eax,cl
ret
652
RETZERO:
653
654
655
656
657
xor eax,eax
xor edx,edx
ret
}
/* *INDENT-ON* */
658
659
660
661
}
#endif /* MSC_VER */
662
#endif /* !HAVE_LIBC */
663
664
/* vi: set ts=4 sw=4 expandtab: */