Changes

Jump to: navigation, search

Bare metal RISC-V GCC 9.3.0 cross compiler instructions

496 bytes added, 12:49, 17 March 2020
m
== Introduction ==
We'll build a GCC 9.23.0 targeting bare metal RISC-V.
== Create directories ==
cd $HOME
mkdir -p src obj/{binutils-build,gcc-build,gdb-build,newlib-build}
== Get GCC, GDB and binutils ==
curl https://ftp.gnu.org/gnu/binutils/binutils-2.33.134.tar.gz | tar -C $HOME/src -xf - curl https://ftp.gnu.org/gnu/gdb/gdb-89.31.tar.gz | tar -C $HOME/src -xf - curl https://ftp.gnu.org/gnu/gcc/gcc-9.23.0/gcc-9.23.0.tar.gz | tar -C $HOME/src -xf - curl ftp://sourceware.org/pub/newlib/newlib-3.13.0.tar.gz | tar -C $HOME/src -xf -
== Download prerequisites ==
cd $HOME/src/gcc-9.23.0
./contrib/download_prerequisites
cd $HOME/obj/binutils-build
../../src/binutils-2.3334/configure --prefix $HOME/xgcc --bindir $HOME/bin --target riscv64-unknown-elf --enable-multilib make -j8 && make install == Build and install gdb ==  cd $HOME/obj/gdb-build ../../src/gdb-9.1/configure --prefix $HOME/xgcc --bindir $HOME/bin --target riscv64-unknown-elf --enable-multilib
make -j8 && make install
cd $HOME/obj/gcc-build
../../src/gcc-9.23.0/configure --prefix $HOME/xgcc --bindir $HOME/bin --target riscv64-unknown-elf --enable-multilib --enable-languages=c --with-gnu-as --with-gnu-ld --without-headers --with-newlib
make -j8 all-gcc && make install-gcc
cd $HOME/obj/newlib-build
../../src/newlib-3.13.0/configure --prefix $HOME/xgcc --bindir $HOME/bin --target riscv64-unknown-elf --enable-multilib
make -j8 all && make install
rm -rf $HOME/obj/gcc-build && mkdir -p $HOME/obj/gcc-build
cd $HOME/obj/gcc-build
../../src/gcc-9.23.0/configure --prefix $HOME/xgcc --bindir $HOME/bin --target riscv64-unknown-elf --enable-multilib --enable-languages=c --with-gnu-as --with-gnu-ld --with-newlib
make -j8 all && make install
 
== Build and install riscv-openocd (optional) ==
 
cd $HOME/src
git clone --recursive git@github.com:riscv/riscv-openocd.git
cd $HOME/src/riscv-openocd
# brew install pkg-config libtool automake autoconf # required by bootstrap
./bootstrap
./configure --prefix=$HOME/riscv --bindir $HOME/bin--enable-remote-bitbang --enable-jtag_vpi
make -j8 && make install

Navigation menu