annotate src/makefile.inc @ 0:53676d1f5817 default tip

firsh commit
author tobaru
date Sun, 04 Feb 2018 17:54:49 +0900
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
1 # Cross-compiling (e.g., on Mac OS X, install arm-none-eabi-gcc with MacPorts)
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
2
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
3 CROSSCOMPILE := arm-linux-gnu-
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
4
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
5 CC = /mnt/dalmore-home/one/src/after_update/time_release/bin/clang
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
6 AS = $(CROSSCOMPILE)as
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
7 LD = $(CROSSCOMPILE)ld
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
8 OBJCOPY = $(CROSSCOMPILE)objcopy
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
9 OBJDUMP = $(CROSSCOMPILE)objdump
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
10
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
11 # CFLAGS = -march=armv6 -fno-pic -static -fno-builtin -fno-strict-aliasing -Wall -Werror -I. -g -O0
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
12 CFLAGS = -target armv6-arm-none-eabi -I /net/open/Linux/arm/gcc-arm-none-eabi-7-2017-q4-major/arm-none-eabi/include/ /net/open/Linux/arm/gcc-arm-none-eabi-7-2017-q4-major/lib/gcc/arm-none-eabi/7.2.1/include-fixed/ -fno-pic -static -fno-builtin -fno-strict-aliasing -Wall -I. -g -O0
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
13 LDFLAGS = -L.
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
14 # ASFLAGS = -march=armv6
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
15 ASFLAGS = -target armv6-arm-none-eabi
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
16
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
17 #LIBGCC = $(shell $(gcc) -print-libgcc-file-name)
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
18 LIBGCC = /net/open/Linux/arm/gcc-arm-none-eabi-7-2017-q4-major/lib/gcc/arm-none-eabi/7.2.1/libgcc.a
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
19
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
20 # host compiler
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
21 # HOSTCC_preferred = gcc
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
22 HOSTCC_preferred = /mnt/dalmore-home/one/src/after_update/time_release/bin/clang
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
23 define get_hostcc
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
24 $(if $(shell which $(HOSTCC_preferred)),$(HOSTCC_preferred),"cc")
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
25 endef
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
26 HOSTCC := $(call get_hostcc)
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
27
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
28 # general rules
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
29 quiet-command = $(if $(V),$1,$(if $(2),@echo $2 && $1, @$1))
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
30
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
31 LINK_BIN = $(call quiet-command,$(LD) $(LDFLAGS) \
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
32 -T $(1) -o $(2) $(3) $(LIBS) -b binary $(4), " LINK $(TARGET_DIR)$@")
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
33
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
34 LINK_INIT = $(call quiet-command,$(LD) $(LDFLAGS) \
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
35 $(1) -o $@.out $<, " LINK $(TARGET_DIR)$@")
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
36 OBJCOPY_INIT = $(call quiet-command,$(OBJCOPY) \
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
37 -S -O binary --prefix-symbols="_binary_$@" $@.out $@, " OBJCOPY $(TARGET_DIR)$@")
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
38
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
39 build-directory = $(shell mkdir -p build build/device build/lib)
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
40
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
41 build/%.o: %.c
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
42 $(call build-directory)
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
43 $(call quiet-command,$(CC) $(CFLAGS) \
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
44 -c -o $@ $<," CC $(TARGET_DIR)$@")
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
45
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
46 AS_WITH = $(call quiet-command,$(CC) $(ASFLAGS) \
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
47 $(1) -c -o $@ $<," AS $(TARGET_DIR)$@")
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
48
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
49 build/%.o: %.S
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
50 $(call build-directory)
53676d1f5817 firsh commit
tobaru
parents:
diff changeset
51 $(call AS_WITH, )