mirror of
https://github.com/cirosantilli/linux-kernel-module-cheat.git
synced 2026-01-28 12:34:26 +01:00
build runs, lots of uncommented and lots of untested though
Refactor everything. Create nice submodules/ and packages/ folders.
This commit is contained in:
10
.gitmodules
vendored
10
.gitmodules
vendored
@@ -1,16 +1,16 @@
|
|||||||
[submodule "buildroot"]
|
[submodule "buildroot"]
|
||||||
path = buildroot
|
path = submodules/buildroot
|
||||||
url = https://github.com/cirosantilli/buildroot
|
url = https://github.com/cirosantilli/buildroot
|
||||||
ignore = dirty
|
ignore = dirty
|
||||||
[submodule "qemu"]
|
[submodule "qemu"]
|
||||||
path = qemu
|
path = submodules/qemu
|
||||||
url = https://github.com/cirosantilli/qemu
|
url = https://github.com/cirosantilli/qemu
|
||||||
[submodule "linux"]
|
[submodule "linux"]
|
||||||
path = linux
|
path = submodules/linux
|
||||||
url = https://github.com/cirosantilli/linux
|
url = https://github.com/cirosantilli/linux
|
||||||
[submodule "gem5/gem5"]
|
[submodule "gem5/gem5"]
|
||||||
path = gem5/gem5
|
path = submodules/gem5
|
||||||
url = https://gem5.googlesource.com/public/gem5
|
url = https://gem5.googlesource.com/public/gem5
|
||||||
[submodule "parsec-benchmark/parsec-benchmark"]
|
[submodule "parsec-benchmark/parsec-benchmark"]
|
||||||
path = parsec-benchmark/parsec-benchmark
|
path = submodules/parsec-benchmark
|
||||||
url = https://github.com/cirosantilli/parsec-benchmark
|
url = https://github.com/cirosantilli/parsec-benchmark
|
||||||
|
|||||||
@@ -334,7 +334,7 @@ otherwise they will cause problems.
|
|||||||
Minimal host build system example:
|
Minimal host build system example:
|
||||||
|
|
||||||
....
|
....
|
||||||
cd hello_host
|
cd hello_host_kernel_module
|
||||||
make
|
make
|
||||||
insmod hello.ko
|
insmod hello.ko
|
||||||
dmesg
|
dmesg
|
||||||
|
|||||||
71
br2/default
71
br2/default
@@ -1,71 +0,0 @@
|
|||||||
# Custom packages
|
|
||||||
BR2_PACKAGE_KERNEL_MODULE=y
|
|
||||||
BR2_SAMPLE_PACKAGE=y
|
|
||||||
|
|
||||||
# Rootfs
|
|
||||||
BR2_TARGET_ROOTFS_CPIO=n
|
|
||||||
BR2_TARGET_ROOTFS_EXT2=y
|
|
||||||
BR2_TARGET_ROOTFS_INITRAMFS=n
|
|
||||||
BR2_TARGET_ROOTFS_EXT2_SIZE="512M"
|
|
||||||
|
|
||||||
# We were tempted to do this to disable S40network neatly,
|
|
||||||
# but that package also creates extra configuration files
|
|
||||||
# such as /etc/network/interfaces which we need. So we just
|
|
||||||
# remove the init.d file for now.
|
|
||||||
#BR2_PACKAGE_IFUPDOWN_SCRIPTS=n
|
|
||||||
|
|
||||||
# Misc
|
|
||||||
BR2_CCACHE=y
|
|
||||||
# Otherwise our precious debug would break!
|
|
||||||
BR2_CCACHE_USE_BASEDIR=n
|
|
||||||
BR2_GCC_ENABLE_GRAPHITE=y
|
|
||||||
BR2_GCC_ENABLE_LTO=y
|
|
||||||
BR2_GCC_ENABLE_OPENMP=y
|
|
||||||
BR2_GLOBAL_PATCH_DIR="../patches/global"
|
|
||||||
BR2_PACKAGE_BUSYBOX_CONFIG_FRAGMENT_FILES="../busybox_config_fragment"
|
|
||||||
BR2_PACKAGE_DHRYSTONE=y
|
|
||||||
BR2_PACKAGE_FILE=y
|
|
||||||
BR2_PACKAGE_OVERRIDE_FILE="../buildroot_override"
|
|
||||||
BR2_PACKAGE_PCIUTILS=y
|
|
||||||
# For qemu-ga on guest. TODO: do something with it, and document it.
|
|
||||||
# Maybe: https://superuser.com/questions/930588/how-to-pass-commands-noninteractively-to-running-qemu-from-the-guest-qmp-via-te
|
|
||||||
BR2_PACKAGE_QEMU=y
|
|
||||||
BR2_PACKAGE_STRACE=y
|
|
||||||
BR2_ROOTFS_OVERLAY="../rootfs_overlay"
|
|
||||||
BR2_ROOTFS_POST_BUILD_SCRIPT="../rootfs_post_build_script"
|
|
||||||
BR2_ROOTFS_POST_IMAGE_SCRIPT="../rootfs_post_image_script"
|
|
||||||
BR2_ROOTFS_USERS_TABLES="../user_table"
|
|
||||||
BR2_TOOLCHAIN_BUILDROOT_CXX=y
|
|
||||||
BR2_TOOLCHAIN_BUILDROOT_FORTRAN=y
|
|
||||||
BR2_TOOLCHAIN_BUILDROOT_WCHAR=y
|
|
||||||
|
|
||||||
# lscpu: TODO not installing?
|
|
||||||
BR2_PACKAGE_UTIL_LINUX=y
|
|
||||||
BR2_PACKAGE_UTIL_LINUX_BINARIES=y
|
|
||||||
# taskset
|
|
||||||
BR2_PACKAGE_UTIL_LINUX_SCHEDUTILS=y
|
|
||||||
|
|
||||||
# Host GDB
|
|
||||||
BR2_GDB_VERSION="7.11.1"
|
|
||||||
BR2_GDB_VERSION_7_10=n
|
|
||||||
BR2_GDB_VERSION_7_11=y
|
|
||||||
BR2_GDB_VERSION_7_12=n
|
|
||||||
BR2_PACKAGE_HOST_GDB=y
|
|
||||||
BR2_PACKAGE_HOST_GDB_PYTHON=y
|
|
||||||
BR2_PACKAGE_HOST_GDB_SIM=y
|
|
||||||
BR2_PACKAGE_HOST_GDB_TUI=y
|
|
||||||
|
|
||||||
# gdbserver
|
|
||||||
BR2_DEBUG_3=y
|
|
||||||
BR2_ENABLE_DEBUG=y
|
|
||||||
BR2_OPTIMIZE_0=y
|
|
||||||
BR2_PACKAGE_GDB=y
|
|
||||||
BR2_PTHREAD_DEBUG=y
|
|
||||||
|
|
||||||
# ftrace
|
|
||||||
BR2_PACKAGE_TRACE_CMD=y
|
|
||||||
|
|
||||||
# DTC
|
|
||||||
BR2_PACKAGE_DTC=y
|
|
||||||
BR2_PACKAGE_DTC_PROGRAMS=y
|
|
||||||
BR2_PACKAGE_HOST_DTC=y
|
|
||||||
6
br2/qemu
6
br2/qemu
@@ -1,6 +0,0 @@
|
|||||||
BR2_PACKAGE_HOST_QEMU=y
|
|
||||||
# False because otherwise we need the host to be as recent as guest, and the build fails with:
|
|
||||||
# package/qemu/qemu.mk:110: *** "Refusing to build qemu-user: target Linux version newer than host's.". Stop.
|
|
||||||
BR2_PACKAGE_HOST_QEMU_LINUX_USER_MODE=n
|
|
||||||
BR2_PACKAGE_HOST_QEMU_SYSTEM_MODE=y
|
|
||||||
BR2_PACKAGE_HOST_QEMU_VDE2=y
|
|
||||||
309
build
309
build
@@ -2,6 +2,7 @@
|
|||||||
|
|
||||||
import multiprocessing
|
import multiprocessing
|
||||||
import os
|
import os
|
||||||
|
import pathlib
|
||||||
import shlex
|
import shlex
|
||||||
import subprocess
|
import subprocess
|
||||||
import sys
|
import sys
|
||||||
@@ -17,166 +18,206 @@ defaults = {
|
|||||||
'kernel_config': [],
|
'kernel_config': [],
|
||||||
'kernel_config_fragment': [],
|
'kernel_config_fragment': [],
|
||||||
'kernel_custom_config_file': None,
|
'kernel_custom_config_file': None,
|
||||||
|
'kernel_module_reconfigure': False,
|
||||||
'linux_reconfigure': False,
|
'linux_reconfigure': False,
|
||||||
'nproc': None,
|
'nproc': None,
|
||||||
'skip_configure': False,
|
'skip_configure': False,
|
||||||
'qemu_reconfigure': False,
|
|
||||||
'verbose': False,
|
'verbose': False,
|
||||||
'extra_make_args': '',
|
'extra_make_args': '',
|
||||||
}
|
}
|
||||||
|
|
||||||
|
def path_relative_to_buildroot(abspath):
|
||||||
|
return os.path.relpath(abspath, common.buildroot_dir)
|
||||||
|
|
||||||
def main(args, extra_args=None):
|
def main(args, extra_args=None):
|
||||||
global defaults
|
global defaults
|
||||||
args = common.resolve_args(defaults, args, extra_args)
|
args = common.resolve_args(defaults, args, extra_args)
|
||||||
mkdir -p "${common_out_dir}"
|
os.makedirs(common.out_dir, exist_ok=True)
|
||||||
|
extra_make_args = shlex.split(args.extra_make_args)
|
||||||
buildroot_configs = args.buildroot_config
|
|
||||||
extra_make_args = args.extra_make_args
|
|
||||||
if args.kernel_module_reconfigure:
|
if args.kernel_module_reconfigure:
|
||||||
extra_make_args.append('kernel_module-reconfigure')
|
extra_make_args.append('kernel_module-reconfigure')
|
||||||
if args.linux_reconfigure:
|
if args.linux_reconfigure:
|
||||||
extra_make_args.append('linux-reconfigure')
|
extra_make_args.append('linux-reconfigure')
|
||||||
if args.qemu_reconfigure:
|
|
||||||
extra_make_args.append('host-qemu-reconfigure')
|
|
||||||
if args.gem5:
|
if args.gem5:
|
||||||
extra_make_args.append('gem5-reconfigure')
|
extra_make_args.append('gem5-reconfigure')
|
||||||
if args.initramfs:
|
|
||||||
buildroot_configs.extend([
|
|
||||||
'BR2_TARGET_ROOTFS_CPIO=n',
|
|
||||||
'BR2_TARGET_ROOTFS_EXT2=n',
|
|
||||||
'BR2_TARGET_ROOTFS_INITRAMFS=y',
|
|
||||||
])
|
|
||||||
if args.initrd:
|
|
||||||
buildroot_configs.extend([
|
|
||||||
'BR2_TARGET_ROOTFS_CPIO=y',
|
|
||||||
'BR2_TARGET_ROOTFS_EXT2=n'
|
|
||||||
'BR2_TARGET_ROOTFS_INITRAMFS=n',
|
|
||||||
])
|
|
||||||
if args.nproc is None:
|
if args.nproc is None:
|
||||||
nproc = multiprocessing.cpu_count()
|
nproc = multiprocessing.cpu_count()
|
||||||
else:
|
else:
|
||||||
nproc = args.nproc
|
nproc = args.nproc
|
||||||
if common.arch == 'x86_64':
|
if args.arch == 'x86_64':
|
||||||
defconfig = 'qemu_x86_64_defconfig'
|
defconfig = 'qemu_x86_64_defconfig'
|
||||||
elif common.arch == 'arm':
|
elif args.arch == 'arm':
|
||||||
defconfig = 'qemu_arm_vexpress_defconfig'
|
defconfig = 'qemu_arm_vexpress_defconfig'
|
||||||
elif common.arch == 'aarch64':
|
elif args.arch == 'aarch64':
|
||||||
defconfig = 'qemu_aarch64_virt_defconfig'
|
defconfig = 'qemu_aarch64_virt_defconfig'
|
||||||
|
|
||||||
# TODO
|
|
||||||
buildroot_config_fragments="${common_root_dir}/br2/default"
|
|
||||||
args.buildroot_config_fragment
|
|
||||||
args.kernel_config
|
|
||||||
args.kernel_config_fragment
|
|
||||||
config_fragments="${config_fragments} ${common_root_dir}/br2/qemu ${br2_cli_file}"
|
|
||||||
|
|
||||||
time {
|
|
||||||
# Configure.
|
# Configure.
|
||||||
if "$configure"; then
|
if not args.skip_configure:
|
||||||
if ! cmp "${kernel_config_fragment_cli_file}" "${kernel_config_fragment_cli_file_tmp}"; then
|
# Initial make configure.
|
||||||
# Only copy if modified, otherwise the kernel always rebuilds.
|
#cd "${common_buildroot_dir}"
|
||||||
cp "${kernel_config_fragment_cli_file_tmp}" "${kernel_config_fragment_cli_file}"
|
#for p in $(find "${common_root_dir}/patches/buildroot/" -maxdepth 1 -name '*.patch' -print); do
|
||||||
fi
|
# patch -N -r - -p 1 < "$p" || :
|
||||||
cd "${common_buildroot_dir}"
|
#done
|
||||||
for p in $(find "${common_root_dir}/patches/buildroot/" -maxdepth 1 -name '*.patch' -print); do
|
br2_external_dirs = []
|
||||||
patch -N -r - -p 1 < "$p" || :
|
packages_dir = os.path.join(common.root_dir, 'packages')
|
||||||
done
|
for package_dir in os.listdir(packages_dir):
|
||||||
br2_external='../kernel_module:../gem5:../parsec-benchmark'
|
package_dir_abs = os.path.join(packages_dir, package_dir)
|
||||||
packages_dir="${common_root_dir}/packages"
|
if os.path.isdir(package_dir_abs):
|
||||||
for package_dir in "${packages_dir}"/*/; do
|
br2_external_dirs.append(path_relative_to_buildroot(package_dir_abs))
|
||||||
br2_external="${br2_external}:../packages/$(basename "${package_dir}")"
|
br2_external_str = ':'.join(br2_external_dirs)
|
||||||
done
|
subprocess.check_call(
|
||||||
make O="$common_buildroot_out_dir" BR2_EXTERNAL="$br2_external" "$defconfig"
|
[
|
||||||
# TODO Can't get rid of these for now.
|
'make',
|
||||||
# http://stackoverflow.com/questions/44078245/is-it-possible-to-use-config-fragments-with-buildroots-config
|
'O={}'.format(common.buildroot_out_dir),
|
||||||
for config_fragment in $config_fragments; do
|
'BR2_EXTERNAL={}'.format(br2_external_str),
|
||||||
cat "$config_fragment" >> "$common.buildroot_config_file"
|
defconfig,
|
||||||
done
|
],
|
||||||
printf "
|
cwd=common.buildroot_dir,
|
||||||
BR2_JLEVEL=${j}
|
)
|
||||||
BR2_DL_DIR=\"${common_dir}/dl\"
|
|
||||||
" >> "$common.buildroot_config_file"
|
|
||||||
if "$common_gem5"; then
|
|
||||||
printf "BR2_PACKAGE_GEM5=y\n" >> "${common.buildroot_config_file}"
|
|
||||||
fi
|
|
||||||
kernel_config_fragment_dir=../kernel_config_fragment
|
|
||||||
if [ -n "$linux_kernel_custom_config_file" ]; then
|
|
||||||
if [ -f "$linux_kernel_custom_config_file" ]; then
|
|
||||||
printf "BR2_LINUX_KERNEL_USE_CUSTOM_CONFIG=y\nBR2_LINUX_KERNEL_CUSTOM_CONFIG_FILE=\"${linux_kernel_custom_config_file}\"\n" >> "$common.buildroot_config_file"
|
|
||||||
if "${linux_reconfigure}"; then
|
|
||||||
touch "${linux_kernel_custom_config_file}"
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
echo "error: -K: file does not exist: ${linux_kernel_custom_config_file}" 1>&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
default_config_fragments=
|
|
||||||
else
|
|
||||||
default_config_fragments="${kernel_config_fragment_dir}/min ${kernel_config_fragment_dir}/default ${kernel_config_fragment_dir}/display"
|
|
||||||
fi
|
|
||||||
printf "BR2_LINUX_KERNEL_CONFIG_FRAGMENT_FILES=\"${default_config_fragments} ${kernel_config_fragments} ${kernel_config_fragment_cli_file}\"\n" >> "$common.buildroot_config_file"
|
|
||||||
if "${linux_reconfigure}"; then
|
|
||||||
# https://stackoverflow.com/questions/49260466/why-when-i-change-br2-linux-kernel-custom-config-file-and-run-make-linux-reconfi
|
|
||||||
touch "${kernel_config_fragment_dir}/min"
|
|
||||||
fi
|
|
||||||
make O="$common_buildroot_out_dir" olddefconfig
|
|
||||||
fi
|
|
||||||
echo 'config time:'
|
|
||||||
}
|
|
||||||
echo
|
|
||||||
|
|
||||||
common_mkdir
|
# Extra buildroot configs.
|
||||||
|
buildroot_configs = args.buildroot_config
|
||||||
|
buildroot_configs.extend([
|
||||||
|
'BR2_JLEVEL={}'.format(nproc),
|
||||||
|
'BR2_DL_DIR="{}"'.format(os.path.join(common.common_dir, 'dl')),
|
||||||
|
'BR2_GLOBAL_PATCH_DIR="{}"'.format(
|
||||||
|
path_relative_to_buildroot(os.path.join(common.root_dir, 'patches', 'global'))),
|
||||||
|
'BR2_PACKAGE_BUSYBOX_CONFIG_FRAGMENT_FILES="{}"'.format(
|
||||||
|
path_relative_to_buildroot(os.path.join(common.root_dir, 'busybox_config_fragment'))),
|
||||||
|
'BR2_PACKAGE_OVERRIDE_FILE="{}"'.format(
|
||||||
|
path_relative_to_buildroot(os.path.join(common.root_dir, 'buildroot_override'))),
|
||||||
|
'BR2_ROOTFS_OVERLAY="{}"'.format(
|
||||||
|
path_relative_to_buildroot(os.path.join(common.root_dir, 'rootfs_overlay'))),
|
||||||
|
'BR2_ROOTFS_POST_BUILD_SCRIPT="{}"'.format(
|
||||||
|
path_relative_to_buildroot(os.path.join(common.root_dir, 'rootfs_post_build_script'))),
|
||||||
|
'BR2_ROOTFS_POST_IMAGE_SCRIPT="{}"'.format(
|
||||||
|
path_relative_to_buildroot(os.path.join(common.root_dir, 'rootfs_post_image_script'))),
|
||||||
|
'BR2_ROOTFS_USERS_TABLES="{}"'.format(
|
||||||
|
path_relative_to_buildroot(os.path.join(common.root_dir, 'user_table'))),
|
||||||
|
])
|
||||||
|
|
||||||
# Manage Linux kernel and QEMU variants.
|
if args.gem5:
|
||||||
symlink_buildroot_variant() (
|
buildroot_configs.append('BR2_PACKAGE_GEM5=y')
|
||||||
custom_dir="$1"
|
if args.initramfs:
|
||||||
variant_dir="$2"
|
buildroot_configs.extend([
|
||||||
if [ -h "$custom_dir" ]; then
|
'BR2_TARGET_ROOTFS_CPIO=n',
|
||||||
rm "$custom_dir"
|
'BR2_TARGET_ROOTFS_EXT2=n',
|
||||||
elif [ -d "$custom_dir" ]; then
|
'BR2_TARGET_ROOTFS_INITRAMFS=y',
|
||||||
# Migration for existing builds.
|
])
|
||||||
mv "$custom_dir" "$variant_dir"
|
if args.initrd:
|
||||||
fi
|
buildroot_configs.extend([
|
||||||
mkdir -p "$variant_dir"
|
'BR2_TARGET_ROOTFS_CPIO=y',
|
||||||
ln -s "$variant_dir" "$custom_dir"
|
'BR2_TARGET_ROOTFS_EXT2=n'
|
||||||
|
'BR2_TARGET_ROOTFS_INITRAMFS=n',
|
||||||
|
])
|
||||||
|
buildroot_config_fragments = [
|
||||||
|
os.path.join(common.root_dir, 'buildroot_config_fragments', 'default')
|
||||||
|
] + args.buildroot_config_fragment
|
||||||
|
|
||||||
|
# Decide kernel configuration.
|
||||||
|
kernel_config_fragments = []
|
||||||
|
if True:
|
||||||
|
# CLI kernel configurations.
|
||||||
|
kernel_config_fragment_cli_path = os.path.join(common.out_dir, 'kernel_config_fragment_cli')
|
||||||
|
kernel_config_cli_str = '\n'.join(args.kernel_config)
|
||||||
|
if os.path.exists(kernel_config_fragment_cli_path):
|
||||||
|
with open(kernel_config_fragment_cli_path, 'r') as kernel_config_fragment_cli_file:
|
||||||
|
kernel_config_cli_str_old = kernel_config_fragment_cli_file.read()
|
||||||
|
if kernel_config_cli_str != kernel_config_cli_str_old:
|
||||||
|
# Only update if modified, otherwise Buildroot rebuilds the
|
||||||
|
# kernel always rebuilds kernel every time.
|
||||||
|
do_write = True
|
||||||
|
else:
|
||||||
|
do_write = True
|
||||||
|
with open(kernel_config_fragment_cli_path, 'w') as kernel_config_fragment_cli_file:
|
||||||
|
kernel_config_fragment_cli_file.write(kernel_config_cli_str)
|
||||||
|
kernel_config_fragments.append(os.path.join(kernel_config_fragment_cli_path))
|
||||||
|
if True:
|
||||||
|
# Kernel configuration fragments.
|
||||||
|
kernel_config_fragment_dir = os.path.join('..', 'kernel_config_fragment')
|
||||||
|
if args.kernel_custom_config_file is not None:
|
||||||
|
if os.path.exists(args.kernel_custom_config_file):
|
||||||
|
buildroot_configs.extend([
|
||||||
|
'BR2_LINUX_KERNEL_USE_CUSTOM_CONFIG=y',
|
||||||
|
'BR2_LINUX_KERNEL_CUSTOM_CONFIG_FILE=\"{}\"'.format(args.kernel_custom_config_file),
|
||||||
|
])
|
||||||
|
if args.linux_reconfigure:
|
||||||
|
pathlib.Path(args.kernel_custom_config_file).touch()
|
||||||
|
else:
|
||||||
|
raise Exception('Kernel config fragment file does not exist: {}'.format(args.kernel_custom_config_file))
|
||||||
|
default_kernel_config_fragments = []
|
||||||
|
else:
|
||||||
|
default_kernel_config_fragments = ['min', 'default', 'display']
|
||||||
|
if args.linux_reconfigure:
|
||||||
|
# https://stackoverflow.com/questions/49260466/why-when-i-change-br2-linux-kernel-custom-config-file-and-run-make-linux-reconfi
|
||||||
|
pathlib.Path(os.path.join(kernel_config_fragment_dir, 'min')).touch()
|
||||||
|
for i, default_kernel_config_fragment in enumerate(default_kernel_config_fragments):
|
||||||
|
default_kernel_config_fragments[i] = os.path.join(kernel_config_fragment_dir, default_kernel_config_fragment)
|
||||||
|
kernel_config_fragments.extend(default_kernel_config_fragments)
|
||||||
|
buildroot_kernel_config_fragment_str = 'BR2_LINUX_KERNEL_CONFIG_FRAGMENT_FILES="{}"'.format(' '.join(kernel_config_fragments))
|
||||||
|
buildroot_configs.append(buildroot_kernel_config_fragment_str)
|
||||||
|
|
||||||
|
# Write extra configs into the Buildroot config file.
|
||||||
|
# TODO Can't get rid of these for now with nice fragments:
|
||||||
|
# http://stackoverflow.com/questions/44078245/is-it-possible-to-use-config-fragments-with-buildroots-config
|
||||||
|
with open(common.buildroot_config_file, 'a') as br2_config_file:
|
||||||
|
for buildroot_config_fragment in buildroot_config_fragments:
|
||||||
|
with open(buildroot_config_fragment, 'r') as br2_config_fragment:
|
||||||
|
for line in br2_config_fragment:
|
||||||
|
br2_config_file.write(line)
|
||||||
|
for buildroot_config in buildroot_configs:
|
||||||
|
br2_config_file.write(buildroot_config + '\n')
|
||||||
|
|
||||||
|
subprocess.check_call(
|
||||||
|
[
|
||||||
|
'make',
|
||||||
|
'O={}'.format(common.buildroot_out_dir),
|
||||||
|
'olddefconfig',
|
||||||
|
],
|
||||||
|
cwd=common.buildroot_dir,
|
||||||
|
)
|
||||||
|
|
||||||
|
common.mkdir()
|
||||||
|
|
||||||
|
## Manage Linux kernel and QEMU variants.
|
||||||
|
#symlink_buildroot_variant() (
|
||||||
|
# custom_dir="$1"
|
||||||
|
# variant_dir="$2"
|
||||||
|
# if [ -h "$custom_dir" ]; then
|
||||||
|
# rm "$custom_dir"
|
||||||
|
# elif [ -d "$custom_dir" ]; then
|
||||||
|
# # Migration for existing builds.
|
||||||
|
# mv "$custom_dir" "$variant_dir"
|
||||||
|
# fi
|
||||||
|
# mkdir -p "$variant_dir"
|
||||||
|
# ln -s "$variant_dir" "$custom_dir"
|
||||||
|
#)
|
||||||
|
#symlink_buildroot_variant "$common_linux_build_dir" "$common_linux_variant_dir"
|
||||||
|
#symlink_buildroot_variant "$common_qemu_build_dir" "$common_qemu_variant_dir"
|
||||||
|
## TODO: this breaks the build. But then I noticed that it wouldn't make sense,
|
||||||
|
## because this is a guest tool, and we don't have image variants yet. Some other day maybe.
|
||||||
|
##symlink_buildroot_variant "$common_qemu_guest_build_dir" "$common_qemu_guest_variant_dir"
|
||||||
|
|
||||||
|
## Manage gem5 variants.
|
||||||
|
#if "$common_gem5"; then
|
||||||
|
# if [ ! -e "${common_gem5_src_dir}/.git" ]; then
|
||||||
|
# git -C "$common_gem5_default_src_dir" worktree add -b "wt/${common_gem5_variant}" "${common_gem5_src_dir}"
|
||||||
|
# fi
|
||||||
|
#fi
|
||||||
|
|
||||||
|
return common.run_cmd(
|
||||||
|
[
|
||||||
|
'make',
|
||||||
|
'O={}'.format(common.buildroot_out_dir),
|
||||||
|
'V={}'.format(int(args.verbose)),
|
||||||
|
] +
|
||||||
|
extra_make_args +
|
||||||
|
['all']
|
||||||
|
,
|
||||||
|
out_file=os.path.join(common.out_arch_dir, 'buildroot.log'),
|
||||||
|
delete_env=['LD_LIBRARY_PATH'],
|
||||||
|
cwd=common.buildroot_dir,
|
||||||
)
|
)
|
||||||
symlink_buildroot_variant "$common_linux_build_dir" "$common_linux_variant_dir"
|
|
||||||
symlink_buildroot_variant "$common_qemu_build_dir" "$common_qemu_variant_dir"
|
|
||||||
# TODO: this breaks the build. But then I noticed that it wouldn't make sense,
|
|
||||||
# because this is a guest tool, and we don't have image variants yet. Some other day maybe.
|
|
||||||
#symlink_buildroot_variant "$common_qemu_guest_build_dir" "$common_qemu_guest_variant_dir"
|
|
||||||
|
|
||||||
# Manage gem5 variants.
|
|
||||||
if "$common_gem5"; then
|
|
||||||
if [ ! -e "${common_gem5_src_dir}/.git" ]; then
|
|
||||||
git -C "$common_gem5_default_src_dir" worktree add -b "wt/${common_gem5_variant}" "${common_gem5_src_dir}"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
cd "$common_buildroot_dir"
|
|
||||||
# HOST_QEMU_OPTS is a hack that happens to work because the QEMU package luckly uses += at all times.
|
|
||||||
# It shouldn't be necessary in the first place: https://bugs.busybox.net/show_bug.cgi?id=9936
|
|
||||||
#
|
|
||||||
# Even if were an autotools package, there is no general way currently to pass extra configs to it:
|
|
||||||
# https://stackoverflow.com/questions/44341188/how-to-pass-extra-custom-configure-autotools-options-to-a-buildroot-package/44341225#44341225
|
|
||||||
#
|
|
||||||
# BR2_ options may be given on the command line here, and they do have direct "define" effects.
|
|
||||||
# But this is generally bad, as it skips the Kconfig mechanism, e.g. it does not set defaults properly.
|
|
||||||
cmd="time \\
|
|
||||||
env \\
|
|
||||||
-u LD_LIBRARY_PATH \\
|
|
||||||
make \\
|
|
||||||
O='${common_buildroot_out_dir}' \\
|
|
||||||
HOST_QEMU_OPTS='--enable-debug --enable-trace-backends=simple --enable-sdl --with-sdlabi=2.0' \\
|
|
||||||
GEM5_LKMC_GEM5_BUILD_TYPE="$common_gem5_build_type" \\
|
|
||||||
GEM5_LKMC_OUTDIR="$common_gem5_out_dir" \\
|
|
||||||
GEM5_LKMC_SRCDIR="$common_gem5_src_dir" \\
|
|
||||||
V='${v}' \\
|
|
||||||
${extra_make_args} \
|
|
||||||
all \\
|
|
||||||
"
|
|
||||||
"${common_root_dir}/eeval" "$cmd" "${common_out_arch_dir}/build.sh"
|
|
||||||
return 0
|
|
||||||
|
|
||||||
def get_argparse():
|
def get_argparse():
|
||||||
parser = common.get_argparse(argparse_args={'description':'Run Linux on an emulator'})
|
parser = common.get_argparse(argparse_args={'description':'Run Linux on an emulator'})
|
||||||
@@ -236,10 +277,6 @@ Still uses options explicitly passed with `-C` and `-c` on top of it.'''
|
|||||||
Touches kernel configuration files to overcome:
|
Touches kernel configuration files to overcome:
|
||||||
https://stackoverflow.com/questions/49260466/why-when-i-change-br2-linux-kernel-custom-config-file-and-run-make-linux-reconfi'''
|
https://stackoverflow.com/questions/49260466/why-when-i-change-br2-linux-kernel-custom-config-file-and-run-make-linux-reconfi'''
|
||||||
)
|
)
|
||||||
parser.add_argument(
|
|
||||||
'-q', '--qemu-reconfigure', default=defaults['qemu_reconfigure'], action='store_true',
|
|
||||||
help='Reconfigure and rebuild QEMU'
|
|
||||||
)
|
|
||||||
parser.add_argument(
|
parser.add_argument(
|
||||||
'-v', '--verbose', default=defaults['verbose'], action='store_true',
|
'-v', '--verbose', default=defaults['verbose'], action='store_true',
|
||||||
help='Do a verbose build'
|
help='Do a verbose build'
|
||||||
|
|||||||
66
buildroot_config_fragments/default
Normal file
66
buildroot_config_fragments/default
Normal file
@@ -0,0 +1,66 @@
|
|||||||
|
# Toolchain options.
|
||||||
|
# Enable as much visibility as possible.
|
||||||
|
BR2_CCACHE=y
|
||||||
|
BR2_CCACHE_USE_BASEDIR=n
|
||||||
|
BR2_DEBUG_3=y
|
||||||
|
BR2_ENABLE_DEBUG=y
|
||||||
|
BR2_GCC_ENABLE_GRAPHITE=y
|
||||||
|
BR2_GCC_ENABLE_LTO=y
|
||||||
|
BR2_GCC_ENABLE_OPENMP=y
|
||||||
|
BR2_OPTIMIZE_0=y
|
||||||
|
BR2_PTHREAD_DEBUG=y
|
||||||
|
BR2_TOOLCHAIN_BUILDROOT_CXX=y
|
||||||
|
BR2_TOOLCHAIN_BUILDROOT_FORTRAN=y
|
||||||
|
BR2_TOOLCHAIN_BUILDROOT_WCHAR=y
|
||||||
|
|
||||||
|
# # Rootfs
|
||||||
|
# BR2_TARGET_ROOTFS_CPIO=n
|
||||||
|
# BR2_TARGET_ROOTFS_EXT2=y
|
||||||
|
# BR2_TARGET_ROOTFS_INITRAMFS=n
|
||||||
|
# BR2_TARGET_ROOTFS_EXT2_SIZE="512M"
|
||||||
|
#
|
||||||
|
# # Host GDB
|
||||||
|
# BR2_GDB_VERSION="7.11.1"
|
||||||
|
# BR2_GDB_VERSION_7_10=n
|
||||||
|
# BR2_GDB_VERSION_7_11=y
|
||||||
|
# BR2_GDB_VERSION_7_12=n
|
||||||
|
# BR2_PACKAGE_HOST_GDB=y
|
||||||
|
# BR2_PACKAGE_HOST_GDB_PYTHON=y
|
||||||
|
# BR2_PACKAGE_HOST_GDB_SIM=y
|
||||||
|
# BR2_PACKAGE_HOST_GDB_TUI=y
|
||||||
|
|
||||||
|
# # Custom packages
|
||||||
|
# BR2_PACKAGE_KERNEL_MODULE=y
|
||||||
|
# BR2_SAMPLE_PACKAGE=y
|
||||||
|
|
||||||
|
# We were tempted to do this to disable S40network neatly,
|
||||||
|
# but that package also creates extra configuration files
|
||||||
|
# such as /etc/network/interfaces which we need. So we just
|
||||||
|
# remove the init.d file for now.
|
||||||
|
#BR2_PACKAGE_IFUPDOWN_SCRIPTS=n
|
||||||
|
|
||||||
|
# misc packages
|
||||||
|
# BR2_PACKAGE_DHRYSTONE=y
|
||||||
|
# BR2_PACKAGE_FILE=y
|
||||||
|
# BR2_PACKAGE_PCIUTILS=y
|
||||||
|
# # For qemu-ga on guest. TODO: do something with it, and document it.
|
||||||
|
# # Maybe: https://superuser.com/questions/930588/how-to-pass-commands-noninteractively-to-running-qemu-from-the-guest-qmp-via-te
|
||||||
|
# BR2_PACKAGE_QEMU=y
|
||||||
|
# BR2_PACKAGE_STRACE=y
|
||||||
|
|
||||||
|
# # lscpu: TODO not installing?
|
||||||
|
# BR2_PACKAGE_UTIL_LINUX=y
|
||||||
|
# BR2_PACKAGE_UTIL_LINUX_BINARIES=y
|
||||||
|
# # taskset
|
||||||
|
# BR2_PACKAGE_UTIL_LINUX_SCHEDUTILS=y
|
||||||
|
|
||||||
|
# # gdbserver
|
||||||
|
# BR2_PACKAGE_GDB=y
|
||||||
|
|
||||||
|
# # ftrace
|
||||||
|
# BR2_PACKAGE_TRACE_CMD=y
|
||||||
|
#
|
||||||
|
# # DTC
|
||||||
|
# BR2_PACKAGE_DTC=y
|
||||||
|
# BR2_PACKAGE_DTC_PROGRAMS=y
|
||||||
|
# BR2_PACKAGE_HOST_DTC=y
|
||||||
@@ -1,5 +1,2 @@
|
|||||||
HOST_QEMU_OVERRIDE_SRCDIR = ../qemu
|
LINUX_OVERRIDE_SRCDIR = ../../submodules/linux
|
||||||
LINUX_OVERRIDE_SRCDIR = ../linux
|
QEMU_OVERRIDE_SRCDIR = ../../submodules/qemu
|
||||||
PARSEC_BENCHMARK_OVERRIDE_SRCDIR = ../parsec-benchmark/parsec-benchmark
|
|
||||||
QEMU_OVERRIDE_SRCDIR = ../qemu
|
|
||||||
# UCLIBC_OVERRIDE_SRCDIR = ../uclibc-ng
|
|
||||||
|
|||||||
11
common.py
11
common.py
@@ -207,6 +207,7 @@ def run_cmd(
|
|||||||
show_stdout=True,
|
show_stdout=True,
|
||||||
show_cmd=True,
|
show_cmd=True,
|
||||||
extra_env=None,
|
extra_env=None,
|
||||||
|
delete_env=None,
|
||||||
**kwargs
|
**kwargs
|
||||||
):
|
):
|
||||||
'''
|
'''
|
||||||
@@ -241,8 +242,12 @@ def run_cmd(
|
|||||||
stderr = subprocess.DEVNULL
|
stderr = subprocess.DEVNULL
|
||||||
if extra_env is None:
|
if extra_env is None:
|
||||||
extra_env = {}
|
extra_env = {}
|
||||||
|
if delete_env is None:
|
||||||
|
delete_env = []
|
||||||
env = os.environ.copy()
|
env = os.environ.copy()
|
||||||
env.update(extra_env)
|
env.update(extra_env)
|
||||||
|
for key in delete_env:
|
||||||
|
del env[key]
|
||||||
if show_cmd:
|
if show_cmd:
|
||||||
print_cmd(cmd, cmd_file, extra_env=extra_env)
|
print_cmd(cmd, cmd_file, extra_env=extra_env)
|
||||||
# Otherwise Ctrl + C gives:
|
# Otherwise Ctrl + C gives:
|
||||||
@@ -282,11 +287,9 @@ def setup(parser, **extra_args):
|
|||||||
this.gem5_arch = 'ARM'
|
this.gem5_arch = 'ARM'
|
||||||
elif args.arch == 'x86_64':
|
elif args.arch == 'x86_64':
|
||||||
this.gem5_arch = 'X86'
|
this.gem5_arch = 'X86'
|
||||||
this.buildroot_dir = os.path.join(root_dir, 'buildroot')
|
|
||||||
this.arch_dir = args.arch
|
this.arch_dir = args.arch
|
||||||
if args.suffix is not None:
|
if args.suffix is not None:
|
||||||
this.arch_dir = '{}-{}'.format(arch_dir, args.suffix)
|
this.arch_dir = '{}-{}'.format(arch_dir, args.suffix)
|
||||||
global out_arch_dir
|
|
||||||
this.out_arch_dir = os.path.join(this.out_dir, this.arch_dir)
|
this.out_arch_dir = os.path.join(this.out_dir, this.arch_dir)
|
||||||
this.buildroot_out_dir = os.path.join(this.out_arch_dir, 'buildroot')
|
this.buildroot_out_dir = os.path.join(this.out_arch_dir, 'buildroot')
|
||||||
this.buildroot_config_file = os.path.join(this.buildroot_out_dir, '.config')
|
this.buildroot_config_file = os.path.join(this.buildroot_out_dir, '.config')
|
||||||
@@ -376,10 +379,12 @@ p9_dir = os.path.join(data_dir, '9p')
|
|||||||
gem5_non_default_src_root_dir = os.path.join(data_dir, 'gem5')
|
gem5_non_default_src_root_dir = os.path.join(data_dir, 'gem5')
|
||||||
gem5_readfile_file = os.path.join(data_dir, 'readfile')
|
gem5_readfile_file = os.path.join(data_dir, 'readfile')
|
||||||
gem5_default_src_dir = os.path.join(root_dir, 'gem5', 'gem5')
|
gem5_default_src_dir = os.path.join(root_dir, 'gem5', 'gem5')
|
||||||
qemu_src_dir = os.path.join(root_dir, 'qemu')
|
|
||||||
out_dir = os.path.join(root_dir, 'out')
|
out_dir = os.path.join(root_dir, 'out')
|
||||||
bench_boot = os.path.join(out_dir, 'bench-boot.txt')
|
bench_boot = os.path.join(out_dir, 'bench-boot.txt')
|
||||||
common_dir = os.path.join(out_dir, 'common')
|
common_dir = os.path.join(out_dir, 'common')
|
||||||
|
submodules_dir = os.path.join(root_dir, 'submodules')
|
||||||
|
buildroot_dir = os.path.join(submodules_dir, 'buildroot')
|
||||||
|
qemu_src_dir = os.path.join(submodules_dir, 'qemu')
|
||||||
|
|
||||||
# Other default variables.
|
# Other default variables.
|
||||||
arch_map = {
|
arch_map = {
|
||||||
|
|||||||
13
configure
vendored
13
configure
vendored
@@ -11,7 +11,7 @@ while getopts gpqt OPT; do
|
|||||||
gem5=true
|
gem5=true
|
||||||
;;
|
;;
|
||||||
p)
|
p)
|
||||||
submodules="$submodules parsec-benchmark/parsec-benchmark"
|
submodules="${submodules} parsec-benchmark"
|
||||||
;;
|
;;
|
||||||
q)
|
q)
|
||||||
qemu=false
|
qemu=false
|
||||||
@@ -100,10 +100,10 @@ fi
|
|||||||
## Submodules
|
## Submodules
|
||||||
|
|
||||||
if "$qemu"; then
|
if "$qemu"; then
|
||||||
submodules="$submodules qemu"
|
submodules="${submodules} qemu"
|
||||||
fi
|
fi
|
||||||
if "$gem5"; then
|
if "$gem5"; then
|
||||||
submodules="$submodules gem5/gem5"
|
submodules="${submodules} gem5"
|
||||||
fi
|
fi
|
||||||
(
|
(
|
||||||
set -e
|
set -e
|
||||||
@@ -113,10 +113,11 @@ fi
|
|||||||
# In particular:
|
# In particular:
|
||||||
# - `shallow = true` on the submodule has no effect for the non default educational branches of our submodules
|
# - `shallow = true` on the submodule has no effect for the non default educational branches of our submodules
|
||||||
# - QEMU's submodules point to commits that are neither under branches nor tags, and so `--shallow-submodules` fails
|
# - QEMU's submodules point to commits that are neither under branches nor tags, and so `--shallow-submodules` fails
|
||||||
git submodule update --depth 1 $gitjobs --init -- $submodules
|
for submodule in submodules/*/; do
|
||||||
|
git submodule update --depth 1 $gitjobs --init -- "submodules/${submodule}"
|
||||||
|
done
|
||||||
if "$qemu"; then
|
if "$qemu"; then
|
||||||
cd qemu
|
git -C submodules/qemu submodule update --init --recursive
|
||||||
git submodule update --init --recursive
|
|
||||||
fi
|
fi
|
||||||
) &
|
) &
|
||||||
# https://unix.stackexchange.com/questions/65532/why-does-set-e-not-work-inside-subshells-with-parenthesis-followed-by-an-or
|
# https://unix.stackexchange.com/questions/65532/why-does-set-e-not-work-inside-subshells-with-parenthesis-followed-by-an-or
|
||||||
|
|||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user