19d310bb7SBarry Smith#!/usr/bin/env python 29d310bb7SBarry Smithfrom __future__ import generators 39d310bb7SBarry Smithimport user 49d310bb7SBarry Smithimport config.base 59d310bb7SBarry Smithimport os 69d310bb7SBarry Smith 79d310bb7SBarry Smithclass Configure(config.base.Configure): 89d310bb7SBarry Smith def __init__(self, framework): 99d310bb7SBarry Smith config.base.Configure.__init__(self, framework) 109d310bb7SBarry Smith self.headerPrefix = '' 119d310bb7SBarry Smith self.substPrefix = '' 129d310bb7SBarry Smith return 139d310bb7SBarry Smith 149d310bb7SBarry Smith def __str__(self): 159d310bb7SBarry Smith return '' 169d310bb7SBarry Smith 179d310bb7SBarry Smith def setupHelp(self, help): 189d310bb7SBarry Smith import nargs 199d310bb7SBarry Smith help.addArgument('PETSc', '-with-log=<bool>', nargs.ArgBool(None, 1, 'Activate logging code in PETSc')) 2022b6d1caSBarry Smith help.addArgument('PETSc', '-with-threadsafety=<bool>', nargs.ArgBool(None, 0, 'Allow individual threads in PETSc to call PETSc routines')) 219d310bb7SBarry Smith help.addArgument('PETSc', '-with-info=<bool>', nargs.ArgBool(None, 1, 'Activate PetscInfo() (i.e. -info) code in PETSc')) 229d310bb7SBarry Smith help.addArgument('PETSc', '-with-ctable=<bool>', nargs.ArgBool(None, 1, 'Activate CTABLE hashing for certain search functions - to conserve memory')) 239d310bb7SBarry Smith help.addArgument('PETSc', '-with-fortran-kernels=<bool>', nargs.ArgBool(None, 0, 'Use Fortran for linear algebra kernels')) 24ef4c6e81SRichard Tran Mills help.addArgument('PETSc', '-with-avx512-kernels=<bool>', nargs.ArgBool(None, 0, 'Use AVX-512 intrinsics for linear algebra kernels when available')) 259d310bb7SBarry Smith help.addArgument('PETSc', '-with-is-color-value-type=<char,short>',nargs.ArgString(None, 'short', 'char, short can store 256, 65536 colors')) 269d310bb7SBarry Smith return 279d310bb7SBarry Smith 289d310bb7SBarry Smith def setupDependencies(self, framework): 299d310bb7SBarry Smith config.base.Configure.setupDependencies(self, framework) 309d310bb7SBarry Smith self.compilers = framework.require('config.compilers', self) 319d310bb7SBarry Smith self.libraries = framework.require('config.libraries', self) 329d310bb7SBarry Smith self.types = framework.require('config.types', self) 33*3d744f9eSBarry Smith self.compilerFlags = framework.require('config.compilerFlags', self) 349d310bb7SBarry Smith return 359d310bb7SBarry Smith 369d310bb7SBarry Smith 379d310bb7SBarry Smith 389d310bb7SBarry Smith def configureLibraryOptions(self): 39ef4c6e81SRichard Tran Mills '''Sets PETSC_USE_DEBUG, PETSC_USE_INFO, PETSC_USE_LOG, PETSC_USE_CTABLE, PETSC_USE_FORTRAN_KERNELS, and PETSC_USE_AVX512_KERNELS''' 409d310bb7SBarry Smith '''Also sets PETSC_AssertAlignx() in Fortran and PETSC_Alignx() in C for IBM BG/P compiler ''' 4122b6d1caSBarry Smith if self.framework.argDB['with-threadsafety']: 42f79c285dSBarry Smith self.addDefine('HAVE_THREADSAFETY',1) 4322b6d1caSBarry Smith self.useThreadSafety = 1 4422b6d1caSBarry Smith else: 4522b6d1caSBarry Smith self.useThreadSafety = 0 4622b6d1caSBarry Smith 4722b6d1caSBarry Smith if self.useThreadSafety and self.framework.argDB['with-log']: 4822b6d1caSBarry Smith raise RuntimeError('Must use --with-log=0 with --with-threadsafety') 4922b6d1caSBarry Smith 509d310bb7SBarry Smith self.useLog = self.framework.argDB['with-log'] 519d310bb7SBarry Smith self.addDefine('USE_LOG', self.useLog) 529d310bb7SBarry Smith 53*3d744f9eSBarry Smith if self.compilerFlags.debugging: 542e3e7a57SBarry Smith if self.useThreadSafety: 552e3e7a57SBarry Smith raise RuntimeError('Must use --with-debugging=0 with --with-threadsafety') 56f79c285dSBarry Smith self.addDefine('USE_DEBUG',1) 577fca349cSMatthew G. Knepley elif not config.setCompilers.Configure.isIBM(self.framework.getCompiler(), self.log): 589d310bb7SBarry Smith # IBM XLC version 12.1 (BG/Q and POWER) miscompiles PetscMalloc3() 599d310bb7SBarry Smith # by reordering "*(void**)&ptr = x" as though ptr was not modified 609d310bb7SBarry Smith # by this statement. 619d310bb7SBarry Smith self.addDefine('USE_MALLOC_COALESCED',1) 629d310bb7SBarry Smith 639d310bb7SBarry Smith self.useInfo = self.framework.argDB['with-info'] 649d310bb7SBarry Smith self.addDefine('USE_INFO', self.useInfo) 659d310bb7SBarry Smith 669d310bb7SBarry Smith self.useCtable = self.framework.argDB['with-ctable'] 679d310bb7SBarry Smith if self.useCtable: 689d310bb7SBarry Smith self.addDefine('USE_CTABLE', '1') 699d310bb7SBarry Smith 709d310bb7SBarry Smith # used in src/mat/impls/sbaij/seq/relax.h 713cafa982SMatthew G. Knepley self.libraries.saveLog() 729d310bb7SBarry Smith if not self.libraries.isBGL(): 739d310bb7SBarry Smith self.addDefine('USE_BACKWARD_LOOP','1') 743cafa982SMatthew G. Knepley self.logWrite(self.libraries.restoreLog()) 759d310bb7SBarry Smith 769d310bb7SBarry Smith self.useFortranKernels = self.framework.argDB['with-fortran-kernels'] 779d310bb7SBarry Smith if not hasattr(self.compilers, 'FC') and self.useFortranKernels: 789d310bb7SBarry Smith raise RuntimeError('Cannot use fortran kernels without a Fortran compiler') 799d310bb7SBarry Smith if self.useFortranKernels: 809d310bb7SBarry Smith self.addDefine('USE_FORTRAN_KERNELS', 1) 819d310bb7SBarry Smith if self.libraries.isBGL(): 829d310bb7SBarry Smith self.addDefine('AssertAlignx(a,b)','call ALIGNX(a,b)') 839d310bb7SBarry Smith else: 849d310bb7SBarry Smith self.addDefine('AssertAlignx(a,b)',' ') 859d310bb7SBarry Smith 86ef4c6e81SRichard Tran Mills self.useAVX512Kernels = self.framework.argDB['with-avx512-kernels'] 87ef4c6e81SRichard Tran Mills if self.useAVX512Kernels: 88ef4c6e81SRichard Tran Mills self.addDefine('USE_AVX512_KERNELS', 1) 89ef4c6e81SRichard Tran Mills 909d310bb7SBarry Smith if self.libraries.isBGL(): 919d310bb7SBarry Smith self.addDefine('Alignx(a,b)','__alignx(a,b)') 929d310bb7SBarry Smith else: 939d310bb7SBarry Smith self.addDefine('Alignx(a,b)',' ') 949d310bb7SBarry Smith return 959d310bb7SBarry Smith 969d310bb7SBarry Smith def configureISColorValueType(self): 979d310bb7SBarry Smith '''Sets PETSC_IS_COLOR_VALUE_TYPE, MPIU_COLORING_VALUE, IS_COLORING_MAX required by ISColor''' 989d310bb7SBarry Smith self.isColorValueType = self.framework.argDB['with-is-color-value-type'] 999d310bb7SBarry Smith if self.isColorValueType != 'char' and self.isColorValueType != 'short': 1009d310bb7SBarry Smith raise RuntimeError('Incorrect --with-is-color-value-type value specified. Can be either char or short. Specified value is :'+self.isColorValueType) 1019d310bb7SBarry Smith if self.isColorValueType == 'char': 1029d310bb7SBarry Smith max = pow(2,self.types.sizes['known-sizeof-char']*self.types.bits_per_byte)-1 1039d310bb7SBarry Smith mpi_type = 'MPI_UNSIGNED_CHAR' 1046564ec32SJed Brown type_f = 'integer1' 1059d310bb7SBarry Smith else: 1069d310bb7SBarry Smith max = pow(2,self.types.sizes['known-sizeof-short']*self.types.bits_per_byte)-1 1079d310bb7SBarry Smith mpi_type = 'MPI_UNSIGNED_SHORT' 1086564ec32SJed Brown type_f = 'integer2' 1099d310bb7SBarry Smith 1109d310bb7SBarry Smith self.framework.addDefine('MPIU_COLORING_VALUE',mpi_type) 1119d310bb7SBarry Smith self.framework.addDefine('IS_COLORING_MAX',max) 1129d310bb7SBarry Smith self.addDefine('IS_COLOR_VALUE_TYPE', self.isColorValueType) 1136564ec32SJed Brown self.addDefine('IS_COLOR_VALUE_TYPE_F', type_f) 1149d310bb7SBarry Smith return 1159d310bb7SBarry Smith 1169d310bb7SBarry Smith def configure(self): 1179d310bb7SBarry Smith self.executeTest(self.configureLibraryOptions) 1189d310bb7SBarry Smith self.executeTest(self.configureISColorValueType) 1199d310bb7SBarry Smith return 120