xref: /petsc/config/PETSc/options/libraryOptions.py (revision 3d744f9e929384d3adb007bbfaba8c1f688562ca)
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