1998-03-18 01:27:52 +08:00
|
|
|
@node Maintenance, Contributors, Installation, Top
|
1998-07-13 20:29:13 +08:00
|
|
|
@c %MENU% How to enhance and port the GNU C Library
|
1995-02-18 09:27:10 +08:00
|
|
|
@appendix Library Maintenance
|
|
|
|
|
|
|
|
@menu
|
|
|
|
* Source Layout:: How to add new functions or header files
|
|
|
|
to the GNU C library.
|
|
|
|
* Porting:: How to port the GNU C library to
|
|
|
|
a new machine or operating system.
|
1996-05-14 01:30:42 +08:00
|
|
|
@end menu
|
1995-02-18 09:27:10 +08:00
|
|
|
|
|
|
|
@node Source Layout
|
|
|
|
@appendixsec Adding New Functions
|
|
|
|
|
|
|
|
The process of building the library is driven by the makefiles, which
|
|
|
|
make heavy use of special features of GNU @code{make}. The makefiles
|
|
|
|
are very complex, and you probably don't want to try to understand them.
|
|
|
|
But what they do is fairly straightforward, and only requires that you
|
|
|
|
define a few variables in the right places.
|
|
|
|
|
|
|
|
The library sources are divided into subdirectories, grouped by topic.
|
1996-05-25 05:42:06 +08:00
|
|
|
|
1995-02-18 09:27:10 +08:00
|
|
|
The @file{string} subdirectory has all the string-manipulation
|
1996-05-25 05:42:06 +08:00
|
|
|
functions, @file{math} has all the mathematical functions, etc.
|
1995-02-18 09:27:10 +08:00
|
|
|
|
|
|
|
Each subdirectory contains a simple makefile, called @file{Makefile},
|
|
|
|
which defines a few @code{make} variables and then includes the global
|
|
|
|
makefile @file{Rules} with a line like:
|
|
|
|
|
|
|
|
@smallexample
|
|
|
|
include ../Rules
|
|
|
|
@end smallexample
|
|
|
|
|
|
|
|
@noindent
|
|
|
|
The basic variables that a subdirectory makefile defines are:
|
|
|
|
|
|
|
|
@table @code
|
|
|
|
@item subdir
|
|
|
|
The name of the subdirectory, for example @file{stdio}.
|
|
|
|
This variable @strong{must} be defined.
|
|
|
|
|
|
|
|
@item headers
|
|
|
|
The names of the header files in this section of the library,
|
|
|
|
such as @file{stdio.h}.
|
|
|
|
|
|
|
|
@item routines
|
|
|
|
@itemx aux
|
|
|
|
The names of the modules (source files) in this section of the library.
|
|
|
|
These should be simple names, such as @samp{strlen} (rather than
|
|
|
|
complete file names, such as @file{strlen.c}). Use @code{routines} for
|
|
|
|
modules that define functions in the library, and @code{aux} for
|
|
|
|
auxiliary modules containing things like data definitions. But the
|
|
|
|
values of @code{routines} and @code{aux} are just concatenated, so there
|
|
|
|
really is no practical difference.@refill
|
|
|
|
|
|
|
|
@item tests
|
|
|
|
The names of test programs for this section of the library. These
|
|
|
|
should be simple names, such as @samp{tester} (rather than complete file
|
|
|
|
names, such as @file{tester.c}). @w{@samp{make tests}} will build and
|
|
|
|
run all the test programs. If a test program needs input, put the test
|
|
|
|
data in a file called @file{@var{test-program}.input}; it will be given to
|
|
|
|
the test program on its standard input. If a test program wants to be
|
|
|
|
run with arguments, put the arguments (all on a single line) in a file
|
1996-05-25 05:42:06 +08:00
|
|
|
called @file{@var{test-program}.args}. Test programs should exit with
|
|
|
|
zero status when the test passes, and nonzero status when the test
|
|
|
|
indicates a bug in the library or error in building.
|
1995-02-18 09:27:10 +08:00
|
|
|
|
|
|
|
@item others
|
|
|
|
The names of ``other'' programs associated with this section of the
|
|
|
|
library. These are programs which are not tests per se, but are other
|
|
|
|
small programs included with the library. They are built by
|
|
|
|
@w{@samp{make others}}.@refill
|
|
|
|
|
|
|
|
@item install-lib
|
|
|
|
@itemx install-data
|
|
|
|
@itemx install
|
|
|
|
Files to be installed by @w{@samp{make install}}. Files listed in
|
|
|
|
@samp{install-lib} are installed in the directory specified by
|
|
|
|
@samp{libdir} in @file{configparms} or @file{Makeconfig}
|
|
|
|
(@pxref{Installation}). Files listed in @code{install-data} are
|
|
|
|
installed in the directory specified by @samp{datadir} in
|
|
|
|
@file{configparms} or @file{Makeconfig}. Files listed in @code{install}
|
|
|
|
are installed in the directory specified by @samp{bindir} in
|
|
|
|
@file{configparms} or @file{Makeconfig}.@refill
|
|
|
|
|
|
|
|
@item distribute
|
|
|
|
Other files from this subdirectory which should be put into a
|
|
|
|
distribution tar file. You need not list here the makefile itself or
|
|
|
|
the source and header files listed in the other standard variables.
|
|
|
|
Only define @code{distribute} if there are files used in an unusual way
|
|
|
|
that should go into the distribution.
|
|
|
|
|
|
|
|
@item generated
|
|
|
|
Files which are generated by @file{Makefile} in this subdirectory.
|
|
|
|
These files will be removed by @w{@samp{make clean}}, and they will
|
|
|
|
never go into a distribution.
|
|
|
|
|
|
|
|
@item extra-objs
|
|
|
|
Extra object files which are built by @file{Makefile} in this
|
|
|
|
subdirectory. This should be a list of file names like @file{foo.o};
|
|
|
|
the files will actually be found in whatever directory object files are
|
|
|
|
being built in. These files will be removed by @w{@samp{make clean}}.
|
|
|
|
This variable is used for secondary object files needed to build
|
|
|
|
@code{others} or @code{tests}.
|
|
|
|
@end table
|
|
|
|
|
|
|
|
@node Porting
|
|
|
|
@appendixsec Porting the GNU C Library
|
|
|
|
|
|
|
|
The GNU C library is written to be easily portable to a variety of
|
|
|
|
machines and operating systems. Machine- and operating system-dependent
|
|
|
|
functions are well separated to make it easy to add implementations for
|
|
|
|
new machines or operating systems. This section describes the layout of
|
|
|
|
the library source tree and explains the mechanisms used to select
|
|
|
|
machine-dependent code to use.
|
|
|
|
|
|
|
|
All the machine-dependent and operating system-dependent files in the
|
|
|
|
library are in the subdirectory @file{sysdeps} under the top-level
|
|
|
|
library source directory. This directory contains a hierarchy of
|
|
|
|
subdirectories (@pxref{Hierarchy Conventions}).
|
|
|
|
|
|
|
|
Each subdirectory of @file{sysdeps} contains source files for a
|
|
|
|
particular machine or operating system, or for a class of machine or
|
|
|
|
operating system (for example, systems by a particular vendor, or all
|
|
|
|
machines that use IEEE 754 floating-point format). A configuration
|
|
|
|
specifies an ordered list of these subdirectories. Each subdirectory
|
|
|
|
implicitly appends its parent directory to the list. For example,
|
|
|
|
specifying the list @file{unix/bsd/vax} is equivalent to specifying the
|
|
|
|
list @file{unix/bsd/vax unix/bsd unix}. A subdirectory can also specify
|
|
|
|
that it implies other subdirectories which are not directly above it in
|
|
|
|
the directory hierarchy. If the file @file{Implies} exists in a
|
|
|
|
subdirectory, it lists other subdirectories of @file{sysdeps} which are
|
|
|
|
appended to the list, appearing after the subdirectory containing the
|
|
|
|
@file{Implies} file. Lines in an @file{Implies} file that begin with a
|
|
|
|
@samp{#} character are ignored as comments. For example,
|
|
|
|
@file{unix/bsd/Implies} contains:@refill
|
|
|
|
@smallexample
|
|
|
|
# BSD has Internet-related things.
|
|
|
|
unix/inet
|
|
|
|
@end smallexample
|
|
|
|
@noindent
|
|
|
|
and @file{unix/Implies} contains:
|
|
|
|
@need 300
|
|
|
|
@smallexample
|
|
|
|
posix
|
|
|
|
@end smallexample
|
|
|
|
|
|
|
|
@noindent
|
|
|
|
So the final list is @file{unix/bsd/vax unix/bsd unix/inet unix posix}.
|
|
|
|
|
1997-10-15 13:34:02 +08:00
|
|
|
@file{sysdeps} has a ``special'' subdirectory called @file{generic}. It
|
|
|
|
is always implicitly appended to the list of subdirectories, so you
|
|
|
|
needn't put it in an @file{Implies} file, and you should not create any
|
|
|
|
subdirectories under it intended to be new specific categories.
|
|
|
|
@file{generic} serves two purposes. First, the makefiles do not bother
|
|
|
|
to look for a system-dependent version of a file that's not in
|
|
|
|
@file{generic}. This means that any system-dependent source file must
|
|
|
|
have an analogue in @file{generic}, even if the routines defined by that
|
|
|
|
file are not implemented on other platforms. Second. the @file{generic}
|
|
|
|
version of a system-dependent file is used if the makefiles do not find
|
|
|
|
a version specific to the system you're compiling for.
|
|
|
|
|
|
|
|
If it is possible to implement the routines in a @file{generic} file in
|
|
|
|
machine-independent C, using only other machine-independent functions in
|
|
|
|
the C library, then you should do so. Otherwise, make them stubs. A
|
|
|
|
@dfn{stub} function is a function which cannot be implemented on a
|
|
|
|
particular machine or operating system. Stub functions always return an
|
|
|
|
error, and set @code{errno} to @code{ENOSYS} (Function not implemented).
|
|
|
|
@xref{Error Reporting}. If you define a stub function, you must place
|
|
|
|
the statement @code{stub_warning(@var{function})}, where @var{function}
|
|
|
|
is the name of your function, after its definition; also, you must
|
|
|
|
include the file @code{<stub-tag.h>} into your file. This causes the
|
|
|
|
function to be listed in the installed @code{<gnu/stubs.h>}, and
|
|
|
|
makes GNU ld warn when the function is used.
|
|
|
|
|
Update.
1997-11-11 21:30 Ulrich Drepper <drepper@cygnus.com>
* include/sys/stat.h: Define stat, fstat, lstat and *64 variants
as macros so the the library compiles correctly even without
optimization.
* io/fstat.c: Undef fstat.
* io/fstat64.c: Undef fstat64
* io/lstat.c: Undef lstat.
* io/lstat64.c: Undef lstat64
* io/stat.c: Undef stat.
* io/stat64.c: Undef stat64
* io/fts.c: Include <include/sys/stat.h> to get macro definitions.
* io/ftw.c: Likewise.
* io/getdirname.c: Likewise.
* Makefile (install): Run test-installation.pl if possible.
* db2/Makefile: Update from db-2.3.12.
* db2/db.h: Likewise.
* db2/db_int.h: Likewise.
* db2/btree/bt_cursor.c: Likewise.
* db2/btree/bt_delete.c: Likewise.
* db2/btree/bt_open.c: Likewise.
* db2/btree/bt_put.c: Likewise.
* db2/btree/bt_rec.c: Likewise.
* db2/btree/bt_recno.c: Likewise.
* db2/btree/bt_search.c: Likewise.
* db2/btree/bt_split.c: Likewise.
* db2/btree/bt_stat.c: Likewise.
* db2/btree/btree.src: Likewise.
* db2/btree/btree_auto.c: Likewise.
* db2/btree/bt_cursor.c: Likewise.
* db2/btree/bt_delete.c: Likewise.
* db2/btree/bt_open.c: Likewise.
* db2/btree/bt_put.c: Likewise.
* db2/btree/bt_rec.c: Likewise.
* db2/btree/bt_recno.c: Likewise.
* db2/btree/bt_search.c: Likewise.
* db2/btree/bt_split.c: Likewise.
* db2/btree/bt_stat.c: Likewise.
* db2/btree/btree.src: Likewise.
* db2/btree/btree_auto.c: Likewise.
* db2/common/db_appinit.c: Likewise.
* db2/common/db_apprec.c: Likewise.
* db2/common/db_byteorder.c: Likewise.
* db2/common/db_region.c: Likewise.
* db2/db/db.c: Likewise
* db2/db/db.src: Likewise
* db2/db/db_auto.c: Likewise
* db2/db/db_dispatch.c: Likewise
* db2/db/db_dup.c: Likewise
* db2/db/db_overflow.c: Likewise
* db2/db/db_pr.c: Likewise
* db2/db/db_rec.c: Likewise
* db2/db/db_ret.c: Likewise
* db2/db/db_thread.c: Likewise
* db2/db185/db185.c: Likewise.
* db2/hash/hash.c: Likewise.
* db2/hash/hash.src: Likewise.
* db2/hash/hash_auto.c: Likewise.
* db2/hash/hash_dup.c: Likewise.
* db2/hash/hash_page.c: Likewise.
* db2/hash/hash_rec.c: Likewise.
* db2/include/btree_auto.h: Likewise.
* db2/include/btree_ext.h: Likewise.
* db2/include/clib_ext.h: Likewise.
* db2/include/common_ext.h: Likewise.
* db2/include/db.h.src: Likewise.
* db2/include/db_am.h: Likewise.
* db2/include/db_auto.h: Likewise.
* db2/include/db_cxx.h: Likewise.
* db2/include/db_ext.h: Likewise.
* db2/include/db_int.h.src: Likewise.
* db2/include/hash.h: Likewise.
* db2/include/hash_auto.h: Likewise.
* db2/include/hash_ext.h: Likewise.
* db2/include/lock.h: Likewise.
* db2/include/lock_ext.h: Likewise.
* db2/include/log.h: Likewise.
* db2/include/log_ext.h: Likewise.
* db2/include/mp.h: Likewise.
* db2/include/mp_ext.h: Likewise.
* db2/include/mutex_ext.h: Likewise.
* db2/include/os_ext.h: Likewise.
* db2/include/os_func.h: Likewise.
* db2/include/txn.h: Likewise.
* db2/include/txn_ext.h: Likewise.
* db2/lock/lock.c: Likewise.
* db2/lock/lock_deadlock.c: Likewise.
* db2/log/log.c: Likewise.
* db2/log/log_archive.c: Likewise.
* db2/log/log_auto.c: Likewise.
* db2/log/log_findckp.c: Likewise.
* db2/log/log_get.c: Likewise.
* db2/log/log_put.c: Likewise.
* db2/log/log_rec.c: Likewise.
* db2/log/log_register.c: Likewise.
* db2/mp/mp_bh.c: Likewise.
* db2/mp/mp_fget.c: Likewise.
* db2/mp/mp_fopen.c: Likewise.
* db2/mp/mp_fput.c: Likewise.
* db2/mp/mp_fset.c: Likewise.
* db2/mp/mp_open.c: Likewise.
* db2/mp/mp_pr.c: Likewise.
* db2/mp/mp_region.c: Likewise.
* db2/mp/mp_sync.c: Likewise.
* db2/mutex/mutex.c: Likewise.
* db2/os/os_abs.c: Likewise.
* db2/os/os_dir.c: Likewise.
* db2/os/os_fid.c: Likewise.
* db2/os/os_fsync.c: Likewise.
* db2/os/os_func.c: Likewise.
* db2/os/os_map.c: Likewise.
* db2/os/os_oflags.c: Likewise.
* db2/os/os_open.c: Likewise.
* db2/os/os_rpath.c: Likewise.
* db2/os/os_rw.c: Likewise.
* db2/os/os_seek.c: Likewise.
* db2/os/os_sleep.c: Likewise.
* db2/os/os_stat.c: Likewise.
* db2/os/os_unlink.c: Likewise.
* db2/progs/db_deadlock/db_deadlock.c: Likewise.
* db2/progs/db_dump/db_dump.c: Likewise.
* db2/progs/db_load/db_load.c: Likewise.
* db2/progs/db_recover/db_recover.c: Likewise.
* db2/progs/db_stat/db_stat.c: Likewise.
* db2/txn/txn.c: Likewise.
* db2/txn/txn_auto.c: Likewise.
* db2/txn/txn_rec.c: Likewise.
* db2/os/db_os_abs.c: Removed.
* db2/os/db_os_dir.c: Removed.
* db2/os/db_os_fid.c: Removed.
* db2/os/db_os_lseek.c: Removed.
* db2/os/db_os_mmap.c: Removed.
* db2/os/db_os_open.c: Removed.
* db2/os/db_os_rw.c: Removed.
* db2/os/db_os_sleep.c: Removed.
* db2/os/db_os_stat.c: Removed.
* db2/os/db_os_unlink.c: Removed.
* libio/stdio.h (fopen): Add __restrict to parameters.
* manual/process.texi (system): Describe behaviour for NULL argument.
* stdio-common/printf-parse.h: Parse hh modifier.
* stdio-common/vfprintf.c: Handle hh modifier.
* stdio-common/vfscanf.c: Likewise.
* manual/stdio.texi: Describe hh modifier for scanf/printf.
* math/complex.h: Don't define _Imaginary_I, but instead _Complex_I.
gcc does no yet know the `imaginary' keyword.
* math/test-math.c: Add little test for know gcc bug.
* math/tgmath.h: Make complex versions of log10() only available
if __USE_GNU.
* stdlib/test-canon.c: Fix typo.
* sysdeps/generic/setenv.c: Avoid compilation warnings.
Reported by Jim Meyering.
* sysdeps/generic/bits/errno.h: EILSEQ is an ISO C error number.
* sysdeps/mach/hurd/bits/errno.h: Likewise.
* sysdeps/standalone/bits/errno.h: Likewise.
* sysdeps/unix/sysv/linux/bits/errno.h: Likewise.
* sysdeps/i386/i586/memcpy.S: New file.
* sysdeps/i386/i586/mempcpy.S: New file.
* sysdeps/i386/i586/memset.S: Fix typo.
* sysdeps/posix/getcwd.c: Define HAVE_MEMPCPY for _LIBC. Add casts.
* sysdeps/posix/system.c: Add comment to explain code.
* sysdeps/wordsize-32/inttypes.h: Include <stddef.h> for wchar_t.
Define PTRDIFF_{MIN,MAX}, SIG_ATOMIC_{MIN,MAX}, SIZE_MAX,
WCHAR_{MIN,MAX}, WINT_{MIN,MAX}.
Define wcstoimax, wcstoumax.
* sysdeps/wordsize-64/inttypes.h: Likewise.
* wcsmbs/wchar.h: Define WCHAR_{MIN,MAX} if not already defined.
Declare __wcsto{l,ul,ll,ull}_internal only if not already done.
* time/Makefile (routines): Add strfxtime.
* time/strftime.c: Implement %F and %f format.
* time/strfxtime.c: New file.
* time/time.h: Define new types and symbols from ISO C 9X.
* time/mktime.c: Little comment correction.
1997-11-10 Andreas Jaeger <aj@arthur.rhein-neckar.de>
* sysdeps/libm-ieee754/s_sincosl.c: Fix typo.
* sysdeps/libm-ieee754/s_tanl.c: Fix typo.
* sysdeps/libm-ieee754/s_floorl.c: Correct typos.
* sysdeps/libm-ieee754/e_remainderl.c: Replace
EXTRACT_LDOUBLE_WORDS by GET_LDOUBLE_WORDS.
* sysdeps/libm-ieee754/e_atan2l.c: Replace EXTRACT_LDOUBLE_WORDS
by GET_LDOUBLE_WORDS.
* sysdeps/libm-ieee754/s_scalbnl.c: Replace ";" by "," for correct
variable declaration.
* sysdeps/libm-ieee754/s_scalblnl.c: Likewise.
* sysdeps/libm-ieee754/s_lrint.c (__lrint): Correct function.
* math/libm-test.c (sqrt_test): Add test for sqrt (0.25).
(asin_test): Add more test.
1997-11-10 23:34 Ulrich Drepper <drepper@cygnus.com>
* sysdeps/libm-ieee754/e_asin.c: Add braces to make code clearer
and to not confuse the poor compiler.
* sysdeps/libm-ieee754/e_asinf.c: Likewise.
Reported by vertex@cagent.com.
1997-11-09 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
* elf/dl-lookup.c (do_lookup): Don't accept the base version if we
require a specific one.
* libio/oldfreopen.c: Bind old symbols to version GLIBC_2.0.
* libio/oldiofopen.c: Likewise.
* libio/oldstdfiles.c: Likewise.
* libc.map: Export them.
1997-11-10 07:40 H.J. Lu <hjl@gnu.ai.mit.edu>
* stdlib/exit.c (exit): Handle recursive calls to exit ().
1997-11-09 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
* sysdeps/m68k/fpu/s_llrint.c: Fixed to take double argument
instead of long double.
* sysdeps/m68k/fpu/s_llrintf.c: New file.
* sysdeps/m68k/fpu/s_llrintl.c: New file.
* sysdeps/libm-ieee754/s_llrint.c: Make compilable and fix
overflow condition.
* sysdeps/libm-ieee754/s_llrintf.c: Fix overflow condition.
* sysdeps/libm-ieee754/s_llrintl.c: Likewise.
* sysdeps/libm-ieee754/s_llround.c: Likewise.
* sysdeps/libm-ieee754/s_llroundf.c: Likewise.
* sysdeps/libm-ieee754/s_llroundl.c: Likewise.
* sysdeps/libm-ieee754/s_lrint.c: Likewise.
* sysdeps/libm-ieee754/s_lrintf.c: Likewise.
* sysdeps/libm-ieee754/s_lrintl.c: Likewise.
* sysdeps/libm-ieee754/s_lround.c: Likewise.
* sysdeps/libm-ieee754/s_lroundf.c: Likewise.
* sysdeps/libm-ieee754/s_lroundl.c: Likewise.
* math/libm-test.c: Test all three variants of lrint and llrint.
Fix typos in lround and llround tests. Add tests for boundary
cases for lrint and llround.
1997-11-08 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
* manual/arith.texi: Misc doc fixes.
* manual/ctype.texi: Likewise.
* manual/pattern.texi: Likewise.
* manual/terminal.texi: Likewise.
1997-11-08 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
* sysdeps/unix/sysv/linux/xstatconv.c: Use struct assignment
instead of memcpy to let the compiler use whatever it regards as
optimal.
* sysdeps/unix/sysv/linux/alpha/xstatconv.c: Likewise.
1997-11-08 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
* sysdeps/unix/sysv/linux/Makefile (sysdep_headers)
[$(subdir)=misc]: Add sys/prctl.h.
* sysdeps/unix/sysv/linux/Dist: Distribute it.
1997-11-08 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
* io/ftwtest-sh: Don't use the unknown which command, instead try
pwd as /bin/pwd and /usr/bin/pwd.
1997-11-08 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
* manual/maint.texi (Tools for Installation): Don't recommend
broken version 3.76.1 of make.
(Porting): Fix wording.
1997-11-06 06:13 H.J. Lu <hjl@gnu.ai.mit.edu>
* config.make.in (build-pic-default): New, defined with
pic_default.
* configure.in (pic_default): New, set to yes if PIC is
default.
* Makeconfig (CPPFLAGS-.o, CPPFLAGS-.op, CPPFLAGS-.og,
CPPFLAGS-.ob): Add -DPIC if $(build-pic-default) is yes.
1997-11-09 18:15 Ulrich Drepper <drepper@cygnus.com>
* Makerules (libc.so): Fix typo.
* csu/Makefile (CFLAGS-initfini.s): Correctly fix moving function
definition. Patch by Zack Weinberg <zack@rabi.phys.columbia.edu>.
* stdlib/strtod.c: Handle numbers like 0.0e10000 correctly which
produce 0.0. Reported by Joe Keane <jgk@jgk.org>.
* sysdeps/libm-ieee754/s_ceill.c: Fix typos.
* sysdeps/libm-ieee754/s_llrint.c: Correct code, it never worked.
1997-11-06 07:00 H.J. Lu <hjl@gnu.ai.mit.edu>
* sysdeps/unix/sysv/i386/i686/time.S: Removed.
1997-11-08 14:07 Thorsten Kukuk <kukuk@vt.uni-paderborn.de>
* nis/libnsl.map: Add __do_niscall2 for nis_cachemgr.
* nis/nis_call.c: Set UDP resend timeout correct.
* nis/nss_compat/compat-grp.c: Rewritten to make it faster.
* nis/nss_compat/compat-pwd.c: Likewise.
* nis/nss_compat/compat-spwd.c: Likewise.
* nis/ypclnt.c: Fix UDP resend timeout, fix yp_bind/do_ypcall
interaction.
* inet/protocols/routed.h: Include sys/socket.h.
* inet/protocols/talkd.h: Likewise.
* inet/protocols/timed.h: Include rpc/types.h.
* sunrpc/rpc/pmap_clnt.h: Include rpc/clnt.h.
1997-11-06 01:39 Ulrich Drepper <drepper@cygnus.com>
* Makerules (libc.so): Add missing closing brace.
1997-11-05 Brendan Kehoe <brendan@lisa.cygnus.com>
* libio.h (__P): Name its arg `p' instead of `params'.
This was added solely to work around problems with
the definition of __P in the Solaris math.h header.
1997-11-12 08:06:02 +08:00
|
|
|
Some rare functions are only useful on specific systems and aren't
|
|
|
|
defined at all on others; these do not appear anywhere in the
|
|
|
|
system-independent source code or makefiles (including the
|
|
|
|
@file{generic} directory), only in the system-dependent @file{Makefile}
|
|
|
|
in the specific system's subdirectory.
|
1995-02-18 09:27:10 +08:00
|
|
|
|
|
|
|
If you come across a file that is in one of the main source directories
|
|
|
|
(@file{string}, @file{stdio}, etc.), and you want to write a machine- or
|
|
|
|
operating system-dependent version of it, move the file into
|
|
|
|
@file{sysdeps/generic} and write your new implementation in the
|
|
|
|
appropriate system-specific subdirectory. Note that if a file is to be
|
|
|
|
system-dependent, it @strong{must not} appear in one of the main source
|
|
|
|
directories.@refill
|
|
|
|
|
|
|
|
There are a few special files that may exist in each subdirectory of
|
|
|
|
@file{sysdeps}:
|
|
|
|
|
|
|
|
@comment Blank lines after items make the table look better.
|
|
|
|
@table @file
|
|
|
|
@item Makefile
|
|
|
|
|
|
|
|
A makefile for this machine or operating system, or class of machine or
|
|
|
|
operating system. This file is included by the library makefile
|
|
|
|
@file{Makerules}, which is used by the top-level makefile and the
|
|
|
|
subdirectory makefiles. It can change the variables set in the
|
|
|
|
including makefile or add new rules. It can use GNU @code{make}
|
|
|
|
conditional directives based on the variable @samp{subdir} (see above) to
|
|
|
|
select different sets of variables and rules for different sections of
|
|
|
|
the library. It can also set the @code{make} variable
|
|
|
|
@samp{sysdep-routines}, to specify extra modules to be included in the
|
|
|
|
library. You should use @samp{sysdep-routines} rather than adding
|
|
|
|
modules to @samp{routines} because the latter is used in determining
|
|
|
|
what to distribute for each subdirectory of the main source tree.@refill
|
|
|
|
|
|
|
|
Each makefile in a subdirectory in the ordered list of subdirectories to
|
|
|
|
be searched is included in order. Since several system-dependent
|
|
|
|
makefiles may be included, each should append to @samp{sysdep-routines}
|
|
|
|
rather than simply setting it:
|
|
|
|
|
|
|
|
@smallexample
|
|
|
|
sysdep-routines := $(sysdep-routines) foo bar
|
|
|
|
@end smallexample
|
|
|
|
|
|
|
|
@need 1000
|
|
|
|
@item Subdirs
|
|
|
|
|
|
|
|
This file contains the names of new whole subdirectories under the
|
|
|
|
top-level library source tree that should be included for this system.
|
|
|
|
These subdirectories are treated just like the system-independent
|
|
|
|
subdirectories in the library source tree, such as @file{stdio} and
|
|
|
|
@file{math}.
|
|
|
|
|
|
|
|
Use this when there are completely new sets of functions and header
|
|
|
|
files that should go into the library for the system this subdirectory
|
|
|
|
of @file{sysdeps} implements. For example,
|
|
|
|
@file{sysdeps/unix/inet/Subdirs} contains @file{inet}; the @file{inet}
|
|
|
|
directory contains various network-oriented operations which only make
|
|
|
|
sense to put in the library on systems that support the Internet.@refill
|
|
|
|
|
|
|
|
@item Dist
|
|
|
|
|
|
|
|
This file contains the names of files (relative to the subdirectory of
|
|
|
|
@file{sysdeps} in which it appears) which should be included in the
|
|
|
|
distribution. List any new files used by rules in the @file{Makefile}
|
|
|
|
in the same directory, or header files used by the source files in that
|
|
|
|
directory. You don't need to list files that are implementations
|
|
|
|
(either C or assembly source) of routines whose names are given in the
|
|
|
|
machine-independent makefiles in the main source tree.
|
|
|
|
|
|
|
|
@item configure
|
|
|
|
|
|
|
|
This file is a shell script fragment to be run at configuration time.
|
|
|
|
The top-level @file{configure} script uses the shell @code{.} command to
|
|
|
|
read the @file{configure} file in each system-dependent directory
|
|
|
|
chosen, in order. The @file{configure} files are often generated from
|
|
|
|
@file{configure.in} files using Autoconf.
|
|
|
|
|
|
|
|
A system-dependent @file{configure} script will usually add things to
|
|
|
|
the shell variables @samp{DEFS} and @samp{config_vars}; see the
|
|
|
|
top-level @file{configure} script for details. The script can check for
|
|
|
|
@w{@samp{--with-@var{package}}} options that were passed to the
|
|
|
|
top-level @file{configure}. For an option
|
|
|
|
@w{@samp{--with-@var{package}=@var{value}}} @file{configure} sets the
|
|
|
|
shell variable @w{@samp{with_@var{package}}} (with any dashes in
|
|
|
|
@var{package} converted to underscores) to @var{value}; if the option is
|
|
|
|
just @w{@samp{--with-@var{package}}} (no argument), then it sets
|
|
|
|
@w{@samp{with_@var{package}}} to @samp{yes}.
|
|
|
|
|
|
|
|
@item configure.in
|
|
|
|
|
|
|
|
This file is an Autoconf input fragment to be processed into the file
|
|
|
|
@file{configure} in this subdirectory. @xref{Introduction,,,
|
|
|
|
autoconf.info, Autoconf: Generating Automatic Configuration Scripts},
|
|
|
|
for a description of Autoconf. You should write either @file{configure}
|
|
|
|
or @file{configure.in}, but not both. The first line of
|
|
|
|
@file{configure.in} should invoke the @code{m4} macro
|
|
|
|
@samp{GLIBC_PROVIDES}. This macro does several @code{AC_PROVIDE} calls
|
|
|
|
for Autoconf macros which are used by the top-level @file{configure}
|
|
|
|
script; without this, those macros might be invoked again unnecessarily
|
|
|
|
by Autoconf.
|
|
|
|
@end table
|
|
|
|
|
|
|
|
That is the general system for how system-dependencies are isolated.
|
|
|
|
@iftex
|
|
|
|
The next section explains how to decide what directories in
|
|
|
|
@file{sysdeps} to use. @ref{Porting to Unix}, has some tips on porting
|
|
|
|
the library to Unix variants.
|
|
|
|
@end iftex
|
|
|
|
|
|
|
|
@menu
|
|
|
|
* Hierarchy Conventions:: The layout of the @file{sysdeps} hierarchy.
|
|
|
|
* Porting to Unix:: Porting the library to an average
|
|
|
|
Unix-like system.
|
|
|
|
@end menu
|
|
|
|
|
|
|
|
@node Hierarchy Conventions
|
|
|
|
@appendixsubsec Layout of the @file{sysdeps} Directory Hierarchy
|
|
|
|
|
|
|
|
A GNU configuration name has three parts: the CPU type, the
|
|
|
|
manufacturer's name, and the operating system. @file{configure} uses
|
|
|
|
these to pick the list of system-dependent directories to look for. If
|
|
|
|
the @samp{--nfp} option is @emph{not} passed to @file{configure}, the
|
|
|
|
directory @file{@var{machine}/fpu} is also used. The operating system
|
|
|
|
often has a @dfn{base operating system}; for example, if the operating
|
1998-03-25 23:21:09 +08:00
|
|
|
system is @samp{Linux}, the base operating system is @samp{unix/sysv}.
|
1995-02-18 09:27:10 +08:00
|
|
|
The algorithm used to pick the list of directories is simple:
|
|
|
|
@file{configure} makes a list of the base operating system,
|
|
|
|
manufacturer, CPU type, and operating system, in that order. It then
|
|
|
|
concatenates all these together with slashes in between, to produce a
|
1998-03-25 23:21:09 +08:00
|
|
|
directory name; for example, the configuration @w{@samp{i686-linux-gnu}}
|
|
|
|
results in @file{unix/sysv/linux/i386/i686}. @file{configure} then
|
1995-02-18 09:27:10 +08:00
|
|
|
tries removing each element of the list in turn, so
|
1998-03-25 23:21:09 +08:00
|
|
|
@file{unix/sysv/linux} and @file{unix/sysv} are also tried, among others.
|
1995-02-18 09:27:10 +08:00
|
|
|
Since the precise version number of the operating system is often not
|
|
|
|
important, and it would be very inconvenient, for example, to have
|
1998-03-25 23:21:09 +08:00
|
|
|
identical @file{irix6.2} and @file{irix6.3} directories,
|
1995-02-18 09:27:10 +08:00
|
|
|
@file{configure} tries successively less specific operating system names
|
|
|
|
by removing trailing suffixes starting with a period.
|
|
|
|
|
|
|
|
As an example, here is the complete list of directories that would be
|
1998-03-25 23:21:09 +08:00
|
|
|
tried for the configuration @w{@samp{i686-linux-gnu}} (with the
|
|
|
|
@file{crypt} and @file{linuxthreads} add-on):
|
1995-02-18 09:27:10 +08:00
|
|
|
|
|
|
|
@smallexample
|
1998-03-25 23:21:09 +08:00
|
|
|
sysdeps/i386/elf
|
|
|
|
crypt/sysdeps/unix
|
|
|
|
linuxthreads/sysdeps/unix/sysv/linux
|
|
|
|
linuxthreads/sysdeps/pthread
|
|
|
|
linuxthreads/sysdeps/unix/sysv
|
|
|
|
linuxthreads/sysdeps/unix
|
|
|
|
linuxthreads/sysdeps/i386/i686
|
|
|
|
linuxthreads/sysdeps/i386
|
|
|
|
linuxthreads/sysdeps/pthread/no-cmpxchg
|
|
|
|
sysdeps/unix/sysv/linux/i386
|
|
|
|
sysdeps/unix/sysv/linux
|
|
|
|
sysdeps/gnu
|
|
|
|
sysdeps/unix/common
|
|
|
|
sysdeps/unix/mman
|
|
|
|
sysdeps/unix/inet
|
|
|
|
sysdeps/unix/sysv/i386/i686
|
|
|
|
sysdeps/unix/sysv/i386
|
|
|
|
sysdeps/unix/sysv
|
|
|
|
sysdeps/unix/i386
|
|
|
|
sysdeps/unix
|
|
|
|
sysdeps/posix
|
|
|
|
sysdeps/i386/i686
|
|
|
|
sysdeps/i386/i486
|
|
|
|
sysdeps/libm-i387/i686
|
|
|
|
sysdeps/i386/fpu
|
|
|
|
sysdeps/libm-i387
|
|
|
|
sysdeps/i386
|
|
|
|
sysdeps/wordsize-32
|
|
|
|
sysdeps/ieee754
|
|
|
|
sysdeps/libm-ieee754
|
|
|
|
sysdeps/generic
|
1995-02-18 09:27:10 +08:00
|
|
|
@end smallexample
|
|
|
|
|
|
|
|
Different machine architectures are conventionally subdirectories at the
|
|
|
|
top level of the @file{sysdeps} directory tree. For example,
|
|
|
|
@w{@file{sysdeps/sparc}} and @w{@file{sysdeps/m68k}}. These contain
|
|
|
|
files specific to those machine architectures, but not specific to any
|
|
|
|
particular operating system. There might be subdirectories for
|
|
|
|
specializations of those architectures, such as
|
|
|
|
@w{@file{sysdeps/m68k/68020}}. Code which is specific to the
|
|
|
|
floating-point coprocessor used with a particular machine should go in
|
|
|
|
@w{@file{sysdeps/@var{machine}/fpu}}.
|
|
|
|
|
|
|
|
There are a few directories at the top level of the @file{sysdeps}
|
|
|
|
hierarchy that are not for particular machine architectures.
|
|
|
|
|
|
|
|
@table @file
|
|
|
|
@item generic
|
1997-10-15 13:34:02 +08:00
|
|
|
As described above (@pxref{Porting}), this is the subdirectory
|
1995-02-18 09:27:10 +08:00
|
|
|
that every configuration implicitly uses after all others.
|
|
|
|
|
|
|
|
@item ieee754
|
|
|
|
This directory is for code using the IEEE 754 floating-point format,
|
|
|
|
where the C type @code{float} is IEEE 754 single-precision format, and
|
|
|
|
@code{double} is IEEE 754 double-precision format. Usually this
|
|
|
|
directory is referred to in the @file{Implies} file in a machine
|
|
|
|
architecture-specific directory, such as @file{m68k/Implies}.
|
|
|
|
|
1998-03-25 23:21:09 +08:00
|
|
|
@item libm-ieee754
|
|
|
|
This directory contains an implementation of a mathematical library
|
|
|
|
usable on platforms which use @w{IEEE 754} conformant floating-point
|
|
|
|
arithmetic.
|
|
|
|
|
|
|
|
@item libm-i387
|
|
|
|
This is a special case. Ideally the code should be in
|
|
|
|
@file{sysdeps/i386/fpu} but for various reasons it is kept aside.
|
|
|
|
|
1995-02-18 09:27:10 +08:00
|
|
|
@item posix
|
|
|
|
This directory contains implementations of things in the library in
|
|
|
|
terms of @sc{POSIX.1} functions. This includes some of the @sc{POSIX.1}
|
|
|
|
functions themselves. Of course, @sc{POSIX.1} cannot be completely
|
|
|
|
implemented in terms of itself, so a configuration using just
|
|
|
|
@file{posix} cannot be complete.
|
|
|
|
|
|
|
|
@item unix
|
|
|
|
This is the directory for Unix-like things. @xref{Porting to Unix}.
|
|
|
|
@file{unix} implies @file{posix}. There are some special-purpose
|
|
|
|
subdirectories of @file{unix}:
|
|
|
|
|
|
|
|
@table @file
|
|
|
|
@item unix/common
|
|
|
|
This directory is for things common to both BSD and System V release 4.
|
|
|
|
Both @file{unix/bsd} and @file{unix/sysv/sysv4} imply @file{unix/common}.
|
|
|
|
|
|
|
|
@item unix/inet
|
|
|
|
This directory is for @code{socket} and related functions on Unix systems.
|
1998-03-18 01:27:52 +08:00
|
|
|
@file{unix/inet/Subdirs} enables the @file{inet} top-level subdirectory.
|
1995-02-18 09:27:10 +08:00
|
|
|
@file{unix/common} implies @file{unix/inet}.
|
|
|
|
@end table
|
|
|
|
|
|
|
|
@item mach
|
|
|
|
This is the directory for things based on the Mach microkernel from CMU
|
|
|
|
(including the GNU operating system). Other basic operating systems
|
|
|
|
(VMS, for example) would have their own directories at the top level of
|
|
|
|
the @file{sysdeps} hierarchy, parallel to @file{unix} and @file{mach}.
|
|
|
|
@end table
|
|
|
|
|
|
|
|
@node Porting to Unix
|
|
|
|
@appendixsubsec Porting the GNU C Library to Unix Systems
|
|
|
|
|
|
|
|
Most Unix systems are fundamentally very similar. There are variations
|
|
|
|
between different machines, and variations in what facilities are
|
|
|
|
provided by the kernel. But the interface to the operating system
|
|
|
|
facilities is, for the most part, pretty uniform and simple.
|
|
|
|
|
|
|
|
The code for Unix systems is in the directory @file{unix}, at the top
|
|
|
|
level of the @file{sysdeps} hierarchy. This directory contains
|
|
|
|
subdirectories (and subdirectory trees) for various Unix variants.
|
|
|
|
|
|
|
|
The functions which are system calls in most Unix systems are
|
1997-09-05 09:43:20 +08:00
|
|
|
implemented in assembly code, which is generated automatically from
|
1998-03-18 01:27:52 +08:00
|
|
|
specifications in files named @file{syscalls.list}. There are several
|
|
|
|
such files, one in @file{sysdeps/unix} and others in its subdirectories.
|
|
|
|
Some special system calls are implemented in files that are named with a
|
1997-09-05 09:43:20 +08:00
|
|
|
suffix of @samp{.S}; for example, @file{_exit.S}. Files ending in
|
|
|
|
@samp{.S} are run through the C preprocessor before being fed to the
|
|
|
|
assembler.
|
1995-02-18 09:27:10 +08:00
|
|
|
|
|
|
|
These files all use a set of macros that should be defined in
|
|
|
|
@file{sysdep.h}. The @file{sysdep.h} file in @file{sysdeps/unix}
|
|
|
|
partially defines them; a @file{sysdep.h} file in another directory must
|
|
|
|
finish defining them for the particular machine and operating system
|
|
|
|
variant. See @file{sysdeps/unix/sysdep.h} and the machine-specific
|
|
|
|
@file{sysdep.h} implementations to see what these macros are and what
|
|
|
|
they should do.@refill
|
|
|
|
|
1998-03-18 01:27:52 +08:00
|
|
|
The system-specific makefile for the @file{unix} directory
|
|
|
|
(@file{sysdeps/unix/Makefile}) gives rules to generate several files
|
1995-02-18 09:27:10 +08:00
|
|
|
from the Unix system you are building the library on (which is assumed
|
|
|
|
to be the target system you are building the library @emph{for}). All
|
|
|
|
the generated files are put in the directory where the object files are
|
|
|
|
kept; they should not affect the source tree itself. The files
|
|
|
|
generated are @file{ioctls.h}, @file{errnos.h}, @file{sys/param.h}, and
|
|
|
|
@file{errlist.c} (for the @file{stdio} section of the library).
|
|
|
|
|
|
|
|
@ignore
|
|
|
|
@c This section might be a good idea if it is finished,
|
|
|
|
@c but there's no point including it as it stands. --rms
|
|
|
|
@c @appendixsec Compatibility with Traditional C
|
|
|
|
|
|
|
|
@c ??? This section is really short now. Want to keep it? --roland
|
|
|
|
|
1998-03-25 23:21:09 +08:00
|
|
|
@c It's not anymore true. glibc 2.1 cannot be used with K&R compilers.
|
|
|
|
@c --drepper
|
|
|
|
|
1996-12-08 16:01:13 +08:00
|
|
|
Although the GNU C library implements the @w{ISO C} library facilities, you
|
|
|
|
@emph{can} use the GNU C library with traditional, ``pre-ISO'' C
|
1995-02-18 09:27:10 +08:00
|
|
|
compilers. However, you need to be careful because the content and
|
|
|
|
organization of the GNU C library header files differs from that of
|
|
|
|
traditional C implementations. This means you may need to make changes
|
|
|
|
to your program in order to get it to compile.
|
|
|
|
@end ignore
|