rules.mak 1.9 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
# Flags for dependency generation
15
QEMU_DGFLAGS += -MMD -MP -MT $@ -MF $(*D)/$(*F).d
16

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

%.o: %.S
21
	$(call quiet-command,$(CC) $(QEMU_CFLAGS) $(QEMU_DGFLAGS) $(CFLAGS) -c -o $@ $<,"  AS    $(TARGET_DIR)$@")
A
aliguori 已提交
22 23

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

26
LINK = $(call quiet-command,$(CC) $(QEMU_CFLAGS) $(CFLAGS) $(LDFLAGS) -o $@ $(1) $(LIBS),"  LINK  $(TARGET_DIR)$@")
A
aliguori 已提交
27 28

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

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

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

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

39 40
cc-option = $(if $(shell $(CC) $1 $2 -S -o /dev/null -xc /dev/null \
              >/dev/null 2>&1 && echo OK), $2, $3)
41

42
VPATH_SUFFIXES = %.c %.h %.S %.m %.mak %.texi
43
set-vpath = $(if $1,$(foreach PATTERN,$(VPATH_SUFFIXES),$(eval vpath $(PATTERN) $1)))
P
Paolo Bonzini 已提交
44

P
Paolo Bonzini 已提交
45 46 47 48 49 50 51 52 53
# find-in-path
# Usage: $(call find-in-path, prog)
# Looks in the PATH if the argument contains no slash, else only considers one
# specific directory.  Returns an # empty string if the program doesn't exist
# there.
find-in-path = $(if $(find-string /, $1), \
        $(wildcard $1), \
        $(wildcard $(patsubst %, %/$1, $(subst :, ,$(PATH)))))

54 55 56 57 58 59
# Generate timestamp files for .h include files

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

%.h-timestamp: %.mak
M
malc 已提交
60
	$(call quiet-command, sh $(SRC_PATH)/create_config < $< > $@, "  GEN   $*.h")
61
	@cmp $@ $*.h >/dev/null 2>&1 || cp $@ $*.h
62 63 64

# will delete the target of a rule if commands exit with a nonzero exit status
.DELETE_ON_ERROR: