add --generic flag to wscript to trigger -mtune=generic builds; stop using old GNU...
authorPaul Davis <paul@linuxaudiosystems.com>
Tue, 15 May 2012 12:55:23 +0000 (12:55 +0000)
committerPaul Davis <paul@linuxaudiosystems.com>
Tue, 15 May 2012 12:55:23 +0000 (12:55 +0000)
git-svn-id: svn://localhost/ardour2/branches/3.0@12290 d708f5d6-7413-0410-9779-e7cbd77b26cf

wscript

diff --git a/wscript b/wscript
index 54b2ffd16f372d410779240a105cd270b7286cba..37770e49886a4325931c48672888635a7cc1c25a 100644 (file)
--- a/wscript
+++ b/wscript
@@ -122,52 +122,51 @@ def set_compiler_flags (conf,opt):
     optimization_flags = []
     debug_flags = []
 
-    # guess at the platform, used to define compiler flags
-
-    config_guess = os.popen("tools/config.guess").read()[:-1]
-
-    config_cpu = 0
-    config_arch = 1
-    config_kernel = 2
-    config_os = 3
-    config = config_guess.split ("-")
+    u = os.uname ()
+    cpu = u[4]
+    platform = u[0].lower()
+    version = u[2]
 
     if opt.gprofile:
         debug_flags = [ '-pg' ]
     else:
-        if config[config_arch] != 'apple':
+        if platform != 'darwin':
             debug_flags = [ '-rdynamic' ] # waf adds -O0 -g itself. thanks waf!
 
     # Autodetect
     if opt.dist_target == 'auto':
-        if config[config_arch] == 'apple':
+        if platform == 'darwin':
             # The [.] matches to the dot after the major version, "." would match any character
-            if re.search ("darwin[0-7][.]", config[config_kernel]) != None:
+            if re.search ("^[0-7][.]", version) != None:
                 conf.env['build_target'] = 'panther'
-            elif re.search ("darwin8[.]", config[config_kernel]) != None:
+            elif re.search ("^8[.]", version) != None:
                 conf.env['build_target'] = 'tiger'
-            else:
+            elif re.search ("^9[.]", version) != None:
                 conf.env['build_target'] = 'leopard'
+            elif re.search ("^10[.]", version) != None:
+                conf.env['build_target'] = 'snowleopard'
+            else:
+                conf.env['build_target'] = 'lion'
         else:
-            if re.search ("x86_64", config[config_cpu]) != None:
+            if re.search ("x86_64", cpu) != None:
                 conf.env['build_target'] = 'x86_64'
-            elif re.search("i[0-5]86", config[config_cpu]) != None:
+            elif re.search("i[0-5]86", cpu) != None:
                 conf.env['build_target'] = 'i386'
-            elif re.search("powerpc", config[config_cpu]) != None:
+            elif re.search("powerpc", config_cpu) != None:
                 conf.env['build_target'] = 'powerpc'
             else:
                 conf.env['build_target'] = 'i686'
     else:
         conf.env['build_target'] = opt.dist_target
 
-    if config[config_cpu] == 'powerpc' and conf.env['build_target'] != 'none':
+    if cpu == 'powerpc' and conf.env['build_target'] != 'none':
         #
         # Apple/PowerPC optimization options
         #
         # -mcpu=7450 does not reliably work with gcc 3.*
         #
         if opt.dist_target == 'panther' or opt.dist_target == 'tiger':
-            if config[config_arch] == 'apple':
+            if platform == 'darwin':
                 # optimization_flags.extend ([ "-mcpu=7450", "-faltivec"])
                 # to support g3s but still have some optimization for above
                 optimization_flags.extend ([ "-mcpu=G3", "-mtune=7450"])
@@ -178,7 +177,7 @@ def set_compiler_flags (conf,opt):
         optimization_flags.extend (["-mhard-float", "-mpowerpc-gfxopt"])
         optimization_flags.extend (["-Os"])
 
-    elif ((re.search ("i[0-9]86", config[config_cpu]) != None) or (re.search ("x86_64", config[config_cpu]) != None)) and conf.env['build_target'] != 'none':
+    elif ((re.search ("i[0-9]86", cpu) != None) or (re.search ("x86_64", cpu) != None)) and conf.env['build_target'] != 'none':
 
 
         #
@@ -187,11 +186,11 @@ def set_compiler_flags (conf,opt):
         # distingush 32 and 64 bit assembler
         #
 
-        if (re.search ("(i[0-9]86|x86_64)", config[config_cpu]) != None):
+        if (re.search ("(i[0-9]86|x86_64)", cpu) != None):
             debug_flags.append ("-DARCH_X86")
             optimization_flags.append ("-DARCH_X86")
 
-        if config[config_kernel] == 'linux' :
+        if platform == 'linux' :
 
             #
             # determine processor flags via /proc/cpuinfo
@@ -209,9 +208,9 @@ def set_compiler_flags (conf,opt):
                 if "3dnow" in x86_flags:
                     optimization_flags.append ("-m3dnow")
 
-            if config[config_cpu] == "i586":
+            if cpu == "i586":
                 optimization_flags.append ("-march=i586")
-            elif config[config_cpu] == "i686":
+            elif cpu == "i686":
                 optimization_flags.append ("-march=i686")
 
         if ((conf.env['build_target'] == 'i686') or (conf.env['build_target'] == 'x86_64')) and build_host_supports_sse:
