<!--#include file="header.html" --> <h3>Toolchains</h3> To use uClibc, you need to have a toolchain. A toolchain consists of <a href="http://sources.redhat.com/binutils/">GNU binutils</a>, <a href="http://gcc.gnu.org/">the gcc compiler</a>, and uClibc, all built to produce binaries for your target system linked with uClibc. You can build your own native uClibc toolchain using the <a href="/cgi-bin/viewcvs.cgi/trunk/buildroot/">uClibc buildroot system</a>. <p> To build your own uClibc toolchain, follow the following simple steps: <ul> <li> Point your web browser <a href="/cgi-bin/viewcvs.cgi/trunk/buildroot/">here</a>, <li> Click on "Download tarball" <li> Unpack the tarball on your Linux system somewhere <li> Edit the Makefile as needed if you wish to change anything. <li> run 'unset CC'. Then run 'unset CXX'. Some Linux systems (i.e. Gentoo) set variables such as 'CC' in the system environment which really messes things up when cross compiling. <li> run 'make menuconfig' <li> Select the things you want to build. If you <em>only</em> want a toolchain, leave everything except the toolchain disabled. <li> save your buildroot configuration. <li> run 'make' <li> go eat a nice wholesome sandwich, drink a pop, call a friend, play a video game, and generally find something to do. While you are waiting, buildroot will download all the needed source code and then compile things up for you. <li> You should now have a shiny new toolchain, and maybe even a shiny new uClibc based root filesystem or development system, depending on the options you selected. </ul> <p> If you want to be <em>really</em> lazy and start using uClibc right away without needing to compile your own toolchain or anything, you can grab a pre-compiled uClibc development system. These are currently available for <a href="http://www.uclibc.org/downloads/root_fs_arm.ext2.bz2">arm</a>, <a href="http://www.uclibc.org/downloads/root_fs_armeb.ext2.bz2">armeb</a>, <a href="http://www.uclibc.org/downloads/root_fs_i386.ext2.bz2">i386</a>, <a href="http://www.uclibc.org/downloads/root_fs_mips.ext2.bz2">mips</a>, <a href="http://www.uclibc.org/downloads/root_fs_mipsel.ext2.bz2">mipsel</a>, <a href="http://www.uclibc.org/downloads/root_fs_powerpc.ext2.bz2">powerpc</a>, and <a href="http://www.uclibc.org/downloads/root_fs_sh4.ext2.bz2">sh4</a>. <p> These are bzip2 compressed ext2 filesystems containing all the development software you need to build your own uClibc applications, including: bash, awk, make, gcc, g++, autoconf, automake, ncurses, zlib, openssl, openssh, gdb, strace, busybox, GNU coreutils, GNU tar, GNU grep, etc. <p> Each of these uClibc development systems was created using <a href="/cgi-bin/viewcvs.cgi/trunk/buildroot/">buildroot</a>, specifically, <a href="http://www.uclibc.org/downloads/buildroot.tar.bz2">buildroot.tar.bz2</a> along with <a href="http://www.uclibc.org/downloads/buildroot-sources">these sources</a>. <p> These development systems should provide pretty much everything you need to get started building your own applications with uClibc. Once you download one of these systems, you can then boot into it, loop mount it, dd it to a spare drive and use a tool such as resize2fs to make it fill a partition... Whatever works best for you. <p> The quickest way to get started using a root_fs image (using the i386 platform as an example) is: <ul> <li>Download root_fs_i386.bz2 from uclibc.org</li> <li>bunzip2 root_fs_i386.bz2</li> <li>mkdir root_fs</li> <li>su root</li> <li>mount -o loop root_fs_i386 root_fs</li> <li>chroot root_fs /bin/su -</li> </ul> Type "exit" to end the chroot session and return to your host system. <p> <!--#include file="footer.html" -->