aboutsummaryrefslogtreecommitdiffstats
path: root/tools/Rules.mk
diff options
context:
space:
mode:
authorJan Beulich <jbeulich@suse.com>2013-05-23 10:15:55 +0200
committerJan Beulich <jbeulich@suse.com>2013-05-23 10:15:55 +0200
commit3ef9022508e6e331e1bedb173a0aad509ceb69aa (patch)
tree94bb42b2a7bec82d46f043dce5ba7bbdc7bd723a /tools/Rules.mk
parentc298f7ec04fb474abdffa360e352be275a024467 (diff)
downloadxen-3ef9022508e6e331e1bedb173a0aad509ceb69aa.tar.gz
xen-3ef9022508e6e331e1bedb173a0aad509ceb69aa.tar.bz2
xen-3ef9022508e6e331e1bedb173a0aad509ceb69aa.zip
tools: fix dependency file generation
There is a small set of places where files in subdirectories get compiled from the parent directory. Dependency file wise this is no problem as long as the files use names distinct without regard to the directories they sit in, and tools/console/ violates this (in having two main.c files). Hence we need to avoid losing the directory name, both to ensure the two compiler instances don't simultaneously write to the same file (happening of which is what triggered me looking into this) and to guarantee dependencies for all files will be seen by make on an incremental rebuild. Signed-off-by: Jan Beulich <jbeulich@suse.com> Acked-by: Ian Campbell <ian.campbell@citrix.com> master commit: 4d788e164d6556d931bc3e0a69e36b8cf7280794 master date: 2013-05-21 10:16:30 +0200
Diffstat (limited to 'tools/Rules.mk')
-rw-r--r--tools/Rules.mk2
1 files changed, 1 insertions, 1 deletions
diff --git a/tools/Rules.mk b/tools/Rules.mk
index f4e84c1b77..e83f682751 100644
--- a/tools/Rules.mk
+++ b/tools/Rules.mk
@@ -62,7 +62,7 @@ SHLIB_libxenlight = -Wl,-rpath-link=$(XEN_XENLIGHT)
CFLAGS += -D__XEN_TOOLS__
# Get gcc to generate the dependencies for us.
-CFLAGS += -MMD -MF .$(@F).d
+CFLAGS += -MMD -MF .$(if $(filter-out .,$(@D)),$(subst /,@,$(@D))@)$(@F).d
DEPS = .*.d
ifneq ($(XEN_OS),NetBSD)