This is the mail archive of the
libc-alpha@sourceware.org
mailing list for the glibc project.
Cross-rpcgen patch, version 4
- From: "Joseph S. Myers" <joseph at codesourcery dot com>
- To: libc-alpha at sourceware dot org
- Cc: Allan McRae <allan at archlinux dot org>
- Date: Wed, 25 Apr 2012 21:12:51 +0000 (UTC)
- Subject: Cross-rpcgen patch, version 4
Here is a version of the cross-rpcgen changes that uses a common
$(build-compile-command.c) shared with $(native-compile) to compile
cross-rpcgen objects. For reference,
<http://sourceware.org/ml/libc-alpha/2012-03/msg00375.html> was the
previous patch version;
<http://sourceware.org/ml/libc-alpha/2012-03/msg00325.html> was the
start of the cross-rpcgen thread. This may still need further changes
(in which case I'll again look for bits to split out), but I hope it's
quite close to a version that can go in if it's not ready to go in
right now.
Allan, I hope this should fix your bug with build-programs=no (bug
14012) by always using the always-built cross-rpcgen instead of an
rpcgen for the host that's disabled by build-programs=no, so I've put
that BZ # in; perhaps you could test if it does indeed fix that for
you?
Tested x86_64.
2012-04-25 Maxim Kuvyrkov <maxim@codesourcery.com>
Joseph Myers <joseph@codesourcery.com>
Paul Pluzhnikov <ppluzhnikov@google.com>
[BZ #14012]
* Makerules (build-compile-command.c): New variable.
(native-compile): Define using $(build-compile-command.c).
* config.h.in [IS_IN_build]: Allow compiling without optimization.
* sunrpc/Makefile [cross-compiling] (headers): Enable additions
requiring rpcgen.
[cross-compiling] (extra-libs): Likewise.
[cross-compiling] (extra-libs-others): Likewise.
[cross-compiling] (librpcsvc-routines): Likewise.
[cross-compiling] (librpcsvc-inhibit-o): Likewise.
[cross-compiling] (omit-deps): Likewise.
(sunrpc-CPPFLAGS): New variable.
(CPPFLAGS): Define using $(sunrpc-CPPFLAGS).
(BUILD_CPPFLAGS): Append $(sunrpc-CPPFLAGS).
(cross-rpcgen-objs): New variable.
($(cross-rpcgen-objs)): New rule.
($(objpfx)cross-rpcgen): Likewise.
(rpcgen-cmd): Define to use $(built-program-file).
($(objpfx)rpcsvc/%.stmp): Depend on cross-rpcgen.
($(objpfx)x%.stmp): Likewise.
* sunrpc/proto.h [IS_IN_build] (_): Define.
[IS_IN_build] (_libc_intl_domainname): Likewise.
diff --git a/Makerules b/Makerules
index 18aeb9e..183f95a 100644
--- a/Makerules
+++ b/Makerules
@@ -1115,10 +1115,11 @@ endif
install: install-no-libc.a-nosubdir
# Command to compile $< using the native libraries.
+build-compile-command.c = $(BUILD_CC) $($(basename $(<F))-CFLAGS) \
+ $(ALL_BUILD_CFLAGS) $< $(OUTPUT_OPTION)
define native-compile
$(make-target-directory)
-$(BUILD_CC) $($(basename $(<F))-CFLAGS) $(ALL_BUILD_CFLAGS) \
- $< $(OUTPUT_OPTION) $(BUILD_LDFLAGS)
+$(build-compile-command.c) $(BUILD_LDFLAGS)
endef
# We always want to use configuration definitions.
diff --git a/config.h.in b/config.h.in
index 3b938f8..81704a1 100644
--- a/config.h.in
+++ b/config.h.in
@@ -1,4 +1,5 @@
-#if !defined __ASSEMBLER__ && !defined _ISOMAC && !defined __OPTIMIZE__
+#if !defined IS_IN_build && !defined __ASSEMBLER__ && !defined _ISOMAC \
+ && !defined __OPTIMIZE__
# error "glibc cannot be compiled without optimization"
#endif
diff --git a/sunrpc/Makefile b/sunrpc/Makefile
index 48790f4..7a4c213 100644
--- a/sunrpc/Makefile
+++ b/sunrpc/Makefile
@@ -97,15 +97,12 @@ ifeq ($(have-thread-library),yes)
xtests += thrsvc
endif
-ifeq (no,$(cross-compiling))
-# We can only build this library if we can run the rpcgen we build.
headers += $(rpcsvc:%.x=rpcsvc/%.h)
extra-libs := librpcsvc
extra-libs-others := librpcsvc # Make it in `others' pass, not `lib' pass.
librpcsvc-routines = $(rpcsvc:%.x=x%)
librpcsvc-inhibit-o = .os # Build no shared rpcsvc library.
omit-deps = $(librpcsvc-routines)
-endif
include ../Rules
@@ -139,7 +136,9 @@ CFLAGS-pmap_rmt.c = -fexceptions
CFLAGS-clnt_perr.c = -fexceptions
CFLAGS-openchild.c = -fexceptions
-CPPFLAGS += -D_RPC_THREAD_SAFE_
+sunrpc-CPPFLAGS = -D_RPC_THREAD_SAFE_
+CPPFLAGS += $(sunrpc-CPPFLAGS)
+BUILD_CPPFLAGS += $(sunrpc-CPPFLAGS)
$(objpfx)tst-getmyaddr: $(common-objpfx)linkobj/libc.so
$(objpfx)tst-xdrmem: $(common-objpfx)linkobj/libc.so
@@ -147,13 +146,22 @@ $(objpfx)tst-xdrmem2: $(common-objpfx)linkobj/libc.so
$(objpfx)rpcgen: $(addprefix $(objpfx),$(rpcgen-objs))
+cross-rpcgen-objs := $(addprefix $(objpfx)cross-,$(rpcgen-objs))
+
+$(cross-rpcgen-objs): $(objpfx)cross-%.o: %.c
+ $(make-target-directory)
+ $(build-compile-command.c) -c
+
+$(objpfx)cross-rpcgen: $(cross-rpcgen-objs)
+ $(BUILD_CC) $^ $(BUILD_LDFLAGS) -o $@
+
# This makes sure -DNOT_IN_libc is passed for all these modules.
cpp-srcs-left := $(rpcgen-objs:.o=.c)
lib := nonlib
include $(patsubst %,$(..)cppflags-iterator.mk,$(cpp-srcs-left))
# Tell rpcgen where to find the C preprocessor.
-rpcgen-cmd = CPP='$(CC) -E -x c-header' $(built-program-cmd) -Y ../scripts
+rpcgen-cmd = CPP='$(CC) -E -x c-header' $(built-program-file) -Y ../scripts
# Install the rpc data base file.
$(inst_sysconfdir)/rpc: etc.rpc $(+force)
@@ -164,7 +172,7 @@ $(inst_sysconfdir)/rpc: etc.rpc $(+force)
# relinked.
$(rpcsvc:%.x=$(objpfx)rpcsvc/%.h): $(objpfx)rpcsvc/%.h: $(objpfx)rpcsvc/%.stmp
@:
-$(objpfx)rpcsvc/%.stmp: rpcsvc/%.x $(objpfx)rpcgen
+$(objpfx)rpcsvc/%.stmp: rpcsvc/%.x $(objpfx)cross-rpcgen
$(make-target-directory)
-@rm -f ${@:stmp=T} $@
$(rpcgen-cmd) -h $< -o ${@:stmp=T}
@@ -174,7 +182,7 @@ $(objpfx)rpcsvc/%.stmp: rpcsvc/%.x $(objpfx)rpcgen
# Generate the rpcsvc XDR functions with rpcgen.
$(rpcsvc:%.x=$(objpfx)x%.c): $(objpfx)x%.c: $(objpfx)x%.stmp
@:
-$(objpfx)x%.stmp: rpcsvc/%.x $(objpfx)rpcgen
+$(objpfx)x%.stmp: rpcsvc/%.x $(objpfx)cross-rpcgen
-@rm -f ${@:stmp=T} $@
$(rpcgen-cmd) -c $< -o ${@:stmp=T}
$(move-if-change) $(@:stmp=T) $(@:stmp=c)
diff --git a/sunrpc/proto.h b/sunrpc/proto.h
index 3e1ecd1..df36ece 100644
--- a/sunrpc/proto.h
+++ b/sunrpc/proto.h
@@ -50,3 +50,14 @@ void crash(void) __attribute__ ((noreturn));
void tabify(FILE *f, int tab);
char *make_argname(const char *pname, const char *vname);
void add_type(int len, const char *type);
+
+/* This header is the last one included in all rpc_*.c files,
+ so we define stuff for cross-rpcgen here to avoid conflicts with
+ $build's C library and $host's glibc. */
+
+#ifdef IS_IN_build
+
+#define _(X) (X)
+#define _libc_intl_domainname "libc"
+
+#endif
--
Joseph S. Myers
joseph@codesourcery.com