From: Maxim Kuvyrkov Date: Thu, 10 May 2012 17:07:45 +0000 (+0000) Subject: Build rpcgen-generated files when cross compiling. X-Git-Tag: glibc-2.16-tps~430 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=28e725016266de6cc18f7aef5c675c57b7a42a89;p=platform%2Fupstream%2Fglibc.git Build rpcgen-generated files when cross compiling. --- diff --git a/ChangeLog b/ChangeLog index 7fb8d56..4acae97 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,29 @@ +2012-05-10 Maxim Kuvyrkov + Joseph Myers + Paul Pluzhnikov + + [BZ #14012] + * 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. + (extra-objs): Append $(cross-rpcgen-objs). + ($(cross-rpcgen-objs)): New rule. + ($(objpfx)cross-rpcgen): Likewise. + (rpcgen-cmd): Define to use $(built-program-file). Expand + comment. + ($(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. + 2012-05-10 H.J. Lu * sysdeps/x86_64/dl-machine.h (elf_machine_rela) [__ILP32__]: diff --git a/sunrpc/Makefile b/sunrpc/Makefile index b4548d5..e61efd0 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 ifeq (yes,$(build-shared)) rpc-compat-routines = $(addprefix compat-,$(need-export-routines)) @@ -143,7 +140,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 @@ -151,13 +150,30 @@ $(objpfx)tst-xdrmem2: $(common-objpfx)linkobj/libc.so $(objpfx)rpcgen: $(addprefix $(objpfx),$(rpcgen-objs)) +cross-rpcgen-objs := $(addprefix $(objpfx)cross-,$(rpcgen-objs)) +extra-objs += $(cross-rpcgen-objs) + +# When generic makefile support for build system programs is +# available, it should replace this code. See +# . +$(cross-rpcgen-objs): $(objpfx)cross-%.o: %.c + $(make-target-directory) + $(BUILD_CC) $($(basename $(