/xv6-vf2

Port of the xv6 OS to the VisionFive 2 RISC V board

Primary LanguageCOtherNOASSERTION

This is a port of xv6 to the VisionFive 2 (VF2) RISC V board.

The VF2 port runs in S mode of the CPU and uses SBI functions for UART output for now.

It is based on the xv6 K210 and my xv6 Allwinner D1 port: https://github.com/HUST-OS/xv6-k210 https://github.com/michaelengel/xv6-d1

Problems:

  • Currently, the RAM disk is included in kernel/include/ramdisk.h - this is a prebuilt FAT image with some of the tools from the xv6-user directory. Regenerating the image is not yet included in the Makefile.

  • No multiprocessor support (enabled) so far.

  • The UART code is still problematic due to interrupt handling of the dwc UART core.

Try it:

  1. Use "make" to build a binary kernel "kernel.bin" in target.

  2. Connect to the UART on the VF2 board using minicom (pinout identical to the Raspberry Pi, 115200 bps, no handshake)

  3. Load the kernel in u-boot via the ymodem protocol using "loady 0x80400000"

  4. If the transfer was successful, boot the kernel using "go 0x80400000"

Have fun!

--- original README ---

xv6 is a re-implementation of Dennis Ritchie's and Ken Thompson's Unix Version 6 (v6). xv6 loosely follows the structure and style of v6, but is implemented for a modern RISC-V multiprocessor using ANSI C.

ACKNOWLEDGMENTS

xv6 is inspired by John Lions's Commentary on UNIX 6th Edition (Peer to Peer Communications; ISBN: 1-57398-013-7; 1st edition (June 14, 2000)). See also https://pdos.csail.mit.edu/6.828/, which provides pointers to on-line resources for v6.

The following people have made contributions: Russ Cox (context switching, locking), Cliff Frey (MP), Xiao Yu (MP), Nickolai Zeldovich, and Austin Clements.

We are also grateful for the bug reports and patches contributed by Silas Boyd-Wickizer, Anton Burtsev, Dan Cross, Cody Cutler, Mike CAT, Tej Chajed, Asami Doi, eyalz800, , Nelson Elhage, Saar Ettinger, Alice Ferrazzi, Nathaniel Filardo, Peter Froehlich, Yakir Goaron,Shivam Handa, Bryan Henry, jaichenhengjie, Jim Huang, Alexander Kapshuk, Anders Kaseorg, kehao95, Wolfgang Keller, Jonathan Kimmitt, Eddie Kohler, Austin Liew, Imbar Marinescu, Yandong Mao, Matan Shabtay, Hitoshi Mitake, Carmi Merimovich, Mark Morrissey, mtasm, Joel Nider, Greg Price, Ayan Shafqat, Eldar Sehayek, Yongming Shen, Fumiya Shigemitsu, Takahiro, Cam Tenny, tyfkda, Rafael Ubal, Warren Toomey, Stephen Tu, Pablo Ventura, Xi Wang, Keiichi Watanabe, Nicolas Wolovick, wxdao, Grant Wu, Jindong Zhang, Icenowy Zheng, and Zou Chang Wei.

The code in the files that constitute xv6 is Copyright 2006-2020 Frans Kaashoek, Robert Morris, and Russ Cox.

ERROR REPORTS

Please send errors and suggestions to Frans Kaashoek and Robert Morris (kaashoek,rtm@mit.edu). The main purpose of xv6 is as a teaching operating system for MIT's 6.S081, so we are more interested in simplifications and clarifications than new features.

BUILDING AND RUNNING XV6

You will need a RISC-V "newlib" tool chain from https://github.com/riscv/riscv-gnu-toolchain, and qemu compiled for riscv64-softmmu. Once they are installed, and in your shell search path, you can run "make qemu".