mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2024-12-27 04:52:05 +08:00
c8693053f8
GDB currently doesn't build on 32-bit Solaris: * On Solaris 11.4/x86: In file included from /usr/include/sys/procfs.h:26, from /vol/src/gnu/gdb/hg/master/dist/gdb/i386-sol2-nat.c:24: /usr/include/sys/old_procfs.h:31:2: error: #error "Cannot use procfs in the large file compilation environment" #error "Cannot use procfs in the large file compilation environment" ^~~~~ * On Solaris 11.3/x86 there are several more instances of this. The interaction between procfs and large-file support historically has been a royal mess on Solaris: * There are two versions of the procfs interface: ** The old ioctl-based /proc, deprecated and not used any longer in either gdb or binutils. ** The `new' (introduced in Solaris 2.6, 1997) structured /proc. * There are two headers one can possibly include: ** <procfs.h> which only provides the structured /proc, definining _STRUCTURED_PROC=1 and then including ... ** <sys/procfs.h> which defaults to _STRUCTURED_PROC=0, the ioctl-based /proc, but provides structured /proc if _STRUCTURED_PROC == 1. * procfs and the large-file environment didn't go well together: ** Until Solaris 11.3, <sys/procfs.h> would always #error in 32-bit compilations when the large-file environment was active (_FILE_OFFSET_BITS == 64). ** In both Solaris 11.4 and Illumos, this restriction was lifted for structured /proc. So one has to be careful always to define _STRUCTURED_PROC=1 when testing for or using <sys/procfs.h> on Solaris. As the errors above show, this isn't always the case in binutils-gdb right now. Also one may need to disable large-file support for 32-bit compilations on Solaris. config/largefile.m4 meant to do this by wrapping the AC_SYS_LARGEFILE autoconf macro with appropriate checks, yielding ACX_LARGEFILE. Unfortunately the macro doesn't always succeed because it neglects the _STRUCTURED_PROC part. To make things even worse, since GCC 9 g++ predefines _FILE_OFFSET_BITS=64 on Solaris. So even if largefile.m4 deciced not to enable large-file support, this has no effect, breaking the gdb build. This patch addresses all this as follows: * All tests for the <sys/procfs.h> header are made with _STRUCTURED_PROC=1, the definition going into the various config.h files instead of having to make them (and sometimes failing) in the affected sources. * To cope with the g++ predefine of _FILE_OFFSET_BITS=64, -U_FILE_OFFSET_BITS is added to various *_CPPFLAGS variables. It had been far easier to have just #undef _FILE_OFFSET_BITS in config.h, but unfortunately such a construct in config.in is commented by config.status irrespective of indentation and whitespace if large-file support is disabled. I found no way around this and putting the #undef in several global headers for bfd, binutils, ld, and gdb seemed way more invasive. * Last, the applicability check in largefile.m4 was modified only to disable largefile support if really needed. To do so, it checks if <sys/procfs.h> compiles with _FILE_OFFSET_BITS=64 defined. If it doesn't, the disabling only happens if gdb exists in-tree and isn't disabled, otherwise (building binutils from a tarball), there's no conflict. What initially confused me was the check for $plugins here, which originally caused the disabling not to take place. Since AC_PLUGINGS does enable plugin support if <dlfcn.h> exists (which it does on Solaris), the disabling never happened. I could find no explanation why the linker plugin needs large-file support but thought it would be enough if gld and GCC's lto-plugin agreed on the _FILE_OFFSET_BITS value. Unfortunately, that's not enough: lto-plugin uses the simple-object interface from libiberty, which includes off_t arguments. So to fully disable large-file support would mean also disabling it in libiberty and its users: gcc and libstdc++-v3. This seems highly undesirable, so I decided to disable the linker plugin instead if large-file support won't work. The patch allows binutils+gdb to build on i386-pc-solaris2.11 (both Solaris 11.3 and 11.4, using GCC 9.3.0 which is the worst case due to predefined _FILE_OFFSET_BITS=64). Also regtested on amd64-pc-solaris2.11 (again on Solaris 11.3 and 11.4), x86_64-pc-linux-gnu and i686-pc-linux-gnu. config: * largefile.m4 (ACX_LARGEFILE) <sparc-*-solaris*|i?86-*-solaris*>: Check for <sys/procfs.h> incompatilibity with large-file support on Solaris. Only disable large-file support and perhaps plugins if needed. Set, substitute LARGEFILE_CPPFLAGS if so. bfd: * bfd.m4 (BFD_SYS_PROCFS_H): New macro. (BFD_HAVE_SYS_PROCFS_TYPE): Require BFD_SYS_PROCFS_H. Don't define _STRUCTURED_PROC. (BFD_HAVE_SYS_PROCFS_TYPE_MEMBER): Likewise. * elf.c [HAVE_SYS_PROCFS_H] (_STRUCTURED_PROC): Don't define. * configure.ac: Use BFD_SYS_PROCFS_H to check for <sys/procfs.h>. * configure, config.in: Regenerate. * Makefile.am (AM_CPPFLAGS): Add LARGEFILE_CPPFLAGS. * Makefile.in, doc/Makefile.in: Regenerate. binutils: * Makefile.am (AM_CPPFLAGS): Add LARGEFILE_CPPFLAGS. * Makefile.in, doc/Makefile.in: Regenerate. * configure: Regenerate. gas: * Makefile.am (AM_CPPFLAGS): Add LARGEFILE_CPPFLAGS. * Makefile.in, doc/Makefile.in: Regenerate. * configure: Regenerate. gdb: * proc-api.c (_STRUCTURED_PROC): Don't define. * proc-events.c: Likewise. * proc-flags.c: Likewise. * proc-why.c: Likewise. * procfs.c: Likewise. * Makefile.in (INTERNAL_CPPFLAGS): Add LARGEFILE_CPPFLAGS. * configure, config.in: Regenerate. gdbserver: * configure, config.in: Regenerate. gdbsupport: * Makefile.am (AM_CPPFLAGS): Add LARGEFILE_CPPFLAGS. * common.m4 (GDB_AC_COMMON): Use BFD_SYS_PROCFS_H to check for <sys/procfs.h>. * Makefile.in: Regenerate. * configure, config.in: Regenerate. gnulib: * configure.ac: Run ACX_LARGEFILE before gl_EARLY. * configure: Regenerate. gprof: * Makefile.am (AM_CPPFLAGS): Add LARGEFILE_CPPFLAGS. * Makefile.in: Regenerate. * configure: Regenerate. ld: * Makefile.am (AM_CPPFLAGS): Add LARGEFILE_CPPFLAGS. * Makefile.in: Regenerate. * configure: Regenerate. |
||
---|---|---|
.. | ||
extra | ||
glthread | ||
m4 | ||
malloc | ||
_Noreturn.h | ||
alloca.c | ||
alloca.in.h | ||
arg-nonnull.h | ||
arpa_inet.in.h | ||
assure.h | ||
at-func.c | ||
basename-lgpl.c | ||
c++defs.h | ||
canonicalize-lgpl.c | ||
cdefs.h | ||
chdir-long.c | ||
chdir-long.h | ||
cloexec.c | ||
cloexec.h | ||
close.c | ||
closedir.c | ||
count-one-bits.c | ||
count-one-bits.h | ||
dirent-private.h | ||
dirent.in.h | ||
dirfd.c | ||
dirname-lgpl.c | ||
dirname.h | ||
dosname.h | ||
dup2.c | ||
dup-safer-flag.c | ||
dup-safer.c | ||
dup.c | ||
errno.in.h | ||
error.c | ||
error.h | ||
exitfail.c | ||
exitfail.h | ||
fchdir.c | ||
fcntl.c | ||
fcntl.in.h | ||
fd-hook.c | ||
fd-hook.h | ||
fd-safer-flag.c | ||
fd-safer.c | ||
fdopendir.c | ||
filename.h | ||
filenamecat-lgpl.c | ||
filenamecat.h | ||
flexmember.h | ||
float.c | ||
float.in.h | ||
float+.h | ||
fnmatch_loop.c | ||
fnmatch.c | ||
fnmatch.in.h | ||
fpucw.h | ||
frexp.c | ||
frexpl.c | ||
fstat.c | ||
fstatat.c | ||
getcwd-lgpl.c | ||
getcwd.c | ||
getdtablesize.c | ||
getlogin_r.c | ||
getprogname.c | ||
getprogname.h | ||
gettext.h | ||
gettimeofday.c | ||
glob_internal.h | ||
glob_pattern_p.c | ||
glob-libc.h | ||
glob.c | ||
glob.in.h | ||
globfree.c | ||
hard-locale.c | ||
hard-locale.h | ||
inet_ntop.c | ||
intprops.h | ||
inttypes.in.h | ||
isnan.c | ||
isnand-nolibm.h | ||
isnand.c | ||
isnanl-nolibm.h | ||
isnanl.c | ||
itold.c | ||
lc-charset-dispatch.c | ||
lc-charset-dispatch.h | ||
libc-config.h | ||
limits.in.h | ||
localcharset.c | ||
localcharset.h | ||
locale.in.h | ||
localtime-buffer.c | ||
localtime-buffer.h | ||
lstat.c | ||
Makefile.am | ||
Makefile.in | ||
malloc.c | ||
malloca.c | ||
malloca.h | ||
math.c | ||
math.in.h | ||
mbrtowc-impl-utf8.h | ||
mbrtowc-impl.h | ||
mbrtowc.c | ||
mbsinit.c | ||
mbsrtowcs-impl.h | ||
mbsrtowcs-state.c | ||
mbsrtowcs.c | ||
mbtowc-lock.c | ||
mbtowc-lock.h | ||
memchr.c | ||
memchr.valgrind | ||
memmem.c | ||
mempcpy.c | ||
memrchr.c | ||
mkdir.c | ||
mkdtemp.c | ||
mkostemp.c | ||
msvc-inval.c | ||
msvc-inval.h | ||
msvc-nothrow.c | ||
msvc-nothrow.h | ||
netinet_in.in.h | ||
open.c | ||
openat-die.c | ||
openat-priv.h | ||
openat-proc.c | ||
openat.c | ||
openat.h | ||
opendir.c | ||
pathmax.h | ||
pipe-safer.c | ||
rawmemchr.c | ||
rawmemchr.valgrind | ||
readdir.c | ||
readlink.c | ||
realloc.c | ||
rename.c | ||
rewinddir.c | ||
rmdir.c | ||
same-inode.h | ||
save-cwd.c | ||
save-cwd.h | ||
scratch_buffer.h | ||
setenv.c | ||
setlocale_null.c | ||
setlocale_null.h | ||
setlocale-lock.c | ||
signal.in.h | ||
stat-time.c | ||
stat-time.h | ||
stat-w32.c | ||
stat-w32.h | ||
stat.c | ||
stdalign.in.h | ||
stdbool.in.h | ||
stddef.in.h | ||
stdint.in.h | ||
stdio.in.h | ||
stdlib.in.h | ||
str-two-way.h | ||
strchrnul.c | ||
strchrnul.valgrind | ||
strdup.c | ||
streq.h | ||
strerror_r.c | ||
strerror-override.c | ||
strerror-override.h | ||
strerror.c | ||
string.in.h | ||
stripslash.c | ||
strnlen1.c | ||
strnlen1.h | ||
strstr.c | ||
strtok_r.c | ||
sys_socket.c | ||
sys_socket.in.h | ||
sys_stat.in.h | ||
sys_time.in.h | ||
sys_types.in.h | ||
sys_uio.in.h | ||
tempname.c | ||
tempname.h | ||
time_r.c | ||
time.in.h | ||
unistd--.h | ||
unistd-safer.h | ||
unistd.c | ||
unistd.in.h | ||
unsetenv.c | ||
verify.h | ||
warn-on-use.h | ||
wchar.in.h | ||
wctype-h.c | ||
wctype.in.h | ||
windows-initguard.h | ||
windows-mutex.c | ||
windows-mutex.h | ||
windows-once.c | ||
windows-once.h | ||
windows-recmutex.c | ||
windows-recmutex.h | ||
windows-rwlock.c | ||
windows-rwlock.h | ||
xalloc-oversized.h |