1f8833479SBarry Smithimport config.base 2f8833479SBarry Smith 3f8833479SBarry Smithimport os 46dd73af6SBarry Smithimport sys 5f8833479SBarry Smithimport re 6492432c8SJed Brownimport pickle 7f8833479SBarry Smith 8f8833479SBarry Smithclass Configure(config.base.Configure): 9f8833479SBarry Smith def __init__(self, framework): 10f8833479SBarry Smith config.base.Configure.__init__(self, framework) 11f8833479SBarry Smith self.headerPrefix = 'PETSC' 12f8833479SBarry Smith self.substPrefix = 'PETSC' 13aa5c8b8eSBarry Smith self.installed = 0 # 1 indicates that Configure itself has already compiled and installed PETSc 144161761dSBarry Smith self.found = 1 15f8833479SBarry Smith return 16f8833479SBarry Smith 177c939e48SSatish Balay def __str2__(self): 18*e4d7ee71SJacob Faibussowitsch import logger 19*e4d7ee71SJacob Faibussowitsch 205b4fc442SVaclav Hapla desc = [' Using GNU make: ' + self.make.make] 217ce81a4bSJacob Faibussowitsch if self.defines.get('USE_COVERAGE'): 227ce81a4bSJacob Faibussowitsch desc.extend([ 237ce81a4bSJacob Faibussowitsch ' Code coverage: yes', 247ce81a4bSJacob Faibussowitsch ' Using code coverage executable: {}'.format(self.getMakeMacro('PETSC_COVERAGE_EXEC')) 257ce81a4bSJacob Faibussowitsch ]) 26*e4d7ee71SJacob Faibussowitsch banner_ends = 'xxx' 27*e4d7ee71SJacob Faibussowitsch banner_middle = '=' * (logger.get_global_divider_length() - 2 * len(banner_ends)) 28*e4d7ee71SJacob Faibussowitsch banner_line = banner_middle.join((banner_ends, banner_ends)) 29*e4d7ee71SJacob Faibussowitsch desc.append(banner_line) 30aa5c8b8eSBarry Smith if not self.installed: 31dc0529c6SBarry Smith desc.append(' Configure stage complete. Now build PETSc libraries with:') 325b4fc442SVaclav Hapla desc.append(' %s PETSC_DIR=%s PETSC_ARCH=%s all' % (self.make.make_user, self.petscdir.dir, self.arch.arch)) 33aa5c8b8eSBarry Smith else: 34aa5c8b8eSBarry Smith desc.append(' Installation complete. You do not need to run make to compile or install the software') 35*e4d7ee71SJacob Faibussowitsch desc.extend([banner_line, '']) 367ce81a4bSJacob Faibussowitsch return '\n'.join(desc) 37f8833479SBarry Smith 38f8833479SBarry Smith def setupHelp(self, help): 39f8833479SBarry Smith import nargs 40ce0b2093SBarry Smith help.addArgument('PETSc', '-prefix=<dir>', nargs.Arg(None, '', 'Specifiy location to install PETSc (eg. /usr/local)')) 417deb5ab3SBarry Smith help.addArgument('PETSc', '-with-prefetch=<bool>', nargs.ArgBool(None, 1,'Enable checking for prefetch instructions')) 42eed94e11SSatish Balay help.addArgument('Windows','-with-windows-graphics=<bool>', nargs.ArgBool(None, 1,'Enable check for Windows Graphics')) 43569865ddSSatish Balay help.addArgument('PETSc', '-with-default-arch=<bool>', nargs.ArgBool(None, 1, 'Allow using the last configured arch without setting PETSC_ARCH')) 4457cb31baSSatish Balay help.addArgument('PETSc','-with-single-library=<bool>', nargs.ArgBool(None, 1,'Put all PETSc code into the single -lpetsc library')) 45cb297985SSatish Balay help.addArgument('PETSc','-with-fortran-bindings=<bool>', nargs.ArgBool(None, 1,'Build PETSc fortran bindings in the library and corresponding module files')) 46525d6f2eSBarry Smith help.addArgument('PETSc', '-with-ios=<bool>', nargs.ArgBool(None, 0, 'Build an iPhone/iPad version of PETSc library')) 4713f9d092SSatish Balay help.addArgument('PETSc', '-with-display=<x11display>', nargs.Arg(None, '', 'Specifiy DISPLAY env variable for use with matlab test)')) 482c30b4dfSSatish Balay help.addArgument('PETSc', '-with-package-scripts=<pyscripts>', nargs.ArgFileList(None,None,'Specify configure package scripts for user provided packages')) 497ce81a4bSJacob Faibussowitsch help.addArgument('PETSc', '-with-coverage=<bool>', nargs.ArgFuzzyBool(None, value=0, help='Enable or disable code-coverage collection')) 507ce81a4bSJacob Faibussowitsch help.addArgument('PETSc', '-with-coverage-exec=<executable>', nargs.ArgExecutable(None, value='default-auto', mustExist=0, help='Name of executable to use for post-processing coverage data, e.g. \'gcov\' or \'llvm-cov\'. Pass \'auto\' to let configure infer from compiler')) 51a0c7f9aaSSamuel Khuvis help.addArgument('PETSc', '-with-tau-perfstubs=<bool>', nargs.ArgBool(None, 1,'Enable TAU profiler stubs')) 52689a5dfaSJacob Faibussowitsch help.addArgument('PETSc', '-with-strict-petscerrorcode=<bool>', nargs.ArgFuzzyBool(None, value=0, help='Enable strict PetscErrorCode mode, which enables additional compile-time checking for misuse of PetscErrorCode and error handling')) 53f8833479SBarry Smith return 54f8833479SBarry Smith 556dd73af6SBarry Smith def registerPythonFile(self,filename,directory): 566dd73af6SBarry Smith ''' Add a python file to the framework and registers its headerprefix, ... externalpackagedir 576dd73af6SBarry Smith directory is the directory where the file relative to the BuildSystem or config path in python notation with . ''' 586dd73af6SBarry Smith (utilityName, ext) = os.path.splitext(filename) 596dd73af6SBarry Smith if not utilityName.startswith('.') and not utilityName.startswith('#') and ext == '.py' and not utilityName == '__init__': 606dd73af6SBarry Smith if directory: directory = directory+'.' 616dd73af6SBarry Smith utilityObj = self.framework.require(directory+utilityName, self) 626dd73af6SBarry Smith utilityObj.headerPrefix = self.headerPrefix 636dd73af6SBarry Smith utilityObj.archProvider = self.arch 646dd73af6SBarry Smith utilityObj.languageProvider = self.languages 656dd73af6SBarry Smith utilityObj.installDirProvider = self.installdir 666dd73af6SBarry Smith utilityObj.externalPackagesDirProvider = self.externalpackagesdir 676dd73af6SBarry Smith utilityObj.precisionProvider = self.scalartypes 686dd73af6SBarry Smith utilityObj.indexProvider = self.indexTypes 696dd73af6SBarry Smith setattr(self, utilityName.lower(), utilityObj) 7051294b80SMatthew G. Knepley return utilityObj 7151294b80SMatthew G. Knepley return None 726dd73af6SBarry Smith 73f8833479SBarry Smith def setupDependencies(self, framework): 74f8833479SBarry Smith config.base.Configure.setupDependencies(self, framework) 75dca78d2bSSatish Balay self.programs = framework.require('config.programs', self) 76f8833479SBarry Smith self.setCompilers = framework.require('config.setCompilers', self) 777ce81a4bSJacob Faibussowitsch self.compilerFlags = framework.require('config.compilerFlags', self) 7830b8aa07SMatthew G. Knepley self.compilers = framework.require('config.compilers', self) 799d310bb7SBarry Smith self.arch = framework.require('PETSc.options.arch', self.setCompilers) 809d310bb7SBarry Smith self.petscdir = framework.require('PETSc.options.petscdir', self.arch) 819d310bb7SBarry Smith self.installdir = framework.require('PETSc.options.installDir', self) 824e00a515SSatish Balay self.dataFilesPath = framework.require('PETSc.options.dataFilesPath',self) 836dd73af6SBarry Smith self.scalartypes = framework.require('PETSc.options.scalarTypes', self) 846dd73af6SBarry Smith self.indexTypes = framework.require('PETSc.options.indexTypes', self) 859d310bb7SBarry Smith self.languages = framework.require('PETSc.options.languages', self.setCompilers) 8630b8aa07SMatthew G. Knepley self.indexTypes = framework.require('PETSc.options.indexTypes', self.compilers) 87f8833479SBarry Smith self.types = framework.require('config.types', self) 88f8833479SBarry Smith self.headers = framework.require('config.headers', self) 89f8833479SBarry Smith self.functions = framework.require('config.functions', self) 90f8833479SBarry Smith self.libraries = framework.require('config.libraries', self) 91cd37d877SShri Abhyankar self.atomics = framework.require('config.atomics', self) 929481793eSSatish Balay self.make = framework.require('config.packages.make', self) 939552296fSBarry Smith self.blasLapack = framework.require('config.packages.BlasLapack',self) 94e6b0c433SBarry Smith self.mpi = framework.require('config.packages.MPI', self) 950542e31aSBarry Smith self.fortran = framework.require('config.compilersFortran', self) 960542e31aSBarry Smith self.externalpackagesdir = framework.require('PETSc.options.externalpackagesdir',self) 9749d43ecaSSatish Balay 9809a6cbfcSBernhard M. Wiedemann for utility in sorted(os.listdir(os.path.join('config','PETSc','options'))): 996dd73af6SBarry Smith self.registerPythonFile(utility,'PETSc.options') 1009d310bb7SBarry Smith 10109a6cbfcSBernhard M. Wiedemann for utility in sorted(os.listdir(os.path.join('config','BuildSystem','config','utilities'))): 1026dd73af6SBarry Smith self.registerPythonFile(utility,'config.utilities') 10306e08bc7SBarry Smith 10409a6cbfcSBernhard M. Wiedemann for package in sorted(os.listdir(os.path.join('config', 'BuildSystem', 'config', 'packages'))): 10551294b80SMatthew G. Knepley obj = self.registerPythonFile(package,'config.packages') 10651294b80SMatthew G. Knepley if obj: 10751294b80SMatthew G. Knepley obj.archProvider = self.framework.requireModule(obj.archProvider, obj) 10851294b80SMatthew G. Knepley obj.languageProvider = self.framework.requireModule(obj.languageProvider, obj) 10951294b80SMatthew G. Knepley obj.installDirProvider = self.framework.requireModule(obj.installDirProvider, obj) 11051294b80SMatthew G. Knepley obj.externalPackagesDirProvider = self.framework.requireModule(obj.externalPackagesDirProvider, obj) 11151294b80SMatthew G. Knepley obj.precisionProvider = self.framework.requireModule(obj.precisionProvider, obj) 11251294b80SMatthew G. Knepley obj.indexProvider = self.framework.requireModule(obj.indexProvider, obj) 1136dd73af6SBarry Smith 1145faf1eacSMatthew G. Knepley # Force blaslapack and opencl to depend on scalarType so precision is set before BlasLapack is built 1159d310bb7SBarry Smith framework.require('PETSc.options.scalarTypes', self.f2cblaslapack) 1169d310bb7SBarry Smith framework.require('PETSc.options.scalarTypes', self.fblaslapack) 1179d310bb7SBarry Smith framework.require('PETSc.options.scalarTypes', self.blaslapack) 1185faf1eacSMatthew G. Knepley framework.require('PETSc.options.scalarTypes', self.opencl) 119f8833479SBarry Smith 120dca78d2bSSatish Balay self.programs.headerPrefix = self.headerPrefix 1215b3958d3SJacob Faibussowitsch self.setCompilers.headerPrefix = self.headerPrefix 122f8833479SBarry Smith self.compilers.headerPrefix = self.headerPrefix 1230542e31aSBarry Smith self.fortran.headerPrefix = self.headerPrefix 124f8833479SBarry Smith self.types.headerPrefix = self.headerPrefix 125f8833479SBarry Smith self.headers.headerPrefix = self.headerPrefix 126f8833479SBarry Smith self.functions.headerPrefix = self.headerPrefix 127f8833479SBarry Smith self.libraries.headerPrefix = self.headerPrefix 1286dd73af6SBarry Smith 1292c30b4dfSSatish Balay # Register user provided package scripts 1302c30b4dfSSatish Balay if 'with-package-scripts' in self.framework.argDB: 1312c30b4dfSSatish Balay for script in self.framework.argDB['with-package-scripts']: 1322c30b4dfSSatish Balay if os.path.splitext(script)[1] != '.py': 1332c30b4dfSSatish Balay raise RuntimeError('Only python scripts compatible with configure package script format should be specified! Invalid option -with-package-scripts='+script) 1342c30b4dfSSatish Balay self.framework.logPrint('User is registering a new package script: '+script) 1352c30b4dfSSatish Balay dname,fname = os.path.split(script) 1362c30b4dfSSatish Balay if dname: sys.path.append(dname) 1372c30b4dfSSatish Balay self.registerPythonFile(fname,'') 1386dd73af6SBarry Smith 1396dd73af6SBarry Smith # test for a variety of basic headers and functions 1404211eb48SBarry Smith headersC = map(lambda name: name+'.h',['setjmp','dos','fcntl','float','io','malloc','pwd','strings', 141ace159c0SJed Brown 'unistd','machine/endian','sys/param','sys/procfs','sys/resource', 1422475b7caSBarry Smith 'sys/systeminfo','sys/times','sys/utsname', 1437e4f0192SMosè Giordano 'sys/socket','sys/wait','netinet/in','netdb','direct','time','Ws2tcpip','sys/types', 14418da0197SPierre Jolivet 'WindowsX','float','ieeefp','stdint','inttypes','immintrin']) 14545082d64SJed Brown functions = ['access','_access','clock','drand48','getcwd','_getcwd','getdomainname','gethostname', 1464e04ae5aSSatish Balay 'posix_memalign','popen','PXFGETARG','rand','getpagesize', 1474211eb48SBarry Smith 'readlink','realpath','usleep','sleep','_sleep', 1482475b7caSBarry Smith 'uname','snprintf','_snprintf','lseek','_lseek','time','fork','stricmp', 1492475b7caSBarry Smith 'strcasecmp','bzero','dlopen','dlsym','dlclose','dlerror', 15067f4e542SPierre Jolivet '_set_output_format','_mkdir','socket','gethostbyname','fpresetsticky', 15118da0197SPierre Jolivet 'fpsetsticky','__gcov_dump'] 152b0651e32SBarry Smith libraries = [(['fpe'],'handle_sigfpes')] 153b0651e32SBarry Smith librariessock = [(['socket','nsl'],'socket')] 154f8833479SBarry Smith self.headers.headers.extend(headersC) 155f8833479SBarry Smith self.functions.functions.extend(functions) 156b0651e32SBarry Smith self.libraries.libraries.extend(libraries) 157b0651e32SBarry Smith if not hasattr(self,'socket'): 158b0651e32SBarry Smith self.libraries.libraries.extend(librariessock) 159f8833479SBarry Smith return 160f8833479SBarry Smith 1618244ab14SJed Brown def DumpPkgconfig(self, petsc_pc): 162262119f8SBarry Smith ''' Create a pkg-config file ''' 163262119f8SBarry Smith if not os.path.exists(os.path.join(self.petscdir.dir,self.arch.arch,'lib','pkgconfig')): 164262119f8SBarry Smith os.makedirs(os.path.join(self.petscdir.dir,self.arch.arch,'lib','pkgconfig')) 1652eefe1c6SJed Brown with open(os.path.join(self.petscdir.dir,self.arch.arch,'lib','pkgconfig',petsc_pc),'w') as fd: 1665e3311eeSJed Brown cflags_inc = ['-I${includedir}'] 167262119f8SBarry Smith if self.framework.argDB['prefix']: 1685bb5b263SMatthew G. Knepley fd.write('prefix='+self.installdir.dir+'\n') 169262119f8SBarry Smith else: 170e1e675deSJed Brown fd.write('prefix='+os.path.join(self.petscdir.dir, self.arch.arch)+'\n') 171e1e675deSJed Brown cflags_inc.append('-I' + os.path.join(self.petscdir.dir, 'include')) 172262119f8SBarry Smith fd.write('exec_prefix=${prefix}\n') 173262119f8SBarry Smith fd.write('includedir=${prefix}/include\n') 1745e3311eeSJed Brown fd.write('libdir=${prefix}/lib\n') 175262119f8SBarry Smith 1762eefe1c6SJed Brown with self.setCompilers.Language('C'): 177262119f8SBarry Smith fd.write('ccompiler='+self.setCompilers.getCompiler()+'\n') 178756c7f9fSJed Brown fd.write('cflags_extra='+self.setCompilers.getCompilerFlags().strip()+'\n') 179756c7f9fSJed Brown fd.write('cflags_dep='+self.compilers.dependenciesGenerationFlag.get('C','')+'\n') 180756c7f9fSJed Brown fd.write('ldflag_rpath='+self.setCompilers.CSharedLinkerFlag+'\n') 18103e383c8SJed Brown if hasattr(self.compilers, 'CXX'): 1822eefe1c6SJed Brown with self.setCompilers.Language('C++'): 183262119f8SBarry Smith fd.write('cxxcompiler='+self.setCompilers.getCompiler()+'\n') 184756c7f9fSJed Brown fd.write('cxxflags_extra='+self.setCompilers.getCompilerFlags().strip()+'\n') 185262119f8SBarry Smith if hasattr(self.compilers, 'FC'): 1862eefe1c6SJed Brown with self.setCompilers.Language('FC'): 187262119f8SBarry Smith fd.write('fcompiler='+self.setCompilers.getCompiler()+'\n') 188756c7f9fSJed Brown fd.write('fflags_extra='+self.setCompilers.getCompilerFlags().strip()+'\n') 18950520af6SPatrick Sanan if hasattr(self.compilers, 'CUDAC'): 19050520af6SPatrick Sanan with self.setCompilers.Language('CUDA'): 19150520af6SPatrick Sanan fd.write('cudacompiler='+self.setCompilers.getCompiler()+'\n') 19250520af6SPatrick Sanan fd.write('cudaflags_extra='+self.setCompilers.getCompilerFlags().strip()+'\n') 1938f561fa3SPatrick Sanan p = self.framework.require('config.packages.cuda') 19450520af6SPatrick Sanan fd.write('cudalib='+self.libraries.toStringNoDupes(p.lib)+'\n') 19550520af6SPatrick Sanan fd.write('cudainclude='+self.headers.toStringNoDupes(p.include)+'\n') 1967ba7a817SBarry Smith if hasattr(self.setCompilers,'CUDA_CXX'): 1977ba7a817SBarry Smith fd.write('cuda_cxx='+self.setCompilers.CUDA_CXX+'\n') 1987ba7a817SBarry Smith fd.write('cuda_cxxflags='+self.setCompilers.CUDA_CXXFLAGS+'\n') 199262119f8SBarry Smith 200262119f8SBarry Smith fd.write('\n') 201262119f8SBarry Smith fd.write('Name: PETSc\n') 202262119f8SBarry Smith fd.write('Description: Library to solve ODEs and algebraic equations\n') 203351d3a41SMatthew G Knepley fd.write('Version: %s\n' % self.petscdir.version) 2045e3311eeSJed Brown fd.write('Cflags: ' + ' '.join([self.setCompilers.CPPFLAGS] + cflags_inc) + '\n') 20537371b91SJed Brown fd.write('Libs: '+self.libraries.toStringNoDupes(['-L${libdir}', self.petsclib], with_rpath=False)+'\n') 2068ebf8858SJed Brown # Remove RPATH flags from library list. User can add them using 2078ebf8858SJed Brown # pkg-config --variable=ldflag_rpath and pkg-config --libs-only-L 208de8f682fSSatish Balay fd.write('Libs.private: '+self.libraries.toStringNoDupes([f for f in self.packagelibs+self.complibs if not f.startswith(self.setCompilers.CSharedLinkerFlag)], with_rpath=False)+'\n') 209262119f8SBarry Smith return 210262119f8SBarry Smith 211351d3a41SMatthew G Knepley def DumpModule(self): 212351d3a41SMatthew G Knepley ''' Create a module file ''' 213af0996ceSBarry Smith if not os.path.exists(os.path.join(self.petscdir.dir,self.arch.arch,'lib','petsc','conf','modules')): 214af0996ceSBarry Smith os.makedirs(os.path.join(self.petscdir.dir,self.arch.arch,'lib','petsc','conf','modules')) 215af0996ceSBarry Smith if not os.path.exists(os.path.join(self.petscdir.dir,self.arch.arch,'lib','petsc','conf','modules','petsc')): 216af0996ceSBarry Smith os.makedirs(os.path.join(self.petscdir.dir,self.arch.arch,'lib','petsc','conf','modules','petsc')) 217351d3a41SMatthew G Knepley if self.framework.argDB['prefix']: 2185bb5b263SMatthew G. Knepley installdir = self.installdir.dir 21955d606a3SSatish Balay installarch = '' 22055d606a3SSatish Balay installpath = os.path.join(installdir,'bin') 221351d3a41SMatthew G Knepley else: 222351d3a41SMatthew G Knepley installdir = self.petscdir.dir 22355d606a3SSatish Balay installarch = self.arch.arch 22455d606a3SSatish Balay installpath = os.path.join(installdir,installarch,'bin')+':'+os.path.join(installdir,'bin') 225af0996ceSBarry Smith fd = open(os.path.join(self.petscdir.dir,self.arch.arch,'lib','petsc','conf','modules','petsc',self.petscdir.version),'w') 226351d3a41SMatthew G Knepley fd.write('''\ 227351d3a41SMatthew G Knepley#%%Module 228351d3a41SMatthew G Knepley 229351d3a41SMatthew G Knepleyproc ModulesHelp { } { 230351d3a41SMatthew G Knepley puts stderr "This module sets the path and environment variables for petsc-%s" 231a17b96a8SKyle Gerard Felker puts stderr " see https://petsc.org/ for more information " 232351d3a41SMatthew G Knepley puts stderr "" 233351d3a41SMatthew G Knepley} 234351d3a41SMatthew G Knepleymodule-whatis "PETSc - Portable, Extensible Toolkit for Scientific Computation" 235351d3a41SMatthew G Knepley 236dd486775SJed Brownset petsc_dir "%s" 237dd486775SJed Brownset petsc_arch "%s" 238351d3a41SMatthew G Knepley 239dd486775SJed Brownsetenv PETSC_ARCH "$petsc_arch" 240dd486775SJed Brownsetenv PETSC_DIR "$petsc_dir" 241dd486775SJed Brownprepend-path PATH "%s" 24255d606a3SSatish Balay''' % (self.petscdir.version, installdir, installarch, installpath)) 243351d3a41SMatthew G Knepley fd.close() 244351d3a41SMatthew G Knepley return 245351d3a41SMatthew G Knepley 246f8833479SBarry Smith def Dump(self): 247f8833479SBarry Smith ''' Actually put the values into the configuration files ''' 248f8833479SBarry Smith # eventually everything between -- should be gone 24917f368bcSBarry Smith if self.mpi.usingMPIUni: 25017f368bcSBarry Smith # 25117f368bcSBarry Smith # Remove any MPI/MPICH include files that may have been put here by previous runs of ./configure 2527908f030SMatthew G. Knepley self.executeShellCommand('rm -rf '+os.path.join(self.petscdir.dir,self.arch.arch,'include','mpi*')+' '+os.path.join(self.petscdir.dir,self.arch.arch,'include','opa*'), log = self.log) 25317f368bcSBarry Smith 254b5f71184SBarry Smith self.logPrintDivider() 255b5f71184SBarry Smith # Test for compiler-specific macros that need to be defined. 256b5f71184SBarry Smith if self.setCompilers.isCrayVector('CC', self.log): 257b5f71184SBarry Smith self.addDefine('HAVE_CRAY_VECTOR','1') 258b5f71184SBarry Smith 259b5f71184SBarry Smith if self.functions.haveFunction('gethostbyname') and self.functions.haveFunction('socket') and self.headers.haveHeader('netinet/in.h'): 260b5f71184SBarry Smith self.addDefine('USE_SOCKET_VIEWER','1') 261b5f71184SBarry Smith if self.checkCompile('#include <sys/socket.h>','setsockopt(0,SOL_SOCKET,SO_REUSEADDR,0,0)'): 262b5f71184SBarry Smith self.addDefine('HAVE_SO_REUSEADDR','1') 263b5f71184SBarry Smith 264b5f71184SBarry Smith self.logPrintDivider() 2655f27b2e0SBarry Smith self.setCompilers.pushLanguage('C') 2665f27b2e0SBarry Smith compiler = self.setCompilers.getCompiler() 267217fe27eSSatish Balay if [s for s in ['mpicc','mpiicc'] if os.path.basename(compiler).find(s)>=0]: 2685f27b2e0SBarry Smith try: 2695f27b2e0SBarry Smith output = self.executeShellCommand(compiler + ' -show', log = self.log)[0] 2705f27b2e0SBarry Smith compiler = output.split(' ')[0] 271f424265bSStefano Zampini self.addDefine('MPICC_SHOW','"'+output.strip().replace('\n','\\\\n').replace('"','')+'"') 2725f27b2e0SBarry Smith except: 273c9872b61SBarry Smith self.addDefine('MPICC_SHOW','"Unavailable"') 274c9872b61SBarry Smith else: 275c9872b61SBarry Smith self.addDefine('MPICC_SHOW','"Unavailable"') 2765f27b2e0SBarry Smith self.setCompilers.popLanguage() 277f8833479SBarry Smith#----------------------------------------------------------------------------------------------------- 278f8833479SBarry Smith 279f8833479SBarry Smith # Sometimes we need C compiler, even if built with C++ 280f8833479SBarry Smith self.setCompilers.pushLanguage('C') 281e4c30378SBarry Smith # do not use getCompilerFlags() because that automatically includes the CPPFLAGS so one ends up with duplication flags in makefile usage 282e4c30378SBarry Smith self.addMakeMacro('CC_FLAGS',self.setCompilers.CFLAGS) 283f8833479SBarry Smith self.setCompilers.popLanguage() 284f8833479SBarry Smith 28534f774f6SJed Brown # And sometimes we need a C++ compiler even when PETSc is built with C 28634f774f6SJed Brown if hasattr(self.compilers, 'CXX'): 28734f774f6SJed Brown self.setCompilers.pushLanguage('Cxx') 28829921a8fSScott Kruger self.addDefine('HAVE_CXX','1') 2890b119762SSatish Balay self.addMakeMacro('CXXPP_FLAGS',self.setCompilers.CXXPPFLAGS) 290e4c30378SBarry Smith # do not use getCompilerFlags() because that automatically includes the CXXPPFLAGS so one ends up with duplication flags in makefile usage 291e4c30378SBarry Smith self.addMakeMacro('CXX_FLAGS',self.setCompilers.CXXFLAGS+' '+self.setCompilers.CXX_CXXFLAGS) 2922f4326f3SSatish Balay cxx_linker = self.setCompilers.getLinker() 2932f4326f3SSatish Balay self.addMakeMacro('CXX_LINKER',cxx_linker) 2942f4326f3SSatish Balay self.addMakeMacro('CXX_LINKER_FLAGS',self.setCompilers.getLinkerFlags()) 29534f774f6SJed Brown self.setCompilers.popLanguage() 29605a757cfSSatish Balay else: 29705a757cfSSatish Balay self.addMakeMacro('CXX','') 29834f774f6SJed Brown 299f8833479SBarry Smith # C preprocessor values 3001315f054SBarry Smith self.addMakeMacro('CPP_FLAGS',self.setCompilers.CPPFLAGS) 301f8833479SBarry Smith 302f8833479SBarry Smith # compiler values 303f8833479SBarry Smith self.setCompilers.pushLanguage(self.languages.clanguage) 304f8833479SBarry Smith self.addMakeMacro('PCC',self.setCompilers.getCompiler()) 305e4c30378SBarry Smith # do not use getCompilerFlags() because that automatically includes the preprocessor flags so one ends up with duplication flags in makefile usage 306e4c30378SBarry Smith if self.languages.clanguage == 'C': 307e4c30378SBarry Smith self.addMakeMacro('PCC_FLAGS','$(CC_FLAGS)') 308e4c30378SBarry Smith else: 309e4c30378SBarry Smith self.addMakeMacro('PCC_FLAGS','$(CXX_FLAGS)') 310f8833479SBarry Smith self.setCompilers.popLanguage() 311f8833479SBarry Smith # .o or .obj 312f8833479SBarry Smith self.addMakeMacro('CC_SUFFIX','o') 313f8833479SBarry Smith 314f8833479SBarry Smith # executable linker values 315f8833479SBarry Smith self.setCompilers.pushLanguage(self.languages.clanguage) 316f8833479SBarry Smith pcc_linker = self.setCompilers.getLinker() 317f8833479SBarry Smith self.addMakeMacro('PCC_LINKER',pcc_linker) 318eacb1f64SJunchao Zhang # We need to add sycl flags when linking petsc. See more in sycl.py. 319eacb1f64SJunchao Zhang if hasattr(self.compilers, 'SYCLC'): 320eacb1f64SJunchao Zhang self.addMakeMacro('PCC_LINKER_FLAGS',self.setCompilers.getLinkerFlags()+' '+self.setCompilers.SYCLFLAGS+' '+self.setCompilers.SYCLC_LINKER_FLAGS) 321eacb1f64SJunchao Zhang else: 322c84a332bSSatish Balay self.addMakeMacro('PCC_LINKER_FLAGS',self.setCompilers.getLinkerFlags()) 323f8833479SBarry Smith self.setCompilers.popLanguage() 324f8833479SBarry Smith # '' for Unix, .exe for Windows 325f8833479SBarry Smith self.addMakeMacro('CC_LINKER_SUFFIX','') 326f8833479SBarry Smith 327f8833479SBarry Smith if hasattr(self.compilers, 'FC'): 328cb297985SSatish Balay if self.framework.argDB['with-fortran-bindings']: 329257f4e5aSSatish Balay if not self.fortran.fortranIsF90: 330257f4e5aSSatish Balay raise RuntimeError('Error! Fortran compiler "'+self.compilers.FC+'" does not support F90! PETSc fortran bindings require a F90 compiler') 331cb297985SSatish Balay self.addDefine('HAVE_FORTRAN','1') 332f8833479SBarry Smith self.setCompilers.pushLanguage('FC') 333f8833479SBarry Smith # need FPPFLAGS in config/setCompilers 3340b119762SSatish Balay self.addMakeMacro('FPP_FLAGS',self.setCompilers.FPPFLAGS) 335f8833479SBarry Smith 336f8833479SBarry Smith # compiler values 337f8833479SBarry Smith self.addMakeMacro('FC_FLAGS',self.setCompilers.getCompilerFlags()) 338f8833479SBarry Smith self.setCompilers.popLanguage() 339f8833479SBarry Smith # .o or .obj 340f8833479SBarry Smith self.addMakeMacro('FC_SUFFIX','o') 341f8833479SBarry Smith 342f8833479SBarry Smith # executable linker values 343f8833479SBarry Smith self.setCompilers.pushLanguage('FC') 344a9acdec7SBarry Smith self.addMakeMacro('FC_LINKER',self.setCompilers.getLinker()) 3456d53d35eSSatish Balay self.addMakeMacro('FC_LINKER_FLAGS',self.setCompilers.getLinkerFlags()) 346bb82cf9cSSatish Balay self.setCompilers.popLanguage() 3475d631499SMatthew Knepley 3485d631499SMatthew Knepley # F90 Modules 3495d631499SMatthew Knepley if self.setCompilers.fortranModuleIncludeFlag: 3505d631499SMatthew Knepley self.addMakeMacro('FC_MODULE_FLAG', self.setCompilers.fortranModuleIncludeFlag) 3516ddd6694SSatish Balay else: # for non-f90 compilers like g77 3526ddd6694SSatish Balay self.addMakeMacro('FC_MODULE_FLAG', '-I') 353a324c51cSMatthew G Knepley if self.setCompilers.fortranModuleIncludeFlag: 354a324c51cSMatthew G Knepley self.addMakeMacro('FC_MODULE_OUTPUT_FLAG', self.setCompilers.fortranModuleOutputFlag) 355f8833479SBarry Smith else: 356f8833479SBarry Smith self.addMakeMacro('FC','') 357f8833479SBarry Smith 35846a3958fSBarry Smith if hasattr(self.compilers, 'CUDAC'): 3597ff2890cSSatish Balay self.setCompilers.pushLanguage('CUDA') 360d93a25ecSSatish Balay self.addMakeMacro('CUDAC_FLAGS',self.setCompilers.getCompilerFlags()) 36150dcbc5aSJunchao Zhang self.addMakeMacro('CUDAPP_FLAGS',self.setCompilers.CUDAPPFLAGS) 3627ff2890cSSatish Balay self.setCompilers.popLanguage() 3637ff2890cSSatish Balay 364694a2f0eSJunchao Zhang if hasattr(self.compilers, 'HIPC'): 36528f796eaSScott Kruger self.setCompilers.pushLanguage('HIP') 366694a2f0eSJunchao Zhang self.addMakeMacro('HIPC_FLAGS',self.setCompilers.getCompilerFlags()) 3677fb1458fSStefano Zampini self.addMakeMacro('HIPPP_FLAGS',self.setCompilers.HIPPPFLAGS) 36828f796eaSScott Kruger self.setCompilers.popLanguage() 36928f796eaSScott Kruger 37050dcbc5aSJunchao Zhang if hasattr(self.compilers, 'SYCLC'): 37128f796eaSScott Kruger self.setCompilers.pushLanguage('SYCL') 37250dcbc5aSJunchao Zhang self.addMakeMacro('SYCLC_FLAGS',self.setCompilers.getCompilerFlags()) 373eacb1f64SJunchao Zhang self.addMakeMacro('SYCLC_LINKER_FLAGS',self.setCompilers.getLinkerFlags()) 37450dcbc5aSJunchao Zhang self.addMakeMacro('SYCLPP_FLAGS',self.setCompilers.SYCLPPFLAGS) 37528f796eaSScott Kruger self.setCompilers.popLanguage() 37628f796eaSScott Kruger 377f8833479SBarry Smith # shared library linker values 378f8833479SBarry Smith self.setCompilers.pushLanguage(self.languages.clanguage) 379f8833479SBarry Smith # need to fix BuildSystem to collect these separately 380f8833479SBarry Smith self.addMakeMacro('SL_LINKER',self.setCompilers.getLinker()) 38170db8aa6SSatish Balay self.addMakeMacro('SL_LINKER_FLAGS','${PCC_LINKER_FLAGS}') 382f8833479SBarry Smith self.setCompilers.popLanguage() 383f8833479SBarry Smith # One of 'a', 'so', 'lib', 'dll', 'dylib' (perhaps others also?) depending on the library generator and architecture 384f8833479SBarry Smith # Note: . is not included in this macro, consistent with AR_LIB_SUFFIX 385f8833479SBarry Smith if self.setCompilers.sharedLibraryExt == self.setCompilers.AR_LIB_SUFFIX: 386f8833479SBarry Smith self.addMakeMacro('SL_LINKER_SUFFIX', '') 38746bc77b6SBarry Smith self.addDefine('SLSUFFIX','""') 388f8833479SBarry Smith else: 389f8833479SBarry Smith self.addMakeMacro('SL_LINKER_SUFFIX', self.setCompilers.sharedLibraryExt) 39046bc77b6SBarry Smith self.addDefine('SLSUFFIX','"'+self.setCompilers.sharedLibraryExt+'"') 391bb82cf9cSSatish Balay 39223e93537SBarry Smith self.addMakeMacro('SL_LINKER_LIBS','${PETSC_EXTERNAL_LIB_BASIC}') 393bb82cf9cSSatish Balay 394f8833479SBarry Smith#----------------------------------------------------------------------------------------------------- 395f8833479SBarry Smith 396f8833479SBarry Smith # CONLY or CPP. We should change the PETSc makefiles to do this better 397f8833479SBarry Smith if self.languages.clanguage == 'C': lang = 'CONLY' 398f8833479SBarry Smith else: lang = 'CXXONLY' 399f8833479SBarry Smith self.addMakeMacro('PETSC_LANGUAGE',lang) 400f8833479SBarry Smith 401f8833479SBarry Smith # real or complex 402f8833479SBarry Smith self.addMakeMacro('PETSC_SCALAR',self.scalartypes.scalartype) 403f8833479SBarry Smith # double or float 404f8833479SBarry Smith self.addMakeMacro('PETSC_PRECISION',self.scalartypes.precision) 405f8833479SBarry Smith 406f8833479SBarry Smith if self.framework.argDB['with-batch']: 407f8833479SBarry Smith self.addMakeMacro('PETSC_WITH_BATCH','1') 408f8833479SBarry Smith 409f8833479SBarry Smith#----------------------------------------------------------------------------------------------------- 410a6cc6bb1SBarry Smith # print include and lib for makefiles 411b5f71184SBarry Smith self.logPrintDivider() 412f8833479SBarry Smith self.framework.packages.reverse() 4135a21677cSJed Brown petscincludes = [os.path.join(self.petscdir.dir,'include'),os.path.join(self.petscdir.dir,self.arch.arch,'include')] 4148749e224SJunchao Zhang petscincludes_install = [os.path.join(self.installdir.dir, 'include')] if self.framework.argDB['prefix'] else petscincludes 4155a21677cSJed Brown includes = [] 416de8f682fSSatish Balay self.packagelibs = [] 417f8833479SBarry Smith for i in self.framework.packages: 4187f0ff1afSBarry Smith if not i.required: 4193972cb20SJacob Faibussowitsch if i.devicePackage: 4203972cb20SJacob Faibussowitsch self.addDefine('HAVE_DEVICE',1) 421eeb16384SBarry Smith self.addDefine('HAVE_'+i.PACKAGE.replace('-','_'), 1) # ONLY list package if it is used directly by PETSc (and not only by another package) 422f8833479SBarry Smith if not isinstance(i.lib, list): 423f8833479SBarry Smith i.lib = [i.lib] 424de8f682fSSatish Balay if i.linkedbypetsc: self.packagelibs.extend(i.lib) 425eeb16384SBarry Smith self.addMakeMacro(i.PACKAGE.replace('-','_')+'_LIB', self.libraries.toStringNoDupes(i.lib)) 426f8833479SBarry Smith if hasattr(i,'include'): 427f8833479SBarry Smith if not isinstance(i.include,list): 428f8833479SBarry Smith i.include = [i.include] 429ac9e4c42SSatish Balay includes.extend(i.include) 430eeb16384SBarry Smith self.addMakeMacro(i.PACKAGE.replace('-','_')+'_INCLUDE',self.headers.toStringNoDupes(i.include)) 4312df986feSBarry Smith if self.framework.argDB['with-single-library']: 432e282ce78SJed Brown self.petsclib = '-lpetsc' 43391bb3077SSatish Balay else: 434e282ce78SJed Brown self.petsclib = '-lpetscts -lpetscsnes -lpetscksp -lpetscdm -lpetscmat -lpetscvec -lpetscsys' 435de8f682fSSatish Balay self.complibs = self.compilers.flibs+self.compilers.cxxlibs+self.compilers.LIBS.split() 4365a21677cSJed Brown self.PETSC_WITH_EXTERNAL_LIB = self.libraries.toStringNoDupes(['-L${PETSC_DIR}/${PETSC_ARCH}/lib', self.petsclib]+self.packagelibs+self.complibs) 437de8f682fSSatish Balay self.PETSC_EXTERNAL_LIB_BASIC = self.libraries.toStringNoDupes(self.packagelibs+self.complibs) 438de8f682fSSatish Balay 439de8f682fSSatish Balay self.addMakeMacro('PETSC_EXTERNAL_LIB_BASIC',self.PETSC_EXTERNAL_LIB_BASIC) 4405a21677cSJed Brown allincludes = petscincludes + includes 4415a21677cSJed Brown allincludes_install = petscincludes_install + includes 4425a21677cSJed Brown self.PETSC_CC_INCLUDES = self.headers.toStringNoDupes(allincludes) 4435a21677cSJed Brown self.PETSC_CC_INCLUDES_INSTALL = self.headers.toStringNoDupes(allincludes_install) 4445a21677cSJed Brown self.addMakeMacro('PETSC_CC_INCLUDES',self.PETSC_CC_INCLUDES) 4455a21677cSJed Brown self.addMakeMacro('PETSC_CC_INCLUDES_INSTALL', self.PETSC_CC_INCLUDES_INSTALL) 446cbd5cc15SBarry Smith if hasattr(self.compilers, 'FC'): 4475a21677cSJed Brown def modinc(includes): 4480542e31aSBarry Smith return includes if self.fortran.fortranIsF90 else [] 4495a21677cSJed Brown self.addMakeMacro('PETSC_FC_INCLUDES',self.headers.toStringNoDupes(allincludes,modinc(allincludes))) 4505a21677cSJed Brown self.addMakeMacro('PETSC_FC_INCLUDES_INSTALL',self.headers.toStringNoDupes(allincludes_install,modinc(allincludes_install))) 451f8833479SBarry Smith 4525bb5b263SMatthew G. Knepley self.addDefine('LIB_DIR','"'+os.path.join(self.installdir.dir,'lib')+'"') 453f8833479SBarry Smith 4540f3b21c2SBarry Smith if self.framework.argDB['with-single-library']: 4550f3b21c2SBarry Smith # overrides the values set in conf/variables 4560f3b21c2SBarry Smith self.addMakeMacro('LIBNAME','${INSTALL_LIB_DIR}/libpetsc.${AR_LIB_SUFFIX}') 45757cb31baSSatish Balay self.addMakeMacro('SHLIBS','libpetsc') 458bccf1c12SBarry Smith self.addMakeMacro('PETSC_LIB_BASIC','-lpetsc') 459797063a9SSatish Balay self.addMakeMacro('PETSC_KSP_LIB_BASIC','-lpetsc') 460797063a9SSatish Balay self.addMakeMacro('PETSC_TS_LIB_BASIC','-lpetsc') 461b0a7d7e7SSatish Balay self.addMakeMacro('PETSC_TAO_LIB_BASIC','-lpetsc') 462de8f682fSSatish Balay self.addMakeMacro('PETSC_WITH_EXTERNAL_LIB',self.PETSC_WITH_EXTERNAL_LIB) 463bb84e0fdSBarry Smith self.addDefine('USE_SINGLE_LIBRARY', '1') 4642df986feSBarry Smith if self.sharedlibraries.useShared: 465ea820d49SSatish Balay self.addMakeMacro('PETSC_SYS_LIB','${C_SH_LIB_PATH} ${PETSC_WITH_EXTERNAL_LIB}') 466ea820d49SSatish Balay self.addMakeMacro('PETSC_VEC_LIB','${C_SH_LIB_PATH} ${PETSC_WITH_EXTERNAL_LIB}') 467ea820d49SSatish Balay self.addMakeMacro('PETSC_MAT_LIB','${C_SH_LIB_PATH} ${PETSC_WITH_EXTERNAL_LIB}') 468ea820d49SSatish Balay self.addMakeMacro('PETSC_DM_LIB','${C_SH_LIB_PATH} ${PETSC_WITH_EXTERNAL_LIB}') 469ea820d49SSatish Balay self.addMakeMacro('PETSC_KSP_LIB','${C_SH_LIB_PATH} ${PETSC_WITH_EXTERNAL_LIB}') 470ea820d49SSatish Balay self.addMakeMacro('PETSC_SNES_LIB','${C_SH_LIB_PATH} ${PETSC_WITH_EXTERNAL_LIB}') 471ea820d49SSatish Balay self.addMakeMacro('PETSC_TS_LIB','${C_SH_LIB_PATH} ${PETSC_WITH_EXTERNAL_LIB}') 472b0a7d7e7SSatish Balay self.addMakeMacro('PETSC_TAO_LIB','${C_SH_LIB_PATH} ${PETSC_WITH_EXTERNAL_LIB}') 473fdb87e33SJed Brown self.addMakeMacro('PETSC_CHARACTERISTIC_LIB','${C_SH_LIB_PATH} ${PETSC_WITH_EXTERNAL_LIB}') 474ea820d49SSatish Balay self.addMakeMacro('PETSC_LIB','${C_SH_LIB_PATH} ${PETSC_WITH_EXTERNAL_LIB}') 475ea820d49SSatish Balay self.addMakeMacro('PETSC_CONTRIB','${C_SH_LIB_PATH} ${PETSC_WITH_EXTERNAL_LIB}') 4762df986feSBarry Smith else: 477ea820d49SSatish Balay self.addMakeMacro('PETSC_SYS_LIB','${PETSC_WITH_EXTERNAL_LIB}') 478ea820d49SSatish Balay self.addMakeMacro('PETSC_VEC_LIB','${PETSC_WITH_EXTERNAL_LIB}') 479ea820d49SSatish Balay self.addMakeMacro('PETSC_MAT_LIB','${PETSC_WITH_EXTERNAL_LIB}') 480ea820d49SSatish Balay self.addMakeMacro('PETSC_DM_LIB','${PETSC_WITH_EXTERNAL_LIB}') 481ea820d49SSatish Balay self.addMakeMacro('PETSC_KSP_LIB','${PETSC_WITH_EXTERNAL_LIB}') 482ea820d49SSatish Balay self.addMakeMacro('PETSC_SNES_LIB','${PETSC_WITH_EXTERNAL_LIB}') 483ea820d49SSatish Balay self.addMakeMacro('PETSC_TS_LIB','${PETSC_WITH_EXTERNAL_LIB}') 484b0a7d7e7SSatish Balay self.addMakeMacro('PETSC_TAO_LIB','${PETSC_WITH_EXTERNAL_LIB}') 485fdb87e33SJed Brown self.addMakeMacro('PETSC_CHARACTERISTIC_LIB','${PETSC_WITH_EXTERNAL_LIB}') 486ea820d49SSatish Balay self.addMakeMacro('PETSC_LIB','${PETSC_WITH_EXTERNAL_LIB}') 487ea820d49SSatish Balay self.addMakeMacro('PETSC_CONTRIB','${PETSC_WITH_EXTERNAL_LIB}') 4880f3b21c2SBarry Smith 489f8833479SBarry Smith if not os.path.exists(os.path.join(self.petscdir.dir,self.arch.arch,'lib')): 490f8833479SBarry Smith os.makedirs(os.path.join(self.petscdir.dir,self.arch.arch,'lib')) 491f8833479SBarry Smith 49213f9d092SSatish Balay# add a makefile endtry for display 49313f9d092SSatish Balay if self.framework.argDB['with-display']: 49413f9d092SSatish Balay self.addMakeMacro('DISPLAY',self.framework.argDB['with-display']) 49513f9d092SSatish Balay 496f8833479SBarry Smith # add a makefile entry for configure options 497f8833479SBarry Smith self.addMakeMacro('CONFIGURE_OPTIONS', self.framework.getOptionsString(['configModules', 'optionsModule']).replace('\"','\\"')) 498a0c7f9aaSSamuel Khuvis 499a0c7f9aaSSamuel Khuvis if self.framework.argDB['with-tau-perfstubs']: 500a0c7f9aaSSamuel Khuvis self.addDefine('HAVE_TAU_PERFSTUBS',1) 501f8833479SBarry Smith return 502f8833479SBarry Smith 503f8833479SBarry Smith def dumpConfigInfo(self): 504f8833479SBarry Smith import time 505c6ef1b5bSJed Brown fd = open(os.path.join(self.arch.arch,'include','petscconfiginfo.h'),'w') 506dc25a686SPierre Jolivet fd.write('static const char *petscconfigureoptions = "'+self.framework.getOptionsString(['configModules', 'optionsModule']).replace('\"','\\"').replace('\\ ','\\\\ ')+'";\n') 507f8833479SBarry Smith fd.close() 508f8833479SBarry Smith return 509f8833479SBarry Smith 5102a4161d9SMatthew G Knepley def dumpMachineInfo(self): 5112a4161d9SMatthew G Knepley import platform 512a970bd74SBernhard M. Wiedemann import datetime 5132a4161d9SMatthew G Knepley import time 51440373944SSatish Balay import script 515ca77dbeeSGeoffrey Irving def escape(s): 516e08ecd42SSatish Balay return s.replace('"',r'\"').replace(r'\ ',r'\\ ') # novermin 517c6ef1b5bSJed Brown fd = open(os.path.join(self.arch.arch,'include','petscmachineinfo.h'),'w') 5182a4161d9SMatthew G Knepley fd.write('static const char *petscmachineinfo = \"\\n\"\n') 5192a4161d9SMatthew G Knepley fd.write('\"-----------------------------------------\\n\"\n') 520a970bd74SBernhard M. Wiedemann buildhost = platform.node() 521a970bd74SBernhard M. Wiedemann if os.environ.get('SOURCE_DATE_EPOCH'): 522a970bd74SBernhard M. Wiedemann buildhost = "reproducible" 523a970bd74SBernhard M. Wiedemann buildtime = datetime.datetime.utcfromtimestamp(int(os.environ.get('SOURCE_DATE_EPOCH', time.time()))) 524a970bd74SBernhard M. Wiedemann fd.write('\"Libraries compiled on %s on %s \\n\"\n' % (buildtime, buildhost)) 52560acdfe7SSatish Balay fd.write('\"Machine characteristics: %s\\n\"\n' % (platform.platform())) 5265188cb68SSatish Balay fd.write('\"Using PETSc directory: %s\\n\"\n' % (escape(self.installdir.petscDir))) 5275188cb68SSatish Balay fd.write('\"Using PETSc arch: %s\\n\"\n' % (escape(self.installdir.petscArch))) 528cdec380aSBarry Smith fd.write('\"-----------------------------------------\\n\";\n') 5292a4161d9SMatthew G Knepley fd.write('static const char *petsccompilerinfo = \"\\n\"\n') 5302a4161d9SMatthew G Knepley self.setCompilers.pushLanguage(self.languages.clanguage) 5315f27b2e0SBarry Smith fd.write('\"Using C compiler: %s %s \\n\"\n' % (escape(self.setCompilers.getCompiler()), escape(self.setCompilers.getCompilerFlags()))) 5322a4161d9SMatthew G Knepley self.setCompilers.popLanguage() 5338782282cSMatthew G Knepley if hasattr(self.compilers, 'FC'): 5342a4161d9SMatthew G Knepley self.setCompilers.pushLanguage('FC') 5355f27b2e0SBarry Smith fd.write('\"Using Fortran compiler: %s %s %s\\n\"\n' % (escape(self.setCompilers.getCompiler()), escape(self.setCompilers.getCompilerFlags()), escape(self.setCompilers.CPPFLAGS))) 5362a4161d9SMatthew G Knepley self.setCompilers.popLanguage() 537cdec380aSBarry Smith fd.write('\"-----------------------------------------\\n\";\n') 5382a4161d9SMatthew G Knepley fd.write('static const char *petsccompilerflagsinfo = \"\\n\"\n') 5395a21677cSJed Brown fd.write('\"Using include paths: %s\\n\"\n' % (escape(self.PETSC_CC_INCLUDES_INSTALL.replace('${PETSC_DIR}', self.installdir.petscDir)))) 540cdec380aSBarry Smith fd.write('\"-----------------------------------------\\n\";\n') 5412a4161d9SMatthew G Knepley fd.write('static const char *petsclinkerinfo = \"\\n\"\n') 5422a4161d9SMatthew G Knepley self.setCompilers.pushLanguage(self.languages.clanguage) 543ca77dbeeSGeoffrey Irving fd.write('\"Using C linker: %s\\n\"\n' % (escape(self.setCompilers.getLinker()))) 5442a4161d9SMatthew G Knepley self.setCompilers.popLanguage() 5458782282cSMatthew G Knepley if hasattr(self.compilers, 'FC'): 5462a4161d9SMatthew G Knepley self.setCompilers.pushLanguage('FC') 547ca77dbeeSGeoffrey Irving fd.write('\"Using Fortran linker: %s\\n\"\n' % (escape(self.setCompilers.getLinker()))) 5482a4161d9SMatthew G Knepley self.setCompilers.popLanguage() 5495188cb68SSatish Balay fd.write('\"Using libraries: %s%s -L%s %s %s\\n\"\n' % (escape(self.setCompilers.CSharedLinkerFlag), escape(os.path.join(self.installdir.petscDir, self.installdir.petscArch, 'lib')), escape(os.path.join(self.installdir.petscDir, self.installdir.petscArch, 'lib')), escape(self.petsclib), escape(self.PETSC_EXTERNAL_LIB_BASIC))) 550cdec380aSBarry Smith fd.write('\"-----------------------------------------\\n\";\n') 5512a4161d9SMatthew G Knepley fd.close() 5522a4161d9SMatthew G Knepley return 553b2843cf1SBarry Smith 554b2843cf1SBarry Smith def configurePrefetch(self): 555b2843cf1SBarry Smith '''Sees if there are any prefetch functions supported''' 5567fca349cSMatthew G. Knepley if config.setCompilers.Configure.isSolaris(self.log) or self.framework.argDB['with-ios'] or not self.framework.argDB['with-prefetch']: 55793f78423SSatish Balay self.addDefine('Prefetch(a,b,c)', ' ') 55893f78423SSatish Balay return 559ec284106SBarry Smith self.pushLanguage(self.languages.clanguage) 56010699583SJed Brown if self.checkLink('#include <xmmintrin.h>', 'void *v = 0;_mm_prefetch((const char*)v,_MM_HINT_NTA);\n'): 56150d8bf02SJed Brown # The Intel Intrinsics manual [1] specifies the prototype 56250d8bf02SJed Brown # 56350d8bf02SJed Brown # void _mm_prefetch(char const *a, int sel); 56450d8bf02SJed Brown # 56550d8bf02SJed Brown # but other vendors seem to insist on using subtly different 56650d8bf02SJed Brown # prototypes, including void* for the pointer, and an enum for 56750d8bf02SJed Brown # sel. These are both reasonable changes, but negatively impact 56850d8bf02SJed Brown # portability. 56950d8bf02SJed Brown # 570a8d69d7bSBarry Smith # [1] https://software.intel.com/file/6373 57150d8bf02SJed Brown self.addDefine('HAVE_XMMINTRIN_H', 1) 57250d8bf02SJed Brown self.addDefine('Prefetch(a,b,c)', '_mm_prefetch((const char*)(a),(c))') 57350d8bf02SJed Brown self.addDefine('PREFETCH_HINT_NTA', '_MM_HINT_NTA') 57450d8bf02SJed Brown self.addDefine('PREFETCH_HINT_T0', '_MM_HINT_T0') 57550d8bf02SJed Brown self.addDefine('PREFETCH_HINT_T1', '_MM_HINT_T1') 57650d8bf02SJed Brown self.addDefine('PREFETCH_HINT_T2', '_MM_HINT_T2') 57750d8bf02SJed Brown elif self.checkLink('#include <xmmintrin.h>', 'void *v = 0;_mm_prefetch(v,_MM_HINT_NTA);\n'): 57850d8bf02SJed Brown self.addDefine('HAVE_XMMINTRIN_H', 1) 57950d8bf02SJed Brown self.addDefine('Prefetch(a,b,c)', '_mm_prefetch((const void*)(a),(c))') 58050d8bf02SJed Brown self.addDefine('PREFETCH_HINT_NTA', '_MM_HINT_NTA') 58150d8bf02SJed Brown self.addDefine('PREFETCH_HINT_T0', '_MM_HINT_T0') 58250d8bf02SJed Brown self.addDefine('PREFETCH_HINT_T1', '_MM_HINT_T1') 58350d8bf02SJed Brown self.addDefine('PREFETCH_HINT_T2', '_MM_HINT_T2') 58410699583SJed Brown elif self.checkLink('', 'void *v = 0;__builtin_prefetch(v,0,0);\n'): 58510699583SJed Brown # From GCC docs: void __builtin_prefetch(const void *addr,int rw,int locality) 58610699583SJed Brown # 58710699583SJed Brown # The value of rw is a compile-time constant one or zero; one 58810699583SJed Brown # means that the prefetch is preparing for a write to the memory 58910699583SJed Brown # address and zero, the default, means that the prefetch is 59010699583SJed Brown # preparing for a read. The value locality must be a compile-time 59110699583SJed Brown # constant integer between zero and three. A value of zero means 59210699583SJed Brown # that the data has no temporal locality, so it need not be left 59310699583SJed Brown # in the cache after the access. A value of three means that the 59410699583SJed Brown # data has a high degree of temporal locality and should be left 59510699583SJed Brown # in all levels of cache possible. Values of one and two mean, 59610699583SJed Brown # respectively, a low or moderate degree of temporal locality. 59710699583SJed Brown # 59810699583SJed Brown # Here we adopt Intel's x86/x86-64 naming scheme for the locality 59910699583SJed Brown # hints. Using macros for these values in necessary since some 60010699583SJed Brown # compilers require an enum. 60110699583SJed Brown self.addDefine('Prefetch(a,b,c)', '__builtin_prefetch((a),(b),(c))') 60210699583SJed Brown self.addDefine('PREFETCH_HINT_NTA', '0') 60310699583SJed Brown self.addDefine('PREFETCH_HINT_T0', '3') 60410699583SJed Brown self.addDefine('PREFETCH_HINT_T1', '2') 60510699583SJed Brown self.addDefine('PREFETCH_HINT_T2', '1') 606b2843cf1SBarry Smith else: 607b2843cf1SBarry Smith self.addDefine('Prefetch(a,b,c)', ' ') 6087d490b44SBarry Smith self.popLanguage() 609b2843cf1SBarry Smith 61049fe22e6SSatish Balay def delGenFiles(self): 61149fe22e6SSatish Balay '''Delete generated files''' 61249fe22e6SSatish Balay delfile = os.path.join(self.arch.arch,'lib','petsc','conf','files') 61349fe22e6SSatish Balay try: 61449fe22e6SSatish Balay os.unlink(delfile) 61549fe22e6SSatish Balay except: pass 61649fe22e6SSatish Balay 61709bc878fSSatish Balay def configureAtoll(self): 61809bc878fSSatish Balay '''Checks if atoll exists''' 61922164b4cSPierre Jolivet if self.checkLink('#define _POSIX_C_SOURCE 200112L\n#include <stdlib.h>','long v = atoll("25");\n(void)v') or self.checkLink ('#include <stdlib.h>','long v = atoll("25");\n(void)v'): 62009bc878fSSatish Balay self.addDefine('HAVE_ATOLL', '1') 62109bc878fSSatish Balay 6222400fdedSBarry Smith def configureUnused(self): 6232400fdedSBarry Smith '''Sees if __attribute((unused)) is supported''' 6241adaff47SSean Farley if self.framework.argDB['with-ios']: 6252400fdedSBarry Smith self.addDefine('UNUSED', ' ') 6262400fdedSBarry Smith return 6272400fdedSBarry Smith self.pushLanguage(self.languages.clanguage) 62822164b4cSPierre Jolivet if self.checkLink('__attribute((unused)) static int myfunc(__attribute((unused)) void *name){ return 1;}', 'int i = 0;\nint j = myfunc(&i);\n(void)j;\ntypedef void* atype;\n__attribute((unused)) atype a'): 6292400fdedSBarry Smith self.addDefine('UNUSED', '__attribute((unused))') 6302400fdedSBarry Smith else: 6312400fdedSBarry Smith self.addDefine('UNUSED', ' ') 6322400fdedSBarry Smith self.popLanguage() 6332400fdedSBarry Smith 63498ed35c3SBarry Smith def configureIsatty(self): 63598ed35c3SBarry Smith '''Check if the Unix C function isatty() works correctly 63698ed35c3SBarry Smith Actually just assumes it does not work correctly on batch systems''' 63798ed35c3SBarry Smith if not self.framework.argDB['with-batch']: 63898ed35c3SBarry Smith self.addDefine('USE_ISATTY',1) 63998ed35c3SBarry Smith 6401ef8df7fSJed Brown def configureDeprecated(self): 6411ef8df7fSJed Brown '''Check if __attribute((deprecated)) is supported''' 6427efe37a1SJacob Faibussowitsch def checkDeprecated(macro_base, src, is_intel): 6437efe37a1SJacob Faibussowitsch ''' 6447efe37a1SJacob Faibussowitsch run through the various attribute deprecated combinations and define MACRO_BAS(why) to the result 6457efe37a1SJacob Faibussowitsch it if it compiles. 6467efe37a1SJacob Faibussowitsch 6477efe37a1SJacob Faibussowitsch If none of the combos work, defines MACRO_BASE(why) as empty 6487efe37a1SJacob Faibussowitsch ''' 6497efe37a1SJacob Faibussowitsch full_macro_name = macro_base + '(why)' 6507efe37a1SJacob Faibussowitsch for prefix in ('__attribute__', '__attribute','__declspec'): 6517efe37a1SJacob Faibussowitsch if prefix == '__declspec': 6527efe37a1SJacob Faibussowitsch # declspec does not have an extra set of brackets around the arguments 6537efe37a1SJacob Faibussowitsch attr_bodies = ('deprecated(why)', 'deprecated') 6541ef8df7fSJed Brown else: 6557efe37a1SJacob Faibussowitsch attr_bodies = ('(deprecated(why))', '(deprecated)') 6567efe37a1SJacob Faibussowitsch 6577efe37a1SJacob Faibussowitsch for attr_body in attr_bodies: 6587efe37a1SJacob Faibussowitsch attr_def = '{}({})'.format(prefix, attr_body) 6597efe37a1SJacob Faibussowitsch test_src = '\n'.join(( 6607efe37a1SJacob Faibussowitsch '#define {} {}'.format(full_macro_name, attr_def), 6617efe37a1SJacob Faibussowitsch src.format(macro_base + '("asdasdadsasd")') 6627efe37a1SJacob Faibussowitsch )) 6637efe37a1SJacob Faibussowitsch if self.checkCompile(test_src, ''): 6647efe37a1SJacob Faibussowitsch self.logPrint('configureDeprecated: \'{}\' appears to work'.format(attr_def)) 6657efe37a1SJacob Faibussowitsch if is_intel and '(why)' in attr_body: 6667efe37a1SJacob Faibussowitsch self.logPrint('configureDeprecated: Intel has conspired to make a supremely environment-sensitive compiler. The Intel compiler looks at the gcc executable in the environment to determine the language compatibility that it should attempt to emulate. Some important Cray installations have built PETSc using the Intel compiler, but with a newer gcc module loaded (e.g. 4.7). Thus at PETSc configure time, the Intel compiler decides to support the string argument, but the gcc found in the default user environment is older and does not support the argument.\n'.format(attr_def)) 6677efe37a1SJacob Faibussowitsch self.logPrint('*** WE WILL THEREFORE REJECT \'{}\' AND CONTINUE TESTING ***'.format(attr_def)) 6687efe37a1SJacob Faibussowitsch continue 6697efe37a1SJacob Faibussowitsch self.addDefine(full_macro_name, attr_def) 6707efe37a1SJacob Faibussowitsch return 6717efe37a1SJacob Faibussowitsch 6727efe37a1SJacob Faibussowitsch self.addDefine(full_macro_name, ' ') 6737efe37a1SJacob Faibussowitsch return 6747efe37a1SJacob Faibussowitsch 6757efe37a1SJacob Faibussowitsch lang = self.languages.clanguage 6767efe37a1SJacob Faibussowitsch with self.Language(lang): 6777efe37a1SJacob Faibussowitsch is_intel = self.setCompilers.isIntel(self.getCompiler(lang=lang), self.log) 6787efe37a1SJacob Faibussowitsch checkDeprecated('DEPRECATED_FUNCTION', '{} int myfunc(void) {{ return 1; }}', is_intel) 6797efe37a1SJacob Faibussowitsch checkDeprecated('DEPRECATED_TYPEDEF', 'typedef int my_int {};', is_intel) 6807efe37a1SJacob Faibussowitsch checkDeprecated('DEPRECATED_ENUM', 'enum E {{ oldval {}, newval }};', is_intel) 6817efe37a1SJacob Faibussowitsch # I was unable to make a CPP macro that takes the old and new values as separate 6827efe37a1SJacob Faibussowitsch # arguments and builds the message needed by _Pragma hence the deprecation message is 6837efe37a1SJacob Faibussowitsch # handled as it is 68405de396fSBarry Smith if self.checkCompile('#define TEST _Pragma("GCC warning \"Testing _Pragma\"") value'): 68505de396fSBarry Smith self.addDefine('DEPRECATED_MACRO(why)', '_Pragma(why)') 68605de396fSBarry Smith else: 68705de396fSBarry Smith self.addDefine('DEPRECATED_MACRO(why)', ' ') 6881ef8df7fSJed Brown 68918f41590SBarry Smith def configureAlign(self): 6907b7fc14bSLisandro Dalcin '''Check if __attribute(aligned) is supported''' 6917b7fc14bSLisandro Dalcin code = '''\ 692752d89a4SSatish Balaystruct mystruct {int myint;} __attribute((aligned(16))); 6937b7fc14bSLisandro Dalcinchar assert_aligned[(sizeof(struct mystruct)==16)*2-1]; 694752d89a4SSatish Balay''' 695752d89a4SSatish Balay self.pushLanguage(self.languages.clanguage) 6967b7fc14bSLisandro Dalcin if self.checkCompile(code): 697752d89a4SSatish Balay self.addDefine('ATTRIBUTEALIGNED(size)', '__attribute((aligned(size)))') 698752d89a4SSatish Balay self.addDefine('HAVE_ATTRIBUTEALIGNED', 1) 699752d89a4SSatish Balay else: 7007b7fc14bSLisandro Dalcin self.framework.logPrint('Incorrect attribute(aligned)') 701752d89a4SSatish Balay self.addDefine('ATTRIBUTEALIGNED(size)', ' ') 7027b7fc14bSLisandro Dalcin self.popLanguage() 703752d89a4SSatish Balay return 70418f41590SBarry Smith 7059800092aSJed Brown def configureExpect(self): 7069800092aSJed Brown '''Sees if the __builtin_expect directive is supported''' 7079800092aSJed Brown self.pushLanguage(self.languages.clanguage) 7089800092aSJed Brown if self.checkLink('', 'if (__builtin_expect(0,1)) return 1;'): 7099800092aSJed Brown self.addDefine('HAVE_BUILTIN_EXPECT', 1) 7109800092aSJed Brown self.popLanguage() 7119800092aSJed Brown 71253c77d0aSJed Brown def configureFunctionName(self): 713fbfcfee5SBarry Smith '''Sees if the compiler supports __func__ or a variant.''' 7141ec50b02SJed Brown def getFunctionName(lang): 715fbfcfee5SBarry Smith name = '"unknown"' 7161ec50b02SJed Brown self.pushLanguage(lang) 717b6ff4c76SKarl Rupp for fname in ['__func__','__FUNCTION__','__extension__ __func__']: 7180117e5a1SSatish Balay code = "if ("+fname+"[0] != 'm') return 1;" 7190117e5a1SSatish Balay if self.checkCompile('',code) and self.checkLink('',code): 7200117e5a1SSatish Balay name = fname 7210117e5a1SSatish Balay break 7221ec50b02SJed Brown self.popLanguage() 7231ec50b02SJed Brown return name 7241ec50b02SJed Brown langs = [] 725628773c9SSatish Balay 726628773c9SSatish Balay self.addDefine('FUNCTION_NAME_C', getFunctionName('C')) 7275f6e5f85SSatish Balay if hasattr(self.compilers, 'CXX'): 728628773c9SSatish Balay self.addDefine('FUNCTION_NAME_CXX', getFunctionName('Cxx')) 72953c77d0aSJed Brown 730753ebd1dSJed Brown def configureIntptrt(self): 731f18a5f7eSJacob Faibussowitsch '''Determine what to use for uintptr_t and intptr_t''' 732753ebd1dSJed Brown def staticAssertSizeMatchesVoidStar(inc,typename): 733753ebd1dSJed Brown # The declaration is an error if either array size is negative. 734753ebd1dSJed Brown # It should be okay to use an int that is too large, but it would be very unlikely for this to be the case 735d26187a0SJed Brown return self.checkCompile(inc, ('#define STATIC_ASSERT(cond) char negative_length_if_false[2*(!!(cond))-1]\n' 736979939cdSSatish Balay + 'STATIC_ASSERT(sizeof(void*) == sizeof(%s));'%typename)) 737f18a5f7eSJacob Faibussowitsch 738f18a5f7eSJacob Faibussowitsch def generate_uintptr_guesses(): 739f18a5f7eSJacob Faibussowitsch for suff in ('max', '64', '32', '16'): 740f18a5f7eSJacob Faibussowitsch yield '#include <stdint.h>', 'uint{}_t'.format(suff), 'PRIx{}'.format(suff.upper()) 741f18a5f7eSJacob Faibussowitsch yield '#include <stdlib.h>\n#include <string.h>', 'size_t', 'zx' 742f18a5f7eSJacob Faibussowitsch yield '', 'unsigned long long', 'llx' 743f18a5f7eSJacob Faibussowitsch yield '', 'unsigned long', 'lx' 744f18a5f7eSJacob Faibussowitsch yield '', 'unsigned', 'x' 745f18a5f7eSJacob Faibussowitsch 746f18a5f7eSJacob Faibussowitsch def generate_intptr_guesses(): 747f18a5f7eSJacob Faibussowitsch for suff in ('max', '64', '32', '16'): 748f18a5f7eSJacob Faibussowitsch yield '#include <stdint.h>', 'int{}_t'.format(suff), 'PRIx{}'.format(suff.upper()) 749f18a5f7eSJacob Faibussowitsch yield '', 'long long', 'llx' 750f18a5f7eSJacob Faibussowitsch yield '', 'long', 'lx' 751f18a5f7eSJacob Faibussowitsch yield '', 'int', 'x' 752f18a5f7eSJacob Faibussowitsch 753f18a5f7eSJacob Faibussowitsch def check(default_typename, generator): 754f18a5f7eSJacob Faibussowitsch macro_name = default_typename.upper() 755f18a5f7eSJacob Faibussowitsch with self.Language(self.languages.clanguage): 756f18a5f7eSJacob Faibussowitsch if self.checkCompile( 757f18a5f7eSJacob Faibussowitsch '#include <stdint.h>', 758f18a5f7eSJacob Faibussowitsch 'int x; {type_name} i = ({type_name})&x; (void)i'.format(type_name=default_typename) 759f18a5f7eSJacob Faibussowitsch ): 760f18a5f7eSJacob Faibussowitsch typename = default_typename 761f18a5f7eSJacob Faibussowitsch print_format = 'PRIxPTR' 762d26187a0SJed Brown else: 763f18a5f7eSJacob Faibussowitsch for include, typename, print_format in generator(): 764f18a5f7eSJacob Faibussowitsch if staticAssertSizeMatchesVoidStar(include, typename): 765f18a5f7eSJacob Faibussowitsch break 766f18a5f7eSJacob Faibussowitsch else: 767f18a5f7eSJacob Faibussowitsch raise RuntimeError('Could not find any {} type matching void*'.format(macro_name)) 768f18a5f7eSJacob Faibussowitsch self.addDefine(macro_name , typename) 769f18a5f7eSJacob Faibussowitsch self.addDefine(macro_name + '_FMT', '\"#\" ' + print_format) 770f18a5f7eSJacob Faibussowitsch return 771f18a5f7eSJacob Faibussowitsch 772f18a5f7eSJacob Faibussowitsch check('uintptr_t', generate_uintptr_guesses) 773f18a5f7eSJacob Faibussowitsch check('intptr_t', generate_intptr_guesses) 774f18a5f7eSJacob Faibussowitsch return 775753ebd1dSJed Brown 776ed938b00SJed Brown def configureRTLDDefault(self): 7777b65ca21SBarry Smith '''Check for dynamic library feature''' 778bfef2c86SBarry Smith if self.checkCompile('#include <dlfcn.h>\n void *ptr = RTLD_DEFAULT;'): 7799fb7294dSPierre Jolivet self.addDefine('HAVE_RTLD_DEFAULT','1') 780f8833479SBarry Smith return 781f8833479SBarry Smith 782f8833479SBarry Smith def configureSolaris(self): 783f8833479SBarry Smith '''Solaris specific stuff''' 784f8833479SBarry Smith if os.path.isdir(os.path.join('/usr','ucblib')): 785f8833479SBarry Smith try: 786f8833479SBarry Smith flag = getattr(self.setCompilers, self.language[-1]+'SharedLinkerFlag') 787f8833479SBarry Smith except AttributeError: 788f8833479SBarry Smith flag = None 789f8833479SBarry Smith if flag is None: 790f8833479SBarry Smith self.compilers.LIBS += ' -L/usr/ucblib' 791f8833479SBarry Smith else: 792f8833479SBarry Smith self.compilers.LIBS += ' '+flag+'/usr/ucblib' 793f8833479SBarry Smith return 794f8833479SBarry Smith 7950f64ec89SBarry Smith def configureDarwin(self): 7960f64ec89SBarry Smith '''Log brew configuration for Apple systems''' 7970f64ec89SBarry Smith try: 7980f64ec89SBarry Smith self.executeShellCommand(['brew', 'config'], log = self.log) 7990f64ec89SBarry Smith self.executeShellCommand(['brew', 'info', 'gcc'], log = self.log) 8000f64ec89SBarry Smith except: 8010f64ec89SBarry Smith pass 8020f64ec89SBarry Smith return 8030f64ec89SBarry Smith 804f8833479SBarry Smith def configureLinux(self): 805f8833479SBarry Smith '''Linux specific stuff''' 8069f15855cSMatthew G Knepley # TODO: Test for this by mallocing an odd number of floats and checking the address 807f8833479SBarry Smith self.addDefine('HAVE_DOUBLE_ALIGN_MALLOC', 1) 808f8833479SBarry Smith return 809f8833479SBarry Smith 810f8833479SBarry Smith def configureWin32(self): 811f8833479SBarry Smith '''Win32 non-cygwin specific stuff''' 812f8833479SBarry Smith kernel32=0 8134e8afd12SMosè Giordano if self.libraries.add('Kernel32.lib','GetComputerName',prototype='#include <windows.h>', call='GetComputerName(NULL,NULL);'): 814f8833479SBarry Smith self.addDefine('HAVE_WINDOWS_H',1) 815f8833479SBarry Smith self.addDefine('HAVE_GETCOMPUTERNAME',1) 816f8833479SBarry Smith kernel32=1 8174e8afd12SMosè Giordano elif self.libraries.add('kernel32','GetComputerName',prototype='#include <windows.h>', call='GetComputerName(NULL,NULL);'): 818f8833479SBarry Smith self.addDefine('HAVE_WINDOWS_H',1) 819f8833479SBarry Smith self.addDefine('HAVE_GETCOMPUTERNAME',1) 820f8833479SBarry Smith kernel32=1 821f8833479SBarry Smith if kernel32: 822eed94e11SSatish Balay if self.framework.argDB['with-windows-graphics']: 823eed94e11SSatish Balay self.addDefine('USE_WINDOWS_GRAPHICS',1) 8244e8afd12SMosè Giordano if self.checkLink('#include <windows.h>','LoadLibrary(0)'): 825f8833479SBarry Smith self.addDefine('HAVE_LOADLIBRARY',1) 8264e8afd12SMosè Giordano if self.checkLink('#include <windows.h>','GetProcAddress(0,0)'): 827b50f6d9eSLisandro Dalcin self.addDefine('HAVE_GETPROCADDRESS',1) 8284e8afd12SMosè Giordano if self.checkLink('#include <windows.h>','FreeLibrary(0)'): 829b50f6d9eSLisandro Dalcin self.addDefine('HAVE_FREELIBRARY',1) 8304e8afd12SMosè Giordano if self.checkLink('#include <windows.h>','GetLastError()'): 831a21658a3SLisandro Dalcin self.addDefine('HAVE_GETLASTERROR',1) 8324e8afd12SMosè Giordano if self.checkLink('#include <windows.h>','SetLastError(0)'): 833a21658a3SLisandro Dalcin self.addDefine('HAVE_SETLASTERROR',1) 8344e8afd12SMosè Giordano if self.checkLink('#include <windows.h>\n','QueryPerformanceCounter(0);\n'): 835bea725cfSBarry Smith self.addDefine('USE_MICROSOFT_TIME',1) 8364e8afd12SMosè Giordano if self.libraries.add('Advapi32.lib','GetUserName',prototype='#include <windows.h>', call='GetUserName(NULL,NULL);'): 837f8833479SBarry Smith self.addDefine('HAVE_GET_USER_NAME',1) 8384e8afd12SMosè Giordano elif self.libraries.add('advapi32','GetUserName',prototype='#include <windows.h>', call='GetUserName(NULL,NULL);'): 839f8833479SBarry Smith self.addDefine('HAVE_GET_USER_NAME',1) 840f8833479SBarry Smith 8414e8afd12SMosè Giordano if not self.libraries.add('User32.lib','GetDC',prototype='#include <windows.h>',call='GetDC(0);'): 8424e8afd12SMosè Giordano self.libraries.add('user32','GetDC',prototype='#include <windows.h>',call='GetDC(0);') 8434e8afd12SMosè Giordano if not self.libraries.add('Gdi32.lib','CreateCompatibleDC',prototype='#include <windows.h>',call='CreateCompatibleDC(0);'): 8444e8afd12SMosè Giordano self.libraries.add('gdi32','CreateCompatibleDC',prototype='#include <windows.h>',call='CreateCompatibleDC(0);') 845f8833479SBarry Smith 846f8833479SBarry Smith self.types.check('int32_t', 'int') 84722164b4cSPierre Jolivet if not self.checkCompile('#include <sys/types.h>\n','uid_t u;\n(void)u'): 848f8833479SBarry Smith self.addTypedef('int', 'uid_t') 849f8833479SBarry Smith self.addTypedef('int', 'gid_t') 85022164b4cSPierre Jolivet if not self.checkLink('#if defined(PETSC_HAVE_UNISTD_H)\n#include <unistd.h>\n#endif\n','int a=R_OK;\n(void)a'): 851f8833479SBarry Smith self.framework.addDefine('R_OK', '04') 852f8833479SBarry Smith self.framework.addDefine('W_OK', '02') 853f8833479SBarry Smith self.framework.addDefine('X_OK', '01') 854f8833479SBarry Smith if not self.checkLink('#include <sys/stat.h>\n','int a=0;\nif (S_ISDIR(a)){}\n'): 855f8833479SBarry Smith self.framework.addDefine('S_ISREG(a)', '(((a)&_S_IFMT) == _S_IFREG)') 856f8833479SBarry Smith self.framework.addDefine('S_ISDIR(a)', '(((a)&_S_IFMT) == _S_IFDIR)') 8574e8afd12SMosè Giordano if self.checkCompile('#include <windows.h>\n','LARGE_INTEGER a;\nDWORD b=a.u.HighPart;\n'): 858f8833479SBarry Smith self.addDefine('HAVE_LARGE_INTEGER_U',1) 859f8833479SBarry Smith 860f8833479SBarry Smith # Windows requires a Binary file creation flag when creating/opening binary files. Is a better test in order? 8614e8afd12SMosè Giordano if self.checkCompile('#include <windows.h>\n#include <fcntl.h>\n', 'int flags = O_BINARY;'): 862f8833479SBarry Smith self.addDefine('HAVE_O_BINARY',1) 863f8833479SBarry Smith 864f8833479SBarry Smith if self.compilers.CC.find('win32fe') >= 0: 865ad4212abSSatish Balay self.addDefine('HAVE_WINDOWS_COMPILERS',1) 866f8833479SBarry Smith self.addDefine('DIR_SEPARATOR','\'\\\\\'') 867f8833479SBarry Smith self.addDefine('REPLACE_DIR_SEPARATOR','\'/\'') 868f8833479SBarry Smith self.addDefine('CANNOT_START_DEBUGGER',1) 8695188cb68SSatish Balay (petscdir,error,status) = self.executeShellCommand('cygpath -w '+self.installdir.petscDir, log = self.log) 87034531a4dSSatish Balay self.addDefine('DIR','"'+petscdir.replace('\\','\\\\')+'"') 8715188cb68SSatish Balay (petscdir,error,status) = self.executeShellCommand('cygpath -m '+self.installdir.petscDir, log = self.log) 872e433681fSSatish Balay self.addMakeMacro('wPETSC_DIR',petscdir) 8734e00a515SSatish Balay if self.dataFilesPath.datafilespath: 8744e00a515SSatish Balay (datafilespath,error,status) = self.executeShellCommand('cygpath -m '+self.dataFilesPath.datafilespath, log = self.log) 8754e00a515SSatish Balay self.addMakeMacro('DATAFILESPATH',datafilespath) 8764e00a515SSatish Balay 877f8833479SBarry Smith else: 878f8833479SBarry Smith self.addDefine('REPLACE_DIR_SEPARATOR','\'\\\\\'') 879f8833479SBarry Smith self.addDefine('DIR_SEPARATOR','\'/\'') 8805188cb68SSatish Balay self.addDefine('DIR','"'+self.installdir.petscDir+'"') 8815188cb68SSatish Balay self.addMakeMacro('wPETSC_DIR',self.installdir.petscDir) 8824e00a515SSatish Balay if self.dataFilesPath.datafilespath: 8834e00a515SSatish Balay self.addMakeMacro('DATAFILESPATH',self.dataFilesPath.datafilespath) 8845188cb68SSatish Balay self.addDefine('ARCH','"'+self.installdir.petscArch+'"') 885f8833479SBarry Smith return 886f8833479SBarry Smith 887d3d5cfdcSJacob Faibussowitsch def configureCoverageForLang(self, log_printer_cls, lang, extra_coverage_flags=None, extra_debug_flags=None): 8887ce81a4bSJacob Faibussowitsch """ 8897ce81a4bSJacob Faibussowitsch Check that a compiler accepts code-coverage flags. If the compiler does accept code-coverage flags 8907ce81a4bSJacob Faibussowitsch try to set debugging flags equivalent to -Og. 8917ce81a4bSJacob Faibussowitsch 8927ce81a4bSJacob Faibussowitsch Arguments: 8937ce81a4bSJacob Faibussowitsch - lang: the language to check the coverage flag for 8947ce81a4bSJacob Faibussowitsch - extra_coverage_flags: a list of extra flags to use when checking the coverage flags 8957ce81a4bSJacob Faibussowitsch - extra_debug_flags: a list of extra flags to try when setting debug flags 8967ce81a4bSJacob Faibussowitsch 8977ce81a4bSJacob Faibussowitsch On success: 8987ce81a4bSJacob Faibussowitsch - defines PETSC_USE_COVERAGE to 1 8997ce81a4bSJacob Faibussowitsch """ 900d3d5cfdcSJacob Faibussowitsch log_print = log_printer_cls(self) 9017ce81a4bSJacob Faibussowitsch 9027ce81a4bSJacob Faibussowitsch def quoted(string): 9037ce81a4bSJacob Faibussowitsch return string.join(("'", "'")) 9047ce81a4bSJacob Faibussowitsch 9057ce81a4bSJacob Faibussowitsch def make_flag_list(default, extra): 9067ce81a4bSJacob Faibussowitsch ret = [default] 9077ce81a4bSJacob Faibussowitsch if extra is not None: 9087ce81a4bSJacob Faibussowitsch assert isinstance(extra, list) 9097ce81a4bSJacob Faibussowitsch ret.extend(extra) 9107ce81a4bSJacob Faibussowitsch return ret 9117ce81a4bSJacob Faibussowitsch 9127ce81a4bSJacob Faibussowitsch log_print('Checking coverage flag for language {}'.format(lang)) 9139b81490aSJacob Faibussowitsch 9149b81490aSJacob Faibussowitsch compiler = self.getCompiler(lang=lang) 9159b81490aSJacob Faibussowitsch if self.setCompilers.isGNU(compiler, self.log): 916d3d5cfdcSJacob Faibussowitsch is_gnuish = True 9179b81490aSJacob Faibussowitsch elif self.setCompilers.isClang(compiler, self.log): 918d3d5cfdcSJacob Faibussowitsch is_gnuish = True 9199b81490aSJacob Faibussowitsch else: 920d3d5cfdcSJacob Faibussowitsch is_gnuish = False 9217ce81a4bSJacob Faibussowitsch 9227ce81a4bSJacob Faibussowitsch # if not gnuish and we don't have a set of extra flags, bail 923d3d5cfdcSJacob Faibussowitsch if not is_gnuish and extra_coverage_flags is None: 9247ce81a4bSJacob Faibussowitsch log_print('Don\'t know how to add coverage for compiler {}. Only know how to add coverage for gnu-like compilers (either gcc or clang). Skipping it!'.format(quoted(compiler))) 9257ce81a4bSJacob Faibussowitsch return 9267ce81a4bSJacob Faibussowitsch 9277ce81a4bSJacob Faibussowitsch coverage_flags = make_flag_list('--coverage', extra_coverage_flags) 9287ce81a4bSJacob Faibussowitsch log_print('Checking set of coverage flags: {}'.format(coverage_flags)) 9297ce81a4bSJacob Faibussowitsch 9309b81490aSJacob Faibussowitsch found = None 9317ce81a4bSJacob Faibussowitsch with self.Language(lang): 9327ce81a4bSJacob Faibussowitsch with self.setCompilers.Language(lang): 9337ce81a4bSJacob Faibussowitsch for flag in coverage_flags: 9349b81490aSJacob Faibussowitsch # the linker also needs to see the coverage flag 9359b81490aSJacob Faibussowitsch with self.setCompilers.extraCompilerFlags([flag], compilerOnly=False) as skip_flags: 9369b81490aSJacob Faibussowitsch if not skip_flags and self.checkRun(): 9379b81490aSJacob Faibussowitsch # flag was accepted 9389b81490aSJacob Faibussowitsch found = flag 9397ce81a4bSJacob Faibussowitsch break 9409b81490aSJacob Faibussowitsch 9417ce81a4bSJacob Faibussowitsch log_print( 9427ce81a4bSJacob Faibussowitsch 'Compiler {} did not accept coverage flag {}'.format(quoted(compiler), quoted(flag)) 9437ce81a4bSJacob Faibussowitsch ) 9447ce81a4bSJacob Faibussowitsch 9459b81490aSJacob Faibussowitsch if found is None: 9469b81490aSJacob Faibussowitsch log_print( 9479b81490aSJacob Faibussowitsch 'Compiler {} did not accept ANY coverage flags: {}, bailing!'.format( 9489b81490aSJacob Faibussowitsch quoted(compiler), coverage_flags 9499b81490aSJacob Faibussowitsch ) 9509b81490aSJacob Faibussowitsch ) 9517ce81a4bSJacob Faibussowitsch return 9527ce81a4bSJacob Faibussowitsch 9539b81490aSJacob Faibussowitsch # must do this exactly here since: 9549b81490aSJacob Faibussowitsch # 9559b81490aSJacob Faibussowitsch # 1. setCompilers.extraCompilerFlags() will reset the compiler flags on __exit__() 9569b81490aSJacob Faibussowitsch # (so cannot do it in the loop) 9579b81490aSJacob Faibussowitsch # 2. we need to set the compiler flag while setCompilers.Language() is still in 9589b81490aSJacob Faibussowitsch # effect (so cannot do it outside the with statements) 9599b81490aSJacob Faibussowitsch self.setCompilers.insertCompilerFlag(flag, False) 9609b81490aSJacob Faibussowitsch 9617ce81a4bSJacob Faibussowitsch if not self.functions.haveFunction('__gcov_dump'): 9627ce81a4bSJacob Faibussowitsch self.functions.checkClassify(['__gcov_dump']) 9637ce81a4bSJacob Faibussowitsch 9647ce81a4bSJacob Faibussowitsch # now check if we can override the optimization level. It is only kosher to do so if 9657ce81a4bSJacob Faibussowitsch # the user did not explicitly set the optimization flags (via CFLAGS, CXXFLAGS, 9667ce81a4bSJacob Faibussowitsch # CXXOPTFLAGS, etc). If they have done so, we sternly warn them about their lapse in 9677ce81a4bSJacob Faibussowitsch # judgement 9687ce81a4bSJacob Faibussowitsch with self.Language(lang): 9697ce81a4bSJacob Faibussowitsch compiler_flags = self.getCompilerFlags() 9707ce81a4bSJacob Faibussowitsch 9717ce81a4bSJacob Faibussowitsch user_set = 0 9727ce81a4bSJacob Faibussowitsch allowed_opt_flags = re.compile(r'|'.join((r'-O[01g]', r'-g[1-9]*'))) 9737ce81a4bSJacob Faibussowitsch for flagsname in [self.getCompilerFlagsName(lang), self.compilerFlags.getOptionalFlagsName(lang)]: 9747ce81a4bSJacob Faibussowitsch if flagsname in self.argDB: 9757ce81a4bSJacob Faibussowitsch opt_flags = [ 9767ce81a4bSJacob Faibussowitsch f for f in self.compilerFlags.findOptFlags(compiler_flags) if not allowed_opt_flags.match(f) 9777ce81a4bSJacob Faibussowitsch ] 9787ce81a4bSJacob Faibussowitsch if opt_flags: 9797ce81a4bSJacob Faibussowitsch self.logPrintWarning('Coverage requested, but optimization flag(s) {} found in {}. Coverage collection will work, but may be less accurate. Suggest removing the flag and/or using -Og (or equivalent) instead'.format(', '.join(map(quoted, opt_flags)), quoted(flagsname))) 9807ce81a4bSJacob Faibussowitsch user_set = 1 9817ce81a4bSJacob Faibussowitsch break 9827ce81a4bSJacob Faibussowitsch 98310b490f0SJacob Faibussowitsch # disable this for now, the warning should be sufficient. If the user still chooses to 98410b490f0SJacob Faibussowitsch # ignore it, then that's on them 98510b490f0SJacob Faibussowitsch if 0 and not user_set: 9867ce81a4bSJacob Faibussowitsch debug_flags = make_flag_list('-Og', extra_debug_flags) 9877ce81a4bSJacob Faibussowitsch with self.setCompilers.Language(lang): 9887ce81a4bSJacob Faibussowitsch for flag in debug_flags: 9897ce81a4bSJacob Faibussowitsch try: 9907ce81a4bSJacob Faibussowitsch self.setCompilers.addCompilerFlag(flag) 9917ce81a4bSJacob Faibussowitsch except RuntimeError: 9927ce81a4bSJacob Faibussowitsch continue 9937ce81a4bSJacob Faibussowitsch break 9947ce81a4bSJacob Faibussowitsch 9957ce81a4bSJacob Faibussowitsch self.addDefine('USE_COVERAGE', 1) 9967ce81a4bSJacob Faibussowitsch return 9977ce81a4bSJacob Faibussowitsch 9989b81490aSJacob Faibussowitsch def configureCoverage(self): 999d3d5cfdcSJacob Faibussowitsch """ 1000d3d5cfdcSJacob Faibussowitsch Configure coverage for all available languages. 1001d3d5cfdcSJacob Faibussowitsch 1002d3d5cfdcSJacob Faibussowitsch If user did not request coverage, this function does nothing and returns immediatel. 1003d3d5cfdcSJacob Faibussowitsch Therefore the following only apply to the case where the user requested coverage. 1004d3d5cfdcSJacob Faibussowitsch 1005d3d5cfdcSJacob Faibussowitsch On success: 1006d3d5cfdcSJacob Faibussowitsch - defines PETSC_USE_COVERAGE to 1 1007d3d5cfdcSJacob Faibussowitsch 1008d3d5cfdcSJacob Faibussowitsch On failure: 1009d3d5cfdcSJacob Faibussowitsch - If no compilers supported the coverage flag, throws RuntimeError 1010d3d5cfdcSJacob Faibussowitsch - 1011d3d5cfdcSJacob Faibussowitsch """ 1012d3d5cfdcSJacob Faibussowitsch class LogPrinter: 1013d3d5cfdcSJacob Faibussowitsch def __init__(self, cfg): 1014d3d5cfdcSJacob Faibussowitsch self.cfg = cfg 1015d3d5cfdcSJacob Faibussowitsch try: 1016d3d5cfdcSJacob Faibussowitsch import inspect 1017d3d5cfdcSJacob Faibussowitsch 1018d3d5cfdcSJacob Faibussowitsch calling_func_stack = inspect.stack()[1] 1019d3d5cfdcSJacob Faibussowitsch if sys.version_info >= (3, 5): 1020d3d5cfdcSJacob Faibussowitsch func_name = calling_func_stack.function 1021d3d5cfdcSJacob Faibussowitsch else: 1022d3d5cfdcSJacob Faibussowitsch func_name = calling_func_stack[3] 1023d3d5cfdcSJacob Faibussowitsch except: 1024d3d5cfdcSJacob Faibussowitsch func_name = 'Unknown' 1025d3d5cfdcSJacob Faibussowitsch self.fmt_str = func_name + '(): {}' 1026d3d5cfdcSJacob Faibussowitsch 1027d3d5cfdcSJacob Faibussowitsch def __call__(self, msg, *args, **kwargs): 1028d3d5cfdcSJacob Faibussowitsch return self.cfg.logPrint(self.fmt_str.format(msg), *args, **kwargs) 1029d3d5cfdcSJacob Faibussowitsch 1030d3d5cfdcSJacob Faibussowitsch argdb_flag = 'with-coverage' 1031d3d5cfdcSJacob Faibussowitsch log_print = LogPrinter(self) 1032d3d5cfdcSJacob Faibussowitsch if not self.argDB[argdb_flag]: 1033d3d5cfdcSJacob Faibussowitsch log_print('coverage was disabled from command line or default') 1034d3d5cfdcSJacob Faibussowitsch return 1035d3d5cfdcSJacob Faibussowitsch 1036d3d5cfdcSJacob Faibussowitsch tested_langs = [] 10379b81490aSJacob Faibussowitsch for LANG in ['C', 'Cxx', 'CUDA', 'HIP', 'SYCL', 'FC']: 10389b81490aSJacob Faibussowitsch compilerName = LANG.upper() if LANG in {'Cxx', 'FC'} else LANG + 'C' 10399b81490aSJacob Faibussowitsch if hasattr(self.setCompilers, compilerName): 10409b81490aSJacob Faibussowitsch kwargs = {} 10419b81490aSJacob Faibussowitsch if LANG in {'CUDA'}: 10429b81490aSJacob Faibussowitsch # nvcc preprocesses the base file into a bunch of intermediate files, which are 10439b81490aSJacob Faibussowitsch # then compiled by the host compiler. Why is this a problem? Because the 10449b81490aSJacob Faibussowitsch # generated coverage data is based on these preprocessed source files! So gcov 10459b81490aSJacob Faibussowitsch # tries to read it later, but since its in the tmp directory it cannot. Thus we 10469b81490aSJacob Faibussowitsch # need to keep them around (in a place we know about). 10479b81490aSJacob Faibussowitsch nvcc_tmp_dir = os.path.join(self.petscdir.dir, self.arch.arch, 'nvcc_tmp') 10489b81490aSJacob Faibussowitsch try: 10499b81490aSJacob Faibussowitsch os.mkdir(nvcc_tmp_dir) 10509b81490aSJacob Faibussowitsch except FileExistsError: 10519b81490aSJacob Faibussowitsch pass 10529b81490aSJacob Faibussowitsch kwargs['extra_coverage_flags'] = [ 10539b81490aSJacob Faibussowitsch '-Xcompiler --coverage -Xcompiler -fPIC --keep --keep-dir={}'.format(nvcc_tmp_dir) 10549b81490aSJacob Faibussowitsch ] 10559b81490aSJacob Faibussowitsch if self.kokkos.found: 10569b81490aSJacob Faibussowitsch # yet again the kokkos nvcc_wrapper goes out of its way to be as useless as 10579b81490aSJacob Faibussowitsch # possible. Its default arch (sm_35) is actually too low to compile kokkos, 10589b81490aSJacob Faibussowitsch # for whatever reason this works if you dont use the --keep and --keep-dir 10599b81490aSJacob Faibussowitsch # flags above. 10609b81490aSJacob Faibussowitsch kwargs['extra_coverage_flags'].append('-arch=native') 10619b81490aSJacob Faibussowitsch kwargs['extra_debug_flags'] = ['-Xcompiler -Og'] 1062d3d5cfdcSJacob Faibussowitsch tested_langs.append(LANG) 1063d3d5cfdcSJacob Faibussowitsch self.executeTest(self.configureCoverageForLang, args=[LogPrinter, LANG], kargs=kwargs) 1064d3d5cfdcSJacob Faibussowitsch 1065d3d5cfdcSJacob Faibussowitsch if not self.defines.get('USE_COVERAGE'): 1066d3d5cfdcSJacob Faibussowitsch # coverage was requested but no compilers accepted it, this is an error 1067d3d5cfdcSJacob Faibussowitsch raise RuntimeError( 1068d3d5cfdcSJacob Faibussowitsch 'Coverage was requested (--{}={}) but none of the compilers supported it:\n{}\n'.format( 1069d3d5cfdcSJacob Faibussowitsch argdb_flag, self.argDB[argdb_flag], 1070d3d5cfdcSJacob Faibussowitsch '\n'.join([' - {} ({})'.format(self.getCompiler(lang=lang), lang) for lang in tested_langs]) 1071d3d5cfdcSJacob Faibussowitsch ) 1072d3d5cfdcSJacob Faibussowitsch ) 1073d3d5cfdcSJacob Faibussowitsch 1074d3d5cfdcSJacob Faibussowitsch return 1075d3d5cfdcSJacob Faibussowitsch # Disabled for now, since this does not really work. It solves the problem of 1076d3d5cfdcSJacob Faibussowitsch # "undefined reference to __gcov_flush()" but if we add -lgcov we get: 1077d3d5cfdcSJacob Faibussowitsch # 1078d3d5cfdcSJacob Faibussowitsch # duplicate symbol '___gcov_reset' in: 1079d3d5cfdcSJacob Faibussowitsch # /Library/.../libclang_rt.profile_osx.a(GCDAProfiling.c.o) 1080d3d5cfdcSJacob Faibussowitsch # /opt/.../libgcov.a(_gcov_reset.o) 1081d3d5cfdcSJacob Faibussowitsch # duplicate symbol '___gcov_dump' in: 1082d3d5cfdcSJacob Faibussowitsch # /opt/.../libgcov.a(_gcov_dump.o) 1083d3d5cfdcSJacob Faibussowitsch # /Library/.../libclang_rt.profile_osx.a(GCDAProfiling.c.o) 1084d3d5cfdcSJacob Faibussowitsch # duplicate symbol '___gcov_fork' in: 1085d3d5cfdcSJacob Faibussowitsch # /opt/.../libgcov.a(_gcov_fork.o) 1086d3d5cfdcSJacob Faibussowitsch # /Library/.../libclang_rt.profile_osx.a(GCDAProfiling.c.o) 1087d3d5cfdcSJacob Faibussowitsch # 1088d3d5cfdcSJacob Faibussowitsch # I don't know how to solve this. 1089d3d5cfdcSJacob Faibussowitsch 1090d3d5cfdcSJacob Faibussowitsch log_print('Checking if compilers can cross-link disparate coverage libraries') 1091d3d5cfdcSJacob Faibussowitsch # At least one of the compilers has coverage enabled. Now need to make sure multiple 1092d3d5cfdcSJacob Faibussowitsch # code coverage impls work together, specifically when using clang C/C++ compiler with 1093d3d5cfdcSJacob Faibussowitsch # gfortran. 1094d3d5cfdcSJacob Faibussowitsch if not hasattr(self.setCompilers, 'FC'): 1095d3d5cfdcSJacob Faibussowitsch log_print('No fortran compiler detected. No need to check cross-linking!') 1096d3d5cfdcSJacob Faibussowitsch return 1097d3d5cfdcSJacob Faibussowitsch 1098d3d5cfdcSJacob Faibussowitsch c_lang = self.languages.clanguage 1099d3d5cfdcSJacob Faibussowitsch if not self.setCompilers.isClang(self.getCompiler(lang=c_lang), self.log): 1100d3d5cfdcSJacob Faibussowitsch # must be GCC 1101d3d5cfdcSJacob Faibussowitsch log_print('C-language ({}) compiler is not clang, assuming it is GCC, so cross-linking with FC ({}) assumed to be OK'.format(c_lang, self.getCompiler(lang='FC'))) 1102d3d5cfdcSJacob Faibussowitsch return 1103d3d5cfdcSJacob Faibussowitsch 1104d3d5cfdcSJacob Faibussowitsch # If we are here we: 1105d3d5cfdcSJacob Faibussowitsch # 1. Have both C/C++ compiler and fortran compiler 1106d3d5cfdcSJacob Faibussowitsch # 2. The C/C++ compiler is *not* the same as the fortran compiler (unless we start 1107d3d5cfdcSJacob Faibussowitsch # using flang) 1108d3d5cfdcSJacob Faibussowitsch # 1109d3d5cfdcSJacob Faibussowitsch # Now we check if we can cross-link 1110d3d5cfdcSJacob Faibussowitsch def can_cross_link(**kwargs): 1111d3d5cfdcSJacob Faibussowitsch f_body = " subroutine foo()\n print*,'testing'\n return\n end\n" 1112d3d5cfdcSJacob Faibussowitsch c_body = "int main() { }" 1113d3d5cfdcSJacob Faibussowitsch 1114d3d5cfdcSJacob Faibussowitsch return self.compilers.checkCrossLink( 1115d3d5cfdcSJacob Faibussowitsch f_body, c_body, language1='FC', language2=c_lang, extralibs=self.compilers.flibs, **kwargs 1116d3d5cfdcSJacob Faibussowitsch ) 1117d3d5cfdcSJacob Faibussowitsch 1118d3d5cfdcSJacob Faibussowitsch log_print('Trying to cross-link WITHOUT extra libs') 1119d3d5cfdcSJacob Faibussowitsch if can_cross_link(): 1120d3d5cfdcSJacob Faibussowitsch log_print('Successfully cross-linked WITHOUT extra libs') 1121d3d5cfdcSJacob Faibussowitsch # success, we already can cross-link 1122d3d5cfdcSJacob Faibussowitsch return 1123d3d5cfdcSJacob Faibussowitsch 1124d3d5cfdcSJacob Faibussowitsch extra_libs = ['-lgcov'] 1125d3d5cfdcSJacob Faibussowitsch log_print('Trying to cross-link with extra libs: {}'.format(extra_libs)) 1126d3d5cfdcSJacob Faibussowitsch if can_cross_link(extraObjs=extra_libs): 1127d3d5cfdcSJacob Faibussowitsch log_print( 1128d3d5cfdcSJacob Faibussowitsch 'Successfully cross-linked using extra libs: {}, adding them to LIBS'.format(extra_libs) 1129d3d5cfdcSJacob Faibussowitsch ) 1130d3d5cfdcSJacob Faibussowitsch self.setCompilers.LIBS += ' ' + ' '.join(extra_libs) 1131d3d5cfdcSJacob Faibussowitsch else: 1132d3d5cfdcSJacob Faibussowitsch # maybe should be an error? 1133d3d5cfdcSJacob Faibussowitsch self.logPrintWarning("Could not successfully cross-link covered code between {} and FC. Sometimes this is a false positive. Assuming this does eventually end up working when the full link-line is assembled when building PETSc. If you later encounter linker errors about missing __gcov_exit(), __gcov_init(), __llvm_cov_flush() etc. this is why!".format(c_lang)) 11349b81490aSJacob Faibussowitsch return 11359b81490aSJacob Faibussowitsch 11367ce81a4bSJacob Faibussowitsch def configureCoverageExecutable(self): 11377ce81a4bSJacob Faibussowitsch """ 11387ce81a4bSJacob Faibussowitsch Check that a code-coverage collecting tool exists and is on PATH. 11397ce81a4bSJacob Faibussowitsch 11407ce81a4bSJacob Faibussowitsch On success: 11417ce81a4bSJacob Faibussowitsch - Adds PETSC_COVERAGE_EXEC make macro containing the full path to the coverage tool executable. 11427ce81a4bSJacob Faibussowitsch 11437ce81a4bSJacob Faibussowitsch Raises RuntimeError if: 11447ce81a4bSJacob Faibussowitsch - User explicitly requests auto-detection of the coverage tool from command line, and this 11457ce81a4bSJacob Faibussowitsch routine fails to guess the suitable tool name. 11467ce81a4bSJacob Faibussowitsch - The routine fails to find the tool, and --with-coverage is true 11477ce81a4bSJacob Faibussowitsch """ 11487ce81a4bSJacob Faibussowitsch def log_print(msg, *args, **kwargs): 11497ce81a4bSJacob Faibussowitsch self.logPrint('checkCoverage: '+str(msg), *args, **kwargs) 11507ce81a4bSJacob Faibussowitsch return 11517ce81a4bSJacob Faibussowitsch 11527ce81a4bSJacob Faibussowitsch def quoted(string): 11537ce81a4bSJacob Faibussowitsch return string.join(("'", "'")) 11547ce81a4bSJacob Faibussowitsch 11557ce81a4bSJacob Faibussowitsch required = bool(self.argDB['with-coverage']) 11567ce81a4bSJacob Faibussowitsch arg_opt = self.argDB['with-coverage-exec'] 11577ce81a4bSJacob Faibussowitsch use_default_path = True 11587ce81a4bSJacob Faibussowitsch search_path = '' 11597ce81a4bSJacob Faibussowitsch 11607ce81a4bSJacob Faibussowitsch log_print('{} to find an executable'.format('REQUIRED' if required else 'NOT required')) 11617ce81a4bSJacob Faibussowitsch if arg_opt in {'auto', 'default-auto', '1'}: 11627ce81a4bSJacob Faibussowitsch # detect it based on the C language compiler, hopefully this does not clash! 1163095fb05fSJacob Faibussowitsch lang = self.setCompilers.languages.clanguage 1164095fb05fSJacob Faibussowitsch compiler = self.getCompiler(lang=lang) 11657ce81a4bSJacob Faibussowitsch log_print('User did not explicitly set coverage exec (got {}), trying to auto-detect based on compiler {}'.format(quoted(arg_opt), quoted(compiler))) 11667ce81a4bSJacob Faibussowitsch if self.setCompilers.isGNU(compiler, self.log): 1167095fb05fSJacob Faibussowitsch compiler_version_re = re.compile(r'[gG][cC\+\-]+[0-9]* \(.+\) (\d+)\.(\d+)\.(\d+)') 11687ce81a4bSJacob Faibussowitsch exec_names = ['gcov'] 11697ce81a4bSJacob Faibussowitsch elif self.setCompilers.isClang(compiler, self.log): 1170095fb05fSJacob Faibussowitsch compiler_version_re = re.compile(r'clang version (\d+)\.(\d+)\.(\d+)') 11717ce81a4bSJacob Faibussowitsch exec_names = ['llvm-cov'] 11727ce81a4bSJacob Faibussowitsch if self.setCompilers.isDarwin(self.log): 11737ce81a4bSJacob Faibussowitsch # macOS masquerades llvm-cov as just 'gcov', so we add this to the list in case 11747ce81a4bSJacob Faibussowitsch # bare llvm-cov does not work 11757ce81a4bSJacob Faibussowitsch exec_names.append('gcov') 11767ce81a4bSJacob Faibussowitsch elif arg_opt == 'default-auto' and not required: 11777ce81a4bSJacob Faibussowitsch # default-auto implies the user did not set it via command line! 11787ce81a4bSJacob Faibussowitsch log_print('Could not auto-detect coverage tool for {}, not a gnuish compiler. Bailing since user did not explicitly set exec on the commandline'.format(quoted(compiler))) 11797ce81a4bSJacob Faibussowitsch return 11807ce81a4bSJacob Faibussowitsch else: 11817ce81a4bSJacob Faibussowitsch # implies 'auto' explicitly set by user, or we were required to find 11827ce81a4bSJacob Faibussowitsch # something. either way we should error 11837ce81a4bSJacob Faibussowitsch raise RuntimeError('Could not auto-detect coverage tool for {}, please set coverage tool name explicitly'.format(quoted(compiler))) 1184095fb05fSJacob Faibussowitsch 1185095fb05fSJacob Faibussowitsch try: 1186095fb05fSJacob Faibussowitsch compiler_version_str = self.compilerFlags.version[lang] 1187095fb05fSJacob Faibussowitsch except KeyError: 1188095fb05fSJacob Faibussowitsch compiler_version_str = 'Unknown' 1189095fb05fSJacob Faibussowitsch 1190095fb05fSJacob Faibussowitsch log_print('Searching version string {} (for compiler {}) using pattern {}'.format(quoted(compiler_version_str), quoted(compiler), quoted(compiler_version_re.pattern))) 1191095fb05fSJacob Faibussowitsch compiler_version = compiler_version_re.search(compiler_version_str) 1192095fb05fSJacob Faibussowitsch if compiler_version is not None: 1193095fb05fSJacob Faibussowitsch log_print('Found major = {}, minor = {}, patch = {}'.format(compiler_version.group(1), compiler_version.group(2), compiler_version.group(3))) 1194095fb05fSJacob Faibussowitsch # form [llvm-cov-14, llvm-cov-14.0, llvm-cov, etc.] 1195095fb05fSJacob Faibussowitsch cov_exec_name = exec_names[0] 1196095fb05fSJacob Faibussowitsch exec_names = [ 1197095fb05fSJacob Faibussowitsch # llvm-cov-14 1198095fb05fSJacob Faibussowitsch '{}-{}'.format(cov_exec_name, compiler_version.group(1)), 1199095fb05fSJacob Faibussowitsch # llvm-cov-14.0 1200095fb05fSJacob Faibussowitsch '{}-{}.{}'.format(cov_exec_name, compiler_version.group(1), compiler_version.group(2)) 1201095fb05fSJacob Faibussowitsch ] + exec_names 12027ce81a4bSJacob Faibussowitsch else: 12037ce81a4bSJacob Faibussowitsch log_print('User explicitly set coverage exec as {}'.format(quoted(arg_opt))) 12047ce81a4bSJacob Faibussowitsch par_dir = os.path.dirname(arg_opt) 12057ce81a4bSJacob Faibussowitsch if os.path.exists(par_dir): 12067ce81a4bSJacob Faibussowitsch # arg_opt is path-like, we should only search the provided directory when we go 12077ce81a4bSJacob Faibussowitsch # looking for the tool 12087ce81a4bSJacob Faibussowitsch use_default_path = False 12097ce81a4bSJacob Faibussowitsch search_path = par_dir 12107ce81a4bSJacob Faibussowitsch exec_names = [arg_opt] 12117ce81a4bSJacob Faibussowitsch 12127ce81a4bSJacob Faibussowitsch make_macro_name = 'PETSC_COVERAGE_EXEC' 12137ce81a4bSJacob Faibussowitsch log_print('Checking for coverage tool(s):\n{}'.format('\n'.join('- '+t for t in exec_names))) 12147ce81a4bSJacob Faibussowitsch found_exec = self.getExecutables( 12157ce81a4bSJacob Faibussowitsch exec_names, 12167ce81a4bSJacob Faibussowitsch path=search_path, getFullPath=True, useDefaultPath=use_default_path, resultName=make_macro_name 12177ce81a4bSJacob Faibussowitsch ) 12187ce81a4bSJacob Faibussowitsch 12197ce81a4bSJacob Faibussowitsch if found_exec is None: 12207ce81a4bSJacob Faibussowitsch # didn't find the coverage tool 12217ce81a4bSJacob Faibussowitsch if required: 12227ce81a4bSJacob Faibussowitsch raise RuntimeError('Coverage tool(s) {} could not be found. Please provide explicit path to coverage tool'.format(exec_names)) 12237ce81a4bSJacob Faibussowitsch return 12247ce81a4bSJacob Faibussowitsch 12257ce81a4bSJacob Faibussowitsch found_exec_name = os.path.basename(found_exec) 12267ce81a4bSJacob Faibussowitsch if 'llvm-cov' in found_exec_name and 'gcov' not in found_exec_name: 12277ce81a4bSJacob Faibussowitsch # llvm-cov needs to be called as 'llvm-cov gcov' to work 12287ce81a4bSJacob Faibussowitsch self.addMakeMacro(make_macro_name, found_exec + ' gcov') 12297ce81a4bSJacob Faibussowitsch return 12307ce81a4bSJacob Faibussowitsch 1231689a5dfaSJacob Faibussowitsch def configureStrictPetscErrorCode(self): 1232689a5dfaSJacob Faibussowitsch """ 1233689a5dfaSJacob Faibussowitsch Enables or disables strict PetscErrorCode checking. 1234689a5dfaSJacob Faibussowitsch 1235689a5dfaSJacob Faibussowitsch If --with-strict-petscerrorcode = 1: 1236689a5dfaSJacob Faibussowitsch - defines PETSC_USE_STRICT_PETSCERRORCODE to 1 1237689a5dfaSJacob Faibussowitsch 1238689a5dfaSJacob Faibussowitsch Else: 1239689a5dfaSJacob Faibussowitsch - deletes any prior PETSC_USE_STRICT_PETSCERRORCODE definitions (if they exist) 1240689a5dfaSJacob Faibussowitsch """ 1241689a5dfaSJacob Faibussowitsch define_name = 'USE_STRICT_PETSCERRORCODE' 1242689a5dfaSJacob Faibussowitsch if self.argDB['with-strict-petscerrorcode']: 1243689a5dfaSJacob Faibussowitsch self.addDefine(define_name, 1) 1244689a5dfaSJacob Faibussowitsch else: 1245689a5dfaSJacob Faibussowitsch # in case it was somehow added previously 1246689a5dfaSJacob Faibussowitsch self.delDefine(define_name) 1247689a5dfaSJacob Faibussowitsch return 1248689a5dfaSJacob Faibussowitsch 1249f8833479SBarry Smith#----------------------------------------------------------------------------------------------------- 1250b10d012aSSatish Balay def configureCygwinBrokenPipe(self): 1251b10d012aSSatish Balay '''Cygwin version <= 1.7.18 had issues with pipes and long commands invoked from gnu-make 1252b10d012aSSatish Balay http://cygwin.com/ml/cygwin/2013-05/msg00340.html ''' 12537fca349cSMatthew G. Knepley if config.setCompilers.Configure.isCygwin(self.log): 1254b10d012aSSatish Balay import platform 1255b10d012aSSatish Balay import re 1256b10d012aSSatish Balay r=re.compile("([0-9]+).([0-9]+).([0-9]+)") 1257b10d012aSSatish Balay m=r.match(platform.release()) 1258b10d012aSSatish Balay major=int(m.group(1)) 1259b10d012aSSatish Balay minor=int(m.group(2)) 1260b10d012aSSatish Balay subminor=int(m.group(3)) 1261b10d012aSSatish Balay if ((major < 1) or (major == 1 and minor < 7) or (major == 1 and minor == 7 and subminor <= 18)): 1262b10d012aSSatish Balay self.addMakeMacro('PETSC_CYGWIN_BROKEN_PIPE','1') 1263b10d012aSSatish Balay return 1264b10d012aSSatish Balay 1265b10d012aSSatish Balay#----------------------------------------------------------------------------------------------------- 1266569865ddSSatish Balay def configureDefaultArch(self): 1267af0996ceSBarry Smith conffile = os.path.join('lib','petsc','conf', 'petscvariables') 1268569865ddSSatish Balay if self.framework.argDB['with-default-arch']: 1269c6ef1b5bSJed Brown fd = open(conffile, 'w') 1270569865ddSSatish Balay fd.write('PETSC_ARCH='+self.arch.arch+'\n') 1271da93591fSBarry Smith fd.write('PETSC_DIR='+self.petscdir.dir+'\n') 1272b9b902edSJed Brown fd.write('include '+os.path.join('$(PETSC_DIR)','$(PETSC_ARCH)','lib','petsc','conf','petscvariables')+'\n') 1273569865ddSSatish Balay fd.close() 1274569865ddSSatish Balay self.framework.actions.addArgument('PETSc', 'Build', 'Set default architecture to '+self.arch.arch+' in '+conffile) 1275569865ddSSatish Balay elif os.path.isfile(conffile): 1276569865ddSSatish Balay try: 1277569865ddSSatish Balay os.unlink(conffile) 1278569865ddSSatish Balay except: 1279569865ddSSatish Balay raise RuntimeError('Unable to remove file '+conffile+'. Did a different user create it?') 1280569865ddSSatish Balay return 1281569865ddSSatish Balay 1282569865ddSSatish Balay#----------------------------------------------------------------------------------------------------- 1283f8833479SBarry Smith def configureScript(self): 1284f8833479SBarry Smith '''Output a script in the conf directory which will reproduce the configuration''' 1285f8833479SBarry Smith import nargs 1286495bf1a9SSatish Balay import sys 1287af0996ceSBarry Smith scriptName = os.path.join(self.arch.arch,'lib','petsc','conf', 'reconfigure-'+self.arch.arch+'.py') 1288f8833479SBarry Smith args = dict([(nargs.Arg.parseArgument(arg)[0], arg) for arg in self.framework.clArgs]) 1289e97fc2efSSatish Balay if 'with-clean' in args: 1290e97fc2efSSatish Balay del args['with-clean'] 1291d418e2d7SSatish Balay if 'force' in args: 1292d418e2d7SSatish Balay del args['force'] 1293f8833479SBarry Smith if 'configModules' in args: 12941063a081SSatish Balay if nargs.Arg.parseArgument(args['configModules'])[1] == 'PETSc.Configure': 1295f8833479SBarry Smith del args['configModules'] 1296f8833479SBarry Smith if 'optionsModule' in args: 129723a19ef1SSatish Balay if nargs.Arg.parseArgument(args['optionsModule'])[1] == 'config.compilerOptions': 1298f8833479SBarry Smith del args['optionsModule'] 1299f8833479SBarry Smith if not 'PETSC_ARCH' in args: 13001063a081SSatish Balay args['PETSC_ARCH'] = 'PETSC_ARCH='+str(self.arch.arch) 1301c6ef1b5bSJed Brown f = open(scriptName, 'w') 1302495bf1a9SSatish Balay f.write('#!'+sys.executable+'\n') 1303f8833479SBarry Smith f.write('if __name__ == \'__main__\':\n') 1304f8833479SBarry Smith f.write(' import sys\n') 13057561c02cSSatish Balay f.write(' import os\n') 13067561c02cSSatish Balay f.write(' sys.path.insert(0, os.path.abspath(\'config\'))\n') 1307f8833479SBarry Smith f.write(' import configure\n') 13081063a081SSatish Balay # pretty print repr(args.values()) 13091063a081SSatish Balay f.write(' configure_options = [\n') 13108bec23c5SJed Brown for itm in sorted(args.values()): 13111063a081SSatish Balay f.write(' \''+str(itm)+'\',\n') 13121063a081SSatish Balay f.write(' ]\n') 1313f8833479SBarry Smith f.write(' configure.petsc_configure(configure_options)\n') 1314f8833479SBarry Smith f.close() 1315f8833479SBarry Smith try: 13165b6bfdb9SJed Brown os.chmod(scriptName, 0o775) 13175b6bfdb9SJed Brown except OSError as e: 1318f8833479SBarry Smith self.framework.logPrint('Unable to make reconfigure script executable:\n'+str(e)) 1319f8833479SBarry Smith self.framework.actions.addArgument('PETSc', 'File creation', 'Created '+scriptName+' for automatic reconfiguration') 1320f8833479SBarry Smith return 1321f8833479SBarry Smith 1322f8833479SBarry Smith def configureInstall(self): 1323f8833479SBarry Smith '''Setup the directories for installation''' 1324f8833479SBarry Smith if self.framework.argDB['prefix']: 13255b4fc442SVaclav Hapla self.addMakeRule('print_mesg_after_build','', 13265b4fc442SVaclav Hapla ['-@echo "========================================="', 13275b4fc442SVaclav Hapla '-@echo "Now to install the libraries do:"', 13285b4fc442SVaclav Hapla '-@echo "%s${MAKE_USER} PETSC_DIR=${PETSC_DIR} PETSC_ARCH=${PETSC_ARCH} install"' % self.installdir.installSudo, 1329315b77e6SSatish Balay '-@echo "========================================="']) 1330f8833479SBarry Smith else: 13315b4fc442SVaclav Hapla self.addMakeRule('print_mesg_after_build','', 13325b4fc442SVaclav Hapla ['-@echo "========================================="', 13335b4fc442SVaclav Hapla '-@echo "Now to check if the libraries are working do:"', 13345b4fc442SVaclav Hapla '-@echo "${MAKE_USER} PETSC_DIR=${PETSC_DIR} PETSC_ARCH=${PETSC_ARCH} check"', 1335315b77e6SSatish Balay '-@echo "========================================="']) 1336f8833479SBarry Smith return 1337f8833479SBarry Smith 133828bb2e72SSatish Balay def postProcessPackages(self): 133928bb2e72SSatish Balay postPackages=[] 134028bb2e72SSatish Balay for i in self.framework.packages: 134128bb2e72SSatish Balay if hasattr(i,'postProcess'): postPackages.append(i) 134228bb2e72SSatish Balay if postPackages: 1343e64d19dfSSatish Balay # ctetgen needs petsc conf files. so attempt to create them early 1344a77eb93bSSatish Balay self.framework.dumpConfFiles() 1345d9293e7bSBarry Smith # tacky fix for dependency of Aluimia on Pflotran; requested via petsc-dev Matt provide a correct fix 1346d9293e7bSBarry Smith for i in postPackages: 1347d9293e7bSBarry Smith if i.name.upper() in ['PFLOTRAN']: 1348d9293e7bSBarry Smith i.postProcess() 1349d9293e7bSBarry Smith postPackages.remove(i) 135028bb2e72SSatish Balay for i in postPackages: i.postProcess() 1351aa5c8b8eSBarry Smith for i in postPackages: 1352aa5c8b8eSBarry Smith if i.installedpetsc: 1353aa5c8b8eSBarry Smith self.installed = 1 1354aa5c8b8eSBarry Smith break 135528bb2e72SSatish Balay return 1356f8833479SBarry Smith 1357f8833479SBarry Smith def configure(self): 1358bf3e94a3SBarry Smith if 'package-prefix-hash' in self.argDB: 1359bf3e94a3SBarry Smith # turn off prefix if it was only used to for installing external packages. 1360bf3e94a3SBarry Smith self.framework.argDB['prefix'] = '' 1361bf3e94a3SBarry Smith self.dir = os.path.abspath(os.path.join(self.petscdir.dir, self.arch.arch)) 1362bf3e94a3SBarry Smith self.installdir.dir = self.dir 1363bf3e94a3SBarry Smith self.installdir.petscDir = self.petscdir.dir 1364bf3e94a3SBarry Smith self.petscDir = self.petscdir.dir 1365bf3e94a3SBarry Smith self.petscArch = self.arch.arch 1366bf3e94a3SBarry Smith self.addMakeMacro('PREFIXDIR',self.dir) 1367bf3e94a3SBarry Smith self.confDir = os.path.abspath(os.path.join(self.petscdir.dir, self.arch.arch)) 1368bf3e94a3SBarry Smith 1369f8833479SBarry Smith if not os.path.samefile(self.petscdir.dir, os.getcwd()): 1370f8833479SBarry Smith raise RuntimeError('Wrong PETSC_DIR option specified: '+str(self.petscdir.dir) + '\n Configure invoked in: '+os.path.realpath(os.getcwd())) 1371550489e3SMatthew G Knepley if self.framework.argDB['prefix'] and os.path.isdir(self.framework.argDB['prefix']) and os.path.samefile(self.framework.argDB['prefix'],self.petscdir.dir): 13723552d8fbSSatish Balay raise RuntimeError('Incorrect option --prefix='+self.framework.argDB['prefix']+' specified. It cannot be same as PETSC_DIR!') 13738fd0dbdbSBarry Smith if self.framework.argDB['prefix'] and self.framework.argDB['prefix'].find(' ') > -1: 13748fd0dbdbSBarry Smith raise RuntimeError('Your --prefix '+self.framework.argDB['prefix']+' has spaces in it; this is not allowed.\n Use a --prefix that does not have spaces in it') 1375c16c35a9SSatish Balay if self.framework.argDB['prefix'] and os.path.isdir(self.framework.argDB['prefix']) and os.path.samefile(self.framework.argDB['prefix'],os.path.join(self.petscdir.dir,self.arch.arch)): 1376c16c35a9SSatish Balay raise RuntimeError('Incorrect option --prefix='+self.framework.argDB['prefix']+' specified. It cannot be same as PETSC_DIR/PETSC_ARCH!') 1377f16c1317SJed Brown self.framework.header = os.path.join(self.arch.arch,'include','petscconf.h') 1378f16c1317SJed Brown self.framework.cHeader = os.path.join(self.arch.arch,'include','petscfix.h') 1379bf113f49SJacob Faibussowitsch self.framework.poisonheader = os.path.join(self.arch.arch,'include','petscconf_poison.h') 13809c735a01SStefano Zampini self.framework.pkgheader = os.path.join(self.arch.arch,'include','petscpkg_version.h') 1381af0996ceSBarry Smith self.framework.makeMacroHeader = os.path.join(self.arch.arch,'lib','petsc','conf','petscvariables') 1382af0996ceSBarry Smith self.framework.makeRuleHeader = os.path.join(self.arch.arch,'lib','petsc','conf','petscrules') 1383f8833479SBarry Smith if self.libraries.math is None: 1384f8833479SBarry Smith raise RuntimeError('PETSc requires a functional math library. Please send configure.log to petsc-maint@mcs.anl.gov.') 1385f8833479SBarry Smith if self.languages.clanguage == 'Cxx' and not hasattr(self.compilers, 'CXX'): 1386f8833479SBarry Smith raise RuntimeError('Cannot set C language to C++ without a functional C++ compiler.') 1387ed938b00SJed Brown self.executeTest(self.configureRTLDDefault) 1388b2843cf1SBarry Smith self.executeTest(self.configurePrefetch) 13892400fdedSBarry Smith self.executeTest(self.configureUnused) 13901ef8df7fSJed Brown self.executeTest(self.configureDeprecated) 139198ed35c3SBarry Smith self.executeTest(self.configureIsatty) 1392e8e972b2SVaclav Hapla self.executeTest(self.configureExpect) 1393e8e972b2SVaclav Hapla self.executeTest(self.configureAlign) 1394e8e972b2SVaclav Hapla self.executeTest(self.configureFunctionName) 1395e8e972b2SVaclav Hapla self.executeTest(self.configureIntptrt) 1396f8833479SBarry Smith self.executeTest(self.configureSolaris) 1397f8833479SBarry Smith self.executeTest(self.configureLinux) 13980f64ec89SBarry Smith self.executeTest(self.configureDarwin) 1399f8833479SBarry Smith self.executeTest(self.configureWin32) 1400b10d012aSSatish Balay self.executeTest(self.configureCygwinBrokenPipe) 1401569865ddSSatish Balay self.executeTest(self.configureDefaultArch) 1402f8833479SBarry Smith self.executeTest(self.configureScript) 1403f8833479SBarry Smith self.executeTest(self.configureInstall) 140409bc878fSSatish Balay self.executeTest(self.configureAtoll) 14059b81490aSJacob Faibussowitsch self.executeTest(self.configureCoverage) 14067ce81a4bSJacob Faibussowitsch self.executeTest(self.configureCoverageExecutable) 1407689a5dfaSJacob Faibussowitsch self.executeTest(self.configureStrictPetscErrorCode) 1408f8833479SBarry Smith 1409f8833479SBarry Smith self.Dump() 1410f8833479SBarry Smith self.dumpConfigInfo() 14112a4161d9SMatthew G Knepley self.dumpMachineInfo() 141249fe22e6SSatish Balay self.delGenFiles() 141340277576SBarry Smith # need to save the current state of BuildSystem so that postProcess() packages can read it in and perhaps run make install 141440277576SBarry Smith self.framework.storeSubstitutions(self.framework.argDB) 1415492432c8SJed Brown self.framework.argDB['configureCache'] = pickle.dumps(self.framework) 141640277576SBarry Smith self.framework.argDB.save(force = True) 14178244ab14SJed Brown self.DumpPkgconfig('PETSc.pc') 14188244ab14SJed Brown self.DumpPkgconfig('petsc.pc') 1419351d3a41SMatthew G Knepley self.DumpModule() 1420f7ad81e1SBarry Smith self.postProcessPackages() 1421f8833479SBarry Smith self.framework.log.write('================================================================================\n') 1422f8833479SBarry Smith self.logClear() 1423f8833479SBarry Smith return 1424