1 # -*- Python -*- 2 3 # Configuration file for 'lit' test runner. 4 # This file contains common rules for various compiler-rt testsuites. 5 # It is mostly copied from lit.cfg used by Clang. 6 import os 7 import platform 8 import re 9 import subprocess 10 11 import lit.formats 12 import lit.util 13 14 # Setup test format. Use bash on Unix and the lit shell on Windows. 15 execute_external = (not sys.platform in ['win32']) 16 config.test_format = lit.formats.ShTest(execute_external) 17 if execute_external: 18 config.available_features.add('shell') 19 20 # Setup clang binary. 21 compiler_path = getattr(config, 'clang', None) 22 if (not compiler_path) or (not os.path.exists(compiler_path)): 23 lit_config.fatal("Can't find compiler on path %r" % compiler_path) 24 25 compiler_id = getattr(config, 'compiler_id', None) 26 if compiler_id == "Clang": 27 if platform.system() != 'Windows': 28 config.cxx_mode_flags = ["--driver-mode=g++"] 29 else: 30 config.cxx_mode_flags = [] 31 # We assume that sanitizers should provide good enough error 32 # reports and stack traces even with minimal debug info. 33 config.debug_info_flags = ["-gline-tables-only"] 34 if platform.system() == 'Windows': 35 config.debug_info_flags.append("-gcodeview") 36 elif compiler_id == 'GNU': 37 config.cxx_mode_flags = ["-x c++"] 38 config.debug_info_flags = ["-g"] 39 else: 40 lit_config.fatal("Unsupported compiler id: %r" % compiler_id) 41 # Add compiler ID to the list of available features. 42 config.available_features.add(compiler_id) 43 44 # Clear some environment variables that might affect Clang. 45 possibly_dangerous_env_vars = ['ASAN_OPTIONS', 'DFSAN_OPTIONS', 'LSAN_OPTIONS', 46 'MSAN_OPTIONS', 'UBSAN_OPTIONS', 47 'COMPILER_PATH', 'RC_DEBUG_OPTIONS', 48 'CINDEXTEST_PREAMBLE_FILE', 'LIBRARY_PATH', 49 'CPATH', 'C_INCLUDE_PATH', 'CPLUS_INCLUDE_PATH', 50 'OBJC_INCLUDE_PATH', 'OBJCPLUS_INCLUDE_PATH', 51 'LIBCLANG_TIMING', 'LIBCLANG_OBJTRACKING', 52 'LIBCLANG_LOGGING', 'LIBCLANG_BGPRIO_INDEX', 53 'LIBCLANG_BGPRIO_EDIT', 'LIBCLANG_NOTHREADS', 54 'LIBCLANG_RESOURCE_USAGE', 55 'LIBCLANG_CODE_COMPLETION_LOGGING'] 56 # Clang/Win32 may refer to %INCLUDE%. vsvarsall.bat sets it. 57 if platform.system() != 'Windows': 58 possibly_dangerous_env_vars.append('INCLUDE') 59 for name in possibly_dangerous_env_vars: 60 if name in config.environment: 61 del config.environment[name] 62 63 # Tweak PATH to include llvm tools dir. 64 llvm_tools_dir = getattr(config, 'llvm_tools_dir', None) 65 if (not llvm_tools_dir) or (not os.path.exists(llvm_tools_dir)): 66 lit_config.fatal("Invalid llvm_tools_dir config attribute: %r" % llvm_tools_dir) 67 path = os.path.pathsep.join((llvm_tools_dir, config.environment['PATH'])) 68 config.environment['PATH'] = path 69 70 # Help MSVS link.exe find the standard libraries. 71 # Make sure we only try to use it when targetting Windows. 72 if platform.system() == 'Windows' and '-win' in config.target_triple: 73 config.environment['LIB'] = os.environ['LIB'] 74 75 if re.match(r'^x86_64.*-linux', config.target_triple): 76 config.available_features.add("x86_64-linux") 77 78 # Use ugly construction to explicitly prohibit "clang", "clang++" etc. 79 # in RUN lines. 80 config.substitutions.append( 81 (' clang', """\n\n*** Do not use 'clangXXX' in tests, 82 instead define '%clangXXX' substitution in lit config. ***\n\n""") ) 83 84 # Allow tests to be executed on a simulator or remotely. 85 config.substitutions.append( ('%run', config.emulator) ) 86 87 # Define CHECK-%os to check for OS-dependent output. 88 config.substitutions.append( ('CHECK-%os', ("CHECK-" + config.host_os))) 89 90 if config.host_os == 'Windows': 91 # FIXME: This isn't quite right. Specifically, it will succeed if the program 92 # does not crash but exits with a non-zero exit code. We ought to merge 93 # KillTheDoctor and not --crash to make the latter more useful and remove the 94 # need for this substitution. 95 config.expect_crash = "not KillTheDoctor " 96 else: 97 config.expect_crash = "not --crash " 98 99 config.substitutions.append( ("%expect_crash ", config.expect_crash) ) 100 101 target_arch = getattr(config, 'target_arch', None) 102 if target_arch: 103 config.available_features.add(target_arch + '-target-arch') 104 if target_arch in ['x86_64', 'i386', 'i686']: 105 config.available_features.add('x86-target-arch') 106 107 compiler_rt_debug = getattr(config, 'compiler_rt_debug', False) 108 if not compiler_rt_debug: 109 config.available_features.add('compiler-rt-optimized') 110 111 sanitizer_can_use_cxxabi = getattr(config, 'sanitizer_can_use_cxxabi', True) 112 if sanitizer_can_use_cxxabi: 113 config.available_features.add('cxxabi') 114 115 if config.has_lld: 116 config.available_features.add('lld') 117 118 if config.can_symbolize: 119 config.available_features.add('can-symbolize') 120 121 lit.util.usePlatformSdkOnDarwin(config, lit_config) 122 123 if config.host_os == 'Darwin': 124 try: 125 osx_version = subprocess.check_output(["sw_vers", "-productVersion"]) 126 osx_version = tuple(int(x) for x in osx_version.split('.')) 127 if osx_version >= (10, 11): 128 config.available_features.add('osx-autointerception') 129 config.available_features.add('osx-ld64-live_support') 130 else: 131 # The ASAN initialization-bug.cc test should XFAIL on OS X systems 132 # older than El Capitan. By marking the test as being unsupported with 133 # this "feature", we can pass the test on newer OS X versions and other 134 # platforms. 135 config.available_features.add('osx-no-ld64-live_support') 136 except: 137 pass 138 139 sancovcc_path = os.path.join(llvm_tools_dir, "sancov") 140 if os.path.exists(sancovcc_path): 141 config.available_features.add("has_sancovcc") 142 config.substitutions.append( ("%sancovcc ", sancovcc_path) ) 143 144 def is_darwin_lto_supported(): 145 return os.path.exists(os.path.join(config.llvm_shlib_dir, 'libLTO.dylib')) 146 147 def is_linux_lto_supported(): 148 if not os.path.exists(os.path.join(config.llvm_shlib_dir, 'LLVMgold.so')): 149 return False 150 151 ld_cmd = subprocess.Popen([config.gold_executable, '--help'], stdout = subprocess.PIPE) 152 ld_out = ld_cmd.stdout.read().decode() 153 ld_cmd.wait() 154 155 if not '-plugin' in ld_out: 156 return False 157 158 return True 159 160 def is_windows_lto_supported(): 161 return os.path.exists(os.path.join(config.llvm_tools_dir, 'lld-link.exe')) 162 163 if config.host_os == 'Darwin' and is_darwin_lto_supported(): 164 config.lto_supported = True 165 config.lto_launch = ["env", "DYLD_LIBRARY_PATH=" + config.llvm_shlib_dir] 166 config.lto_flags = [] 167 elif config.host_os == 'Linux' and is_linux_lto_supported(): 168 config.lto_supported = True 169 config.lto_launch = [] 170 config.lto_flags = ["-fuse-ld=gold"] 171 elif config.host_os == 'Windows' and is_windows_lto_supported(): 172 config.lto_supported = True 173 config.lto_launch = [] 174 config.lto_flags = ["-fuse-ld=lld"] 175 else: 176 config.lto_supported = False 177 178 # Ask llvm-config about assertion mode. 179 try: 180 llvm_config_cmd = subprocess.Popen( 181 [os.path.join(config.llvm_tools_dir, 'llvm-config'), '--assertion-mode'], 182 stdout = subprocess.PIPE, 183 env=config.environment) 184 except OSError: 185 print("Could not find llvm-config in " + llvm_tools_dir) 186 exit(42) 187 188 if re.search(r'ON', llvm_config_cmd.stdout.read().decode('ascii')): 189 config.available_features.add('asserts') 190 llvm_config_cmd.wait() 191 192 # Sanitizer tests tend to be flaky on Windows due to PR24554, so add some 193 # retries. We don't do this on otther platforms because it's slower. 194 if platform.system() == 'Windows': 195 config.test_retry_attempts = 2 196