git: 5912458941af - main - emulators/rvvm: RISC-V Virtual Machine
Date: Thu, 23 Jan 2025 01:07:21 UTC
The branch main has been updated by fuz:
URL: https://cgit.FreeBSD.org/ports/commit/?id=5912458941af2189b7fa940dd20a21fd168e67fd
commit 5912458941af2189b7fa940dd20a21fd168e67fd
Author: Robert Clausecker <fuz@FreeBSD.org>
AuthorDate: 2025-01-22 23:29:49 +0000
Commit: Robert Clausecker <fuz@FreeBSD.org>
CommitDate: 2025-01-23 01:06:22 +0000
emulators/rvvm: RISC-V Virtual Machine
RVVM is a virtual machine / emulator for RISC-V guests, which emphasizes
on performance, security, lean code and portability. It already runs a
lot of guest operating systems, including Linux, Haiku, FreeBSD,
OpenBSD, etc. It also aims to run RISC-V applications on a foreign-arch
host without full OS guest & isolation (Userland emulation).
WWW: https://github.com/LekKit/RVVM
---
emulators/Makefile | 1 +
emulators/rvvm/Makefile | 79 +++++++++++++++++++++++++++++++++++++
emulators/rvvm/distinfo | 9 +++++
emulators/rvvm/files/patch-Makefile | 75 +++++++++++++++++++++++++++++++++++
emulators/rvvm/files/pkg-message.in | 11 ++++++
emulators/rvvm/pkg-descr | 5 +++
emulators/rvvm/pkg-plist | 30 ++++++++++++++
7 files changed, 210 insertions(+)
diff --git a/emulators/Makefile b/emulators/Makefile
index 6e7629939545..e5a377684001 100644
--- a/emulators/Makefile
+++ b/emulators/Makefile
@@ -128,6 +128,7 @@
SUBDIR += riscv-isa-sim
SUBDIR += rpcs3
SUBDIR += rubygem-fission
+ SUBDIR += rvvm
SUBDIR += sameboy
SUBDIR += simh
SUBDIR += simh-hp2100
diff --git a/emulators/rvvm/Makefile b/emulators/rvvm/Makefile
new file mode 100644
index 000000000000..452ca690a17d
--- /dev/null
+++ b/emulators/rvvm/Makefile
@@ -0,0 +1,79 @@
+PORTNAME= RVVM
+DISTVERSIONPREFIX= v
+DISTVERSION= 0.6
+CATEGORIES= emulators
+MASTER_SITES= https://github.com/LekKit/patches-misc/releases/download/rvvm-uboot-2024.7/:fw \
+ https://github.com/LekKit/riscv-tests/releases/download/rvvm-tests/:tests
+DISTFILES= ${FWFILES:.bin=.bin:fw} riscv-tests.tar.gz:tests
+DIST_SUBDIR= rvvm-${DISTVERSION}
+EXTRACT_ONLY= ${DISTFILE_DEFAULT}
+
+MAINTAINER= fuz@FreeBSD.org
+COMMENT= RISC-V Virtual Machine
+
+LICENSE= GPLv2 GPLv3 MPL20
+LICENSE_COMB= multi
+LICENSE_FILE_GPLv3= ${WRKSRC}/LICENSE-GPL
+LICENSE_FILE_MPL20= ${WRKSRC}/LICENSE-MPL
+LICENSE_DISTFILES_GPLv2= ${FWFILES}
+LICENSE_DISTFILES_GPLv3= ${DISTFILE_DEFAULT}
+LICENSE_DISTFILES_MPL20= ${DISTFILE_DEFAULT}
+
+FLAVORS= x11 nox11
+FLAVOR?= ${FLAVORS:[1]}
+nox11_PKGNAMESUFFIX= -nox11
+
+USES= gmake localbase:ldflags
+USE_GITHUB= yes
+GH_ACCOUNT= LekKit
+USE_LDCONFIG= yes
+
+BUILDDIR= ${WRKDIR}/.build
+MAKE_ENV+= BUILDDIR=${BUILDDIR}
+TEST_TARGET= test
+SUB_FILES= pkg-message
+
+OPTIONS_DEFINE= FDT FPU JIT JNI SPINLOCK_DEBUG NET PCI RV64
+OPTIONS_DEFAULT= FDT FPU JIT JNI SPINLOCK_DEBUG NET PCI RV64
+FDT_DESC= enable automatic FDT generation
+FPU_DESC= enable floating point (F/D) CPU extension
+JIT_DESC= enable RVJIT accelerator
+JNI_DESC= include native JNI bindings in shared librvvm
+NET_DESC= enable unprivileged userland networking stack
+PCI_DESC= enable PCI support in ATA, etc devices
+RV64_DESC= enable riscv64 CPU support
+SPINLOCK_DEBUG_DESC= enable deadlock debugging (minimal runtime overhead)
+
+FWFILES= fw_jump.bin fw_payload.bin
+
+.for o in ${OPTIONS_DEFINE}
+$o_MAKE_ENV= USE_$o=1
+$o_MAKE_ENV_OFF= USE_$o=0
+.endfor
+
+.if ${FLAVOR} == x11
+MAKE_ENV+= USE_FB=1 USE_XSHM=1
+USES+= xorg
+USE_XORG+= x11 xext
+.else
+MAKE_ENV+= USE_FB=0 USE_XSHM=0
+.endif
+
+.include <bsd.port.pre.mk>
+
+.if defined(WITH_DEBUG)
+MAKE_ENV+= USE_DEBUG=1
+.endif
+
+post-install:
+ ${STRIP_CMD} ${STAGEDIR}${PREFIX}/bin/rvvm
+ ${STRIP_CMD} ${STAGEDIR}${PREFIX}/lib/librvvm.so
+ ${MKDIR} ${STAGEDIR}${DATADIR}
+.for f in ${FWFILES}
+ ${INSTALL_DATA} ${_DISTDIR}/$f ${STAGEDIR}${DATADIR}/
+.endfor
+
+pre-test:
+ ${LN} -sf ${_DISTDIR}/riscv-tests.tar.gz ${BUILDDIR}/
+
+.include <bsd.port.post.mk>
diff --git a/emulators/rvvm/distinfo b/emulators/rvvm/distinfo
new file mode 100644
index 000000000000..765e15982143
--- /dev/null
+++ b/emulators/rvvm/distinfo
@@ -0,0 +1,9 @@
+TIMESTAMP = 1737591303
+SHA256 (rvvm-0.6/fw_jump.bin) = 60f5aedaf90be271eef9e4f1a479171c183987f97f86208811e9212b121d5b45
+SIZE (rvvm-0.6/fw_jump.bin) = 136776
+SHA256 (rvvm-0.6/fw_payload.bin) = d97321ca71be85a98dcc1757b721616d6ed68304afe853336273cb19b424da6c
+SIZE (rvvm-0.6/fw_payload.bin) = 2958016
+SHA256 (rvvm-0.6/riscv-tests.tar.gz) = f0e888a8db158b1e82ac09cebd01d8e1d5913477d1515c41286fae5e309e5322
+SIZE (rvvm-0.6/riscv-tests.tar.gz) = 87062
+SHA256 (rvvm-0.6/LekKit-RVVM-v0.6_GH0.tar.gz) = 97e98c95d8785438758b81fb5c695b8eafb564502c6af7f52555b056e3bb7d7a
+SIZE (rvvm-0.6/LekKit-RVVM-v0.6_GH0.tar.gz) = 313342
diff --git a/emulators/rvvm/files/patch-Makefile b/emulators/rvvm/files/patch-Makefile
new file mode 100644
index 000000000000..2962262b0bb5
--- /dev/null
+++ b/emulators/rvvm/files/patch-Makefile
@@ -0,0 +1,75 @@
+--- Makefile.orig 2024-03-18 16:11:18 UTC
++++ Makefile
+@@ -33,7 +33,7 @@ BOLD := $(shell tput md $(NULL_STDERR) || tput bo
+ SPACE :=
+ ifneq (,$(TERM))
+ BOLD := $(shell tput md $(NULL_STDERR) || tput bold $(NULL_STDERR) || printf "\033[1m" $(NULL_STDERR))
+-RESET := $(shell tput me $(NULL_STDERR) || tput sgr0 $(NULL_STDERR) || printf "\033[0m" $(NULL_STDERR))$(BOLD)
++RESET := $(shell tput me $(NULL_STDERR) || tput sgr0 $(NULL_STDERR) || printf "\033[0m" $(NULL_STDERR))
+ RED := $(shell tput AF 1 $(NULL_STDERR) || tput setaf 1 $(NULL_STDERR) || printf "\033[31m" $(NULL_STDERR))$(BOLD)
+ GREEN := $(shell tput AF 2 $(NULL_STDERR) || tput setaf 2 $(NULL_STDERR) || printf "\033[32m" $(NULL_STDERR))$(BOLD)
+ YELLOW := $(shell tput AF 3 $(NULL_STDERR) || tput setaf 3 $(NULL_STDERR) || printf "\033[33m" $(NULL_STDERR))$(BOLD)
+@@ -231,8 +231,8 @@ endif
+
+ # Warning options (Strict safety/portability, stack/object size limits)
+ # -Wbad-function-cast, -Wcast-align, -Wdouble-promotion need fixes in codebase
+-WARN_OPTS := -Wall -Wextra -Wshadow -Wvla -Wpointer-arith -Walloca -Wduplicated-cond \
+--Wtrampolines -Wlarger-than=1048576 -Wframe-larger-than=32768 -Werror=return-type
++WARN_OPTS := -Wall -Wextra -Wshadow -Wvla -Wpointer-arith -Walloca \
++-Wlarger-than=1048576 -Wframe-larger-than=32768 -Werror=return-type
+
+ # Compiler-specific options
+ ifeq ($(CC_TYPE),gcc)
+@@ -467,13 +467,11 @@ endif
+ endif
+
+ # Do not pass lib-related flags for dev/cli/test builds (Faster)
+-ifneq (,$(findstring lib, $(MAKECMDGOALS))$(findstring install, $(MAKECMDGOALS)))
+ override CFLAGS += -DUSE_LIB -fPIC -ffat-lto-objects
+ # Build JNI bindings inside librvvm dynlib
+ ifeq ($(USE_JNI),1)
+ SRC += $(SRCDIR)/bindings/jni/rvvm_jni.c
+ endif
+-endif
+
+ # CPU interpreter sources
+ SRC += $(wildcard $(SRCDIR)/cpu/riscv_*.c)
+@@ -583,10 +581,10 @@ test: $(BINARY)
+ @echo
+ @echo "[$(YELLOW)INFO$(RESET)] Running RISC-V Tests (RV32)"
+ @echo
+- @for file in $(BUILDDIR)/riscv-tests/rv32*.bin; do \
++ @for file in $(BUILDDIR)/riscv-tests/rv32*; do \
+ result=$$($(BINARY) $$file -nogui -rv32 | tr -d '\0'); \
+ result="$${result##* }"; \
+- if [[ "$$result" == "0" ]]; then \
++ if [ "$$result" -eq "0" ]; then \
+ echo "[$(GREEN)PASS$(RESET)] $$file"; \
+ else \
+ echo "[$(RED)FAIL: $$result$(RESET)] $$file"; \
+@@ -596,10 +594,10 @@ ifeq ($(USE_RV64),1)
+ @echo
+ @echo "[$(YELLOW)INFO$(RESET)] Running RISC-V Tests (RV64)"
+ @echo
+- @for file in $(BUILDDIR)/riscv-tests/rv64*.bin; do \
++ @for file in $(BUILDDIR)/riscv-tests/rv64*; do \
+ result=$$($(BINARY) $$file -nogui -rv64 | tr -d '\0'); \
+ result="$${result##* }"; \
+- if [[ "$$result" == "0" ]]; then \
++ if [ "$$result" -eq "0" ]; then \
+ echo "[$(GREEN)PASS$(RESET)] $$file"; \
+ else \
+ echo "[$(RED)FAIL: $$result$(RESET)] $$file"; \
+@@ -647,11 +645,10 @@ ifeq ($(HOST_POSIX),1)
+ @install -Dm755 $(BINARY) $(DESTDIR)$(bindir)/rvvm
+ @install -Dm755 $(SHARED) $(DESTDIR)$(libdir)/librvvm$(LIB_EXT)
+ @install -Dm644 $(STATIC) $(DESTDIR)$(libdir)/librvvm_static.a
++ @install -d $(DESTDIR)$(includedir)/rvvm
+ @install -Dm644 $(SRCDIR)/rvvmlib.h $(DESTDIR)$(includedir)/rvvm/rvvmlib.h
+ @install -Dm644 $(SRCDIR)/fdtlib.h $(DESTDIR)$(includedir)/rvvm/fdtlib.h
+ @install -Dm644 $(SRCDIR)/devices/*.h $(DESTDIR)$(includedir)/rvvm/
+- @install -d $(DESTDIR)$(datadir)/licenses/rvvm/
+- @install -Dm644 LICENSE* $(DESTDIR)$(datadir)/licenses/rvvm/
+ else
+ @echo "[$(RED)WARN$(RESET)] Unsupported on non-POSIX!"
+ endif
diff --git a/emulators/rvvm/files/pkg-message.in b/emulators/rvvm/files/pkg-message.in
new file mode 100644
index 000000000000..114244484781
--- /dev/null
+++ b/emulators/rvvm/files/pkg-message.in
@@ -0,0 +1,11 @@
+RVVM has been installed.
+
+To execute a disk image, run
+
+ rvvm %%DATADIR%%/fw_payload.bin [flags] -i $disk.img
+
+To execute a custom kernel payload, run
+
+ rvvm %%DATADIR%%/fw_jump.bin [flags] -k $kernel.bin
+
+For further details, execute rvvm --help.
diff --git a/emulators/rvvm/pkg-descr b/emulators/rvvm/pkg-descr
new file mode 100644
index 000000000000..735272afc3e3
--- /dev/null
+++ b/emulators/rvvm/pkg-descr
@@ -0,0 +1,5 @@
+RVVM is a virtual machine / emulator for RISC-V guests, which emphasizes
+on performance, security, lean code and portability. It already runs a
+lot of guest operating systems, including Linux, Haiku, FreeBSD,
+OpenBSD, etc. It also aims to run RISC-V applications on a foreign-arch
+host without full OS guest & isolation (Userland emulation).
diff --git a/emulators/rvvm/pkg-plist b/emulators/rvvm/pkg-plist
new file mode 100644
index 000000000000..a7c8a02ef60c
--- /dev/null
+++ b/emulators/rvvm/pkg-plist
@@ -0,0 +1,30 @@
+bin/rvvm
+include/rvvm/ata.h
+include/rvvm/chardev.h
+include/rvvm/clint.h
+include/rvvm/eth-oc.h
+include/rvvm/fb_window.h
+include/rvvm/fdtlib.h
+include/rvvm/framebuffer.h
+include/rvvm/gpio-sifive.h
+include/rvvm/gpio_api.h
+include/rvvm/hid_api.h
+include/rvvm/hid_dev.h
+include/rvvm/i2c-hid.h
+include/rvvm/i2c-oc.h
+include/rvvm/mtd-physmap.h
+include/rvvm/ns16550a.h
+include/rvvm/nvme.h
+include/rvvm/pci-bus.h
+include/rvvm/plic.h
+include/rvvm/ps2-altera.h
+include/rvvm/rtc-ds1742.h
+include/rvvm/rtc-goldfish.h
+include/rvvm/rtl8169.h
+include/rvvm/rvvmlib.h
+include/rvvm/syscon.h
+include/rvvm/tap_api.h
+lib/librvvm.so
+lib/librvvm_static.a
+%%DATADIR%%/fw_jump.bin
+%%DATADIR%%/fw_payload.bin