| Commit message (Collapse) | Author | Age | Files | Lines |
... | |
|
|
|
|
|
|
| |
wrapping them with an implicit extern "C" since that breaks the webkit port.
Help from matthew@ and landry@.
ok landry@
|
|
|
|
|
| |
fixup_match_2() on landisk building mysql; gcc PR #28467
help and prodding jsg@, ok kettenis@
|
|
|
|
|
|
| |
we're default PIE.
allows Theo to build PIE-by-default sparc; ok kettenis@
|
|
|
|
|
|
|
|
|
| |
to emit -fstack-protector code that doesn't need GOT indirection for
accessing __guard.
Tested on amd64, i386, sparc64, hppa, loongson, and sgi (thanks lteo,
djm, sthen, todd, naddy, kettenis, phessler, jasper, and anyone else
that I'm missing who tested).
|
|
|
|
|
|
| |
powerpc now gets the right behaviour for -pthread as well.
ok pascal@, krw@, millert@
|
|
|
|
|
|
| |
Found out the hard way by deraadt@.
ok kettenis@
|
|
|
|
| |
(things link now).
|
|
|
|
|
|
|
|
|
|
| |
different approach than the one taken in kurt@'s original diff, but deemed
better after discussion and diff exchange with kettenis@ and matthew@.
Lots of feedback by kettenis@ and matthew@, prodding and encouragement by
deraadt@.
ok kettenis@ matthew@
|
|
|
|
|
|
|
| |
commit. It breaks make build on arm and generally causes more grief than the
the (small) benefit it is supposed to bring.
ok matthew@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| |
- Link libpthread.so with -znodlopen. Because libpthread overrides
the weak symbols in libc, we can't allow it to be dynamically
loaded or else libc's weak symbols might have already been
resolved by ld.so. (Also, major bump because this is technically
a backwards incompat change in behavior, although dlopen()ing
libpthread never really worked.)
- Link libc.so with -nodefaultlibs -lgcc. This ensures that libc
doesn't try to link against itself (which ld.so wouldn't like).
- Change GCC 4 to link shared objects with -lpthread and -lc as
appropriate, now that there's no issues with doing so. This means
that it's no longer necessary to patch software to use -pthread
instead of -lpthread. (Ports tree rejoice!)
Also, to preemptively answer this question: No, this does not
eliminate the need for LD_PRELOAD=libpthread.so. That's a separate
issue that won't be resolved until we eliminate libc's weak symbols.
Discussed extensively on email and icb over the past few months.
ok deraadt
|
|
|
|
|
|
|
|
| |
so override gcc's default of long/unsigned long on amd64 like we
do the other LP64 platforms. This lets format checking of %jd/%ju
work correctly there.
ok matthew@ millert@
|
|
|
|
|
|
|
|
|
|
|
|
|
| |
_POSIX_THREAD_PRIORITY_SCHEDULING. POSIX 2001 states that they can be
defined to -1 to indicate that the feature is not supported (which is
how we define them), so it's not okay to just check whether or not
they're defined.
Arguably, SUSv2 allows GCC's usage, but we don't special case these
feature flags for SUSv2, and these files need to be compilable in BSD
and POSIX compat modes anyway.
From Brad.
|
|
|
|
| |
(gcc3 may need the same patch, untested yet)
|
|
|
|
|
|
| |
posix_memalign().
ok matthew@ guenther@
|
|
|
|
| |
for ages by now.
|
| |
|
|
|
|
|
| |
unable to find a register to spill in class 'R0_REGS'
ICE when compiling PIC code. Similar to the MI targhooks.c change.
|
|
|
|
|
| |
with _REENTRANT. Also remove undef _POSIX_THREADS in phread.h.
From brad@comstyle.com. okay guenther@
|
|
|
|
|
|
| |
so we can use the existing sh libkern functions.
ok miod@
|
|
|
|
|
|
|
|
| |
totally fucked up, effectively leading to inverted behaviour of the -fident and
-fno-ident flags (while keeping the .ident string in by default). Revert it
back to normal and default to -fno-ident.
ok millert@
|
|
|
|
|
|
|
|
|
|
|
| |
a lifesaver for R4000 and R4400 operation; without these, every int->long
promotion occuring shortly after an integer multiplication (such as an array
element access when the array item size is not a power of two) loses horribly,
and panic^Whilarity ensues.
This mostly causes assembly insns to be shuffled, but almost no code size
growth and no noticeable performance hit on processors which do not need
these insn placement workarounds.
|
|
|
|
|
|
|
|
|
| |
Found by Brad.
Also, consider stpcpy an unsafe builtin and prevent it from being optimised
away.
ok miod@
|
|
|
|
|
|
|
|
|
|
| |
kprintf supports %z, doesn't support old ddb %n/%r%z anymore, and check of
%b arguments have to occur on the next argument, like, duh.
These changes will eventually allow for kernel to be compiled without
-Wno-format, but some more casts or type changes are necessary, first.
Discussed about six months ago at s2k11, time to put this in, so that I have no excuse not to work on the format fixes diffs.
|
| |
|
|
|
|
|
|
|
|
|
|
| |
C++98, so clang++ rightfully complains about it when in C++98 mode (the
default).
Found while investigating the other clang issue, with helpful input from
espie@.
ok jsg@
|
|
|
|
|
|
|
|
| |
without barfing about conflicting declarations.
Issue reported by Amit Kulkarni, investigated by matthew@ and kettenis@.
ok kettenis@
|
|
|
|
|
|
|
|
|
|
| |
and change ASM_OUTPUT_ALIGNED_COMMON to output an explicit .align directive,
as gas will not compute it from the size (despite what comments elsewhere in
gcc code say).
This effectively makes __attribute__ ((aligned (N))) constructs work as
intended for .bss objects.
ok kettenis@
|
|
|
|
| |
word boundaries, and enable the builtins.c `one-byte memcpy' workaround.
|
|
|
|
|
|
|
|
|
|
|
|
|
| |
size 1 (the size being known at compile-time) into an inline mempcpy()
expansion, which will in turn expand into a byte load and store operation.
This expansion loses precious address alignment information at some point
(because everybody knows that you can read a byte from any address, right?),
and this loses bigtime on strict alignment platforms which lack the ability
to accesse bytes directly, such as alpha (unless compiling with -mbwx and
runnning on a BWX-capable cpu).
An example of such call with size 1 is lib/libkvm/kvm.c line 780.
|
|
|
|
| |
From brad. ok kettenis espie
|
|
|
|
|
|
| |
(passes -export-dynamic to ld(1))
ok drahn@ miod@
|
|
|
|
| |
from brad; ok kettenis
|
| |
|
|
|
|
|
|
|
|
|
|
|
|
| |
jasper@.
This omits the sizeof(pointer) tracking which is very difficult to
implement for gcc4 due to internal changes.
Thanks to landry@ for running through a ports bulk build and both
landry@ and jasper@ for fixing a few issues.
ok deraadt millert jasper
|
|
|
|
| |
implemented in hardware anyway.
|
|
|
|
| |
ok deraadt@
|
| |
|
| |
|
|
|
|
|
|
|
|
| |
http://gcc.gnu.org/ml/gcc-patches/2008-06/msg01641.html
This fixes a stack protector code bug which only got triggered by some
particular function patterns, such as libc's __vfprintf.
ok drahn@
|
| |
|
|
|
|
|
|
|
| |
Default gcc on alpha to -mfp-rounding-mode=d, to make code which assumes
the rounding mode is always controlled by fpsetround() happy.
ok martynas@, miod@
|
|
|
|
| |
requested by and ok deraadt
|
|
|
|
| |
ok kettenis espie
|
| |
|
|
|
|
| |
on this in-tree not diffs floating around for > 1 year. ok miod@
|
|
|
|
|
| |
(Fix both ppc compilers in tree, was previously committed to wrong one).
OK deraadt@ discusssed with millert@ otto@ and kettenis@
|
|
|
|
|
|
| |
0" should output "+0", not "0".
Diff from upstream (which is still GPLv2+) via Brad.
|
|
|
|
|
|
|
|
| |
to get #pragma pack and #pragma push work in order to be compatible
with MS compilers because there is some code out there (e.g. chromium)
that uses these pragmas.
ok kettenis@
|
|
|
|
|
|
|
|
|
|
|
| |
does not throw warnings for stuff like
if ()
__throw_exception_again;
which does happen in its own fucking headers.
builds of qt3 should no longer warn...
okay millert@, no objection kettenis@
|
|
|
|
|
|
| |
<sys/types.h>.
ok miod@
|