xref: /petsc/config/PETSc/options/libraryOptions.py (revision fb33c7d240f4e7d37a181ec87a75c5af552be88e)
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'))
2315681d7cSHong 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)
3060da17ecSBarry Smith    self.setCompilers     = framework.require('config.setCompilers', self)
319d310bb7SBarry Smith    self.libraries        = framework.require('config.libraries', self)
329d310bb7SBarry Smith    self.types            = framework.require('config.types', self)
333d744f9eSBarry Smith    self.compilerFlags    = framework.require('config.compilerFlags', self)
3460da17ecSBarry Smith    self.sharedLibraries  = framework.require('PETSc.options.sharedLibraries', None)
3560da17ecSBarry Smith    self.petscConfigure   = framework.require('PETSc.Configure', None)
369d310bb7SBarry Smith    return
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
50*fb33c7d2SBarry Smith    if self.useThreadSafety and not ((self.sharedLibraries.useShared and self.setCompilers.dynamicLibraries) or self.framework.argDB['with-single-library']):
5160da17ecSBarry Smith      raise RuntimeError('Must use --with-shared-libraries or --with-single-library with --with-threadsafety')
5260da17ecSBarry Smith
539d310bb7SBarry Smith    self.useLog   = self.framework.argDB['with-log']
549d310bb7SBarry Smith    self.addDefine('USE_LOG',   self.useLog)
559d310bb7SBarry Smith
563d744f9eSBarry Smith    if self.compilerFlags.debugging:
572e3e7a57SBarry Smith      if self.useThreadSafety:
582e3e7a57SBarry Smith        raise RuntimeError('Must use --with-debugging=0 with --with-threadsafety')
59f79c285dSBarry Smith      self.addDefine('USE_DEBUG',1)
607fca349cSMatthew G. Knepley    elif not config.setCompilers.Configure.isIBM(self.framework.getCompiler(), self.log):
619d310bb7SBarry Smith      # IBM XLC version 12.1 (BG/Q and POWER) miscompiles PetscMalloc3()
629d310bb7SBarry Smith      # by reordering "*(void**)&ptr = x" as though ptr was not modified
639d310bb7SBarry Smith      # by this statement.
649d310bb7SBarry Smith      self.addDefine('USE_MALLOC_COALESCED',1)
659d310bb7SBarry Smith
669d310bb7SBarry Smith    self.useInfo   = self.framework.argDB['with-info']
679d310bb7SBarry Smith    self.addDefine('USE_INFO',   self.useInfo)
689d310bb7SBarry Smith
699d310bb7SBarry Smith    self.useCtable = self.framework.argDB['with-ctable']
709d310bb7SBarry Smith    if self.useCtable:
719d310bb7SBarry Smith      self.addDefine('USE_CTABLE', '1')
729d310bb7SBarry Smith
739d310bb7SBarry Smith    # used in src/mat/impls/sbaij/seq/relax.h
743cafa982SMatthew G. Knepley    self.libraries.saveLog()
759d310bb7SBarry Smith    if not self.libraries.isBGL():
769d310bb7SBarry Smith      self.addDefine('USE_BACKWARD_LOOP','1')
773cafa982SMatthew G. Knepley    self.logWrite(self.libraries.restoreLog())
789d310bb7SBarry Smith
799d310bb7SBarry Smith    self.useFortranKernels = self.framework.argDB['with-fortran-kernels']
809d310bb7SBarry Smith    if not hasattr(self.compilers, 'FC') and self.useFortranKernels:
819d310bb7SBarry Smith      raise RuntimeError('Cannot use fortran kernels without a Fortran compiler')
829d310bb7SBarry Smith    if self.useFortranKernels:
839d310bb7SBarry Smith      self.addDefine('USE_FORTRAN_KERNELS', 1)
849d310bb7SBarry Smith      if self.libraries.isBGL():
859d310bb7SBarry Smith        self.addDefine('AssertAlignx(a,b)','call ALIGNX(a,b)')
869d310bb7SBarry Smith      else:
879d310bb7SBarry Smith        self.addDefine('AssertAlignx(a,b)','  ')
889d310bb7SBarry Smith
89ef4c6e81SRichard Tran Mills    self.useAVX512Kernels = self.framework.argDB['with-avx512-kernels']
90ef4c6e81SRichard Tran Mills    if self.useAVX512Kernels:
91ef4c6e81SRichard Tran Mills      self.addDefine('USE_AVX512_KERNELS', 1)
92ef4c6e81SRichard Tran Mills
939d310bb7SBarry Smith    if self.libraries.isBGL():
949d310bb7SBarry Smith      self.addDefine('Alignx(a,b)','__alignx(a,b)')
959d310bb7SBarry Smith    else:
969d310bb7SBarry Smith      self.addDefine('Alignx(a,b)','  ')
979d310bb7SBarry Smith    return
989d310bb7SBarry Smith
999d310bb7SBarry Smith  def configureISColorValueType(self):
100569ea7c4SPierre Jolivet    '''Sets PETSC_IS_COLORING_VALUE_TYPE, PETSC_MPIU_IS_COLORING_VALUE_TYPE, and PETSC_IS_COLORING_MAX as required by ISColoring'''
1019d310bb7SBarry Smith    self.isColorValueType  = self.framework.argDB['with-is-color-value-type']
1029d310bb7SBarry Smith    if self.isColorValueType != 'char' and self.isColorValueType != 'short':
1039d310bb7SBarry Smith      raise RuntimeError('Incorrect --with-is-color-value-type value specified. Can be either char or short. Specified value is :'+self.isColorValueType)
1049d310bb7SBarry Smith    if self.isColorValueType == 'char':
10515a5570dSLisandro Dalcin      max_value = 'UCHAR_MAX'
1069d310bb7SBarry Smith      mpi_type = 'MPI_UNSIGNED_CHAR'
1076564ec32SJed Brown      type_f = 'integer1'
1089d310bb7SBarry Smith    else:
10915a5570dSLisandro Dalcin      max_value = 'USHRT_MAX'
1109d310bb7SBarry Smith      mpi_type = 'MPI_UNSIGNED_SHORT'
1116564ec32SJed Brown      type_f = 'integer2'
1129d310bb7SBarry Smith
113569ea7c4SPierre Jolivet    self.addDefine('MPIU_IS_COLORING_VALUE_TYPE',mpi_type)
114569ea7c4SPierre Jolivet    self.addDefine('IS_COLORING_MAX',max_value)
115569ea7c4SPierre Jolivet    self.addDefine('IS_COLORING_VALUE_TYPE',self.isColorValueType)
116569ea7c4SPierre Jolivet    self.addDefine('IS_COLORING_VALUE_TYPE_F',type_f)
1179d310bb7SBarry Smith    return
1189d310bb7SBarry Smith
1199d310bb7SBarry Smith  def configure(self):
1209d310bb7SBarry Smith    self.executeTest(self.configureLibraryOptions)
1219d310bb7SBarry Smith    self.executeTest(self.configureISColorValueType)
1229d310bb7SBarry Smith    return
123