RISC-V Proxy Kernel
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
Andrew Waterman 241ce51583 License my ASCII RISC-V logo 8 years ago
bbl Properly license all nontrivial files 8 years ago
dummy_payload Properly license all nontrivial files 8 years ago
machine Properly license all nontrivial files 8 years ago
pk Properly license all nontrivial files 8 years ago
scripts Properly license all nontrivial files 8 years ago
softfloat Properly license all nontrivial files 8 years ago
util Properly license all nontrivial files 8 years ago
.gitignore Ignore some generated files 9 years ago
LICENSE add missing LICENSE file 13 years ago
LICENSE.Batten Properly license all nontrivial files 8 years ago
LICENSE.SoftFloat Properly license all nontrivial files 8 years ago
LICENSE.riscv_logo.txt License my ASCII RISC-V logo 8 years ago
Makefile.in Properly license all nontrivial files 8 years ago
README.md Changed install_subdir to $host_alias with substituted 64->32 instead… (#89) 8 years ago
aclocal.m4 Properly license all nontrivial files 8 years ago
config.h.in RISC-V: Support separate firmware and kernel payload 8 years ago
configure Replace the --enable-32bit option by --with-arch 8 years ago
configure.ac Properly license all nontrivial files 8 years ago

README.md

RISC-V Proxy Kernel and Boot Loader

About

The RISC-V Proxy Kernel, pk, is a lightweight application execution environment that can host statically-linked RISC-V ELF binaries. It is designed to support tethered RISC-V implementations with limited I/O capability and and thus handles I/O-related system calls by proxying them to a host computer.

This package also contains the Berkeley Boot Loader, bbl, which is a supervisor execution environment for tethered RISC-V systems. It is designed to host the RISC-V Linux port.

Build Steps

We assume that the RISCV environment variable is set to the RISC-V tools install path, and that the riscv-gnu-toolchain package is installed. Please note that building the binaries directly inside the source directory is not supported; you need to use a separate build directory.

$ mkdir build
$ cd build
$ ../configure --prefix=$RISCV --host=riscv64-unknown-elf
$ make
$ make install

Alternatively, the GNU/Linux toolchain may be used to build this package, by setting --host=riscv64-unknown-linux-gnu.

By default, 64-bit (RV64) versions of pk and bbl are built. To built 32-bit (RV32) versions, supply a --enable-32bit flag to the configure command.

The install step installs 64-bit build products into a directory matching your host (e.g. $RISCV/riscv64-unknown-elf). 32-bit versions are installed into a directory matching a 32-bit version of your host (e.g. $RISCV/riscv32-unknown-elf).