annotate src/makefile-armgccbc @ 54:aa0095c4c2b0

fix cmake linker options
author anatofuz
date Thu, 06 Jun 2019 19:16:22 +0900
parents 36bd61f5c847
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
17
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
1 # specify path to QEMU, installed with MacPorts
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
2 QEMU = qemu-system-arm
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
3
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
4 include makefile.inc
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
5
24
36bd61f5c847 rewrite sys_read cbc
mir3636
parents: 17
diff changeset
6 CC = /mnt/dalmore-home/one/src/armgcc/cross/bin/arm-none-eabi-gcc -B/mnt/dalmore-home/one/src/armgcc/cross/bin/arm-none-eabi-
36bd61f5c847 rewrite sys_read cbc
mir3636
parents: 17
diff changeset
7 #AS = arm-linux-gnu-gcc
36bd61f5c847 rewrite sys_read cbc
mir3636
parents: 17
diff changeset
8 AS = /mnt/dalmore-home/one/src/armgcc/cross/bin/arm-none-eabi-gcc
36bd61f5c847 rewrite sys_read cbc
mir3636
parents: 17
diff changeset
9 #LD = arm-linux-gnu-ld
36bd61f5c847 rewrite sys_read cbc
mir3636
parents: 17
diff changeset
10 LD = /mnt/dalmore-home/one/src/armgcc/cross/bin/arm-none-eabi-ld
36bd61f5c847 rewrite sys_read cbc
mir3636
parents: 17
diff changeset
11 #OBJCOPY = arm-linux-gnu-objcopy
36bd61f5c847 rewrite sys_read cbc
mir3636
parents: 17
diff changeset
12 OBJCOPY = /mnt/dalmore-home/one/src/armgcc/cross/bin/arm-none-eabi-objcopy
36bd61f5c847 rewrite sys_read cbc
mir3636
parents: 17
diff changeset
13 #OBJDUMP = arm-linux-gnu-objdump
36bd61f5c847 rewrite sys_read cbc
mir3636
parents: 17
diff changeset
14 OBJDUMP = /mnt/dalmore-home/one/src/armgcc/cross/bin/arm-none-eabi-objdump
17
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
15 CFLAGS = -fno-pic -static -fno-builtin -fno-strict-aliasing -Wall -I. -g -O0
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
16
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
17 ASFLAGS =
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
18
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
19 LIBGCC = $(shell $(CC) -print-libgcc-file-name)
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
20
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
21 LINK_BIN = $(call quiet-command,$(LD) $(LDFLAGS) \
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
22 -T $(1) -o $(2) $(3) $(LIBS) -b binary $(4), " LINK $(TARGET_DIR)$@")
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
23
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
24 LINK_INIT = $(call quiet-command,$(LD) $(LDFLAGS) \
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
25 $(1) -o $@.out $<, " LINK $(TARGET_DIR)$@")
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
26 OBJCOPY_INIT = $(call quiet-command,$(OBJCOPY) \
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
27 -S -O binary --prefix-symbols="_binary_$@" $@.out $@, " OBJCOPY $(TARGET_DIR)$@")
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
28 AS_WITH = $(call quiet-command,$(AS) $(ASFLAGS) \
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
29 $(1) -c -o $@ $<," AS $(TARGET_DIR)$@")
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
30
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
31 # link the libgcc.a for __aeabi_idiv. ARM has no native support for div
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
32 LIBS = $(LIBGCC)
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
33
54
aa0095c4c2b0 fix cmake linker options
anatofuz
parents: 24
diff changeset
34 CMAKEDIR = CMakeFiles/kernel.dir
aa0095c4c2b0 fix cmake linker options
anatofuz
parents: 24
diff changeset
35
17
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
36 OBJS = \
54
aa0095c4c2b0 fix cmake linker options
anatofuz
parents: 24
diff changeset
37 $(CMAKEDIR)/lib/string.c.o \
aa0095c4c2b0 fix cmake linker options
anatofuz
parents: 24
diff changeset
38 $(CMAKEDIR)/c/kernel-context.c.o\
aa0095c4c2b0 fix cmake linker options
anatofuz
parents: 24
diff changeset
39 $(CMAKEDIR)/arm.c.o\
aa0095c4c2b0 fix cmake linker options
anatofuz
parents: 24
diff changeset
40 $(CMAKEDIR)/asm.S.o\
aa0095c4c2b0 fix cmake linker options
anatofuz
parents: 24
diff changeset
41 $(CMAKEDIR)/bio.c.o\
aa0095c4c2b0 fix cmake linker options
anatofuz
parents: 24
diff changeset
42 $(CMAKEDIR)/buddy.c.o\
aa0095c4c2b0 fix cmake linker options
anatofuz
parents: 24
diff changeset
43 $(CMAKEDIR)/c/console.c.o\
aa0095c4c2b0 fix cmake linker options
anatofuz
parents: 24
diff changeset
44 $(CMAKEDIR)/exec.c.o\
aa0095c4c2b0 fix cmake linker options
anatofuz
parents: 24
diff changeset
45 $(CMAKEDIR)/c/file.c.o\
aa0095c4c2b0 fix cmake linker options
anatofuz
parents: 24
diff changeset
46 $(CMAKEDIR)/fs.c.o\
aa0095c4c2b0 fix cmake linker options
anatofuz
parents: 24
diff changeset
47 $(CMAKEDIR)/log.c.o\
aa0095c4c2b0 fix cmake linker options
anatofuz
parents: 24
diff changeset
48 $(CMAKEDIR)/main.c.o\
aa0095c4c2b0 fix cmake linker options
anatofuz
parents: 24
diff changeset
49 $(CMAKEDIR)/memide.c.o\
aa0095c4c2b0 fix cmake linker options
anatofuz
parents: 24
diff changeset
50 $(CMAKEDIR)/c/pipe.c.o\
aa0095c4c2b0 fix cmake linker options
anatofuz
parents: 24
diff changeset
51 $(CMAKEDIR)/c/proc.c.o\
aa0095c4c2b0 fix cmake linker options
anatofuz
parents: 24
diff changeset
52 $(CMAKEDIR)/c/spinlock.c.o\
aa0095c4c2b0 fix cmake linker options
anatofuz
parents: 24
diff changeset
53 $(CMAKEDIR)/start.c.o\
aa0095c4c2b0 fix cmake linker options
anatofuz
parents: 24
diff changeset
54 $(CMAKEDIR)/swtch.S.o\
aa0095c4c2b0 fix cmake linker options
anatofuz
parents: 24
diff changeset
55 $(CMAKEDIR)/c/syscall.c.o\
aa0095c4c2b0 fix cmake linker options
anatofuz
parents: 24
diff changeset
56 $(CMAKEDIR)/c/sysfile.c.o\
aa0095c4c2b0 fix cmake linker options
anatofuz
parents: 24
diff changeset
57 $(CMAKEDIR)/sysproc.c.o\
aa0095c4c2b0 fix cmake linker options
anatofuz
parents: 24
diff changeset
58 $(CMAKEDIR)/trap_asm.c.o\
aa0095c4c2b0 fix cmake linker options
anatofuz
parents: 24
diff changeset
59 $(CMAKEDIR)/trap.c.o\
aa0095c4c2b0 fix cmake linker options
anatofuz
parents: 24
diff changeset
60 $(CMAKEDIR)/vm.c.o \
17
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
61 \
54
aa0095c4c2b0 fix cmake linker options
anatofuz
parents: 24
diff changeset
62 $(CMAKEDIR)/device/picirq.c.o \
aa0095c4c2b0 fix cmake linker options
anatofuz
parents: 24
diff changeset
63 $(CMAKEDIR)/device/timer.c.o \
aa0095c4c2b0 fix cmake linker options
anatofuz
parents: 24
diff changeset
64 $(CMAKEDIR)/device/uart.c.o
17
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
65
54
aa0095c4c2b0 fix cmake linker options
anatofuz
parents: 24
diff changeset
66 KERN_OBJS = $(OBJS) entry.S.o
aa0095c4c2b0 fix cmake linker options
anatofuz
parents: 24
diff changeset
67 kernel.elf: $(KERN_OBJS) kernel.ld build/initcode build/fs.img
17
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
68 cp -f build/initcode initcode
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
69 cp -f build/fs.img fs.img
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
70 $(call LINK_BIN, kernel.ld, kernel.elf, \
54
aa0095c4c2b0 fix cmake linker options
anatofuz
parents: 24
diff changeset
71 $(KERN_OBJS), \
17
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
72 initcode fs.img)
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
73 $(OBJDUMP) -S kernel.elf > kernel.asm
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
74 $(OBJDUMP) -t kernel.elf | sed '1,/SYMBOL TABLE/d; s/ .* / /; /^$$/d' > kernel.sym
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
75 rm -f initcode fs.img
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
76
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
77 qemu: kernel.elf
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
78 @clear
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
79 @echo "Press Ctrl-A and then X to terminate QEMU session\n"
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
80 $(QEMU) -M versatilepb -m 128 -cpu arm1176 -nographic -kernel kernel.elf
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
81
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
82 INITCODE_OBJ = initcode.o
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
83 $(addprefix build/,$(INITCODE_OBJ)): initcode.S
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
84 $(call build-directory)
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
85 $(call AS_WITH, -nostdinc -I.)
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
86
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
87 #initcode is linked into the kernel, it will be used to craft the first process
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
88 build/initcode: $(addprefix build/,$(INITCODE_OBJ))
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
89 $(call LINK_INIT, -N -e start -Ttext 0)
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
90 $(call OBJCOPY_INIT)
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
91 $(OBJDUMP) -S $< > initcode.asm
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
92
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
93 build/fs.img:
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
94 make -C tools
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
95 make -C usr -f makfile-armgccbc
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
96
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
97 clean:
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
98 rm -rf build
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
99 rm -f *.o *.d *.asm *.sym vectors.S bootblock entryother \
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
100 initcode initcode.out kernel xv6.img fs.img kernel.elf memfs
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
101 make -C tools clean
c0f6f3eb25ae argccbc
kono
parents:
diff changeset
102 make -C usr clean