Build gem5 through buildroot

Oh, btw, also make it work, since the build was completely broken since
the recent -K refactoring :0)
This commit is contained in:
Ciro Santilli
2018-03-12 03:46:53 +00:00
parent 7b08433840
commit b8413532a5
6 changed files with 45 additions and 31 deletions

15
build
View File

@@ -100,13 +100,13 @@ BR2_JLEVEL=$j
BR2_ROOTFS_POST_SCRIPT_ARGS=\"$post_script_args\" BR2_ROOTFS_POST_SCRIPT_ARGS=\"$post_script_args\"
" >> "${config_file}" " >> "${config_file}"
if "$gem5"; then if "$gem5"; then
printf "BR2_PACKAGE_GEM5=y\n" >> "${config_file}"
if [ -z "$linux_kernel_custom_config_file" ]; then if [ -z "$linux_kernel_custom_config_file" ]; then
printf "BR2_LINUX_KERNEL_CUSTOM_CONFIG_FILE=\"../kernel_config_${arch_dir}\"" >> "${config_file}" printf "BR2_LINUX_KERNEL_CUSTOM_CONFIG_FILE=\"../kernel_config_${arch_dir}\"\n" >> "${config_file}"
fi fi
printf "BR2_PACKAGE_GEM5=\"../kernel_config_${arch_dir}\"" >> "${config_file}"
else else
if [ -z "$linux_kernel_custom_config_file" ]; then if [ -z "$linux_kernel_custom_config_file" ]; then
printf "BR2_LINUX_KERNEL_CONFIG_FRAGMENT_FILES=\"../kernel_config_fragment\"" >> "${config_file}" printf "BR2_LINUX_KERNEL_CONFIG_FRAGMENT_FILES=\"../kernel_config_fragment\"\n" >> "${config_file}"
fi fi
fi fi
if [ "$arch" = 'mips64' ]; then if [ "$arch" = 'mips64' ]; then
@@ -114,11 +114,8 @@ BR2_ROOTFS_POST_SCRIPT_ARGS=\"$post_script_args\"
# http://lists.busybox.net/pipermail/buildroot/2017-August/201053.html # http://lists.busybox.net/pipermail/buildroot/2017-August/201053.html
sed -Ei 's/^BR2_PACKAGE_LINUX_TOOLS_GPIO/BR2_PACKAGE_LINUX_TOOLS_GPIO=n/' "${config_file}" sed -Ei 's/^BR2_PACKAGE_LINUX_TOOLS_GPIO/BR2_PACKAGE_LINUX_TOOLS_GPIO=n/' "${config_file}"
fi fi
# TODO why is this needed. Otherwise kernel .config does not change, even though Buildroot
# .config did due to -K. even if we are running linux-kernel-reconfigure!
rm -f "${out_dir}/build/linux-custom/.config"
if [ -n "$linux_kernel_custom_config_file" ]; then if [ -n "$linux_kernel_custom_config_file" ]; then
printf "BR2_LINUX_KERNEL_CUSTOM_CONFIG_FILE=\"../${linux_kernel_custom_config_file}\"" >> "${config_file}" printf "BR2_LINUX_KERNEL_CUSTOM_CONFIG_FILE=\"../${linux_kernel_custom_config_file}\"\n" >> "${config_file}"
fi fi
make O="$out_dir" olddefconfig make O="$out_dir" olddefconfig
fi fi
@@ -147,7 +144,3 @@ cmd="time \
" "
echo "$cmd" | tee "${root_dir}/build.log" echo "$cmd" | tee "${root_dir}/build.log"
eval "$cmd" eval "$cmd"
if "$gem5"; then
cd "${root_dir}"
./build-gem5 -a "$arch"
fi

2
gem5/.gitignore vendored
View File

@@ -1 +1 @@
/gem5-system /system

10
gem5/README.adoc Normal file
View File

@@ -0,0 +1,10 @@
= gem5
We Build gem5 as a Buildroot package for the following reasons:
* if we build in tree without Buildroot, we still want to build the `m5` tool through Buildroot. But then Buildroot rsyncs the build for all archs into `output/build`, which takes quite some disk space. There seems to be no way to exclude some packages from the sync.
* it allows us to reuse Buildroot's:
** configuration system, which reduces duplication: set the gem5 package option, everything just gets built
** timestamping system, which could save a few seconds on rebuilds, since we then don't ever run `scons` when gem5 is not modified
What is preventing upstreaming to Buildroot: a minimal kernel config like the ones QEMU has.

View File

