mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-03 19:55:31 +00:00
Merge branch 'local-vmtest-enhancement-and-rv64-enabled'
Pu Lehui says: ==================== Local vmtest enhancement and RV64 enabled Patch 1-3 fix some problem about bpf selftests. Patch 4 add local rootfs image support for vmtest. Patch 5 enable cross-platform testing for vmtest. Patch 6-10 enable vmtest on RV64. We can now perform cross platform testing for riscv64 bpf using the following command: PLATFORM=riscv64 CROSS_COMPILE=riscv64-linux-gnu- \ tools/testing/selftests/bpf/vmtest.sh \ -l <path of local rootfs image> -- \ ./test_progs -d \ \"$(cat tools/testing/selftests/bpf/DENYLIST.riscv64 \ | cut -d'#' -f1 \ | sed -e 's/^[[:space:]]*//' \ -e 's/[[:space:]]*$//' \ | tr -s '\n' ',' \ )\" For better regression, we rely on commit [0]. And since the work of riscv ftrace to remove stop_machine atomic replacement is in progress, we also need to revert commit [1] [2]. The test platform is x86_64 architecture, and the versions of relevant components are as follows: QEMU: 8.2.0 CLANG: 17.0.6 (align to BPF CI) ROOTFS: ubuntu noble (generated by [3]) Link: https://lore.kernel.org/all/20240831071520.1630360-1-pulehui@huaweicloud.com/ [0] Link: https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?id=3308172276db [1] Link: https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?id=7caa9765465f [2] Link: https://github.com/libbpf/ci/blob/main/rootfs/mkrootfs_debian.sh [3] v3: - Use llvm static linking when detecting that feature-llvm is enabled - Add Acked-by by Eduard v2: https://lore.kernel.org/all/20240904141951.1139090-1-pulehui@huaweicloud.com/ - Drop patch about relaxing Zbb insns restrictions. - Add local rootfs image support - Add description about running vmtest on RV64 - Fix some problem about bpf selftests v1: https://lore.kernel.org/all/20240328124916.293173-1-pulehui@huaweicloud.com/ ==================== Acked-by: Daniel Borkmann <daniel@iogearbox.net> Tested-by: Daniel Borkmann <daniel@iogearbox.net> Link: https://lore.kernel.org/r/20240905081401.1894789-1-pulehui@huaweicloud.com Signed-off-by: Alexei Starovoitov <ast@kernel.org>
This commit is contained in:
commit
b9d32677ff
3
tools/testing/selftests/bpf/DENYLIST.riscv64
Normal file
3
tools/testing/selftests/bpf/DENYLIST.riscv64
Normal file
@ -0,0 +1,3 @@
|
||||
# riscv64 deny list for BPF CI and local vmtest
|
||||
exceptions # JIT does not support exceptions
|
||||
tailcalls/tailcall_bpf2bpf* # JIT does not support mixing bpf2bpf and tailcalls
|
@ -187,8 +187,14 @@ FEATURE_TESTS := llvm
|
||||
FEATURE_DISPLAY := $(FEATURE_TESTS)
|
||||
|
||||
# Makefile.feature expects OUTPUT to end with a slash
|
||||
ifeq ($(shell expr $(MAKE_VERSION) \>= 4.4), 1)
|
||||
$(let OUTPUT,$(OUTPUT)/,\
|
||||
$(eval include ../../../build/Makefile.feature))
|
||||
else
|
||||
OUTPUT := $(OUTPUT)/
|
||||
$(eval include ../../../build/Makefile.feature)
|
||||
OUTPUT := $(patsubst %/,%,$(OUTPUT))
|
||||
endif
|
||||
endif
|
||||
|
||||
ifeq ($(feature-llvm),1)
|
||||
@ -196,11 +202,9 @@ ifeq ($(feature-llvm),1)
|
||||
LLVM_CONFIG_LIB_COMPONENTS := mcdisassembler all-targets
|
||||
# both llvm-config and lib.mk add -D_GNU_SOURCE, which ends up as conflict
|
||||
LLVM_CFLAGS += $(filter-out -D_GNU_SOURCE,$(shell $(LLVM_CONFIG) --cflags))
|
||||
LLVM_LDLIBS += $(shell $(LLVM_CONFIG) --libs $(LLVM_CONFIG_LIB_COMPONENTS))
|
||||
ifeq ($(shell $(LLVM_CONFIG) --shared-mode),static)
|
||||
LLVM_LDLIBS += $(shell $(LLVM_CONFIG) --system-libs $(LLVM_CONFIG_LIB_COMPONENTS))
|
||||
LLVM_LDLIBS += -lstdc++
|
||||
endif
|
||||
LLVM_LDLIBS += $(shell $(LLVM_CONFIG) --link-static --libs $(LLVM_CONFIG_LIB_COMPONENTS))
|
||||
LLVM_LDLIBS += $(shell $(LLVM_CONFIG) --link-static --system-libs $(LLVM_CONFIG_LIB_COMPONENTS))
|
||||
LLVM_LDLIBS += -lstdc++
|
||||
LLVM_LDFLAGS += $(shell $(LLVM_CONFIG) --ldflags)
|
||||
endif
|
||||
|
||||
|
@ -85,7 +85,37 @@ In case of linker errors when running selftests, try using static linking:
|
||||
If you want to change pahole and llvm, you can change `PATH` environment
|
||||
variable in the beginning of script.
|
||||
|
||||
.. note:: The script currently only supports x86_64 and s390x architectures.
|
||||
Running vmtest on RV64
|
||||
======================
|
||||
To speed up testing and avoid various dependency issues, it is recommended to
|
||||
run vmtest in a Docker container. Before running vmtest, we need to prepare
|
||||
Docker container and local rootfs image. The overall steps are as follows:
|
||||
|
||||
1. Create Docker container as shown in link [0].
|
||||
|
||||
2. Use mkrootfs_debian.sh script [1] to build local rootfs image:
|
||||
|
||||
.. code-block:: console
|
||||
|
||||
$ sudo ./mkrootfs_debian.sh --arch riscv64 --distro noble
|
||||
|
||||
3. Start Docker container [0] and run vmtest in the container:
|
||||
|
||||
.. code-block:: console
|
||||
|
||||
$ PLATFORM=riscv64 CROSS_COMPILE=riscv64-linux-gnu- \
|
||||
tools/testing/selftests/bpf/vmtest.sh \
|
||||
-l <path of local rootfs image> -- \
|
||||
./test_progs -d \
|
||||
\"$(cat tools/testing/selftests/bpf/DENYLIST.riscv64 \
|
||||
| cut -d'#' -f1 \
|
||||
| sed -e 's/^[[:space:]]*//' \
|
||||
-e 's/[[:space:]]*$//' \
|
||||
| tr -s '\n' ',' \
|
||||
)\"
|
||||
|
||||
Link: https://github.com/pulehui/riscv-bpf-vmtest.git [0]
|
||||
Link: https://github.com/libbpf/ci/blob/main/rootfs/mkrootfs_debian.sh [1]
|
||||
|
||||
Additional information about selftest failures are
|
||||
documented here.
|
||||
|
84
tools/testing/selftests/bpf/config.riscv64
Normal file
84
tools/testing/selftests/bpf/config.riscv64
Normal file
@ -0,0 +1,84 @@
|
||||
CONFIG_AUDIT=y
|
||||
CONFIG_BLK_CGROUP=y
|
||||
CONFIG_BLK_DEV_INITRD=y
|
||||
CONFIG_BLK_DEV_RAM=y
|
||||
CONFIG_BONDING=y
|
||||
CONFIG_BPF_JIT_ALWAYS_ON=y
|
||||
CONFIG_BPF_PRELOAD=y
|
||||
CONFIG_BPF_PRELOAD_UMD=y
|
||||
CONFIG_CGROUPS=y
|
||||
CONFIG_CGROUP_CPUACCT=y
|
||||
CONFIG_CGROUP_DEVICE=y
|
||||
CONFIG_CGROUP_FREEZER=y
|
||||
CONFIG_CGROUP_HUGETLB=y
|
||||
CONFIG_CGROUP_NET_CLASSID=y
|
||||
CONFIG_CGROUP_PERF=y
|
||||
CONFIG_CGROUP_PIDS=y
|
||||
CONFIG_CGROUP_SCHED=y
|
||||
CONFIG_CPUSETS=y
|
||||
CONFIG_DEBUG_ATOMIC_SLEEP=y
|
||||
CONFIG_DEBUG_FS=y
|
||||
CONFIG_DETECT_HUNG_TASK=y
|
||||
CONFIG_DEVTMPFS=y
|
||||
CONFIG_DEVTMPFS_MOUNT=y
|
||||
CONFIG_EXPERT=y
|
||||
CONFIG_EXT4_FS=y
|
||||
CONFIG_EXT4_FS_POSIX_ACL=y
|
||||
CONFIG_EXT4_FS_SECURITY=y
|
||||
CONFIG_FRAME_POINTER=y
|
||||
CONFIG_HARDLOCKUP_DETECTOR=y
|
||||
CONFIG_HIGH_RES_TIMERS=y
|
||||
CONFIG_HUGETLBFS=y
|
||||
CONFIG_INET=y
|
||||
CONFIG_IPV6_SEG6_LWTUNNEL=y
|
||||
CONFIG_IP_ADVANCED_ROUTER=y
|
||||
CONFIG_IP_MULTICAST=y
|
||||
CONFIG_IP_MULTIPLE_TABLES=y
|
||||
CONFIG_JUMP_LABEL=y
|
||||
CONFIG_KALLSYMS_ALL=y
|
||||
CONFIG_KPROBES=y
|
||||
CONFIG_MEMCG=y
|
||||
CONFIG_NAMESPACES=y
|
||||
CONFIG_NET=y
|
||||
CONFIG_NETDEVICES=y
|
||||
CONFIG_NETFILTER_XT_MATCH_BPF=y
|
||||
CONFIG_NET_ACT_BPF=y
|
||||
CONFIG_NET_L3_MASTER_DEV=y
|
||||
CONFIG_NET_VRF=y
|
||||
CONFIG_NONPORTABLE=y
|
||||
CONFIG_NO_HZ_IDLE=y
|
||||
CONFIG_NR_CPUS=256
|
||||
CONFIG_PACKET=y
|
||||
CONFIG_PANIC_ON_OOPS=y
|
||||
CONFIG_PARTITION_ADVANCED=y
|
||||
CONFIG_PCI=y
|
||||
CONFIG_PCI_HOST_GENERIC=y
|
||||
CONFIG_POSIX_MQUEUE=y
|
||||
CONFIG_PRINTK_TIME=y
|
||||
CONFIG_PROC_KCORE=y
|
||||
CONFIG_PROFILING=y
|
||||
CONFIG_RCU_CPU_STALL_TIMEOUT=60
|
||||
CONFIG_RISCV_EFFICIENT_UNALIGNED_ACCESS=y
|
||||
CONFIG_RISCV_ISA_C=y
|
||||
CONFIG_RISCV_PMU=y
|
||||
CONFIG_RISCV_PMU_SBI=y
|
||||
CONFIG_RT_GROUP_SCHED=y
|
||||
CONFIG_SECURITY_NETWORK=y
|
||||
CONFIG_SERIAL_8250=y
|
||||
CONFIG_SERIAL_8250_CONSOLE=y
|
||||
CONFIG_SERIAL_OF_PLATFORM=y
|
||||
CONFIG_SMP=y
|
||||
CONFIG_SOC_VIRT=y
|
||||
CONFIG_SYSVIPC=y
|
||||
CONFIG_TCP_CONG_ADVANCED=y
|
||||
CONFIG_TLS=y
|
||||
CONFIG_TMPFS=y
|
||||
CONFIG_TMPFS_POSIX_ACL=y
|
||||
CONFIG_TUN=y
|
||||
CONFIG_UNIX=y
|
||||
CONFIG_UPROBES=y
|
||||
CONFIG_USER_NS=y
|
||||
CONFIG_VETH=y
|
||||
CONFIG_VLAN_8021Q=y
|
||||
CONFIG_VSOCKETS_LOOPBACK=y
|
||||
CONFIG_XFRM_USER=y
|
@ -285,7 +285,7 @@ static void test_dctcp_fallback(void)
|
||||
dctcp_skel = bpf_dctcp__open();
|
||||
if (!ASSERT_OK_PTR(dctcp_skel, "dctcp_skel"))
|
||||
return;
|
||||
strcpy(dctcp_skel->rodata->fallback, "cubic");
|
||||
strcpy(dctcp_skel->rodata->fallback_cc, "cubic");
|
||||
if (!ASSERT_OK(bpf_dctcp__load(dctcp_skel), "bpf_dctcp__load"))
|
||||
goto done;
|
||||
|
||||
|
@ -26,7 +26,7 @@ static bool before(__u32 seq1, __u32 seq2)
|
||||
|
||||
char _license[] SEC("license") = "GPL";
|
||||
|
||||
volatile const char fallback[TCP_CA_NAME_MAX];
|
||||
volatile const char fallback_cc[TCP_CA_NAME_MAX];
|
||||
const char bpf_dctcp[] = "bpf_dctcp";
|
||||
const char tcp_cdg[] = "cdg";
|
||||
char cc_res[TCP_CA_NAME_MAX];
|
||||
@ -71,10 +71,10 @@ void BPF_PROG(bpf_dctcp_init, struct sock *sk)
|
||||
struct bpf_dctcp *ca = inet_csk_ca(sk);
|
||||
int *stg;
|
||||
|
||||
if (!(tp->ecn_flags & TCP_ECN_OK) && fallback[0]) {
|
||||
if (!(tp->ecn_flags & TCP_ECN_OK) && fallback_cc[0]) {
|
||||
/* Switch to fallback */
|
||||
if (bpf_setsockopt(sk, SOL_TCP, TCP_CONGESTION,
|
||||
(void *)fallback, sizeof(fallback)) == -EBUSY)
|
||||
(void *)fallback_cc, sizeof(fallback_cc)) == -EBUSY)
|
||||
ebusy_cnt++;
|
||||
|
||||
/* Switch back to myself and the recurred bpf_dctcp_init()
|
||||
@ -87,7 +87,7 @@ void BPF_PROG(bpf_dctcp_init, struct sock *sk)
|
||||
|
||||
/* Switch back to fallback */
|
||||
if (bpf_setsockopt(sk, SOL_TCP, TCP_CONGESTION,
|
||||
(void *)fallback, sizeof(fallback)) == -EBUSY)
|
||||
(void *)fallback_cc, sizeof(fallback_cc)) == -EBUSY)
|
||||
ebusy_cnt++;
|
||||
|
||||
/* Expecting -ENOTSUPP for tcp_cdg_res */
|
||||
|
@ -1,31 +1,47 @@
|
||||
#!/bin/bash
|
||||
# SPDX-License-Identifier: GPL-2.0
|
||||
|
||||
set -u
|
||||
set -e
|
||||
|
||||
# This script currently only works for x86_64 and s390x, as
|
||||
# it is based on the VM image used by the BPF CI, which is
|
||||
# available only for these architectures.
|
||||
ARCH="$(uname -m)"
|
||||
case "${ARCH}" in
|
||||
# This script currently only works for the following platforms,
|
||||
# as it is based on the VM image used by the BPF CI, which is
|
||||
# available only for these architectures. We can also specify
|
||||
# the local rootfs image generated by the following script:
|
||||
# https://github.com/libbpf/ci/blob/main/rootfs/mkrootfs_debian.sh
|
||||
PLATFORM="${PLATFORM:-$(uname -m)}"
|
||||
case "${PLATFORM}" in
|
||||
s390x)
|
||||
QEMU_BINARY=qemu-system-s390x
|
||||
QEMU_CONSOLE="ttyS1"
|
||||
QEMU_FLAGS=(-smp 2)
|
||||
HOST_FLAGS=(-smp 2 -enable-kvm)
|
||||
CROSS_FLAGS=(-smp 2)
|
||||
BZIMAGE="arch/s390/boot/vmlinux"
|
||||
ARCH="s390"
|
||||
;;
|
||||
x86_64)
|
||||
QEMU_BINARY=qemu-system-x86_64
|
||||
QEMU_CONSOLE="ttyS0,115200"
|
||||
QEMU_FLAGS=(-cpu host -smp 8)
|
||||
HOST_FLAGS=(-cpu host -enable-kvm -smp 8)
|
||||
CROSS_FLAGS=(-smp 8)
|
||||
BZIMAGE="arch/x86/boot/bzImage"
|
||||
ARCH="x86"
|
||||
;;
|
||||
aarch64)
|
||||
QEMU_BINARY=qemu-system-aarch64
|
||||
QEMU_CONSOLE="ttyAMA0,115200"
|
||||
QEMU_FLAGS=(-M virt,gic-version=3 -cpu host -smp 8)
|
||||
HOST_FLAGS=(-M virt,gic-version=3 -cpu host -enable-kvm -smp 8)
|
||||
CROSS_FLAGS=(-M virt,gic-version=3 -cpu cortex-a76 -smp 8)
|
||||
BZIMAGE="arch/arm64/boot/Image"
|
||||
ARCH="arm64"
|
||||
;;
|
||||
riscv64)
|
||||
# required qemu version v7.2.0+
|
||||
QEMU_BINARY=qemu-system-riscv64
|
||||
QEMU_CONSOLE="ttyS0,115200"
|
||||
HOST_FLAGS=(-M virt -cpu host -enable-kvm -smp 8)
|
||||
CROSS_FLAGS=(-M virt -cpu rv64,sscofpmf=true -smp 8)
|
||||
BZIMAGE="arch/riscv/boot/Image"
|
||||
ARCH="riscv"
|
||||
;;
|
||||
*)
|
||||
echo "Unsupported architecture"
|
||||
@ -34,11 +50,12 @@ aarch64)
|
||||
esac
|
||||
DEFAULT_COMMAND="./test_progs"
|
||||
MOUNT_DIR="mnt"
|
||||
LOCAL_ROOTFS_IMAGE=""
|
||||
ROOTFS_IMAGE="root.img"
|
||||
OUTPUT_DIR="$HOME/.bpf_selftests"
|
||||
KCONFIG_REL_PATHS=("tools/testing/selftests/bpf/config"
|
||||
"tools/testing/selftests/bpf/config.vm"
|
||||
"tools/testing/selftests/bpf/config.${ARCH}")
|
||||
"tools/testing/selftests/bpf/config.${PLATFORM}")
|
||||
INDEX_URL="https://raw.githubusercontent.com/libbpf/ci/master/INDEX"
|
||||
NUM_COMPILE_JOBS="$(nproc)"
|
||||
LOG_FILE_BASE="$(date +"bpf_selftests.%Y-%m-%d_%H-%M-%S")"
|
||||
@ -58,6 +75,10 @@ tools/testing/selftests/bpf. e.g:
|
||||
If no command is specified and a debug shell (-s) is not requested,
|
||||
"${DEFAULT_COMMAND}" will be run by default.
|
||||
|
||||
Using PLATFORM= and CROSS_COMPILE= options will enable cross platform testing:
|
||||
|
||||
PLATFORM=<platform> CROSS_COMPILE=<toolchain> $0 -- ./test_progs -t test_lsm
|
||||
|
||||
If you build your kernel using KBUILD_OUTPUT= or O= options, these
|
||||
can be passed as environment variables to the script:
|
||||
|
||||
@ -69,6 +90,7 @@ or
|
||||
|
||||
Options:
|
||||
|
||||
-l) Specify the path to the local rootfs image.
|
||||
-i) Update the rootfs image with a newer version.
|
||||
-d) Update the output directory (default: ${OUTPUT_DIR})
|
||||
-j) Number of jobs for compilation, similar to -j in make
|
||||
@ -92,9 +114,23 @@ populate_url_map()
|
||||
fi
|
||||
}
|
||||
|
||||
download()
|
||||
newest_rootfs_version()
|
||||
{
|
||||
local file="$1"
|
||||
{
|
||||
for file in "${!URLS[@]}"; do
|
||||
if [[ $file =~ ^"${PLATFORM}"/libbpf-vmtest-rootfs-(.*)\.tar\.zst$ ]]; then
|
||||
echo "${BASH_REMATCH[1]}"
|
||||
fi
|
||||
done
|
||||
} | sort -rV | head -1
|
||||
}
|
||||
|
||||
download_rootfs()
|
||||
{
|
||||
populate_url_map
|
||||
|
||||
local rootfsversion="$(newest_rootfs_version)"
|
||||
local file="${PLATFORM}/libbpf-vmtest-rootfs-$rootfsversion.tar.zst"
|
||||
|
||||
if [[ ! -v URLS[$file] ]]; then
|
||||
echo "$file not found" >&2
|
||||
@ -105,29 +141,20 @@ download()
|
||||
curl -Lsf "${URLS[$file]}" "${@:2}"
|
||||
}
|
||||
|
||||
newest_rootfs_version()
|
||||
load_rootfs()
|
||||
{
|
||||
{
|
||||
for file in "${!URLS[@]}"; do
|
||||
if [[ $file =~ ^"${ARCH}"/libbpf-vmtest-rootfs-(.*)\.tar\.zst$ ]]; then
|
||||
echo "${BASH_REMATCH[1]}"
|
||||
fi
|
||||
done
|
||||
} | sort -rV | head -1
|
||||
}
|
||||
|
||||
download_rootfs()
|
||||
{
|
||||
local rootfsversion="$1"
|
||||
local dir="$2"
|
||||
local dir="$1"
|
||||
|
||||
if ! which zstd &> /dev/null; then
|
||||
echo 'Could not find "zstd" on the system, please install zstd'
|
||||
exit 1
|
||||
fi
|
||||
|
||||
download "${ARCH}/libbpf-vmtest-rootfs-$rootfsversion.tar.zst" |
|
||||
zstd -d | sudo tar -C "$dir" -x
|
||||
if [[ -n "${LOCAL_ROOTFS_IMAGE}" ]]; then
|
||||
cat "${LOCAL_ROOTFS_IMAGE}" | zstd -d | sudo tar -C "$dir" -x
|
||||
else
|
||||
download_rootfs | zstd -d | sudo tar -C "$dir" -x
|
||||
fi
|
||||
}
|
||||
|
||||
recompile_kernel()
|
||||
@ -227,7 +254,7 @@ create_vm_image()
|
||||
mkfs.ext4 -q "${rootfs_img}"
|
||||
|
||||
mount_image
|
||||
download_rootfs "$(newest_rootfs_version)" "${mount_dir}"
|
||||
load_rootfs "${mount_dir}"
|
||||
unmount_image
|
||||
}
|
||||
|
||||
@ -244,12 +271,17 @@ EOF
|
||||
exit 1
|
||||
fi
|
||||
|
||||
if [[ "${PLATFORM}" != "$(uname -m)" ]]; then
|
||||
QEMU_FLAGS=("${CROSS_FLAGS[@]}")
|
||||
else
|
||||
QEMU_FLAGS=("${HOST_FLAGS[@]}")
|
||||
fi
|
||||
|
||||
${QEMU_BINARY} \
|
||||
-nodefaults \
|
||||
-display none \
|
||||
-serial mon:stdio \
|
||||
"${QEMU_FLAGS[@]}" \
|
||||
-enable-kvm \
|
||||
-m 4G \
|
||||
-drive file="${rootfs_img}",format=raw,index=1,media=disk,if=virtio,cache=none \
|
||||
-kernel "${kernel_bzimage}" \
|
||||
@ -341,8 +373,11 @@ main()
|
||||
local exit_command="poweroff -f"
|
||||
local debug_shell="no"
|
||||
|
||||
while getopts ':hskid:j:' opt; do
|
||||
while getopts ':hskl:id:j:' opt; do
|
||||
case ${opt} in
|
||||
l)
|
||||
LOCAL_ROOTFS_IMAGE="$OPTARG"
|
||||
;;
|
||||
i)
|
||||
update_image="yes"
|
||||
;;
|
||||
@ -377,6 +412,11 @@ main()
|
||||
|
||||
trap 'catch "$?"' EXIT
|
||||
|
||||
if [[ "${PLATFORM}" != "$(uname -m)" ]] && [[ -z "${CROSS_COMPILE}" ]]; then
|
||||
echo "Cross-platform testing needs to specify CROSS_COMPILE"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
if [[ $# -eq 0 && "${debug_shell}" == "no" ]]; then
|
||||
echo "No command specified, will run ${DEFAULT_COMMAND} in the vm"
|
||||
else
|
||||
@ -384,7 +424,8 @@ main()
|
||||
fi
|
||||
|
||||
local kconfig_file="${OUTPUT_DIR}/latest.config"
|
||||
local make_command="make -j ${NUM_COMPILE_JOBS} KCONFIG_CONFIG=${kconfig_file}"
|
||||
local make_command="make ARCH=${ARCH} CROSS_COMPILE=${CROSS_COMPILE} \
|
||||
-j ${NUM_COMPILE_JOBS} KCONFIG_CONFIG=${kconfig_file}"
|
||||
|
||||
# Figure out where the kernel is being built.
|
||||
# O takes precedence over KBUILD_OUTPUT.
|
||||
@ -402,8 +443,6 @@ main()
|
||||
make_command="${make_command} KBUILD_OUTPUT=${KBUILD_OUTPUT}"
|
||||
fi
|
||||
|
||||
populate_url_map
|
||||
|
||||
local rootfs_img="${OUTPUT_DIR}/${ROOTFS_IMAGE}"
|
||||
local mount_dir="${OUTPUT_DIR}/${MOUNT_DIR}"
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user