mirror of
https://github.com/cirosantilli/linux-kernel-module-cheat.git
synced 2026-01-23 02:05:57 +01:00
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:
15
build
15
build
@@ -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
2
gem5/.gitignore
vendored
@@ -1 +1 @@
|
|||||||
/gem5-system
|
/system
|
||||||
|
|||||||
10
gem5/README.adoc
Normal file
10
gem5/README.adoc
Normal 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.
|
||||||
@@ -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
|
||||||
@@ -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
24
run
@@ -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} \
|
||||||
"
|
"
|
||||||
|
|||||||
Reference in New Issue
Block a user