[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-Id: <1492149003-19136-3-git-send-email-yamada.masahiro@socionext.com>
Date: Fri, 14 Apr 2017 14:50:03 +0900
From: Masahiro Yamada <yamada.masahiro@...ionext.com>
To: linux-kbuild@...r.kernel.org
Cc: Matthias Kaehlcke <mka@...omium.org>,
David Howells <dhowells@...hat.com>,
Michael Davidson <md@...gle.com>,
Michal Marek <mmarek@...e.com>,
Jan Beulich <JBeulich@...ell.com>,
Alexander van Heukelum <heukelum@...tmail.fm>,
Jeroen Hofstee <jeroen@...pectrum.nl>,
Masahiro Yamada <yamada.masahiro@...ionext.com>,
linux-kernel@...r.kernel.org
Subject: [PATCH 2/2] kbuild: fix asm-offset generation to work with clang
From: Jeroen Hofstee <jeroen@...pectrum.nl>
KBuild abuses the asm statement to write to a file and
clang chokes about these invalid asm statements. Hack it
even more by fooling this is actual valid asm code.
Signed-off-by: Jeroen Hofstee <jeroen@...pectrum.nl>
[masahiro:
Import Jeroen's work for U-Boot:
http://patchwork.ozlabs.org/patch/375026/
Tweak sed script a little to drop garbage '#' for GCC case, like
#define NR_PAGEFLAGS 23 /* __NR_PAGEFLAGS # */ ]
Signed-off-by: Masahiro Yamada <yamada.masahiro@...ionext.com>
---
include/linux/kbuild.h | 6 +++---
scripts/Makefile.lib | 5 +++--
2 files changed, 6 insertions(+), 5 deletions(-)
diff --git a/include/linux/kbuild.h b/include/linux/kbuild.h
index 22a7219..4e80f3a 100644
--- a/include/linux/kbuild.h
+++ b/include/linux/kbuild.h
@@ -2,14 +2,14 @@
#define __LINUX_KBUILD_H
#define DEFINE(sym, val) \
- asm volatile("\n->" #sym " %0 " #val : : "i" (val))
+ asm volatile("\n.ascii \"->" #sym " %0 " #val "\"" : : "i" (val))
-#define BLANK() asm volatile("\n->" : : )
+#define BLANK() asm volatile("\n.ascii \"->\"" : : )
#define OFFSET(sym, str, mem) \
DEFINE(sym, offsetof(struct str, mem))
#define COMMENT(x) \
- asm volatile("\n->#" x)
+ asm volatile("\n.ascii \"->#" x "\"")
#endif
diff --git a/scripts/Makefile.lib b/scripts/Makefile.lib
index 9c20690..a050859 100644
--- a/scripts/Makefile.lib
+++ b/scripts/Makefile.lib
@@ -414,9 +414,10 @@ cmd_xzmisc = (cat $(filter-out FORCE,$^) | \
# Default sed regexp - multiline due to syntax constraints
define sed-offsets
- "/^->/{s:->#\(.*\):/* \1 */:; \
+ 's:^\.ascii *"\(.*\)".*:\1:; \
+ /^->/{s:->#\(.*\):/* \1 */:; \
s:^->\([^ ]*\) [\$$#]*\([^ ]*\) \(.*\):#define \1 \2 /* \3 */:; \
- s:->::; p;}"
+ s:->::; p;}'
endef
# Use filechk to avoid rebuilds when a header changes, but the resulting file
--
2.7.4
Powered by blists - more mailing lists