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 14f8833479SBarry Smith return 15f8833479SBarry Smith 167c939e48SSatish Balay def __str2__(self): 177c939e48SSatish Balay desc = [] 18aa5c8b8eSBarry Smith if not self.installed: 19a0022257SSatish Balay desc.append('xxx=========================================================================xxx') 20ac1d0f13SJed Brown if self.make.getMakeMacro('MAKE_IS_GNUMAKE'): 219481793eSSatish Balay build_type = 'gnumake build' 229481793eSSatish Balay elif self.getMakeMacro('PETSC_BUILD_USING_CMAKE'): 23b3618d6dSSatish Balay build_type = 'cmake build' 24b3618d6dSSatish Balay else: 25b3618d6dSSatish Balay build_type = 'legacy build' 26b3618d6dSSatish Balay desc.append(' Configure stage complete. Now build PETSc libraries with (%s):' % build_type) 27b3618d6dSSatish Balay desc.append(' make PETSC_DIR='+self.petscdir.dir+' PETSC_ARCH='+self.arch.arch+' all') 28a0022257SSatish Balay desc.append('xxx=========================================================================xxx') 29aa5c8b8eSBarry Smith else: 30aa5c8b8eSBarry Smith desc.append('xxx=========================================================================xxx') 31aa5c8b8eSBarry Smith desc.append(' Installation complete. You do not need to run make to compile or install the software') 32aa5c8b8eSBarry Smith desc.append('xxx=========================================================================xxx') 337c939e48SSatish Balay return '\n'.join(desc)+'\n' 34f8833479SBarry Smith 35f8833479SBarry Smith def setupHelp(self, help): 36f8833479SBarry Smith import nargs 37ce0b2093SBarry Smith help.addArgument('PETSc', '-prefix=<dir>', nargs.Arg(None, '', 'Specifiy location to install PETSc (eg. /usr/local)')) 387deb5ab3SBarry Smith help.addArgument('PETSc', '-with-prefetch=<bool>', nargs.ArgBool(None, 1,'Enable checking for prefetch instructions')) 39eed94e11SSatish Balay help.addArgument('Windows','-with-windows-graphics=<bool>', nargs.ArgBool(None, 1,'Enable check for Windows Graphics')) 40569865ddSSatish Balay help.addArgument('PETSc', '-with-default-arch=<bool>', nargs.ArgBool(None, 1, 'Allow using the last configured arch without setting PETSC_ARCH')) 4157cb31baSSatish Balay help.addArgument('PETSc','-with-single-library=<bool>', nargs.ArgBool(None, 1,'Put all PETSc code into the single -lpetsc library')) 42cb297985SSatish Balay help.addArgument('PETSc','-with-fortran-bindings=<bool>', nargs.ArgBool(None, 1,'Build PETSc fortran bindings in the library and corresponding module files')) 43525d6f2eSBarry Smith help.addArgument('PETSc', '-with-ios=<bool>', nargs.ArgBool(None, 0, 'Build an iPhone/iPad version of PETSc library')) 448fd71741SJason Sarich help.addArgument('PETSc', '-with-xsdk-defaults', nargs.ArgBool(None, 0, 'Set the following as defaults for the xSDK standard: --enable-debug=1, --enable-shared=1, --with-precision=double, --with-index-size=32, locate blas/lapack automatically')) 45752d89a4SSatish Balay help.addArgument('PETSc', '-known-has-attribute-aligned=<bool>',nargs.ArgBool(None, None, 'Indicates __attribute((aligned(16)) directive works (the usual test will be skipped)')) 4613f9d092SSatish Balay help.addArgument('PETSc', '-with-display=<x11display>', nargs.Arg(None, '', 'Specifiy DISPLAY env variable for use with matlab test)')) 472c30b4dfSSatish Balay help.addArgument('PETSc', '-with-package-scripts=<pyscripts>',nargs.ArgFileList(None,None,'Specify configure package scripts for user provided packages')) 48f8833479SBarry Smith return 49f8833479SBarry Smith 506dd73af6SBarry Smith def registerPythonFile(self,filename,directory): 516dd73af6SBarry Smith ''' Add a python file to the framework and registers its headerprefix, ... externalpackagedir 526dd73af6SBarry Smith directory is the directory where the file relative to the BuildSystem or config path in python notation with . ''' 536dd73af6SBarry Smith (utilityName, ext) = os.path.splitext(filename) 546dd73af6SBarry Smith if not utilityName.startswith('.') and not utilityName.startswith('#') and ext == '.py' and not utilityName == '__init__': 556dd73af6SBarry Smith if directory: directory = directory+'.' 566dd73af6SBarry Smith utilityObj = self.framework.require(directory+utilityName, self) 576dd73af6SBarry Smith utilityObj.headerPrefix = self.headerPrefix 586dd73af6SBarry Smith utilityObj.archProvider = self.arch 596dd73af6SBarry Smith utilityObj.languageProvider = self.languages 606dd73af6SBarry Smith utilityObj.installDirProvider = self.installdir 616dd73af6SBarry Smith utilityObj.externalPackagesDirProvider = self.externalpackagesdir 626dd73af6SBarry Smith utilityObj.precisionProvider = self.scalartypes 636dd73af6SBarry Smith utilityObj.indexProvider = self.indexTypes 646dd73af6SBarry Smith setattr(self, utilityName.lower(), utilityObj) 6551294b80SMatthew G. Knepley return utilityObj 6651294b80SMatthew G. Knepley return None 676dd73af6SBarry Smith 68f8833479SBarry Smith def setupDependencies(self, framework): 69f8833479SBarry Smith config.base.Configure.setupDependencies(self, framework) 70dca78d2bSSatish Balay self.programs = framework.require('config.programs', self) 71f8833479SBarry Smith self.setCompilers = framework.require('config.setCompilers', self) 7230b8aa07SMatthew G. Knepley self.compilers = framework.require('config.compilers', self) 739d310bb7SBarry Smith self.arch = framework.require('PETSc.options.arch', self.setCompilers) 749d310bb7SBarry Smith self.petscdir = framework.require('PETSc.options.petscdir', self.arch) 759d310bb7SBarry Smith self.installdir = framework.require('PETSc.options.installDir', self) 766dd73af6SBarry Smith self.scalartypes = framework.require('PETSc.options.scalarTypes', self) 776dd73af6SBarry Smith self.indexTypes = framework.require('PETSc.options.indexTypes', self) 789d310bb7SBarry Smith self.languages = framework.require('PETSc.options.languages', self.setCompilers) 7930b8aa07SMatthew G. Knepley self.indexTypes = framework.require('PETSc.options.indexTypes', self.compilers) 80f8833479SBarry Smith self.compilers = framework.require('config.compilers', self) 81f8833479SBarry Smith self.types = framework.require('config.types', self) 82f8833479SBarry Smith self.headers = framework.require('config.headers', self) 83f8833479SBarry Smith self.functions = framework.require('config.functions', self) 84f8833479SBarry Smith self.libraries = framework.require('config.libraries', self) 85cd37d877SShri Abhyankar self.atomics = framework.require('config.atomics', self) 869481793eSSatish Balay self.make = framework.require('config.packages.make', self) 879552296fSBarry Smith self.blasLapack = framework.require('config.packages.BlasLapack',self) 8806e08bc7SBarry Smith self.cmake = framework.require('config.packages.cmake',self) 899d310bb7SBarry Smith self.externalpackagesdir = framework.require('PETSc.options.externalpackagesdir',self) 90e6b0c433SBarry Smith self.mpi = framework.require('config.packages.MPI',self) 9149d43ecaSSatish Balay 9209a6cbfcSBernhard M. Wiedemann for utility in sorted(os.listdir(os.path.join('config','PETSc','options'))): 936dd73af6SBarry Smith self.registerPythonFile(utility,'PETSc.options') 949d310bb7SBarry Smith 9509a6cbfcSBernhard M. Wiedemann for utility in sorted(os.listdir(os.path.join('config','BuildSystem','config','utilities'))): 966dd73af6SBarry Smith self.registerPythonFile(utility,'config.utilities') 9706e08bc7SBarry Smith 9809a6cbfcSBernhard M. Wiedemann for package in sorted(os.listdir(os.path.join('config', 'BuildSystem', 'config', 'packages'))): 9951294b80SMatthew G. Knepley obj = self.registerPythonFile(package,'config.packages') 10051294b80SMatthew G. Knepley if obj: 10151294b80SMatthew G. Knepley obj.archProvider = self.framework.requireModule(obj.archProvider, obj) 10251294b80SMatthew G. Knepley obj.languageProvider = self.framework.requireModule(obj.languageProvider, obj) 10351294b80SMatthew G. Knepley obj.installDirProvider = self.framework.requireModule(obj.installDirProvider, obj) 10451294b80SMatthew G. Knepley obj.externalPackagesDirProvider = self.framework.requireModule(obj.externalPackagesDirProvider, obj) 10551294b80SMatthew G. Knepley obj.precisionProvider = self.framework.requireModule(obj.precisionProvider, obj) 10651294b80SMatthew G. Knepley obj.indexProvider = self.framework.requireModule(obj.indexProvider, obj) 1076dd73af6SBarry Smith 1085faf1eacSMatthew G. Knepley # Force blaslapack and opencl to depend on scalarType so precision is set before BlasLapack is built 1099d310bb7SBarry Smith framework.require('PETSc.options.scalarTypes', self.f2cblaslapack) 1109d310bb7SBarry Smith framework.require('PETSc.options.scalarTypes', self.fblaslapack) 1119d310bb7SBarry Smith framework.require('PETSc.options.scalarTypes', self.blaslapack) 1125faf1eacSMatthew G. Knepley framework.require('PETSc.options.scalarTypes', self.opencl) 113f8833479SBarry Smith 114dca78d2bSSatish Balay self.programs.headerPrefix = self.headerPrefix 115f8833479SBarry Smith self.compilers.headerPrefix = self.headerPrefix 116f8833479SBarry Smith self.types.headerPrefix = self.headerPrefix 117f8833479SBarry Smith self.headers.headerPrefix = self.headerPrefix 118f8833479SBarry Smith self.functions.headerPrefix = self.headerPrefix 119f8833479SBarry Smith self.libraries.headerPrefix = self.headerPrefix 1206dd73af6SBarry Smith 1212c30b4dfSSatish Balay # Register user provided package scripts 1222c30b4dfSSatish Balay if 'with-package-scripts' in self.framework.argDB: 1232c30b4dfSSatish Balay for script in self.framework.argDB['with-package-scripts']: 1242c30b4dfSSatish Balay if os.path.splitext(script)[1] != '.py': 1252c30b4dfSSatish Balay raise RuntimeError('Only python scripts compatible with configure package script format should be specified! Invalid option -with-package-scripts='+script) 1262c30b4dfSSatish Balay self.framework.logPrint('User is registering a new package script: '+script) 1272c30b4dfSSatish Balay dname,fname = os.path.split(script) 1282c30b4dfSSatish Balay if dname: sys.path.append(dname) 1292c30b4dfSSatish Balay self.registerPythonFile(fname,'') 1306dd73af6SBarry Smith 1316dd73af6SBarry Smith # test for a variety of basic headers and functions 132a8b45ee7SBarry Smith headersC = map(lambda name: name+'.h', ['setjmp','dos', 'endian', 'fcntl', 'float', 'io', 'limits', 'malloc', 'pwd', 'search', 'strings', 133ba61063dSBarry Smith 'unistd', 'sys/sysinfo', 'machine/endian', 'sys/param', 'sys/procfs', 'sys/resource', 134a3aaec0aSJed Brown 'sys/systeminfo', 'sys/times', 'sys/utsname','string', 'stdlib', 135f8833479SBarry Smith 'sys/socket','sys/wait','netinet/in','netdb','Direct','time','Ws2tcpip','sys/types', 136ffebf242SSatish Balay 'WindowsX', 'cxxabi','float','ieeefp','stdint','sched','pthread','inttypes','immintrin','zmmintrin']) 13745082d64SJed Brown functions = ['access', '_access', 'clock', 'drand48', 'getcwd', '_getcwd', 'getdomainname', 'gethostname', 1389dcccc9aSSatish Balay 'gettimeofday', 'getwd', 'memalign', 'mkstemp', 'popen', 'PXFGETARG', 'rand', 'getpagesize', 13938ecfe64SSatish Balay 'readlink', 'realpath', 'sigaction', 'signal', 'sigset', 'usleep', 'sleep', '_sleep', 'socket', 140473bb0d5SSatish Balay 'times', 'gethostbyname', 'uname','snprintf','_snprintf','lseek','_lseek','time','fork','stricmp', 141ac7218bbSSatish Balay 'strcasecmp', 'bzero', 'dlopen', 'dlsym', 'dlclose', 'dlerror','get_nprocs','sysctlbyname', 1420787ed6cSSatish Balay '_set_output_format','_mkdir'] 143f8833479SBarry Smith libraries1 = [(['socket', 'nsl'], 'socket'), (['fpe'], 'handle_sigfpes')] 144f8833479SBarry Smith self.headers.headers.extend(headersC) 145f8833479SBarry Smith self.functions.functions.extend(functions) 146f8833479SBarry Smith self.libraries.libraries.extend(libraries1) 1477d421530SBarry Smith 148f8833479SBarry Smith return 149f8833479SBarry Smith 150262119f8SBarry Smith def DumpPkgconfig(self): 151262119f8SBarry Smith ''' Create a pkg-config file ''' 152262119f8SBarry Smith if not os.path.exists(os.path.join(self.petscdir.dir,self.arch.arch,'lib','pkgconfig')): 153262119f8SBarry Smith os.makedirs(os.path.join(self.petscdir.dir,self.arch.arch,'lib','pkgconfig')) 154262119f8SBarry Smith fd = open(os.path.join(self.petscdir.dir,self.arch.arch,'lib','pkgconfig','PETSc.pc'),'w') 1555e3311eeSJed Brown cflags_inc = ['-I${includedir}'] 156262119f8SBarry Smith if self.framework.argDB['prefix']: 1575bb5b263SMatthew G. Knepley fd.write('prefix='+self.installdir.dir+'\n') 158262119f8SBarry Smith else: 159e1e675deSJed Brown fd.write('prefix='+os.path.join(self.petscdir.dir, self.arch.arch)+'\n') 160e1e675deSJed Brown cflags_inc.append('-I' + os.path.join(self.petscdir.dir, 'include')) 161262119f8SBarry Smith fd.write('exec_prefix=${prefix}\n') 162262119f8SBarry Smith fd.write('includedir=${prefix}/include\n') 1635e3311eeSJed Brown fd.write('libdir=${prefix}/lib\n') 164262119f8SBarry Smith 165262119f8SBarry Smith self.setCompilers.pushLanguage('C') 166262119f8SBarry Smith fd.write('ccompiler='+self.setCompilers.getCompiler()+'\n') 167756c7f9fSJed Brown fd.write('cflags_extra='+self.setCompilers.getCompilerFlags().strip()+'\n') 168756c7f9fSJed Brown fd.write('cflags_dep='+self.compilers.dependenciesGenerationFlag.get('C','')+'\n') 169756c7f9fSJed Brown fd.write('ldflag_rpath='+self.setCompilers.CSharedLinkerFlag+'\n') 170262119f8SBarry Smith self.setCompilers.popLanguage() 171262119f8SBarry Smith if hasattr(self.compilers, 'C++'): 172262119f8SBarry Smith self.setCompilers.pushLanguage('C++') 173262119f8SBarry Smith fd.write('cxxcompiler='+self.setCompilers.getCompiler()+'\n') 174756c7f9fSJed Brown fd.write('cxxflags_extra='+self.setCompilers.getCompilerFlags().strip()+'\n') 175262119f8SBarry Smith self.setCompilers.popLanguage() 176262119f8SBarry Smith if hasattr(self.compilers, 'FC'): 177262119f8SBarry Smith self.setCompilers.pushLanguage('FC') 178262119f8SBarry Smith fd.write('fcompiler='+self.setCompilers.getCompiler()+'\n') 179756c7f9fSJed Brown fd.write('fflags_extra='+self.setCompilers.getCompilerFlags().strip()+'\n') 180262119f8SBarry Smith self.setCompilers.popLanguage() 181262119f8SBarry Smith 182262119f8SBarry Smith fd.write('\n') 183262119f8SBarry Smith fd.write('Name: PETSc\n') 184262119f8SBarry Smith fd.write('Description: Library to solve ODEs and algebraic equations\n') 185351d3a41SMatthew G Knepley fd.write('Version: %s\n' % self.petscdir.version) 1865e3311eeSJed Brown fd.write('Cflags: ' + ' '.join([self.setCompilers.CPPFLAGS] + cflags_inc) + '\n') 18737371b91SJed Brown fd.write('Libs: '+self.libraries.toStringNoDupes(['-L${libdir}', self.petsclib], with_rpath=False)+'\n') 1888ebf8858SJed Brown # Remove RPATH flags from library list. User can add them using 1898ebf8858SJed Brown # pkg-config --variable=ldflag_rpath and pkg-config --libs-only-L 190de8f682fSSatish 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') 191473a3ab2SBarry Smith 192262119f8SBarry Smith fd.close() 193262119f8SBarry Smith return 194262119f8SBarry Smith 195351d3a41SMatthew G Knepley def DumpModule(self): 196351d3a41SMatthew G Knepley ''' Create a module file ''' 197af0996ceSBarry Smith if not os.path.exists(os.path.join(self.petscdir.dir,self.arch.arch,'lib','petsc','conf','modules')): 198af0996ceSBarry Smith os.makedirs(os.path.join(self.petscdir.dir,self.arch.arch,'lib','petsc','conf','modules')) 199af0996ceSBarry Smith if not os.path.exists(os.path.join(self.petscdir.dir,self.arch.arch,'lib','petsc','conf','modules','petsc')): 200af0996ceSBarry Smith os.makedirs(os.path.join(self.petscdir.dir,self.arch.arch,'lib','petsc','conf','modules','petsc')) 201351d3a41SMatthew G Knepley if self.framework.argDB['prefix']: 2025bb5b263SMatthew G. Knepley installdir = self.installdir.dir 20355d606a3SSatish Balay installarch = '' 20455d606a3SSatish Balay installpath = os.path.join(installdir,'bin') 205351d3a41SMatthew G Knepley else: 206351d3a41SMatthew G Knepley installdir = self.petscdir.dir 20755d606a3SSatish Balay installarch = self.arch.arch 20855d606a3SSatish Balay installpath = os.path.join(installdir,installarch,'bin')+':'+os.path.join(installdir,'bin') 209af0996ceSBarry Smith fd = open(os.path.join(self.petscdir.dir,self.arch.arch,'lib','petsc','conf','modules','petsc',self.petscdir.version),'w') 210351d3a41SMatthew G Knepley fd.write('''\ 211351d3a41SMatthew G Knepley#%%Module 212351d3a41SMatthew G Knepley 213351d3a41SMatthew G Knepleyproc ModulesHelp { } { 214351d3a41SMatthew G Knepley puts stderr "This module sets the path and environment variables for petsc-%s" 215*a8d69d7bSBarry Smith puts stderr " see https://www.mcs.anl.gov/petsc/ for more information " 216351d3a41SMatthew G Knepley puts stderr "" 217351d3a41SMatthew G Knepley} 218351d3a41SMatthew G Knepleymodule-whatis "PETSc - Portable, Extensible Toolkit for Scientific Computation" 219351d3a41SMatthew G Knepley 220dd486775SJed Brownset petsc_dir "%s" 221dd486775SJed Brownset petsc_arch "%s" 222351d3a41SMatthew G Knepley 223dd486775SJed Brownsetenv PETSC_ARCH "$petsc_arch" 224dd486775SJed Brownsetenv PETSC_DIR "$petsc_dir" 225dd486775SJed Brownprepend-path PATH "%s" 22655d606a3SSatish Balay''' % (self.petscdir.version, installdir, installarch, installpath)) 227351d3a41SMatthew G Knepley fd.close() 228351d3a41SMatthew G Knepley return 229351d3a41SMatthew G Knepley 230f8833479SBarry Smith def Dump(self): 231f8833479SBarry Smith ''' Actually put the values into the configuration files ''' 232f8833479SBarry Smith # eventually everything between -- should be gone 23317f368bcSBarry Smith if self.mpi.usingMPIUni: 23417f368bcSBarry Smith # 23517f368bcSBarry Smith # Remove any MPI/MPICH include files that may have been put here by previous runs of ./configure 2367908f030SMatthew 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) 23717f368bcSBarry Smith 2385f27b2e0SBarry Smith self.setCompilers.pushLanguage('C') 2395f27b2e0SBarry Smith compiler = self.setCompilers.getCompiler() 240c9872b61SBarry Smith if compiler.endswith('mpicc') or compiler.endswith('mpiicc'): 2415f27b2e0SBarry Smith try: 2425f27b2e0SBarry Smith output = self.executeShellCommand(compiler + ' -show', log = self.log)[0] 2435f27b2e0SBarry Smith compiler = output.split(' ')[0] 2445f27b2e0SBarry Smith self.addDefine('MPICC_SHOW','"'+output.strip().replace('\n','\\\\n')+'"') 2455f27b2e0SBarry Smith except: 246c9872b61SBarry Smith self.addDefine('MPICC_SHOW','"Unavailable"') 247c9872b61SBarry Smith else: 248c9872b61SBarry Smith self.addDefine('MPICC_SHOW','"Unavailable"') 2495f27b2e0SBarry Smith self.setCompilers.popLanguage() 250f8833479SBarry Smith#----------------------------------------------------------------------------------------------------- 251f8833479SBarry Smith 252f8833479SBarry Smith # Sometimes we need C compiler, even if built with C++ 253f8833479SBarry Smith self.setCompilers.pushLanguage('C') 254f8833479SBarry Smith self.addMakeMacro('CC_FLAGS',self.setCompilers.getCompilerFlags()) 255f8833479SBarry Smith self.setCompilers.popLanguage() 256f8833479SBarry Smith 25734f774f6SJed Brown # And sometimes we need a C++ compiler even when PETSc is built with C 25834f774f6SJed Brown if hasattr(self.compilers, 'CXX'): 25934f774f6SJed Brown self.setCompilers.pushLanguage('Cxx') 26029921a8fSScott Kruger self.addDefine('HAVE_CXX','1') 26134f774f6SJed Brown self.addMakeMacro('CXX_FLAGS',self.setCompilers.getCompilerFlags()) 2622f4326f3SSatish Balay cxx_linker = self.setCompilers.getLinker() 2632f4326f3SSatish Balay self.addMakeMacro('CXX_LINKER',cxx_linker) 2642f4326f3SSatish Balay self.addMakeMacro('CXX_LINKER_FLAGS',self.setCompilers.getLinkerFlags()) 26534f774f6SJed Brown self.setCompilers.popLanguage() 26634f774f6SJed Brown 267f8833479SBarry Smith # C preprocessor values 2681315f054SBarry Smith self.addMakeMacro('CPP_FLAGS',self.setCompilers.CPPFLAGS) 269f8833479SBarry Smith 270f8833479SBarry Smith # compiler values 271f8833479SBarry Smith self.setCompilers.pushLanguage(self.languages.clanguage) 272f8833479SBarry Smith self.addMakeMacro('PCC',self.setCompilers.getCompiler()) 273f8833479SBarry Smith self.addMakeMacro('PCC_FLAGS',self.setCompilers.getCompilerFlags()) 274f8833479SBarry Smith self.setCompilers.popLanguage() 275f8833479SBarry Smith # .o or .obj 276f8833479SBarry Smith self.addMakeMacro('CC_SUFFIX','o') 277f8833479SBarry Smith 278f8833479SBarry Smith # executable linker values 279f8833479SBarry Smith self.setCompilers.pushLanguage(self.languages.clanguage) 280f8833479SBarry Smith pcc_linker = self.setCompilers.getLinker() 281f8833479SBarry Smith self.addMakeMacro('PCC_LINKER',pcc_linker) 282c84a332bSSatish Balay self.addMakeMacro('PCC_LINKER_FLAGS',self.setCompilers.getLinkerFlags()) 283f8833479SBarry Smith self.setCompilers.popLanguage() 284f8833479SBarry Smith # '' for Unix, .exe for Windows 285f8833479SBarry Smith self.addMakeMacro('CC_LINKER_SUFFIX','') 286f8833479SBarry Smith 287f8833479SBarry Smith if hasattr(self.compilers, 'FC'): 288cb297985SSatish Balay if self.framework.argDB['with-fortran-bindings']: 289cb297985SSatish Balay self.addDefine('HAVE_FORTRAN','1') 290f8833479SBarry Smith self.setCompilers.pushLanguage('FC') 291f8833479SBarry Smith # need FPPFLAGS in config/setCompilers 292f8833479SBarry Smith self.addMakeMacro('FPP_FLAGS',self.setCompilers.CPPFLAGS) 293f8833479SBarry Smith 294f8833479SBarry Smith # compiler values 295f8833479SBarry Smith self.addMakeMacro('FC_FLAGS',self.setCompilers.getCompilerFlags()) 296f8833479SBarry Smith self.setCompilers.popLanguage() 297f8833479SBarry Smith # .o or .obj 298f8833479SBarry Smith self.addMakeMacro('FC_SUFFIX','o') 299f8833479SBarry Smith 300f8833479SBarry Smith # executable linker values 301f8833479SBarry Smith self.setCompilers.pushLanguage('FC') 302f8833479SBarry Smith # Cannot have NAG f90 as the linker - so use pcc_linker as fc_linker 303f8833479SBarry Smith fc_linker = self.setCompilers.getLinker() 3047fca349cSMatthew G. Knepley if config.setCompilers.Configure.isNAG(fc_linker, self.log): 305f8833479SBarry Smith self.addMakeMacro('FC_LINKER',pcc_linker) 306f8833479SBarry Smith else: 307f8833479SBarry Smith self.addMakeMacro('FC_LINKER',fc_linker) 3086d53d35eSSatish Balay self.addMakeMacro('FC_LINKER_FLAGS',self.setCompilers.getLinkerFlags()) 3093feacd00SBarry Smith # apple requires this shared library linker flag on SOME versions of the os 3103feacd00SBarry Smith if self.setCompilers.getLinkerFlags().find('-Wl,-commons,use_dylibs') > -1: 3113feacd00SBarry Smith self.addMakeMacro('DARWIN_COMMONS_USE_DYLIBS',' -Wl,-commons,use_dylibs ') 312bb82cf9cSSatish Balay self.setCompilers.popLanguage() 3135d631499SMatthew Knepley 3145d631499SMatthew Knepley # F90 Modules 3155d631499SMatthew Knepley if self.setCompilers.fortranModuleIncludeFlag: 3165d631499SMatthew Knepley self.addMakeMacro('FC_MODULE_FLAG', self.setCompilers.fortranModuleIncludeFlag) 3176ddd6694SSatish Balay else: # for non-f90 compilers like g77 3186ddd6694SSatish Balay self.addMakeMacro('FC_MODULE_FLAG', '-I') 319a324c51cSMatthew G Knepley if self.setCompilers.fortranModuleIncludeFlag: 320a324c51cSMatthew G Knepley self.addMakeMacro('FC_MODULE_OUTPUT_FLAG', self.setCompilers.fortranModuleOutputFlag) 321f8833479SBarry Smith else: 322f8833479SBarry Smith self.addMakeMacro('FC','') 323f8833479SBarry Smith 32446a3958fSBarry Smith if hasattr(self.compilers, 'CUDAC'): 3257ff2890cSSatish Balay self.setCompilers.pushLanguage('CUDA') 326d93a25ecSSatish Balay self.addMakeMacro('CUDAC_FLAGS',self.setCompilers.getCompilerFlags()) 3277ff2890cSSatish Balay self.setCompilers.popLanguage() 3287ff2890cSSatish Balay 329f8833479SBarry Smith # shared library linker values 330f8833479SBarry Smith self.setCompilers.pushLanguage(self.languages.clanguage) 331f8833479SBarry Smith # need to fix BuildSystem to collect these separately 332f8833479SBarry Smith self.addMakeMacro('SL_LINKER',self.setCompilers.getLinker()) 33370db8aa6SSatish Balay self.addMakeMacro('SL_LINKER_FLAGS','${PCC_LINKER_FLAGS}') 334f8833479SBarry Smith self.setCompilers.popLanguage() 335f8833479SBarry Smith # One of 'a', 'so', 'lib', 'dll', 'dylib' (perhaps others also?) depending on the library generator and architecture 336f8833479SBarry Smith # Note: . is not included in this macro, consistent with AR_LIB_SUFFIX 337f8833479SBarry Smith if self.setCompilers.sharedLibraryExt == self.setCompilers.AR_LIB_SUFFIX: 338f8833479SBarry Smith self.addMakeMacro('SL_LINKER_SUFFIX', '') 33946bc77b6SBarry Smith self.addDefine('SLSUFFIX','""') 340f8833479SBarry Smith else: 341f8833479SBarry Smith self.addMakeMacro('SL_LINKER_SUFFIX', self.setCompilers.sharedLibraryExt) 34246bc77b6SBarry Smith self.addDefine('SLSUFFIX','"'+self.setCompilers.sharedLibraryExt+'"') 343bb82cf9cSSatish Balay 34423e93537SBarry Smith self.addMakeMacro('SL_LINKER_LIBS','${PETSC_EXTERNAL_LIB_BASIC}') 345bb82cf9cSSatish Balay 346f8833479SBarry Smith#----------------------------------------------------------------------------------------------------- 347f8833479SBarry Smith 348f8833479SBarry Smith # CONLY or CPP. We should change the PETSc makefiles to do this better 349f8833479SBarry Smith if self.languages.clanguage == 'C': lang = 'CONLY' 350f8833479SBarry Smith else: lang = 'CXXONLY' 351f8833479SBarry Smith self.addMakeMacro('PETSC_LANGUAGE',lang) 352f8833479SBarry Smith 353f8833479SBarry Smith # real or complex 354f8833479SBarry Smith self.addMakeMacro('PETSC_SCALAR',self.scalartypes.scalartype) 355f8833479SBarry Smith # double or float 356f8833479SBarry Smith self.addMakeMacro('PETSC_PRECISION',self.scalartypes.precision) 357f8833479SBarry Smith 358f8833479SBarry Smith if self.framework.argDB['with-batch']: 359f8833479SBarry Smith self.addMakeMacro('PETSC_WITH_BATCH','1') 360f8833479SBarry Smith 361f8833479SBarry Smith # Test for compiler-specific macros that need to be defined. 3627fca349cSMatthew G. Knepley if self.setCompilers.isCrayVector('CC', self.log): 363b409243cSBarry Smith self.addDefine('HAVE_CRAY_VECTOR','1') 364f8833479SBarry Smith 365f8833479SBarry Smith#----------------------------------------------------------------------------------------------------- 366df1a78b3SMatthew G Knepley if self.functions.haveFunction('gethostbyname') and self.functions.haveFunction('socket') and self.headers.haveHeader('netinet/in.h'): 367f8833479SBarry Smith self.addDefine('USE_SOCKET_VIEWER','1') 36880e3883bSBarry Smith if self.checkCompile('#include <sys/socket.h>','setsockopt(0,SOL_SOCKET,SO_REUSEADDR,0,0)'): 36980e3883bSBarry Smith self.addDefine('HAVE_SO_REUSEADDR','1') 370f8833479SBarry Smith 371f8833479SBarry Smith#----------------------------------------------------------------------------------------------------- 372a6cc6bb1SBarry Smith # print include and lib for makefiles 373f8833479SBarry Smith self.framework.packages.reverse() 3745a21677cSJed Brown petscincludes = [os.path.join(self.petscdir.dir,'include'),os.path.join(self.petscdir.dir,self.arch.arch,'include')] 3755a21677cSJed Brown petscincludes_install = [os.path.join(self.installdir.dir, 'include')] if self.framework.argDB['prefix'] else petscincludes 3765a21677cSJed Brown includes = [] 377de8f682fSSatish Balay self.packagelibs = [] 378f8833479SBarry Smith for i in self.framework.packages: 379898a086dSBarry Smith if i.useddirectly: 380eeb16384SBarry Smith self.addDefine('HAVE_'+i.PACKAGE.replace('-','_'), 1) # ONLY list package if it is used directly by PETSc (and not only by another package) 381f8833479SBarry Smith if not isinstance(i.lib, list): 382f8833479SBarry Smith i.lib = [i.lib] 383de8f682fSSatish Balay if i.linkedbypetsc: self.packagelibs.extend(i.lib) 384eeb16384SBarry Smith self.addMakeMacro(i.PACKAGE.replace('-','_')+'_LIB', self.libraries.toStringNoDupes(i.lib)) 385f8833479SBarry Smith if hasattr(i,'include'): 386f8833479SBarry Smith if not isinstance(i.include,list): 387f8833479SBarry Smith i.include = [i.include] 388ac9e4c42SSatish Balay includes.extend(i.include) 389eeb16384SBarry Smith self.addMakeMacro(i.PACKAGE.replace('-','_')+'_INCLUDE',self.headers.toStringNoDupes(i.include)) 3902df986feSBarry Smith if self.framework.argDB['with-single-library']: 391e282ce78SJed Brown self.petsclib = '-lpetsc' 39291bb3077SSatish Balay else: 393e282ce78SJed Brown self.petsclib = '-lpetscts -lpetscsnes -lpetscksp -lpetscdm -lpetscmat -lpetscvec -lpetscsys' 394de8f682fSSatish Balay self.complibs = self.compilers.flibs+self.compilers.cxxlibs+self.compilers.LIBS.split() 3955a21677cSJed Brown self.PETSC_WITH_EXTERNAL_LIB = self.libraries.toStringNoDupes(['-L${PETSC_DIR}/${PETSC_ARCH}/lib', self.petsclib]+self.packagelibs+self.complibs) 396de8f682fSSatish Balay self.PETSC_EXTERNAL_LIB_BASIC = self.libraries.toStringNoDupes(self.packagelibs+self.complibs) 397de8f682fSSatish Balay 398de8f682fSSatish Balay self.addMakeMacro('PETSC_EXTERNAL_LIB_BASIC',self.PETSC_EXTERNAL_LIB_BASIC) 3995a21677cSJed Brown allincludes = petscincludes + includes 4005a21677cSJed Brown allincludes_install = petscincludes_install + includes 4015a21677cSJed Brown self.PETSC_CC_INCLUDES = self.headers.toStringNoDupes(allincludes) 4025a21677cSJed Brown self.PETSC_CC_INCLUDES_INSTALL = self.headers.toStringNoDupes(allincludes_install) 4035a21677cSJed Brown self.addMakeMacro('PETSC_CC_INCLUDES',self.PETSC_CC_INCLUDES) 4045a21677cSJed Brown self.addMakeMacro('PETSC_CC_INCLUDES_INSTALL', self.PETSC_CC_INCLUDES_INSTALL) 405cbd5cc15SBarry Smith if hasattr(self.compilers, 'FC'): 4065a21677cSJed Brown def modinc(includes): 4075a21677cSJed Brown return includes if self.compilers.fortranIsF90 else [] 4085a21677cSJed Brown self.addMakeMacro('PETSC_FC_INCLUDES',self.headers.toStringNoDupes(allincludes,modinc(allincludes))) 4095a21677cSJed Brown self.addMakeMacro('PETSC_FC_INCLUDES_INSTALL',self.headers.toStringNoDupes(allincludes_install,modinc(allincludes_install))) 410f8833479SBarry Smith 4115bb5b263SMatthew G. Knepley self.addDefine('LIB_DIR','"'+os.path.join(self.installdir.dir,'lib')+'"') 412f8833479SBarry Smith 4130f3b21c2SBarry Smith if self.framework.argDB['with-single-library']: 4140f3b21c2SBarry Smith # overrides the values set in conf/variables 4150f3b21c2SBarry Smith self.addMakeMacro('LIBNAME','${INSTALL_LIB_DIR}/libpetsc.${AR_LIB_SUFFIX}') 41657cb31baSSatish Balay self.addMakeMacro('SHLIBS','libpetsc') 417bccf1c12SBarry Smith self.addMakeMacro('PETSC_LIB_BASIC','-lpetsc') 418797063a9SSatish Balay self.addMakeMacro('PETSC_KSP_LIB_BASIC','-lpetsc') 419797063a9SSatish Balay self.addMakeMacro('PETSC_TS_LIB_BASIC','-lpetsc') 420b0a7d7e7SSatish Balay self.addMakeMacro('PETSC_TAO_LIB_BASIC','-lpetsc') 421de8f682fSSatish Balay self.addMakeMacro('PETSC_WITH_EXTERNAL_LIB',self.PETSC_WITH_EXTERNAL_LIB) 422bb84e0fdSBarry Smith self.addDefine('USE_SINGLE_LIBRARY', '1') 4232df986feSBarry Smith if self.sharedlibraries.useShared: 424ea820d49SSatish Balay self.addMakeMacro('PETSC_SYS_LIB','${C_SH_LIB_PATH} ${PETSC_WITH_EXTERNAL_LIB}') 425ea820d49SSatish Balay self.addMakeMacro('PETSC_VEC_LIB','${C_SH_LIB_PATH} ${PETSC_WITH_EXTERNAL_LIB}') 426ea820d49SSatish Balay self.addMakeMacro('PETSC_MAT_LIB','${C_SH_LIB_PATH} ${PETSC_WITH_EXTERNAL_LIB}') 427ea820d49SSatish Balay self.addMakeMacro('PETSC_DM_LIB','${C_SH_LIB_PATH} ${PETSC_WITH_EXTERNAL_LIB}') 428ea820d49SSatish Balay self.addMakeMacro('PETSC_KSP_LIB','${C_SH_LIB_PATH} ${PETSC_WITH_EXTERNAL_LIB}') 429ea820d49SSatish Balay self.addMakeMacro('PETSC_SNES_LIB','${C_SH_LIB_PATH} ${PETSC_WITH_EXTERNAL_LIB}') 430ea820d49SSatish Balay self.addMakeMacro('PETSC_TS_LIB','${C_SH_LIB_PATH} ${PETSC_WITH_EXTERNAL_LIB}') 431b0a7d7e7SSatish Balay self.addMakeMacro('PETSC_TAO_LIB','${C_SH_LIB_PATH} ${PETSC_WITH_EXTERNAL_LIB}') 432fdb87e33SJed Brown self.addMakeMacro('PETSC_CHARACTERISTIC_LIB','${C_SH_LIB_PATH} ${PETSC_WITH_EXTERNAL_LIB}') 433ea820d49SSatish Balay self.addMakeMacro('PETSC_LIB','${C_SH_LIB_PATH} ${PETSC_WITH_EXTERNAL_LIB}') 434ea820d49SSatish Balay self.addMakeMacro('PETSC_CONTRIB','${C_SH_LIB_PATH} ${PETSC_WITH_EXTERNAL_LIB}') 4352df986feSBarry Smith else: 436ea820d49SSatish Balay self.addMakeMacro('PETSC_SYS_LIB','${PETSC_WITH_EXTERNAL_LIB}') 437ea820d49SSatish Balay self.addMakeMacro('PETSC_VEC_LIB','${PETSC_WITH_EXTERNAL_LIB}') 438ea820d49SSatish Balay self.addMakeMacro('PETSC_MAT_LIB','${PETSC_WITH_EXTERNAL_LIB}') 439ea820d49SSatish Balay self.addMakeMacro('PETSC_DM_LIB','${PETSC_WITH_EXTERNAL_LIB}') 440ea820d49SSatish Balay self.addMakeMacro('PETSC_KSP_LIB','${PETSC_WITH_EXTERNAL_LIB}') 441ea820d49SSatish Balay self.addMakeMacro('PETSC_SNES_LIB','${PETSC_WITH_EXTERNAL_LIB}') 442ea820d49SSatish Balay self.addMakeMacro('PETSC_TS_LIB','${PETSC_WITH_EXTERNAL_LIB}') 443b0a7d7e7SSatish Balay self.addMakeMacro('PETSC_TAO_LIB','${PETSC_WITH_EXTERNAL_LIB}') 444fdb87e33SJed Brown self.addMakeMacro('PETSC_CHARACTERISTIC_LIB','${PETSC_WITH_EXTERNAL_LIB}') 445ea820d49SSatish Balay self.addMakeMacro('PETSC_LIB','${PETSC_WITH_EXTERNAL_LIB}') 446ea820d49SSatish Balay self.addMakeMacro('PETSC_CONTRIB','${PETSC_WITH_EXTERNAL_LIB}') 4470f3b21c2SBarry Smith 448f8833479SBarry Smith if not os.path.exists(os.path.join(self.petscdir.dir,self.arch.arch,'lib')): 449f8833479SBarry Smith os.makedirs(os.path.join(self.petscdir.dir,self.arch.arch,'lib')) 450f8833479SBarry Smith 45113f9d092SSatish Balay# add a makefile endtry for display 45213f9d092SSatish Balay if self.framework.argDB['with-display']: 45313f9d092SSatish Balay self.addMakeMacro('DISPLAY',self.framework.argDB['with-display']) 45413f9d092SSatish Balay 455f8833479SBarry Smith # add a makefile entry for configure options 456f8833479SBarry Smith self.addMakeMacro('CONFIGURE_OPTIONS', self.framework.getOptionsString(['configModules', 'optionsModule']).replace('\"','\\"')) 457f8833479SBarry Smith return 458f8833479SBarry Smith 459f8833479SBarry Smith def dumpConfigInfo(self): 460f8833479SBarry Smith import time 461c6ef1b5bSJed Brown fd = open(os.path.join(self.arch.arch,'include','petscconfiginfo.h'),'w') 462f8833479SBarry Smith fd.write('static const char *petscconfigureoptions = "'+self.framework.getOptionsString(['configModules', 'optionsModule']).replace('\"','\\"')+'";\n') 463f8833479SBarry Smith fd.close() 464f8833479SBarry Smith return 465f8833479SBarry Smith 4662a4161d9SMatthew G Knepley def dumpMachineInfo(self): 4672a4161d9SMatthew G Knepley import platform 468a970bd74SBernhard M. Wiedemann import datetime 4692a4161d9SMatthew G Knepley import time 47040373944SSatish Balay import script 471ca77dbeeSGeoffrey Irving def escape(s): 472ca77dbeeSGeoffrey Irving return s.replace('"',r'\"').replace(r'\ ',r'\\ ') 473c6ef1b5bSJed Brown fd = open(os.path.join(self.arch.arch,'include','petscmachineinfo.h'),'w') 4742a4161d9SMatthew G Knepley fd.write('static const char *petscmachineinfo = \"\\n\"\n') 4752a4161d9SMatthew G Knepley fd.write('\"-----------------------------------------\\n\"\n') 476a970bd74SBernhard M. Wiedemann buildhost = platform.node() 477a970bd74SBernhard M. Wiedemann if os.environ.get('SOURCE_DATE_EPOCH'): 478a970bd74SBernhard M. Wiedemann buildhost = "reproducible" 479a970bd74SBernhard M. Wiedemann buildtime = datetime.datetime.utcfromtimestamp(int(os.environ.get('SOURCE_DATE_EPOCH', time.time()))) 480a970bd74SBernhard M. Wiedemann fd.write('\"Libraries compiled on %s on %s \\n\"\n' % (buildtime, buildhost)) 48160acdfe7SSatish Balay fd.write('\"Machine characteristics: %s\\n\"\n' % (platform.platform())) 4825188cb68SSatish Balay fd.write('\"Using PETSc directory: %s\\n\"\n' % (escape(self.installdir.petscDir))) 4835188cb68SSatish Balay fd.write('\"Using PETSc arch: %s\\n\"\n' % (escape(self.installdir.petscArch))) 484cdec380aSBarry Smith fd.write('\"-----------------------------------------\\n\";\n') 4852a4161d9SMatthew G Knepley fd.write('static const char *petsccompilerinfo = \"\\n\"\n') 4862a4161d9SMatthew G Knepley self.setCompilers.pushLanguage(self.languages.clanguage) 4875f27b2e0SBarry Smith fd.write('\"Using C compiler: %s %s \\n\"\n' % (escape(self.setCompilers.getCompiler()), escape(self.setCompilers.getCompilerFlags()))) 4882a4161d9SMatthew G Knepley self.setCompilers.popLanguage() 4898782282cSMatthew G Knepley if hasattr(self.compilers, 'FC'): 4902a4161d9SMatthew G Knepley self.setCompilers.pushLanguage('FC') 4915f27b2e0SBarry Smith fd.write('\"Using Fortran compiler: %s %s %s\\n\"\n' % (escape(self.setCompilers.getCompiler()), escape(self.setCompilers.getCompilerFlags()), escape(self.setCompilers.CPPFLAGS))) 4922a4161d9SMatthew G Knepley self.setCompilers.popLanguage() 493cdec380aSBarry Smith fd.write('\"-----------------------------------------\\n\";\n') 4942a4161d9SMatthew G Knepley fd.write('static const char *petsccompilerflagsinfo = \"\\n\"\n') 4955a21677cSJed Brown fd.write('\"Using include paths: %s\\n\"\n' % (escape(self.PETSC_CC_INCLUDES_INSTALL.replace('${PETSC_DIR}', self.installdir.petscDir)))) 496cdec380aSBarry Smith fd.write('\"-----------------------------------------\\n\";\n') 4972a4161d9SMatthew G Knepley fd.write('static const char *petsclinkerinfo = \"\\n\"\n') 4982a4161d9SMatthew G Knepley self.setCompilers.pushLanguage(self.languages.clanguage) 499ca77dbeeSGeoffrey Irving fd.write('\"Using C linker: %s\\n\"\n' % (escape(self.setCompilers.getLinker()))) 5002a4161d9SMatthew G Knepley self.setCompilers.popLanguage() 5018782282cSMatthew G Knepley if hasattr(self.compilers, 'FC'): 5022a4161d9SMatthew G Knepley self.setCompilers.pushLanguage('FC') 503ca77dbeeSGeoffrey Irving fd.write('\"Using Fortran linker: %s\\n\"\n' % (escape(self.setCompilers.getLinker()))) 5042a4161d9SMatthew G Knepley self.setCompilers.popLanguage() 5055188cb68SSatish 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))) 506cdec380aSBarry Smith fd.write('\"-----------------------------------------\\n\";\n') 5072a4161d9SMatthew G Knepley fd.close() 5082a4161d9SMatthew G Knepley return 509b2843cf1SBarry Smith 510511a6afcSJed Brown def dumpCMakeConfig(self): 511511a6afcSJed Brown ''' 512724dfae7SSatish Balay Writes configuration-specific values to ${PETSC_ARCH}/lib/petsc/conf/PETScBuildInternal.cmake. 513511a6afcSJed Brown This file is private to PETSc and should not be included by third parties 514511a6afcSJed Brown (a suitable file can be produced later by CMake, but this is not it). 515511a6afcSJed Brown ''' 516511a6afcSJed Brown def cmakeset(fd,key,val=True): 517511a6afcSJed Brown if val == True: val = 'YES' 518511a6afcSJed Brown if val == False: val = 'NO' 519511a6afcSJed Brown fd.write('set (' + key + ' ' + val + ')\n') 520511a6afcSJed Brown def ensurelist(a): 521826d9344SJed Brown if isinstance(a,list): 522826d9344SJed Brown return a 523826d9344SJed Brown else: 524826d9344SJed Brown return [a] 525511a6afcSJed Brown def libpath(lib): 526511a6afcSJed Brown 'Returns a search path if that is what this item provides, else "" which will be cleaned out later' 5271b1c0b30SJed Brown if not isinstance(lib,str): return '' 528511a6afcSJed Brown if lib.startswith('-L'): return lib[2:] 529511a6afcSJed Brown if lib.startswith('-R'): return lib[2:] 530511a6afcSJed Brown if lib.startswith('-Wl,-rpath,'): 531511a6afcSJed Brown # This case occurs when an external package needs a specific system library that is normally provided by the compiler. 532511a6afcSJed Brown # In other words, the -L path is builtin to the wrapper or compiler, here we provide it so that CMake can locate the 533511a6afcSJed Brown # corresponding library. 534511a6afcSJed Brown return lib[len('-Wl,-rpath,'):] 535511a6afcSJed Brown if lib.startswith('-'): return '' 536511a6afcSJed Brown return os.path.dirname(lib) 537511a6afcSJed Brown def cleanlib(lib): 538511a6afcSJed Brown 'Returns a library name if that is what this item provides, else "" which will be cleaned out later' 53942e8629dSMatthew G Knepley if not isinstance(lib,str): return '' 540511a6afcSJed Brown if lib.startswith('-l'): return lib[2:] 541511a6afcSJed Brown if lib.startswith('-Wl') or lib.startswith('-L'): return '' 542511a6afcSJed Brown lib = os.path.splitext(os.path.basename(lib))[0] 543511a6afcSJed Brown if lib.startswith('lib'): return lib[3:] 544511a6afcSJed Brown return lib 545511a6afcSJed Brown def nub(lst): 54606e8c1ddSJed Brown 'Return a list containing the first occurrence of each unique element' 547511a6afcSJed Brown unique = [] 548511a6afcSJed Brown for elem in lst: 549511a6afcSJed Brown if elem not in unique and elem != '': 550511a6afcSJed Brown unique.append(elem) 551511a6afcSJed Brown return unique 55206e8c1ddSJed Brown def nublast(lst): 55306e8c1ddSJed Brown 'Return a list containing the last occurrence of each unique entry in a list' 55450937898SJed Brown return reversed(nub(reversed(lst))) 555511a6afcSJed Brown def cmakeexpand(varname): 556511a6afcSJed Brown return r'"${' + varname + r'}"' 557582751aaSJed Brown def uniqextend(lst,new): 558511a6afcSJed Brown for x in ensurelist(new): 559582751aaSJed Brown if x not in lst: 560582751aaSJed Brown lst.append(x) 561511a6afcSJed Brown def notstandardinclude(path): 562040257f2SJed Brown return path not in '/usr/include'.split() # /usr/local/include is not automatically included on FreeBSD 563511a6afcSJed Brown def writeMacroDefinitions(fd): 564511a6afcSJed Brown if self.mpi.usingMPIUni: 565511a6afcSJed Brown cmakeset(fd,'PETSC_HAVE_MPIUNI') 566511a6afcSJed Brown for pkg in self.framework.packages: 567511a6afcSJed Brown if pkg.useddirectly: 568eeb16384SBarry Smith cmakeset(fd,'PETSC_HAVE_' + pkg.PACKAGE.replace('-','_')) 569a23e9343SMatthew G Knepley for pair in pkg.defines.items(): 570440af75fSJed Brown if pair[0].startswith('HAVE_') and pair[1]: 571a23e9343SMatthew G Knepley cmakeset(fd, self.framework.getFullDefineName(pkg, pair[0]), pair[1]) 572511a6afcSJed Brown for name,val in self.functions.defines.items(): 573511a6afcSJed Brown cmakeset(fd,'PETSC_'+name,val) 574511a6afcSJed Brown for dct in [self.defines, self.libraryoptions.defines]: 575511a6afcSJed Brown for k,v in dct.items(): 576511a6afcSJed Brown if k.startswith('USE_'): 577511a6afcSJed Brown cmakeset(fd,'PETSC_' + k, v) 578511a6afcSJed Brown cmakeset(fd,'PETSC_USE_COMPLEX', self.scalartypes.scalartype == 'complex') 579ce63c4c1SBarry Smith cmakeset(fd,'PETSC_USE_REAL_' + self.scalartypes.precision.upper()) 580511a6afcSJed Brown cmakeset(fd,'PETSC_CLANGUAGE_'+self.languages.clanguage) 581511a6afcSJed Brown if hasattr(self.compilers, 'FC'): 582511a6afcSJed Brown cmakeset(fd,'PETSC_HAVE_FORTRAN') 583511a6afcSJed Brown if self.compilers.fortranIsF90: 584511a6afcSJed Brown cmakeset(fd,'PETSC_USING_F90') 585876d5c60SBarry Smith if self.compilers.fortranIsF2003: 586876d5c60SBarry Smith cmakeset(fd,'PETSC_USING_F2003') 58713c0a95cSJed Brown if hasattr(self.compilers, 'CXX'): 58813c0a95cSJed Brown cmakeset(fd,'PETSC_HAVE_CXX') 589511a6afcSJed Brown if self.sharedlibraries.useShared: 590511a6afcSJed Brown cmakeset(fd,'BUILD_SHARED_LIBS') 591511a6afcSJed Brown def writeBuildFlags(fd): 59206e8c1ddSJed Brown def extendby(lib): 59306e8c1ddSJed Brown libs = ensurelist(lib) 59406e8c1ddSJed Brown lib_paths.extend(map(libpath,libs)) 59506e8c1ddSJed Brown lib_libs.extend(map(cleanlib,libs)) 596511a6afcSJed Brown lib_paths = [] 597511a6afcSJed Brown lib_libs = [] 598511a6afcSJed Brown includes = [] 599511a6afcSJed Brown libvars = [] 600511a6afcSJed Brown for pkg in self.framework.packages: 6014d02c0d4SBarry Smith if pkg.linkedbypetsc: 60206e8c1ddSJed Brown extendby(pkg.lib) 603040257f2SJed Brown uniqextend(includes,pkg.include) 60406e8c1ddSJed Brown extendby(self.libraries.math) 60506e8c1ddSJed Brown extendby(self.libraries.rt) 60606e8c1ddSJed Brown extendby(self.compilers.flibs) 60706e8c1ddSJed Brown extendby(self.compilers.cxxlibs) 60806e8c1ddSJed Brown extendby(self.compilers.LIBS.split()) 60906e8c1ddSJed Brown for libname in nublast(lib_libs): 610511a6afcSJed Brown libvar = 'PETSC_' + libname.upper() + '_LIB' 6114c0032a9SSatish Balay addpath = '' 61206e8c1ddSJed Brown for lpath in nublast(lib_paths): 6134c0032a9SSatish Balay addpath += '"' + str(lpath) + '" ' 6144c0032a9SSatish Balay fd.write('find_library (' + libvar + ' ' + libname + ' HINTS ' + addpath + ')\n') 615511a6afcSJed Brown libvars.append(libvar) 616511a6afcSJed Brown fd.write('mark_as_advanced (' + ' '.join(libvars) + ')\n') 617511a6afcSJed Brown fd.write('set (PETSC_PACKAGE_LIBS ' + ' '.join(map(cmakeexpand,libvars)) + ')\n') 618bb3dd2f6SJed Brown includes = list(filter(notstandardinclude,includes)) 619040257f2SJed Brown fd.write('set (PETSC_PACKAGE_INCLUDES ' + ' '.join(map(lambda i: '"'+i+'"',includes)) + ')\n') 620724dfae7SSatish Balay fd = open(os.path.join(self.arch.arch,'lib','petsc','conf','PETScBuildInternal.cmake'), 'w') 621511a6afcSJed Brown writeMacroDefinitions(fd) 622511a6afcSJed Brown writeBuildFlags(fd) 623511a6afcSJed Brown fd.close() 624511a6afcSJed Brown return 625511a6afcSJed Brown 6268b0282a9SJed Brown def dumpCMakeLists(self): 6278b0282a9SJed Brown import sys 628994b4dadSSatish Balay if sys.version_info >= (2,4): 6298b0282a9SJed Brown import cmakegen 6308b0282a9SJed Brown try: 631a98e69d2SJed Brown cmakegen.main(self.petscdir.dir, log=self.framework.log) 6325b6bfdb9SJed Brown except (OSError) as e: 6338b0282a9SJed Brown self.framework.logPrint('Generating CMakeLists.txt failed:\n' + str(e)) 634aac20692SSatish Balay else: 635aac20692SSatish Balay self.framework.logPrint('Skipping cmakegen due to old python version: ' +str(sys.version_info) ) 6368b0282a9SJed Brown 6378b0282a9SJed Brown def cmakeBoot(self): 6388b0282a9SJed Brown import sys 639ae937f1dSJed Brown self.cmakeboot_success = False 640994b4dadSSatish Balay if sys.version_info >= (2,4) and hasattr(self.cmake,'cmake'): 6415a4feeedSSatish Balay oldRead = self.argDB.readonly 6425a4feeedSSatish Balay self.argDB.readonly = True 643356464bcSMatthew G Knepley try: 6448b0282a9SJed Brown import cmakeboot 645ae937f1dSJed Brown self.cmakeboot_success = cmakeboot.main(petscdir=self.petscdir.dir,petscarch=self.arch.arch,argDB=self.argDB,framework=self.framework,log=self.framework.log) 6465b6bfdb9SJed Brown except (OSError) as e: 6478b0282a9SJed Brown self.framework.logPrint('Booting CMake in PETSC_ARCH failed:\n' + str(e)) 6485b6bfdb9SJed Brown except (ImportError, KeyError) as e: 649356464bcSMatthew G Knepley self.framework.logPrint('Importing cmakeboot failed:\n' + str(e)) 6505a4feeedSSatish Balay self.argDB.readonly = oldRead 6519b12c9c7SJed Brown if self.cmakeboot_success: 6522f730bc2SKarl Rupp if hasattr(self.compilers, 'FC') and self.compilers.fortranIsF90 and not self.setCompilers.fortranModuleOutputFlag: 65391f9b906SSatish Balay self.framework.logPrint('CMake configured successfully, but could not be used by default because of missing fortranModuleOutputFlag\n') 6549b12c9c7SJed Brown else: 6559b12c9c7SJed Brown self.framework.logPrint('CMake configured successfully, using as default build\n') 656f7b66a64SJed Brown self.addMakeMacro('PETSC_BUILD_USING_CMAKE',1) 657aac20692SSatish Balay else: 6589b12c9c7SJed Brown self.framework.logPrint('CMake configuration was unsuccessful\n') 6599b12c9c7SJed Brown else: 660aac20692SSatish Balay self.framework.logPrint('Skipping cmakeboot due to old python version: ' +str(sys.version_info) ) 661356464bcSMatthew G Knepley return 6628b0282a9SJed Brown 663b2843cf1SBarry Smith def configurePrefetch(self): 664b2843cf1SBarry Smith '''Sees if there are any prefetch functions supported''' 6657fca349cSMatthew G. Knepley if config.setCompilers.Configure.isSolaris(self.log) or self.framework.argDB['with-ios'] or not self.framework.argDB['with-prefetch']: 66693f78423SSatish Balay self.addDefine('Prefetch(a,b,c)', ' ') 66793f78423SSatish Balay return 668ec284106SBarry Smith self.pushLanguage(self.languages.clanguage) 66910699583SJed Brown if self.checkLink('#include <xmmintrin.h>', 'void *v = 0;_mm_prefetch((const char*)v,_MM_HINT_NTA);\n'): 67050d8bf02SJed Brown # The Intel Intrinsics manual [1] specifies the prototype 67150d8bf02SJed Brown # 67250d8bf02SJed Brown # void _mm_prefetch(char const *a, int sel); 67350d8bf02SJed Brown # 67450d8bf02SJed Brown # but other vendors seem to insist on using subtly different 67550d8bf02SJed Brown # prototypes, including void* for the pointer, and an enum for 67650d8bf02SJed Brown # sel. These are both reasonable changes, but negatively impact 67750d8bf02SJed Brown # portability. 67850d8bf02SJed Brown # 679*a8d69d7bSBarry Smith # [1] https://software.intel.com/file/6373 68050d8bf02SJed Brown self.addDefine('HAVE_XMMINTRIN_H', 1) 68150d8bf02SJed Brown self.addDefine('Prefetch(a,b,c)', '_mm_prefetch((const char*)(a),(c))') 68250d8bf02SJed Brown self.addDefine('PREFETCH_HINT_NTA', '_MM_HINT_NTA') 68350d8bf02SJed Brown self.addDefine('PREFETCH_HINT_T0', '_MM_HINT_T0') 68450d8bf02SJed Brown self.addDefine('PREFETCH_HINT_T1', '_MM_HINT_T1') 68550d8bf02SJed Brown self.addDefine('PREFETCH_HINT_T2', '_MM_HINT_T2') 68650d8bf02SJed Brown elif self.checkLink('#include <xmmintrin.h>', 'void *v = 0;_mm_prefetch(v,_MM_HINT_NTA);\n'): 68750d8bf02SJed Brown self.addDefine('HAVE_XMMINTRIN_H', 1) 68850d8bf02SJed Brown self.addDefine('Prefetch(a,b,c)', '_mm_prefetch((const void*)(a),(c))') 68950d8bf02SJed Brown self.addDefine('PREFETCH_HINT_NTA', '_MM_HINT_NTA') 69050d8bf02SJed Brown self.addDefine('PREFETCH_HINT_T0', '_MM_HINT_T0') 69150d8bf02SJed Brown self.addDefine('PREFETCH_HINT_T1', '_MM_HINT_T1') 69250d8bf02SJed Brown self.addDefine('PREFETCH_HINT_T2', '_MM_HINT_T2') 69310699583SJed Brown elif self.checkLink('', 'void *v = 0;__builtin_prefetch(v,0,0);\n'): 69410699583SJed Brown # From GCC docs: void __builtin_prefetch(const void *addr,int rw,int locality) 69510699583SJed Brown # 69610699583SJed Brown # The value of rw is a compile-time constant one or zero; one 69710699583SJed Brown # means that the prefetch is preparing for a write to the memory 69810699583SJed Brown # address and zero, the default, means that the prefetch is 69910699583SJed Brown # preparing for a read. The value locality must be a compile-time 70010699583SJed Brown # constant integer between zero and three. A value of zero means 70110699583SJed Brown # that the data has no temporal locality, so it need not be left 70210699583SJed Brown # in the cache after the access. A value of three means that the 70310699583SJed Brown # data has a high degree of temporal locality and should be left 70410699583SJed Brown # in all levels of cache possible. Values of one and two mean, 70510699583SJed Brown # respectively, a low or moderate degree of temporal locality. 70610699583SJed Brown # 70710699583SJed Brown # Here we adopt Intel's x86/x86-64 naming scheme for the locality 70810699583SJed Brown # hints. Using macros for these values in necessary since some 70910699583SJed Brown # compilers require an enum. 71010699583SJed Brown self.addDefine('Prefetch(a,b,c)', '__builtin_prefetch((a),(b),(c))') 71110699583SJed Brown self.addDefine('PREFETCH_HINT_NTA', '0') 71210699583SJed Brown self.addDefine('PREFETCH_HINT_T0', '3') 71310699583SJed Brown self.addDefine('PREFETCH_HINT_T1', '2') 71410699583SJed Brown self.addDefine('PREFETCH_HINT_T2', '1') 715b2843cf1SBarry Smith else: 716b2843cf1SBarry Smith self.addDefine('Prefetch(a,b,c)', ' ') 7177d490b44SBarry Smith self.popLanguage() 718b2843cf1SBarry Smith 71909bc878fSSatish Balay def configureAtoll(self): 72009bc878fSSatish Balay '''Checks if atoll exists''' 721436b02dcSSatish Balay if self.checkLink('#define _POSIX_C_SOURCE 200112L\n#include <stdlib.h>','long v = atoll("25")') or self.checkLink ('#include <stdlib.h>','long v = atoll("25")'): 72209bc878fSSatish Balay self.addDefine('HAVE_ATOLL', '1') 72309bc878fSSatish Balay 7242400fdedSBarry Smith def configureUnused(self): 7252400fdedSBarry Smith '''Sees if __attribute((unused)) is supported''' 7261adaff47SSean Farley if self.framework.argDB['with-ios']: 7272400fdedSBarry Smith self.addDefine('UNUSED', ' ') 7282400fdedSBarry Smith return 7292400fdedSBarry Smith self.pushLanguage(self.languages.clanguage) 730edf21b64SSatish Balay if self.checkLink('__attribute((unused)) static int myfunc(__attribute((unused)) void *name){ return 1;}', 'int i = 0;\nint j = myfunc(&i);\ntypedef void* atype;\n__attribute((unused)) atype a;\n'): 7312400fdedSBarry Smith self.addDefine('UNUSED', '__attribute((unused))') 7322400fdedSBarry Smith else: 7332400fdedSBarry Smith self.addDefine('UNUSED', ' ') 7342400fdedSBarry Smith self.popLanguage() 7352400fdedSBarry Smith 73698ed35c3SBarry Smith def configureIsatty(self): 73798ed35c3SBarry Smith '''Check if the Unix C function isatty() works correctly 73898ed35c3SBarry Smith Actually just assumes it does not work correctly on batch systems''' 73998ed35c3SBarry Smith if not self.framework.argDB['with-batch']: 74098ed35c3SBarry Smith self.addDefine('USE_ISATTY',1) 74198ed35c3SBarry Smith 7421ef8df7fSJed Brown def configureDeprecated(self): 7431ef8df7fSJed Brown '''Check if __attribute((deprecated)) is supported''' 7441ef8df7fSJed Brown self.pushLanguage(self.languages.clanguage) 74559a26b54SJed Brown ## Recent versions of gcc and clang support __attribute((deprecated("string argument"))), which is very useful, but 74659a26b54SJed Brown ## Intel has conspired to make a supremely environment-sensitive compiler. The Intel compiler looks at the gcc 74759a26b54SJed Brown ## executable in the environment to determine the language compatibility that it should attempt to emulate. Some 74859a26b54SJed Brown ## important Cray installations have built PETSc using the Intel compiler, but with a newer gcc module loaded (e.g., 749df3898eeSBarry Smith ## 4.7). Thus at PETSc configure time, the Intel compiler decides to support the string argument, but the gcc 75059a26b54SJed Brown ## found in the default user environment is older and does not support the argument. If GCC and Intel were cool 75159a26b54SJed Brown ## like Clang and supported __has_attribute, we could avoid configure tests entirely, but they don't. And that is 75259a26b54SJed Brown ## why we can't have nice things. 75359a26b54SJed Brown # 75459a26b54SJed Brown # if self.checkCompile("""__attribute((deprecated("Why you shouldn't use myfunc"))) static int myfunc(void) { return 1;}""", ''): 75525ef9dfeSBarry Smith # self.addDefine('DEPRECATED_FUNCTION(why)', '__attribute((deprecated(why)))') 75625ef9dfeSBarry Smith # self.addDefine('DEPRECATED_TYPEDEF(why)', '__attribute((deprecated(why)))') 75759a26b54SJed Brown if self.checkCompile("""__attribute((deprecated)) static int myfunc(void) { return 1;}""", ''): 75825ef9dfeSBarry Smith self.addDefine('DEPRECATED_FUNCTION(why)', '__attribute((deprecated))') 75925ef9dfeSBarry Smith self.addDefine('DEPRECATED_TYPEDEF(why)', '__attribute((deprecated))') 7601ef8df7fSJed Brown else: 76125ef9dfeSBarry Smith self.addDefine('DEPRECATED_FUNCTION(why)', ' ') 76225ef9dfeSBarry Smith self.addDefine('DEPRECATED_TYPEDEF(why)', ' ') 763a8678870SSatish Balay if self.checkCompile("""enum E {oldval __attribute((deprecated)), newval };""", ''): 764933a48e8SSatish Balay self.addDefine('DEPRECATED_ENUM(why)', '__attribute((deprecated))') 765933a48e8SSatish Balay else: 766933a48e8SSatish Balay self.addDefine('DEPRECATED_ENUM(why)', ' ') 76705de396fSBarry Smith # I was unable to make a CPP macro that takes the old and new values as seperate arguments and builds the message needed by _Pragma 76805de396fSBarry Smith # hence the deprecation message is handled as it is 76905de396fSBarry Smith if self.checkCompile('#define TEST _Pragma("GCC warning \"Testing _Pragma\"") value'): 77005de396fSBarry Smith self.addDefine('DEPRECATED_MACRO(why)', '_Pragma(why)') 77105de396fSBarry Smith else: 77205de396fSBarry Smith self.addDefine('DEPRECATED_MACRO(why)', ' ') 7731ef8df7fSJed Brown self.popLanguage() 7741ef8df7fSJed Brown 77518f41590SBarry Smith def configureAlign(self): 77618f41590SBarry Smith '''Check if __attribute(align) is supported''' 777752d89a4SSatish Balay filename = 'conftestalign' 778752d89a4SSatish Balay includes = ''' 779752d89a4SSatish Balay#include <sys/types.h> 780752d89a4SSatish Balay#if STDC_HEADERS 781752d89a4SSatish Balay#include <stdlib.h> 782752d89a4SSatish Balay#include <stdio.h> 783752d89a4SSatish Balay#include <stddef.h> 784752d89a4SSatish Balay#endif\n''' 785752d89a4SSatish Balay body = ''' 786752d89a4SSatish Balaystruct mystruct {int myint;} __attribute((aligned(16))); 787752d89a4SSatish BalayFILE *f = fopen("'''+filename+'''", "w"); 788752d89a4SSatish Balayif (!f) exit(1); 789752d89a4SSatish Balayfprintf(f, "%lu\\n", (unsigned long)sizeof(struct mystruct)); 790752d89a4SSatish Balay''' 791752d89a4SSatish Balay if 'known-has-attribute-aligned' in self.argDB: 792752d89a4SSatish Balay if self.argDB['known-has-attribute-aligned']: 793752d89a4SSatish Balay size = 16 79418f41590SBarry Smith else: 795752d89a4SSatish Balay size = -3 796752d89a4SSatish Balay elif not self.argDB['with-batch']: 797752d89a4SSatish Balay self.pushLanguage(self.languages.clanguage) 798752d89a4SSatish Balay try: 799752d89a4SSatish Balay if self.checkRun(includes, body) and os.path.exists(filename): 800c6ef1b5bSJed Brown f = open(filename) 801752d89a4SSatish Balay size = int(f.read()) 802752d89a4SSatish Balay f.close() 803752d89a4SSatish Balay os.remove(filename) 8040045a809SSatish Balay else: 8050045a809SSatish Balay size = -4 806752d89a4SSatish Balay except: 807752d89a4SSatish Balay size = -1 808752d89a4SSatish Balay self.framework.logPrint('Error checking attribute(aligned)') 80918f41590SBarry Smith self.popLanguage() 810752d89a4SSatish Balay else: 811752d89a4SSatish Balay self.framework.addBatchInclude(['#include <stdlib.h>', '#include <stdio.h>', '#include <sys/types.h>','struct mystruct {int myint;} __attribute((aligned(16)));']) 812752d89a4SSatish Balay self.framework.addBatchBody('fprintf(output, " \'--known-has-attribute-aligned=%d\',\\n", sizeof(struct mystruct)==16);') 813752d89a4SSatish Balay size = -2 814752d89a4SSatish Balay if size == 16: 815752d89a4SSatish Balay self.addDefine('ATTRIBUTEALIGNED(size)', '__attribute((aligned (size)))') 816752d89a4SSatish Balay self.addDefine('HAVE_ATTRIBUTEALIGNED', 1) 817752d89a4SSatish Balay else: 818752d89a4SSatish Balay self.framework.logPrint('incorrect alignment. Found alignment:'+ str(size)) 819752d89a4SSatish Balay self.addDefine('ATTRIBUTEALIGNED(size)', ' ') 820752d89a4SSatish Balay return 82118f41590SBarry Smith 8229800092aSJed Brown def configureExpect(self): 8239800092aSJed Brown '''Sees if the __builtin_expect directive is supported''' 8249800092aSJed Brown self.pushLanguage(self.languages.clanguage) 8259800092aSJed Brown if self.checkLink('', 'if (__builtin_expect(0,1)) return 1;'): 8269800092aSJed Brown self.addDefine('HAVE_BUILTIN_EXPECT', 1) 8279800092aSJed Brown self.popLanguage() 8289800092aSJed Brown 82953c77d0aSJed Brown def configureFunctionName(self): 830fbfcfee5SBarry Smith '''Sees if the compiler supports __func__ or a variant.''' 8311ec50b02SJed Brown def getFunctionName(lang): 832fbfcfee5SBarry Smith name = '"unknown"' 8331ec50b02SJed Brown self.pushLanguage(lang) 834b6ff4c76SKarl Rupp for fname in ['__func__','__FUNCTION__','__extension__ __func__']: 8350117e5a1SSatish Balay code = "if ("+fname+"[0] != 'm') return 1;" 8360117e5a1SSatish Balay if self.checkCompile('',code) and self.checkLink('',code): 8370117e5a1SSatish Balay name = fname 8380117e5a1SSatish Balay break 8391ec50b02SJed Brown self.popLanguage() 8401ec50b02SJed Brown return name 8411ec50b02SJed Brown langs = [] 842628773c9SSatish Balay 843628773c9SSatish Balay self.addDefine('FUNCTION_NAME_C', getFunctionName('C')) 8445f6e5f85SSatish Balay if hasattr(self.compilers, 'CXX'): 845628773c9SSatish Balay self.addDefine('FUNCTION_NAME_CXX', getFunctionName('Cxx')) 84653c77d0aSJed Brown 847753ebd1dSJed Brown def configureIntptrt(self): 848753ebd1dSJed Brown '''Determine what to use for uintptr_t''' 849753ebd1dSJed Brown def staticAssertSizeMatchesVoidStar(inc,typename): 850753ebd1dSJed Brown # The declaration is an error if either array size is negative. 851753ebd1dSJed 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 852d26187a0SJed Brown return self.checkCompile(inc, ('#define STATIC_ASSERT(cond) char negative_length_if_false[2*(!!(cond))-1]\n' 853979939cdSSatish Balay + 'STATIC_ASSERT(sizeof(void*) == sizeof(%s));'%typename)) 854753ebd1dSJed Brown self.pushLanguage(self.languages.clanguage) 855753ebd1dSJed Brown if self.checkCompile('#include <stdint.h>', 'int x; uintptr_t i = (uintptr_t)&x;'): 856753ebd1dSJed Brown self.addDefine('UINTPTR_T', 'uintptr_t') 857753ebd1dSJed Brown elif staticAssertSizeMatchesVoidStar('','unsigned long long'): 858753ebd1dSJed Brown self.addDefine('UINTPTR_T', 'unsigned long long') 859753ebd1dSJed Brown elif staticAssertSizeMatchesVoidStar('#include <stdlib.h>','size_t') or staticAssertSizeMatchesVoidStar('#include <string.h>', 'size_t'): 860753ebd1dSJed Brown self.addDefine('UINTPTR_T', 'size_t') 861c82284b1SJed Brown elif staticAssertSizeMatchesVoidStar('','unsigned long'): 862c82284b1SJed Brown self.addDefine('UINTPTR_T', 'unsigned long') 8632d1b7972SSatish Balay elif staticAssertSizeMatchesVoidStar('','unsigned'): 864753ebd1dSJed Brown self.addDefine('UINTPTR_T', 'unsigned') 865d26187a0SJed Brown else: 866d26187a0SJed Brown raise RuntimeError('Could not find any unsigned integer type matching void*') 867753ebd1dSJed Brown self.popLanguage() 868753ebd1dSJed Brown 869ed938b00SJed Brown def configureRTLDDefault(self): 870bfef2c86SBarry Smith if self.checkCompile('#include <dlfcn.h>\n void *ptr = RTLD_DEFAULT;'): 871bfef2c86SBarry Smith self.addDefine('RTLD_DEFAULT','1') 872f8833479SBarry Smith return 873f8833479SBarry Smith 874f8833479SBarry Smith def configureSolaris(self): 875f8833479SBarry Smith '''Solaris specific stuff''' 876f8833479SBarry Smith if os.path.isdir(os.path.join('/usr','ucblib')): 877f8833479SBarry Smith try: 878f8833479SBarry Smith flag = getattr(self.setCompilers, self.language[-1]+'SharedLinkerFlag') 879f8833479SBarry Smith except AttributeError: 880f8833479SBarry Smith flag = None 881f8833479SBarry Smith if flag is None: 882f8833479SBarry Smith self.compilers.LIBS += ' -L/usr/ucblib' 883f8833479SBarry Smith else: 884f8833479SBarry Smith self.compilers.LIBS += ' '+flag+'/usr/ucblib' 885f8833479SBarry Smith return 886f8833479SBarry Smith 887f8833479SBarry Smith def configureLinux(self): 888f8833479SBarry Smith '''Linux specific stuff''' 8899f15855cSMatthew G Knepley # TODO: Test for this by mallocing an odd number of floats and checking the address 890f8833479SBarry Smith self.addDefine('HAVE_DOUBLE_ALIGN_MALLOC', 1) 891f8833479SBarry Smith return 892f8833479SBarry Smith 893f8833479SBarry Smith def configureWin32(self): 894f8833479SBarry Smith '''Win32 non-cygwin specific stuff''' 895f8833479SBarry Smith kernel32=0 896f8833479SBarry Smith if self.libraries.add('Kernel32.lib','GetComputerName',prototype='#include <Windows.h>', call='GetComputerName(NULL,NULL);'): 897f8833479SBarry Smith self.addDefine('HAVE_WINDOWS_H',1) 898f8833479SBarry Smith self.addDefine('HAVE_GETCOMPUTERNAME',1) 899f8833479SBarry Smith kernel32=1 900f8833479SBarry Smith elif self.libraries.add('kernel32','GetComputerName',prototype='#include <Windows.h>', call='GetComputerName(NULL,NULL);'): 901f8833479SBarry Smith self.addDefine('HAVE_WINDOWS_H',1) 902f8833479SBarry Smith self.addDefine('HAVE_GETCOMPUTERNAME',1) 903f8833479SBarry Smith kernel32=1 904f8833479SBarry Smith if kernel32: 905eed94e11SSatish Balay if self.framework.argDB['with-windows-graphics']: 906eed94e11SSatish Balay self.addDefine('USE_WINDOWS_GRAPHICS',1) 907f8833479SBarry Smith if self.checkLink('#include <Windows.h>','LoadLibrary(0)'): 908f8833479SBarry Smith self.addDefine('HAVE_LOADLIBRARY',1) 909b50f6d9eSLisandro Dalcin if self.checkLink('#include <Windows.h>','GetProcAddress(0,0)'): 910b50f6d9eSLisandro Dalcin self.addDefine('HAVE_GETPROCADDRESS',1) 911b50f6d9eSLisandro Dalcin if self.checkLink('#include <Windows.h>','FreeLibrary(0)'): 912b50f6d9eSLisandro Dalcin self.addDefine('HAVE_FREELIBRARY',1) 913a21658a3SLisandro Dalcin if self.checkLink('#include <Windows.h>','GetLastError()'): 914a21658a3SLisandro Dalcin self.addDefine('HAVE_GETLASTERROR',1) 915a21658a3SLisandro Dalcin if self.checkLink('#include <Windows.h>','SetLastError(0)'): 916a21658a3SLisandro Dalcin self.addDefine('HAVE_SETLASTERROR',1) 917f8833479SBarry Smith if self.checkLink('#include <Windows.h>\n','QueryPerformanceCounter(0);\n'): 918bea725cfSBarry Smith self.addDefine('USE_MICROSOFT_TIME',1) 919f8833479SBarry Smith if self.libraries.add('Advapi32.lib','GetUserName',prototype='#include <Windows.h>', call='GetUserName(NULL,NULL);'): 920f8833479SBarry Smith self.addDefine('HAVE_GET_USER_NAME',1) 921f8833479SBarry Smith elif self.libraries.add('advapi32','GetUserName',prototype='#include <Windows.h>', call='GetUserName(NULL,NULL);'): 922f8833479SBarry Smith self.addDefine('HAVE_GET_USER_NAME',1) 923f8833479SBarry Smith 924f8833479SBarry Smith if not self.libraries.add('User32.lib','GetDC',prototype='#include <Windows.h>',call='GetDC(0);'): 925f8833479SBarry Smith self.libraries.add('user32','GetDC',prototype='#include <Windows.h>',call='GetDC(0);') 926f8833479SBarry Smith if not self.libraries.add('Gdi32.lib','CreateCompatibleDC',prototype='#include <Windows.h>',call='CreateCompatibleDC(0);'): 927f8833479SBarry Smith self.libraries.add('gdi32','CreateCompatibleDC',prototype='#include <Windows.h>',call='CreateCompatibleDC(0);') 928f8833479SBarry Smith 929f8833479SBarry Smith self.types.check('int32_t', 'int') 930f8833479SBarry Smith if not self.checkCompile('#include <sys/types.h>\n','uid_t u;\n'): 931f8833479SBarry Smith self.addTypedef('int', 'uid_t') 932f8833479SBarry Smith self.addTypedef('int', 'gid_t') 933f8833479SBarry Smith if not self.checkLink('#if defined(PETSC_HAVE_UNISTD_H)\n#include <unistd.h>\n#endif\n','int a=R_OK;\n'): 934f8833479SBarry Smith self.framework.addDefine('R_OK', '04') 935f8833479SBarry Smith self.framework.addDefine('W_OK', '02') 936f8833479SBarry Smith self.framework.addDefine('X_OK', '01') 937f8833479SBarry Smith if not self.checkLink('#include <sys/stat.h>\n','int a=0;\nif (S_ISDIR(a)){}\n'): 938f8833479SBarry Smith self.framework.addDefine('S_ISREG(a)', '(((a)&_S_IFMT) == _S_IFREG)') 939f8833479SBarry Smith self.framework.addDefine('S_ISDIR(a)', '(((a)&_S_IFMT) == _S_IFDIR)') 940f8833479SBarry Smith if self.checkCompile('#include <Windows.h>\n','LARGE_INTEGER a;\nDWORD b=a.u.HighPart;\n'): 941f8833479SBarry Smith self.addDefine('HAVE_LARGE_INTEGER_U',1) 942f8833479SBarry Smith 943f8833479SBarry Smith # Windows requires a Binary file creation flag when creating/opening binary files. Is a better test in order? 944ef2cfba3SSatish Balay if self.checkCompile('#include <Windows.h>\n#include <fcntl.h>\n', 'int flags = O_BINARY;'): 945f8833479SBarry Smith self.addDefine('HAVE_O_BINARY',1) 946f8833479SBarry Smith 947f8833479SBarry Smith if self.compilers.CC.find('win32fe') >= 0: 948ad4212abSSatish Balay self.addDefine('HAVE_WINDOWS_COMPILERS',1) 949f8833479SBarry Smith self.addDefine('PATH_SEPARATOR','\';\'') 950f8833479SBarry Smith self.addDefine('DIR_SEPARATOR','\'\\\\\'') 951f8833479SBarry Smith self.addDefine('REPLACE_DIR_SEPARATOR','\'/\'') 952f8833479SBarry Smith self.addDefine('CANNOT_START_DEBUGGER',1) 9535188cb68SSatish Balay (petscdir,error,status) = self.executeShellCommand('cygpath -w '+self.installdir.petscDir, log = self.log) 95434531a4dSSatish Balay self.addDefine('DIR','"'+petscdir.replace('\\','\\\\')+'"') 9555188cb68SSatish Balay (petscdir,error,status) = self.executeShellCommand('cygpath -m '+self.installdir.petscDir, log = self.log) 956e433681fSSatish Balay self.addMakeMacro('wPETSC_DIR',petscdir) 957f8833479SBarry Smith else: 958f8833479SBarry Smith self.addDefine('PATH_SEPARATOR','\':\'') 959f8833479SBarry Smith self.addDefine('REPLACE_DIR_SEPARATOR','\'\\\\\'') 960f8833479SBarry Smith self.addDefine('DIR_SEPARATOR','\'/\'') 9615188cb68SSatish Balay self.addDefine('DIR','"'+self.installdir.petscDir+'"') 9625188cb68SSatish Balay self.addMakeMacro('wPETSC_DIR',self.installdir.petscDir) 9635188cb68SSatish Balay self.addDefine('ARCH','"'+self.installdir.petscArch+'"') 964f8833479SBarry Smith return 965f8833479SBarry Smith 966f8833479SBarry Smith#----------------------------------------------------------------------------------------------------- 967b10d012aSSatish Balay def configureCygwinBrokenPipe(self): 968b10d012aSSatish Balay '''Cygwin version <= 1.7.18 had issues with pipes and long commands invoked from gnu-make 969b10d012aSSatish Balay http://cygwin.com/ml/cygwin/2013-05/msg00340.html ''' 9707fca349cSMatthew G. Knepley if config.setCompilers.Configure.isCygwin(self.log): 971b10d012aSSatish Balay import platform 972b10d012aSSatish Balay import re 973b10d012aSSatish Balay r=re.compile("([0-9]+).([0-9]+).([0-9]+)") 974b10d012aSSatish Balay m=r.match(platform.release()) 975b10d012aSSatish Balay major=int(m.group(1)) 976b10d012aSSatish Balay minor=int(m.group(2)) 977b10d012aSSatish Balay subminor=int(m.group(3)) 978b10d012aSSatish Balay if ((major < 1) or (major == 1 and minor < 7) or (major == 1 and minor == 7 and subminor <= 18)): 979b10d012aSSatish Balay self.addMakeMacro('PETSC_CYGWIN_BROKEN_PIPE','1') 980b10d012aSSatish Balay return 981b10d012aSSatish Balay 982b10d012aSSatish Balay#----------------------------------------------------------------------------------------------------- 983569865ddSSatish Balay def configureDefaultArch(self): 984af0996ceSBarry Smith conffile = os.path.join('lib','petsc','conf', 'petscvariables') 985569865ddSSatish Balay if self.framework.argDB['with-default-arch']: 986c6ef1b5bSJed Brown fd = open(conffile, 'w') 987569865ddSSatish Balay fd.write('PETSC_ARCH='+self.arch.arch+'\n') 988da93591fSBarry Smith fd.write('PETSC_DIR='+self.petscdir.dir+'\n') 989b9b902edSJed Brown fd.write('include '+os.path.join('$(PETSC_DIR)','$(PETSC_ARCH)','lib','petsc','conf','petscvariables')+'\n') 990569865ddSSatish Balay fd.close() 991569865ddSSatish Balay self.framework.actions.addArgument('PETSc', 'Build', 'Set default architecture to '+self.arch.arch+' in '+conffile) 992569865ddSSatish Balay elif os.path.isfile(conffile): 993569865ddSSatish Balay try: 994569865ddSSatish Balay os.unlink(conffile) 995569865ddSSatish Balay except: 996569865ddSSatish Balay raise RuntimeError('Unable to remove file '+conffile+'. Did a different user create it?') 997569865ddSSatish Balay return 998569865ddSSatish Balay 999569865ddSSatish Balay#----------------------------------------------------------------------------------------------------- 1000f8833479SBarry Smith def configureScript(self): 1001f8833479SBarry Smith '''Output a script in the conf directory which will reproduce the configuration''' 1002f8833479SBarry Smith import nargs 1003495bf1a9SSatish Balay import sys 1004af0996ceSBarry Smith scriptName = os.path.join(self.arch.arch,'lib','petsc','conf', 'reconfigure-'+self.arch.arch+'.py') 1005f8833479SBarry Smith args = dict([(nargs.Arg.parseArgument(arg)[0], arg) for arg in self.framework.clArgs]) 1006e97fc2efSSatish Balay if 'with-clean' in args: 1007e97fc2efSSatish Balay del args['with-clean'] 1008f8833479SBarry Smith if 'configModules' in args: 10091063a081SSatish Balay if nargs.Arg.parseArgument(args['configModules'])[1] == 'PETSc.Configure': 1010f8833479SBarry Smith del args['configModules'] 1011f8833479SBarry Smith if 'optionsModule' in args: 101223a19ef1SSatish Balay if nargs.Arg.parseArgument(args['optionsModule'])[1] == 'config.compilerOptions': 1013f8833479SBarry Smith del args['optionsModule'] 1014f8833479SBarry Smith if not 'PETSC_ARCH' in args: 10151063a081SSatish Balay args['PETSC_ARCH'] = 'PETSC_ARCH='+str(self.arch.arch) 1016c6ef1b5bSJed Brown f = open(scriptName, 'w') 1017495bf1a9SSatish Balay f.write('#!'+sys.executable+'\n') 1018f8833479SBarry Smith f.write('if __name__ == \'__main__\':\n') 1019f8833479SBarry Smith f.write(' import sys\n') 10207561c02cSSatish Balay f.write(' import os\n') 10217561c02cSSatish Balay f.write(' sys.path.insert(0, os.path.abspath(\'config\'))\n') 1022f8833479SBarry Smith f.write(' import configure\n') 10231063a081SSatish Balay # pretty print repr(args.values()) 10241063a081SSatish Balay f.write(' configure_options = [\n') 10258bec23c5SJed Brown for itm in sorted(args.values()): 10261063a081SSatish Balay f.write(' \''+str(itm)+'\',\n') 10271063a081SSatish Balay f.write(' ]\n') 1028f8833479SBarry Smith f.write(' configure.petsc_configure(configure_options)\n') 1029f8833479SBarry Smith f.close() 1030f8833479SBarry Smith try: 10315b6bfdb9SJed Brown os.chmod(scriptName, 0o775) 10325b6bfdb9SJed Brown except OSError as e: 1033f8833479SBarry Smith self.framework.logPrint('Unable to make reconfigure script executable:\n'+str(e)) 1034f8833479SBarry Smith self.framework.actions.addArgument('PETSc', 'File creation', 'Created '+scriptName+' for automatic reconfiguration') 1035f8833479SBarry Smith return 1036f8833479SBarry Smith 1037f8833479SBarry Smith def configureInstall(self): 1038f8833479SBarry Smith '''Setup the directories for installation''' 1039f8833479SBarry Smith if self.framework.argDB['prefix']: 1040824e893fSSatish Balay self.addMakeRule('shared_install','',['-@echo "Now to install the libraries do:"',\ 1041d093bd8dSBarry Smith '-@echo "'+self.installdir.installSudo+'make PETSC_DIR=${PETSC_DIR} PETSC_ARCH=${PETSC_ARCH} install"',\ 1042315b77e6SSatish Balay '-@echo "========================================="']) 1043f8833479SBarry Smith else: 1044824e893fSSatish Balay self.addMakeRule('shared_install','',['-@echo "Now to check if the libraries are working do:"',\ 10450cd68fe6SJed Brown '-@echo "make PETSC_DIR=${PETSC_DIR} PETSC_ARCH=${PETSC_ARCH} check"',\ 1046315b77e6SSatish Balay '-@echo "========================================="']) 1047f8833479SBarry Smith return 1048f8833479SBarry Smith 1049f8833479SBarry Smith def configureGCOV(self): 1050f8833479SBarry Smith if self.framework.argDB['with-gcov']: 1051f8833479SBarry Smith self.addDefine('USE_GCOV','1') 1052f8833479SBarry Smith return 1053f8833479SBarry Smith 105428bb2e72SSatish Balay def postProcessPackages(self): 105528bb2e72SSatish Balay postPackages=[] 105628bb2e72SSatish Balay for i in self.framework.packages: 105728bb2e72SSatish Balay if hasattr(i,'postProcess'): postPackages.append(i) 105828bb2e72SSatish Balay if postPackages: 1059e64d19dfSSatish Balay # ctetgen needs petsc conf files. so attempt to create them early 1060a77eb93bSSatish Balay self.framework.dumpConfFiles() 1061d9293e7bSBarry Smith # tacky fix for dependency of Aluimia on Pflotran; requested via petsc-dev Matt provide a correct fix 1062d9293e7bSBarry Smith for i in postPackages: 1063d9293e7bSBarry Smith if i.name.upper() in ['PFLOTRAN']: 1064d9293e7bSBarry Smith i.postProcess() 1065d9293e7bSBarry Smith postPackages.remove(i) 106628bb2e72SSatish Balay for i in postPackages: i.postProcess() 1067aa5c8b8eSBarry Smith for i in postPackages: 1068aa5c8b8eSBarry Smith if i.installedpetsc: 1069aa5c8b8eSBarry Smith self.installed = 1 1070aa5c8b8eSBarry Smith break 107128bb2e72SSatish Balay return 1072f8833479SBarry Smith 1073f8833479SBarry Smith def configure(self): 1074f8833479SBarry Smith if not os.path.samefile(self.petscdir.dir, os.getcwd()): 1075f8833479SBarry Smith raise RuntimeError('Wrong PETSC_DIR option specified: '+str(self.petscdir.dir) + '\n Configure invoked in: '+os.path.realpath(os.getcwd())) 1076550489e3SMatthew 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): 10773552d8fbSSatish Balay raise RuntimeError('Incorrect option --prefix='+self.framework.argDB['prefix']+' specified. It cannot be same as PETSC_DIR!') 10788fd0dbdbSBarry Smith if self.framework.argDB['prefix'] and self.framework.argDB['prefix'].find(' ') > -1: 10798fd0dbdbSBarry 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') 1080c16c35a9SSatish 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)): 1081c16c35a9SSatish Balay raise RuntimeError('Incorrect option --prefix='+self.framework.argDB['prefix']+' specified. It cannot be same as PETSC_DIR/PETSC_ARCH!') 1082f16c1317SJed Brown self.framework.header = os.path.join(self.arch.arch,'include','petscconf.h') 1083f16c1317SJed Brown self.framework.cHeader = os.path.join(self.arch.arch,'include','petscfix.h') 1084af0996ceSBarry Smith self.framework.makeMacroHeader = os.path.join(self.arch.arch,'lib','petsc','conf','petscvariables') 1085af0996ceSBarry Smith self.framework.makeRuleHeader = os.path.join(self.arch.arch,'lib','petsc','conf','petscrules') 1086f8833479SBarry Smith if self.libraries.math is None: 1087f8833479SBarry Smith raise RuntimeError('PETSc requires a functional math library. Please send configure.log to petsc-maint@mcs.anl.gov.') 1088f8833479SBarry Smith if self.languages.clanguage == 'Cxx' and not hasattr(self.compilers, 'CXX'): 1089f8833479SBarry Smith raise RuntimeError('Cannot set C language to C++ without a functional C++ compiler.') 1090ed938b00SJed Brown self.executeTest(self.configureRTLDDefault) 1091b2843cf1SBarry Smith self.executeTest(self.configurePrefetch) 10922400fdedSBarry Smith self.executeTest(self.configureUnused) 10931ef8df7fSJed Brown self.executeTest(self.configureDeprecated) 109498ed35c3SBarry Smith self.executeTest(self.configureIsatty) 10959800092aSJed Brown self.executeTest(self.configureExpect); 109618f41590SBarry Smith self.executeTest(self.configureAlign); 109753c77d0aSJed Brown self.executeTest(self.configureFunctionName); 1098753ebd1dSJed Brown self.executeTest(self.configureIntptrt); 1099f8833479SBarry Smith self.executeTest(self.configureSolaris) 1100f8833479SBarry Smith self.executeTest(self.configureLinux) 1101f8833479SBarry Smith self.executeTest(self.configureWin32) 1102b10d012aSSatish Balay self.executeTest(self.configureCygwinBrokenPipe) 1103569865ddSSatish Balay self.executeTest(self.configureDefaultArch) 1104f8833479SBarry Smith self.executeTest(self.configureScript) 1105f8833479SBarry Smith self.executeTest(self.configureInstall) 1106f8833479SBarry Smith self.executeTest(self.configureGCOV) 110709bc878fSSatish Balay self.executeTest(self.configureAtoll) 1108f8833479SBarry Smith 1109f8833479SBarry Smith self.Dump() 1110f8833479SBarry Smith self.dumpConfigInfo() 11112a4161d9SMatthew G Knepley self.dumpMachineInfo() 1112511a6afcSJed Brown self.dumpCMakeConfig() 11138b0282a9SJed Brown self.dumpCMakeLists() 111440277576SBarry Smith # need to save the current state of BuildSystem so that postProcess() packages can read it in and perhaps run make install 111540277576SBarry Smith self.framework.storeSubstitutions(self.framework.argDB) 1116492432c8SJed Brown self.framework.argDB['configureCache'] = pickle.dumps(self.framework) 111740277576SBarry Smith self.framework.argDB.save(force = True) 11188b0282a9SJed Brown self.cmakeBoot() 1119262119f8SBarry Smith self.DumpPkgconfig() 1120351d3a41SMatthew G Knepley self.DumpModule() 1121f7ad81e1SBarry Smith self.postProcessPackages() 1122f8833479SBarry Smith self.framework.log.write('================================================================================\n') 1123f8833479SBarry Smith self.logClear() 1124f8833479SBarry Smith return 1125