xref: /petsc/config/PETSc/options/libraryOptions.py (revision 15681d7c25ea474a288b86a9c5a3af2aa4c040ce)
19d310bb7SBarry Smith#!/usr/bin/env python
29d310bb7SBarry Smithfrom __future__ import generators
39d310bb7SBarry Smithimport config.base
49d310bb7SBarry Smithimport os
59d310bb7SBarry Smith
69d310bb7SBarry Smithclass Configure(config.base.Configure):
79d310bb7SBarry Smith  def __init__(self, framework):
89d310bb7SBarry Smith    config.base.Configure.__init__(self, framework)
99d310bb7SBarry Smith    self.headerPrefix = ''
109d310bb7SBarry Smith    self.substPrefix  = ''
119d310bb7SBarry Smith    return
129d310bb7SBarry Smith
139d310bb7SBarry Smith  def __str__(self):
149d310bb7SBarry Smith    return ''
159d310bb7SBarry Smith
169d310bb7SBarry Smith  def setupHelp(self, help):
179d310bb7SBarry Smith    import nargs
189d310bb7SBarry Smith    help.addArgument('PETSc', '-with-log=<bool>',              nargs.ArgBool(None, 1, 'Activate logging code in PETSc'))
1922b6d1caSBarry Smith    help.addArgument('PETSc', '-with-threadsafety=<bool>',     nargs.ArgBool(None, 0, 'Allow individual threads in PETSc to call PETSc routines'))
209d310bb7SBarry Smith    help.addArgument('PETSc', '-with-info=<bool>',             nargs.ArgBool(None, 1, 'Activate PetscInfo() (i.e. -info)  code in PETSc'))
219d310bb7SBarry Smith    help.addArgument('PETSc', '-with-ctable=<bool>',           nargs.ArgBool(None, 1, 'Activate CTABLE hashing for certain search functions - to conserve memory'))
229d310bb7SBarry Smith    help.addArgument('PETSc', '-with-fortran-kernels=<bool>',  nargs.ArgBool(None, 0, 'Use Fortran for linear algebra kernels'))
23*15681d7cSHong Zhang    help.addArgument('PETSc', '-with-avx512-kernels=<bool>',   nargs.ArgBool(None, 1, 'Use AVX-512 intrinsics for linear algebra kernels when available'))
249d310bb7SBarry Smith    help.addArgument('PETSc', '-with-is-color-value-type=<char,short>',nargs.ArgString(None, 'short', 'char, short can store 256, 65536 colors'))
259d310bb7SBarry Smith    return
269d310bb7SBarry Smith
279d310bb7SBarry Smith  def setupDependencies(self, framework):
289d310bb7SBarry Smith    config.base.Configure.setupDependencies(self, framework)
299d310bb7SBarry Smith    self.compilers   = framework.require('config.compilers', self)
309d310bb7SBarry Smith    self.libraries   = framework.require('config.libraries', self)
319d310bb7SBarry Smith    self.types       = framework.require('config.types', self)
323d744f9eSBarry Smith    self.compilerFlags = framework.require('config.compilerFlags', self)
339d310bb7SBarry Smith    return
349d310bb7SBarry Smith
359d310bb7SBarry Smith
369d310bb7SBarry Smith
379d310bb7SBarry Smith  def configureLibraryOptions(self):
38ef4c6e81SRichard Tran Mills    '''Sets PETSC_USE_DEBUG, PETSC_USE_INFO, PETSC_USE_LOG, PETSC_USE_CTABLE, PETSC_USE_FORTRAN_KERNELS, and PETSC_USE_AVX512_KERNELS'''
399d310bb7SBarry Smith    '''Also sets PETSC_AssertAlignx() in Fortran and PETSC_Alignx() in C for IBM BG/P compiler '''
4022b6d1caSBarry Smith    if self.framework.argDB['with-threadsafety']:
41f79c285dSBarry Smith      self.addDefine('HAVE_THREADSAFETY',1)
4222b6d1caSBarry Smith      self.useThreadSafety = 1
4322b6d1caSBarry Smith    else:
4422b6d1caSBarry Smith      self.useThreadSafety = 0
4522b6d1caSBarry Smith
4622b6d1caSBarry Smith    if self.useThreadSafety and self.framework.argDB['with-log']:
4722b6d1caSBarry Smith      raise RuntimeError('Must use --with-log=0 with --with-threadsafety')
4822b6d1caSBarry Smith
499d310bb7SBarry Smith    self.useLog   = self.framework.argDB['with-log']
509d310bb7SBarry Smith    self.addDefine('USE_LOG',   self.useLog)
519d310bb7SBarry Smith
523d744f9eSBarry Smith    if self.compilerFlags.debugging:
532e3e7a57SBarry Smith      if self.useThreadSafety:
542e3e7a57SBarry Smith        raise RuntimeError('Must use --with-debugging=0 with --with-threadsafety')
55f79c285dSBarry Smith      self.addDefine('USE_DEBUG',1)
567fca349cSMatthew G. Knepley    elif not config.setCompilers.Configure.isIBM(self.framework.getCompiler(), self.log):
579d310bb7SBarry Smith      # IBM XLC version 12.1 (BG/Q and POWER) miscompiles PetscMalloc3()
589d310bb7SBarry Smith      # by reordering "*(void**)&ptr = x" as though ptr was not modified
599d310bb7SBarry Smith      # by this statement.
609d310bb7SBarry Smith      self.addDefine('USE_MALLOC_COALESCED',1)
619d310bb7SBarry Smith
629d310bb7SBarry Smith    self.useInfo   = self.framework.argDB['with-info']
639d310bb7SBarry Smith    self.addDefine('USE_INFO',   self.useInfo)
649d310bb7SBarry Smith
659d310bb7SBarry Smith    self.useCtable = self.framework.argDB['with-ctable']
669d310bb7SBarry Smith    if self.useCtable:
679d310bb7SBarry Smith      self.addDefine('USE_CTABLE', '1')
689d310bb7SBarry Smith
699d310bb7SBarry Smith    # used in src/mat/impls/sbaij/seq/relax.h
703cafa982SMatthew G. Knepley    self.libraries.saveLog()
719d310bb7SBarry Smith    if not self.libraries.isBGL():
729d310bb7SBarry Smith      self.addDefine('USE_BACKWARD_LOOP','1')
733cafa982SMatthew G. Knepley    self.logWrite(self.libraries.restoreLog())
749d310bb7SBarry Smith
759d310bb7SBarry Smith    self.useFortranKernels = self.framework.argDB['with-fortran-kernels']
769d310bb7SBarry Smith    if not hasattr(self.compilers, 'FC') and self.useFortranKernels:
779d310bb7SBarry Smith      raise RuntimeError('Cannot use fortran kernels without a Fortran compiler')
789d310bb7SBarry Smith    if self.useFortranKernels:
799d310bb7SBarry Smith      self.addDefine('USE_FORTRAN_KERNELS', 1)
809d310bb7SBarry Smith      if self.libraries.isBGL():
819d310bb7SBarry Smith        self.addDefine('AssertAlignx(a,b)','call ALIGNX(a,b)')
829d310bb7SBarry Smith      else:
839d310bb7SBarry Smith        self.addDefine('AssertAlignx(a,b)','  ')
849d310bb7SBarry Smith
85ef4c6e81SRichard Tran Mills    self.useAVX512Kernels = self.framework.argDB['with-avx512-kernels']
86ef4c6e81SRichard Tran Mills    if self.useAVX512Kernels:
87ef4c6e81SRichard Tran Mills      self.addDefine('USE_AVX512_KERNELS', 1)
88ef4c6e81SRichard Tran Mills
899d310bb7SBarry Smith    if self.libraries.isBGL():
909d310bb7SBarry Smith      self.addDefine('Alignx(a,b)','__alignx(a,b)')
919d310bb7SBarry Smith    else:
929d310bb7SBarry Smith      self.addDefine('Alignx(a,b)','  ')
939d310bb7SBarry Smith    return
949d310bb7SBarry Smith
959d310bb7SBarry Smith  def configureISColorValueType(self):
969d310bb7SBarry Smith    '''Sets PETSC_IS_COLOR_VALUE_TYPE, MPIU_COLORING_VALUE, IS_COLORING_MAX required by ISColor'''
979d310bb7SBarry Smith    self.isColorValueType  = self.framework.argDB['with-is-color-value-type']
989d310bb7SBarry Smith    if self.isColorValueType != 'char' and self.isColorValueType != 'short':
999d310bb7SBarry Smith      raise RuntimeError('Incorrect --with-is-color-value-type value specified. Can be either char or short. Specified value is :'+self.isColorValueType)
1009d310bb7SBarry Smith    if self.isColorValueType == 'char':
10115a5570dSLisandro Dalcin      max_value = 'UCHAR_MAX'
1029d310bb7SBarry Smith      mpi_type = 'MPI_UNSIGNED_CHAR'
1036564ec32SJed Brown      type_f = 'integer1'
1049d310bb7SBarry Smith    else:
10515a5570dSLisandro Dalcin      max_value = 'USHRT_MAX'
1069d310bb7SBarry Smith      mpi_type = 'MPI_UNSIGNED_SHORT'
1076564ec32SJed Brown      type_f = 'integer2'
1089d310bb7SBarry Smith
1099d310bb7SBarry Smith    self.framework.addDefine('MPIU_COLORING_VALUE',mpi_type)
11015a5570dSLisandro Dalcin    self.framework.addDefine('IS_COLORING_MAX',max_value)
1119d310bb7SBarry Smith    self.addDefine('IS_COLOR_VALUE_TYPE', self.isColorValueType)
1126564ec32SJed Brown    self.addDefine('IS_COLOR_VALUE_TYPE_F', type_f)
1139d310bb7SBarry Smith    return
1149d310bb7SBarry Smith
1159d310bb7SBarry Smith  def configure(self):
1169d310bb7SBarry Smith    self.executeTest(self.configureLibraryOptions)
1179d310bb7SBarry Smith    self.executeTest(self.configureISColorValueType)
1189d310bb7SBarry Smith    return
119