rules.mak 1.3 KB
Newer Older
A
aliguori 已提交
1

2 3 4 5 6 7 8 9 10 11 12 13
# Don't use implicit rules or variables
# we have explicit rules for everything
MAKEFLAGS += -rR

# Files with this suffixes are final, don't try to generate them
# using implicit rules
%.d:
%.h:
%.c:
%.m:
%.mak:

14 15
QEMU_CFLAGS += -MMD -MP -MT $@

A
aliguori 已提交
16
%.o: %.c
J
Juan Quintela 已提交
17
	$(call quiet-command,$(CC) $(QEMU_CFLAGS) $(CFLAGS) -c -o $@ $<,"  CC    $(TARGET_DIR)$@")
A
aliguori 已提交
18 19

%.o: %.S
J
Juan Quintela 已提交
20
	$(call quiet-command,$(CC) $(QEMU_CFLAGS) $(CLAGS) -c -o $@ $<,"  AS    $(TARGET_DIR)$@")
A
aliguori 已提交
21 22

%.o: %.m
J
Juan Quintela 已提交
23
	$(call quiet-command,$(CC) $(QEMU_CFLAGS) $(CFLAGS) -c -o $@ $<,"  OBJC  $(TARGET_DIR)$@")
A
aliguori 已提交
24

A
Anthony Liguori 已提交
25
LINK = $(call quiet-command,$(CC) $(LDFLAGS) -o $@ $(1) $(ARLIBS_BEGIN) $(ARLIBS) $(ARLIBS_END) $(LIBS),"  LINK  $(TARGET_DIR)$@")
A
aliguori 已提交
26 27

%$(EXESUF): %.o
A
Anthony Liguori 已提交
28
	$(call LINK,$^)
A
aliguori 已提交
29

30
%.a:
31
	$(call quiet-command,rm -f $@ && $(AR) rcs $@ $^,"  AR    $(TARGET_DIR)$@")
32

33
quiet-command = $(if $(V),$1,$(if $(2),@echo $2 && $1, @$1))
34 35

# cc-option
36
# Usage: CFLAGS+=$(call cc-option, -falign-functions=0, -malign-functions=0)
37

38 39
cc-option = $(if $(shell $(CC) $1 $2 -S -o /dev/null -xc /dev/null \
              >/dev/null 2>&1 && echo OK), $2, $3)
40 41 42 43 44 45 46 47 48

# Generate timestamp files for .h include files

%.h: %.h-timestamp
	@test -f $@ || cp $< $@

%.h-timestamp: %.mak
	$(call quiet-command, $(SRC_PATH)/create_config < $< > $@, "  GEN   $*.h")
	@cmp $@ $*.h >/dev/null 2>&1 || cp $@ $*.h