@@ -222,7 +221,7 @@ def set_compiler_flags (conf,opt):
 
     # optimization section
     if conf.env['FPU_OPTIMIZATION']:
-        if conf.env['build_target'] == 'tiger' or conf.env['build_target'] == 'leopard':
+        if sys.platform == 'darwin':
             optimization_flags.append ("-DBUILD_VECLIB_OPTIMIZATIONS");
             debug_flags.append ("-DBUILD_VECLIB_OPTIMIZATIONS");
             conf.env.append_value('LINKFLAGS', "-framework Accelerate")
@@ -270,9 +269,9 @@ def set_compiler_flags (conf,opt):
         conf.define ('IS_OSX', 0)
 
     #
-    # save off guessed arch element in an env
+    # save off CPU element in an env
     #
-    conf.define ('CONFIG_ARCH', config[config_arch])
+    conf.define ('CONFIG_ARCH', cpu)
 
     #
     # ARCH="..." overrides all
@@ -315,14 +314,23 @@ def set_compiler_flags (conf,opt):
         conf.env.append_value('CXXFLAGS', '-DDEBUG_DENORMAL_EXCEPTION')
 
     if opt.universal:
-        if not Options.options.nocarbon:
-            conf.env.append_value('CFLAGS', ["-arch", "i386", "-arch", "ppc"])
-            conf.env.append_value('CXXFLAGS', ["-arch", "i386", "-arch", "ppc"])
-            conf.env.append_value('LINKFLAGS', ["-arch", "i386", "-arch", "ppc"])
+        if opt.generic:
+            print ('Specifying Universal and Generic builds at the same time is not supported')
+            sys.exit (1)
         else:
-            conf.env.append_value('CFLAGS', ["-arch", "x86_64", "-arch", "i386", "-arch", "ppc"])
-            conf.env.append_value('CXXFLAGS', ["-arch", "x86_64", "-arch", "i386", "-arch", "ppc"])
-            conf.env.append_value('LINKFLAGS', ["-arch", "x86_64", "-arch", "i386", "-arch", "ppc"])
+            if not Options.options.nocarbon:
+                conf.env.append_value('CFLAGS', ["-arch", "i386", "-arch", "ppc"])
+                conf.env.append_value('CXXFLAGS', ["-arch", "i386", "-arch", "ppc"])
+                conf.env.append_value('LINKFLAGS', ["-arch", "i386", "-arch", "ppc"])
+            else:
+                conf.env.append_value('CFLAGS', ["-arch", "x86_64", "-arch", "i386", "-arch", "ppc"])
+                conf.env.append_value('CXXFLAGS', ["-arch", "x86_64", "-arch", "i386", "-arch", "ppc"])
+                conf.env.append_value('LINKFLAGS', ["-arch", "x86_64", "-arch", "i386", "-arch", "ppc"])
+    else:
+        if opt.generic:
+            conf.env.append_value('CFLAGS', ['-mtune=generic'])
+            conf.env.append_value('CXXFLAGS', ['-mtune=generic'])
+            conf.env.append_value('LINKFLAGS', ['-mtune=generic'])
 
     #
     # warnings flags
@@ -401,6 +409,8 @@ def options(opt):
                     help='Compile with support for Frontier Designs Tranzport (if libusb is available)')
     opt.add_option('--universal', action='store_true', default=False, dest='universal',
                     help='Compile as universal binary (OS X ONLY, requires that external libraries are universal)')
+    opt.add_option('--generic', action='store_true', default=False, dest='generic',
+                    help='Compile with -march=generic')
     opt.add_option('--versioned', action='store_true', default=False, dest='versioned',
                     help='Add revision information to executable name inside the build directory')
     opt.add_option('--windows-vst', action='store_true', default=False, dest='windows_vst',
@@ -466,8 +476,7 @@ def configure(conf):
 
         conf.define ('HAVE_COREAUDIO', 1)
         conf.define ('AUDIOUNIT_SUPPORT', 1)
-        if not Options.options.nocarbon:
-            conf.define ('WITH_CARBON', 1)
+
         if not Options.options.freebie:
             conf.define ('AU_STATE_SUPPORT', 1)
 
@@ -522,9 +531,12 @@ def configure(conf):
 
         if not Options.options.freebie:
             conf.env.append_value('CXXFLAGS_AUDIOUNITS', "-DAU_STATE_SUPPORT")
-        if not Options.options.nocarbon:
+
+        if re.search ("^[1-9][0-9]\.", os.uname()[2]) == None and not Options.options.nocarbon:
             conf.env.append_value('CXXFLAGS_AUDIOUNITS', "-DWITH_CARBON")
             conf.env.append_value('LINKFLAGS_AUDIOUNITS', ['-framework', 'Carbon'])
+        else:
+            print ('No Carbon support available for this build\n')
 
     if Options.options.boost_include != '':
         conf.env.append_value('CXXFLAGS', '-I' + Options.options.boost_include)
@@ -661,6 +673,7 @@ const char* const ardour_config_info = "\\n\\
     write_config_text('Tranzport',             opts.tranzport)
     write_config_text('Unit tests',            conf.env['BUILD_TESTS'])
     write_config_text('Universal binary',      opts.universal)
+    write_config_text('Generic x86 CPU',       opts.generic)
     write_config_text('Windows VST support',   opts.windows_vst)
     write_config_text('Wiimote support',       opts.wiimote)
     write_config_text('Windows key',           opts.windows_key)