aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSam Ravnborg <sam@ravnborg.org>2008-06-22 15:42:06 -0400
committerSam Ravnborg <sam@ravnborg.org>2008-07-25 16:12:34 -0400
commit2e57d051160dd61776461637f767df19036b1186 (patch)
treefc167eb026320e6aa9ecd1990e62ce0ee100572d
parenta53ce098a763a33311b60c53161572f5789d5594 (diff)
kbuild: asm symlink support for arch/$ARCH/include
Adjust the asm symlink support so we do not create the symlink unless really needed. We check the precense of include/asm-$ARCH by checking for the system.h file. We may end up with a stale directory so it is not enough to check if the directory is present. Signed-off-by: Sam Ravnborg <sam@ravnborg.org>
-rw-r--r--Kbuild3
-rw-r--r--Makefile42
2 files changed, 29 insertions, 16 deletions
diff --git a/Kbuild b/Kbuild
index e750e9c3fe59..f056b4feee51 100644
--- a/Kbuild
+++ b/Kbuild
@@ -43,7 +43,7 @@ $(obj)/$(bounds-file): kernel/bounds.s Kbuild
43# 2) Generate asm-offsets.h 43# 2) Generate asm-offsets.h
44# 44#
45 45
46offsets-file := include/asm-$(SRCARCH)/asm-offsets.h 46offsets-file := include/asm/asm-offsets.h
47 47
48always += $(offsets-file) 48always += $(offsets-file)
49targets += $(offsets-file) 49targets += $(offsets-file)
@@ -81,7 +81,6 @@ arch/$(SRCARCH)/kernel/asm-offsets.s: arch/$(SRCARCH)/kernel/asm-offsets.c \
81 $(call if_changed_dep,cc_s_c) 81 $(call if_changed_dep,cc_s_c)
82 82
83$(obj)/$(offsets-file): arch/$(SRCARCH)/kernel/asm-offsets.s Kbuild 83$(obj)/$(offsets-file): arch/$(SRCARCH)/kernel/asm-offsets.s Kbuild
84 $(Q)mkdir -p $(dir $@)
85 $(call cmd,offsets) 84 $(call cmd,offsets)
86 85
87##### 86#####
diff --git a/Makefile b/Makefile
index ad0533b9a0d4..f6fcad704d23 100644
--- a/Makefile
+++ b/Makefile
@@ -925,7 +925,9 @@ ifneq ($(KBUILD_SRC),)
925 /bin/false; \ 925 /bin/false; \
926 fi; 926 fi;
927 $(Q)if [ ! -d include2 ]; then mkdir -p include2; fi; 927 $(Q)if [ ! -d include2 ]; then mkdir -p include2; fi;
928 $(Q)ln -fsn $(srctree)/include/asm-$(SRCARCH) include2/asm 928 $(Q)if [ -e $(srctree)/include/asm-$(SRCARCH)/system.h ]; then \
929 ln -fsn $(srctree)/include/asm-$(SRCARCH) include2/asm; \
930 fi
929endif 931endif
930 932
931# prepare2 creates a makefile if using a separate output directory 933# prepare2 creates a makefile if using a separate output directory
@@ -951,22 +953,34 @@ export CPPFLAGS_vmlinux.lds += -P -C -U$(ARCH)
951 953
952# The asm symlink changes when $(ARCH) changes. 954# The asm symlink changes when $(ARCH) changes.
953# Detect this and ask user to run make mrproper 955# Detect this and ask user to run make mrproper
954 956define check-symlink
955include/asm: FORCE 957 set -e; \
956 $(Q)set -e; asmlink=`readlink include/asm | cut -d '-' -f 2`; \ 958 if [ -L include/asm ]; then \
957 if [ -L include/asm ]; then \ 959 asmlink=`readlink include/asm | cut -d '-' -f 2`; \
958 if [ "$$asmlink" != "$(SRCARCH)" ]; then \ 960 if [ "$$asmlink" != "$(SRCARCH)" ]; then \
959 echo "ERROR: the symlink $@ points to asm-$$asmlink but asm-$(SRCARCH) was expected"; \ 961 echo "ERROR: the symlink $@ points to asm-$$asmlink but asm-$(SRCARCH) was expected"; \
960 echo " set ARCH or save .config and run 'make mrproper' to fix it"; \ 962 echo " set ARCH or save .config and run 'make mrproper' to fix it"; \
961 exit 1; \ 963 exit 1; \
962 fi; \ 964 fi; \
963 else \ 965 fi
964 echo ' SYMLINK $@ -> include/asm-$(SRCARCH)'; \ 966endef
965 if [ ! -d include ]; then \ 967
966 mkdir -p include; \ 968# We create the target directory of the symlink if it does
967 fi; \ 969# not exist so the test in chack-symlink works and we have a
968 ln -fsn asm-$(SRCARCH) $@; \ 970# directory for generated filesas used by some architectures.
971define create-symlink
972 if [ ! -L include/asm ]; then \
973 echo ' SYMLINK $@ -> include/asm-$(SRCARCH)'; \
974 if [ ! -d include/asm-$(SRCARCH) ]; then \
975 mkdir -p include/asm-$(SRCARCH); \
976 fi; \
977 ln -fsn asm-$(SRCARCH) $@; \
969 fi 978 fi
979endef
980
981include/asm: FORCE
982 $(Q)$(check-symlink)
983 $(Q)$(create-symlink)
970 984
971# Generate some files 985# Generate some files
972# --------------------------------------------------------------------------- 986# ---------------------------------------------------------------------------