about summary refs log tree commit diff
diff options
context:
space:
mode:
-rw-r--r--Makefile2
-rw-r--r--Makerules20
-rw-r--r--scripts/gen-as-const.awk29
3 files changed, 49 insertions, 2 deletions
diff --git a/Makefile b/Makefile
index 3a92ccb192..b48738c1c2 100644
--- a/Makefile
+++ b/Makefile
@@ -280,7 +280,7 @@ distribute  :=	README README.libm INSTALL FAQ FAQ.in NOTES NEWS BUGS	\
 			    test-installation.pl gen-FAQ.pl versions.awk\
 			    gen-sorted.awk abi-versions.awk abilist.awk	\
 			    firstversions.awk documented.sh cpp		\
-			    output-format.sed)
+			    output-format.sed gen-as-const.awk)
 
 distribute := $(strip $(distribute))
 generated := $(generated) stubs.h
diff --git a/Makerules b/Makerules
index df56d7a3ed..7e31ef7fba 100644
--- a/Makerules
+++ b/Makerules
@@ -663,7 +663,8 @@ ifeq ($(build-programs),yes)
 endif
 +depfiles := $(addprefix $(objpfx),\
 			 $(filter-out $(addsuffix .d,$(omit-deps)),\
-				      $(+depfiles)))
+				      $(+depfiles))) \
+	     $(addprefix $(common-objpfx),$(gen-as-const-headers:.sym=.h.d))
 
 ifdef +depfiles
 ifneq ($(no_deps),t)
@@ -1177,6 +1178,23 @@ common-generated += libc.symlist
 endif
 
 endif
+
+# Generating headers for assembly constants.
+$(common-objpfx)%.h $(common-objpfx)%.h.d: $(..)scripts/gen-as-const.awk %.sym
+	$(AWK) -f $^ \
+	| $(CC) -S -o - $(CFLAGS) $(CPPFLAGS) -x c - \
+		-MD -MF $(@:.h=.h.d)T -MT '$(@:.h=.h.d) $(@:.h.d=.h)' \
+	| sed -n 's/^.*@@@name@@@\([^@]*\)@@@value@@@[^@]*\([0-9Xxa-fA-F-][0-9Xxa-fA-F-]*\).*@@@end@@@.*$$/#define \1 \2/p' > $(@:.h.d=.h)T
+	sed $(sed-remove-objpfx) \
+	    -e 's@  *\([^ 	\/][^ 	\]*\)@ $$(..)\1@g' \
+	    -e 's@  *\.\.\/\([^ 	\]*\)@ $$(..)\1@g' \
+	    $(@:.h=.h.d)T > $(@:.h=.h.d)T2
+	rm -f $(@:.h=.h.d)T
+	mv -f $(@:.h=.h.d)T2 $(@:.h=.h.d)
+	mv -f $(@:.h.d=.h)T $(@:.h.d=.h)
+vpath %.sym $(sysdirs)
+
+before-compile += $(gen-as-const-headers:%.sym=$(common-objpfx)%.h)
 
 .PHONY: TAGS
 TAGS: $(objpfx)distinfo $(..)MakeTAGS
diff --git a/scripts/gen-as-const.awk b/scripts/gen-as-const.awk
new file mode 100644
index 0000000000..b29656ee71
--- /dev/null
+++ b/scripts/gen-as-const.awk
@@ -0,0 +1,29 @@
+# Script used in producing headers of assembly constants from C expressions.
+# The input to this script looks like:
+#	#cpp-directive ...
+#	NAME1
+#	NAME2 expression ...
+# The output of this script is C code to be run through gcc -S and then
+# massaged to extract the integer constant values of the given C expressions.
+# A line giving just a name implies an expression consisting of just that name.
+
+BEGIN { started = 0 }
+
+# cpp directives go straight through.
+/^#/ { print; next }
+
+NF >= 1 && !started {
+  print "void dummy(void) {";
+  started = 1;
+}
+
+NF == 1 { sub(/^.*$/, "& &"); }
+
+NF > 1 {
+  name = $1;
+  sub(/^[^ 	]+[ 	]+/, "");
+  printf "asm (\"@@@name@@@%s@@@value@@@%%0@@@end@@@\" : : \"i\" (%s));\n",
+    name, $0;
+}
+
+END { if (started) print "}" }