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

ruby-changes:54654

From: k0kubun <ko1@a...>
Date: Sat, 19 Jan 2019 16:35:34 +0900 (JST)
Subject: [ruby-changes:54654] k0kubun:r66870 (trunk): mjit_worker.c: try to simplify CC_DLDFLAGS_ARGS

k0kubun	2019-01-19 16:35:30 +0900 (Sat, 19 Jan 2019)

  New Revision: 66870

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

  Log:
    mjit_worker.c: try to simplify CC_DLDFLAGS_ARGS
    
    assuming that -nostartfiles is just optional for mingw, cygwin, and AIX.

  Modified files:
    trunk/mjit_worker.c
Index: mjit_worker.c
===================================================================
--- mjit_worker.c	(revision 66869)
+++ mjit_worker.c	(revision 66870)
@@ -247,10 +247,10 @@ static char *libruby_pathflag; https://github.com/ruby/ruby/blob/trunk/mjit_worker.c#L247
 # define MJIT_CFLAGS_PIPE 0
 #endif
 
-// Use `-nodefaultlibs -nostdlib` for GCC where possible, which does not work on mingw, cygwin, AIX, and OpenBSD.
-// This seems to improve MJIT performance on GCC.
+// Use `-nostartfiles -nodefaultlibs -nostdlib` for GCC where possible, which does not work on mingw, cygwin, AIX, and OpenBSD.
+// This seems to improve MJIT performance on GCC. TODO: Check if it works with MJIT and add it on configure.
 #if defined __GNUC__ && !defined __clang__ && !defined(_WIN32) && !defined(__CYGWIN__) && !defined(_AIX) && !defined(__OpenBSD__)
-# define GCC_NOSTDLIB_FLAGS "-nodefaultlibs", "-nostdlib",
+# define GCC_NOSTDLIB_FLAGS "-nostartfiles", "-nodefaultlibs", "-nostdlib",
 #else
 # define GCC_NOSTDLIB_FLAGS /* empty */
 #endif
@@ -264,13 +264,7 @@ static const char *const CC_DEBUG_ARGS[] https://github.com/ruby/ruby/blob/trunk/mjit_worker.c#L264
 static const char *const CC_OPTIMIZE_ARGS[] = {MJIT_OPTFLAGS NULL};
 
 static const char *const CC_LDSHARED_ARGS[] = {MJIT_LDSHARED GCC_PIC_FLAGS NULL};
-static const char *const CC_DLDFLAGS_ARGS[] = {
-    MJIT_DLDFLAGS
-#if defined __GNUC__ && !defined __clang__ && !defined(__OpenBSD__)
-    "-nostartfiles",
-#endif
-    GCC_NOSTDLIB_FLAGS NULL
-};
+static const char *const CC_DLDFLAGS_ARGS[] = {MJIT_DLDFLAGS GCC_NOSTDLIB_FLAGS NULL};
 
 static const char *const CC_LIBS[] = {
 #if defined(_WIN32) || defined(__CYGWIN__)
@@ -280,7 +274,7 @@ static const char *const CC_LIBS[] = { https://github.com/ruby/ruby/blob/trunk/mjit_worker.c#L274
 # if defined(_WIN32)
     "-lmsvcrt", // mingw
 # endif
-    "-lgcc", // mingw, cygwin, and GCC platforms using `-nodefaultlibs -nostdlib`
+    "-lgcc", // all platforms using GCC
 #endif
     NULL
 };

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

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