Embedded C library http://uclibc-ng.org

Manuel Novoa III 24b3f737bc Don't install floating point related headers, and wrap some previously 20 years ago
debian 2fd364618a Update version 21 years ago
docs 9f24aacae6 Remove ftw and nftw as exceptions, add getgrgid_r and getgrnam_r 20 years ago
extra 41130f0233 Let people enable ftw, make glob an option, add a new "Big and Tall" 20 years ago
include 24b3f737bc Don't install floating point related headers, and wrap some previously 20 years ago
ldso 44e38f0001 cleanup/simplify duplicate handling. 20 years ago
libc 1bb56f3592 oops. ftw would blow chunks if UCLIBC_HAS_LFS was disabled. 20 years ago
libcrypt cf0a78c882 Cleanup crypt and remove the crypt_r stuff, since SuSv3 22 years ago
libintl 8f15281c9c Rework a few things. 20 years ago
libm 557ea04ce0 Atsushi Nemoto writes: 20 years ago
libnsl a3ac5450a6 Somewhat pointless naming pedantry 21 years ago
libpthread e71b7cc95c here is (I hope) a better way to handle this one. I regularly build 20 years ago
libresolv 65fe2cc096 Fix broken ignore file 21 years ago
libutil efe2271a53 Make login actually write out utmp and wtmp junk (even 21 years ago
test 63b7491b2b Make it easier to disable lib debugging (mainly for when testing 20 years ago
.cvsignore 6737908f74 Ok, this commit is _huge_ and its gonna change the world. I've 21 years ago
COPYING.LIB 64bc641218 Initial revision 24 years ago
Changelog 0df62682dd oops. This is 0.9.20, not .30 21 years ago
Changelog.full db2863760e Update for release 21 years ago
INSTALL fc71b53fcc Fix typo noticed by V.Radhakrishnan 21 years ago
Makefile 24b3f737bc Don't install floating point related headers, and wrap some previously 20 years ago
README 7d7d0766d2 Minor update regarding binutils 21 years ago
Rules.mak 38303cbca9 Bump version number in preparation for a release 20 years ago
TODO 1e680eeea6 Add a couple of things... And check that cvs commit diffs are 20 years ago

README


uClibc - a Small C Library for Linux
Erik Andersen

uClibc (aka Clibc/pronounced yew-see-lib-see) is a C library for
developing embedded Linux systems. It is much smaller than the
GNU C Library, but nearly all applications supported by glibc
also work perfectly with uClibc. Porting applications from glibc
to uClibc typically involves just recompiling the source code.
uClibc even supports shared libraries and threading. It currently
runs on standard Linux and MMU-less (also known as Clinux)
systems with support for alpha, ARM, i386, i960, h8300, m68k,
mips/mipsel, PowerPC, SH, SPARC, and v850 processors.

If you are building an embedded Linux system and you find that
glibc is eating up too much space, you should consider using
uClibc. If you are building a huge fileserver with 12 Terabytes
of storage, then using glibc may be a better choice...

uClibc is maintained by Erik Andersen and is licensed under the
GNU LIBRARY GENERAL PUBLIC LICENSE . This license allows you to
make closed source commercial applications using uClibc (Please
consider sharing some of the money you make ;-). You do not need
to give away all your source code just because you use uClibc
and/or run on Linux.


For installation instructions, see the file INSTALL.

This distribution contains a wrapper for gcc and ld that allows you
to use existing toolchains that were targetted for glibc. See
extra/gcc-uClibc/ for information.

uClibc strives to be standards compliant, which means that most
documentation written for functions in glibc also applies to uClibc
functions. However, many GNU extensions are not supported because
they have not been ported, or more importantly, would increase the
size of uClibc disproportional to the added functionality.

Additional information (recent releases, FAQ, mailing list, bugs,
etc.) can be found at http://www.uclibc.org/.

uClibc may be freely modified distributed under the terms of the
GNU Library General Public License, which can be found in the
file COPYING.LIB.

Please Note:

There is an unwholesomely huge amount of code out there
that depends on the presence of GNU libc header files.
We have GNU libc header files. So we have committed a
horrible sin in uClibc. We _lie_ and claim to be GNU
libc in order to force these applications to work as their
developers intended. This is IMHO, pardonable, since
these defines are not really intended to check for the
presence of a particular library, but rather are used to
define an _interface_. Some programs are especially
chummy with glibc, and may need this behavior disabled
by adding CFLAGS+=-D__FORCE_NOGLIBC