forked from heshamelmatary/sel4test
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMakefile
127 lines (105 loc) · 3.75 KB
/
Makefile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
#
# Copyright 2014, NICTA
#
# This software may be distributed and modified according to the terms of
# the BSD 2-Clause license. Note that NO WARRANTY is provided.
# See "LICENSE_BSD2.txt" for details.
#
# @TAG(NICTA_BSD)
#
lib-dirs:=libs
# The main target we want to generate
all: app-images
-include .config
include tools/common/project.mk
# tests to run
ifeq (${TEST}y,y)
TEST=".*"
endif
# objdump args
ifeq (${OBJFLAGS}y,y)
OBJFLAGS="Dlx"
endif
# test that all configs compile
compile-all:
${PWD}/projects/sel4test/tools/compile-all.sh
# objdump the kernel image
objdump-kernel:
${CONFIG_CROSS_COMPILER_PREFIX}objdump -${OBJFLAGS} stage/${ARCH}/${PLAT}/kernel.elf
# objdump driver app
objdump-driver:
${CONFIG_CROSS_COMPILER_PREFIX}objdump -${OBJFLAGS} stage/${ARCH}/${PLAT}/bin/sel4test-driver
# objdump tests app
objdump-tests:
${CONFIG_CROSS_COMPILER_PREFIX}objdump -${OBJFLAGS} stage/${ARCH}/${PLAT}/bin/sel4test-tests
# pick a test or subset of tests to run
# usage: make select-test TEST=<regexp>
select-test:
sed -i "s/CONFIG_TESTPRINTER_REGEX=\".*\"/CONFIG_TESTPRINTER_REGEX=\"${TEST}\"/" .config
@echo "Selected test ${TEST}"
# Some example qemu invocations
# note: this relies on qemu after version 2.0
simulate-kzm:
qemu-system-arm -nographic -M kzm \
-kernel images/${apps}-image-arm-imx31
# This relies on a helper script to build a bootable image
simulate-beagle:
beagle_run_elf images/${apps}-image-arm-omap3
simulate-ia32:
qemu-system-i386 \
-m 512 -nographic -kernel images/kernel-ia32-pc99 \
-initrd images/${apps}-image-ia32-pc99
simulate-x86_64:
qemu-system-x86_64 \
-m 512 -nographic -kernel images/kernel-x86_64-pc99 \
-initrd images/sel4test-driver-image-x86_64-pc99 -cpu Haswell
simulate-sabre:
qemu-system-arm \
-machine sabrelite -nographic -m size=1024M \
-s -serial null -serial mon:stdio \
-kernel images/${apps}-image-arm-imx6
simulate-zynq:
qemu-system-arm \
-machine xilinx-zynq-a9 -nographic -m size=1024M \
-s -serial null -serial mon:stdio \
-kernel images/${apps}-image-arm-zynq7000
simulate-wandq:
qemu-system-arm \
-machine sabrelite -nographic -m size=2048M \
-s -serial mon:stdio \
-kernel images/${apps}-image-arm-imx6
simulate-spike:
qemu-system-riscv64 \
-nographic -m size=4096M \
-s -serial mon:stdio \
-kernel images/${apps}-image-riscv-spike
# Some example image builds (NOTE: may need to adapt addresses)
build-binary: images/${apps}-image-${ARCH}-${PLAT}
${CONFIG_CROSS_COMPILER_PREFIX}objcopy -O binary \
images/${apps}-image-${ARCH}-${PLAT} images/sel4test.bin
@echo "1. put file images/sel4test.bin into SD card root directory"
@echo "2. At U-Boot prompt, enter:"
@echo " > mmc dev 1"
@echo " > ext2load mmc ${disk}:1 20000000 sel4test.bin"
@echo " > go 20000000"
build-uImage: images/${apps}-image-${ARCH}-${PLAT}
mkimage -A arm -a 0x30000000 -e 0x30000000 -C none \
-A ${ARCH} -T kernel -O qnx \
-d images/${apps}-image-${ARCH}-${PLAT} images/sel4test.uImage
@echo "1. put file images/sel4test.uImage into SD card root directory"
@echo "2. At U-Boot prompt, enter:"
@echo " > mmc dev 1"
@echo " > ext2load mmc ${disk}:1 10800000 sel4test.uImage"
@echo " > bootm 10800000"
.PHONY: help
help:
@echo "sel4test - unit and regression tests for seL4"
@echo " make menuconfig - Select build configuration via menus."
@echo " make <defconfig> - Apply one of the default configurations. See"
@echo " below for valid configurations."
@echo " make silentoldconfig - Update configuration with the defaults of any"
@echo " newly introduced settings."
@echo " make - Build with the current configuration."
@echo ""
@echo "Valid default configurations are:"
@ls -1 configs | sed -e 's/\(.*\)/\t\1/g'