From ec9391eba24c2ec0b930c4ac611c414d0a92f7e3 Mon Sep 17 00:00:00 2001 From: Alex Bradbury Date: Tue, 15 Oct 2024 15:12:42 +0100 Subject: [PATCH 1/6] Add ability to use a CMake toolchains file for specifying details of the stage1 CC/CXX This allows us to follow best/usual CMake practice for configuring cross compiling. --- zorg/buildbot/builders/ClangBuilder.py | 40 ++++++++++++++++++++++---- 1 file changed, 35 insertions(+), 5 deletions(-) diff --git a/zorg/buildbot/builders/ClangBuilder.py b/zorg/buildbot/builders/ClangBuilder.py index 001d824a3..33f36ee17 100644 --- a/zorg/buildbot/builders/ClangBuilder.py +++ b/zorg/buildbot/builders/ClangBuilder.py @@ -162,6 +162,10 @@ def getClangCMakeBuildFactory( # CMake arguments to use for stage2 instead of extra_cmake_args. extra_stage2_cmake_args=None, + # If set, use a toolchains file for the stage 2 build and add + # these options to it. + stage2_toolchain_options=None, + # Extra repositories checkout_clang_tools_extra=True, checkout_compiler_rt=True, @@ -180,6 +184,7 @@ def getClangCMakeBuildFactory( submitURL=submitURL, testerName=testerName, env=env, extra_cmake_args=extra_cmake_args, extra_stage2_cmake_args=extra_stage2_cmake_args, + stage2_toolchain_options=stage2_toolchain_options, checkout_clang_tools_extra=checkout_clang_tools_extra, checkout_lld=checkout_lld, checkout_compiler_rt=checkout_compiler_rt, @@ -219,6 +224,10 @@ def _getClangCMakeBuildFactory( # CMake arguments to use for stage2 instead of extra_cmake_args. extra_stage2_cmake_args=None, + # If set, use a toolchains file for the stage 2 build and add + # these options to it. + stage2_toolchain_options=None, + # Extra repositories checkout_clang_tools_extra=True, checkout_compiler_rt=True, @@ -427,9 +436,31 @@ def _getClangCMakeBuildFactory( # Note: Backslash path separators do not work well with cmake and ninja. # Forward slash path separator works on Windows as well. stage1_cc = InterpolateToPosixPath( - f"-DCMAKE_C_COMPILER=%(prop:builddir)s/{stage1_install}/bin/{cc}") + f"%(prop:builddir)s/{stage1_install}/bin/{cc}") stage1_cxx = InterpolateToPosixPath( - f"-DCMAKE_CXX_COMPILER=%(prop:builddir)s/{stage1_install}/bin/{cxx}") + f"%(prop:builddir)s/{stage1_install}/bin/{cxx}") + + # If stage2_toolchain_options is set when we'll use a toolchain file + # to specify the compiler being used (the just-built stage1) and add + # any stage2_toolchain_options to it. Otherwise, just set + # -DCMAKE_{C,CXX}_COMPILER. + if stage2_toolchain_options is None: + compiler_args = [ + f"-DCMAKE_C_COMPILER={stage1_cc}", + f"-DCMAKE_CXX_COMPILER={stage1_cxx}" + ] + else: + toolchain_file = InterpolateToPosixPath( + f"%(prop:builddir)s/{stage2_build}/stage1-toolchain.cmake") + with open(toolchain_file, 'w') as file: + file.write(f"set(CMAKE_C_COMPILER {stage1_cc})\n") + file.write(f"set(CMAKE_CXX_COMPILER {stage1_cxx})\n") + for option in stage2_toolchain_options: + file.write(f"{option}\n") + + compiler_args = [ + "-DCMAKE_TOOLCHAIN_FILE={toolchain_file}" + ] # If we have a separate stage2 cmake arg list, then ensure we re-apply # enable_projects and enable_runtimes if necessary. @@ -445,13 +476,12 @@ def _getClangCMakeBuildFactory( rel_src_dir = LLVMBuildFactory.pathRelativeTo(f.llvm_srcdir, stage2_build) cmake_cmd2 = [cmake, "-G", "Ninja", rel_src_dir, - stage1_cc, - stage1_cxx, f"-DCMAKE_BUILD_TYPE={stage2_config}", "-DLLVM_ENABLE_ASSERTIONS=True", f"-DLLVM_LIT_ARGS={lit_args}", f"-DCMAKE_INSTALL_PREFIX=../{stage2_install}" - ] + (extra_stage2_cmake_args or extra_cmake_args) + ] + (extra_stage2_cmake_args or extra_cmake_args) \ + + compiler_args f.addStep(ShellCommand(name='cmake stage 2', command=cmake_cmd2, From 6f37f5b2f3ee60f4169c6a5a28108ead630884ad Mon Sep 17 00:00:00 2001 From: Alex Bradbury Date: Tue, 15 Oct 2024 15:40:55 +0100 Subject: [PATCH 2/6] [RISCV] Move clang-riscv-rva20-2stage to cross-build and then test under qemu-system --- buildbot/osuosl/master/config/builders.py | 25 +++++++++++++++++++---- 1 file changed, 21 insertions(+), 4 deletions(-) diff --git a/buildbot/osuosl/master/config/builders.py b/buildbot/osuosl/master/config/builders.py index 2f1180f4d..c91db975f 100644 --- a/buildbot/osuosl/master/config/builders.py +++ b/buildbot/osuosl/master/config/builders.py @@ -3151,7 +3151,9 @@ 'CXX': 'clang++', })}, - ## RISC-V RVA20 profile check-all 2-stage + ## RISC-V RVA20 profile check-all 2-stage. The second stage is + # cross-compiled on the x86 host and then lit runs under a qemu-system image + # using the just-build artifacts. {'name' : "clang-riscv-rva20-2stage", 'tags' : ["clang"], 'workernames' : ["rise-clang-riscv-rva20-2stage"], @@ -3161,6 +3163,7 @@ useTwoStage=True, runTestSuite=False, testStage1=False, + checkout_compiler_rt=False, extra_cmake_args=[ "-DCMAKE_C_COMPILER=clang", "-DCMAKE_CXX_COMPILER=clang++", @@ -3169,9 +3172,23 @@ "-DCMAKE_C_COMPILER_LAUNCHER=ccache", "-DCMAKE_CXX_COMPILER_LAUNCHER=ccache"], extra_stage2_cmake_args=[ - "-DLLVM_ENABLE_LLD=True", - "-DCMAKE_C_FLAGS='-march=rva20u64'", - "-DCMAKE_CXX_FLAGS='-march=rva20u64'"] + util.Interpolate(f"-DLLVM_NATIVE_TOOL_DIR=%(prop:builddir)s/stage1.install/bin"), + "-DLLVM_BUILD_TESTS=True", + "-DLLVM_EXTERNAL_LIT=/home/buildbot-worker/lit-on-qemu-system-rva20.py", + ], + stage2_toolchain_options=[ + "set(CMAKE_SYSTEM_NAME Linux)", + "set(CMAKE_SYSROOT /home/buildbot-worker/rvsysroot)", + "set(CMAKE_C_COMPILER_TARGET riscv64-linux-gnu)", + "set(CMAKE_CXX_COMPILER_TARGET riscv64-linux-gnu)", + "set(CMAKE_C_FLAGS_INIT '-march=rva20u64')", + "set(CMAKE_CXX_FLAGS_INIT '-march=rva20u64')", + "set(CMAKE_LINKER_TYPE LLD)", + "set(CMAKE_FIND_ROOT_PATH_MODE_PROGRAM NEVER)", + "set(CMAKE_FIND_ROOT_PATH_MODE_LIBRARY ONLY)", + "set(CMAKE_FIND_ROOT_PATH_MODE_INCLUDE ONLY)", + "set(CMAKE_FIND_ROOT_PATH_MODE_PACKAGE ONLY)", + ] )}, ## RISC-V RVA23 profile check-all 2-stage From 03f14e6897e6cd4e521031293e4f682fa30376d9 Mon Sep 17 00:00:00 2001 From: Alex Bradbury Date: Tue, 12 Nov 2024 21:53:18 +0000 Subject: [PATCH 3/6] Use StringDownload to transfer toolchains file and fix issues related to interpolation --- buildbot/osuosl/master/config/builders.py | 2 +- zorg/buildbot/builders/ClangBuilder.py | 29 ++++++++++------------- 2 files changed, 14 insertions(+), 17 deletions(-) diff --git a/buildbot/osuosl/master/config/builders.py b/buildbot/osuosl/master/config/builders.py index c91db975f..ef5c4e7e8 100644 --- a/buildbot/osuosl/master/config/builders.py +++ b/buildbot/osuosl/master/config/builders.py @@ -3153,7 +3153,7 @@ ## RISC-V RVA20 profile check-all 2-stage. The second stage is # cross-compiled on the x86 host and then lit runs under a qemu-system image - # using the just-build artifacts. + # using the just-built artifacts. {'name' : "clang-riscv-rva20-2stage", 'tags' : ["clang"], 'workernames' : ["rise-clang-riscv-rva20-2stage"], diff --git a/zorg/buildbot/builders/ClangBuilder.py b/zorg/buildbot/builders/ClangBuilder.py index 33f36ee17..4b6d5c91f 100644 --- a/zorg/buildbot/builders/ClangBuilder.py +++ b/zorg/buildbot/builders/ClangBuilder.py @@ -4,6 +4,7 @@ from buildbot.plugins import util from buildbot.steps.shell import ShellCommand, SetProperty from buildbot.steps.shell import WarningCountingShellCommand +from buildbot.steps.transfer import StringDownload import zorg.buildbot.builders.Util as builders_util @@ -435,10 +436,8 @@ def _getClangCMakeBuildFactory( # Absolute paths to just built compilers. # Note: Backslash path separators do not work well with cmake and ninja. # Forward slash path separator works on Windows as well. - stage1_cc = InterpolateToPosixPath( - f"%(prop:builddir)s/{stage1_install}/bin/{cc}") - stage1_cxx = InterpolateToPosixPath( - f"%(prop:builddir)s/{stage1_install}/bin/{cxx}") + stage1_cc = f"%(prop:builddir)s/{stage1_install}/bin/{cc}" + stage1_cxx = f"%(prop:builddir)s/{stage1_install}/bin/{cxx}" # If stage2_toolchain_options is set when we'll use a toolchain file # to specify the compiler being used (the just-built stage1) and add @@ -446,21 +445,19 @@ def _getClangCMakeBuildFactory( # -DCMAKE_{C,CXX}_COMPILER. if stage2_toolchain_options is None: compiler_args = [ - f"-DCMAKE_C_COMPILER={stage1_cc}", - f"-DCMAKE_CXX_COMPILER={stage1_cxx}" + InterpolateToPosixPath(f"-DCMAKE_C_COMPILER={stage1_cc}"), + InterpolateToPosixPath(f"-DCMAKE_CXX_COMPILER={stage1_cxx}"), ] else: - toolchain_file = InterpolateToPosixPath( - f"%(prop:builddir)s/{stage2_build}/stage1-toolchain.cmake") - with open(toolchain_file, 'w') as file: - file.write(f"set(CMAKE_C_COMPILER {stage1_cc})\n") - file.write(f"set(CMAKE_CXX_COMPILER {stage1_cxx})\n") - for option in stage2_toolchain_options: - file.write(f"{option}\n") + toolchain_file = f"%(prop:builddir)s/{stage2_build}/stage1-toolchain.cmake" + toolchain_file_contents = "\n".join([ + f"set(CMAKE_C_COMPILER {stage1_cc})", + f"set(CMAKE_CXX_COMPILER {stage1_cxx})", + ] + stage2_toolchain_options) + f.addStep(StringDownload(util.Interpolate(toolchain_file_contents), + workerdest=InterpolateToPosixPath(toolchain_file))) + compiler_args = [InterpolateToPosixPath(f"-DCMAKE_TOOLCHAIN_FILE={toolchain_file}")] - compiler_args = [ - "-DCMAKE_TOOLCHAIN_FILE={toolchain_file}" - ] # If we have a separate stage2 cmake arg list, then ensure we re-apply # enable_projects and enable_runtimes if necessary. From 7571d3518963c74e2a5d4a4776b1825998639451 Mon Sep 17 00:00:00 2001 From: Alex Bradbury Date: Mon, 9 Dec 2024 11:26:04 +0000 Subject: [PATCH 4/6] Add scripts used for RISE RISC-V builders and use them --- buildbot/osuosl/master/config/builders.py | 18 ++- .../create-sid-riscv-appliance-image.sh | 85 ++++++++++++ buildbot/riscv-rise/lit-on-qemu | 128 ++++++++++++++++++ zorg/buildbot/builders/ClangBuilder.py | 9 ++ 4 files changed, 233 insertions(+), 7 deletions(-) create mode 100755 buildbot/riscv-rise/create-sid-riscv-appliance-image.sh create mode 100755 buildbot/riscv-rise/lit-on-qemu diff --git a/buildbot/osuosl/master/config/builders.py b/buildbot/osuosl/master/config/builders.py index ef5c4e7e8..5b466a309 100644 --- a/buildbot/osuosl/master/config/builders.py +++ b/buildbot/osuosl/master/config/builders.py @@ -3159,11 +3159,12 @@ 'workernames' : ["rise-clang-riscv-rva20-2stage"], 'builddir':"clang-riscv-rva20-2stage", 'factory' : ClangBuilder.getClangCMakeBuildFactory( - clean=False, + clean=True, useTwoStage=True, runTestSuite=False, testStage1=False, checkout_compiler_rt=False, + checkout_zorg=True, extra_cmake_args=[ "-DCMAKE_C_COMPILER=clang", "-DCMAKE_CXX_COMPILER=clang++", @@ -3172,13 +3173,12 @@ "-DCMAKE_C_COMPILER_LAUNCHER=ccache", "-DCMAKE_CXX_COMPILER_LAUNCHER=ccache"], extra_stage2_cmake_args=[ - util.Interpolate(f"-DLLVM_NATIVE_TOOL_DIR=%(prop:builddir)s/stage1.install/bin"), + util.Interpolate("-DLLVM_NATIVE_TOOL_DIR=%(prop:builddir)s/stage1.install/bin"), "-DLLVM_BUILD_TESTS=True", - "-DLLVM_EXTERNAL_LIT=/home/buildbot-worker/lit-on-qemu-system-rva20.py", - ], + util.Interpolate("-DLLVM_EXTERNAL_LIT=%(prop:builddir)s/llvm-zorg/buildbot/riscv-rise/lit-on-qemu")], stage2_toolchain_options=[ "set(CMAKE_SYSTEM_NAME Linux)", - "set(CMAKE_SYSROOT /home/buildbot-worker/rvsysroot)", + util.Interpolate("set(CMAKE_SYSROOT %(prop:builddir)s/../rvsysroot)"), "set(CMAKE_C_COMPILER_TARGET riscv64-linux-gnu)", "set(CMAKE_CXX_COMPILER_TARGET riscv64-linux-gnu)", "set(CMAKE_C_FLAGS_INIT '-march=rva20u64')", @@ -3187,8 +3187,12 @@ "set(CMAKE_FIND_ROOT_PATH_MODE_PROGRAM NEVER)", "set(CMAKE_FIND_ROOT_PATH_MODE_LIBRARY ONLY)", "set(CMAKE_FIND_ROOT_PATH_MODE_INCLUDE ONLY)", - "set(CMAKE_FIND_ROOT_PATH_MODE_PACKAGE ONLY)", - ] + "set(CMAKE_FIND_ROOT_PATH_MODE_PACKAGE ONLY)"], + env={ + "BB_IMG_DIR": util.Interpolate("%(prop:builddir)s/.."), + "BB_QEMU_CPU": "rv64,zfa=false,zba=false,zbb=false,zbc=false,zbs=false", + "BB_QEMU_SMP": 32, + "BB_QEMU_MEM": "64G"} )}, ## RISC-V RVA23 profile check-all 2-stage diff --git a/buildbot/riscv-rise/create-sid-riscv-appliance-image.sh b/buildbot/riscv-rise/create-sid-riscv-appliance-image.sh new file mode 100755 index 000000000..f35504f89 --- /dev/null +++ b/buildbot/riscv-rise/create-sid-riscv-appliance-image.sh @@ -0,0 +1,85 @@ +#!/bin/sh +#===----------------------------------------------------------------------===// +# +# Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. +# See https://llvm.org/LICENSE.txt for license information. +# SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception +# +#===----------------------------------------------------------------------===// + +TGT=riscv-sid-for-qemu +# Uses +~/rootless-debootstrap-wrapper \ + --arch=riscv64 \ + --suite=sid \ + --cache-dir="$HOME/debcache" \ + --target-dir=$TGT \ + --include=linux-image-riscv64,zstd,dbus,adduser,python3,python3-psutil,git +cat - < $TGT/etc/resolv.conf +nameserver 1.1.1.1 +EOF +"$TGT/_enter" sh -e <<'EOF' +ln -sf /dev/null /etc/udev/rules.d/80-net-setup-link.rules # disable persistent network names +cat - < /etc/systemd/network/10-eth0.network +[Match] +Name=eth0 + +[Network] +DHCP=yes +INNER_EOF +systemctl enable systemd-networkd +echo root:root | chpasswd +adduser --gecos ",,," --disabled-password user +echo user:user | chpasswd +ln -sf /dev/null /etc/systemd/system/serial-getty@hvc0.service +ln -sf /dev/null /etc/systemd/system/serial-getty@ttyS0.service + +cat - <<'INNER_EOF' > /opt/on-boot-logic.sh +#!/bin/sh +error() { + printf "!!!!!!!!!! Error: %s !!!!!!!!!!\n" "$*" >&2 + exit 1 +} + +mkdir -p /mnt/hgcomm +mount -t 9p -o trans=virtio,version=9p2000.L hgcomm /mnt/hgcomm || error "Failed to mount hgcomm" +if [ -e /mnt/hgcomm/debug-mode-on ]; then + echo "debug-mode-on file present: Not executing exec-on-boot and instead starting getty" + systemctl unmask serial-getty@ttyS0.service + systemctl start serial-getty@ttyS0.service + systemctl mask serial-getty@ttyS0.service + exit 0 +fi +[ -f /mnt/hgcomm/exec-on-boot ] || error "exec-on-boot doesn't exist" +[ -x /mnt/hgcomm/exec-on-boot ] || error "exec-on-boot isn't executable" +/mnt/hgcomm/exec-on-boot +echo "$?" > /mnt/hgcomm/exec-on-boot.exitcode +poweroff +INNER_EOF +chmod +x /opt/on-boot-logic.sh + +cat - <<'INNER_EOF' > /etc/systemd/system/appliance.service +[Unit] +Description=Execute on boot logic +After=multi-user.target + +[Service] +Type=oneshot +StandardOutput=tty +TTYPath=/dev/ttyS0 +ExecStart=/opt/on-boot-logic.sh +ExecStopPost=/bin/sh -c '[ "$EXIT_STATUS" != 0 ] && poweroff' + +[Install] +WantedBy=multi-user.target +INNER_EOF +systemctl enable appliance.service +echo "Finished rootfs config" +EOF + +fakeroot -i $TGT/.fakeroot.env sh <&2 + exit 1 +}} +[ -e "{base_mount_path}" ] && error "Can't mount path, already exists" +mkdir -p "{base_mount_path}" || error "Can't make mount path" +chown {target_uid}:{target_gid} "{base_mount_path}" || error "Chown failed" +mount -t ext4 /dev/vdb "{base_mount_path}" || error "Mount failed" +cd "{current_path}" +su user -c "./bin/llvm-lit {args_string}" +""" +exec_on_boot_path = hgcomm_path / "exec-on-boot" +exec_on_boot_path.write_text(exec_on_boot_content) +exec_on_boot_path.chmod(0o755) + +# Create ext4 filesystem containing the LLVM build directory and LLVM source +# tree. Two layouts are supported: +# 1) A typical layout used in local development, with build directories within +# build/ in the monorepo checkout. +# 2) The layout used by ClangBuilder.py in CI, with build directories as +# siblings to the monorepo checkout (named 'llvm'). +print("@@@@@@@@@@ Creating ext4 filesystem with LLVM build directory @@@@@@@@") +subprocess.run(["fallocate", "-l", "15GiB", "llvm-project.img"], check=True) + +if (current_path.parent.parent / ".git").is_directory(): + print("Note: 'Local dev' layout detected (build/build_dir nested in LLVM checkout)") + extra_tar_args = [ + f"--exclude=build/{p.name} " + for p in current_path.parent.iterdir() + if p.is_dir() and p.name != build_dir_name + ] + extra_tar_args.append("--exclude=.git") + extra_tar_args.append(f"--exclude=build/{build_dir_name}/llvm-project.img") + paths_to_tar = "." +elif (current_path.parent / "llvm" / ".git").is_directory(): + # Case 2) above - CI layout. + print("Note: 'CI style' layout detected (llvm checkout and build_dir as siblings)") + extra_tar_args.append("--exclude=llvm/.git") + extra_tar_args.append(f"--exclude={build_dir_name}/llvm-project.img") + paths_to_tar = f"llvm {build_dir_name}" +else: + error("Unrecognized repo/build layout") + +parent_dir = current_path.parent +tar_command = ( + f"tar --create --file=- --owner={target_uid} --group={target_gid} " + f"{' '.join(extra_tar_args)} " + f"-C ../../ {paths_to_tar} | mkfs.ext4 -d - llvm-project.img" +) +subprocess.run(tar_command, shell=True, check=True) + +# Launch qemu-system appliance +print("@@@@@@@@@@ Pivoting execution to qemu-system @@@@@@@@") +# fmt: off +qemu_command = [ + "qemu-system-riscv64", + "-machine", "virt", + "-cpu", os.getenv("BB_QEMU_CPU"), + "-smp", os.getenv("BB_QEMU_SMP"), + "-m", os.getenv("BB_QEMU_MEM"), + "-device", "virtio-blk-device,drive=hd", + "-drive", f"file={os.getenv('BB_IMG_DIR')}/rootfs.img,if=none,id=hd,format=raw", + "-virtfs", "local,path=hgcomm,mount_tag=hgcomm,security_model=none,id=hgcomm", + "-device", "virtio-blk-device,drive=hdb", + "-drive", "file=llvm-project.img,format=raw,if=none,id=hdb", + "-device", "virtio-net-device,netdev=net", + "-netdev", "user,id=net,hostfwd=tcp:127.0.0.1:10222-:22", + "-bios", "/usr/share/qemu/opensbi-riscv64-generic-fw_dynamic.bin", + "-kernel", f"{os.getenv('BB_IMG_DIR')}/kernel", + "-initrd", f"{os.getenv('BB_IMG_DIR')}/initrd", + "-object", "rng-random,filename=/dev/urandom,id=rng", + "-device", "virtio-rng-device,rng=rng", + "-nographic", + "-append", "rw quiet root=/dev/vda console=ttyS0", +] +# fmt: on +subprocess.run(qemu_command, check=True) +print("@@@@@@@@@@ qemu-system execution finished @@@@@@@@") + +exit_code_file = hgcomm_path / "exec-on-boot.exitcode" +if exit_code_file.is_file(): + sys.exit(int(exit_code_file.read_text().strip())) +else: + sys.exit(111) diff --git a/zorg/buildbot/builders/ClangBuilder.py b/zorg/buildbot/builders/ClangBuilder.py index 4b6d5c91f..fab752815 100644 --- a/zorg/buildbot/builders/ClangBuilder.py +++ b/zorg/buildbot/builders/ClangBuilder.py @@ -174,6 +174,7 @@ def getClangCMakeBuildFactory( checkout_libcxx=False, checkout_flang=False, checkout_test_suite=False, + checkout_zorg=False, enable_runtimes="auto"): return _getClangCMakeBuildFactory( @@ -192,6 +193,7 @@ def getClangCMakeBuildFactory( checkout_libcxx=checkout_libcxx, checkout_flang=checkout_flang, checkout_test_suite=checkout_test_suite, + checkout_zorg=checkout_zorg, enable_runtimes=enable_runtimes) def _getClangCMakeBuildFactory( @@ -236,6 +238,7 @@ def _getClangCMakeBuildFactory( checkout_libcxx=False, checkout_test_suite=False, checkout_flang=False, + checkout_zorg=False, enable_runtimes="auto", @@ -303,6 +306,12 @@ def _getClangCMakeBuildFactory( src_dir='test/test-suite', alwaysUseLatest=True) + if checkout_zorg: + f.addGetSourcecodeForProject( + project='zorg', + src_dir='llvm-zorg', + alwaysUseLatest=True) + # Then get the LLVM source code revision this particular build is for. f.addGetSourcecodeSteps() From 4a7fce4a3ca707b3f44f752be6fd7fafba0262b7 Mon Sep 17 00:00:00 2001 From: Alex Bradbury Date: Wed, 11 Dec 2024 09:57:11 +0000 Subject: [PATCH 5/6] Fixups --- buildbot/osuosl/master/config/builders.py | 4 ++-- buildbot/riscv-rise/lit-on-qemu | 17 ++++++++++------- zorg/buildbot/builders/ClangBuilder.py | 5 +++-- 3 files changed, 15 insertions(+), 11 deletions(-) diff --git a/buildbot/osuosl/master/config/builders.py b/buildbot/osuosl/master/config/builders.py index 0521921fe..ed32f992d 100644 --- a/buildbot/osuosl/master/config/builders.py +++ b/buildbot/osuosl/master/config/builders.py @@ -3271,7 +3271,7 @@ util.Interpolate("-DLLVM_EXTERNAL_LIT=%(prop:builddir)s/llvm-zorg/buildbot/riscv-rise/lit-on-qemu")], stage2_toolchain_options=[ "set(CMAKE_SYSTEM_NAME Linux)", - util.Interpolate("set(CMAKE_SYSROOT %(prop:builddir)s/../rvsysroot)"), + "set(CMAKE_SYSROOT %(prop:builddir)s/../rvsysroot)", "set(CMAKE_C_COMPILER_TARGET riscv64-linux-gnu)", "set(CMAKE_CXX_COMPILER_TARGET riscv64-linux-gnu)", "set(CMAKE_C_FLAGS_INIT '-march=rva20u64')", @@ -3284,7 +3284,7 @@ env={ "BB_IMG_DIR": util.Interpolate("%(prop:builddir)s/.."), "BB_QEMU_CPU": "rv64,zfa=false,zba=false,zbb=false,zbc=false,zbs=false", - "BB_QEMU_SMP": 32, + "BB_QEMU_SMP": "32", "BB_QEMU_MEM": "64G"} )}, diff --git a/buildbot/riscv-rise/lit-on-qemu b/buildbot/riscv-rise/lit-on-qemu index 124436843..0b7620009 100755 --- a/buildbot/riscv-rise/lit-on-qemu +++ b/buildbot/riscv-rise/lit-on-qemu @@ -64,9 +64,9 @@ exec_on_boot_path.chmod(0o755) # 2) The layout used by ClangBuilder.py in CI, with build directories as # siblings to the monorepo checkout (named 'llvm'). print("@@@@@@@@@@ Creating ext4 filesystem with LLVM build directory @@@@@@@@") -subprocess.run(["fallocate", "-l", "15GiB", "llvm-project.img"], check=True) +subprocess.run(["fallocate", "-l", "25GiB", "llvm-project.img"], check=True) -if (current_path.parent.parent / ".git").is_directory(): +if (current_path.parent.parent / ".git").is_dir(): print("Note: 'Local dev' layout detected (build/build_dir nested in LLVM checkout)") extra_tar_args = [ f"--exclude=build/{p.name} " @@ -76,12 +76,15 @@ if (current_path.parent.parent / ".git").is_directory(): extra_tar_args.append("--exclude=.git") extra_tar_args.append(f"--exclude=build/{build_dir_name}/llvm-project.img") paths_to_tar = "." -elif (current_path.parent / "llvm" / ".git").is_directory(): - # Case 2) above - CI layout. + change_to_dir = "../.." +elif (current_path.parent / "llvm" / ".git").is_dir(): print("Note: 'CI style' layout detected (llvm checkout and build_dir as siblings)") - extra_tar_args.append("--exclude=llvm/.git") - extra_tar_args.append(f"--exclude={build_dir_name}/llvm-project.img") + extra_tar_args = [ + "--exclude=llvm/.git", + f"--exclude={build_dir_name}/llvm-project.img" + ] paths_to_tar = f"llvm {build_dir_name}" + change_to_dir = ".." else: error("Unrecognized repo/build layout") @@ -89,7 +92,7 @@ parent_dir = current_path.parent tar_command = ( f"tar --create --file=- --owner={target_uid} --group={target_gid} " f"{' '.join(extra_tar_args)} " - f"-C ../../ {paths_to_tar} | mkfs.ext4 -d - llvm-project.img" + f"-C {change_to_dir} {paths_to_tar} | mkfs.ext4 -d - llvm-project.img" ) subprocess.run(tar_command, shell=True, check=True) diff --git a/zorg/buildbot/builders/ClangBuilder.py b/zorg/buildbot/builders/ClangBuilder.py index 5439586b9..fe6a62c25 100644 --- a/zorg/buildbot/builders/ClangBuilder.py +++ b/zorg/buildbot/builders/ClangBuilder.py @@ -311,7 +311,8 @@ def _getClangCMakeBuildFactory( f.addGetSourcecodeForProject( project='zorg', src_dir='llvm-zorg', - alwaysUseLatest=True) + alwaysUseLatest=True, + repourl="https://github.com/asb/llvm-zorg.git") # Then get the LLVM source code revision this particular build is for. f.addGetSourcecodeSteps() @@ -449,7 +450,7 @@ def _getClangCMakeBuildFactory( stage1_cc = f"%(prop:builddir)s/{stage1_install}/bin/{cc}" stage1_cxx = f"%(prop:builddir)s/{stage1_install}/bin/{cxx}" - # If stage2_toolchain_options is set when we'll use a toolchain file + # If stage2_toolchain_options is set then we'll use a toolchain file # to specify the compiler being used (the just-built stage1) and add # any stage2_toolchain_options to it. Otherwise, just set # -DCMAKE_{C,CXX}_COMPILER. From be98c963475cc30e3fac76a6a4c87640d6fea7b2 Mon Sep 17 00:00:00 2001 From: Alex Bradbury Date: Wed, 11 Dec 2024 13:40:53 +0000 Subject: [PATCH 6/6] Don't use llvm-zorg fork (holdover from testing) --- zorg/buildbot/builders/ClangBuilder.py | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/zorg/buildbot/builders/ClangBuilder.py b/zorg/buildbot/builders/ClangBuilder.py index fe6a62c25..9d261011b 100644 --- a/zorg/buildbot/builders/ClangBuilder.py +++ b/zorg/buildbot/builders/ClangBuilder.py @@ -311,8 +311,7 @@ def _getClangCMakeBuildFactory( f.addGetSourcecodeForProject( project='zorg', src_dir='llvm-zorg', - alwaysUseLatest=True, - repourl="https://github.com/asb/llvm-zorg.git") + alwaysUseLatest=True) # Then get the LLVM source code revision this particular build is for. f.addGetSourcecodeSteps()