Masahiro Yamada | 5aed6ed | 2014-02-24 11:12:11 +0900 | [diff] [blame] | 1 | # |
| 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 Yamada | 33ff360 | 2015-03-27 10:59:01 +0900 | [diff] [blame] | 7 | # Default sed regexp - multiline due to syntax constraints |
| 8 | define 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;}" |
| 14 | endef |
Masahiro Yamada | 5aed6ed | 2014-02-24 11:12:11 +0900 | [diff] [blame] | 15 | |
Michal Marek | e19b6e0 | 2015-03-27 10:59:03 +0900 | [diff] [blame] | 16 | # Use filechk to avoid rebuilds when a header changes, but the resulting file |
| 17 | # does not |
| 18 | define filechk_offsets |
Masahiro Yamada | 5aed6ed | 2014-02-24 11:12:11 +0900 | [diff] [blame] | 19 | (set -e; \ |
Masahiro Yamada | 33ff360 | 2015-03-27 10:59:01 +0900 | [diff] [blame] | 20 | echo "#ifndef $2"; \ |
| 21 | echo "#define $2"; \ |
Masahiro Yamada | 5aed6ed | 2014-02-24 11:12:11 +0900 | [diff] [blame] | 22 | echo "/*"; \ |
| 23 | echo " * DO NOT MODIFY."; \ |
| 24 | echo " *"; \ |
| 25 | echo " * This file was generated by Kbuild"; \ |
Masahiro Yamada | 5aed6ed | 2014-02-24 11:12:11 +0900 | [diff] [blame] | 26 | echo " */"; \ |
| 27 | echo ""; \ |
Michal Marek | e19b6e0 | 2015-03-27 10:59:03 +0900 | [diff] [blame] | 28 | sed -ne $(sed-y); \ |
Masahiro Yamada | 5aed6ed | 2014-02-24 11:12:11 +0900 | [diff] [blame] | 29 | echo ""; \ |
Michal Marek | e19b6e0 | 2015-03-27 10:59:03 +0900 | [diff] [blame] | 30 | echo "#endif" ) |
Masahiro Yamada | 5aed6ed | 2014-02-24 11:12:11 +0900 | [diff] [blame] | 31 | endef |
| 32 | |
Masahiro Yamada | 33ff360 | 2015-03-27 10:59:01 +0900 | [diff] [blame] | 33 | ##### |
| 34 | # 1) Generate generic-asm-offsets.h |
| 35 | |
| 36 | generic-offsets-file := include/generated/generic-asm-offsets.h |
| 37 | |
| 38 | always := $(generic-offsets-file) |
| 39 | targets := $(generic-offsets-file) lib/asm-offsets.s |
| 40 | |
Masahiro Yamada | 5aed6ed | 2014-02-24 11:12:11 +0900 | [diff] [blame] | 41 | # We use internal kbuild rules to avoid the "is up to date" message from make |
| 42 | lib/asm-offsets.s: lib/asm-offsets.c FORCE |
| 43 | $(Q)mkdir -p $(dir $@) |
| 44 | $(call if_changed_dep,cc_s_c) |
| 45 | |
Michal Marek | e19b6e0 | 2015-03-27 10:59:03 +0900 | [diff] [blame] | 46 | $(obj)/$(generic-offsets-file): lib/asm-offsets.s FORCE |
| 47 | $(call filechk,offsets,__GENERIC_ASM_OFFSETS_H__) |
Masahiro Yamada | 5aed6ed | 2014-02-24 11:12:11 +0900 | [diff] [blame] | 48 | |
| 49 | ##### |
| 50 | # 2) Generate asm-offsets.h |
| 51 | # |
| 52 | |
Masahiro Yamada | 8226dfd | 2014-03-18 16:38:13 +0900 | [diff] [blame] | 53 | ifneq ($(wildcard $(srctree)/arch/$(ARCH)/lib/asm-offsets.c),) |
Masahiro Yamada | 5aed6ed | 2014-02-24 11:12:11 +0900 | [diff] [blame] | 54 | offsets-file := include/generated/asm-offsets.h |
| 55 | endif |
| 56 | |
| 57 | always += $(offsets-file) |
| 58 | targets += $(offsets-file) |
Masahiro Yamada | 8226dfd | 2014-03-18 16:38:13 +0900 | [diff] [blame] | 59 | targets += arch/$(ARCH)/lib/asm-offsets.s |
Masahiro Yamada | 5aed6ed | 2014-02-24 11:12:11 +0900 | [diff] [blame] | 60 | |
Masahiro Yamada | 5aed6ed | 2014-02-24 11:12:11 +0900 | [diff] [blame] | 61 | CFLAGS_asm-offsets.o := -DDO_DEPS_ONLY |
| 62 | |
Masahiro Yamada | 5aed6ed | 2014-02-24 11:12:11 +0900 | [diff] [blame] | 63 | # We use internal kbuild rules to avoid the "is up to date" message from make |
Masahiro Yamada | 8226dfd | 2014-03-18 16:38:13 +0900 | [diff] [blame] | 64 | arch/$(ARCH)/lib/asm-offsets.s: arch/$(ARCH)/lib/asm-offsets.c FORCE |
Masahiro Yamada | 5aed6ed | 2014-02-24 11:12:11 +0900 | [diff] [blame] | 65 | $(Q)mkdir -p $(dir $@) |
| 66 | $(call if_changed_dep,cc_s_c) |
| 67 | |
Michal Marek | e19b6e0 | 2015-03-27 10:59:03 +0900 | [diff] [blame] | 68 | $(obj)/$(offsets-file): arch/$(ARCH)/lib/asm-offsets.s FORCE |
| 69 | $(call filechk,offsets,__ASM_OFFSETS_H__) |