diff options
author | Axel Huebl <axel.huebl@plasma.ninja> | 2019-10-01 23:28:36 -0700 |
---|---|---|
committer | GitHub <noreply@github.com> | 2019-10-01 23:28:36 -0700 |
commit | bec283080292f90f8f97dcb7ceb070a9a86ed388 (patch) | |
tree | 12c65f428bf8f0d5695e3e7e1a49e58fb7d31281 /var | |
parent | 9dfec4a57c7331c05f0a70b657f1bbc628e34586 (diff) | |
download | spack-bec283080292f90f8f97dcb7ceb070a9a86ed388.tar.gz spack-bec283080292f90f8f97dcb7ceb070a9a86ed388.tar.bz2 spack-bec283080292f90f8f97dcb7ceb070a9a86ed388.tar.xz spack-bec283080292f90f8f97dcb7ceb070a9a86ed388.zip |
ZFP: CMake Package (#12999)
* ZFP: CMake Package
ZFP is primarily build via CMake, which will have all install logic
and configuration files generated.
The 0.5.0 release did not support this yet, so we toss it.
* Patch ADIOS1: ZFP 0.5.1+ support
* ZFP: Expose all CMake variants
Diffstat (limited to 'var')
4 files changed, 65 insertions, 38 deletions
diff --git a/var/spack/repos/builtin/packages/adios/package.py b/var/spack/repos/builtin/packages/adios/package.py index d4ea3258e2..ac9ab76468 100644 --- a/var/spack/repos/builtin/packages/adios/package.py +++ b/var/spack/repos/builtin/packages/adios/package.py @@ -79,7 +79,7 @@ class Adios(AutotoolsPackage): depends_on('sz@:1.4.10', when='@:1.12.0 +sz') depends_on('sz@1.4.11.0:1.4.11.99', when='@1.13.0 +sz') depends_on('sz@1.4.12.3:1.4.12.99', when='@1.13.1: +sz') - depends_on('zfp@:0.5.0', when='+zfp') + depends_on('zfp@0.5.1:0.5.99', when='+zfp') depends_on('lz4', when='+lz4') depends_on('c-blosc@1.12.0:', when='+blosc') # optional transports & file converters @@ -101,6 +101,10 @@ class Adios(AutotoolsPackage): # https://github.com/spack/spack/issues/1683 patch('adios_1100.patch', when='@:1.10.0^hdf5@1.10:') + # ADIOS 1.13.1 is written for ZFP 0.5.0 interfaces + # https://github.com/ornladios/ADIOS/pull/204 + patch('zfp051.patch', when='@1.11.0:1.13.1') + def validate(self, spec): """Checks if incompatible variants have been activated at the same time diff --git a/var/spack/repos/builtin/packages/adios/zfp051.patch b/var/spack/repos/builtin/packages/adios/zfp051.patch new file mode 100644 index 0000000000..d602ce39ed --- /dev/null +++ b/var/spack/repos/builtin/packages/adios/zfp051.patch @@ -0,0 +1,22 @@ +diff --git a/src/transforms/adios_transform_zfp_common.h b/src/transforms/adios_transform_zfp_common.h +index e453d078..681198ee 100644 +--- a/src/transforms/adios_transform_zfp_common.h ++++ b/src/transforms/adios_transform_zfp_common.h +@@ -146,7 +146,7 @@ static void zfp_initialize(void* array, struct zfp_buffer* zbuff) + zbuff->error = true; + return; + } +- zfp_stream_set_accuracy(zbuff->zstream, tol, zbuff->type); ++ zfp_stream_set_accuracy(zbuff->zstream, tol); + } + else if (zbuff->mode == 1) // precision + { +@@ -172,7 +172,7 @@ static void zfp_initialize(void* array, struct zfp_buffer* zbuff) + tol = (uint) ct; + + +- zfp_stream_set_precision(zbuff->zstream, tol, zbuff->type); ++ zfp_stream_set_precision(zbuff->zstream, tol); + } + else if (zbuff->mode == 2) // rate + { diff --git a/var/spack/repos/builtin/packages/adios2/package.py b/var/spack/repos/builtin/packages/adios2/package.py index b4061aa1cf..2a3d3698df 100644 --- a/var/spack/repos/builtin/packages/adios2/package.py +++ b/var/spack/repos/builtin/packages/adios2/package.py @@ -94,7 +94,7 @@ class Adios2(CMakePackage): depends_on('bzip2', when='+bzip2') depends_on('libpng@1.6:', when='@2.4.0: +png') # depends_on('mgard', when='@2.3.0: +mgard') - depends_on('zfp', when='+zfp') + depends_on('zfp@0.5.1:', when='+zfp') # depends_on('sz@:1.4.12', when='+sz') extends('python', when='+python') diff --git a/var/spack/repos/builtin/packages/zfp/package.py b/var/spack/repos/builtin/packages/zfp/package.py index c7cf5b1038..7eb5e511d0 100644 --- a/var/spack/repos/builtin/packages/zfp/package.py +++ b/var/spack/repos/builtin/packages/zfp/package.py @@ -6,7 +6,7 @@ from spack import * -class Zfp(MakefilePackage): +class Zfp(CMakePackage): """zfp is an open source C/C++ library for high-fidelity, high-throughput lossy compression of floating-point and integer multi-dimensional arrays. @@ -15,10 +15,10 @@ class Zfp(MakefilePackage): homepage = 'http://computing.llnl.gov/projects/floating-point-compression' url = 'http://computing.llnl.gov/projects/floating-point-compression/download/zfp-0.5.2.tar.gz' + version('0.5.5', sha256='fdf7b948bab1f4e5dccfe2c2048fd98c24e417ad8fb8a51ed3463d04147393c5') version('0.5.4', sha256='768a05ed9bf10e54ac306f90b81dd17b0e7b13782f01823d7da4394fd2da8adb') - version('0.5.2', '2f0a77aa34087219a6e10b8b7d031e77') - version('0.5.1', '0ed7059a9b480635e0dd33745e213d17') - version('0.5.0', '2ab29a852e65ad85aae38925c5003654') + version('0.5.2', sha256='89e718edb966422b5898b5c37b1b0a781d4effacb511520558469e3ff7f65d7c') + version('0.5.1', sha256='867c04cf965f1c70d9725b396c6e1b5d29db55b0d69b8e87a995aaebd221b830') variant('bsws', default='64', @@ -26,41 +26,42 @@ class Zfp(MakefilePackage): multi=False, description='Bit stream word size: use smaller for finer ' 'rate granularity. Use 8 for H5Z-ZFP filter.') - + variant('strided', default=False, + description='Enable strided access for progressive zfp streams') + variant('aligned', default=False, + description='Enable aligned memory allocation') + variant('twoway', default=False, + description='Use two-way skew-associative cache') + variant('fasthash', default=False, + description='Use a faster but more collision prone hash function') + variant('profile', default=False, + description='Count cache misses') variant('shared', default=True, description='Build shared versions of the library') - def edit(self, spec, prefix): - config_file = FileFilter('Config') - config_file.filter( - r'^\s*#\s*DEFS\s*\+=\s*-DBIT_STREAM_WORD_TYPE\s*=\s*uint8', - 'DEFS += -DBIT_STREAM_WORD_TYPE=uint%s' % - spec.variants['bsws'].value) + depends_on('cmake@3.4.0:', type='build') - def build(self, spec, prefix): - with working_dir('src'): - if '~shared' in spec: - make('static') - else: - make('shared') + def cmake_args(self): + spec = self.spec - def install(self, spec, prefix): - incdir = 'include' if spec.satisfies('@0.5.1:') else 'inc' + args = [ + '-DZFP_BIT_STREAM_WORD_SIZE:STRING={0}'.format( + spec.variants['bsws'].value), + '-DZFP_WITH_BIT_STREAM_STRIDED:BOOL={0}'.format( + 'ON' if '+strided' in spec else 'OFF'), + '-DZFP_WITH_ALIGNED_ALLOC:BOOL={0}'.format( + 'ON' if '+aligned' in spec else 'OFF'), + '-DZFP_WITH_CACHE_TWOWAY:BOOL={0}'.format( + 'ON' if '+twoway' in spec else 'OFF'), + '-DBUILD_SHARED_LIBS:BOOL={0}'.format( + 'ON' if '+shared' in spec else 'OFF'), + '-DBUILD_TESTING:BOOL={0}'.format( + 'ON' if self.run_tests else 'OFF') + ] + if spec.version >= Version('0.5.2'): + args.append('-DZFP_WITH_CACHE_FAST_HASH:BOOL={0}'.format( + 'ON' if '+fasthash' in spec else 'OFF')) + args.append('-DZFP_WITH_CACHE_PROFILE:BOOL={0}'.format( + 'ON' if '+profile' in spec else 'OFF')) - # Note: ZFP package does not provide an install target - mkdirp(prefix.lib) - mkdirp(prefix.include) - # Note: ZFP package builds .so files even on OSX - if '~shared' in spec: - install('lib/libzfp.a', prefix.lib) - else: - install('lib/libzfp.so', prefix.lib) - install('%s/zfp.h' % incdir, prefix.include) - install('%s/bitstream.h' % incdir, prefix.include) - if spec.satisfies('@0.5.1:'): - mkdirp('%s/zfp' % prefix.include) - install('%s/zfp/system.h' % incdir, '%s/zfp' % prefix.include) - install('%s/zfp/types.h' % incdir, '%s/zfp' % prefix.include) - else: - install('%s/types.h' % incdir, prefix.include) - install('%s/system.h' % incdir, prefix.include) + return args |