@@ -1,22 +1,29 @@
#/usr/bin/env bash #/usr/bin/env bash
set -eu set -eu
arch=x86_64 arch=x86_64
while getopts 'a:' OPT; do j=''
while getopts a:j: OPT; do
case "$OPT" in case "$OPT" in
a) a)
arch="$OPTARG" arch="$OPTARG"
;; ;;
j)
j="$OPTARG"
;;
esac esac
done done
shift "$(($OPTIND - 1))" shift "$(($OPTIND - 1))"
top="$(pwd)/gem5" if [ -z "$j" ]; then
system_dir="${top}/gem5-system" j="$(nproc)"
fi
top="$(dirname "$0")"
system_dir="${top}/system"
binaries_dir="${system_dir}/binaries" binaries_dir="${system_dir}/binaries"
disks_dir="${system_dir}/disks" disks_dir="${system_dir}/disks"
mkdir -p "$binaries_dir" "$disks_dir" mkdir -p "$binaries_dir" "$disks_dir"
cd "${top}/gem5" cd "${top}/gem5"
if [ "$arch" = x86_64 ]; then if [ "$arch" = x86_64 ]; then
CC=gcc-6 CXX=g++-6 scons -j"$(nproc)" --ignore-style build/X86/gem5.opt CC=gcc-6 CXX=g++-6 scons -j"$j" --ignore-style build/X86/gem5.opt
f="${disks_dir}/linux-bigswap2.img" f="${disks_dir}/linux-bigswap2.img"
dd if=/dev/zero of="$f" bs=1024 count=65536 dd if=/dev/zero of="$f" bs=1024 count=65536
mkswap "$f" mkswap "$f"
@@ -26,10 +33,11 @@ if [ "$arch" = x86_64 ]; then
elif [ "$arch" = arm ] || [ "$arch" = aarch64 ]; then elif [ "$arch" = arm ] || [ "$arch" = aarch64 ]; then
# Compilation fails with gcc 7 on that commit. # Compilation fails with gcc 7 on that commit.
# There were some recent portability patches, so it will likely get there soon. # There were some recent portability patches, so it will likely get there soon.
CC=gcc-6 CXX=g++-6 scons -j"$(nproc)" --ignore-style build/ARM/gem5.opt CC=gcc-6 CXX=g++-6 scons -j"$j" --ignore-style build/ARM/gem5.opt
make -C system/arm/dt make -C ./system/arm/dt
make -C system/arm/simple_bootloader # TODO use the buildroot cross compiler here, and remove the dependencies from configure.
make -C system/arm/aarch64_bootloader/ make -C ./system/arm/simple_bootloader
make -C ./system/arm/aarch64_bootloader/
cp ./system/arm/simple_bootloader/boot_emm.arm "$binaries_dir" cp ./system/arm/simple_bootloader/boot_emm.arm "$binaries_dir"
cp ./system/arm/aarch64_bootloader/boot_emm.arm64 "$binaries_dir" cp ./system/arm/aarch64_bootloader/boot_emm.arm64 "$binaries_dir"
fi fi

View File

@@ -15,6 +15,7 @@ ARCH_MAKE = $(ARCH)
endif endif
define GEM5_BUILD_CMDS define GEM5_BUILD_CMDS
cd '$(@D)' && ./build -a '$(ARCH)' -j '$(BR2_JLEVEL)'
cd '$(@D)/gem5/util/m5' && $(MAKE) -f 'Makefile.$(ARCH_MAKE)' CC='$(TARGET_CC)' LD='$(TARGET_LD)' cd '$(@D)/gem5/util/m5' && $(MAKE) -f 'Makefile.$(ARCH_MAKE)' CC='$(TARGET_CC)' LD='$(TARGET_LD)'
endef endef

24
run
View File

