From 777901843f040c11a0ef2e49563f5edc158e1a9d Mon Sep 17 00:00:00 2001 From: Atsushi Hori Date: Tue, 19 Jan 2021 07:50:48 +0900 Subject: [PATCH] New Package: Process-in-Process (PiP) -- 2nd trial (#20925) * Adding PiP recipe * pip@1 recipe (it seems working) * change install dir hierarchy * installing PiP man pages * add pip-glibc & pip-gdb * fix configure option designations, fix dependency types * fix dependency type of pip * use AutotoolsPackage in pip recipe * add patch for pip-glibc & pip-gdb to enable 'disable-werror' * change glibc install directory * add linux distro check to pip-gdb * create process-in-process package * use flag_handler and join_path * add gcc version constraint, change install-test to check-installed * fix gcc version designations on conflicts() * add constraint of target cpu, fix flake8 warnings * add version constraint to resource() * Some fixes to adapt the current version not to execute 'piplnlibs' change documentation install command * Update new branch name of PiP-gdb adapting PiP-Testsuite * update pip-gdb github urls * The very first commit of Process-in-Process (PiP) details can be found at https://github.com/RIKEN-SysSoft/PiP * Fix comment style issues * New Package: Process-in-Process (PiP) -- 2nd trial * fix style issue * change inline comments style (required to have two spaces) Co-authored-by: Daiki Matsunaga --- .../packages/process-in-process/package.py | 177 ++++++++++++++++++ 1 file changed, 177 insertions(+) create mode 100644 var/spack/repos/builtin/packages/process-in-process/package.py diff --git a/var/spack/repos/builtin/packages/process-in-process/package.py b/var/spack/repos/builtin/packages/process-in-process/package.py new file mode 100644 index 0000000000..31c3e451d4 --- /dev/null +++ b/var/spack/repos/builtin/packages/process-in-process/package.py @@ -0,0 +1,177 @@ +# Copyright 2013-2021 Lawrence Livermore National Security, LLC and other +# Spack Project Developers. See the top-level COPYRIGHT file for details. +# +# SPDX-License-Identifier: (Apache-2.0 OR MIT) + +from spack import * + + +class ProcessInProcess(Package): + """Process-in-Process""" + + homepage = "https://github.com/RIKEN-SysSoft/PiP" + git = "https://github.com/RIKEN-SysSoft/PiP.git" + + maintainers = ['ahori'] + + # PiP version 1 is obsolete + version('2', branch='pip-2', preferred=True) + version('3', branch='pip-3') # experimental + + conflicts('%gcc@:3', when='os=centos7') + conflicts('%gcc@5:', when='os=centos7') + conflicts('%gcc@:3', when='os=rhel7') + conflicts('%gcc@5:', when='os=rhel7') + conflicts('%gcc@:7', when='os=centos8') + conflicts('%gcc@9:', when='os=centos8') + conflicts('%gcc@:7', when='os=rhel8') + conflicts('%gcc@9:', when='os=rhel8') + + # packages required for building PiP-gdb + depends_on('texinfo', type='build') + + # resources for PiP version 2 + # PiP-glibc resource + # for rhel/centos 7 + resource(name='PiP-glibc', + git='https://github.com/RIKEN-SysSoft/PiP-glibc.git', + branch='centos/glibc-2.17-260.el7.pip.branch', + destination='PiP-glibc', + when='@2 os=centos7') + resource(name='PiP-glibc', + git='https://github.com/RIKEN-SysSoft/PiP-glibc.git', + branch='centos/glibc-2.17-260.el7.pip.branch', + destination='PiP-glibc', + when='@2 os=rhel7') + # for rhel/centos 8 + resource(name='PiP-glibc', + git='https://github.com/RIKEN-SysSoft/PiP-glibc.git', + branch='centos/glibc-2.28-72.el8_1.1.pip.branch', + destination='PiP-glibc', + when='@2 os=centos8') + resource(name='PiP-glibc', + git='https://github.com/RIKEN-SysSoft/PiP-glibc.git', + branch='centos/glibc-2.28-72.el8_1.1.pip.branch', + destination='PiP-glibc', + when='@2 os=rhel8') + + # PiP-gdb resource + # for rhel/centos 7 + resource(name='PiP-gdb', + git='https://github.com/RIKEN-SysSoft/PiP-gdb.git', + branch='centos/gdb-7.6.1-94.el7.pip.branch', + destination='PiP-gdb', + when='@2 os=centos7') + resource(name='PiP-gdb', + git='https://github.com/RIKEN-SysSoft/PiP-gdb.git', + branch='centos/gdb-7.6.1-94.el7.pip.branch', + destination='PiP-gdb', + when='@2 os=rhel7') + # for rhel/centos 8 + resource(name='PiP-gdb', + git='https://github.com/RIKEN-SysSoft/PiP-gdb.git', + branch='centos/gdb-8.2-12.el8.pip.branch', + destination='PiP-gdb', + when='@2 os=centos8') + resource(name='PiP-gdb', + git='https://github.com/RIKEN-SysSoft/PiP-gdb.git', + branch='centos/gdb-8.2-12.el8.pip.branch', + destination='PiP-gdb', + when='@2 os=rhel8') + + # resources for PiP version 3 + # PiP-glibc resource + # for rhel/centos 7 + resource(name='PiP-glibc', + git='https://github.com/RIKEN-SysSoft/PiP-glibc.git', + branch='centos/glibc-2.17-260.el7.pip.branch', + destination='PiP-glibc', + when='@3 os=centos7') + resource(name='PiP-glibc', + git='https://github.com/RIKEN-SysSoft/PiP-glibc.git', + branch='centos/glibc-2.17-260.el7.pip.branch', + destination='PiP-glibc', + when='@3 os=rhel7') + # for rhel/centos 8 + resource(name='PiP-glibc', + git='https://github.com/RIKEN-SysSoft/PiP-glibc.git', + branch='centos/glibc-2.28-72.el8_1.1.pip.branch', + destination='PiP-glibc', + when='@3 os=centos8') + resource(name='PiP-glibc', + git='https://github.com/RIKEN-SysSoft/PiP-glibc.git', + branch='centos/glibc-2.28-72.el8_1.1.pip.branch', + destination='PiP-glibc', + when='@3 os=rhel8') + + # PiP-gdb resource + # for rhel/centos 7 + resource(name='PiP-gdb', + git='https://github.com/RIKEN-SysSoft/PiP-gdb.git', + branch='centos/gdb-7.6.1-94.el7.pip.branch', + destination='PiP-gdb', + when='@3 os=centos7') + resource(name='PiP-gdb', + git='https://github.com/RIKEN-SysSoft/PiP-gdb.git', + branch='centos/gdb-7.6.1-94.el7.pip.branch', + destination='PiP-gdb', + when='@3 os=rhel7') + # for rhel/centos 8 + resource(name='PiP-gdb', + git='https://github.com/RIKEN-SysSoft/PiP-gdb.git', + branch='centos/gdb-8.2-12.el8.pip.branch', + destination='PiP-gdb', + when='@3 os=centos8') + resource(name='PiP-gdb', + git='https://github.com/RIKEN-SysSoft/PiP-gdb.git', + branch='centos/gdb-8.2-12.el8.pip.branch', + destination='PiP-gdb', + when='@3 os=rhel8') + + # PiP testsuite (agnostic with PiP and OS versions) + resource(name='PiP-Testsuite', + git='https://github.com/RIKEN-SysSoft/PiP-Testsuite.git', + destination='PiP-Testsuite') + + def install(self, spec, prefix): + "Install Process-in-Process including PiP-glibc, PiP-gdb" + + # checking os and arch + arch = self.spec.architecture + target = self.spec.target + if arch.os not in ['centos7', 'rhel7', 'centos8', 'rhel8']: + raise InstallError('PIP only supports rhel/centos 7 and 8') + if target.family not in ['x86_64', 'aarch64']: + raise InstallError('PIP only supports x86_64 and aarch64') + + bash = which('bash') + + # installing PiP-glibc + glibc_builddir = join_path('PiP-glibc', 'PiP-glibc.build') + with working_dir(glibc_builddir, create=True): + # build.sh does build and install + bash(join_path('..', 'PiP-glibc', 'build.sh'), prefix.glibc) + + # installing PiP lib + configure('--prefix=%s' % prefix, + '--with-glibc-libdir=%s' % prefix.glibc.lib) + make() + make('install') + # installing already-doxygen-ed documents (man pages, html, ...) + make('doc') + + # testing PiP by using PiP-Testsuite (another repo), no need install + with working_dir(join_path('PiP-Testsuite', 'PiP-Testsuite')): + bash('configure', '--with-pip=%s' % prefix) + # make test programs + make() + # and run the test programs + make('test10', parallel=False) + + # installing PiP-gdb + with working_dir(join_path('PiP-gdb', 'PiP-gdb')): + # build.sh does build and install + bash('build.sh', '--prefix=%s' % prefix, '--with-pip=%s' % prefix) + # testing PiP-gdb + bash('test.sh', parallel=False) + # all done !!