annotate src/makefile-armclang @ 18:d058830337d9

fix llvm arm cpu setting
author kono
date Mon, 05 Mar 2018 19:31:28 +0900
parents c0f6f3eb25ae
children 33c9000056b5
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
1 # specify path to QEMU, installed with MacPorts
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
2 QEMU = qemu-system-arm
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
3
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
4 include makefile.inc
18
d058830337d9 fix llvm arm cpu setting
kono
parents: 17
diff changeset
5 CPU = armv6
14
02a1ce33746e armclang
mir3636
parents: 13
diff changeset
6 CC = /usr/local/cbclang/bin/clang
02a1ce33746e armclang
mir3636
parents: 13
diff changeset
7 AS = arm-linux-gnu-as
02a1ce33746e armclang
mir3636
parents: 13
diff changeset
8 LD = arm-linux-gnu-ld
02a1ce33746e armclang
mir3636
parents: 13
diff changeset
9 OBJCOPY = arm-linux-gnu-objcopy
02a1ce33746e armclang
mir3636
parents: 13
diff changeset
10 OBJDUMP = arm-linux-gnu-objdump
02a1ce33746e armclang
mir3636
parents: 13
diff changeset
11
02a1ce33746e armclang
mir3636
parents: 13
diff changeset
12 # CFLAGS = -march=armv6 -fno-pic -static -fno-builtin -fno-strict-aliasing -Wall -Werror -I. -g -O0
18
d058830337d9 fix llvm arm cpu setting
kono
parents: 17
diff changeset
13 CFLAGS = -target arm-linux-gnueabihf -march=${CPU} -fno-pic -static -fno-builtin -fno-strict-aliasing -Wall -I. -I ../cbclang/arm -g -O0
16
7eb81a3c4b29 kernel.elf
tobaru
parents: 14
diff changeset
14 LDFLAGS = --noinhibit-exec
14
02a1ce33746e armclang
mir3636
parents: 13
diff changeset
15 # ASFLAGS = -march=armv6
16
7eb81a3c4b29 kernel.elf
tobaru
parents: 14
diff changeset
16 ASFLAGS = -target arm-linux-gnueabihf
14
02a1ce33746e armclang
mir3636
parents: 13
diff changeset
17
16
7eb81a3c4b29 kernel.elf
tobaru
parents: 14
diff changeset
18 LIBGCC = $(shell $(CC) $(CFLAGS) -print-libgcc-file-name)
0
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
19
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
20 # link the libgcc.a for __aeabi_idiv. ARM has no native support for div
16
7eb81a3c4b29 kernel.elf
tobaru
parents: 14
diff changeset
21 LIBS =/net/open/RaspberryPi/rasbian-img/usr/lib/gcc/arm-linux-gnueabihf/6/libgcc.a
7eb81a3c4b29 kernel.elf
tobaru
parents: 14
diff changeset
22
0
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
23
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
24 OBJS = \
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
25 lib/string.o \
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
26 \
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
27 arm.o\
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
28 asm.o\
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
29 bio.o\
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
30 buddy.o\
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
31 console.o\
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
32 exec.o\
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
33 file.o\
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
34 fs.o\
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
35 log.o\
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
36 main.o\
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
37 memide.o\
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
38 pipe.o\
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
39 proc.o\
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
40 spinlock.o\
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
41 start.o\
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
42 swtch.o\
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
43 syscall.o\
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
44 sysfile.o\
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
45 sysproc.o\
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
46 trap_asm.o\
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
47 trap.o\
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
48 vm.o \
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
49 \
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
50 device/picirq.o \
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
51 device/timer.o \
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
52 device/uart.o
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
53
13
f28daf1e47c1 clang-arm
mir3636
parents: 0
diff changeset
54 KERN_OBJS = $(OBJS) entry-clang.o
f28daf1e47c1 clang-arm
mir3636
parents: 0
diff changeset
55 kernel.elf: $(addprefix build/,$(KERN_OBJS)) kernel-clang.ld build/initcode build/fs.img
0
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
56 cp -f build/initcode initcode
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
57 cp -f build/fs.img fs.img
13
f28daf1e47c1 clang-arm
mir3636
parents: 0
diff changeset
58 $(call LINK_BIN, kernel-clang.ld, kernel.elf, \
0
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
59 $(addprefix build/,$(KERN_OBJS)), \
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
60 initcode fs.img)
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
61 $(OBJDUMP) -S kernel.elf > kernel.asm
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
62 $(OBJDUMP) -t kernel.elf | sed '1,/SYMBOL TABLE/d; s/ .* / /; /^$$/d' > kernel.sym
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
63 rm -f initcode fs.img
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
64
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
65 qemu: kernel.elf
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
66 @clear
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
67 @echo "Press Ctrl-A and then X to terminate QEMU session\n"
17
c0f6f3eb25ae argccbc
kono
parents: 16
diff changeset
68 export QEMU_AUDIO_DRV=none ; $(QEMU) -M versatilepb -m 128 -cpu arm1176 -nographic -soundhw hda -kernel kernel.elf
c0f6f3eb25ae argccbc
kono
parents: 16
diff changeset
69
c0f6f3eb25ae argccbc
kono
parents: 16
diff changeset
70 qemu-debug : kernel.elf
c0f6f3eb25ae argccbc
kono
parents: 16
diff changeset
71 @clear
c0f6f3eb25ae argccbc
kono
parents: 16
diff changeset
72 @echo "Press Ctrl-A and then X to terminate QEMU session\n"
c0f6f3eb25ae argccbc
kono
parents: 16
diff changeset
73 export QEMU_AUDIO_DRV=none ; $(QEMU) -M versatilepb -m 128 -cpu arm1176 -nographic -singlestep -d exec,cpu,guest_errors -D qemu.log -kernel kernel.elf -s -S
0
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
74
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
75 INITCODE_OBJ = initcode.o
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
76 $(addprefix build/,$(INITCODE_OBJ)): initcode.S
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
77 $(call build-directory)
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
78 $(call AS_WITH, -nostdinc -I.)
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
79
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
80 #initcode is linked into the kernel, it will be used to craft the first process
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
81 build/initcode: $(addprefix build/,$(INITCODE_OBJ))
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
82 $(call LINK_INIT, -N -e start -Ttext 0)
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
83 $(call OBJCOPY_INIT)
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
84 $(OBJDUMP) -S $< > initcode.asm
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
85
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
86 build/fs.img:
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
87 make -C tools
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
88 make -C usr
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
89
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
90 clean:
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
91 rm -rf build
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
92 rm -f *.o *.d *.asm *.sym vectors.S bootblock entryother \
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
93 initcode initcode.out kernel xv6.img fs.img kernel.elf memfs
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
94 make -C tools clean
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents:
diff changeset
95 make -C usr clean