@@ -74,13 +74,15 @@ buildroot_dir="${root_dir}/buildroot"
out_dir="${root_dir}/buildroot/output.${arch_dir}~" out_dir="${root_dir}/buildroot/output.${arch_dir}~"
if "$gem5"; then if "$gem5"; then
gem5_dir="${root_dir}/gem5/gem5" build_dir="${out_dir}/build/gem5-1.0"
gem5_dir="${build_dir}/gem5"
if [ "$arch" = x86_64 ]; then if [ "$arch" = x86_64 ]; then
if "$kvm"; then if "$kvm"; then
extra_flags="$extra_flags --cpu-type=X86KvmCPU" extra_flags="$extra_flags --cpu-type=X86KvmCPU"
fi fi
cmd="\ cmd="\
M5_PATH='${root_dir}/gem5/gem5-system' \ M5_PATH='${build_dir}/system' \
$debug_vm \
'${gem5_dir}/build/X86/gem5.opt' \ '${gem5_dir}/build/X86/gem5.opt' \
${gem5opts} \ ${gem5opts} \
'${gem5_dir}/configs/example/fs.py' \ '${gem5_dir}/configs/example/fs.py' \
@@ -92,7 +94,7 @@ $extra_flags \
" "
elif [ "$arch" = arm ] || [ "$arch" = aarch64 ]; then elif [ "$arch" = arm ] || [ "$arch" = aarch64 ]; then
cmd="\ cmd="\
M5_PATH='${root_dir}/gem5/gem5-system' \ M5_PATH='${build_dir}/system' \
$debug_vm \ $debug_vm \
'${gem5_dir}/build/ARM/gem5.opt' \ '${gem5_dir}/build/ARM/gem5.opt' \
${gem5opts} \ ${gem5opts} \
@@ -102,7 +104,7 @@ ${gem5opts} \
--dtb-file='${gem5_dir}/system/arm/dt/$([ "$arch" = arm ] && echo "armv7_gem5_v1_${cpus}cpu" || echo "armv8_gem5_v1_${cpus}cpu").dtb' \ --dtb-file='${gem5_dir}/system/arm/dt/$([ "$arch" = arm ] && echo "armv7_gem5_v1_${cpus}cpu" || echo "armv8_gem5_v1_${cpus}cpu").dtb' \
--kernel='${out_dir}/build/linux-custom/vmlinux' \ --kernel='${out_dir}/build/linux-custom/vmlinux' \
--machine-type=VExpress_GEM5_V1 \ --machine-type=VExpress_GEM5_V1 \
--num-cpus=${cpus} \ --num-cpus='${cpus}' \
$extra_flags \ $extra_flags \
" "
fi fi
@@ -113,8 +115,8 @@ else
extra_flags="${extra_flags_qemu} ${extra_flags}" extra_flags="${extra_flags_qemu} ${extra_flags}"
images_dir="${out_dir}/images" images_dir="${out_dir}/images"
qemu_common="\ qemu_common="\
${debug_vm} \ '${debug_vm}' \
${out_dir}/host/usr/bin/qemu-system-${arch} \ '${out_dir}/host/usr/bin/qemu-system-${arch}' \
-m 128M \ -m 128M \
-monitor telnet::45454,server,nowait \ -monitor telnet::45454,server,nowait \
-netdev user,hostfwd=tcp::45455-:45455,id=net0 \ -netdev user,hostfwd=tcp::45455-:45455,id=net0 \
@@ -141,7 +143,7 @@ ${out_dir}/host/usr/bin/qemu-system-${arch} \
-device edu \ -device edu \
-device lkmc_pci_min \ -device lkmc_pci_min \
-device virtio-net-pci,netdev=net0 \ -device virtio-net-pci,netdev=net0 \
-kernel ${images_dir}/bzImage \ -kernel '${images_dir}/bzImage' \
${extra_flags} \ ${extra_flags} \
" "
;; ;;
@@ -157,8 +159,8 @@ ${extra_flags} \
-M versatilepb \ -M versatilepb \
-append '$root $extra_append' \ -append '$root $extra_append' \
-device rtl8139,netdev=net0 \ -device rtl8139,netdev=net0 \
-dtb ${images_dir}/versatile-pb.dtb \ -dtb '${images_dir}/versatile-pb.dtb' \
-kernel ${images_dir}/zImage \ -kernel '${images_dir}/zImage' \
-serial stdio \ -serial stdio \
$extra_flags \ $extra_flags \
" "
@@ -172,7 +174,7 @@ $extra_flags \
-append 'root=/dev/sda ${extra_append}' \ -append 'root=/dev/sda ${extra_append}' \
-cpu cortex-a57 \ -cpu cortex-a57 \
-device virtio-net-device,netdev=net0 \ -device virtio-net-device,netdev=net0 \
-kernel ${images_dir}/Image \ -kernel '${images_dir}/Image' \
-nographic \ -nographic \
-serial stdio \ -serial stdio \
${extra_flags} \ ${extra_flags} \
@@ -188,7 +190,7 @@ ${extra_flags} \
-append 'root=/dev/hda ${extra_append}' \ -append 'root=/dev/hda ${extra_append}' \
-cpu I6400 \ -cpu I6400 \
-device pcnet \ -device pcnet \
-kernel ${images_dir}/vmlinux \ -kernel '${images_dir}/vmlinux' \
-nographic \ -nographic \
${extra_flags} \ ${extra_flags} \
" "