blob: 979555f54f77343891a302c85f19f159f70f2e40 [file] [log] [blame]
Masahiro Yamada6a44d802014-02-24 11:12:11 +09001#
2# Kbuild for top-level directory of U-Boot
3# This file takes care of the following:
4# 1) Generate generic-asm-offsets.h
5# 2) Generate asm-offsets.h
6
Masahiro Yamada490cf5f2015-03-27 10:59:01 +09007# Default sed regexp - multiline due to syntax constraints
8define sed-y
9 "s:[[:space:]]*\.ascii[[:space:]]*\"\(.*\)\":\1:; \
10 /^->/{s:->#\(.*\):/* \1 */:; \
11 s:^->\([^ ]*\) [\$$#]*\([-0-9]*\) \(.*\):#define \1 \2 /* \3 */:; \
12 s:^->\([^ ]*\) [\$$#]*\([^ ]*\) \(.*\):#define \1 \2 /* \3 */:; \
13 s:->::; p;}"
14endef
Masahiro Yamada6a44d802014-02-24 11:12:11 +090015
Masahiro Yamada490cf5f2015-03-27 10:59:01 +090016quiet_cmd_offsets = GEN $@
17define cmd_offsets
Masahiro Yamada6a44d802014-02-24 11:12:11 +090018 (set -e; \
Masahiro Yamada490cf5f2015-03-27 10:59:01 +090019 echo "#ifndef $2"; \
20 echo "#define $2"; \
Masahiro Yamada6a44d802014-02-24 11:12:11 +090021 echo "/*"; \
22 echo " * DO NOT MODIFY."; \
23 echo " *"; \
24 echo " * This file was generated by Kbuild"; \
25 echo " *"; \
26 echo " */"; \
27 echo ""; \
28 sed -ne $(sed-y) $<; \
29 echo ""; \
30 echo "#endif" ) > $@
31endef
32
Masahiro Yamada490cf5f2015-03-27 10:59:01 +090033#####
34# 1) Generate generic-asm-offsets.h
35
36generic-offsets-file := include/generated/generic-asm-offsets.h
37
38always := $(generic-offsets-file)
39targets := $(generic-offsets-file) lib/asm-offsets.s
40
Masahiro Yamada6a44d802014-02-24 11:12:11 +090041# We use internal kbuild rules to avoid the "is up to date" message from make
42lib/asm-offsets.s: lib/asm-offsets.c FORCE
43 $(Q)mkdir -p $(dir $@)
44 $(call if_changed_dep,cc_s_c)
45
46$(obj)/$(generic-offsets-file): lib/asm-offsets.s Kbuild
47 $(Q)mkdir -p $(dir $@)
Masahiro Yamada490cf5f2015-03-27 10:59:01 +090048 $(call cmd,offsets,__GENERIC_ASM_OFFSETS_H__)
Masahiro Yamada6a44d802014-02-24 11:12:11 +090049
50#####
51# 2) Generate asm-offsets.h
52#
53
Masahiro Yamada254d68b2014-03-18 16:38:13 +090054ifneq ($(wildcard $(srctree)/arch/$(ARCH)/lib/asm-offsets.c),)
Masahiro Yamada6a44d802014-02-24 11:12:11 +090055offsets-file := include/generated/asm-offsets.h
56endif
57
58always += $(offsets-file)
59targets += $(offsets-file)
Masahiro Yamada254d68b2014-03-18 16:38:13 +090060targets += arch/$(ARCH)/lib/asm-offsets.s
Masahiro Yamada6a44d802014-02-24 11:12:11 +090061
Masahiro Yamada6a44d802014-02-24 11:12:11 +090062CFLAGS_asm-offsets.o := -DDO_DEPS_ONLY
63
Masahiro Yamada6a44d802014-02-24 11:12:11 +090064# We use internal kbuild rules to avoid the "is up to date" message from make
Masahiro Yamada254d68b2014-03-18 16:38:13 +090065arch/$(ARCH)/lib/asm-offsets.s: arch/$(ARCH)/lib/asm-offsets.c FORCE
Masahiro Yamada6a44d802014-02-24 11:12:11 +090066 $(Q)mkdir -p $(dir $@)
67 $(call if_changed_dep,cc_s_c)
68
Masahiro Yamada254d68b2014-03-18 16:38:13 +090069$(obj)/$(offsets-file): arch/$(ARCH)/lib/asm-offsets.s Kbuild
Masahiro Yamada490cf5f2015-03-27 10:59:01 +090070 $(call cmd,offsets,__ASM_OFFSETS_H__)