[前][次][番号順一覧][スレッド一覧]

ruby-changes:53371

From: nobu <ko1@a...>
Date: Wed, 7 Nov 2018 11:49:31 +0900 (JST)
Subject: [ruby-changes:53371] nobu:r65587 (trunk): mjit_build_dir: separate MJIT_BUILD_DIR

nobu	2018-11-07 11:49:26 +0900 (Wed, 07 Nov 2018)

  New Revision: 65587

  https://svn.ruby-lang.org/cgi-bin/viewvc.cgi?view=revision&revision=65587

  Log:
    mjit_build_dir: separate MJIT_BUILD_DIR
    
    * Makefile.in (mjit_build_dir.so): separate MJIT_BUILD_DIR to
      eliminate the feature for test-all after installation.

  Modified files:
    trunk/Makefile.in
    trunk/mjit.c
    trunk/test/lib/jit_support.rb
Index: Makefile.in
===================================================================
--- Makefile.in	(revision 65586)
+++ Makefile.in	(revision 65587)
@@ -445,6 +445,7 @@ clean-local:: https://github.com/ruby/ruby/blob/trunk/Makefile.in#L445
 	$(Q)$(RM) $(MJIT_MIN_HEADER) $(MJIT_MIN_HEADER:.h=)$(MJIT_HEADER_SUFFIX:%=*).h
 	$(Q)$(RM) $(MJIT_HEADER_INSTALL_DIR)/rb_mjit_min_header-*.h
 	$(Q)$(RM) $(TIMESTAMPDIR)/$(MJIT_HEADER:.h=)$(MJIT_HEADER_SUFFIX).time mjit_config.h
+	$(Q)$(RM) mjit_build_dir.*
 	-$(Q) $(RMDIRS) $(MJIT_HEADER_INSTALL_DIR) 2> $(NULL) || exit 0
 
 # DTrace static library hacks described here:
@@ -607,7 +608,6 @@ mjit_config.h: https://github.com/ruby/ruby/blob/trunk/Makefile.in#L608
 	echo '#define RUBY_MJIT_CONFIG_H 1'; \
 	echo; \
 	sep=; \
-	quote MJIT_BUILD_DIR "`$(CHDIR) . && pwd`"; \
 	quote MJIT_MIN_HEADER_NAME "/$(MJIT_HEADER_INSTALL_DIR)/$(MJIT_MIN_HEADER_NAME)"; \
 	sep=,; \
 	quote "MJIT_CC_COMMON  " $(MJIT_CC); \
@@ -617,6 +617,7 @@ mjit_config.h: https://github.com/ruby/ruby/blob/trunk/Makefile.in#L617
 	quote "MJIT_LDSHARED   " $(MJIT_LDSHARED); \
 	quote "MJIT_DLDFLAGS   $${need_mjit_archflag:+ MJIT_ARCHFLAG}" $(MJIT_DLDFLAGS); \
 	quote "MJIT_LIBS       " $(LIBRUBYARG_SHARED); \
+	quote 'PRELOADENV       "@PRELOADENV@"'; \
 	$${archs:+echo} $${archs:+'#if 0'}; \
 	for arch in $$archs; do \
 	    echo "#elif defined __$${arch%=*}__"; \
@@ -630,3 +631,12 @@ mjit_config.h: https://github.com/ruby/ruby/blob/trunk/Makefile.in#L631
 	echo; \
 	echo '#endif /* RUBY_MJIT_CONFIG_H */'; \
 	} > $@
+
+yes-test-all: mjit_build_dir.$(SOEXT)
+mjit_build_dir.$(SOEXT): $(MJIT_MIN_HEADER)
+	$(ECHO) making $@
+	$(Q) { \
+	echo 'const char MJIT_BUILD_DIR[] = "'"`$(CHDIR) . && pwd`"'";'; \
+	} > $(@:.$(SOEXT)=.c)
+	$(Q) cat $(@:.$(SOEXT)=.c)
+	$(Q) $(DLDSHARED) $(MJIT_DLDFLAGS) $(ARCH_FLAG) $(CFLAGS) $(CPPFLAGS) $(@:.$(SOEXT)=.c) $(OUTFLAG)$@
Index: test/lib/jit_support.rb
===================================================================
--- test/lib/jit_support.rb	(revision 65586)
+++ test/lib/jit_support.rb	(revision 65587)
@@ -30,6 +30,10 @@ module JITSupport https://github.com/ruby/ruby/blob/trunk/test/lib/jit_support.rb#L30
     args << '--jit-save-temps' if save_temps
     args << '-e' << script
     base_env = { 'MJIT_SEARCH_BUILD_DIR' => 'true' } # workaround to skip requiring `make install` for `make test-all`
+    if preloadenv = RbConfig::CONFIG['PRELOADENV'] and !preloadenv.empty?
+      so = "mjit_build_dir.#{RbConfig::CONFIG['SOEXT']}"
+      base_env[preloadenv] = File.realpath(so) rescue nil
+    end
     args.unshift(env ? base_env.merge!(env) : base_env)
     EnvUtil.invoke_ruby(args,
       '', true, true, timeout: timeout,
Index: mjit.c
===================================================================
--- mjit.c	(revision 65586)
+++ mjit.c	(revision 65587)
@@ -388,7 +388,7 @@ init_header_filename(void) https://github.com/ruby/ruby/blob/trunk/mjit.c#L388
     const size_t libpathflag_len = sizeof(libpathflag) - 1;
 #endif
 #ifndef LOAD_RELATIVE
-    static const char build_dir[] = MJIT_BUILD_DIR;
+    const char *build_dir = 0;
     struct stat st;
 #endif
 
@@ -401,7 +401,12 @@ init_header_filename(void) https://github.com/ruby/ruby/blob/trunk/mjit.c#L401
         /* This path is not intended to be used on production, but using build directory's
            header file here because people want to run `make test-all` without running
            `make install`. Don't use $MJIT_SEARCH_BUILD_DIR except for test-all. */
-        if (build_dir[0] != '/') {
+
+        build_dir = dlsym(RTLD_DEFAULT, "MJIT_BUILD_DIR");
+        if (!build_dir) {
+            verbose(1, "No mjit_build_directory");
+        }
+        else if (build_dir[0] != '/') {
             verbose(1, "Non-absolute path MJIT_BUILD_DIR: %s", build_dir);
         }
         else if (stat(build_dir, &st) || !S_ISDIR(st.st_mode)) {
@@ -412,8 +417,14 @@ init_header_filename(void) https://github.com/ruby/ruby/blob/trunk/mjit.c#L417
             return FALSE;
         }
         else {
+            /* Do not pass PRELOADENV to child processes, on
+             * multi-arch environment */
+            verbose(3, "PRELOADENV("PRELOADENV")=%s", getenv(PRELOADENV));
+            /* assume no other PRELOADENV in test-all */
+            unsetenv(PRELOADENV);
+            verbose(3, "MJIT_BUILD_DIR: %s", build_dir);
             basedir = build_dir;
-            baselen = sizeof(build_dir) - 1;
+            baselen = strlen(build_dir);
         }
     }
 #endif

--
ML: ruby-changes@q...
Info: http://www.atdot.net/~ko1/quickml/

[前][次][番号順一覧][スレッド一覧]