mirror of
https://github.com/frida/tinycc
synced 2025-01-21 18:52:02 +03:00
Attention: never use hard tabs other than 8 (eight) wide
The attached fix (libcrt.c) is just one example. There seem
many more such introduced from latest commits that look badly
formatted in anyone else's editors and should be fixed.
General recommended policy:
- if possible, do not add new hard tabs ('\t') at all.
Use spaces (soft tabs) instead
- in any case, configure your editor to read/write hard tabs
with width of 8 (eight)
Also:
- Avoid merge commits (unless for very good reason). Instead
use "git cherry-pick" or "git rebase" to put your commits on
top of the public branch. ref: 2a8905c93b
Also:
- jiang: please explain what you are doing, in the commit message
and on the list. Subscribe to the mailing list to receive feedback
from people for your work.
For example, what was wrong with 'parse_number'? Show a test
case and how your version fixes it (it is slower btw).
This commit is contained in:
parent
59a22d59a2
commit
504d40a328
112
lib/libcrt.c
112
lib/libcrt.c
@ -530,77 +530,77 @@ long double __floatundixf(unsigned long long a)
|
|||||||
|
|
||||||
unsigned long long __fixunssfdi (float a1)
|
unsigned long long __fixunssfdi (float a1)
|
||||||
{
|
{
|
||||||
register union float_long fl1;
|
register union float_long fl1;
|
||||||
register int exp;
|
register int exp;
|
||||||
register unsigned long l;
|
register unsigned long l;
|
||||||
int s;
|
int s;
|
||||||
fl1.f = a1;
|
fl1.f = a1;
|
||||||
|
|
||||||
if (fl1.l == 0)
|
if (fl1.l == 0)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
exp = EXP (fl1.l) - EXCESS - 24;
|
exp = EXP (fl1.l) - EXCESS - 24;
|
||||||
|
|
||||||
l = MANT(fl1.l);
|
l = MANT(fl1.l);
|
||||||
s = SIGN(fl1.l)? -1: 1;
|
s = SIGN(fl1.l)? -1: 1;
|
||||||
if (exp >= 64)
|
if (exp >= 64)
|
||||||
return (unsigned long long)-1;
|
return (unsigned long long)-1;
|
||||||
else if (exp >= 0)
|
else if (exp >= 0)
|
||||||
return ((unsigned long long)l << exp)*s;
|
return ((unsigned long long)l << exp)*s;
|
||||||
else if (exp >= -23)
|
else if (exp >= -23)
|
||||||
return (l >> -exp)*s;
|
return (l >> -exp)*s;
|
||||||
else
|
else
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
unsigned long long __fixunsdfdi (double a1)
|
unsigned long long __fixunsdfdi (double a1)
|
||||||
{
|
{
|
||||||
register union double_long dl1;
|
register union double_long dl1;
|
||||||
register int exp;
|
register int exp;
|
||||||
register unsigned long long l;
|
register unsigned long long l;
|
||||||
int s;
|
int s;
|
||||||
dl1.d = a1;
|
dl1.d = a1;
|
||||||
|
|
||||||
if (dl1.ll == 0)
|
if (dl1.ll == 0)
|
||||||
return (0);
|
return (0);
|
||||||
|
|
||||||
exp = EXPD (dl1) - EXCESSD - 53;
|
exp = EXPD (dl1) - EXCESSD - 53;
|
||||||
|
|
||||||
l = MANTD_LL(dl1);
|
l = MANTD_LL(dl1);
|
||||||
s = SIGND(dl1)? -1: 1;
|
s = SIGND(dl1)? -1: 1;
|
||||||
if (exp >= 64)
|
if (exp >= 64)
|
||||||
return (unsigned long long)-1;
|
return (unsigned long long)-1;
|
||||||
else if (exp >= 0)
|
else if (exp >= 0)
|
||||||
return (l << exp)*s;
|
return (l << exp)*s;
|
||||||
else if (exp >= -52)
|
else if (exp >= -52)
|
||||||
return (l >> -exp)*s;
|
return (l >> -exp)*s;
|
||||||
else
|
else
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
unsigned long long __fixunsxfdi (long double a1)
|
unsigned long long __fixunsxfdi (long double a1)
|
||||||
{
|
{
|
||||||
register union ldouble_long dl1;
|
register union ldouble_long dl1;
|
||||||
register int exp;
|
register int exp;
|
||||||
register unsigned long long l;
|
register unsigned long long l;
|
||||||
int s;
|
int s;
|
||||||
dl1.ld = a1;
|
dl1.ld = a1;
|
||||||
|
|
||||||
if (dl1.l.lower == 0 && dl1.l.upper == 0)
|
if (dl1.l.lower == 0 && dl1.l.upper == 0)
|
||||||
return (0);
|
return (0);
|
||||||
|
|
||||||
exp = EXPLD (dl1) - EXCESSLD - 64;
|
exp = EXPLD (dl1) - EXCESSLD - 64;
|
||||||
s = SIGNLD(dl1)? -1: 1;
|
s = SIGNLD(dl1)? -1: 1;
|
||||||
l = dl1.l.lower;
|
l = dl1.l.lower;
|
||||||
|
|
||||||
if (exp >= 64)
|
if (exp >= 64)
|
||||||
return (unsigned long long)-1;
|
return (unsigned long long)-1;
|
||||||
else if (exp >= 0)
|
else if (exp >= 0)
|
||||||
return ((unsigned long long)l << exp)*s;
|
return ((unsigned long long)l << exp)*s;
|
||||||
else if (exp >= -64)
|
else if (exp >= -64)
|
||||||
return (l >> -exp)*s;
|
return (l >> -exp)*s;
|
||||||
else
|
else
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
long long __fixsfdi (float a1)
|
long long __fixsfdi (float a1)
|
||||||
@ -640,7 +640,7 @@ extern void abort(void);
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
enum __va_arg_type {
|
enum __va_arg_type {
|
||||||
__va_gen_reg, __va_float_reg, __va_ld_reg, __va_stack
|
__va_gen_reg, __va_float_reg, __va_ld_reg, __va_stack
|
||||||
};
|
};
|
||||||
|
|
||||||
//This should be in sync with the declaration on our include/stdarg.h
|
//This should be in sync with the declaration on our include/stdarg.h
|
||||||
@ -691,7 +691,7 @@ void *__va_arg(__va_list_struct *ap,
|
|||||||
size = 8;
|
size = 8;
|
||||||
goto use_overflow_area;
|
goto use_overflow_area;
|
||||||
|
|
||||||
case __va_ld_reg:
|
case __va_ld_reg:
|
||||||
ap->overflow_arg_area = (char*)((intptr_t)(ap->overflow_arg_area + align - 1) & -(intptr_t)align);
|
ap->overflow_arg_area = (char*)((intptr_t)(ap->overflow_arg_area + align - 1) & -(intptr_t)align);
|
||||||
case __va_stack:
|
case __va_stack:
|
||||||
use_overflow_area:
|
use_overflow_area:
|
||||||
|
Loading…
Reference in New Issue
Block a user