1 from os import getenv, path !! 1 from os import getenv 2 from subprocess import Popen, PIPE 2 from subprocess import Popen, PIPE 3 from re import sub 3 from re import sub 4 4 5 cc = getenv("CC") << 6 << 7 # Check if CC has options, as is the case in y << 8 cc_tokens = cc.split() << 9 if len(cc_tokens) > 1: << 10 cc = cc_tokens[0] << 11 cc_options = " ".join([str(e) for e in cc_ << 12 else: << 13 cc_options = "" << 14 << 15 cc_is_clang = b"clang version" in Popen([cc, " << 16 src_feature_tests = getenv('srctree') + '/too << 17 << 18 def clang_has_option(option): 5 def clang_has_option(option): 19 cc_output = Popen([cc, cc_options + option !! 6 return [o for o in Popen(['clang', option], stderr=PIPE).stderr.readlines() if b"unknown argument" in o] == [ ] 20 return [o for o in cc_output if ((b"unknow << 21 7 22 if cc_is_clang: !! 8 cc = getenv("CC") 23 from sysconfig import get_config_vars !! 9 if cc == "clang": >> 10 from distutils.sysconfig import get_config_vars 24 vars = get_config_vars() 11 vars = get_config_vars() 25 for var in ('CFLAGS', 'OPT'): 12 for var in ('CFLAGS', 'OPT'): 26 vars[var] = sub("-specs=[^ ]+", "", va 13 vars[var] = sub("-specs=[^ ]+", "", vars[var]) 27 if not clang_has_option("-mcet"): 14 if not clang_has_option("-mcet"): 28 vars[var] = sub("-mcet", "", vars[ 15 vars[var] = sub("-mcet", "", vars[var]) 29 if not clang_has_option("-fcf-protecti 16 if not clang_has_option("-fcf-protection"): 30 vars[var] = sub("-fcf-protection", 17 vars[var] = sub("-fcf-protection", "", vars[var]) 31 if not clang_has_option("-fstack-clash 18 if not clang_has_option("-fstack-clash-protection"): 32 vars[var] = sub("-fstack-clash-pro 19 vars[var] = sub("-fstack-clash-protection", "", vars[var]) 33 if not clang_has_option("-fstack-prote 20 if not clang_has_option("-fstack-protector-strong"): 34 vars[var] = sub("-fstack-protector 21 vars[var] = sub("-fstack-protector-strong", "", vars[var]) 35 if not clang_has_option("-fno-semantic << 36 vars[var] = sub("-fno-semantic-int << 37 if not clang_has_option("-ffat-lto-obj << 38 vars[var] = sub("-ffat-lto-objects << 39 if not clang_has_option("-ftree-loop-d << 40 vars[var] = sub("-ftree-loop-distr << 41 if not clang_has_option("-gno-variable << 42 vars[var] = sub("-gno-variable-loc << 43 22 44 from setuptools import setup, Extension !! 23 from distutils.core import setup, Extension 45 24 46 from setuptools.command.build_ext import bui !! 25 from distutils.command.build_ext import build_ext as _build_ext 47 from setuptools.command.install_lib import ins !! 26 from distutils.command.install_lib import install_lib as _install_lib 48 27 49 class build_ext(_build_ext): 28 class build_ext(_build_ext): 50 def finalize_options(self): 29 def finalize_options(self): 51 _build_ext.finalize_options(self) 30 _build_ext.finalize_options(self) 52 self.build_lib = build_lib 31 self.build_lib = build_lib 53 self.build_temp = build_tmp 32 self.build_temp = build_tmp 54 33 55 class install_lib(_install_lib): 34 class install_lib(_install_lib): 56 def finalize_options(self): 35 def finalize_options(self): 57 _install_lib.finalize_options(self) 36 _install_lib.finalize_options(self) 58 self.build_dir = build_lib 37 self.build_dir = build_lib 59 38 60 39 61 cflags = getenv('CFLAGS', '').split() 40 cflags = getenv('CFLAGS', '').split() 62 # switch off several checks (need to be at the 41 # switch off several checks (need to be at the end of cflags list) 63 cflags += ['-fno-strict-aliasing', '-Wno-write 42 cflags += ['-fno-strict-aliasing', '-Wno-write-strings', '-Wno-unused-parameter', '-Wno-redundant-decls' ] 64 if cc_is_clang: !! 43 if cc != "clang": 65 cflags += ["-Wno-unused-command-line-argum << 66 if clang_has_option("-Wno-cast-function-ty << 67 cflags += ["-Wno-cast-function-type-mi << 68 else: << 69 cflags += ['-Wno-cast-function-type' ] 44 cflags += ['-Wno-cast-function-type' ] 70 45 71 # The python headers have mixed code with decl << 72 cflags += [ "-Wno-declaration-after-statement" << 73 << 74 src_perf = getenv('srctree') + '/tools/perf' 46 src_perf = getenv('srctree') + '/tools/perf' 75 build_lib = getenv('PYTHON_EXTBUILD_LIB') 47 build_lib = getenv('PYTHON_EXTBUILD_LIB') 76 build_tmp = getenv('PYTHON_EXTBUILD_TMP') 48 build_tmp = getenv('PYTHON_EXTBUILD_TMP') >> 49 libtraceevent = getenv('LIBTRACEEVENT') >> 50 libapikfs = getenv('LIBAPI') >> 51 libperf = getenv('LIBPERF') >> 52 >> 53 ext_sources = [f.strip() for f in open('util/python-ext-sources') >> 54 if len(f.strip()) > 0 and f[0] != '#'] >> 55 >> 56 # use full paths with source files >> 57 ext_sources = list(map(lambda x: '%s/%s' % (src_perf, x) , ext_sources)) >> 58 >> 59 extra_libraries = [] >> 60 if '-DHAVE_LIBNUMA_SUPPORT' in cflags: >> 61 extra_libraries = [ 'numa' ] >> 62 if '-DHAVE_LIBCAP_SUPPORT' in cflags: >> 63 extra_libraries += [ 'cap' ] 77 64 78 perf = Extension('perf', 65 perf = Extension('perf', 79 sources = [ src_perf + '/util !! 66 sources = ext_sources, 80 include_dirs = ['util !! 67 include_dirs = ['util/include'], 81 extra_compile_args = !! 68 libraries = extra_libraries, >> 69 extra_compile_args = cflags, >> 70 extra_objects = [libtraceevent, libapikfs, libperf], 82 ) 71 ) 83 72 84 setup(name='perf', 73 setup(name='perf', 85 version='0.1', 74 version='0.1', 86 description='Interface with the Linux pr 75 description='Interface with the Linux profiling infrastructure', 87 author='Arnaldo Carvalho de Melo', 76 author='Arnaldo Carvalho de Melo', 88 author_email='acme@redhat.com', 77 author_email='acme@redhat.com', 89 license='GPLv2', 78 license='GPLv2', 90 url='http://perf.wiki.kernel.org', 79 url='http://perf.wiki.kernel.org', 91 ext_modules=[perf], 80 ext_modules=[perf], 92 cmdclass={'build_ext': build_ext, 'insta 81 cmdclass={'build_ext': build_ext, 'install_lib': install_lib})
Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.