mirror of
https://github.com/cirosantilli/linux-kernel-module-cheat.git
synced 2026-01-27 20:14:27 +01:00
build: move br2_cli.gitignore to out/
This commit is contained in:
49
build
49
build
@@ -2,10 +2,11 @@
|
|||||||
set -eu
|
set -eu
|
||||||
. common
|
. common
|
||||||
set -- ${cli_build:-} "$@"
|
set -- ${cli_build:-} "$@"
|
||||||
rm -f br2_cli.gitignore
|
br2_cli_file="${out_dir}/br2_cli"
|
||||||
touch br2_cli.gitignore
|
rm -f "$br2_cli_file"
|
||||||
|
touch "$br2_cli_file"
|
||||||
configure=true
|
configure=true
|
||||||
config_fragments=br2
|
config_fragments="${root_dir}/br2"
|
||||||
extra_make_args=
|
extra_make_args=
|
||||||
gem5=false
|
gem5=false
|
||||||
j="$(nproc)"
|
j="$(nproc)"
|
||||||
@@ -20,10 +21,10 @@ while getopts 'a:B:b:CGgj:hIiK:klp:qSv' OPT; do
|
|||||||
arch="$OPTARG"
|
arch="$OPTARG"
|
||||||
;;
|
;;
|
||||||
b)
|
b)
|
||||||
config_fragments="$config_fragments $OPTARG"
|
config_fragments="${config_fragments} $(common_abspath "${OPTARG}")"
|
||||||
;;
|
;;
|
||||||
B)
|
B)
|
||||||
echo "$OPTARG" >> br2_cli.gitignore
|
echo "$OPTARG" >> "$br2_cli_file"
|
||||||
;;
|
;;
|
||||||
C)
|
C)
|
||||||
configure=false
|
configure=false
|
||||||
@@ -45,17 +46,17 @@ while getopts 'a:B:b:CGgj:hIiK:klp:qSv' OPT; do
|
|||||||
BR2_TARGET_ROOTFS_CPIO=n
|
BR2_TARGET_ROOTFS_CPIO=n
|
||||||
BR2_TARGET_ROOTFS_EXT2=n
|
BR2_TARGET_ROOTFS_EXT2=n
|
||||||
BR2_TARGET_ROOTFS_INITRAMFS=y
|
BR2_TARGET_ROOTFS_INITRAMFS=y
|
||||||
" >> br2_cli.gitignore
|
" >> "$br2_cli_file"
|
||||||
;;
|
;;
|
||||||
i)
|
i)
|
||||||
echo "
|
echo "
|
||||||
BR2_TARGET_ROOTFS_CPIO=y
|
BR2_TARGET_ROOTFS_CPIO=y
|
||||||
BR2_TARGET_ROOTFS_EXT2=n
|
BR2_TARGET_ROOTFS_EXT2=n
|
||||||
BR2_TARGET_ROOTFS_INITRAMFS=n
|
BR2_TARGET_ROOTFS_INITRAMFS=n
|
||||||
" >> br2_cli.gitignore
|
" >> "$br2_cli_file"
|
||||||
;;
|
;;
|
||||||
j)
|
j)
|
||||||
echo "$OPTARG" >> br2_cli.gitignore
|
j="$OPTARG"
|
||||||
;;
|
;;
|
||||||
K)
|
K)
|
||||||
linux_kernel_custom_config_file="$OPTARG"
|
linux_kernel_custom_config_file="$OPTARG"
|
||||||
@@ -106,40 +107,40 @@ case "$arch" in
|
|||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
if ! "$gem5"; then
|
if ! "$gem5"; then
|
||||||
config_fragments="$config_fragments br2_qemu"
|
config_fragments="$config_fragments ${root_dir}/br2_qemu"
|
||||||
fi
|
fi
|
||||||
config_fragments="$config_fragments br2_cli.gitignore"
|
config_fragments="${config_fragments} ${br2_cli_file}"
|
||||||
|
|
||||||
# Configure.
|
# Configure.
|
||||||
if "$configure"; then
|
if "$configure"; then
|
||||||
cd "${buildroot_dir}"
|
cd "${buildroot_dir}"
|
||||||
for p in $(find "${root_dir}/buildroot_patches/" -maxdepth 1 -name '*.patch' -print); do
|
for p in $(find "${root_dir}/buildroot_patches/" -maxdepth 1 -name '*.patch' -print); do
|
||||||
patch -N -r - -p 1 <"$p" || :
|
patch -N -r - -p 1 < "$p" || :
|
||||||
done
|
done
|
||||||
make O="$buildroot_out_dir" BR2_EXTERNAL="../kernel_module:../gem5:../parsec-benchmark:../sample_package" "$defconfig"
|
make O="$buildroot_out_dir" BR2_EXTERNAL="../kernel_module:../gem5:../parsec-benchmark:../sample_package" "$defconfig"
|
||||||
# TODO Can't get rid of these for now.
|
# TODO Can't get rid of these for now.
|
||||||
# http://stackoverflow.com/questions/44078245/is-it-possible-to-use-config-fragments-with-buildroots-config
|
# http://stackoverflow.com/questions/44078245/is-it-possible-to-use-config-fragments-with-buildroots-config
|
||||||
for config_fragment in $config_fragments; do
|
for config_fragment in $config_fragments; do
|
||||||
cat "../$config_fragment" >> "${config_file}"
|
cat "$config_fragment" >> "$config_file"
|
||||||
done
|
done
|
||||||
printf "
|
printf "
|
||||||
BR2_JLEVEL=$j
|
BR2_JLEVEL=${j}
|
||||||
BR2_DL_DIR=\"${common_dir}/dl\"
|
BR2_DL_DIR=\"${common_dir}/dl\"
|
||||||
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}"
|
printf "BR2_PACKAGE_GEM5=y\n" >> "${config_file}"
|
||||||
if [ -z "$linux_kernel_custom_config_file" ] && [ ! "$arch" = aarch64 ]; then
|
if [ -z "$linux_kernel_custom_config_file" ] && [ ! "$arch" = aarch64 ]; then
|
||||||
f="../kernel_config_${arch_dir}"
|
f="../kernel_config_${arch_dir}"
|
||||||
if [ -f "$f" ]; then
|
if [ -f "$f" ]; then
|
||||||
printf "BR2_LINUX_KERNEL_CUSTOM_CONFIG_FILE=\"$f\"\n" >> "${config_file}"
|
printf "BR2_LINUX_KERNEL_CUSTOM_CONFIG_FILE=\"$f\"\n" >> "$config_file"
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
if [ -n "$linux_kernel_custom_config_file" ]; then
|
if [ -n "$linux_kernel_custom_config_file" ]; then
|
||||||
f="../${linux_kernel_custom_config_file}"
|
f="../${linux_kernel_custom_config_file}"
|
||||||
if [ -f "$f" ]; then
|
if [ -f "$f" ]; then
|
||||||
printf "BR2_LINUX_KERNEL_CUSTOM_CONFIG_FILE=\"${f}\"\n" >> "${config_file}"
|
printf "BR2_LINUX_KERNEL_CUSTOM_CONFIG_FILE=\"${f}\"\n" >> "$config_file"
|
||||||
if "${linux_reconfigure}"; then
|
if "${linux_reconfigure}"; then
|
||||||
touch "$f"
|
touch "$f"
|
||||||
fi
|
fi
|
||||||
@@ -149,7 +150,7 @@ BR2_ROOTFS_POST_SCRIPT_ARGS=\"$post_script_args\"
|
|||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
f=../kernel_config_fragment
|
f=../kernel_config_fragment
|
||||||
printf "BR2_LINUX_KERNEL_CONFIG_FRAGMENT_FILES=\"${f}\"\n" >> "${config_file}"
|
printf "BR2_LINUX_KERNEL_CONFIG_FRAGMENT_FILES=\"${f}\"\n" >> "$config_file"
|
||||||
if "${linux_reconfigure}"; then
|
if "${linux_reconfigure}"; then
|
||||||
# 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
|
||||||
touch "$f"
|
touch "$f"
|
||||||
@@ -158,17 +159,17 @@ BR2_ROOTFS_POST_SCRIPT_ARGS=\"$post_script_args\"
|
|||||||
if [ "$arch" = 'mips64' ]; then
|
if [ "$arch" = 'mips64' ]; then
|
||||||
# Workaround for:
|
# Workaround for:
|
||||||
# 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
|
||||||
make O="$buildroot_out_dir" olddefconfig
|
make O="$buildroot_out_dir" olddefconfig
|
||||||
fi
|
fi
|
||||||
|
|
||||||
mkdir -p \
|
mkdir -p \
|
||||||
"${gem5_out_dir}" \
|
"$gem5_out_dir" \
|
||||||
"${qemu_out_dir}" \
|
"$qemu_out_dir" \
|
||||||
"${p9_dir}" \
|
"$p9_dir" \
|
||||||
;
|
;
|
||||||
cd "${buildroot_dir}"
|
cd "$buildroot_dir"
|
||||||
# HOST_QEMU_OPTS is a hack that happens to work because the QEMU package luckly uses += at all times.
|
# 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
|
# It shouldn't be necessary in the first place: https://bugs.busybox.net/show_bug.cgi?id=9936
|
||||||
#
|
#
|
||||||
@@ -187,4 +188,4 @@ V='${v}' \\
|
|||||||
${extra_make_args} \
|
${extra_make_args} \
|
||||||
all \\
|
all \\
|
||||||
"
|
"
|
||||||
./eeval "$cmd" "${out_arch_dir}/build.sh"
|
"${root_dir}/eeval" "$cmd" "${out_arch_dir}/build.sh"
|
||||||
|
|||||||
3
common
3
common
@@ -1,4 +1,7 @@
|
|||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
|
common_abspath() (
|
||||||
|
echo "$(cd "$(dirname "$1")"; pwd)/$(basename "$1")"
|
||||||
|
)
|
||||||
common_bench_cmd() (
|
common_bench_cmd() (
|
||||||
# Benchmark a command.
|
# Benchmark a command.
|
||||||
#
|
#
|
||||||
|
|||||||
2
run
2
run
@@ -296,4 +296,4 @@ if "$tmux"; then
|
|||||||
eval "./tmu 'sleep 2;./gem5-shell'"
|
eval "./tmu 'sleep 2;./gem5-shell'"
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
./eeval "$cmd" "${out_arch_dir}/run.sh"
|
"${root_dir}/eeval" "$cmd" "${out_arch_dir}/run.sh"
|
||||||
|
|||||||
Reference in New Issue
Block a user