mirror of
https://github.com/zeldaret/st
synced 2026-05-23 06:54:21 -04:00
Match MSL_C (#8)
* match wstring.c * match math_api.c, mbstring.c, mem.c and mem_funcs.c * more progress * build issues * fix non-matching issues * reorganise files * match fdlibm (+ libc progress) * fix jp build * solved some non-matchings and progress * removed types.h usage in libc * match data and add missing delinks for jp
This commit is contained in:
@@ -20,3 +20,131 @@ libs/cpp/src/__register_global_object.c:
|
||||
|
||||
src/Main/func_02017ea4.cpp:
|
||||
.text start:0x02017ea4 end:0x02017f38
|
||||
|
||||
libs/c/src/locale.c:
|
||||
complete
|
||||
.data start:0x02044790 end:0x020449ac
|
||||
|
||||
libs/c/src/abort_exit_arm_eabi.c:
|
||||
complete
|
||||
.bss start:0x02051570 end:0x02051680
|
||||
.text start:0x020336e8 end:0x02033870
|
||||
|
||||
libs/c/src/ansi_files.c:
|
||||
complete
|
||||
.data start:0x020446a8 end:0x0204478c
|
||||
.bss start:0x020517a0 end:0x02051aa0
|
||||
.text start:0x02033870 end:0x020338d4
|
||||
|
||||
libs/c/src/float.c:
|
||||
complete
|
||||
.data start:0x0204478c end:0x02044790
|
||||
|
||||
libs/c/src/arith.c:
|
||||
complete
|
||||
.text start:0x020338d4 end:0x020338ec
|
||||
|
||||
libs/c/src/buffer_io.c:
|
||||
complete
|
||||
.text start:0x020338ec end:0x0203399c
|
||||
|
||||
libs/c/src/file_io.c:
|
||||
complete
|
||||
.text start:0x0203399c end:0x02033a80
|
||||
|
||||
libs/c/src/math_api.c:
|
||||
complete
|
||||
.text start:0x02033b14 end:0x02033ba0
|
||||
|
||||
libs/c/src/mbstring.c:
|
||||
complete
|
||||
.text start:0x02033ba0 end:0x02033c90
|
||||
|
||||
libs/c/src/mem.c:
|
||||
complete
|
||||
.text start:0x02033c90 end:0x02033d7c
|
||||
|
||||
libs/c/src/mem_funcs.c:
|
||||
complete
|
||||
.text start:0x02033d7c end:0x02033e28
|
||||
|
||||
libs/c/src/secure_error.c:
|
||||
complete
|
||||
.bss start:0x02051aa4 end:0x02051aa8
|
||||
.text start:0x02033e28 end:0x02033e54
|
||||
|
||||
libs/c/src/signal.c:
|
||||
complete
|
||||
.text start:0x02033e54 end:0x02033f7c
|
||||
.bss start:0x02051aa8 end:0x02051ac4
|
||||
|
||||
libs/c/src/string.c:
|
||||
complete
|
||||
.text start:0x02033f7c end:0x020341f8
|
||||
|
||||
libs/c/src/wmem.c:
|
||||
complete
|
||||
.text start:0x020341f8 end:0x02034230
|
||||
|
||||
libs/c/src/wprintf.c:
|
||||
.data start:0x020449ac end:0x02044a2c
|
||||
.text start:0x02034230 end:0x0203615c
|
||||
|
||||
libs/c/src/wstring.c:
|
||||
complete
|
||||
.text start:0x0203615c end:0x0203621c
|
||||
|
||||
libs/c/src/ansi_fp.c:
|
||||
.data start:0x02044a2c end:0x02044b00
|
||||
.text start:0x0203621c end:0x02036ba4
|
||||
|
||||
libs/c/src/extras.c:
|
||||
complete
|
||||
.text start:0x02036ba4 end:0x02036bd0
|
||||
|
||||
libs/c/src/math/e_log.c:
|
||||
complete
|
||||
.bss start:0x02051ac4 end:0x02051acc
|
||||
.text start:0x02036bd0 end:0x02037300
|
||||
|
||||
libs/c/src/math/e_log10.c:
|
||||
complete
|
||||
.bss start:0x02051acc end:0x02051ad4
|
||||
.text start:0x02037300 end:0x020374d8
|
||||
|
||||
libs/c/src/math/e_pow.c:
|
||||
complete
|
||||
.rodata start:0x02043188 end:0x020431b8
|
||||
.text start:0x020374d8 end:0x02038660
|
||||
|
||||
libs/c/src/math/s_ceil.c:
|
||||
complete
|
||||
.text start:0x02038660 end:0x02038820
|
||||
|
||||
libs/c/src/math/s_copysign.c:
|
||||
complete
|
||||
.text start:0x02038820 end:0x02038848
|
||||
|
||||
libs/c/src/math/s_fabs.c:
|
||||
complete
|
||||
.text start:0x02038848 end:0x02038868
|
||||
|
||||
libs/c/src/math/s_frexp.c:
|
||||
complete
|
||||
.text start:0x02038868 end:0x02038928
|
||||
|
||||
libs/c/src/math/s_ldexp.c:
|
||||
complete
|
||||
.text start:0x02038928 end:0x02038b88
|
||||
|
||||
libs/c/src/math/w_log.c:
|
||||
complete
|
||||
.text start:0x02038b88 end:0x02038b94
|
||||
|
||||
libs/c/src/math/w_log10f.c:
|
||||
complete
|
||||
.text start:0x02038b94 end:0x02038ba0
|
||||
|
||||
libs/c/src/math/w_pow.c:
|
||||
complete
|
||||
.text start:0x02038ba0 end:0x02038bac
|
||||
|
||||
@@ -61,7 +61,7 @@ data_027e0850 kind:bss addr:0x027e0850
|
||||
data_027e0854 kind:bss addr:0x027e0854
|
||||
data_027e0858 kind:bss addr:0x027e0858
|
||||
data_027e085c kind:bss addr:0x027e085c
|
||||
data_027e0860 kind:bss addr:0x027e0860
|
||||
ThreadInfo kind:bss addr:0x027e0860
|
||||
data_027e0864 kind:bss addr:0x027e0864
|
||||
data_027e0870 kind:bss addr:0x027e0870
|
||||
data_027e08f0 kind:bss addr:0x027e08f0
|
||||
|
||||
@@ -21,4 +21,4 @@ data_ov110_021861e0 kind:data(any) addr:0x021861e0
|
||||
data_ov110_021861ec kind:data(any) addr:0x021861ec
|
||||
_ZTV22UnkStruct_PlayerGet_74 kind:data(any) addr:0x021861f8
|
||||
_ZTV9PlayerGet kind:data(any) addr:0x02186204
|
||||
data_ov110_02186240 kind:bss(size=0x3F68) addr:0x02186240
|
||||
data_ov110_02186240 kind:bss(size=0x3f68) addr:0x02186240
|
||||
|
||||
@@ -5055,7 +5055,7 @@ from:0x02033e7c kind:arm_call to:0x020274f8 module:main
|
||||
from:0x02033edc kind:arm_call to:0x020273e0 module:main
|
||||
from:0x02033f28 kind:arm_call to:0x02027460 module:main
|
||||
from:0x02033f54 kind:arm_call to:0x02033710 module:main
|
||||
from:0x02033f68 kind:load to:0x02051770 module:main
|
||||
from:0x02033f68 kind:load to:0x020516c8 add:0xa8 module:main
|
||||
from:0x02033f6c kind:load to:0x027e0860 module:dtcm
|
||||
from:0x02033f70 kind:load to:0x02051680 module:main
|
||||
from:0x02033f74 kind:load to:0x020516a4 module:main
|
||||
|
||||
+131
-130
@@ -1475,8 +1475,8 @@ func_02026718 kind:function(arm,size=0x18) addr:0x02026718
|
||||
func_02026730 kind:function(arm,size=0x8) addr:0x02026730
|
||||
func_02026738 kind:function(arm,size=0x58) addr:0x02026738
|
||||
func_02026790 kind:function(arm,size=0x30) addr:0x02026790
|
||||
func_020267c0 kind:function(arm,size=0x28) addr:0x020267c0
|
||||
func_020267e8 kind:function(arm,size=0x18) addr:0x020267e8
|
||||
sscanf kind:function(arm,size=0x28) addr:0x020267c0
|
||||
vsscanf kind:function(arm,size=0x18) addr:0x020267e8
|
||||
func_02026800 kind:function(arm,size=0x28) addr:0x02026800
|
||||
func_02026828 kind:function(arm,size=0xc) addr:0x02026828
|
||||
func_02026834 kind:function(arm,size=0x18) addr:0x02026834
|
||||
@@ -1518,10 +1518,10 @@ func_020271f8 kind:function(arm,size=0x94) addr:0x020271f8
|
||||
func_0202728c kind:function(arm,size=0xa0) addr:0x0202728c
|
||||
func_0202732c kind:function(arm,size=0x9c) addr:0x0202732c
|
||||
OS_InitMutex kind:function(arm,size=0x18) addr:0x020273c8
|
||||
func_020273e0 kind:function(arm,size=0x80) addr:0x020273e0
|
||||
func_02027460 kind:function(arm,size=0x5c) addr:0x02027460
|
||||
OS_LockMutex kind:function(arm,size=0x80) addr:0x020273e0
|
||||
OS_UnlockMutex kind:function(arm,size=0x5c) addr:0x02027460
|
||||
func_020274bc kind:function(arm,size=0x3c) addr:0x020274bc
|
||||
func_020274f8 kind:function(arm,size=0x70) addr:0x020274f8
|
||||
OS_TryLockMutex kind:function(arm,size=0x70) addr:0x020274f8
|
||||
func_02027568 kind:function(arm,size=0x24) addr:0x02027568
|
||||
func_0202758c kind:function(arm,size=0x24) addr:0x0202758c
|
||||
func_020275b0 kind:function(arm,size=0xc) addr:0x020275b0
|
||||
@@ -1954,75 +1954,74 @@ func_02032e08 kind:function(arm,size=0x54) addr:0x02032e08
|
||||
func_02032e5c kind:function(arm,size=0x58) addr:0x02032e5c
|
||||
func_02032eb4 kind:function(arm,size=0x28) addr:0x02032eb4
|
||||
func_02032edc kind:function(arm,size=0x80c) addr:0x02032edc
|
||||
func_020336e8 kind:function(arm,size=0x28) addr:0x020336e8
|
||||
func_02033710 kind:function(arm,size=0x44) addr:0x02033710
|
||||
func_02033754 kind:function(arm,size=0x11c) addr:0x02033754
|
||||
func_02033870 kind:function(arm,size=0x64) addr:0x02033870
|
||||
func_020338d4 kind:function(arm,size=0xc) addr:0x020338d4
|
||||
func_020338e0 kind:function(arm,size=0xc) addr:0x020338e0
|
||||
func_020338ec kind:function(arm,size=0x4) addr:0x020338ec
|
||||
func_020338f0 kind:function(arm,size=0x28) addr:0x020338f0
|
||||
func_02033918 kind:function(arm,size=0x84) addr:0x02033918
|
||||
func_0203399c kind:function(arm,size=0xe4) addr:0x0203399c
|
||||
abort kind:function(arm,size=0x28) addr:0x020336e8
|
||||
exit kind:function(arm,size=0x44) addr:0x02033710
|
||||
__exit kind:function(arm,size=0x11c) addr:0x02033754
|
||||
__flush_all kind:function(arm,size=0x64) addr:0x02033870
|
||||
abs kind:function(arm,size=0xc) addr:0x020338d4
|
||||
labs kind:function(arm,size=0xc) addr:0x020338e0
|
||||
__convert_from_newlines kind:function(arm,size=0x4) addr:0x020338ec
|
||||
__prep_buffer kind:function(arm,size=0x28) addr:0x020338f0
|
||||
__flush_buffer kind:function(arm,size=0x84) addr:0x02033918
|
||||
fflush kind:function(arm,size=0xe4) addr:0x0203399c
|
||||
func_02033a80 kind:function(arm,size=0x94) addr:0x02033a80
|
||||
func_02033b14 kind:function(arm,size=0x1c) addr:0x02033b14
|
||||
func_02033b30 kind:function(arm,size=0x70) addr:0x02033b30
|
||||
func_02033ba0 kind:function(arm,size=0x1c) addr:0x02033ba0
|
||||
func_02033bbc kind:function(arm,size=0x38) addr:0x02033bbc
|
||||
func_02033bf4 kind:function(arm,size=0x14) addr:0x02033bf4
|
||||
func_02033c08 kind:function(arm,size=0x88) addr:0x02033c08
|
||||
func_02033c90 kind:function(arm,size=0x20) addr:0x02033c90
|
||||
func_02033cb0 kind:function(arm,size=0x4c) addr:0x02033cb0
|
||||
func_02033cfc kind:function(arm,size=0x14) addr:0x02033cfc
|
||||
func_02033d10 kind:function(arm,size=0x2c) addr:0x02033d10
|
||||
func_02033d3c kind:function(arm,size=0x40) addr:0x02033d3c
|
||||
func_02033d7c kind:function(arm,size=0xac) addr:0x02033d7c
|
||||
func_02033e28 kind:function(arm,size=0x28) addr:0x02033e28
|
||||
func_02033e50 kind:function(arm,size=0x4) addr:0x02033e50
|
||||
func_02033e54 kind:function(arm,size=0x128) addr:0x02033e54
|
||||
__signbitd kind:function(arm,size=0x1c) addr:0x02033b14
|
||||
__fpclassifyd kind:function(arm,size=0x70) addr:0x02033b30
|
||||
mbtowc kind:function(arm,size=0x1c) addr:0x02033ba0
|
||||
__mbtowc_noconv kind:function(arm,size=0x38) addr:0x02033bbc
|
||||
__wctomb_noconv kind:function(arm,size=0x14) addr:0x02033bf4
|
||||
mbstowcs kind:function(arm,size=0x88) addr:0x02033c08
|
||||
memcpy kind:function(arm,size=0x20) addr:0x02033c90
|
||||
memmove kind:function(arm,size=0x4c) addr:0x02033cb0
|
||||
memset kind:function(arm,size=0x14) addr:0x02033cfc
|
||||
memchr kind:function(arm,size=0x2c) addr:0x02033d10
|
||||
memcmp kind:function(arm,size=0x40) addr:0x02033d3c
|
||||
__fill_mem kind:function(arm,size=0xac) addr:0x02033d7c
|
||||
__msl_runtime_constraint_violation_s kind:function(arm,size=0x28) addr:0x02033e28
|
||||
secure_error_func_02033e50 kind:function(arm,size=0x4) addr:0x02033e50
|
||||
raise kind:function(arm,size=0x128) addr:0x02033e54
|
||||
strlen kind:function(arm,size=0x1c) addr:0x02033f7c
|
||||
func_02033f98 kind:function(arm,size=0xc8) addr:0x02033f98
|
||||
strcpy kind:function(arm,size=0xc8) addr:0x02033f98
|
||||
strncpy kind:function(arm,size=0x50) addr:0x02034060
|
||||
func_020340b0 kind:function(arm,size=0x114) addr:0x020340b0
|
||||
func_020341c4 kind:function(arm,size=0x34) addr:0x020341c4
|
||||
func_020341f8 kind:function(arm,size=0x10) addr:0x020341f8
|
||||
func_02034208 kind:function(arm,size=0x28) addr:0x02034208
|
||||
func_02034230 kind:function(arm,size=0x518) addr:0x02034230
|
||||
func_02034748 kind:function(arm,size=0x24c) addr:0x02034748
|
||||
func_02034994 kind:function(arm,size=0x2d8) addr:0x02034994
|
||||
func_02034c6c kind:function(arm,size=0x3c0) addr:0x02034c6c
|
||||
func_0203502c kind:function(arm,size=0x114) addr:0x0203502c
|
||||
func_02035140 kind:function(arm,size=0x5f8) addr:0x02035140
|
||||
func_02035738 kind:function(arm,size=0x95c) addr:0x02035738
|
||||
func_02036094 kind:function(arm,size=0x40) addr:0x02036094
|
||||
func_020360d4 kind:function(arm,size=0x28) addr:0x020360d4
|
||||
func_020360fc kind:function(arm,size=0x60) addr:0x020360fc
|
||||
func_0203615c kind:function(arm,size=0x1c) addr:0x0203615c
|
||||
func_02036178 kind:function(arm,size=0x20) addr:0x02036178
|
||||
func_02036198 kind:function(arm,size=0x50) addr:0x02036198
|
||||
func_020361e8 kind:function(arm,size=0x34) addr:0x020361e8
|
||||
func_0203621c kind:function(arm,size=0x6c) addr:0x0203621c
|
||||
func_02036288 kind:function(arm,size=0x4c) addr:0x02036288
|
||||
func_020362d4 kind:function(arm,size=0x4) addr:0x020362d4
|
||||
func_020362d8 kind:function(arm,size=0x40) addr:0x020362d8
|
||||
func_02036318 kind:function(arm,size=0xc4) addr:0x02036318
|
||||
func_020363dc kind:function(arm,size=0x180) addr:0x020363dc
|
||||
func_0203655c kind:function(arm,size=0x9c) addr:0x0203655c
|
||||
func_020365f8 kind:function(arm,size=0x380) addr:0x020365f8
|
||||
func_02036978 kind:function(arm,size=0x180) addr:0x02036978
|
||||
func_02036af8 kind:function(arm,size=0xac) addr:0x02036af8
|
||||
func_02036ba4 kind:function(arm,size=0x2c) addr:0x02036ba4
|
||||
func_02036bd0 kind:function(arm,size=0x730) addr:0x02036bd0
|
||||
func_02037300 kind:function(arm,size=0x1d8) addr:0x02037300
|
||||
func_020374d8 kind:function(arm,size=0x1188) addr:0x020374d8
|
||||
func_02038660 kind:function(arm,size=0x1c0) addr:0x02038660
|
||||
func_02038820 kind:function(arm,size=0x28) addr:0x02038820
|
||||
func_02038848 kind:function(arm,size=0x20) addr:0x02038848
|
||||
func_02038868 kind:function(arm,size=0xc0) addr:0x02038868
|
||||
func_02038928 kind:function(arm,size=0x260) addr:0x02038928
|
||||
func_02038b88 kind:function(arm,size=0xc) addr:0x02038b88
|
||||
func_02038b94 kind:function(arm,size=0xc) addr:0x02038b94
|
||||
func_02038ba0 kind:function(arm,size=0xc) addr:0x02038ba0
|
||||
strcmp kind:function(arm,size=0x114) addr:0x020340b0
|
||||
strncmp kind:function(arm,size=0x34) addr:0x020341c4
|
||||
wmemcpy kind:function(arm,size=0x10) addr:0x020341f8
|
||||
wmemchr kind:function(arm,size=0x28) addr:0x02034208
|
||||
parse_format kind:function(arm,size=0x518) addr:0x02034230
|
||||
long2str kind:function(arm,size=0x24c) addr:0x02034748
|
||||
longlong2str kind:function(arm,size=0x2d8) addr:0x02034994
|
||||
double2hex kind:function(arm,size=0x3c0) addr:0x02034c6c
|
||||
round_decimal kind:function(arm,size=0x114) addr:0x0203502c
|
||||
float2str kind:function(arm,size=0x5f8) addr:0x02035140
|
||||
__wpformatter kind:function(arm,size=0x95c) addr:0x02035738
|
||||
__wStringWrite kind:function(arm,size=0x40) addr:0x02036094
|
||||
swprintf kind:function(arm,size=0x28) addr:0x020360d4
|
||||
vswprintf kind:function(arm,size=0x60) addr:0x020360fc
|
||||
wcslen kind:function(arm,size=0x1c) addr:0x0203615c
|
||||
wcscpy kind:function(arm,size=0x20) addr:0x02036178
|
||||
wcsncpy kind:function(arm,size=0x50) addr:0x02036198
|
||||
wcschr kind:function(arm,size=0x34) addr:0x020361e8
|
||||
__must_round kind:function(arm,size=0x6c) addr:0x0203621c
|
||||
__dorounddecup kind:function(arm,size=0x50) addr:0x02036288
|
||||
__rounddec kind:function(arm,size=0x40) addr:0x020362d8
|
||||
__ull2dec kind:function(arm,size=0xc4) addr:0x02036318
|
||||
__timesdec kind:function(arm,size=0x180) addr:0x020363dc
|
||||
__str2dec kind:function(arm,size=0x9c) addr:0x0203655c
|
||||
__two_exp kind:function(arm,size=0x380) addr:0x020365f8
|
||||
__num2dec_internal kind:function(arm,size=0x180) addr:0x02036978
|
||||
__num2dec kind:function(arm,size=0xac) addr:0x02036af8
|
||||
scalbn kind:function(arm,size=0x2c) addr:0x02036ba4
|
||||
__ieee754_log kind:function(arm,size=0x730) addr:0x02036bd0
|
||||
__ieee754_log10 kind:function(arm,size=0x1d8) addr:0x02037300
|
||||
__ieee754_pow kind:function(arm,size=0x1188) addr:0x020374d8
|
||||
ceil kind:function(arm,size=0x1c0) addr:0x02038660
|
||||
copysign kind:function(arm,size=0x28) addr:0x02038820
|
||||
fabs kind:function(arm,size=0x20) addr:0x02038848
|
||||
frexp kind:function(arm,size=0xc0) addr:0x02038868
|
||||
ldexp kind:function(arm,size=0x260) addr:0x02038928
|
||||
log kind:function(arm,size=0xc) addr:0x02038b88
|
||||
log10f kind:function(arm,size=0xc) addr:0x02038b94
|
||||
pow kind:function(arm,size=0xc) addr:0x02038ba0
|
||||
func_02038bac kind:function(arm,size=0x78) addr:0x02038bac
|
||||
func_02038c24 kind:function(arm,size=0x28) addr:0x02038c24
|
||||
func_02038c4c kind:function(arm,size=0x10) addr:0x02038c4c
|
||||
@@ -2041,73 +2040,73 @@ func_02038d44 kind:function(arm,size=0x20) addr:0x02038d44
|
||||
func_02038d64 kind:function(arm,size=0x30) addr:0x02038d64
|
||||
func_02038d94 kind:function(arm,size=0x2c) addr:0x02038d94
|
||||
func_02038dc0 kind:function(arm,size=0x8c) addr:0x02038dc0
|
||||
func_02038e4c kind:function(arm,size=0x318) addr:0x02038e4c
|
||||
func_0203917c kind:function(arm,size=0x3b4) addr:0x0203917c
|
||||
_dadd kind:function(arm,size=0x318) addr:0x02038e4c
|
||||
_dsub kind:function(arm,size=0x3b4) addr:0x0203917c
|
||||
_dmul kind:function(arm,size=0x364) addr:0x02039530
|
||||
_fflt kind:function(arm,size=0x104) addr:0x02039894
|
||||
_dflt kind:function(arm,size=0x40) addr:0x02039998
|
||||
func_020399d8 kind:function(arm,size=0x3c) addr:0x020399d8
|
||||
func_02039a14 kind:function(arm,size=0x98) addr:0x02039a14
|
||||
func_02039aac kind:function(arm,size=0xa4) addr:0x02039aac
|
||||
func_02039b50 kind:function(arm,size=0x9c) addr:0x02039b50
|
||||
func_02039bec kind:function(arm,size=0x8c) addr:0x02039bec
|
||||
func_02039c78 kind:function(arm,size=0x8c) addr:0x02039c78
|
||||
_dgr kind:function(arm,size=0x98) addr:0x02039a14
|
||||
_dleq kind:function(arm,size=0xa4) addr:0x02039aac
|
||||
_dls kind:function(arm,size=0x9c) addr:0x02039b50
|
||||
_deq kind:function(arm,size=0x8c) addr:0x02039bec
|
||||
_dneq kind:function(arm,size=0x8c) addr:0x02039c78
|
||||
func_02039d04 kind:function(arm,size=0x5c) addr:0x02039d04
|
||||
func_02039d60 kind:function(arm,size=0x5c) addr:0x02039d60
|
||||
func_02039dbc kind:function(arm,size=0x5c) addr:0x02039dbc
|
||||
func_02039e18 kind:function(arm,size=0x68) addr:0x02039e18
|
||||
func_02039e80 kind:function(arm,size=0x84) addr:0x02039e80
|
||||
_f2d kind:function(arm,size=0x84) addr:0x02039e80
|
||||
func_02039f04 kind:function(arm,size=0x48) addr:0x02039f04
|
||||
func_02039f4c kind:function(arm,size=0x48) addr:0x02039f4c
|
||||
func_02039f94 kind:function(arm,size=0x10) addr:0x02039f94
|
||||
func_02039fa4 kind:function(arm,size=0x1b0) addr:0x02039fa4
|
||||
_ll_udiv kind:function(arm,size=0xc) addr:0x0203a154
|
||||
func_0203a160 kind:function(arm,size=0x3c) addr:0x0203a160
|
||||
_ull_mod kind:function(arm,size=0x3c) addr:0x0203a160
|
||||
func_0203a19c kind:function(arm,size=0x20) addr:0x0203a19c
|
||||
_s32_div_f kind:function(arm,size=0x20c) addr:0x0203a1bc
|
||||
_u32_div_f kind:function(arm,size=0x1e4) addr:0x0203a3c8
|
||||
.L_0203a3d0 kind:label(arm) addr:0x0203a3d0
|
||||
func_0203a5ac kind:function(arm,size=0x34) addr:0x0203a5ac
|
||||
func_0203a5e0 kind:function(arm,size=0x40) addr:0x0203a5e0
|
||||
_ffix kind:function(arm,size=0x34) addr:0x0203a5ac
|
||||
_ffixu kind:function(arm,size=0x40) addr:0x0203a5e0
|
||||
func_0203a620 kind:function(arm,size=0x4c) addr:0x0203a620
|
||||
func_0203a66c kind:function(arm,size=0x8c) addr:0x0203a66c
|
||||
func_0203a6f8 kind:function(arm,size=0x19c) addr:0x0203a6f8
|
||||
_ll_ufrom_d kind:function(arm,size=0x8c) addr:0x0203a66c
|
||||
sqrt kind:function(arm,size=0x19c) addr:0x0203a6f8
|
||||
func_0203a894 kind:function(arm,size=0xe4) addr:0x0203a894
|
||||
func_0203a978 kind:function(arm,size=0x1e0) addr:0x0203a978
|
||||
_fmul kind:function(arm,size=0x1e0) addr:0x0203a978
|
||||
func_0203ab58 kind:function(arm,size=0x21c) addr:0x0203ab58
|
||||
func_0203ad74 kind:function(arm,size=0x8) addr:0x0203ad74
|
||||
func_0203ad88 kind:function(arm,size=0x278) addr:0x0203ad88
|
||||
func_0203b00c kind:function(arm,size=0x3b8) addr:0x0203b00c
|
||||
_fdiv kind:function(arm,size=0x3b8) addr:0x0203b00c
|
||||
_ddiv kind:function(arm,size=0x544) addr:0x0203b3dc
|
||||
func_0203b920 kind:function(arm,size=0x4) addr:0x0203b920
|
||||
func_0203b924 kind:function(arm,size=0xc) addr:0x0203b924
|
||||
_ExitProcess kind:function(arm,size=0xc) addr:0x0203b924
|
||||
func_0203b930 kind:function(arm,size=0x4) addr:0x0203b930
|
||||
func_0203b934 kind:function(arm,size=0x4) addr:0x0203b934
|
||||
func_0203b938 kind:function(arm,size=0x8) addr:0x0203b938
|
||||
sys_ReadChar kind:function(arm,size=0x8) addr:0x0203b938
|
||||
func_0203b940 kind:function(arm,size=0x4) addr:0x0203b940
|
||||
func_0203b944 kind:function(arm,size=0x50) addr:0x0203b944
|
||||
func_0203b994 kind:function(arm,size=0x44) addr:0x0203b994
|
||||
func_0203b9d8 kind:function(arm,size=0x8) addr:0x0203b9d8
|
||||
__read_console kind:function(arm,size=0x50) addr:0x0203b944
|
||||
__write_console kind:function(arm,size=0x44) addr:0x0203b994
|
||||
__close_console kind:function(arm,size=0x8) addr:0x0203b9d8
|
||||
func_0203b9e0 kind:function(arm,size=0x84) addr:0x0203b9e0
|
||||
func_0203ba64 kind:function(arm,size=0x84) addr:0x0203ba64
|
||||
func_0203bae8 kind:function(arm,size=0x64) addr:0x0203bae8
|
||||
_Z12BinarySearchP19ExceptionTableIndexmPc kind:function(arm,size=0x64) addr:0x0203bae8
|
||||
func_0203bb4c kind:function(arm,size=0x108) addr:0x0203bb4c
|
||||
func_0203bc54 kind:function(arm,size=0x1c) addr:0x0203bc54
|
||||
_Z13CurrentActionPK14ActionIterator kind:function(arm,size=0x1c) addr:0x0203bc54
|
||||
func_0203bc70 kind:function(arm,size=0x2bc) addr:0x0203bc70
|
||||
func_0203bf2c kind:function(arm,size=0x82c) addr:0x0203bf2c
|
||||
_Z11UnwindStackP12ThrowContextP13ExceptionInfoPc kind:function(arm,size=0x82c) addr:0x0203bf2c
|
||||
func_0203c758 kind:function(arm,size=0x8) addr:0x0203c758
|
||||
func_0203c760 kind:function(arm,size=0x154) addr:0x0203c760
|
||||
func_0203c8b4 kind:function(arm,size=0x80) addr:0x0203c8b4
|
||||
func_0203c934 kind:function(arm,size=0xac) addr:0x0203c934
|
||||
func_0203c9e0 kind:function(arm,size=0x4) addr:0x0203c9e0
|
||||
func_0203c9e4 kind:function(arm,size=0x60) addr:0x0203c9e4
|
||||
_Z16HandleUnexpectedP12ThrowContextP13ExceptionInfoP16ex_specificationPc kind:function(arm,size=0x60) addr:0x0203c9e4
|
||||
func_0203ca44 kind:function(arm,size=0x1dc) addr:0x0203ca44
|
||||
func_0203cc20 kind:function(arm,size=0x5c) addr:0x0203cc20
|
||||
_Z14SetupCatchInfoP12ThrowContextll kind:function(arm,size=0x5c) addr:0x0203cc20
|
||||
func_0203cc7c kind:function(arm,size=0xf4) addr:0x0203cc7c
|
||||
func_0203cd70 kind:function(arm,size=0x28) addr:0x0203cd70
|
||||
func_0203cd98 kind:function(arm,size=0x14) addr:0x0203cd98
|
||||
func_0203cdac kind:function(arm,size=0xc) addr:0x0203cdac
|
||||
CallStaticInitializers kind:function(arm,size=0x30) addr:0x0203cdb8
|
||||
_Z26__call_static_initializersv kind:function(arm,size=0x30) addr:0x0203cdb8
|
||||
__destroy_global_chain kind:function(arm,size=0x44) addr:0x0203cde8
|
||||
func_0203ce2c kind:function(arm,size=0xc) addr:0x0203ce2c
|
||||
func_0203ce38 kind:function(arm,size=0xc) addr:0x0203ce38
|
||||
@@ -2293,10 +2292,10 @@ data_02042cfc kind:data(any) addr:0x02042cfc
|
||||
data_02042fd0 kind:data(any) addr:0x02042fd0
|
||||
data_02042ff4 kind:data(any) addr:0x02042ff4
|
||||
data_02043034 kind:data(any) addr:0x02043034
|
||||
data_02043088 kind:data(any) addr:0x02043088
|
||||
data_02043188 kind:data(any) addr:0x02043188
|
||||
data_02043198 kind:data(any) addr:0x02043198
|
||||
data_020431a8 kind:data(any) addr:0x020431a8
|
||||
__ctype_mapC kind:data(any) addr:0x02043088
|
||||
dp_h kind:data(any) addr:0x02043188 local
|
||||
bp kind:data(any) addr:0x02043198 local
|
||||
dp_l kind:data(any) addr:0x020431a8 local
|
||||
data_020431b8 kind:data(any) addr:0x020431b8
|
||||
.p__sinit_0203d824 kind:data(word) addr:0x020431c0
|
||||
.p__sinit_0203d840 kind:data(word) addr:0x020431c4
|
||||
@@ -2591,21 +2590,21 @@ data_0204462c kind:data(any) addr:0x0204462c
|
||||
data_02044670 kind:data(any) addr:0x02044670
|
||||
data_02044674 kind:data(any) addr:0x02044674
|
||||
data_020446a4 kind:data(any) addr:0x020446a4
|
||||
data_020446a8 kind:data(any) addr:0x020446a8
|
||||
data_0204478c kind:data(any) addr:0x0204478c
|
||||
data_02044790 kind:data(any) addr:0x02044790
|
||||
data_02044794 kind:data(any) addr:0x02044794
|
||||
data_02044798 kind:data(any) addr:0x02044798
|
||||
data_020447a0 kind:data(any) addr:0x020447a0
|
||||
data_020447a8 kind:data(any) addr:0x020447a8
|
||||
data_020447b8 kind:data(any) addr:0x020447b8
|
||||
data_020447d8 kind:data(any) addr:0x020447d8
|
||||
data_020447e4 kind:data(any) addr:0x020447e4
|
||||
data_020447f0 kind:data(any) addr:0x020447f0
|
||||
data_020447fc kind:data(any) addr:0x020447fc
|
||||
data_0204480c kind:data(any) addr:0x0204480c
|
||||
data_02044864 kind:data(any) addr:0x02044864
|
||||
data_020448ec kind:data(any) addr:0x020448ec
|
||||
__files kind:data(any) addr:0x020446a8
|
||||
__float_nan kind:data(any) addr:0x0204478c
|
||||
@19 kind:data(any) addr:0x02044790 local
|
||||
@16 kind:data(any) addr:0x02044794 local
|
||||
@12 kind:data(any) addr:0x02044798 local
|
||||
__ctype_cmpt kind:data(any) addr:0x020447a0
|
||||
__coll_cmpt kind:data(any) addr:0x020447a8
|
||||
__time_cmpt kind:data(any) addr:0x020447b8
|
||||
@15 kind:data(any) addr:0x020447d8 local
|
||||
_current_locale kind:data(any) addr:0x020447e4
|
||||
@14 kind:data(any) addr:0x020447f0 local
|
||||
@13 kind:data(any) addr:0x020447fc local
|
||||
@17 kind:data(any) addr:0x0204480c local
|
||||
@18 kind:data(any) addr:0x02044864 local
|
||||
char_coll_table kind:data(any) addr:0x020448ec
|
||||
data_020449ac kind:data(any) addr:0x020449ac
|
||||
data_020449b8 kind:data(any) addr:0x020449b8
|
||||
data_020449c4 kind:data(any) addr:0x020449c4
|
||||
@@ -2864,18 +2863,20 @@ data_02050fa4 kind:bss addr:0x02050fa4
|
||||
data_02051060 kind:bss addr:0x02051060
|
||||
data_02051148 kind:bss addr:0x02051148
|
||||
data_0205114c kind:bss addr:0x0205114c
|
||||
data_02051570 kind:bss addr:0x02051570
|
||||
data_02051580 kind:bss addr:0x02051580
|
||||
data_02051680 kind:bss addr:0x02051680
|
||||
data_020516a4 kind:bss addr:0x020516a4
|
||||
data_020516c8 kind:bss addr:0x020516c8
|
||||
data_02051770 kind:bss addr:0x02051770
|
||||
data_020517a0 kind:bss addr:0x020517a0
|
||||
data_020518a0 kind:bss addr:0x020518a0
|
||||
data_020519a0 kind:bss addr:0x020519a0
|
||||
data_02051aa0 kind:bss addr:0x02051aa0
|
||||
data_02051aa4 kind:bss addr:0x02051aa4
|
||||
data_02051aa8 kind:bss addr:0x02051aa8
|
||||
data_02051ac4 kind:bss addr:0x02051ac4
|
||||
data_02051acc kind:bss addr:0x02051acc
|
||||
__console_exit kind:bss addr:0x02051570
|
||||
__stdio_exit kind:bss addr:0x02051574
|
||||
__atexit_curr_func kind:bss addr:0x02051578 local
|
||||
__aborting kind:bss addr:0x0205157c
|
||||
__atexit_funcs kind:bss addr:0x02051580 local
|
||||
__cs_id kind:bss addr:0x02051680
|
||||
__cs_ref kind:bss addr:0x020516a4
|
||||
__cs kind:bss addr:0x020516c8
|
||||
stderr_buff kind:bss addr:0x020517a0 local
|
||||
stdout_buff kind:bss addr:0x020518a0 local
|
||||
stdin_buff kind:bss addr:0x020519a0 local
|
||||
errno kind:bss addr:0x02051aa0
|
||||
__msl_constraint_handler kind:bss addr:0x02051aa4
|
||||
signal_funcs kind:bss addr:0x02051aa8
|
||||
zero kind:bss addr:0x02051ac4 local
|
||||
zero kind:bss addr:0x02051acc local
|
||||
__global_destructor_chain kind:bss(size=0x4) addr:0x02051ad4
|
||||
|
||||
@@ -20,3 +20,131 @@ libs/cpp/src/__register_global_object.c:
|
||||
|
||||
src/Main/func_02017ea4.cpp:
|
||||
.text start:0x02017e3c end:0x02017ed0
|
||||
|
||||
libs/c/src/locale.c:
|
||||
complete
|
||||
.data start:0x02045d04 end:0x02045f20
|
||||
|
||||
libs/c/src/abort_exit_arm_eabi.c:
|
||||
complete
|
||||
.text start:0x02034c18 end:0x02034da0
|
||||
.bss start:0x02052af0 end:0x02052c00
|
||||
|
||||
libs/c/src/ansi_files.c:
|
||||
complete
|
||||
.bss start:0x02052d20 end:0x02053020
|
||||
.data start:0x02045c1c end:0x02045d00
|
||||
.text start:0x02034da0 end:0x02034e04
|
||||
|
||||
libs/c/src/float.c:
|
||||
complete
|
||||
.data start:0x02045d00 end:0x02045d04
|
||||
|
||||
libs/c/src/arith.c:
|
||||
complete
|
||||
.text start:0x02034e04 end:0x02034e1c
|
||||
|
||||
libs/c/src/buffer_io.c:
|
||||
complete
|
||||
.text start:0x02034e1c end:0x02034ecc
|
||||
|
||||
libs/c/src/file_io.c:
|
||||
complete
|
||||
.text start:0x02034ecc end:0x02034fb0
|
||||
|
||||
libs/c/src/math_api.c:
|
||||
complete
|
||||
.text start:0x02035044 end:0x020350d0
|
||||
|
||||
libs/c/src/mbstring.c:
|
||||
complete
|
||||
.text start:0x020350d0 end:0x020351c0
|
||||
|
||||
libs/c/src/mem.c:
|
||||
complete
|
||||
.text start:0x020351c0 end:0x020352ac
|
||||
|
||||
libs/c/src/mem_funcs.c:
|
||||
complete
|
||||
.text start:0x020352ac end:0x02035358
|
||||
|
||||
libs/c/src/secure_error.c:
|
||||
complete
|
||||
.bss start:0x02053024 end:0x02053028
|
||||
.text start:0x02035358 end:0x02035384
|
||||
|
||||
libs/c/src/signal.c:
|
||||
complete
|
||||
.text start:0x02035384 end:0x020354ac
|
||||
.bss start:0x02053028 end:0x02053044
|
||||
|
||||
libs/c/src/string.c:
|
||||
complete
|
||||
.text start:0x020354ac end:0x02035728
|
||||
|
||||
libs/c/src/wmem.c:
|
||||
complete
|
||||
.text start:0x02035728 end:0x02035760
|
||||
|
||||
libs/c/src/wprintf.c:
|
||||
.data start:0x02045f20 end:0x02045fa0
|
||||
.text start:0x02035760 end:0x0203768c
|
||||
|
||||
libs/c/src/wstring.c:
|
||||
complete
|
||||
.text start:0x0203768c end:0x0203774c
|
||||
|
||||
libs/c/src/ansi_fp.c:
|
||||
.data start:0x02045fa0 end:0x02046074
|
||||
.text start:0x0203774c end:0x020380d4
|
||||
|
||||
libs/c/src/extras.c:
|
||||
complete
|
||||
.text start:0x020380d4 end:0x02038100
|
||||
|
||||
libs/c/src/math/e_log.c:
|
||||
complete
|
||||
.bss start:0x02053044 end:0x0205304c
|
||||
.text start:0x02038100 end:0x02038830
|
||||
|
||||
libs/c/src/math/e_log10.c:
|
||||
complete
|
||||
.bss start:0x0205304c end:0x02053054
|
||||
.text start:0x02038830 end:0x02038a08
|
||||
|
||||
libs/c/src/math/e_pow.c:
|
||||
complete
|
||||
.rodata start:0x020446d4 end:0x02044704
|
||||
.text start:0x02038a08 end:0x02039b90
|
||||
|
||||
libs/c/src/math/s_ceil.c:
|
||||
complete
|
||||
.text start:0x02039b90 end:0x02039d50
|
||||
|
||||
libs/c/src/math/s_copysign.c:
|
||||
complete
|
||||
.text start:0x02039d50 end:0x02039d78
|
||||
|
||||
libs/c/src/math/s_fabs.c:
|
||||
complete
|
||||
.text start:0x02039d78 end:0x02039d98
|
||||
|
||||
libs/c/src/math/s_frexp.c:
|
||||
complete
|
||||
.text start:0x02039d98 end:0x02039e58
|
||||
|
||||
libs/c/src/math/s_ldexp.c:
|
||||
complete
|
||||
.text start:0x02039e58 end:0x0203a0b8
|
||||
|
||||
libs/c/src/math/w_log.c:
|
||||
complete
|
||||
.text start:0x0203a0b8 end:0x0203a0c4
|
||||
|
||||
libs/c/src/math/w_log10f.c:
|
||||
complete
|
||||
.text start:0x0203a0c4 end:0x0203a0d0
|
||||
|
||||
libs/c/src/math/w_pow.c:
|
||||
complete
|
||||
.text start:0x0203a0d0 end:0x0203a0dc
|
||||
|
||||
@@ -61,7 +61,7 @@ data_027e0850 kind:bss addr:0x027e0850
|
||||
data_027e0854 kind:bss addr:0x027e0854
|
||||
data_027e0858 kind:bss addr:0x027e0858
|
||||
data_027e085c kind:bss addr:0x027e085c
|
||||
data_027e0860 kind:bss addr:0x027e0860
|
||||
ThreadInfo kind:bss addr:0x027e0860
|
||||
data_027e0864 kind:bss addr:0x027e0864
|
||||
data_027e0870 kind:bss addr:0x027e0870
|
||||
data_027e08f0 kind:bss addr:0x027e08f0
|
||||
|
||||
@@ -5169,7 +5169,7 @@ from:0x020353ac kind:arm_call to:0x02028a28 module:main
|
||||
from:0x0203540c kind:arm_call to:0x02028910 module:main
|
||||
from:0x02035458 kind:arm_call to:0x02028990 module:main
|
||||
from:0x02035484 kind:arm_call to:0x02034c40 module:main
|
||||
from:0x02035498 kind:load to:0x02052cf0 module:main
|
||||
from:0x02035498 kind:load to:0x02052c48 add:0xA8 module:main
|
||||
from:0x0203549c kind:load to:0x027e0860 module:dtcm
|
||||
from:0x020354a0 kind:load to:0x02052c00 module:main
|
||||
from:0x020354a4 kind:load to:0x02052c24 module:main
|
||||
|
||||
+152
-151
@@ -1496,8 +1496,8 @@ func_02027c48 kind:function(arm,size=0x18) addr:0x02027c48
|
||||
func_02027c60 kind:function(arm,size=0x8) addr:0x02027c60
|
||||
func_02027c68 kind:function(arm,size=0x58) addr:0x02027c68
|
||||
func_02027cc0 kind:function(arm,size=0x30) addr:0x02027cc0
|
||||
func_02027cf0 kind:function(arm,size=0x28) addr:0x02027cf0
|
||||
func_02027d18 kind:function(arm,size=0x18) addr:0x02027d18
|
||||
sscanf kind:function(arm,size=0x28) addr:0x02027cf0
|
||||
vsscanf kind:function(arm,size=0x18) addr:0x02027d18
|
||||
func_02027d30 kind:function(arm,size=0x28) addr:0x02027d30
|
||||
func_02027d58 kind:function(arm,size=0xc) addr:0x02027d58
|
||||
func_02027d64 kind:function(arm,size=0x18) addr:0x02027d64
|
||||
@@ -1539,10 +1539,10 @@ func_02028728 kind:function(arm,size=0x94) addr:0x02028728
|
||||
func_020287bc kind:function(arm,size=0xa0) addr:0x020287bc
|
||||
func_0202885c kind:function(arm,size=0x9c) addr:0x0202885c
|
||||
OS_InitMutex kind:function(arm,size=0x18) addr:0x020288f8
|
||||
func_02028910 kind:function(arm,size=0x80) addr:0x02028910
|
||||
func_02028990 kind:function(arm,size=0x5c) addr:0x02028990
|
||||
OS_LockMutex kind:function(arm,size=0x80) addr:0x02028910
|
||||
OS_UnlockMutex kind:function(arm,size=0x5c) addr:0x02028990
|
||||
func_020289ec kind:function(arm,size=0x3c) addr:0x020289ec
|
||||
func_02028a28 kind:function(arm,size=0x70) addr:0x02028a28
|
||||
OS_TryLockMutex kind:function(arm,size=0x70) addr:0x02028a28
|
||||
func_02028a98 kind:function(arm,size=0x24) addr:0x02028a98
|
||||
func_02028abc kind:function(arm,size=0x24) addr:0x02028abc
|
||||
func_02028ae0 kind:function(arm,size=0xc) addr:0x02028ae0
|
||||
@@ -1975,75 +1975,74 @@ func_02034338 kind:function(arm,size=0x54) addr:0x02034338
|
||||
func_0203438c kind:function(arm,size=0x58) addr:0x0203438c
|
||||
func_020343e4 kind:function(arm,size=0x28) addr:0x020343e4
|
||||
func_0203440c kind:function(arm,size=0x80c) addr:0x0203440c
|
||||
func_02034c18 kind:function(arm,size=0x28) addr:0x02034c18
|
||||
func_02034c40 kind:function(arm,size=0x44) addr:0x02034c40
|
||||
func_02034c84 kind:function(arm,size=0x11c) addr:0x02034c84
|
||||
func_02034da0 kind:function(arm,size=0x64) addr:0x02034da0
|
||||
func_02034e04 kind:function(arm,size=0xc) addr:0x02034e04
|
||||
func_02034e10 kind:function(arm,size=0xc) addr:0x02034e10
|
||||
func_02034e1c kind:function(arm,size=0x4) addr:0x02034e1c
|
||||
func_02034e20 kind:function(arm,size=0x28) addr:0x02034e20
|
||||
func_02034e48 kind:function(arm,size=0x84) addr:0x02034e48
|
||||
func_02034ecc kind:function(arm,size=0xe4) addr:0x02034ecc
|
||||
abort kind:function(arm,size=0x28) addr:0x02034c18
|
||||
exit kind:function(arm,size=0x44) addr:0x02034c40
|
||||
__exit kind:function(arm,size=0x11c) addr:0x02034c84
|
||||
__flush_all kind:function(arm,size=0x64) addr:0x02034da0
|
||||
abs kind:function(arm,size=0xc) addr:0x02034e04
|
||||
labs kind:function(arm,size=0xc) addr:0x02034e10
|
||||
__convert_from_newlines kind:function(arm,size=0x4) addr:0x02034e1c
|
||||
__prep_buffer kind:function(arm,size=0x28) addr:0x02034e20
|
||||
__flush_buffer kind:function(arm,size=0x84) addr:0x02034e48
|
||||
fflush kind:function(arm,size=0xe4) addr:0x02034ecc
|
||||
func_02034fb0 kind:function(arm,size=0x94) addr:0x02034fb0
|
||||
func_02035044 kind:function(arm,size=0x1c) addr:0x02035044
|
||||
func_02035060 kind:function(arm,size=0x70) addr:0x02035060
|
||||
func_020350d0 kind:function(arm,size=0x1c) addr:0x020350d0
|
||||
func_020350ec kind:function(arm,size=0x38) addr:0x020350ec
|
||||
func_02035124 kind:function(arm,size=0x14) addr:0x02035124
|
||||
func_02035138 kind:function(arm,size=0x88) addr:0x02035138
|
||||
func_020351c0 kind:function(arm,size=0x20) addr:0x020351c0
|
||||
func_020351e0 kind:function(arm,size=0x4c) addr:0x020351e0
|
||||
func_0203522c kind:function(arm,size=0x14) addr:0x0203522c
|
||||
func_02035240 kind:function(arm,size=0x2c) addr:0x02035240
|
||||
func_0203526c kind:function(arm,size=0x40) addr:0x0203526c
|
||||
func_020352ac kind:function(arm,size=0xac) addr:0x020352ac
|
||||
func_02035358 kind:function(arm,size=0x28) addr:0x02035358
|
||||
func_02035380 kind:function(arm,size=0x4) addr:0x02035380
|
||||
func_02035384 kind:function(arm,size=0x128) addr:0x02035384
|
||||
__signbitd kind:function(arm,size=0x1c) addr:0x02035044
|
||||
__fpclassifyd kind:function(arm,size=0x70) addr:0x02035060
|
||||
mbtowc kind:function(arm,size=0x1c) addr:0x020350d0
|
||||
__mbtowc_noconv kind:function(arm,size=0x38) addr:0x020350ec
|
||||
__wctomb_noconv kind:function(arm,size=0x14) addr:0x02035124
|
||||
mbstowcs kind:function(arm,size=0x88) addr:0x02035138
|
||||
memcpy kind:function(arm,size=0x20) addr:0x020351c0
|
||||
memmove kind:function(arm,size=0x4c) addr:0x020351e0
|
||||
memset kind:function(arm,size=0x14) addr:0x0203522c
|
||||
memchr kind:function(arm,size=0x2c) addr:0x02035240
|
||||
memcmp kind:function(arm,size=0x40) addr:0x0203526c
|
||||
__fill_mem kind:function(arm,size=0xac) addr:0x020352ac
|
||||
__msl_runtime_constraint_violation_s kind:function(arm,size=0x28) addr:0x02035358
|
||||
secure_error_func_02033e50 kind:function(arm,size=0x4) addr:0x02035380
|
||||
raise kind:function(arm,size=0x128) addr:0x02035384
|
||||
strlen kind:function(arm,size=0x1c) addr:0x020354ac
|
||||
func_020354c8 kind:function(arm,size=0xc8) addr:0x020354c8
|
||||
strcpy kind:function(arm,size=0xc8) addr:0x020354c8
|
||||
strncpy kind:function(arm,size=0x50) addr:0x02035590
|
||||
func_020355e0 kind:function(arm,size=0x114) addr:0x020355e0
|
||||
func_020356f4 kind:function(arm,size=0x34) addr:0x020356f4
|
||||
func_02035728 kind:function(arm,size=0x10) addr:0x02035728
|
||||
func_02035738 kind:function(arm,size=0x28) addr:0x02035738
|
||||
func_02035760 kind:function(arm,size=0x518) addr:0x02035760
|
||||
func_02035c78 kind:function(arm,size=0x24c) addr:0x02035c78
|
||||
func_02035ec4 kind:function(arm,size=0x2d8) addr:0x02035ec4
|
||||
func_0203619c kind:function(arm,size=0x3c0) addr:0x0203619c
|
||||
func_0203655c kind:function(arm,size=0x114) addr:0x0203655c
|
||||
func_02036670 kind:function(arm,size=0x5f8) addr:0x02036670
|
||||
func_02036c68 kind:function(arm,size=0x95c) addr:0x02036c68
|
||||
func_020375c4 kind:function(arm,size=0x40) addr:0x020375c4
|
||||
func_02037604 kind:function(arm,size=0x28) addr:0x02037604
|
||||
func_0203762c kind:function(arm,size=0x60) addr:0x0203762c
|
||||
func_0203768c kind:function(arm,size=0x1c) addr:0x0203768c
|
||||
func_020376a8 kind:function(arm,size=0x20) addr:0x020376a8
|
||||
func_020376c8 kind:function(arm,size=0x50) addr:0x020376c8
|
||||
func_02037718 kind:function(arm,size=0x34) addr:0x02037718
|
||||
func_0203774c kind:function(arm,size=0x6c) addr:0x0203774c
|
||||
func_020377b8 kind:function(arm,size=0x4c) addr:0x020377b8
|
||||
func_02037804 kind:function(arm,size=0x4) addr:0x02037804
|
||||
func_02037808 kind:function(arm,size=0x40) addr:0x02037808
|
||||
func_02037848 kind:function(arm,size=0xc4) addr:0x02037848
|
||||
func_0203790c kind:function(arm,size=0x180) addr:0x0203790c
|
||||
func_02037a8c kind:function(arm,size=0x9c) addr:0x02037a8c
|
||||
func_02037b28 kind:function(arm,size=0x380) addr:0x02037b28
|
||||
func_02037ea8 kind:function(arm,size=0x180) addr:0x02037ea8
|
||||
func_02038028 kind:function(arm,size=0xac) addr:0x02038028
|
||||
func_020380d4 kind:function(arm,size=0x2c) addr:0x020380d4
|
||||
func_02038100 kind:function(arm,size=0x730) addr:0x02038100
|
||||
func_02038830 kind:function(arm,size=0x1d8) addr:0x02038830
|
||||
func_02038a08 kind:function(arm,size=0x1188) addr:0x02038a08
|
||||
func_02039b90 kind:function(arm,size=0x1c0) addr:0x02039b90
|
||||
func_02039d50 kind:function(arm,size=0x28) addr:0x02039d50
|
||||
func_02039d78 kind:function(arm,size=0x20) addr:0x02039d78
|
||||
func_02039d98 kind:function(arm,size=0xc0) addr:0x02039d98
|
||||
func_02039e58 kind:function(arm,size=0x260) addr:0x02039e58
|
||||
func_0203a0b8 kind:function(arm,size=0xc) addr:0x0203a0b8
|
||||
func_0203a0c4 kind:function(arm,size=0xc) addr:0x0203a0c4
|
||||
func_0203a0d0 kind:function(arm,size=0xc) addr:0x0203a0d0
|
||||
strcmp kind:function(arm,size=0x114) addr:0x020355e0
|
||||
strncmp kind:function(arm,size=0x34) addr:0x020356f4
|
||||
wmemcpy kind:function(arm,size=0x10) addr:0x02035728
|
||||
wmemchr kind:function(arm,size=0x28) addr:0x02035738
|
||||
parse_format kind:function(arm,size=0x518) addr:0x02035760
|
||||
long2str kind:function(arm,size=0x24c) addr:0x02035c78
|
||||
longlong2str kind:function(arm,size=0x2d8) addr:0x02035ec4
|
||||
double2hex kind:function(arm,size=0x3c0) addr:0x0203619c
|
||||
round_decimal kind:function(arm,size=0x114) addr:0x0203655c
|
||||
float2str kind:function(arm,size=0x5f8) addr:0x02036670
|
||||
__wpformatter kind:function(arm,size=0x95c) addr:0x02036c68
|
||||
__wStringWrite kind:function(arm,size=0x40) addr:0x020375c4
|
||||
swprintf kind:function(arm,size=0x28) addr:0x02037604
|
||||
vswprintf kind:function(arm,size=0x60) addr:0x0203762c
|
||||
wcslen kind:function(arm,size=0x1c) addr:0x0203768c
|
||||
wcscpy kind:function(arm,size=0x20) addr:0x020376a8
|
||||
wcsncpy kind:function(arm,size=0x50) addr:0x020376c8
|
||||
wcschr kind:function(arm,size=0x34) addr:0x02037718
|
||||
__must_round kind:function(arm,size=0x6c) addr:0x0203774c
|
||||
__dorounddecup kind:function(arm,size=0x50) addr:0x020377b8
|
||||
__rounddec kind:function(arm,size=0x40) addr:0x02037808
|
||||
__ull2dec kind:function(arm,size=0xc4) addr:0x02037848
|
||||
__timesdec kind:function(arm,size=0x180) addr:0x0203790c
|
||||
__str2dec kind:function(arm,size=0x9c) addr:0x02037a8c
|
||||
__two_exp kind:function(arm,size=0x380) addr:0x02037b28
|
||||
__num2dec_internal kind:function(arm,size=0x180) addr:0x02037ea8
|
||||
__num2dec kind:function(arm,size=0xac) addr:0x02038028
|
||||
scalbn kind:function(arm,size=0x2c) addr:0x020380d4
|
||||
__ieee754_log kind:function(arm,size=0x730) addr:0x02038100
|
||||
__ieee754_log10 kind:function(arm,size=0x1d8) addr:0x02038830
|
||||
__ieee754_pow kind:function(arm,size=0x1188) addr:0x02038a08
|
||||
ceil kind:function(arm,size=0x1c0) addr:0x02039b90
|
||||
copysign kind:function(arm,size=0x28) addr:0x02039d50
|
||||
fabs kind:function(arm,size=0x20) addr:0x02039d78
|
||||
frexp kind:function(arm,size=0xc0) addr:0x02039d98
|
||||
ldexp kind:function(arm,size=0x260) addr:0x02039e58
|
||||
log kind:function(arm,size=0xc) addr:0x0203a0b8
|
||||
log10f kind:function(arm,size=0xc) addr:0x0203a0c4
|
||||
pow kind:function(arm,size=0xc) addr:0x0203a0d0
|
||||
func_0203a0dc kind:function(arm,size=0x78) addr:0x0203a0dc
|
||||
func_0203a154 kind:function(arm,size=0x28) addr:0x0203a154
|
||||
func_0203a17c kind:function(arm,size=0x10) addr:0x0203a17c
|
||||
@@ -2062,75 +2061,75 @@ func_0203a274 kind:function(arm,size=0x20) addr:0x0203a274
|
||||
func_0203a294 kind:function(arm,size=0x30) addr:0x0203a294
|
||||
func_0203a2c4 kind:function(arm,size=0x2c) addr:0x0203a2c4
|
||||
func_0203a2f0 kind:function(arm,size=0x8c) addr:0x0203a2f0
|
||||
func_0203a37c kind:function(arm,size=0x318) addr:0x0203a37c
|
||||
func_0203a6ac kind:function(arm,size=0x3b4) addr:0x0203a6ac
|
||||
_dadd kind:function(arm,size=0x318) addr:0x0203a37c
|
||||
_dsub kind:function(arm,size=0x3b4) addr:0x0203a6ac
|
||||
_dmul kind:function(arm,size=0x364) addr:0x0203aa60
|
||||
_fflt kind:function(arm,size=0x104) addr:0x0203adc4
|
||||
_dflt kind:function(arm,size=0x40) addr:0x0203aec8
|
||||
func_0203af08 kind:function(arm,size=0x3c) addr:0x0203af08
|
||||
func_0203af44 kind:function(arm,size=0x98) addr:0x0203af44
|
||||
func_0203afdc kind:function(arm,size=0xa4) addr:0x0203afdc
|
||||
func_0203b080 kind:function(arm,size=0x9c) addr:0x0203b080
|
||||
func_0203b11c kind:function(arm,size=0x8c) addr:0x0203b11c
|
||||
func_0203b1a8 kind:function(arm,size=0x8c) addr:0x0203b1a8
|
||||
_dgr kind:function(arm,size=0x98) addr:0x0203af44
|
||||
_dleq kind:function(arm,size=0xa4) addr:0x0203afdc
|
||||
_dls kind:function(arm,size=0x9c) addr:0x0203b080
|
||||
_deq kind:function(arm,size=0x8c) addr:0x0203b11c
|
||||
_dneq kind:function(arm,size=0x8c) addr:0x0203b1a8
|
||||
func_0203b234 kind:function(arm,size=0x5c) addr:0x0203b234
|
||||
func_0203b290 kind:function(arm,size=0x5c) addr:0x0203b290
|
||||
func_0203b2ec kind:function(arm,size=0x5c) addr:0x0203b2ec
|
||||
func_0203b348 kind:function(arm,size=0x68) addr:0x0203b348
|
||||
func_0203b3b0 kind:function(arm,size=0x84) addr:0x0203b3b0
|
||||
_f2d kind:function(arm,size=0x84) addr:0x0203b3b0
|
||||
func_0203b434 kind:function(arm,size=0x48) addr:0x0203b434
|
||||
func_0203b47c kind:function(arm,size=0x48) addr:0x0203b47c
|
||||
func_0203b4c4 kind:function(arm,size=0x10) addr:0x0203b4c4
|
||||
func_0203b4d4 kind:function(arm,size=0x1b0) addr:0x0203b4d4
|
||||
_ll_udiv kind:function(arm,size=0xc) addr:0x0203b684
|
||||
func_0203b690 kind:function(arm,size=0x3c) addr:0x0203b690
|
||||
_ull_mod kind:function(arm,size=0x3c) addr:0x0203b690
|
||||
func_0203b6cc kind:function(arm,size=0x20) addr:0x0203b6cc
|
||||
_s32_div_f kind:function(arm,size=0x20c) addr:0x0203b6ec
|
||||
_u32_div_f kind:function(arm,size=0x1e4) addr:0x0203b8f8
|
||||
.L_0203b900 kind:label(arm) addr:0x0203b900
|
||||
func_0203badc kind:function(arm,size=0x34) addr:0x0203badc
|
||||
func_0203bb10 kind:function(arm,size=0x40) addr:0x0203bb10
|
||||
_ffix kind:function(arm,size=0x34) addr:0x0203badc
|
||||
_ffixu kind:function(arm,size=0x40) addr:0x0203bb10
|
||||
func_0203bb50 kind:function(arm,size=0x4c) addr:0x0203bb50
|
||||
func_0203bb9c kind:function(arm,size=0x8c) addr:0x0203bb9c
|
||||
func_0203bc28 kind:function(arm,size=0x19c) addr:0x0203bc28
|
||||
_ll_ufrom_d kind:function(arm,size=0x8c) addr:0x0203bb9c
|
||||
sqrt kind:function(arm,size=0x19c) addr:0x0203bc28
|
||||
func_0203bdc4 kind:function(arm,size=0xe4) addr:0x0203bdc4
|
||||
func_0203bea8 kind:function(arm,size=0x1e0) addr:0x0203bea8
|
||||
_fmul kind:function(arm,size=0x1e0) addr:0x0203bea8
|
||||
func_0203c088 kind:function(arm,size=0x21c) addr:0x0203c088
|
||||
func_0203c2a4 kind:function(arm,size=0x8) addr:0x0203c2a4
|
||||
func_0203c2b8 kind:function(arm,size=0x278) addr:0x0203c2b8
|
||||
func_0203c53c kind:function(arm,size=0x3b8) addr:0x0203c53c
|
||||
_fdiv kind:function(arm,size=0x3b8) addr:0x0203c53c
|
||||
.L_0203c5f0 kind:data(byte[0]) addr:0x0203c5f0
|
||||
_ddiv kind:function(arm,size=0x544) addr:0x0203c90c
|
||||
.L_0203ca44 kind:data(byte[0]) addr:0x0203ca44
|
||||
func_0203b920 kind:function(arm,size=0x4) addr:0x0203ce50
|
||||
func_0203ce54 kind:function(arm,size=0xc) addr:0x0203ce54
|
||||
_ExitProcess kind:function(arm,size=0xc) addr:0x0203ce54
|
||||
func_0203ce60 kind:function(arm,size=0x4) addr:0x0203ce60
|
||||
func_0203ce64 kind:function(arm,size=0x4) addr:0x0203ce64
|
||||
func_0203ce68 kind:function(arm,size=0x8) addr:0x0203ce68
|
||||
sys_ReadChar kind:function(arm,size=0x8) addr:0x0203ce68
|
||||
func_0203ce70 kind:function(arm,size=0x4) addr:0x0203ce70
|
||||
func_0203ce74 kind:function(arm,size=0x50) addr:0x0203ce74
|
||||
func_0203cec4 kind:function(arm,size=0x44) addr:0x0203cec4
|
||||
func_0203cf08 kind:function(arm,size=0x8) addr:0x0203cf08
|
||||
__read_console kind:function(arm,size=0x50) addr:0x0203ce74
|
||||
__write_console kind:function(arm,size=0x44) addr:0x0203cec4
|
||||
__close_console kind:function(arm,size=0x8) addr:0x0203cf08
|
||||
func_0203cf10 kind:function(arm,size=0x84) addr:0x0203cf10
|
||||
func_0203cf94 kind:function(arm,size=0x84) addr:0x0203cf94
|
||||
func_0203d018 kind:function(arm,size=0x64) addr:0x0203d018
|
||||
_Z12BinarySearchP19ExceptionTableIndexmPc kind:function(arm,size=0x64) addr:0x0203d018
|
||||
func_0203d07c kind:function(arm,size=0x108) addr:0x0203d07c
|
||||
func_0203d184 kind:function(arm,size=0x1c) addr:0x0203d184
|
||||
_Z13CurrentActionPK14ActionIterator kind:function(arm,size=0x1c) addr:0x0203d184
|
||||
func_0203d1a0 kind:function(arm,size=0x2bc) addr:0x0203d1a0
|
||||
func_0203d45c kind:function(arm,size=0x82c) addr:0x0203d45c
|
||||
_Z11UnwindStackP12ThrowContextP13ExceptionInfoPc kind:function(arm,size=0x82c) addr:0x0203d45c
|
||||
func_0203dc88 kind:function(arm,size=0x8) addr:0x0203dc88
|
||||
func_0203dc90 kind:function(arm,size=0x154) addr:0x0203dc90
|
||||
func_0203dde4 kind:function(arm,size=0x80) addr:0x0203dde4
|
||||
func_0203de64 kind:function(arm,size=0xac) addr:0x0203de64
|
||||
func_0203df10 kind:function(arm,size=0x4) addr:0x0203df10
|
||||
func_0203df14 kind:function(arm,size=0x60) addr:0x0203df14
|
||||
_Z16HandleUnexpectedP12ThrowContextP13ExceptionInfoP16ex_specificationPc kind:function(arm,size=0x60) addr:0x0203df14
|
||||
func_0203df74 kind:function(arm,size=0x1dc) addr:0x0203df74
|
||||
func_0203e150 kind:function(arm,size=0x5c) addr:0x0203e150
|
||||
_Z14SetupCatchInfoP12ThrowContextll kind:function(arm,size=0x5c) addr:0x0203e150
|
||||
func_0203e1ac kind:function(arm,size=0xf4) addr:0x0203e1ac
|
||||
func_0203cd70 kind:function(arm,size=0x28) addr:0x0203e2a0
|
||||
func_0203e2c8 kind:function(arm,size=0x14) addr:0x0203e2c8
|
||||
func_0203e2dc kind:function(arm,size=0xc) addr:0x0203e2dc
|
||||
CallStaticInitializers kind:function(arm,size=0x30) addr:0x0203e2e8
|
||||
_Z26__call_static_initializersv kind:function(arm,size=0x30) addr:0x0203e2e8
|
||||
__destroy_global_chain kind:function(arm,size=0x44) addr:0x0203e318
|
||||
func_0203e35c kind:function(arm,size=0xc) addr:0x0203e35c
|
||||
func_0203e368 kind:function(arm,size=0xc) addr:0x0203e368
|
||||
@@ -2317,10 +2316,10 @@ data_02044248 kind:data(any) addr:0x02044248
|
||||
data_0204451c kind:data(any) addr:0x0204451c
|
||||
data_02044540 kind:data(any) addr:0x02044540
|
||||
data_02044580 kind:data(any) addr:0x02044580
|
||||
data_020445d4 kind:data(any) addr:0x020445d4
|
||||
data_020446d4 kind:data(any) addr:0x020446d4
|
||||
data_020446e4 kind:data(any) addr:0x020446e4
|
||||
data_020446f4 kind:data(any) addr:0x020446f4
|
||||
__ctype_mapC kind:data(any) addr:0x020445d4
|
||||
dp_h kind:data(any) addr:0x020446d4 local
|
||||
bp kind:data(any) addr:0x020446e4 local
|
||||
dp_l kind:data(any) addr:0x020446f4 local
|
||||
data_02044704 kind:data(any) addr:0x02044704
|
||||
.p__sinit_0203ed54 kind:data(word) addr:0x0204470c
|
||||
.p__sinit_0203ed70 kind:data(word) addr:0x02044710
|
||||
@@ -2614,21 +2613,21 @@ data_02045ba0 kind:data(any) addr:0x02045ba0
|
||||
data_02045be4 kind:data(any) addr:0x02045be4
|
||||
data_02045be8 kind:data(any) addr:0x02045be8
|
||||
data_02045c18 kind:data(any) addr:0x02045c18
|
||||
data_02045c1c kind:data(any) addr:0x02045c1c
|
||||
data_02045d00 kind:data(any) addr:0x02045d00
|
||||
data_02045d04 kind:data(any) addr:0x02045d04
|
||||
data_02045d08 kind:data(any) addr:0x02045d08
|
||||
data_02045d0c kind:data(any) addr:0x02045d0c
|
||||
data_02045d14 kind:data(any) addr:0x02045d14
|
||||
data_02045d1c kind:data(any) addr:0x02045d1c
|
||||
data_02045d2c kind:data(any) addr:0x02045d2c
|
||||
data_02045d4c kind:data(any) addr:0x02045d4c
|
||||
data_02045d58 kind:data(any) addr:0x02045d58
|
||||
data_02045d64 kind:data(any) addr:0x02045d64
|
||||
data_02045d70 kind:data(any) addr:0x02045d70
|
||||
data_02045d80 kind:data(any) addr:0x02045d80
|
||||
data_02045dd8 kind:data(any) addr:0x02045dd8
|
||||
data_02045e60 kind:data(any) addr:0x02045e60
|
||||
__files kind:data(any) addr:0x02045c1c
|
||||
__float_nan kind:data(any) addr:0x02045d00
|
||||
@19 kind:data(any) addr:0x02045d04 local
|
||||
@16 kind:data(any) addr:0x02045d08 local
|
||||
@12 kind:data(any) addr:0x02045d0c local
|
||||
__ctype_cmpt kind:data(any) addr:0x02045d14
|
||||
__coll_cmpt kind:data(any) addr:0x02045d1c
|
||||
__time_cmpt kind:data(any) addr:0x02045d2c
|
||||
@15 kind:data(any) addr:0x02045d4c local
|
||||
_current_locale kind:data(any) addr:0x02045d58
|
||||
@14 kind:data(any) addr:0x02045d64 local
|
||||
@13 kind:data(any) addr:0x02045d70 local
|
||||
@17 kind:data(any) addr:0x02045d80 local
|
||||
@18 kind:data(any) addr:0x02045dd8 local
|
||||
char_coll_table kind:data(any) addr:0x02045e60
|
||||
data_02045f20 kind:data(any) addr:0x02045f20
|
||||
data_02045f2c kind:data(any) addr:0x02045f2c
|
||||
data_02045f38 kind:data(any) addr:0x02045f38
|
||||
@@ -2643,27 +2642,27 @@ data_02045f88 kind:data(any) addr:0x02045f88
|
||||
data_02045f90 kind:data(any) addr:0x02045f90
|
||||
data_02045f98 kind:data(any) addr:0x02045f98
|
||||
data_02045f9c kind:data(any) addr:0x02045f9c
|
||||
data_02045fa0 kind:data(any) addr:0x02045fa0
|
||||
data_02045fd0 kind:data(any) addr:0x02045fd0
|
||||
data_02045ff8 kind:data(any) addr:0x02045ff8
|
||||
data_02046010 kind:data(any) addr:0x02046010
|
||||
data_02046020 kind:data(any) addr:0x02046020
|
||||
data_02046028 kind:data(any) addr:0x02046028
|
||||
data_02046030 kind:data(any) addr:0x02046030
|
||||
data_02046038 kind:data(any) addr:0x02046038
|
||||
data_02046040 kind:data(any) addr:0x02046040
|
||||
data_02046044 kind:data(any) addr:0x02046044
|
||||
data_02046048 kind:data(any) addr:0x02046048
|
||||
data_0204604c kind:data(any) addr:0x0204604c
|
||||
data_02046050 kind:data(any) addr:0x02046050
|
||||
data_02046054 kind:data(any) addr:0x02046054
|
||||
data_02046058 kind:data(any) addr:0x02046058
|
||||
data_0204605c kind:data(any) addr:0x0204605c
|
||||
data_02046060 kind:data(any) addr:0x02046060
|
||||
data_02046064 kind:data(any) addr:0x02046064
|
||||
data_02046068 kind:data(any) addr:0x02046068
|
||||
data_0204606c kind:data(any) addr:0x0204606c
|
||||
data_02046070 kind:data(any) addr:0x02046070
|
||||
@311 kind:data(any) addr:0x02045fa0 local
|
||||
@312 kind:data(any) addr:0x02045fd0 local
|
||||
@313 kind:data(any) addr:0x02045ff8 local
|
||||
@314 kind:data(any) addr:0x02046010 local
|
||||
@315 kind:data(any) addr:0x02046020 local
|
||||
@316 kind:data(any) addr:0x02046028 local
|
||||
@317 kind:data(any) addr:0x02046030 local
|
||||
@318 kind:data(any) addr:0x02046038 local
|
||||
@319 kind:data(any) addr:0x02046040 local
|
||||
@320 kind:data(any) addr:0x02046044 local
|
||||
@321 kind:data(any) addr:0x02046048 local
|
||||
@322 kind:data(any) addr:0x0204604c local
|
||||
@323 kind:data(any) addr:0x02046050 local
|
||||
@324 kind:data(any) addr:0x02046054 local
|
||||
@325 kind:data(any) addr:0x02046058 local
|
||||
@326 kind:data(any) addr:0x0204605c local
|
||||
@327 kind:data(any) addr:0x02046060 local
|
||||
@328 kind:data(any) addr:0x02046064 local
|
||||
@329 kind:data(any) addr:0x02046068 local
|
||||
@330 kind:data(any) addr:0x0204606c local
|
||||
@331 kind:data(any) addr:0x02046070 local
|
||||
data_02046074 kind:data(any) addr:0x02046074
|
||||
data_0204607c kind:data(any) addr:0x0204607c
|
||||
data_02046084 kind:data(any) addr:0x02046084
|
||||
@@ -2886,18 +2885,20 @@ data_02052524 kind:bss addr:0x02052524
|
||||
data_020525e0 kind:bss addr:0x020525e0
|
||||
data_020526c8 kind:bss addr:0x020526c8
|
||||
data_020526cc kind:bss addr:0x020526cc
|
||||
data_02052af0 kind:bss addr:0x02052af0
|
||||
data_02052b00 kind:bss addr:0x02052b00
|
||||
data_02052c00 kind:bss addr:0x02052c00
|
||||
data_02052c24 kind:bss addr:0x02052c24
|
||||
data_02052c48 kind:bss addr:0x02052c48
|
||||
data_02052cf0 kind:bss addr:0x02052cf0
|
||||
data_02052d20 kind:bss addr:0x02052d20
|
||||
data_02052e20 kind:bss addr:0x02052e20
|
||||
data_02052f20 kind:bss addr:0x02052f20
|
||||
data_02053020 kind:bss addr:0x02053020
|
||||
data_02053024 kind:bss addr:0x02053024
|
||||
data_02053028 kind:bss addr:0x02053028
|
||||
data_02053044 kind:bss addr:0x02053044
|
||||
data_0205304c kind:bss addr:0x0205304c
|
||||
__console_exit kind:bss addr:0x02052af0
|
||||
__stdio_exit kind:bss addr:0x02052af4
|
||||
__atexit_curr_func kind:bss addr:0x02052af8 local
|
||||
__aborting kind:bss addr:0x02052afc
|
||||
__atexit_funcs kind:bss addr:0x02052b00 local
|
||||
__cs_id kind:bss addr:0x02052c00
|
||||
__cs_ref kind:bss addr:0x02052c24
|
||||
__cs kind:bss addr:0x02052c48
|
||||
stderr_buff kind:bss addr:0x02052d20 local
|
||||
stdout_buff kind:bss addr:0x02052e20 local
|
||||
stdin_buff kind:bss addr:0x02052f20 local
|
||||
errno kind:bss addr:0x02053020
|
||||
__msl_constraint_handler kind:bss addr:0x02053024
|
||||
signal_funcs kind:bss addr:0x02053028
|
||||
zero kind:bss addr:0x02053044 local
|
||||
zero kind:bss addr:0x0205304c local
|
||||
__global_destructor_chain kind:bss(size=0x4) addr:0x02053054
|
||||
|
||||
@@ -0,0 +1,15 @@
|
||||
#ifndef NITROSDK_OS_CONTEXT_H
|
||||
#define NITROSDK_OS_CONTEXT_H
|
||||
|
||||
#include <types.h>
|
||||
|
||||
typedef struct OSContext {
|
||||
/* 0x00 */ u32 cpsr;
|
||||
/* 0x04 */ u32 r[13];
|
||||
/* 0x38 */ u32 sp;
|
||||
/* 0x3C */ u32 lr;
|
||||
/* 0x40 */ u32 pc;
|
||||
/* 0x44 */ char unk_40[0x20];
|
||||
} OSContext; // Size: 0x64
|
||||
|
||||
#endif // NITROSDK_OS_CONTEXT_H
|
||||
@@ -0,0 +1,20 @@
|
||||
#ifndef NITROSDK_OS_MUTEX_H
|
||||
#define NITROSDK_OS_MUTEX_H
|
||||
|
||||
#include <nitro/os/thread.h>
|
||||
#include <types.h>
|
||||
|
||||
typedef struct OSMutex {
|
||||
/* 0x00 */ OSThreadQueue queue;
|
||||
/* 0x08 */ OSThread *thread;
|
||||
/* 0x0C */ s32 count;
|
||||
/* 0x10 */ OSMutexLinkedList list;
|
||||
} OSMutex; // Size: 0x18
|
||||
|
||||
void OS_InitMutex(OSMutex *mutex);
|
||||
void OS_LockMutex(OSMutex *mutex);
|
||||
void OS_UnlockMutex(OSMutex *mutex);
|
||||
void OS_UnlockAllQueuedThreadMutex(OSThread *thread);
|
||||
bool OS_TryLockMutex(OSMutex *mutex);
|
||||
|
||||
#endif
|
||||
@@ -0,0 +1,98 @@
|
||||
#ifndef NITROSDK_OS_THREAD_H
|
||||
#define NITROSDK_OS_THREAD_H
|
||||
|
||||
#include <nitro/os/context.h>
|
||||
|
||||
/// MARK: Types
|
||||
|
||||
typedef struct OSThread OSThread;
|
||||
typedef struct OSMutex OSMutex;
|
||||
|
||||
typedef void (*OSThreadSwitchCallback)(OSThread *oldThread, OSThread *newThread);
|
||||
typedef void (*OSThreadDestructor)(void *);
|
||||
|
||||
typedef struct OSThreadLinkedList {
|
||||
/* 0x04 */ OSThread *prev;
|
||||
/* 0x00 */ OSThread *next;
|
||||
} OSThreadLinkedList;
|
||||
|
||||
typedef struct OSMutexQueue {
|
||||
/* 0x00 */ OSMutex *head;
|
||||
/* 0x04 */ OSMutex *tail;
|
||||
} OSMutexQueue;
|
||||
|
||||
typedef struct OSMutexLinkedList {
|
||||
/* 0x00 */ OSMutex *next;
|
||||
/* 0x04 */ OSMutex *prev;
|
||||
} OSMutexLinkedList;
|
||||
|
||||
typedef struct OSThreadQueue {
|
||||
/* 0x00 */ OSThread *head;
|
||||
/* 0x04 */ OSThread *tail;
|
||||
} OSThreadQueue;
|
||||
|
||||
typedef struct OSThreadInfo {
|
||||
/* 0x00 */ u16 isSchedulerWaiting;
|
||||
/* 0x02 */ u16 irqDepth;
|
||||
/* 0x10 */ OSThread *current;
|
||||
/* 0x14 */ OSThread *list;
|
||||
/* 0x18 */ OSThreadSwitchCallback callback;
|
||||
} OSThreadInfo;
|
||||
|
||||
typedef struct OSThread {
|
||||
/* 0x00 */ OSContext context;
|
||||
/* 0x64 */ s32 state;
|
||||
/* 0x68 */ OSThread *next;
|
||||
/* 0x6C */ u32 id;
|
||||
/* 0x70 */ u32 priority;
|
||||
/* 0x74 */ void *profiler;
|
||||
/* 0x78 */ OSThreadQueue *queue;
|
||||
/* 0x7C */ OSThreadLinkedList list;
|
||||
/* 0x84 */ OSMutex *mutex;
|
||||
/* 0x88 */ OSMutexQueue mutexQueue;
|
||||
/* 0x90 */ u32 stackTop;
|
||||
/* 0x94 */ u32 stackBottom;
|
||||
/* 0x98 */ u32 stackOffset;
|
||||
/* 0x9C */ OSThreadQueue joinQueue;
|
||||
/* 0xA4 */ void *unk_A4[3];
|
||||
/* 0xB0 */ void *unk_B0;
|
||||
/* 0xB4 */ OSThreadDestructor destructor;
|
||||
/* 0xB8 */ void *userParam;
|
||||
/* 0xBC */ s32 error;
|
||||
} OSThread; // Size: 0xC0
|
||||
|
||||
extern OSThreadInfo ThreadInfo;
|
||||
|
||||
/// MARK: Functions
|
||||
|
||||
void OS_PauseThread(OSThreadQueue *queue);
|
||||
void OS_UnpauseThread(OSThreadQueue *queue);
|
||||
OSMutex *OS_RemoveMutexFromQueue(OSMutexQueue *queue);
|
||||
OSThread *OS_SelectThread(void);
|
||||
void OS_CreateThread(OSThread *thread, void (*func)(void *), void *arg, void *stack, u32 stackSize, u32 priority);
|
||||
void OS_ExitThread(void);
|
||||
|
||||
/// MARK: Inlines
|
||||
|
||||
static inline void OS_InitThreadQueue(OSThreadQueue *queue) {
|
||||
queue->tail = NULL;
|
||||
queue->head = NULL;
|
||||
}
|
||||
|
||||
static inline OSThreadInfo *OS_GetThreadInfo(void) {
|
||||
return &ThreadInfo;
|
||||
}
|
||||
|
||||
static inline OSThread *OS_GetCurrentThread(void) {
|
||||
return OS_GetThreadInfo()->current;
|
||||
}
|
||||
|
||||
static inline void OS_SetCurrentThread(OSThread *thread) {
|
||||
OS_GetThreadInfo()->current = thread;
|
||||
}
|
||||
|
||||
static inline u32 OS_GetThreadId(OSThread *thread) {
|
||||
return thread->id;
|
||||
}
|
||||
|
||||
#endif // NITROSDK_OS_THREAD_H
|
||||
+3
-4
@@ -13,14 +13,13 @@ typedef int s32;
|
||||
typedef short s16;
|
||||
typedef char s8;
|
||||
|
||||
typedef float f32;
|
||||
typedef double f64;
|
||||
|
||||
typedef s8 unk8;
|
||||
typedef s16 unk16;
|
||||
typedef s32 unk32;
|
||||
|
||||
#ifndef __cplusplus
|
||||
typedef s32 bool;
|
||||
#endif
|
||||
|
||||
#define CEIL_DIV(a, b) (((a) + (b) - 1) / (b))
|
||||
|
||||
#endif
|
||||
|
||||
@@ -0,0 +1,19 @@
|
||||
#ifndef _C_ABORT_EXIT_ARM_EABI_H
|
||||
#define _C_ABORT_EXIT_ARM_EABI_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#define SIGABRT 1
|
||||
#define EXIT_FAILURE 1
|
||||
|
||||
void abort(void);
|
||||
void exit(int status);
|
||||
void __exit(int status);
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif
|
||||
@@ -0,0 +1,19 @@
|
||||
#ifndef _C_ANSI_FILES_H
|
||||
#define _C_ANSI_FILES_H
|
||||
|
||||
#include <file_struc.h>
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#define console_buff_mode _IOLBF
|
||||
#define console_buff_size 256
|
||||
|
||||
typedef unsigned char console_buff[console_buff_size];
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif
|
||||
@@ -0,0 +1,43 @@
|
||||
#ifndef _C_ANSI_FP_H
|
||||
#define _C_ANSI_FP_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#define FLOATDECIMAL ((char) (0))
|
||||
#define FIXEDDECIMAL ((char) (1))
|
||||
|
||||
#define DBL_MIN 0x1.0000000000000P-1022
|
||||
#define DBL_EPSILON 0x1.0000000000000P-52
|
||||
#define DBL_MAX 0x1.fffffffffffffP1023
|
||||
|
||||
#define LDBL_MIN 0x1.0000000000000P-1022L
|
||||
#define LDBL_EPSILON 0x1.0000000000000P-52L
|
||||
#define LDBL_MAX 0x1.fffffffffffffP1023L
|
||||
|
||||
typedef struct decimal {
|
||||
unsigned char sgn;
|
||||
char unused;
|
||||
short exp;
|
||||
struct {
|
||||
unsigned char length;
|
||||
unsigned char text[32];
|
||||
unsigned char unused;
|
||||
} sig;
|
||||
} decimal;
|
||||
|
||||
typedef struct decform {
|
||||
char style;
|
||||
char unused;
|
||||
short digits;
|
||||
} decform;
|
||||
|
||||
void __num2dec(const decform *f, double x, decimal *d);
|
||||
double __dec2num(const decimal *d);
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif
|
||||
@@ -0,0 +1,15 @@
|
||||
#ifndef _C_ARITH_H
|
||||
#define _C_ARITH_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
int abs(int __x);
|
||||
long labs(long __x);
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif
|
||||
@@ -0,0 +1,18 @@
|
||||
#ifndef _C_BUFFER_IO_H
|
||||
#define _C_BUFFER_IO_H
|
||||
|
||||
#include <stddef.h>
|
||||
#include <stdio.h>
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
int __flush_buffer(FILE *file, size_t *length);
|
||||
void __prep_buffer(FILE *file);
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif
|
||||
@@ -0,0 +1,16 @@
|
||||
#ifndef _C_CONSOLE_IO_H
|
||||
#define _C_CONSOLE_IO_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
extern int __read_console(unsigned int handle, unsigned char *buffer, int *count, void *ref);
|
||||
extern int __write_console(unsigned int handle, unsigned char *buffer, int *count, void *ref);
|
||||
extern int __close_console();
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif
|
||||
@@ -0,0 +1,49 @@
|
||||
#ifndef MSL_COMMON_CRITICAL_REGIONS_H
|
||||
#define MSL_COMMON_CRITICAL_REGIONS_H
|
||||
|
||||
#include <nitro/os/mutex.h>
|
||||
|
||||
enum critical_regions {
|
||||
atexit_funcs_access = 0,
|
||||
malloc_pool_access = 1,
|
||||
stdin_access = 2,
|
||||
stdout_access = 3,
|
||||
stderr_access = 4,
|
||||
files_access = 5,
|
||||
console_status_access = 6,
|
||||
signal_funcs_access = 7,
|
||||
thread_access = 8,
|
||||
num_critical_regions = 9
|
||||
};
|
||||
|
||||
extern OSMutex __cs[num_critical_regions];
|
||||
extern int __cs_id[num_critical_regions];
|
||||
extern int __cs_ref[num_critical_regions];
|
||||
|
||||
static inline void __begin_critical_region(int region) {
|
||||
OSThread *currentThread;
|
||||
|
||||
if (OS_TryLockMutex(&__cs[region]) == 0) {
|
||||
currentThread = OS_GetCurrentThread();
|
||||
__cs_id[region] = OS_GetThreadId(currentThread);
|
||||
__cs_ref[region] = 1;
|
||||
} else {
|
||||
currentThread = OS_GetCurrentThread();
|
||||
if (OS_GetThreadId(currentThread) == __cs_id[region]) {
|
||||
__cs_ref[region]++;
|
||||
} else {
|
||||
OS_LockMutex(&__cs[region]);
|
||||
currentThread = OS_GetCurrentThread();
|
||||
__cs_id[region] = OS_GetThreadId(currentThread);
|
||||
__cs_ref[region] = 1;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
static inline void __end_critical_region(int region) {
|
||||
if (--__cs_ref[region] == 0) {
|
||||
OS_UnlockMutex(&__cs[region]);
|
||||
}
|
||||
}
|
||||
|
||||
#endif // MSL_COMMON_CRITICAL_REGIONS_H
|
||||
@@ -0,0 +1,60 @@
|
||||
#ifndef _C_CTYPE_H
|
||||
#define _C_CTYPE_H
|
||||
|
||||
#include <locale.h>
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#define __msl_cmap_size 128
|
||||
|
||||
extern const unsigned short __ctype_mapC[__msl_cmap_size];
|
||||
extern const unsigned char __lower_mapC[__msl_cmap_size];
|
||||
extern const unsigned char __upper_mapC[__msl_cmap_size];
|
||||
|
||||
#define _MSL_CMAP_ACCESS __ctype_mapC
|
||||
#define _MSL_CLOWER_ACCESS __lower_mapC
|
||||
#define _MSL_CUPPER_ACCESS __upper_mapC
|
||||
|
||||
#define __msl_alpha 0x001
|
||||
#define __msl_blank 0x002
|
||||
#define __msl_cntrl 0x004
|
||||
#define __msl_digit 0x008
|
||||
#define __msl_graph 0x010
|
||||
#define __msl_lower 0x020
|
||||
#define __msl_print 0x040
|
||||
#define __msl_punct 0x080
|
||||
#define __msl_space 0x100
|
||||
#define __msl_upper 0x200
|
||||
#define __msl_xdigit 0x400
|
||||
|
||||
static inline int isalpha(unsigned int c) {
|
||||
return ((c < 0) || (c >= __msl_cmap_size)) ? 0 : (int) (_MSL_CMAP_ACCESS[c] & __msl_alpha);
|
||||
}
|
||||
|
||||
static inline int isdigit(unsigned int c) {
|
||||
return ((c < 0) || (c >= __msl_cmap_size)) ? 0 : (int) (_MSL_CMAP_ACCESS[c] & __msl_digit);
|
||||
}
|
||||
|
||||
static inline int isspace(unsigned int c) {
|
||||
return ((c < 0) || (c >= __msl_cmap_size)) ? 0 : (int) (_MSL_CMAP_ACCESS[c] & __msl_space);
|
||||
}
|
||||
|
||||
static inline int isupper(unsigned int c) {
|
||||
return ((c < 0) || (c >= __msl_cmap_size)) ? 0 : (int) (_MSL_CMAP_ACCESS[c] & __msl_upper);
|
||||
}
|
||||
|
||||
static inline int isxdigit(unsigned int c) {
|
||||
return ((c < 0) || (c >= __msl_cmap_size)) ? 0 : (int) (_MSL_CMAP_ACCESS[c] & __msl_xdigit);
|
||||
}
|
||||
|
||||
static inline int toupper(unsigned int c) {
|
||||
return ((c < 0) || (c >= __msl_cmap_size)) ? c : (int) (_MSL_CUPPER_ACCESS[c]);
|
||||
}
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif
|
||||
@@ -0,0 +1,21 @@
|
||||
#ifndef _C_ERRNO_H
|
||||
#define _C_ERRNO_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
extern int errno;
|
||||
|
||||
#define ENOERR 0
|
||||
#define EDOM 33
|
||||
#define ERANGE 34
|
||||
#define ESIGPARM 36
|
||||
#define EFPOS 40
|
||||
#define EILSEQ 84
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif
|
||||
@@ -0,0 +1,62 @@
|
||||
#ifndef _C_FDLIBM_H
|
||||
#define _C_FDLIBM_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <errno.h>
|
||||
#include <limits.h>
|
||||
|
||||
/**
|
||||
* For including FDLIBM declarations without also including its many macros.
|
||||
*/
|
||||
|
||||
double __ieee754_acos(double);
|
||||
double __ieee754_fmod(double, double);
|
||||
double __ieee754_log(double);
|
||||
double __ieee754_log10(double);
|
||||
double __ieee754_pow(double, double);
|
||||
double __ieee754_sqrt(double);
|
||||
double __ieee754_atan2(double, double);
|
||||
double __ieee754_asin(double);
|
||||
double __ieee754_exp(double);
|
||||
int __ieee754_rem_pio2(double, double *);
|
||||
|
||||
double __kernel_sin(double, double, int);
|
||||
double __kernel_cos(double, double);
|
||||
double __kernel_tan(double, double, int);
|
||||
|
||||
double nan(const char *arg);
|
||||
double atan(double x);
|
||||
double ceil(double x);
|
||||
double copysign(double x, double y);
|
||||
double cos(double x);
|
||||
double floor(double x);
|
||||
double frexp(double x, int *eptr);
|
||||
double ldexp(double value, int exp);
|
||||
double modf(double x, double *iptr);
|
||||
double sin(double x);
|
||||
double tan(double x);
|
||||
double acos(double x);
|
||||
double asin(double x);
|
||||
double atan2(double y, double x);
|
||||
double fmod(double x, double y);
|
||||
double pow(double x, double y);
|
||||
double sqrt(double x);
|
||||
double log(double x);
|
||||
float log10f(float x);
|
||||
|
||||
// In reality, these are "weak" functions which all have C++ names (except scalbn).
|
||||
// We fake it by defining them as strong C functions instead.
|
||||
float sin__Ff(float x);
|
||||
float cos__Ff(float x);
|
||||
double scalbn(double x, int n);
|
||||
double fabs__Fd(double x);
|
||||
float fabsf__Ff(float x);
|
||||
|
||||
#ifdef __cplusplus
|
||||
};
|
||||
#endif
|
||||
|
||||
#endif
|
||||
@@ -0,0 +1,17 @@
|
||||
#ifndef _C_FILE_IO_H
|
||||
#define _C_FILE_IO_H
|
||||
|
||||
#include <stdio.h>
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
int fclose(FILE *file);
|
||||
int fflush(FILE *file);
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif
|
||||
@@ -0,0 +1,19 @@
|
||||
#ifndef _C_FILE_POS_H
|
||||
#define _C_FILE_POS_H
|
||||
|
||||
#include <stdio.h>
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
int fseek(FILE *stream, unsigned int offset, int whence);
|
||||
int _fseek(FILE *stream, unsigned int offset, int whence);
|
||||
int ftell(FILE *stream);
|
||||
int _ftell(FILE *stream);
|
||||
|
||||
#ifdef __cplusplus
|
||||
};
|
||||
#endif
|
||||
|
||||
#endif
|
||||
@@ -0,0 +1,123 @@
|
||||
#ifndef _C_FILE_STRUC_H
|
||||
#define _C_FILE_STRUC_H
|
||||
|
||||
#include <stddef.h>
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
typedef unsigned long __file_handle;
|
||||
typedef unsigned long fpos_t;
|
||||
typedef struct _FILE _FILE, *P_FILE;
|
||||
|
||||
#define __ungetc_buffer_size 2
|
||||
|
||||
enum __file_kinds {
|
||||
__closed_file,
|
||||
__disk_file,
|
||||
__console_file,
|
||||
__unavailable_file
|
||||
};
|
||||
|
||||
enum __open_modes {
|
||||
__must_exist,
|
||||
__create_if_necessary,
|
||||
__create_or_truncate
|
||||
};
|
||||
|
||||
enum __file_orientation {
|
||||
__unoriented,
|
||||
__char_oriented,
|
||||
__wide_oriented
|
||||
};
|
||||
|
||||
enum __io_modes {
|
||||
__read = 1,
|
||||
__write = 2,
|
||||
__read_write = 3,
|
||||
__append = 4
|
||||
};
|
||||
|
||||
typedef struct __file_modes {
|
||||
unsigned int open_mode : 2;
|
||||
unsigned int io_mode : 3;
|
||||
unsigned int buffer_mode : 2;
|
||||
unsigned int file_kind : 3;
|
||||
unsigned int file_orientation : 2;
|
||||
unsigned int binary_io : 1;
|
||||
} __file_modes;
|
||||
|
||||
enum __io_states {
|
||||
__neutral,
|
||||
__writing,
|
||||
__reading,
|
||||
__rereading
|
||||
};
|
||||
|
||||
typedef struct __file_state {
|
||||
unsigned int io_state : 3;
|
||||
unsigned int free_buffer : 1;
|
||||
unsigned char eof;
|
||||
unsigned char error;
|
||||
} __file_state;
|
||||
|
||||
typedef void *__ref_con;
|
||||
typedef void (*__idle_proc)(void);
|
||||
typedef int (*__pos_proc)(unsigned int file, unsigned int *position, int mode, void *ref);
|
||||
typedef int (*__io_proc)(unsigned int handle, unsigned char *buffer, int *count, void *ref);
|
||||
typedef int (*__close_proc)(unsigned int file);
|
||||
|
||||
struct _FILE {
|
||||
__file_handle handle;
|
||||
__file_modes mode;
|
||||
__file_state state;
|
||||
unsigned char char_buffer;
|
||||
unsigned char char_buffer_overflow;
|
||||
unsigned char ungetc_buffer[__ungetc_buffer_size];
|
||||
wchar_t ungetwc_buffer[__ungetc_buffer_size];
|
||||
unsigned int position;
|
||||
unsigned char *buffer;
|
||||
unsigned int buffer_size;
|
||||
unsigned char *buffer_ptr;
|
||||
unsigned int buffer_len;
|
||||
unsigned int buffer_alignment;
|
||||
unsigned int saved_buffer_len;
|
||||
unsigned int buffer_pos;
|
||||
__pos_proc position_proc;
|
||||
__io_proc read_proc;
|
||||
__io_proc write_proc;
|
||||
__close_proc close_proc;
|
||||
__ref_con ref_con;
|
||||
};
|
||||
|
||||
typedef struct _FILE FILE;
|
||||
|
||||
#define _IONBF 0
|
||||
#define _IOLBF 1
|
||||
#define _IOFBF 2
|
||||
|
||||
// define standard C file pointer location names
|
||||
#define SEEK_SET (0)
|
||||
#define SEEK_CUR (1)
|
||||
#define SEEK_END (2)
|
||||
|
||||
#define set_error(file) \
|
||||
do { \
|
||||
(file)->state.error = 1; \
|
||||
(file)->buffer_len = 0; \
|
||||
} while (FALSE)
|
||||
|
||||
#define stdin &(__files[0])
|
||||
#define stdout &(__files[1])
|
||||
#define stderr &(__files[2])
|
||||
|
||||
#define _STATIC_FILES 3
|
||||
|
||||
extern FILE __files[];
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif
|
||||
@@ -0,0 +1,29 @@
|
||||
#ifndef _C_FLOAT_H
|
||||
#define _C_FLOAT_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#define FLT_MAX 3.402823466e+38f
|
||||
#define FLT_EPSILON 1.192092896e-07f
|
||||
#define FLT_MIN 1.175494351e-38f
|
||||
|
||||
#define DBL_EPSILON 1.1920929e-07
|
||||
|
||||
#define LDBL_MANT_DIG 53
|
||||
#define LDBL_DIG 15
|
||||
#define LDBL_MIN_EXP (-1021)
|
||||
#define LDBL_MIN_10_EXP (-308)
|
||||
#define LDBL_MAX_EXP 1024
|
||||
#define LDBL_MAX_10_EXP 308
|
||||
|
||||
#define LDBL_MAX 0x1.fffffffffffffP1023L
|
||||
#define LDBL_EPSILON 0x1.0000000000000P-52L
|
||||
#define LDBL_MIN 0x1.0000000000000P-1022L
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif
|
||||
@@ -0,0 +1,37 @@
|
||||
#ifndef _C_LIMITS_H
|
||||
#define _C_LIMITS_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#define SCHAR_MIN (-0x7F - 1)
|
||||
#define SCHAR_MAX 0x7F
|
||||
#define UCHAR_MAX 0xFFU
|
||||
|
||||
#define CHAR_MIN SCHAR_MIN
|
||||
#define CHAR_MAX SCHAR_MAX
|
||||
|
||||
#define SHRT_MIN (-0x7FFF - 1)
|
||||
#define SHRT_MAX 0x7FFF
|
||||
#define USHRT_MAX 0xFFFF
|
||||
|
||||
#define INT_MIN (-0x7FFFFFFF - 1)
|
||||
#define INT_MAX 0x7FFFFFFF
|
||||
#define UINT_MAX 0xFFFFFFFF
|
||||
|
||||
#define LONG_MIN (-0x7FFFFFFFL - 1)
|
||||
#define LONG_MAX 0x7FFFFFFFL
|
||||
#define ULONG_MAX 0xFFFFFFFFUL
|
||||
|
||||
#define LLONG_MIN (-0x7FFFFFFFFFFFFFFFLL - 1)
|
||||
#define LLONG_MAX 0x7FFFFFFFFFFFFFFFLL
|
||||
#define ULLONG_MAX 0xFFFFFFFFFFFFFFFFULL
|
||||
|
||||
#define CHAR_BIT 8
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif
|
||||
@@ -0,0 +1,76 @@
|
||||
#ifndef _C_LOCALE_H
|
||||
#define _C_LOCALE_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#define _COMPONENT_NAME_LEN 8
|
||||
|
||||
typedef int (*__decode_mbyte)(unsigned short *, const char *, int);
|
||||
typedef int (*__encode_mbyte)(char *, unsigned short);
|
||||
|
||||
struct _loc_coll_cmpt {
|
||||
int char_start_value;
|
||||
int char_coll_tab_size;
|
||||
short char_spec_accents;
|
||||
unsigned short *char_coll_table_ptr;
|
||||
};
|
||||
|
||||
struct _loc_ctype_cmpt {
|
||||
/* 0x00 */ __decode_mbyte decode_mb;
|
||||
/* 0x04 */ __encode_mbyte encode_wc;
|
||||
};
|
||||
|
||||
struct _loc_time_cmpt {
|
||||
char *am_pm;
|
||||
char *DateTime_Format;
|
||||
char *Twelve_hr_format;
|
||||
char *Date_Format;
|
||||
char *Time_Format;
|
||||
char *Day_Names;
|
||||
char *MonthNames;
|
||||
char *TimeZone;
|
||||
};
|
||||
|
||||
struct __locale {
|
||||
/* 0x00 */ struct _loc_time_cmpt *time_cmpt_ptr;
|
||||
/* 0x04 */ struct _loc_coll_cmpt *coll_cmpt_ptr;
|
||||
/* 0x08 */ struct _loc_ctype_cmpt *ctype_cmpt_ptr;
|
||||
};
|
||||
|
||||
struct lconv {
|
||||
char *decimal_point;
|
||||
char *thousands_sep;
|
||||
char *grouping;
|
||||
char *mon_decimal_point;
|
||||
char *mon_thousands_sep;
|
||||
char *mon_grouping;
|
||||
char *positive_sign;
|
||||
char *negative_sign;
|
||||
char *currency_symbol;
|
||||
char frac_digits;
|
||||
char p_cs_precedes;
|
||||
char n_cs_precedes;
|
||||
char p_sep_by_space;
|
||||
char n_sep_by_space;
|
||||
char p_sign_posn;
|
||||
char n_sign_posn;
|
||||
char *int_curr_symbol;
|
||||
char int_frac_digits;
|
||||
char int_p_cs_precedes;
|
||||
char int_n_cs_precedes;
|
||||
char int_p_sep_by_space;
|
||||
char int_n_sep_by_space;
|
||||
char int_p_sign_posn;
|
||||
char int_n_sign_posn;
|
||||
};
|
||||
|
||||
extern struct lconv __lconv;
|
||||
extern struct __locale _current_locale;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif
|
||||
@@ -0,0 +1,61 @@
|
||||
#ifndef _C_MATH_H
|
||||
#define _C_MATH_H
|
||||
|
||||
#include <errno.h>
|
||||
#include <fdlibm.h>
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#define DONT_INLINE_SQRT
|
||||
|
||||
#define M_PI 3.1415926535897932
|
||||
#define M_SQRT3 1.7320499420166016
|
||||
|
||||
extern int __float_nan[];
|
||||
extern int __float_huge[];
|
||||
extern int __double_huge[];
|
||||
|
||||
#define NAN (*(float *) __float_nan)
|
||||
#define INFINITY (*(float *) __float_huge)
|
||||
#define HUGE_VAL (*(double *) __double_huge)
|
||||
|
||||
// f64 bit-twiddling macros
|
||||
#ifdef __BIG_ENDIAN__
|
||||
#define __HI(x) (((int *) &x)[0])
|
||||
#define __LO(x) (((int *) &x)[1])
|
||||
#else
|
||||
#define __HI(x) (((int *) &x)[1])
|
||||
#define __LO(x) (((int *) &x)[0])
|
||||
#endif
|
||||
|
||||
#define FP_NAN 1
|
||||
#define FP_INFINITE 2
|
||||
#define FP_ZERO 3
|
||||
#define FP_NORMAL 4
|
||||
#define FP_SUBNORMAL 5
|
||||
|
||||
int __fpclassifyd(double x);
|
||||
int __signbitd(double x);
|
||||
double fabs(double x);
|
||||
double nan(const char *x);
|
||||
double sqrt(double __x);
|
||||
|
||||
#define fpclassify(x) ((sizeof(x) == sizeof(float)) ? __fpclassifyf((float) (x)) : __fpclassifyd((double) (x)))
|
||||
#define signbit(x) ((sizeof(x) == sizeof(float)) ? __signbitf((float) (x)) : __signbitd((double) (x)))
|
||||
|
||||
#define isnormal(x) (fpclassify(x) == FP_NORMAL)
|
||||
#define isnan(x) (fpclassify(x) == FP_NAN)
|
||||
#define isinf(x) (fpclassify(x) == FP_INFINITE)
|
||||
#define isfinite(x) (fpclassify(x) > FP_INFINITE)
|
||||
|
||||
static inline long double fabsl(long double x) {
|
||||
return (long double) fabs((double) x);
|
||||
}
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif
|
||||
@@ -0,0 +1,19 @@
|
||||
#ifndef _C_MBSTRING_H
|
||||
#define _C_MBSTRING_H
|
||||
|
||||
#include <stddef.h>
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
int mbtowc(wchar_t *pwc, const char *s, int n);
|
||||
int __mbtowc_noconv(wchar_t *pwc, const char *str, int n);
|
||||
int __wctomb_noconv(char *s, wchar_t wchar);
|
||||
size_t mbstowcs(wchar_t *pDest, const char *pSrc, size_t num);
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif
|
||||
@@ -0,0 +1,20 @@
|
||||
#ifndef _C_MEM_H
|
||||
#define _C_MEM_H
|
||||
|
||||
#include <stddef.h>
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
void *memcpy(void *dst, const void *src, int n);
|
||||
void *memmove(void *dst, const void *src, size_t len);
|
||||
void *memset(void *dest, int val, int n);
|
||||
void *memchr(const void *src, int val, int n);
|
||||
int memcmp(const void *src1, const void *src2, int n);
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif
|
||||
@@ -0,0 +1,14 @@
|
||||
#ifndef _C_MEM_FUNCS_H
|
||||
#define _C_MEM_FUNCS_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
void __fill_mem(void *dst, int val, unsigned int n);
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif
|
||||
@@ -0,0 +1,23 @@
|
||||
#ifndef _C_PRINTF_H
|
||||
#define _C_PRINTF_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdarg.h>
|
||||
#include <stdio.h>
|
||||
|
||||
int printf(const char *format, ...);
|
||||
int fprintf(FILE *, const char *format, ...);
|
||||
int vprintf(const char *, va_list);
|
||||
int vsnprintf(char *, size_t, const char *, va_list);
|
||||
int vsprintf(char *, const char *, va_list);
|
||||
int snprintf(char *, size_t, const char *, ...);
|
||||
int sprintf(char *, const char *, ...);
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif
|
||||
@@ -0,0 +1,17 @@
|
||||
#ifndef _C_SCANF_H
|
||||
#define _C_SCANF_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdarg.h>
|
||||
|
||||
int vsscanf(const char *, const char *, va_list);
|
||||
int sscanf(const char *, const char *, ...);
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif
|
||||
@@ -0,0 +1,16 @@
|
||||
#ifndef _C_SECURE_ERROR_H
|
||||
#define _C_SECURE_ERROR_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
typedef void (*msl_constraint_handler)(int, int, int);
|
||||
|
||||
void __msl_runtime_constraint_violation_s(int param1, int param2, int param3);
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif
|
||||
@@ -0,0 +1,18 @@
|
||||
#ifndef _C_SIGNAL_H
|
||||
#define _C_SIGNAL_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
extern void exit(int);
|
||||
|
||||
typedef void (*sig_func)(int sig);
|
||||
|
||||
int raise(int sig);
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif
|
||||
@@ -0,0 +1,22 @@
|
||||
#ifndef _C_STDARG_H
|
||||
#define _C_STDARG_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
typedef char *va_list;
|
||||
|
||||
#define __fourbytealign(n) ((((unsigned int) (n)) + 3U) & ~3U)
|
||||
#define __va_start(parm) ((va_list) ((char *) ((unsigned int) (&parm) & ~3U) + __fourbytealign(sizeof(parm))))
|
||||
|
||||
#define va_start(ap, parm) ((ap) = __va_start(parm))
|
||||
#define va_arg(ap, type) (*(type *) ((ap += __fourbytealign(sizeof(type))) - __fourbytealign(sizeof(type))))
|
||||
#define va_end(ap) ((void) 0)
|
||||
#define va_copy(dest, src) dest = src
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif
|
||||
+28
-1
@@ -1,8 +1,35 @@
|
||||
#ifndef _C_STDDEF_H
|
||||
#define _C_STDDEF_H
|
||||
|
||||
#define NULL 0
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#ifndef NULL
|
||||
#define NULL 0
|
||||
#endif
|
||||
|
||||
#ifndef nullptr
|
||||
#define nullptr 0
|
||||
#endif
|
||||
|
||||
#define offsetof(ST, M) ((size_t) &(((ST *) 0)->M))
|
||||
|
||||
typedef signed long intptr_t;
|
||||
typedef unsigned long uintptr_t;
|
||||
typedef intptr_t ptrdiff_t;
|
||||
|
||||
typedef unsigned int size_t;
|
||||
|
||||
#ifndef __cplusplus
|
||||
typedef int bool;
|
||||
typedef unsigned short wchar_t;
|
||||
#define true 1
|
||||
#define false 0
|
||||
#endif
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif
|
||||
|
||||
@@ -0,0 +1,22 @@
|
||||
#ifndef _C_STDIO_H
|
||||
#define _C_STDIO_H
|
||||
|
||||
#include <stddef.h>
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
// clang-format off
|
||||
#include <stdio_api.h>
|
||||
#include <file_pos.h>
|
||||
#include <file_io.h>
|
||||
#include <printf.h>
|
||||
#include <scanf.h>
|
||||
// clang-format on
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif
|
||||
@@ -0,0 +1,53 @@
|
||||
#ifndef _C_STDIO_API_H
|
||||
#define _C_STDIO_API_H
|
||||
|
||||
#include <file_struc.h>
|
||||
#include <stddef.h>
|
||||
#include <wchar_io.h>
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
enum __ReadProcActions {
|
||||
__GetAChar,
|
||||
__UngetAChar,
|
||||
__TestForError
|
||||
};
|
||||
|
||||
enum __WReadProcActions {
|
||||
__GetAwChar,
|
||||
__UngetAwChar,
|
||||
__TestForwcsError
|
||||
};
|
||||
|
||||
typedef struct {
|
||||
char *CharStr;
|
||||
size_t MaxCharCount;
|
||||
size_t CharsWritten;
|
||||
} __OutStrCtrl;
|
||||
|
||||
typedef struct {
|
||||
char *NextChar;
|
||||
int NullCharDetected;
|
||||
} __InStrCtrl;
|
||||
|
||||
typedef struct {
|
||||
wchar_t *wCharStr;
|
||||
size_t MaxCharCount;
|
||||
size_t CharsWritten;
|
||||
} __wOutStrCtrl;
|
||||
|
||||
typedef struct {
|
||||
wchar_t *wNextChar;
|
||||
int wNullCharDetected;
|
||||
} __wInStrCtrl;
|
||||
|
||||
size_t __fwrite(const void *pPtr, size_t memb_size, size_t num_memb, FILE *file);
|
||||
int __StringRead(void *, int, int);
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif
|
||||
@@ -1,15 +1,20 @@
|
||||
#ifndef _C_STRING_H
|
||||
#define _C_STRING_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
typedef unsigned int size_t;
|
||||
|
||||
size_t strlen(const char *str);
|
||||
char *strcpy(char *dest, const char *src);
|
||||
char *strncpy(char *dest, const char *src, size_t num);
|
||||
char *strcat(char *dest, const char *src);
|
||||
int strcmp(char *str1, char *str2);
|
||||
int strncmp(char *str1, char *str2, size_t num);
|
||||
const char *strchr(const char *str, char ch);
|
||||
const char *strstr(const char *str1, const char *str2);
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif
|
||||
|
||||
@@ -0,0 +1,16 @@
|
||||
#ifndef _C_WCHAR_H
|
||||
#define _C_WCHAR_H
|
||||
|
||||
#include <stdio.h>
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
int fwide(FILE *stream, int mode);
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif
|
||||
@@ -0,0 +1,19 @@
|
||||
#ifndef _C_WSTRING_H
|
||||
#define _C_WSTRING_H
|
||||
|
||||
#include <stddef.h>
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
size_t wcslen(const wchar_t *str);
|
||||
wchar_t *wcscpy(wchar_t *dest, const wchar_t *src);
|
||||
wchar_t *wcsncpy(wchar_t *dest, const wchar_t *src, size_t n);
|
||||
const wchar_t *wcschr(const wchar_t *str, wchar_t chr);
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif
|
||||
@@ -0,0 +1,51 @@
|
||||
#include <MWException.h>
|
||||
#include <abort_exit_arm_eabi.h>
|
||||
#include <critical_regions.h>
|
||||
#include <file_io.h>
|
||||
#include <signal.h>
|
||||
|
||||
extern void _ExitProcess(void);
|
||||
|
||||
static void (*__atexit_funcs[64])(void);
|
||||
bool __aborting = false;
|
||||
static int __atexit_curr_func = 0;
|
||||
void (*__stdio_exit)(void) = NULL;
|
||||
void (*__console_exit)(void) = NULL;
|
||||
|
||||
void abort(void) {
|
||||
raise(SIGABRT);
|
||||
__aborting = true;
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
|
||||
void exit(int status) {
|
||||
if (__aborting == false) {
|
||||
__destroy_global_chain();
|
||||
|
||||
if (__stdio_exit != NULL) {
|
||||
__stdio_exit();
|
||||
__stdio_exit = NULL;
|
||||
}
|
||||
}
|
||||
|
||||
__exit(status);
|
||||
}
|
||||
|
||||
void __exit(int status) {
|
||||
__begin_critical_region(atexit_funcs_access);
|
||||
|
||||
while (__atexit_curr_func > 0) {
|
||||
__atexit_funcs[--__atexit_curr_func]();
|
||||
}
|
||||
|
||||
__end_critical_region(atexit_funcs_access);
|
||||
|
||||
if (__console_exit != NULL) {
|
||||
__console_exit();
|
||||
__console_exit = NULL;
|
||||
}
|
||||
|
||||
fflush(NULL);
|
||||
|
||||
_ExitProcess();
|
||||
}
|
||||
@@ -0,0 +1,98 @@
|
||||
#include <ansi_files.h>
|
||||
#include <console_io.h>
|
||||
#include <file_io.h>
|
||||
#include <stdio.h>
|
||||
|
||||
static console_buff stdin_buff;
|
||||
static console_buff stdout_buff;
|
||||
static console_buff stderr_buff;
|
||||
|
||||
FILE __files[_STATIC_FILES] = {
|
||||
{
|
||||
0,
|
||||
{__must_exist, __read, console_buff_mode, __console_file, 0},
|
||||
{__neutral, 0, 0, 0},
|
||||
0,
|
||||
0,
|
||||
{0, 0},
|
||||
{0, 0},
|
||||
0,
|
||||
stdin_buff,
|
||||
console_buff_size,
|
||||
stdin_buff,
|
||||
0,
|
||||
0,
|
||||
0,
|
||||
0,
|
||||
NULL,
|
||||
__read_console,
|
||||
__write_console,
|
||||
__close_console,
|
||||
NULL,
|
||||
},
|
||||
{
|
||||
1,
|
||||
{__must_exist, __write, console_buff_mode, __console_file, 0},
|
||||
{__neutral, 0, 0, 0},
|
||||
0,
|
||||
0,
|
||||
{0, 0},
|
||||
{0, 0},
|
||||
0,
|
||||
stdout_buff,
|
||||
console_buff_size,
|
||||
stdout_buff,
|
||||
0,
|
||||
0,
|
||||
0,
|
||||
0,
|
||||
NULL,
|
||||
__read_console,
|
||||
__write_console,
|
||||
__close_console,
|
||||
NULL,
|
||||
},
|
||||
{
|
||||
2,
|
||||
{__must_exist, __write, _IONBF, __console_file, 0},
|
||||
{__neutral, 0, 0, 0},
|
||||
0,
|
||||
0,
|
||||
{0, 0},
|
||||
{0, 0},
|
||||
0,
|
||||
stderr_buff,
|
||||
console_buff_size,
|
||||
stderr_buff,
|
||||
0,
|
||||
0,
|
||||
0,
|
||||
0,
|
||||
NULL,
|
||||
__read_console,
|
||||
__write_console,
|
||||
__close_console,
|
||||
NULL,
|
||||
},
|
||||
};
|
||||
|
||||
int __flush_all(void) {
|
||||
int result = 0;
|
||||
FILE *file = &__files[0];
|
||||
int file_index = 1;
|
||||
|
||||
do {
|
||||
if (file->mode.file_kind != __closed_file) {
|
||||
if (fflush(file) != 0) {
|
||||
result = -1;
|
||||
}
|
||||
}
|
||||
if (file_index < 3) {
|
||||
file = &__files[file_index++];
|
||||
} else {
|
||||
file = NULL;
|
||||
}
|
||||
} while (file != NULL);
|
||||
|
||||
return result;
|
||||
}
|
||||
@@ -0,0 +1,367 @@
|
||||
#include <ansi_fp.h>
|
||||
#include <fdlibm.h>
|
||||
#include <float.h>
|
||||
#include <math.h>
|
||||
|
||||
#pragma dont_reuse_strings off
|
||||
|
||||
typedef unsigned long long d_int;
|
||||
#define SIGDIGLEN 32
|
||||
|
||||
static inline int count_trailing(double x) {
|
||||
return __builtin___count_trailing_zero64(*(unsigned long long *) &x | 0x0010000000000000);
|
||||
}
|
||||
|
||||
static inline int __count_trailing_zerol(unsigned int x) {
|
||||
return 32 - __cntlzw(~x & (x - 1));
|
||||
}
|
||||
|
||||
static inline int __count_trailing_zero(double n) {
|
||||
unsigned int *array = (unsigned int *) &n;
|
||||
|
||||
unsigned int hi = array[1] | 0x100000;
|
||||
unsigned int lo = array[0];
|
||||
int zeros = __count_trailing_zerol(lo);
|
||||
|
||||
if (lo == 0) {
|
||||
return 32 + __count_trailing_zerol(hi);
|
||||
}
|
||||
|
||||
return zeros;
|
||||
}
|
||||
|
||||
static int __must_round(const decimal *d, int digits) {
|
||||
unsigned char const *i = d->sig.text + digits;
|
||||
|
||||
if (*i > 5) {
|
||||
return 1;
|
||||
}
|
||||
|
||||
if (*i < 5) {
|
||||
return -1;
|
||||
}
|
||||
|
||||
{
|
||||
unsigned char const *e = d->sig.text + d->sig.length;
|
||||
|
||||
for (i++; i < e; i++) {
|
||||
if (*i != 0) {
|
||||
return 1;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (d->sig.text[digits - 1] & 1) {
|
||||
return 1;
|
||||
}
|
||||
|
||||
return -1;
|
||||
}
|
||||
|
||||
static void __dorounddecup(decimal *d, int digits) {
|
||||
unsigned char *b = d->sig.text;
|
||||
unsigned char *i = b + digits - 1;
|
||||
|
||||
while (1) {
|
||||
if (*i < 9) {
|
||||
*i += 1;
|
||||
break;
|
||||
}
|
||||
if (i == b) {
|
||||
*i = 1;
|
||||
d->exp++;
|
||||
break;
|
||||
}
|
||||
*i-- = 0;
|
||||
}
|
||||
}
|
||||
|
||||
static void __rounddec(decimal *d, int digits) {
|
||||
if (digits > 0 && digits < d->sig.length) {
|
||||
int unkBool = __must_round(d, digits);
|
||||
d->sig.length = digits;
|
||||
|
||||
if (unkBool >= 0) {
|
||||
__dorounddecup(d, digits);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void __ull2dec(decimal *result, unsigned long long val) {
|
||||
result->sgn = 0;
|
||||
result->sig.length = 0;
|
||||
|
||||
for (; val != 0; val /= 10) {
|
||||
result->sig.text[result->sig.length++] = (unsigned char) (val % 10);
|
||||
}
|
||||
|
||||
{
|
||||
unsigned char *i = result->sig.text;
|
||||
unsigned char *j = result->sig.text + result->sig.length;
|
||||
|
||||
for (; i < --j; ++i) {
|
||||
unsigned char t = *i;
|
||||
*i = *j;
|
||||
*j = t;
|
||||
}
|
||||
}
|
||||
|
||||
result->exp = result->sig.length - 1;
|
||||
}
|
||||
|
||||
void __timesdec(decimal *result, const decimal *x, const decimal *y) {
|
||||
unsigned int accumulator = 0;
|
||||
unsigned char mantissa[SIGDIGLEN * 2];
|
||||
int i = x->sig.length + y->sig.length - 1;
|
||||
unsigned char *pDigit;
|
||||
unsigned char *ip = mantissa + i + 1;
|
||||
unsigned char *ep = ip;
|
||||
|
||||
result->sgn = 0;
|
||||
|
||||
for (; i > 0; i--) {
|
||||
int k = y->sig.length - 1;
|
||||
int j = i - k - 1;
|
||||
int l;
|
||||
int t;
|
||||
const unsigned char *jp;
|
||||
const unsigned char *kp;
|
||||
|
||||
if (j < 0) {
|
||||
j = 0;
|
||||
k = i - 1;
|
||||
}
|
||||
|
||||
jp = x->sig.text + j;
|
||||
kp = y->sig.text + k;
|
||||
l = k + 1;
|
||||
t = x->sig.length - j;
|
||||
|
||||
if (l > t) {
|
||||
l = t;
|
||||
}
|
||||
|
||||
for (; l > 0; l--, jp++, kp--) {
|
||||
accumulator += *jp * *kp;
|
||||
}
|
||||
|
||||
*--ip = (unsigned char) (accumulator % 10);
|
||||
accumulator /= 10;
|
||||
}
|
||||
|
||||
result->exp = (short) (x->exp + y->exp);
|
||||
|
||||
if (accumulator) {
|
||||
*--ip = (unsigned char) (accumulator);
|
||||
result->exp++;
|
||||
}
|
||||
|
||||
for (i = 0; i < SIGDIGLEN && ip < ep; i++, ip++) {
|
||||
result->sig.text[i] = *ip;
|
||||
}
|
||||
result->sig.length = (unsigned char) (i);
|
||||
|
||||
if (ip < ep && *ip >= 5) {
|
||||
if (*ip == 5) {
|
||||
unsigned char *jp = ip + 1;
|
||||
for (; jp < ep; jp++) {
|
||||
if (*jp != 0) {
|
||||
goto round;
|
||||
}
|
||||
}
|
||||
if ((ip[-1] & 1) == 0) {
|
||||
return;
|
||||
}
|
||||
}
|
||||
round:
|
||||
__dorounddecup(result, result->sig.length);
|
||||
}
|
||||
}
|
||||
|
||||
void __str2dec(decimal *d, const char *str, short exp) {
|
||||
const unsigned char *s = (const unsigned char *) str;
|
||||
int i;
|
||||
|
||||
d->exp = exp;
|
||||
d->sgn = 0;
|
||||
|
||||
for (i = 0; i < SIGDIGLEN && *s;) {
|
||||
d->sig.text[i++] = *s++ - '0';
|
||||
}
|
||||
d->sig.length = i;
|
||||
|
||||
if (*s != 0) {
|
||||
if (*s < 5) {
|
||||
return;
|
||||
}
|
||||
if (*s > 5) {
|
||||
goto round;
|
||||
}
|
||||
|
||||
{
|
||||
const unsigned char *p = s + 1;
|
||||
|
||||
for (; *p != 0; p++) {
|
||||
if (*p != '0') {
|
||||
goto round;
|
||||
}
|
||||
}
|
||||
|
||||
if ((d->sig.text[i - 1] & 1) == 0) {
|
||||
return;
|
||||
}
|
||||
}
|
||||
round:
|
||||
__dorounddecup(d, d->sig.length);
|
||||
}
|
||||
}
|
||||
|
||||
void __two_exp(decimal *result, long exp) {
|
||||
switch (exp) {
|
||||
case -64:
|
||||
__str2dec(result, "542101086242752217003726400434970855712890625", -20);
|
||||
return;
|
||||
case -53:
|
||||
__str2dec(result, "11102230246251565404236316680908203125", -16);
|
||||
return;
|
||||
case -32:
|
||||
__str2dec(result, "23283064365386962890625", -10);
|
||||
return;
|
||||
case -16:
|
||||
__str2dec(result, "152587890625", -5);
|
||||
return;
|
||||
case -8:
|
||||
__str2dec(result, "390625", -3);
|
||||
return;
|
||||
case -7:
|
||||
__str2dec(result, "78125", -3);
|
||||
return;
|
||||
case -6:
|
||||
__str2dec(result, "15625", -2);
|
||||
return;
|
||||
case -5:
|
||||
__str2dec(result, "3125", -2);
|
||||
return;
|
||||
case -4:
|
||||
__str2dec(result, "625", -2);
|
||||
return;
|
||||
case -3:
|
||||
__str2dec(result, "125", -1);
|
||||
return;
|
||||
case -2:
|
||||
__str2dec(result, "25", -1);
|
||||
return;
|
||||
case -1:
|
||||
__str2dec(result, "5", -1);
|
||||
return;
|
||||
case 0:
|
||||
__str2dec(result, "1", 0);
|
||||
return;
|
||||
case 1:
|
||||
__str2dec(result, "2", 0);
|
||||
return;
|
||||
case 2:
|
||||
__str2dec(result, "4", 0);
|
||||
return;
|
||||
case 3:
|
||||
__str2dec(result, "8", 0);
|
||||
return;
|
||||
case 4:
|
||||
__str2dec(result, "16", 1);
|
||||
return;
|
||||
case 5:
|
||||
__str2dec(result, "32", 1);
|
||||
return;
|
||||
case 6:
|
||||
__str2dec(result, "64", 1);
|
||||
return;
|
||||
case 7:
|
||||
__str2dec(result, "128", 2);
|
||||
return;
|
||||
case 8:
|
||||
__str2dec(result, "256", 2);
|
||||
return;
|
||||
}
|
||||
|
||||
{
|
||||
decimal x2, temp;
|
||||
|
||||
__two_exp(&x2, ((long) ((0x80000000UL & exp) >> 31) + exp) >> 1);
|
||||
__timesdec(result, &x2, &x2);
|
||||
|
||||
if (exp & 1) {
|
||||
temp = *result;
|
||||
|
||||
if (exp > 0) {
|
||||
__str2dec(&x2, "2", 0);
|
||||
} else {
|
||||
__str2dec(&x2, "5", -1);
|
||||
}
|
||||
|
||||
__timesdec(result, &temp, &x2);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// non-matching: https://decomp.me/scratch/xVomE
|
||||
void __num2dec_internal(decimal *d, double x) {
|
||||
char sign = (char) (signbit(x) != 0);
|
||||
|
||||
if (x == 0) {
|
||||
d->sgn = sign;
|
||||
d->exp = 0;
|
||||
d->sig.length = 1;
|
||||
d->sig.text[0] = 0;
|
||||
return;
|
||||
}
|
||||
|
||||
if (!isfinite(x)) {
|
||||
d->sgn = sign;
|
||||
d->exp = 0;
|
||||
d->sig.length = 1;
|
||||
d->sig.text[0] = fpclassify(x) == 1 ? 'N' : 'I';
|
||||
return;
|
||||
}
|
||||
|
||||
if (sign != 0) {
|
||||
x = -x;
|
||||
}
|
||||
|
||||
{
|
||||
int exp;
|
||||
double frac = frexp(x, &exp);
|
||||
int num_bits_extract = 53 - __count_trailing_zero(frac);
|
||||
decimal int_d, pow2_d;
|
||||
|
||||
__two_exp(&pow2_d, exp - num_bits_extract);
|
||||
__ull2dec(&int_d, ldexp(frac, num_bits_extract));
|
||||
__timesdec(d, &int_d, &pow2_d);
|
||||
d->sgn = sign;
|
||||
}
|
||||
}
|
||||
|
||||
void __num2dec(const decform *form, double x, decimal *d) {
|
||||
short digits = form->digits;
|
||||
int i;
|
||||
__num2dec_internal(d, x);
|
||||
|
||||
if (d->sig.text[0] > 9) {
|
||||
return;
|
||||
}
|
||||
|
||||
if (digits > SIGDIGLEN) {
|
||||
digits = SIGDIGLEN;
|
||||
}
|
||||
|
||||
__rounddec(d, digits);
|
||||
|
||||
while (d->sig.length < digits) {
|
||||
d->sig.text[d->sig.length++] = 0;
|
||||
}
|
||||
|
||||
d->exp -= d->sig.length - 1;
|
||||
|
||||
for (i = 0; i < d->sig.length; i++) {
|
||||
d->sig.text[i] += '0';
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,9 @@
|
||||
#include <arith.h>
|
||||
|
||||
int abs(int __x) {
|
||||
return __x < 0 ? -__x : __x;
|
||||
}
|
||||
|
||||
long labs(long __x) {
|
||||
return __x < 0 ? -__x : __x;
|
||||
}
|
||||
@@ -0,0 +1,40 @@
|
||||
#include <buffer_io.h>
|
||||
|
||||
void __convert_from_newlines(unsigned char *p, int *n) {}
|
||||
|
||||
void __prep_buffer(FILE *file) {
|
||||
file->buffer_ptr = file->buffer;
|
||||
file->buffer_len = file->buffer_size;
|
||||
file->buffer_len = file->buffer_len - (file->position & file->buffer_alignment);
|
||||
file->buffer_pos = file->position;
|
||||
return;
|
||||
}
|
||||
|
||||
int __flush_buffer(FILE *file, size_t *length) {
|
||||
size_t bufferLen;
|
||||
int writeCode;
|
||||
|
||||
bufferLen = file->buffer_ptr - file->buffer;
|
||||
if (bufferLen) {
|
||||
file->buffer_len = bufferLen;
|
||||
|
||||
if (file->mode.binary_io == 0) {
|
||||
__convert_from_newlines(file->buffer, &file->buffer_len);
|
||||
}
|
||||
|
||||
writeCode = file->write_proc(file->handle, file->buffer, &file->buffer_len, file->ref_con);
|
||||
|
||||
if (length) {
|
||||
*length = file->buffer_len;
|
||||
}
|
||||
|
||||
if (writeCode) {
|
||||
return writeCode;
|
||||
}
|
||||
|
||||
file->position += file->buffer_len;
|
||||
}
|
||||
|
||||
__prep_buffer(file);
|
||||
return 0;
|
||||
}
|
||||
@@ -0,0 +1,11 @@
|
||||
#include <math.h>
|
||||
|
||||
double scalbn(double x, int n) {
|
||||
double value;
|
||||
int exp;
|
||||
|
||||
value = frexp(x, &exp);
|
||||
exp += n;
|
||||
|
||||
return ldexp(value, exp);
|
||||
}
|
||||
@@ -0,0 +1,39 @@
|
||||
#include <stdio.h>
|
||||
|
||||
int fflush(FILE *file) {
|
||||
if (file == NULL) {
|
||||
return __flush_all();
|
||||
}
|
||||
|
||||
if (file->state.error != 0 || file->mode.file_kind == __closed_file) {
|
||||
return -1;
|
||||
}
|
||||
|
||||
if (file->mode.io_mode == 1) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
if (file->state.io_state >= 3) {
|
||||
file->state.io_state = 2;
|
||||
}
|
||||
|
||||
if (file->state.io_state == 2) {
|
||||
file->buffer_len = 0;
|
||||
}
|
||||
|
||||
if (file->state.io_state != 1) {
|
||||
file->state.io_state = 0;
|
||||
return 0;
|
||||
}
|
||||
|
||||
if (__flush_buffer(file, 0) != 0) {
|
||||
file->state.error = 1;
|
||||
file->buffer_len = 0;
|
||||
return -1;
|
||||
}
|
||||
|
||||
file->state.io_state = 0;
|
||||
file->position = 0;
|
||||
file->buffer_len = 0;
|
||||
return 0;
|
||||
}
|
||||
@@ -0,0 +1 @@
|
||||
int __float_nan[] = {0x7FFFFFFF};
|
||||
@@ -0,0 +1,43 @@
|
||||
#include <locale.h>
|
||||
#include <mbstring.h>
|
||||
|
||||
struct _loc_ctype_cmpt __ctype_cmpt = {
|
||||
.decode_mb = __mbtowc_noconv,
|
||||
.encode_wc = __wctomb_noconv,
|
||||
};
|
||||
|
||||
unsigned short char_coll_table[0x60] = {
|
||||
0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f, 0x10, 0x21, 0x22, 0x23,
|
||||
0x24, 0x25, 0x26, 0x27, 0x28, 0x29, 0x2a, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16, 0x17, 0x2b, 0x2d, 0x2f, 0x31, 0x33,
|
||||
0x35, 0x37, 0x39, 0x3b, 0x3d, 0x3f, 0x41, 0x43, 0x45, 0x47, 0x49, 0x4b, 0x4d, 0x4f, 0x51, 0x53, 0x55, 0x57, 0x59,
|
||||
0x5b, 0x5d, 0x18, 0x19, 0x1a, 0x1b, 0x1c, 0x00, 0x2c, 0x2e, 0x30, 0x32, 0x34, 0x36, 0x38, 0x3a, 0x3c, 0x3e, 0x40,
|
||||
0x42, 0x44, 0x46, 0x48, 0x4a, 0x4c, 0x4e, 0x50, 0x52, 0x54, 0x56, 0x58, 0x5a, 0x5c, 0x5e, 0x1d, 0x1e, 0x1f, 0x20,
|
||||
};
|
||||
|
||||
struct _loc_coll_cmpt __coll_cmpt = {
|
||||
.char_start_value = ' ',
|
||||
.char_coll_tab_size = 110,
|
||||
.char_spec_accents = 0,
|
||||
.char_coll_table_ptr = &char_coll_table[0],
|
||||
};
|
||||
|
||||
struct _loc_time_cmpt __time_cmpt = {
|
||||
.am_pm = "AM|PM",
|
||||
.DateTime_Format = "%a %b %e %T %Y",
|
||||
.Twelve_hr_format = "%I:%M:%S %p",
|
||||
.Date_Format = "%m/%d/%y",
|
||||
.Time_Format = "%T",
|
||||
.Day_Names = "Sun|Sunday|Mon|Monday|Tue|Tuesday|Wed|Wednesday"
|
||||
"|Thu|Thursday|Fri|Friday|Sat|Saturday",
|
||||
.MonthNames = "Jan|January|Feb|February|Mar|March"
|
||||
"|Apr|April|May|May|Jun|June"
|
||||
"|Jul|July|Aug|August|Sep|September"
|
||||
"|Oct|October|Nov|November|Dec|December",
|
||||
.TimeZone = "",
|
||||
};
|
||||
|
||||
struct __locale _current_locale = {
|
||||
.time_cmpt_ptr = &__time_cmpt,
|
||||
.coll_cmpt_ptr = &__coll_cmpt,
|
||||
.ctype_cmpt_ptr = &__ctype_cmpt,
|
||||
};
|
||||
@@ -0,0 +1,161 @@
|
||||
/* @(#)e_log.c 1.3 95/01/18 */
|
||||
/*
|
||||
* ====================================================
|
||||
* Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
|
||||
*
|
||||
* Developed at SunSoft, a Sun Microsystems, Inc. business.
|
||||
* Permission to use, copy, modify, and distribute this
|
||||
* software is freely granted, provided that this notice
|
||||
* is preserved.
|
||||
* ====================================================
|
||||
*/
|
||||
|
||||
/* __ieee754_log(x)
|
||||
* Return the logrithm of x
|
||||
*
|
||||
* Method :
|
||||
* 1. Argument Reduction: find k and f such that
|
||||
* x = 2^k * (1+f),
|
||||
* where sqrt(2)/2 < 1+f < sqrt(2) .
|
||||
*
|
||||
* 2. Approximation of log(1+f).
|
||||
* Let s = f/(2+f) ; based on log(1+f) = log(1+s) - log(1-s)
|
||||
* = 2s + 2/3 s**3 + 2/5 s**5 + .....,
|
||||
* = 2s + s*R
|
||||
* We use a special Reme algorithm on [0,0.1716] to generate
|
||||
* a polynomial of degree 14 to approximate R The maximum error
|
||||
* of this polynomial approximation is bounded by 2**-58.45. In
|
||||
* other words,
|
||||
* 2 4 6 8 10 12 14
|
||||
* R(z) ~ Lg1*s +Lg2*s +Lg3*s +Lg4*s +Lg5*s +Lg6*s +Lg7*s
|
||||
* (the values of Lg1 to Lg7 are listed in the program)
|
||||
* and
|
||||
* | 2 14 | -58.45
|
||||
* | Lg1*s +...+Lg7*s - R(z) | <= 2
|
||||
* | |
|
||||
* Note that 2s = f - s*f = f - hfsq + s*hfsq, where hfsq = f*f/2.
|
||||
* In order to guarantee error in log below 1ulp, we compute log
|
||||
* by
|
||||
* log(1+f) = f - s*(f - R) (if f is not too large)
|
||||
* log(1+f) = f - (hfsq - s*(hfsq+R)). (better accuracy)
|
||||
*
|
||||
* 3. Finally, log(x) = k*ln2 + log(1+f).
|
||||
* = k*ln2_hi+(f-(hfsq-(s*(hfsq+R)+k*ln2_lo)))
|
||||
* Here ln2 is split into two floating point number:
|
||||
* ln2_hi + ln2_lo,
|
||||
* where n*ln2_hi is always exact for |n| < 2000.
|
||||
*
|
||||
* Special cases:
|
||||
* log(x) is NaN with signal if x < 0 (including -INF) ;
|
||||
* log(+INF) is +INF; log(0) is -INF with signal;
|
||||
* log(NaN) is that NaN with no signal.
|
||||
*
|
||||
* Accuracy:
|
||||
* according to an error analysis, the error is always less than
|
||||
* 1 ulp (unit in the last place).
|
||||
*
|
||||
* Constants:
|
||||
* The hexadecimal values are the intended ones for the following
|
||||
* constants. The decimal values may be used, provided that the
|
||||
* compiler will convert from decimal to binary accurately enough
|
||||
* to produce the hexadecimal values shown.
|
||||
*/
|
||||
|
||||
#include <math.h>
|
||||
|
||||
#ifdef __STDC__
|
||||
static const double
|
||||
#else
|
||||
static double
|
||||
#endif
|
||||
ln2_hi = 6.93147180369123816490e-01, /* 3fe62e42 fee00000 */
|
||||
ln2_lo = 1.90821492927058770002e-10, /* 3dea39ef 35793c76 */
|
||||
two54 = 1.80143985094819840000e+16, /* 43500000 00000000 */
|
||||
Lg1 = 6.666666666666735130e-01, /* 3FE55555 55555593 */
|
||||
Lg2 = 3.999999999940941908e-01, /* 3FD99999 9997FA04 */
|
||||
Lg3 = 2.857142874366239149e-01, /* 3FD24924 94229359 */
|
||||
Lg4 = 2.222219843214978396e-01, /* 3FCC71C5 1D8E78AF */
|
||||
Lg5 = 1.818357216161805012e-01, /* 3FC74664 96CB03DE */
|
||||
Lg6 = 1.531383769920937332e-01, /* 3FC39A09 D078C69F */
|
||||
Lg7 = 1.479819860511658591e-01; /* 3FC2F112 DF3E5244 */
|
||||
|
||||
static double zero = 0.0;
|
||||
|
||||
#ifdef __STDC__
|
||||
double __ieee754_log(double x)
|
||||
#else
|
||||
double __ieee754_log(x)
|
||||
double x;
|
||||
#endif
|
||||
{
|
||||
double hfsq, f, s, z, R, w, t1, t2, dk;
|
||||
int k, hx, i, j;
|
||||
unsigned lx;
|
||||
|
||||
hx = __HI(x); /* high word of x */
|
||||
lx = __LO(x); /* low word of x */
|
||||
|
||||
k = 0;
|
||||
if (hx < 0x00100000) { /* x < 2**-1022 */
|
||||
if (((hx & 0x7fffffff) | lx) == 0) {
|
||||
return -two54 / zero; /* log(+-0)=-inf */
|
||||
}
|
||||
if (hx < 0) {
|
||||
errno = EDOM;
|
||||
return (x - x) / zero;
|
||||
} /* log(-#) = NaN */
|
||||
k -= 54;
|
||||
x *= two54; /* subnormal number, scale up x */
|
||||
hx = __HI(x); /* high word of x */
|
||||
}
|
||||
if (hx >= 0x7ff00000) {
|
||||
return x + x;
|
||||
}
|
||||
k += (hx >> 20) - 1023;
|
||||
hx &= 0x000fffff;
|
||||
i = (hx + 0x95f64) & 0x100000;
|
||||
__HI(x) = hx | (i ^ 0x3ff00000); /* normalize x or x/2 */
|
||||
k += (i >> 20);
|
||||
f = x - 1.0;
|
||||
if ((0x000fffff & (2 + hx)) < 3) { /* |f| < 2**-20 */
|
||||
if (f == zero) {
|
||||
if (k == 0) {
|
||||
return zero;
|
||||
} else {
|
||||
dk = (double) k;
|
||||
return dk * ln2_hi + dk * ln2_lo;
|
||||
}
|
||||
}
|
||||
R = f * f * (0.5 - 0.33333333333333333 * f);
|
||||
if (k == 0) {
|
||||
return f - R;
|
||||
} else {
|
||||
dk = (double) k;
|
||||
return dk * ln2_hi - ((R - dk * ln2_lo) - f);
|
||||
}
|
||||
}
|
||||
s = f / (2.0 + f);
|
||||
dk = (double) k;
|
||||
z = s * s;
|
||||
i = hx - 0x6147a;
|
||||
w = z * z;
|
||||
j = 0x6b851 - hx;
|
||||
t1 = w * (Lg2 + w * (Lg4 + w * Lg6));
|
||||
t2 = z * (Lg1 + w * (Lg3 + w * (Lg5 + w * Lg7)));
|
||||
i |= j;
|
||||
R = t2 + t1;
|
||||
if (i > 0) {
|
||||
hfsq = 0.5 * f * f;
|
||||
if (k == 0) {
|
||||
return f - (hfsq - s * (hfsq + R));
|
||||
} else {
|
||||
return dk * ln2_hi - ((hfsq - (s * (hfsq + R) + dk * ln2_lo)) - f);
|
||||
}
|
||||
} else {
|
||||
if (k == 0) {
|
||||
return f - s * (f - R);
|
||||
} else {
|
||||
return dk * ln2_hi - ((s * (f - R) - dk * ln2_lo) - f);
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,99 @@
|
||||
|
||||
/* @(#)e_log10.c 1.3 95/01/18 */
|
||||
/*
|
||||
* ====================================================
|
||||
* Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
|
||||
*
|
||||
* Developed at SunSoft, a Sun Microsystems, Inc. business.
|
||||
* Permission to use, copy, modify, and distribute this
|
||||
* software is freely granted, provided that this notice
|
||||
* is preserved.
|
||||
* ====================================================
|
||||
*/
|
||||
|
||||
/* __ieee754_log10(x)
|
||||
* Return the base 10 logarithm of x
|
||||
*
|
||||
* Method :
|
||||
* Let log10_2hi = leading 40 bits of log10(2) and
|
||||
* log10_2lo = log10(2) - log10_2hi,
|
||||
* ivln10 = 1/log(10) rounded.
|
||||
* Then
|
||||
* n = ilogb(x),
|
||||
* if(n<0) n = n+1;
|
||||
* x = scalbn(x,-n);
|
||||
* log10(x) := n*log10_2hi + (n*log10_2lo + ivln10*log(x))
|
||||
*
|
||||
* Note 1:
|
||||
* To guarantee log10(10**n)=n, where 10**n is normal, the rounding
|
||||
* mode must set to Round-to-Nearest.
|
||||
* Note 2:
|
||||
* [1/log(10)] rounded to 53 bits has error .198 ulps;
|
||||
* log10 is monotonic at all binary break points.
|
||||
*
|
||||
* Special cases:
|
||||
* log10(x) is NaN with signal if x < 0;
|
||||
* log10(+INF) is +INF with no signal; log10(0) is -INF with signal;
|
||||
* log10(NaN) is that NaN with no signal;
|
||||
* log10(10**N) = N for N=0,1,...,22.
|
||||
*
|
||||
* Constants:
|
||||
* The hexadecimal values are the intended ones for the following constants.
|
||||
* The decimal values may be used, provided that the compiler will convert
|
||||
* from decimal to binary accurately enough to produce the hexadecimal values
|
||||
* shown.
|
||||
*/
|
||||
|
||||
#include <math.h>
|
||||
|
||||
#ifdef __STDC__
|
||||
static const double
|
||||
#else
|
||||
static double
|
||||
#endif
|
||||
two54 = 1.80143985094819840000e+16, /* 0x43500000, 0x00000000 */
|
||||
ivln10 = 4.34294481903251816668e-01, /* 0x3FDBCB7B, 0x1526E50E */
|
||||
log10_2hi = 3.01029995663611771306e-01, /* 0x3FD34413, 0x509F6000 */
|
||||
log10_2lo = 3.69423907715893078616e-13; /* 0x3D59FEF3, 0x11F12B36 */
|
||||
|
||||
static double zero = 0.0;
|
||||
|
||||
#ifdef __STDC__
|
||||
double __ieee754_log10(double x)
|
||||
#else
|
||||
double __ieee754_log10(x)
|
||||
double x;
|
||||
#endif
|
||||
{
|
||||
double y, z;
|
||||
int i, k, hx;
|
||||
unsigned lx;
|
||||
|
||||
hx = __HI(x); /* high word of x */
|
||||
lx = __LO(x); /* low word of x */
|
||||
|
||||
k = 0;
|
||||
if (hx < 0x00100000) { /* x < 2**-1022 */
|
||||
if (((hx & 0x7fffffff) | lx) == 0) {
|
||||
errno = EDOM;
|
||||
return -two54 / zero;
|
||||
} /* log(+-0)=-inf */
|
||||
if (hx < 0) {
|
||||
errno = EDOM;
|
||||
return (x - x) / zero;
|
||||
} /* log(-#) = NaN */
|
||||
k -= 54;
|
||||
x *= two54; /* subnormal number, scale up x */
|
||||
hx = __HI(x); /* high word of x */
|
||||
}
|
||||
if (hx >= 0x7ff00000) {
|
||||
return x + x;
|
||||
}
|
||||
k += (hx >> 20) - 1023;
|
||||
i = ((unsigned) k & 0x80000000) >> 31;
|
||||
hx = (hx & 0x000fffff) | ((0x3ff - i) << 20);
|
||||
y = (double) (k + i);
|
||||
__HI(x) = hx;
|
||||
z = y * log10_2lo + ivln10 * log(x);
|
||||
return z + y * log10_2hi;
|
||||
}
|
||||
@@ -0,0 +1,370 @@
|
||||
/* @(#)e_pow.c 1.2 95/01/04 */
|
||||
/*
|
||||
* ====================================================
|
||||
* Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
|
||||
*
|
||||
* Developed at SunPro, a Sun Microsystems, Inc. business.
|
||||
* Permission to use, copy, modify, and distribute this
|
||||
* software is freely granted, provided that this notice
|
||||
* is preserved.
|
||||
* ====================================================
|
||||
*/
|
||||
|
||||
/* __ieee754_pow(x,y) return x**y
|
||||
*
|
||||
* n
|
||||
* Method: Let x = 2 * (1+f)
|
||||
* 1. Compute and return log2(x) in two pieces:
|
||||
* log2(x) = w1 + w2,
|
||||
* where w1 has 53-24 = 29 bit trailing zeros.
|
||||
* 2. Perform y*log2(x) = n+y' by simulating muti-precision
|
||||
* arithmetic, where |y'|<=0.5.
|
||||
* 3. Return x**y = 2**n*exp(y'*log2)
|
||||
*
|
||||
* Special cases:
|
||||
* 1. (anything) ** 0 is 1
|
||||
* 2. (anything) ** 1 is itself
|
||||
* 3. (anything) ** NAN is NAN
|
||||
* 4. NAN ** (anything except 0) is NAN
|
||||
* 5. +-(|x| > 1) ** +INF is +INF
|
||||
* 6. +-(|x| > 1) ** -INF is +0
|
||||
* 7. +-(|x| < 1) ** +INF is +0
|
||||
* 8. +-(|x| < 1) ** -INF is +INF
|
||||
* 9. +-1 ** +-INF is NAN
|
||||
* 10. +0 ** (+anything except 0, NAN) is +0
|
||||
* 11. -0 ** (+anything except 0, NAN, odd integer) is +0
|
||||
* 12. +0 ** (-anything except 0, NAN) is +INF
|
||||
* 13. -0 ** (-anything except 0, NAN, odd integer) is +INF
|
||||
* 14. -0 ** (odd integer) = -( +0 ** (odd integer) )
|
||||
* 15. +INF ** (+anything except 0,NAN) is +INF
|
||||
* 16. +INF ** (-anything except 0,NAN) is +0
|
||||
* 17. -INF ** (anything) = -0 ** (-anything)
|
||||
* 18. (-anything) ** (integer) is (-1)**(integer)*(+anything**integer)
|
||||
* 19. (-anything except 0 and inf) ** (non-integer) is NAN
|
||||
*
|
||||
* Accuracy:
|
||||
* pow(x,y) returns x**y nearly rounded. In particular
|
||||
* pow(integer,integer)
|
||||
* always returns the correct integer provided it is
|
||||
* representable.
|
||||
*
|
||||
* Constants :
|
||||
* The hexadecimal values are the intended ones for the following
|
||||
* constants. The decimal values may be used, provided that the
|
||||
* compiler will convert from decimal to binary accurately enough
|
||||
* to produce the hexadecimal values shown.
|
||||
*/
|
||||
|
||||
#include <math.h>
|
||||
#ifdef __STDC__
|
||||
static const double
|
||||
#else
|
||||
static double
|
||||
#endif
|
||||
bp[] =
|
||||
{
|
||||
1.0,
|
||||
1.5,
|
||||
},
|
||||
dp_h[] =
|
||||
{
|
||||
0.0,
|
||||
5.84962487220764160156e-01,
|
||||
}, /* 0x3FE2B803, 0x40000000 */
|
||||
dp_l[] =
|
||||
{
|
||||
0.0,
|
||||
1.35003920212974897128e-08,
|
||||
}, /* 0x3E4CFDEB, 0x43CFD006 */
|
||||
zero = 0.0, one = 1.0, two = 2.0, two53 = 9007199254740992.0, /* 0x43400000, 0x00000000 */
|
||||
big = 1.0e300, tiny = 1.0e-300,
|
||||
/* poly coefs for (3/2)*(log(x)-2s-2/3*s**3 */
|
||||
L1 = 5.99999999999994648725e-01, /* 0x3FE33333, 0x33333303 */
|
||||
L2 = 4.28571428578550184252e-01, /* 0x3FDB6DB6, 0xDB6FABFF */
|
||||
L3 = 3.33333329818377432918e-01, /* 0x3FD55555, 0x518F264D */
|
||||
L4 = 2.72728123808534006489e-01, /* 0x3FD17460, 0xA91D4101 */
|
||||
L5 = 2.30660745775561754067e-01, /* 0x3FCD864A, 0x93C9DB65 */
|
||||
L6 = 2.06975017800338417784e-01, /* 0x3FCA7E28, 0x4A454EEF */
|
||||
P1 = 1.66666666666666019037e-01, /* 0x3FC55555, 0x5555553E */
|
||||
P2 = -2.77777777770155933842e-03, /* 0xBF66C16C, 0x16BEBD93 */
|
||||
P3 = 6.61375632143793436117e-05, /* 0x3F11566A, 0xAF25DE2C */
|
||||
P4 = -1.65339022054652515390e-06, /* 0xBEBBBD41, 0xC5D26BF1 */
|
||||
P5 = 4.13813679705723846039e-08, /* 0x3E663769, 0x72BEA4D0 */
|
||||
lg2 = 6.93147180559945286227e-01, /* 0x3FE62E42, 0xFEFA39EF */
|
||||
lg2_h = 6.93147182464599609375e-01, /* 0x3FE62E43, 0x00000000 */
|
||||
lg2_l = -1.90465429995776804525e-09, /* 0xBE205C61, 0x0CA86C39 */
|
||||
ovt = 8.0085662595372944372e-0017, /* -(1024-log2(ovfl+.5ulp)) */
|
||||
cp = 9.61796693925975554329e-01, /* 0x3FEEC709, 0xDC3A03FD =2/(3ln2) */
|
||||
cp_h = 9.61796700954437255859e-01, /* 0x3FEEC709, 0xE0000000 =(float)cp */
|
||||
cp_l = -7.02846165095275826516e-09, /* 0xBE3E2FE0, 0x145B01F5 =tail of cp_h*/
|
||||
ivln2 = 1.44269504088896338700e+00, /* 0x3FF71547, 0x652B82FE =1/ln2 */
|
||||
ivln2_h = 1.44269502162933349609e+00, /* 0x3FF71547, 0x60000000 =24b 1/ln2*/
|
||||
ivln2_l = 1.92596299112661746887e-08; /* 0x3E54AE0B, 0xF85DDF44 =1/ln2 tail*/
|
||||
|
||||
#ifdef __STDC__
|
||||
double __ieee754_pow(double x, double y)
|
||||
#else
|
||||
double __ieee754_pow(x, y)
|
||||
double x, y;
|
||||
#endif
|
||||
{
|
||||
double z, ax, z_h, z_l, p_h, p_l;
|
||||
double y1, t1, t2, r, s, t, u, v, w;
|
||||
int i, j, k, yisint, n;
|
||||
int hx, hy, ix, iy;
|
||||
unsigned int lx, ly;
|
||||
|
||||
hx = __HI(x);
|
||||
lx = __LO(x);
|
||||
hy = __HI(y);
|
||||
ly = __LO(y);
|
||||
ix = hx & 0x7fffffff;
|
||||
iy = hy & 0x7fffffff;
|
||||
|
||||
/* y==zero: x**0 = 1 */
|
||||
if ((iy | ly) == 0) {
|
||||
return one;
|
||||
}
|
||||
|
||||
/* +-NaN return x+y */
|
||||
if (ix > 0x7ff00000 || ((ix == 0x7ff00000) && (lx != 0)) || iy > 0x7ff00000 || ((iy == 0x7ff00000) && (ly != 0))) {
|
||||
return x + y;
|
||||
#ifdef __STDC__
|
||||
errno = EDOM; /* mf-- added to conform to old ANSI standard */
|
||||
#endif
|
||||
}
|
||||
|
||||
/* determine if y is an odd int when x < 0
|
||||
* yisint = 0 ... y is not an integer
|
||||
* yisint = 1 ... y is an odd int
|
||||
* yisint = 2 ... y is an even int
|
||||
*/
|
||||
yisint = 0;
|
||||
if (hx < 0) {
|
||||
if (iy >= 0x43400000) {
|
||||
yisint = 2; /* even integer y */
|
||||
} else if (iy >= 0x3ff00000) {
|
||||
k = (iy >> 20) - 0x3ff; /* exponent */
|
||||
if (k > 20) {
|
||||
j = ly >> (52 - k);
|
||||
if ((j << (52 - k)) == ly) {
|
||||
yisint = 2 - (j & 1);
|
||||
}
|
||||
} else if (ly == 0) {
|
||||
j = iy >> (20 - k);
|
||||
if ((j << (20 - k)) == iy) {
|
||||
yisint = 2 - (j & 1);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/* special value of y */
|
||||
if (ly == 0) {
|
||||
if (iy == 0x7ff00000) {
|
||||
|
||||
/* y is +-inf */
|
||||
if (((ix - 0x3ff00000) | lx) == 0) {
|
||||
return y - y; /* inf**+-1 is NaN */
|
||||
} else if (ix >= 0x3ff00000) { /* (|x|>1)**+-inf = inf,0 */
|
||||
return (hy >= 0) ? y : zero;
|
||||
} else { /* (|x|<1)**-,+inf = inf,0 */
|
||||
return (hy < 0) ? -y : zero;
|
||||
}
|
||||
}
|
||||
if (iy == 0x3ff00000) {
|
||||
/* y is +-1 */
|
||||
if (hy < 0) {
|
||||
return one / x;
|
||||
} else {
|
||||
return x;
|
||||
}
|
||||
}
|
||||
if (hy == 0x40000000) {
|
||||
return x * x; /* y is 2 */
|
||||
}
|
||||
if (hy == 0x3fe00000) { /* y is 0.5 */
|
||||
if (hx >= 0) { /* x >= +0 */
|
||||
return sqrt(x);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
ax = fabs(x);
|
||||
/* special value of x */
|
||||
if (lx == 0) {
|
||||
if (ix == 0x7ff00000 || ix == 0 || ix == 0x3ff00000) {
|
||||
z = ax; /*x is +-0,+-inf,+-1*/
|
||||
if (hy < 0) {
|
||||
z = one / z; /* z = (1/|x|) */
|
||||
}
|
||||
if (hx < 0) {
|
||||
if (((ix - 0x3ff00000) | yisint) == 0) {
|
||||
z = (z - z) / (z - z); /* (-1)**non-int is NaN */
|
||||
} else if (yisint == 1) {
|
||||
z = -z; /* (x<0)**odd = -(|x|**odd) */
|
||||
}
|
||||
}
|
||||
return z;
|
||||
}
|
||||
}
|
||||
|
||||
/* (x<0)**(non-int) is NaN */
|
||||
if ((((hx >> 31) + 1) | yisint) == 0) {
|
||||
#ifdef __STDC__
|
||||
errno = EDOM; /* mf-- added to conform to old ANSI standard */
|
||||
#endif
|
||||
return NAN;
|
||||
}
|
||||
|
||||
/* |y| is big */
|
||||
if (iy > 0x41e00000) { /* if |y| > 2**31 */
|
||||
if (iy > 0x43f00000) { /* if |y| > 2**64, must o/uflow */
|
||||
if (ix <= 0x3fefffff) {
|
||||
return (hy < 0) ? big * big : tiny * tiny;
|
||||
}
|
||||
if (ix >= 0x3ff00000) {
|
||||
return (hy > 0) ? big * big : tiny * tiny;
|
||||
}
|
||||
}
|
||||
/* over/underflow if x is not close to one */
|
||||
if (ix < 0x3fefffff) {
|
||||
return (hy < 0) ? big * big : tiny * tiny;
|
||||
}
|
||||
if (ix > 0x3ff00000) {
|
||||
return (hy > 0) ? big * big : tiny * tiny;
|
||||
}
|
||||
/* now |1-x| is tiny <= 2**-20, suffice to compute
|
||||
log(x) by x-x^2/2+x^3/3-x^4/4 */
|
||||
t = x - 1; /* t has 20 trailing zeros */
|
||||
w = (t * t) * (0.5 - t * (0.3333333333333333333333 - t * 0.25));
|
||||
u = ivln2_h * t; /* ivln2_h has 21 sig. bits */
|
||||
v = t * ivln2_l - w * ivln2;
|
||||
t1 = u + v;
|
||||
__LO(t1) = 0;
|
||||
t2 = v - (t1 - u);
|
||||
} else {
|
||||
double s2, s_h, s_l, t_h, t_l;
|
||||
n = 0;
|
||||
/* take care subnormal number */
|
||||
if (ix < 0x00100000) {
|
||||
ax *= two53;
|
||||
n -= 53;
|
||||
ix = __HI(ax);
|
||||
}
|
||||
n += ((ix) >> 20) - 0x3ff;
|
||||
j = ix & 0x000fffff;
|
||||
/* determine interval */
|
||||
ix = j | 0x3ff00000; /* normalize ix */
|
||||
if (j <= 0x3988E) {
|
||||
k = 0; /* |x|<sqrt(3/2) */
|
||||
} else if (j < 0xBB67A) {
|
||||
k = 1; /* |x|<sqrt(3) */
|
||||
} else {
|
||||
k = 0;
|
||||
n += 1;
|
||||
ix -= 0x00100000;
|
||||
}
|
||||
__HI(ax) = ix;
|
||||
|
||||
/* compute s = s_h+s_l = (x-1)/(x+1) or (x-1.5)/(x+1.5) */
|
||||
u = ax - bp[k]; /* bp[0]=1.0, bp[1]=1.5 */
|
||||
v = one / (ax + bp[k]);
|
||||
s = u * v;
|
||||
s_h = s;
|
||||
__LO(s_h) = 0;
|
||||
/* t_h=ax+bp[k] High */
|
||||
t_h = zero;
|
||||
__HI(t_h) = ((ix >> 1) | 0x20000000) + 0x00080000 + (k << 18);
|
||||
t_l = ax - (t_h - bp[k]);
|
||||
s_l = v * ((u - s_h * t_h) - s_h * t_l);
|
||||
/* compute log(ax) */
|
||||
s2 = s * s;
|
||||
r = s2 * s2 * (L1 + s2 * (L2 + s2 * (L3 + s2 * (L4 + s2 * (L5 + s2 * L6)))));
|
||||
r += s_l * (s_h + s);
|
||||
s2 = s_h * s_h;
|
||||
t_h = 3.0 + s2 + r;
|
||||
__LO(t_h) = 0;
|
||||
t_l = r - ((t_h - 3.0) - s2);
|
||||
/* u+v = s*(1+...) */
|
||||
u = s_h * t_h;
|
||||
v = s_l * t_h + t_l * s;
|
||||
/* 2/(3log2)*(s+...) */
|
||||
p_h = u + v;
|
||||
__LO(p_h) = 0;
|
||||
p_l = v - (p_h - u);
|
||||
z_h = cp_h * p_h; /* cp_h+cp_l = 2/(3*log2) */
|
||||
z_l = cp_l * p_h + p_l * cp + dp_l[k];
|
||||
/* log2(ax) = (s+..)*2/(3*log2) = n + dp_h + z_h + z_l */
|
||||
t = (double) n;
|
||||
t1 = (((z_h + z_l) + dp_h[k]) + t);
|
||||
__LO(t1) = 0;
|
||||
t2 = z_l - (((t1 - t) - dp_h[k]) - z_h);
|
||||
}
|
||||
|
||||
s = one; /* s (sign of result -ve**odd) = -1 else = 1 */
|
||||
if ((((hx >> 31) + 1) | (yisint - 1)) == 0) {
|
||||
s = -one; /* (-ve)**(odd int) */
|
||||
}
|
||||
|
||||
/* split up y into y1+y2 and compute (y1+y2)*(t1+t2) */
|
||||
y1 = y;
|
||||
__LO(y1) = 0;
|
||||
p_l = (y - y1) * t1 + y * t2;
|
||||
p_h = y1 * t1;
|
||||
z = p_l + p_h;
|
||||
j = __HI(z);
|
||||
i = __LO(z);
|
||||
if (j >= 0x40900000) { /* z >= 1024 */
|
||||
if (((j - 0x40900000) | i) != 0) { /* if z > 1024 */
|
||||
return s * big * big; /* overflow */
|
||||
} else {
|
||||
if (p_l + ovt > z - p_h) {
|
||||
return s * big * big; /* overflow */
|
||||
}
|
||||
}
|
||||
} else if ((j & 0x7fffffff) >= 0x4090cc00) { /* z <= -1075 */
|
||||
if (((j - 0xc090cc00) | i) != 0) { /* z < -1075 */
|
||||
return s * tiny * tiny; /* underflow */
|
||||
} else {
|
||||
if (p_l <= z - p_h) {
|
||||
return s * tiny * tiny; /* underflow */
|
||||
}
|
||||
}
|
||||
}
|
||||
/*
|
||||
* compute 2**(p_h+p_l)
|
||||
*/
|
||||
i = j & 0x7fffffff;
|
||||
k = (i >> 20) - 0x3ff;
|
||||
n = 0;
|
||||
if (i > 0x3fe00000) { /* if |z| > 0.5, set n = [z+0.5] */
|
||||
n = j + (0x00100000 >> (k + 1));
|
||||
k = ((n & 0x7fffffff) >> 20) - 0x3ff; /* new k for n */
|
||||
t = zero;
|
||||
__HI(t) = (n & ~(0x000fffff >> k));
|
||||
n = ((n & 0x000fffff) | 0x00100000) >> (20 - k);
|
||||
if (j < 0) {
|
||||
n = -n;
|
||||
}
|
||||
p_h -= t;
|
||||
}
|
||||
t = p_l + p_h;
|
||||
__LO(t) = 0;
|
||||
u = t * lg2_h;
|
||||
v = (p_l - (t - p_h)) * lg2 + t * lg2_l;
|
||||
z = u + v;
|
||||
w = v - (z - u);
|
||||
t = z * z;
|
||||
t1 = z - t * (P1 + t * (P2 + t * (P3 + t * (P4 + t * P5))));
|
||||
r = (z * t1) / (t1 - two) - (w + z * w);
|
||||
z = one - (r - z);
|
||||
j = __HI(z);
|
||||
j += (n << 20);
|
||||
if ((j >> 20) <= 0) {
|
||||
z = scalbn(z, n); /* subnormal output */
|
||||
} else {
|
||||
__HI(z) += (n << 20);
|
||||
}
|
||||
return s * z;
|
||||
}
|
||||
@@ -0,0 +1,96 @@
|
||||
|
||||
/* @(#)s_ceil.c 1.3 95/01/18 */
|
||||
/*
|
||||
* ====================================================
|
||||
* Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
|
||||
*
|
||||
* Developed at SunSoft, a Sun Microsystems, Inc. business.
|
||||
* Permission to use, copy, modify, and distribute this
|
||||
* software is freely granted, provided that this notice
|
||||
* is preserved.
|
||||
* ====================================================
|
||||
*/
|
||||
|
||||
/*
|
||||
* ceil(x)
|
||||
* Return x rounded toward -inf to integral value
|
||||
* Method:
|
||||
* Bit twiddling.
|
||||
* Exception:
|
||||
* Inexact flag raised if x not equal to ceil(x).
|
||||
*/
|
||||
|
||||
#include <math.h>
|
||||
|
||||
#ifdef __STDC__
|
||||
static const double huge = 1.0e300;
|
||||
#else
|
||||
static double huge = 1.0e300;
|
||||
#endif
|
||||
|
||||
#ifdef __STDC__
|
||||
double ceil(double x)
|
||||
#else
|
||||
double ceil(x)
|
||||
double x;
|
||||
#endif
|
||||
{
|
||||
int i0, i1, j0;
|
||||
unsigned i, j;
|
||||
i0 = __HI(x);
|
||||
i1 = __LO(x);
|
||||
j0 = ((i0 >> 20) & 0x7ff) - 0x3ff;
|
||||
if (j0 < 20) {
|
||||
if (j0 < 0) { /* raise inexact if x != 0 */
|
||||
if (huge + x > 0.0) { /* return 0*sign(x) if |x|<1 */
|
||||
if (i0 < 0) {
|
||||
i0 = 0x80000000;
|
||||
i1 = 0;
|
||||
} else if ((i0 | i1) != 0) {
|
||||
i0 = 0x3ff00000;
|
||||
i1 = 0;
|
||||
}
|
||||
}
|
||||
} else {
|
||||
i = (0x000fffff) >> j0;
|
||||
if (((i0 & i) | i1) == 0) {
|
||||
return x; /* x is integral */
|
||||
}
|
||||
if (huge + x > 0.0) { /* raise inexact flag */
|
||||
if (i0 > 0) {
|
||||
i0 += (0x00100000) >> j0;
|
||||
}
|
||||
i0 &= (~i);
|
||||
i1 = 0;
|
||||
}
|
||||
}
|
||||
} else if (j0 > 51) {
|
||||
if (j0 == 0x400) {
|
||||
return x + x; /* inf or NaN */
|
||||
} else {
|
||||
return x; /* x is integral */
|
||||
}
|
||||
} else {
|
||||
i = ((unsigned) (0xffffffff)) >> (j0 - 20);
|
||||
if ((i1 & i) == 0) {
|
||||
return x; /* x is integral */
|
||||
}
|
||||
if (huge + x > 0.0) { /* raise inexact flag */
|
||||
if (i0 > 0) {
|
||||
if (j0 == 20) {
|
||||
i0 += 1;
|
||||
} else {
|
||||
j = i1 + (1 << (52 - j0));
|
||||
if (j < i1) {
|
||||
i0 += 1; /* got a carry */
|
||||
}
|
||||
i1 = j;
|
||||
}
|
||||
}
|
||||
i1 &= (~i);
|
||||
}
|
||||
}
|
||||
__HI(x) = i0;
|
||||
__LO(x) = i1;
|
||||
return x;
|
||||
}
|
||||
@@ -0,0 +1,31 @@
|
||||
|
||||
/* @(#)s_copysign.c 1.3 95/01/18 */
|
||||
/*
|
||||
* ====================================================
|
||||
* Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
|
||||
*
|
||||
* Developed at SunSoft, a Sun Microsystems, Inc. business.
|
||||
* Permission to use, copy, modify, and distribute this
|
||||
* software is freely granted, provided that this notice
|
||||
* is preserved.
|
||||
* ====================================================
|
||||
*/
|
||||
|
||||
/*
|
||||
* copysign(double x, double y)
|
||||
* copysign(x,y) returns a value with the magnitude of x and
|
||||
* with the sign bit of y.
|
||||
*/
|
||||
|
||||
#include <math.h>
|
||||
|
||||
#ifdef __STDC__
|
||||
double copysign(double x, double y)
|
||||
#else
|
||||
double copysign(x, y)
|
||||
double x, y;
|
||||
#endif
|
||||
{
|
||||
__HI(x) = (__HI(x) & 0x7fffffff) | (__HI(y) & 0x80000000);
|
||||
return x;
|
||||
}
|
||||
@@ -0,0 +1,29 @@
|
||||
|
||||
/* @(#)s_fabs.c 1.3 95/01/18 */
|
||||
/*
|
||||
* ====================================================
|
||||
* Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
|
||||
*
|
||||
* Developed at SunSoft, a Sun Microsystems, Inc. business.
|
||||
* Permission to use, copy, modify, and distribute this
|
||||
* software is freely granted, provided that this notice
|
||||
* is preserved.
|
||||
* ====================================================
|
||||
*/
|
||||
|
||||
/*
|
||||
* fabs(x) returns the absolute value of x.
|
||||
*/
|
||||
|
||||
#include <math.h>
|
||||
|
||||
#ifdef __STDC__
|
||||
double fabs(double x)
|
||||
#else
|
||||
double fabs(x)
|
||||
double x;
|
||||
#endif
|
||||
{
|
||||
__HI(x) &= 0x7fffffff;
|
||||
return x;
|
||||
}
|
||||
@@ -0,0 +1,59 @@
|
||||
|
||||
/* @(#)s_frexp.c 1.4 95/01/18 */
|
||||
/*
|
||||
* ====================================================
|
||||
* Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
|
||||
*
|
||||
* Developed at SunSoft, a Sun Microsystems, Inc. business.
|
||||
* Permission to use, copy, modify, and distribute this
|
||||
* software is freely granted, provided that this notice
|
||||
* is preserved.
|
||||
* ====================================================
|
||||
*/
|
||||
|
||||
/*
|
||||
* for non-zero x
|
||||
* x = frexp(arg,&exp);
|
||||
* return a double fp quantity x such that 0.5 <= |x| <1.0
|
||||
* and the corresponding binary exponent "exp". That is
|
||||
* arg = x*2^exp.
|
||||
* If arg is inf, 0.0, or NaN, then frexp(arg,&exp) returns arg
|
||||
* with *exp=0.
|
||||
*/
|
||||
|
||||
#include <math.h>
|
||||
|
||||
#ifdef __STDC__
|
||||
static const double
|
||||
#else
|
||||
static double
|
||||
#endif
|
||||
two54 = 1.80143985094819840000e+16; /* 0x43500000, 0x00000000 */
|
||||
|
||||
#ifdef __STDC__
|
||||
double frexp(double x, int *eptr)
|
||||
#else
|
||||
double frexp(x, eptr)
|
||||
double x;
|
||||
int *eptr;
|
||||
#endif
|
||||
{
|
||||
int hx, ix, lx;
|
||||
hx = __HI(x);
|
||||
ix = 0x7fffffff & hx;
|
||||
lx = __LO(x);
|
||||
*eptr = 0;
|
||||
if (ix >= 0x7ff00000 || ((ix | lx) == 0)) {
|
||||
return x; /* 0,inf,nan */
|
||||
}
|
||||
if (ix < 0x00100000) { /* subnormal */
|
||||
x *= two54;
|
||||
hx = __HI(x);
|
||||
ix = hx & 0x7fffffff;
|
||||
*eptr = -54;
|
||||
}
|
||||
*eptr += (ix >> 20) - 1022;
|
||||
hx = (hx & 0x800fffff) | 0x3fe00000;
|
||||
__HI(x) = hx;
|
||||
return x;
|
||||
}
|
||||
@@ -0,0 +1,66 @@
|
||||
#ifndef _No_Floating_Point
|
||||
/* @(#)s_ldexp.c 1.2 95/01/04 */
|
||||
/* $Id: s_ldexp.c,v 1.3.14.1 2002/01/31 15:24:14 ceciliar Exp $ */
|
||||
/*
|
||||
* ====================================================
|
||||
* Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
|
||||
*
|
||||
* Developed at SunPro, a Sun Microsystems, Inc. business.
|
||||
* Permission to use, copy, modify, and distribute this
|
||||
* software is freely granted, provided that this notice
|
||||
* is preserved.
|
||||
* ====================================================
|
||||
*/
|
||||
|
||||
#include <math.h>
|
||||
|
||||
static const double two54 = 1.80143985094819840000e+16, /* 0x43500000, 0x00000000 */
|
||||
twom54 = 5.55111512312578270212e-17, /* 0x3C900000, 0x00000000 */
|
||||
big = 1.0e+300, tiny = 1.0e-300;
|
||||
|
||||
double ldexp(double x, int n) {
|
||||
int k, hx, lx;
|
||||
if (!isfinite(x) || x == 0.0) {
|
||||
return x;
|
||||
}
|
||||
|
||||
hx = __HI(x);
|
||||
lx = __LO(x);
|
||||
k = (hx & 0x7ff00000) >> 20; /* extract exponent */
|
||||
if (k == 0) { /* 0 or subnormal x */
|
||||
if ((lx | (hx & 0x7fffffff)) == 0) {
|
||||
return x; /* +-0 */
|
||||
}
|
||||
x *= two54;
|
||||
hx = __HI(x);
|
||||
k = ((hx & 0x7ff00000) >> 20) - 54;
|
||||
if (n < -50000) {
|
||||
return tiny * x; /*underflow*/
|
||||
}
|
||||
}
|
||||
if (k == 0x7ff) {
|
||||
return x + x; /* NaN or Inf */
|
||||
}
|
||||
k = k + n;
|
||||
if (k > 0x7fe) {
|
||||
return big * copysign(big, x); /* overflow */
|
||||
}
|
||||
if (k > 0) /* normal result */
|
||||
{
|
||||
__HI(x) = (hx & 0x800fffff) | (k << 20);
|
||||
return x;
|
||||
}
|
||||
if (k <= -54) {
|
||||
if (n > 50000) { /* in case integer overflow in n+k */
|
||||
return big * copysign(big, x); /*overflow*/
|
||||
} else {
|
||||
return tiny * copysign(tiny, x); /*underflow*/
|
||||
}
|
||||
}
|
||||
k += 54; /* subnormal result */
|
||||
__HI(x) = (hx & 0x800fffff) | (k << 20);
|
||||
return x * twom54;
|
||||
}
|
||||
|
||||
/* changed __finite to __isfinite to match new naming convention 141097 bds */
|
||||
#endif /* _No_Floating_Point */
|
||||
@@ -0,0 +1,16 @@
|
||||
/*
|
||||
* ====================================================
|
||||
* Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
|
||||
*
|
||||
* Developed at SunSoft, a Sun Microsystems, Inc. business.
|
||||
* Permission to use, copy, modify, and distribute this
|
||||
* software is freely granted, provided that this notice
|
||||
* is preserved.
|
||||
* ====================================================
|
||||
*/
|
||||
|
||||
extern double __ieee754_log();
|
||||
|
||||
double log(double __x) {
|
||||
return (double) __ieee754_log();
|
||||
}
|
||||
@@ -0,0 +1,16 @@
|
||||
/*
|
||||
* ====================================================
|
||||
* Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
|
||||
*
|
||||
* Developed at SunSoft, a Sun Microsystems, Inc. business.
|
||||
* Permission to use, copy, modify, and distribute this
|
||||
* software is freely granted, provided that this notice
|
||||
* is preserved.
|
||||
* ====================================================
|
||||
*/
|
||||
|
||||
extern double __ieee754_log10();
|
||||
|
||||
double log10f(double __x) {
|
||||
return (double) __ieee754_log10();
|
||||
}
|
||||
@@ -0,0 +1,16 @@
|
||||
/*
|
||||
* ====================================================
|
||||
* Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
|
||||
*
|
||||
* Developed at SunSoft, a Sun Microsystems, Inc. business.
|
||||
* Permission to use, copy, modify, and distribute this
|
||||
* software is freely granted, provided that this notice
|
||||
* is preserved.
|
||||
* ====================================================
|
||||
*/
|
||||
|
||||
extern double __ieee754_pow();
|
||||
|
||||
double pow(double __x, double __y) {
|
||||
return (double) __ieee754_pow();
|
||||
}
|
||||
@@ -0,0 +1,26 @@
|
||||
#include <math.h>
|
||||
|
||||
int __signbitd(double x) {
|
||||
return (__HI(x) & 0x80000000) != 0;
|
||||
}
|
||||
|
||||
int __fpclassifyd(double x) {
|
||||
switch (__HI(x) & 0x7FF00000) {
|
||||
case 0x7FF00000:
|
||||
if ((__HI(x) & 0x000FFFFF) || (__LO(x) & 0xFFFFFFFF)) {
|
||||
return 1;
|
||||
} else {
|
||||
return 2;
|
||||
}
|
||||
break;
|
||||
case 0:
|
||||
if ((__HI(x) & 0x000FFFFf) || (__LO(x) & 0xFFFFFFFF)) {
|
||||
return 5;
|
||||
} else {
|
||||
return 3;
|
||||
}
|
||||
break;
|
||||
}
|
||||
|
||||
return 4;
|
||||
}
|
||||
@@ -0,0 +1,72 @@
|
||||
#include <locale.h>
|
||||
#include <stddef.h>
|
||||
|
||||
char *strncpy(char *dest, const char *src, size_t n);
|
||||
size_t strlen(const char *str);
|
||||
|
||||
int mbtowc(short *pwc, const char *s, int n) {
|
||||
return _current_locale.ctype_cmpt_ptr->decode_mb(pwc, s, n);
|
||||
}
|
||||
|
||||
int __mbtowc_noconv(unsigned short *pwc, const char *str, int n) {
|
||||
const unsigned char *s = (const unsigned char *) str;
|
||||
|
||||
if (s == NULL) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
if (n == 0) {
|
||||
return -1;
|
||||
}
|
||||
|
||||
if (pwc != NULL) {
|
||||
*pwc = (unsigned char) *s;
|
||||
}
|
||||
|
||||
if (*s == 0) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
return 1;
|
||||
}
|
||||
|
||||
int __wctomb_noconv(char *s, unsigned short wchar) {
|
||||
if (s == NULL) {
|
||||
return 0;
|
||||
}
|
||||
*s = wchar;
|
||||
return 1;
|
||||
}
|
||||
|
||||
size_t mbstowcs(wchar_t *pDest, const char *pSrc, size_t num) {
|
||||
int res;
|
||||
unsigned char *src;
|
||||
int count;
|
||||
size_t src_len;
|
||||
|
||||
src_len = strlen(pSrc);
|
||||
|
||||
if (pDest != 0) {
|
||||
src = (unsigned char *) pSrc;
|
||||
|
||||
for (count = 0; count < num; count++) {
|
||||
if (*src) {
|
||||
res = mbtowc(pDest++, src, src_len);
|
||||
|
||||
if (res > 0) {
|
||||
src += res;
|
||||
src_len -= res;
|
||||
} else {
|
||||
return -1;
|
||||
}
|
||||
} else {
|
||||
*pDest = 0;
|
||||
break;
|
||||
}
|
||||
}
|
||||
} else {
|
||||
count = 0;
|
||||
}
|
||||
|
||||
return count;
|
||||
}
|
||||
@@ -0,0 +1,64 @@
|
||||
#include <mem_funcs.h>
|
||||
#include <stddef.h>
|
||||
|
||||
void *memcpy(void *dst, const void *src, int n) {
|
||||
const unsigned char *p = (unsigned char *) src;
|
||||
unsigned char *q = (unsigned char *) dst;
|
||||
|
||||
for (n++; --n;) {
|
||||
*q++ = *p++;
|
||||
}
|
||||
|
||||
return dst;
|
||||
}
|
||||
|
||||
void *memmove(void *dst, const void *src, size_t len) {
|
||||
unsigned char *csrc;
|
||||
unsigned char *cdst;
|
||||
|
||||
int reverse = (unsigned int) src < (unsigned int) dst;
|
||||
|
||||
if (!reverse) {
|
||||
for (csrc = (const char *) src, cdst = (char *) dst, len++; --len;) {
|
||||
*cdst++ = *csrc++;
|
||||
}
|
||||
} else {
|
||||
for (csrc = (const char *) src + len, cdst = (char *) dst + len, len++; --len;) {
|
||||
*--cdst = *--csrc;
|
||||
}
|
||||
}
|
||||
|
||||
return dst;
|
||||
}
|
||||
|
||||
void *memset(void *dest, int val, int n) {
|
||||
__fill_mem(dest, val, n);
|
||||
return dest;
|
||||
}
|
||||
|
||||
void *memchr(const void *src, int val, int n) {
|
||||
const unsigned char *p;
|
||||
|
||||
unsigned int v = (val & 0xff);
|
||||
|
||||
for (p = (unsigned char *) src, n++; --n;) {
|
||||
if (*p++ == v) {
|
||||
return ((void *) (p - 1));
|
||||
}
|
||||
}
|
||||
|
||||
return NULL;
|
||||
}
|
||||
|
||||
int memcmp(const void *src1, const void *src2, int n) {
|
||||
const unsigned char *p1;
|
||||
const unsigned char *p2;
|
||||
|
||||
for (p1 = (const unsigned char *) src1, p2 = (const unsigned char *) src2, n++; --n;) {
|
||||
if (*p1++ != *p2++) {
|
||||
return ((*--p1 < *--p2) ? -1 : +1);
|
||||
}
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
@@ -0,0 +1,59 @@
|
||||
#include <mem_funcs.h>
|
||||
|
||||
#define cps ((unsigned char *) src)
|
||||
#define cpd ((unsigned char *) dst)
|
||||
#define lps ((unsigned int *) src)
|
||||
#define lpd ((unsigned int *) dst)
|
||||
|
||||
#define deref_auto_inc(p) *(p)++
|
||||
|
||||
void __fill_mem(void *dst, int val, unsigned int n) {
|
||||
unsigned int v = (unsigned char) val;
|
||||
unsigned int i;
|
||||
|
||||
if (n >= 32) {
|
||||
i = (-(unsigned int) dst) & 3;
|
||||
|
||||
if (i) {
|
||||
n -= i;
|
||||
do {
|
||||
deref_auto_inc(cpd) = v;
|
||||
} while (--i);
|
||||
}
|
||||
|
||||
if (v) {
|
||||
v |= v << 24 | v << 16 | v << 8;
|
||||
}
|
||||
|
||||
i = n >> 5;
|
||||
|
||||
if (i) {
|
||||
do {
|
||||
deref_auto_inc(lpd) = v;
|
||||
deref_auto_inc(lpd) = v;
|
||||
deref_auto_inc(lpd) = v;
|
||||
deref_auto_inc(lpd) = v;
|
||||
deref_auto_inc(lpd) = v;
|
||||
deref_auto_inc(lpd) = v;
|
||||
deref_auto_inc(lpd) = v;
|
||||
deref_auto_inc(lpd) = v;
|
||||
} while (--i);
|
||||
}
|
||||
|
||||
i = (n & 31) >> 2;
|
||||
|
||||
if (i) {
|
||||
do {
|
||||
deref_auto_inc(lpd) = v;
|
||||
} while (--i);
|
||||
}
|
||||
|
||||
n &= 3;
|
||||
}
|
||||
|
||||
if (n) {
|
||||
do {
|
||||
deref_auto_inc(cpd) = v;
|
||||
} while (--n);
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,18 @@
|
||||
#include <secure_error.h>
|
||||
#include <stddef.h>
|
||||
|
||||
msl_constraint_handler __msl_constraint_handler;
|
||||
|
||||
void secure_error_func_02033e50();
|
||||
|
||||
void __msl_runtime_constraint_violation_s(int param1, int param2, int param3) {
|
||||
if (__msl_constraint_handler != NULL) {
|
||||
__msl_constraint_handler(param1, param2, param3);
|
||||
return;
|
||||
}
|
||||
|
||||
secure_error_func_02033e50();
|
||||
}
|
||||
|
||||
//! TODO: figure out the real name
|
||||
void secure_error_func_02033e50() {}
|
||||
@@ -0,0 +1,33 @@
|
||||
#include <critical_regions.h>
|
||||
|
||||
typedef void (*sig_func)(int sig);
|
||||
sig_func signal_funcs[7];
|
||||
|
||||
int raise(int sig) {
|
||||
sig_func temp_r31;
|
||||
|
||||
if (sig < 1 || sig > 7) {
|
||||
return -1;
|
||||
}
|
||||
|
||||
__begin_critical_region(signal_funcs_access);
|
||||
|
||||
temp_r31 = signal_funcs[sig - 1];
|
||||
|
||||
if ((unsigned int) temp_r31 != 1) {
|
||||
signal_funcs[sig - 1] = 0;
|
||||
}
|
||||
|
||||
__end_critical_region(signal_funcs_access);
|
||||
|
||||
if ((unsigned int) temp_r31 == 1 || ((int) temp_r31 == 0 && sig == 1)) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
if ((unsigned int) temp_r31 == 0) {
|
||||
exit(0);
|
||||
}
|
||||
|
||||
temp_r31(sig);
|
||||
return 0;
|
||||
}
|
||||
@@ -0,0 +1,197 @@
|
||||
#include <stddef.h>
|
||||
#include <string.h>
|
||||
|
||||
#define K1 0x80808080
|
||||
#define K2 0xFEFEFEFF
|
||||
|
||||
size_t strlen(const char *str) {
|
||||
int length = -1;
|
||||
unsigned char *p = (unsigned char *) str;
|
||||
|
||||
do {
|
||||
length++;
|
||||
} while (*p++);
|
||||
|
||||
return length;
|
||||
}
|
||||
|
||||
char *strcpy(char *dest, const char *src) {
|
||||
register unsigned char *destb, *fromb;
|
||||
register unsigned int w, t, align;
|
||||
register unsigned int k1, k2;
|
||||
|
||||
fromb = (unsigned char *) src;
|
||||
destb = (unsigned char *) dest;
|
||||
|
||||
if ((align = ((unsigned int) fromb & 3)) != ((unsigned int) destb & 3)) {
|
||||
goto bytecopy;
|
||||
}
|
||||
|
||||
if (align != 0) {
|
||||
if ((*destb = *fromb) == 0) {
|
||||
return dest;
|
||||
}
|
||||
|
||||
for (align = 3 - align; align != 0; align--) {
|
||||
if ((*++destb = *++fromb) == 0) {
|
||||
return dest;
|
||||
}
|
||||
}
|
||||
++destb;
|
||||
++fromb;
|
||||
}
|
||||
|
||||
k1 = K1;
|
||||
k2 = K2;
|
||||
|
||||
w = *((int *) fromb);
|
||||
t = w + k2;
|
||||
t &= ~w;
|
||||
t &= k1;
|
||||
|
||||
if (t != 0) {
|
||||
goto bytecopy;
|
||||
}
|
||||
|
||||
--((int *) (destb));
|
||||
|
||||
do {
|
||||
*(++((int *) destb)) = w;
|
||||
w = *(++((int *) fromb));
|
||||
t = w + k2;
|
||||
t &= ~w;
|
||||
t &= k1;
|
||||
if (t != 0) {
|
||||
goto adjust;
|
||||
}
|
||||
} while (true);
|
||||
|
||||
adjust:
|
||||
++((int *) destb);
|
||||
bytecopy:
|
||||
if ((*destb = *fromb) == 0) {
|
||||
return dest;
|
||||
}
|
||||
|
||||
do {
|
||||
if ((*++destb = *++fromb) == 0) {
|
||||
return dest;
|
||||
}
|
||||
} while (true);
|
||||
|
||||
return dest;
|
||||
}
|
||||
|
||||
char *strncpy(char *dest, const char *src, size_t n) {
|
||||
const unsigned char *p = (const unsigned char *) src;
|
||||
unsigned char *q = (unsigned char *) dest;
|
||||
|
||||
n++;
|
||||
|
||||
while (--n != 0) {
|
||||
if ((*q++ = *p++) == 0) {
|
||||
while (--n != 0) {
|
||||
*q++ = 0;
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
return dest;
|
||||
}
|
||||
|
||||
int strcmp(char *str1, char *str2) {
|
||||
register unsigned char *left = (unsigned char *) str1;
|
||||
register unsigned char *right = (unsigned char *) str2;
|
||||
unsigned int k1, k2, align, l1, r1, x;
|
||||
|
||||
l1 = *left;
|
||||
r1 = *right;
|
||||
if (l1 - r1) {
|
||||
return (l1 - r1);
|
||||
}
|
||||
|
||||
if ((align = ((unsigned int) left & 3)) != ((unsigned int) right & 3)) {
|
||||
goto bytecopy;
|
||||
}
|
||||
if (align) {
|
||||
if (l1 == 0) {
|
||||
return (0);
|
||||
}
|
||||
for (align = 3 - align; align; align--) {
|
||||
l1 = *(++left);
|
||||
r1 = *(++right);
|
||||
if (l1 - r1) {
|
||||
return (l1 - r1);
|
||||
}
|
||||
if (l1 == 0) {
|
||||
return (0);
|
||||
}
|
||||
}
|
||||
left++;
|
||||
right++;
|
||||
}
|
||||
|
||||
k1 = K1;
|
||||
k2 = K2;
|
||||
|
||||
l1 = *(unsigned int *) left;
|
||||
r1 = *(unsigned int *) right;
|
||||
x = l1 + k2;
|
||||
x &= ~l1;
|
||||
if (x & k1) {
|
||||
goto adjust;
|
||||
}
|
||||
while (l1 == r1) {
|
||||
l1 = *(++((unsigned int *) (left)));
|
||||
r1 = *(++((unsigned int *) (right)));
|
||||
x = l1 + k2;
|
||||
if (x & k1) {
|
||||
goto adjust;
|
||||
}
|
||||
}
|
||||
|
||||
--left;
|
||||
--right;
|
||||
goto bytecopy;
|
||||
|
||||
adjust:
|
||||
l1 = *left;
|
||||
r1 = *right;
|
||||
if (l1 - r1) {
|
||||
return (l1 - r1);
|
||||
}
|
||||
bytecopy:
|
||||
if (l1 == 0) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
do {
|
||||
l1 = *(++left);
|
||||
r1 = *(++right);
|
||||
if (l1 - r1) {
|
||||
return (l1 - r1);
|
||||
}
|
||||
if (l1 == 0) {
|
||||
return 0;
|
||||
}
|
||||
} while (true);
|
||||
}
|
||||
|
||||
int strncmp(char *str1, char *str2, size_t n) {
|
||||
const unsigned char *p1 = (unsigned char *) str1;
|
||||
const unsigned char *p2 = (unsigned char *) str2;
|
||||
unsigned int c1, c2;
|
||||
|
||||
n++;
|
||||
|
||||
while (--n) {
|
||||
if ((c1 = *p1++) != (c2 = *p2++)) {
|
||||
return (c1 - c2);
|
||||
} else if (!c1) {
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
@@ -0,0 +1,18 @@
|
||||
#include <mem.h>
|
||||
|
||||
wchar_t *wmemcpy(wchar_t *pDest, const wchar_t *pSrc, size_t num) {
|
||||
return (wchar_t *) memcpy(pDest, pSrc, num * sizeof(wchar_t));
|
||||
}
|
||||
|
||||
wchar_t *wmemchr(const wchar_t *pSrc, wchar_t val, size_t num) {
|
||||
while (num != 0) {
|
||||
if (*pSrc == val) {
|
||||
return (wchar_t *) pSrc;
|
||||
}
|
||||
|
||||
pSrc++;
|
||||
num--;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
File diff suppressed because it is too large
Load Diff
@@ -0,0 +1,53 @@
|
||||
#include <wstring.h>
|
||||
|
||||
size_t wcslen(const wchar_t *str) {
|
||||
size_t len = -1;
|
||||
|
||||
do {
|
||||
len++;
|
||||
} while (*str++ != 0);
|
||||
|
||||
return len;
|
||||
}
|
||||
|
||||
wchar_t *wcscpy(wchar_t *dest, const wchar_t *src) {
|
||||
const wchar_t *p = src;
|
||||
wchar_t *q = dest;
|
||||
|
||||
while ((*q++ = *p++) != L'\0')
|
||||
;
|
||||
|
||||
return dest;
|
||||
}
|
||||
|
||||
wchar_t *wcsncpy(wchar_t *dest, const wchar_t *src, size_t n) {
|
||||
const wchar_t *p = src;
|
||||
wchar_t *q = dest;
|
||||
|
||||
n++;
|
||||
|
||||
while (--n != 0) {
|
||||
if ((*q++ = *p++) == 0) {
|
||||
while (--n != 0) {
|
||||
*q++ = 0;
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
return dest;
|
||||
}
|
||||
|
||||
const wchar_t *wcschr(const wchar_t *str, wchar_t chr) {
|
||||
const wchar_t *p = str;
|
||||
wchar_t c = chr;
|
||||
wchar_t ch;
|
||||
|
||||
while (ch = *p++) {
|
||||
if (ch == c) {
|
||||
return ((char *) (p - 1));
|
||||
}
|
||||
}
|
||||
|
||||
return (c ? 0 : (char *) (p - 1));
|
||||
}
|
||||
@@ -0,0 +1,53 @@
|
||||
#ifndef _RUNTIME_MWEXCEPTION_H
|
||||
#define _RUNTIME_MWEXCEPTION_H
|
||||
|
||||
#include <types.h>
|
||||
|
||||
typedef void (*DestructorFunc)(void *);
|
||||
|
||||
typedef short vbase_ctor_arg_type;
|
||||
typedef u8 local_cond_type;
|
||||
|
||||
typedef struct CatchInfo {
|
||||
void *location;
|
||||
void *typeinfo;
|
||||
void *dtor;
|
||||
void *sublocation;
|
||||
long pointercopy;
|
||||
void *stacktop;
|
||||
} CatchInfo;
|
||||
|
||||
typedef struct DestructorChain {
|
||||
/* 0x00 */ struct DestructorChain *next;
|
||||
/* 0x04 */ DestructorFunc dtor;
|
||||
/* 0x08 */ void *object;
|
||||
} DestructorChain;
|
||||
|
||||
void __end_catch(CatchInfo *catchinfo);
|
||||
|
||||
extern DestructorChain *__global_destructor_chain;
|
||||
|
||||
/**
|
||||
* @brief Call all static initializers
|
||||
*/
|
||||
extern void __call_static_initializers(void);
|
||||
|
||||
/**
|
||||
* @brief Destroy all constructed global objects
|
||||
*/
|
||||
extern void __destroy_global_chain(void);
|
||||
|
||||
extern void __throw(char *throwtype, void *location, void *dtor);
|
||||
extern void __rethrow(void);
|
||||
extern char __throw_catch_compare(const u8 *throwtype, const u8 *catchtype, s32 *offset_result);
|
||||
|
||||
#define DTORARG_TYPE short
|
||||
#define DTORARG_PARTIAL (0) // destroy non-virtual bases
|
||||
#define DTORARG_COMPLETE (-1) // destroy all bases
|
||||
#define DTORARG_DELETE (1) // destroy all bases and delete object
|
||||
|
||||
#define DTORCALL_COMPLETE(dtor, objptr) (((void (*)(void *, DTORARG_TYPE)) dtor)(objptr, DTORARG_COMPLETE))
|
||||
#define DTORCALL_PARTIAL(dtor, objptr) (((void (*)(void *, DTORARG_TYPE)) dtor)(objptr, DTORARG_PARTIAL))
|
||||
#define DTORCALL_VTTOBJECT(dtor, objptr, vttptr) (((void (*)(void *, void *)) dtor)(objptr, vttptr))
|
||||
|
||||
#endif
|
||||
@@ -49,6 +49,7 @@ CC_FLAGS = " ".join([
|
||||
"-gccinc", # Interpret #include "..." and #include <...> equally
|
||||
"-nolink", # Do not link
|
||||
"-msgstyle gcc", # Use GCC-like messages (some IDEs will make file names clickable)
|
||||
"-ipa file", # InterProcedural Analysis
|
||||
])
|
||||
# Passed to all modules and final arm9.o link
|
||||
LD_FLAGS = " ".join([
|
||||
|
||||
+2
-1
@@ -21,7 +21,8 @@ CXX_FLAGS = [
|
||||
'-nostdinc',
|
||||
'-Iinclude',
|
||||
'-Ilibs/c/include',
|
||||
'-Ilibs/cpp/include'
|
||||
'-Ilibs/cpp/include',
|
||||
'-Ilibs/runtime/include',
|
||||
]
|
||||
|
||||
script_dir = Path(os.path.dirname(os.path.realpath(__file__)))
|
||||
|
||||
Reference in New Issue
Block a user