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

Tobias Anderberg f970ce6348 Save r0 before modifying it. 21 年之前
debian 64d5a0b1fb Minor .deb updates 21 年之前
docs 68fd847f6f blah 21 年之前
extra d45e66d4ff UCLIBC_COMPLETELY_PIC does nothing, so kill it 21 年之前
include 0a20ca071b Change clock() to allow wrapping. 21 年之前
ldso f970ce6348 Save r0 before modifying it. 21 年之前
libc 58fff9b55c Obligatory forgotten file... 21 年之前
libcrypt d8c8b456f4 We need to link with libgcc.a when creating shared libs, in order to 22 年之前
libintl d8c8b456f4 We need to link with libgcc.a when creating shared libs, in order to 22 年之前
libm ac1281c278 Nicolas Pitre writes: 22 年之前
libnsl d8c8b456f4 We need to link with libgcc.a when creating shared libs, in order to 22 年之前
libpthread 201ca767d5 Alexandre Oliva writes: 21 年之前
libresolv d8c8b456f4 We need to link with libgcc.a when creating shared libs, in order to 22 年之前
libutil ada7878ba0 Based on a patch from Alexandre Oliva, remove all reference to 'bzero' (which 21 年之前
test 119b5a98ec Add ldflags where needed 22 年之前
utils 0c91a787b6 Look in /usr/X11R6/lib as well 21 年之前
.cvsignore 62348cb744 Minor update... Config no longer used. 22 年之前
COPYING.LIB 64bc641218 Initial revision 25 年之前
Changelog eecd5c649c Update for release 22 年之前
Changelog.full eecd5c649c Update for release 22 年之前
Changelog.full.last ba64d84bc7 Update for release 22 年之前
DEDICATION.mjn3 38583d5986 Today's Toni's birthday. Seems an appropriate day to add this. 22 年之前
INSTALL 1528771f28 Update docs in preparation for release 22 年之前
Makefile 909c7fda1f Alexandre Oliva writes: 21 年之前
README 1528771f28 Update docs in preparation for release 22 年之前
Rules.mak bbab258ae6 Update the x86 processor listing a bit, to preempt further questions 21 年之前
TODO f6b6b3b7a4 Update todo list indicating the items remaining before 0.9.27 21 年之前

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, cris, e1, h8300, i386, i960,
m68k, microblaze, 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 make more sense. Unless, for
example, that 12 Terabytes will be Network Attached Storage and
you plan to burn Linux into the system's firmware...

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 an unmodified
version of 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. You should, however,
carefuly review the license and make certain you understand and
abide by it strictly.


For installation instructions, see the file INSTALL.

uClibc strives to be standards compliant, which means that most
documentation written for SuSv3, or for 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. There is some discussion of these differences
in the "docs" directory.

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

uClibc may be freely modified and 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 compatible 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

If you want to make special exceptions in your code which are
specifically for uClibc, you can make certain to include features.h,
and then have your code check for uClibc as follows:

#ifdef __UCLIBC__
do_something_special();
#endif

And most of all, but sure to have some fun!
-Erik