mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 c18ae6327a
			
		
	
	
		c18ae6327a
		
	
	
	
	
		
			
			Some distros put -fstack-protector-strong in the compiler flags to be used to build python extensions, but then, the clang version in that distro doesn't know about that, only gcc does. Check if that is the case and remove it from the set of options used to build the python binding with clang. Case at hand: oraclelinux:7 $ head -2 /etc/os-release NAME="Oracle Linux Server" VERSION="7.6" $ grep stack-protector /usr/lib64/python2.7/_sysconfigdata.py | head -1 | cut -c-120 'CFLAGS': '-fno-strict-aliasing -O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector-strong --para $ gcc version 4.8.5 20150623 (Red Hat 4.8.5-36.0.1) (GCC) clang version 3.4.2 (tags/RELEASE_34/dot2-final) clang: error: unknown argument: '-fstack-protector-strong' clang: error: unknown argument: '-fstack-protector-strong' error: command 'clang' failed with exit status 1 cp: cannot stat '/tmp/build/perf/python_ext_build/lib/perf*.so': No such file or directory make[2]: *** [/tmp/build/perf/python/perf.so] Error 1 Cc: Adrian Hunter <adrian.hunter@intel.com> Cc: Jiri Olsa <jolsa@kernel.org> Cc: Namhyung Kim <namhyung@kernel.org> Link: https://lkml.kernel.org/n/tip-brmp2415zxpbhz45etkgjoma@git.kernel.org Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
		
			
				
	
	
		
			79 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			79 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| from os import getenv
 | |
| from subprocess import Popen, PIPE
 | |
| from re import sub
 | |
| 
 | |
| def clang_has_option(option):
 | |
|     return [o for o in Popen(['clang', option], stderr=PIPE).stderr.readlines() if b"unknown argument" in o] == [ ]
 | |
| 
 | |
| cc = getenv("CC")
 | |
| if cc == "clang":
 | |
|     from distutils.sysconfig import get_config_vars
 | |
|     vars = get_config_vars()
 | |
|     for var in ('CFLAGS', 'OPT'):
 | |
|         vars[var] = sub("-specs=[^ ]+", "", vars[var])
 | |
|         if not clang_has_option("-mcet"):
 | |
|             vars[var] = sub("-mcet", "", vars[var])
 | |
|         if not clang_has_option("-fcf-protection"):
 | |
|             vars[var] = sub("-fcf-protection", "", vars[var])
 | |
|         if not clang_has_option("-fstack-clash-protection"):
 | |
|             vars[var] = sub("-fstack-clash-protection", "", vars[var])
 | |
|         if not clang_has_option("-fstack-protector-strong"):
 | |
|             vars[var] = sub("-fstack-protector-strong", "", vars[var])
 | |
| 
 | |
| from distutils.core import setup, Extension
 | |
| 
 | |
| from distutils.command.build_ext   import build_ext   as _build_ext
 | |
| from distutils.command.install_lib import install_lib as _install_lib
 | |
| 
 | |
| class build_ext(_build_ext):
 | |
|     def finalize_options(self):
 | |
|         _build_ext.finalize_options(self)
 | |
|         self.build_lib  = build_lib
 | |
|         self.build_temp = build_tmp
 | |
| 
 | |
| class install_lib(_install_lib):
 | |
|     def finalize_options(self):
 | |
|         _install_lib.finalize_options(self)
 | |
|         self.build_dir = build_lib
 | |
| 
 | |
| 
 | |
| cflags = getenv('CFLAGS', '').split()
 | |
| # switch off several checks (need to be at the end of cflags list)
 | |
| cflags += ['-fno-strict-aliasing', '-Wno-write-strings', '-Wno-unused-parameter', '-Wno-redundant-decls' ]
 | |
| if cc != "clang":
 | |
|     cflags += ['-Wno-cast-function-type' ]
 | |
| 
 | |
| src_perf  = getenv('srctree') + '/tools/perf'
 | |
| build_lib = getenv('PYTHON_EXTBUILD_LIB')
 | |
| build_tmp = getenv('PYTHON_EXTBUILD_TMP')
 | |
| libtraceevent = getenv('LIBTRACEEVENT')
 | |
| libapikfs = getenv('LIBAPI')
 | |
| 
 | |
| ext_sources = [f.strip() for f in open('util/python-ext-sources')
 | |
| 				if len(f.strip()) > 0 and f[0] != '#']
 | |
| 
 | |
| # use full paths with source files
 | |
| ext_sources = list(map(lambda x: '%s/%s' % (src_perf, x) , ext_sources))
 | |
| 
 | |
| extra_libraries = []
 | |
| if '-DHAVE_LIBNUMA_SUPPORT' in cflags:
 | |
|     extra_libraries = [ 'numa' ]
 | |
| 
 | |
| perf = Extension('perf',
 | |
| 		  sources = ext_sources,
 | |
| 		  include_dirs = ['util/include'],
 | |
| 		  libraries = extra_libraries,
 | |
| 		  extra_compile_args = cflags,
 | |
| 		  extra_objects = [libtraceevent, libapikfs],
 | |
|                  )
 | |
| 
 | |
| setup(name='perf',
 | |
|       version='0.1',
 | |
|       description='Interface with the Linux profiling infrastructure',
 | |
|       author='Arnaldo Carvalho de Melo',
 | |
|       author_email='acme@redhat.com',
 | |
|       license='GPLv2',
 | |
|       url='http://perf.wiki.kernel.org',
 | |
|       ext_modules=[perf],
 | |
|       cmdclass={'build_ext': build_ext, 'install_lib': install_lib})
 |