# # Copyright (c) 2004-2005 The Trustees of Indiana University and Indiana # University Research and Technology # Corporation. All rights reserved. # Copyright (c) 2004-2005 The University of Tennessee and The University # of Tennessee Research Foundation. All rights # reserved. # Copyright (c) 2004-2005 High Performance Computing Center Stuttgart, # University of Stuttgart. All rights reserved. # Copyright (c) 2004-2005 The Regents of the University of California. # All rights reserved. # Copyright (c) 2006-2012 Cisco Systems, Inc. All rights reserved. # Copyright (c) 2013 Mellanox Technologies, Inc. # All rights reserved. # $COPYRIGHT$ # # Additional copyrights may follow # # $HEADER$ # ############################################################################ # # Copyright (c) 2003, The Regents of the University of California, through # Lawrence Berkeley National Laboratory (subject to receipt of any # required approvals from the U.S. Dept. of Energy). All rights reserved. # # Initially written by: # Greg Kurtzer, # ############################################################################ ############################################################################# # # Configuration Options # # Options that can be passed in via rpmbuild's --define option. Note # that --define takes *1* argument: a multi-token string where the first # token is the name of the variable to define, and all remaining tokens # are the value. For example: # # shell$ rpmbuild ... --define 'install_in_opt 1' ... # # Or (a multi-token example): # # shell$ rpmbuild ... \ # --define 'configure_options CFLAGS=-g --with-openib=/usr/local/ofed' ... # ############################################################################# # Define this if you want to make this SRPM build in # /opt/NAME/VERSION-RELEASE instead of the default /usr/. # type: bool (0/1) %{!?install_in_opt: %define install_in_opt 0} # Define this if you want this RPM to install environment setup # shell scripts. # type: bool (0/1) %{!?install_shell_scripts: %define install_shell_scripts 0} # type: string (root path to install shell scripts) %{!?shell_scripts_path: %define shell_scripts_path %{_bindir}} # type: string (base name of the shell scripts) %{!?shell_scripts_basename: %define shell_scripts_basename mpivars} # Define this to 1 if you want this RPM to install a modulefile. # type: bool (0/1) %{!?install_modulefile: %define install_modulefile 0} # type: string (root path to install modulefiles) %{!?modulefile_path: %define modulefile_path /usr/share/Modules/modulefiles} # type: string (subdir to install modulefile) %{!?modulefile_subdir: %define modulefile_subdir %{name}} # type: string (name of modulefile) %{!?modulefile_name: %define modulefile_name %{version}} # The name of the modules RPM. Can vary from system to system. # RHEL6 calls it "environment-modules". # type: string (name of modules RPM) %{!?modules_rpm_name: %define modules_rpm_name environment-modules} # Should we use the mpi-selector functionality? # type: bool (0/1) %{!?use_mpi_selector: %define use_mpi_selector 0} # The name of the mpi-selector RPM. Can vary from system to system. # type: string (name of mpi-selector RPM) %{!?mpi_selector_rpm_name: %define mpi_selector_rpm_name mpi-selector} # The location of the mpi-selector executable (can be a relative path # name if "mpi-selector" can be found in the path) # type: string (path to mpi-selector exectuable) %{!?mpi_selector: %define mpi_selector mpi-selector} # Should we build a debuginfo RPM or not? # type: bool (0/1) %{!?build_debuginfo_rpm: %define build_debuginfo_rpm 0} # Should we build an all-in-one RPM, or several sub-package RPMs? # type: bool (0/1) %{!?build_all_in_one_rpm: %define build_all_in_one_rpm 1} # Should we use the default "check_files" RPM step (i.e., check for # unpackaged files)? It is discouraged to disable this, but some # installers need it (e.g., older versions of OFED, because they # installed lots of other stuff in the BUILD_ROOT before Open MPI/SHMEM). # type: bool (0/1) %{!?use_check_files: %define use_check_files 1} # By default, RPM supplies a bunch of optimization flags, some of # which may not work with non-gcc compilers. We attempt to weed some # of these out (below), but sometimes it's better to just ignore them # altogether (e.g., PGI 6.2 will warn about unknown compiler flags, # but PGI 7.0 will error -- and RPM_OPT_FLAGS contains a lot of flags # that PGI 7.0 does not understand). The default is to use the flags, # but you can set this variable to 0, indicating that RPM_OPT_FLAGS # should be erased (in which case you probabl want to supply your own # optimization flags!). # type: bool (0/1) %{!?use_default_rpm_opt_flags: %define use_default_rpm_opt_flags 1} # Some compilers can be installed via tarball or RPM (e.g., Intel, # PGI). If they're installed via RPM, then rpmbuild's auto-dependency # generation stuff will work fine. But if they're installed via # tarball, then rpmbuild's auto-dependency generation stuff will # break; complaining that it can't find a bunch of compiler .so files. # So provide an option to turn this stuff off. # type: bool (0/1) %{!?disable_auto_requires: %define disable_auto_requires 0} # On some platforms, Open MPI/SHMEM just flat-out doesn't work with # -D_FORTIFY_SOURCE (e.g., some users have reported that there are # problems on ioa64 platforms). In this case, just turn it off # (meaning: this specfile will strip out that flag from the # OS-provided compiler flags). We already strip out _FORTIFY_SOURCE # for non-GCC compilers; setting this option to 0 will *always* strip # it out, even if you're using GCC. # type: bool (0/1) %{!?allow_fortify_source: %define allow_fortify_source 1} ############################################################################# # # Configuration Logic # ############################################################################# %if %{install_in_opt} %define _prefix /opt/%{name}/%{version} %define _sysconfdir /opt/%{name}/%{version}/etc %define _libdir /opt/%{name}/%{version}/lib %define _includedir /opt/%{name}/%{version}/include %define _mandir /opt/%{name}/%{version}/man # Note that the name "openmpi" is hard-coded in # opal/mca/installdirs/config for pkgdatadir; there is currently no # easy way to have OMPI change this directory name internally. So we # just hard-code that name here as well (regardless of the value of # %{name} or %{_name}). %define _pkgdatadir /opt/%{name}/%{version}/share/openmpi # Per advice from Doug Ledford at Red Hat, docdir is supposed to be in # a fixed location. But if you're installing a package in /opt, all # bets are off. So feel free to install it anywhere in your tree. He # suggests $prefix/doc. %define _defaultdocdir /opt/%{name}/%{version}/doc %endif %if !%{build_debuginfo_rpm} %define debug_package %{nil} %endif %if %(test "%{_prefix}" = "/usr" && echo 1 || echo 0) %global _sysconfdir /etc %else %global _sysconfdir %{_prefix}/etc %endif # Is the sysconfdir under the prefix directory? This affects # whether we list the sysconfdir separately in the files sections, # below. %define sysconfdir_in_prefix %(test "`echo %{_sysconfdir} | grep %{_prefix}`" = "" && echo 0 || echo 1) %{!?_pkgdatadir: %define _pkgdatadir %{_datadir}/openmpi} %if !%{use_check_files} %define __check_files %{nil} %endif %{!?configure_options: %define configure_options %{nil}} %if !%{use_default_rpm_opt_flags} %define optflags "" %endif %if %{use_mpi_selector} %define install_shell_scripts 1 %endif ############################################################################# # # Preamble Section # ############################################################################# Summary: A powerful implementation of MPI/SHMEM Name: %{?_name:%{_name}}%{!?_name:openmpi} Version: $VERSION Release: 1 License: BSD Group: Development/Libraries Source: openmpi-%{version}.tar.$EXTENSION Packager: %{?_packager:%{_packager}}%{!?_packager:%{_vendor}} Vendor: %{?_vendorinfo:%{_vendorinfo}}%{!?_vendorinfo:%{_vendor}} Distribution: %{?_distribution:%{_distribution}}%{!?_distribution:%{_vendor}} Prefix: %{_prefix} Provides: mpi BuildRoot: /var/tmp/%{name}-%{version}-%{release}-root %if %{disable_auto_requires} AutoReq: no %endif %if %{install_modulefile} Requires: %{modules_rpm_name} %endif %if %{use_mpi_selector} Requires: %{mpi_selector_rpm_name} %endif %description Open MPI is a project combining technologies and resources from several other projects (FT-MPI, LA-MPI, LAM/MPI, and PACX-MPI) in order to build the best MPI library available. The project includes implementation of SHMEM parallel programming library in the Partitioned Global Address Space. This library provides fast inter-processor communication for large messages using data passing and one-sided communication techniques. SHMEM API based on OpenSHMEM standard from http://www.openshmem.org/ This RPM contains all the tools necessary to compile, link, and run Open MPI/SHMEM jobs. %if !%{build_all_in_one_rpm} ############################################################################# # # Preamble Section (runtime) # ############################################################################# %package runtime Summary: Tools and plugin modules for running Open MPI/SHMEM jobs Group: Development/Libraries Provides: mpi %if %{disable_auto_requires} AutoReq: no %endif %if %{install_modulefile} Requires: %{modules_rpm_name} %endif %description runtime Open MPI is a project combining technologies and resources from several other projects (FT-MPI, LA-MPI, LAM/MPI, and PACX-MPI) in order to build the best MPI library available. The project includes implementation of SHMEM parallel programming library in the Partitioned Global Address Space. This library provides fast inter-processor communication for large messages using data passing and one-sided communication techniques. SHMEM API based on OpenSHMEM standard from http://www.openshmem.org/ This subpackage provides general tools (mpirun, mpiexec, etc.) and the Module Component Architecture (MCA) base and plugins necessary for running Open MPI/SHMEM jobs. %endif ############################################################################# # # Preamble Section (devel) # ############################################################################# %package devel Summary: Development tools and header files for Open MPI/SHMEM Group: Development/Libraries %if %{disable_auto_requires} AutoReq: no %endif Requires: %{name}-runtime %description devel Open MPI is a project combining technologies and resources from several other projects (FT-MPI, LA-MPI, LAM/MPI, and PACX-MPI) in order to build the best MPI library available. The project includes implementation of SHMEM parallel programming library in the Partitioned Global Address Space. This library provides fast inter-processor communication for large messages using data passing and one-sided communication techniques. SHMEM API based on OpenSHMEM standard from http://www.openshmem.org/ This subpackage provides the development files for Open MPI/SHMEM, such as wrapper compilers and header files for MPI/SHMEM development. ############################################################################# # # Preamble Section (docs) # ############################################################################# %package docs Summary: Documentation for Open MPI/SHMEM Group: Development/Documentation %if %{disable_auto_requires} AutoReq: no %endif Requires: %{name}-runtime %description docs Open MPI is a project combining technologies and resources from several other projects (FT-MPI, LA-MPI, LAM/MPI, and PACX-MPI) in order to build the best MPI library available. The project includes implementation of SHMEM parallel programming library in the Partitioned Global Address Space. This library provides fast inter-processor communication for large messages using data passing and one-sided communication techniques. SHMEM API based on OpenSHMEM standard from http://www.openshmem.org/ This subpackage provides the documentation for Open MPI/SHMEM. ############################################################################# # # Prepatory Section # ############################################################################# %prep # Unbelievably, some versions of RPM do not first delete the previous # installation root (e.g., it may have been left over from a prior # failed build). This can lead to Badness later if there's files in # there that are not meant to be packaged. rm -rf $RPM_BUILD_ROOT %setup -q -n openmpi-%{version} ############################################################################# # # Build Section # ############################################################################# %build # rpmbuild processes seem to be geared towards the GNU compilers -- # they pass in some flags that will only work with gcc. So if we're # trying to build with some other compiler, the process will choke. # This is *not* something the user can override with a well-placed # --define on the rpmbuild command line, unless they find and override # all "global" CFLAGS kinds of RPM macros (every distro names them # differently). For example, non-gcc compilers cannot use # FORTIFY_SOURCE (at least, not as of 6 Oct 2006). We can really only # examine the basename of the compiler, so search for it in a few # places. %if %{allow_fortify_source} using_gcc=1 if test "$CC" != ""; then # Do horrible things to get the basename of just the compiler, # particularly in the case of multword values for $CC eval "set $CC" if test "`basename $1`" != "gcc"; then using_gcc=0 fi fi if test "$using_gcc" = "1"; then # Do wretched things to find a CC=* token eval "set -- %{configure_options}" compiler= while test "$1" != "" -a "$compiler" = ""; do case "$1" in CC=*) compiler=`echo $1 | cut -d= -f2-` ;; esac shift done # Now that we *might* have the compiler name, do a best-faith # effort to see if it's gcc. Blah! if test "$compiler" != ""; then if test "`basename $compiler`" != "gcc"; then using_gcc=0 fi fi fi %else # If we're not allowing _FORTIFY_SOURCE, then just set using_gcc to 0 and # the logic below will strip _FORTIFY_SOURCE out if it's present. using_gcc=0 %endif # If we're not using the default RPM_OPT_FLAGS, then wipe them clean # (the "optflags" macro has already been wiped clean, above). %if !%{use_default_rpm_opt_flags} RPM_OPT_FLAGS= export RPM_OPT_FLAGS %endif # If we're not GCC, strip out any GCC-specific arguments in the # RPM_OPT_FLAGS before potentially propagating them everywhere. if test "$using_gcc" = 0; then # Non-gcc compilers cannot handle FORTIFY_SOURCE (at least, not as # of Oct 2006) RPM_OPT_FLAGS="`echo $RPM_OPT_FLAGS | sed -e 's@-D_FORTIFY_SOURCE[=0-9]*@@'`" # Non-gcc compilers will generate warnings for several flags # placed in RPM_OPT_FLAGS by RHEL5, but -mtune=generic will cause # an error for icc 9.1. RPM_OPT_FLAGS="`echo $RPM_OPT_FLAGS | sed -e 's@-mtune=generic@@'`" fi CFLAGS="%{?cflags:%{cflags}}%{!?cflags:$RPM_OPT_FLAGS}" CXXFLAGS="%{?cxxflags:%{cxxflags}}%{!?cxxflags:$RPM_OPT_FLAGS}" FFLAGS="%{?f77flags:%{f77flags}}%{!?f7flags:$RPM_OPT_FLAGS}" FCFLAGS="%{?fcflags:%{fcflags}}%{!?fcflags:$RPM_OPT_FLAGS}" export CFLAGS CXXFLAGS F77FLAGS FCFLAGS %configure %{configure_options} %{__make} %{?mflags} ############################################################################# # # Install Section # ############################################################################# %install %{__make} install DESTDIR=$RPM_BUILD_ROOT %{?mflags_install} # We've had cases of config.log being left in the installation tree. # We don't need that in an RPM. find $RPM_BUILD_ROOT -name config.log -exec rm -f {} \; # First, the [optional] modulefile %if %{install_modulefile} %{__mkdir_p} $RPM_BUILD_ROOT/%{modulefile_path}/%{modulefile_subdir}/ cat <$RPM_BUILD_ROOT/%{modulefile_path}/%{modulefile_subdir}/%{modulefile_name} #%Module # NOTE: This is an automatically-generated file! (generated by the # Open MPI/SHMEM RPM). Any changes made here will be lost a) if the RPM is # uninstalled, or b) if the RPM is upgraded or uninstalled. proc ModulesHelp { } { puts stderr "This module adds Open MPI/SHMEM v%{version} to various paths" } module-whatis "Sets up Open MPI/SHMEM v%{version} in your enviornment" prepend-path PATH "%{_prefix}/bin/" prepend-path LD_LIBRARY_PATH %{_libdir} prepend-path MANPATH %{_mandir} EOF %endif # End of modulefile if # Next, the [optional] shell scripts %if %{install_shell_scripts} %{__mkdir_p} $RPM_BUILD_ROOT/%{shell_scripts_path} cat < $RPM_BUILD_ROOT/%{shell_scripts_path}/%{shell_scripts_basename}.sh # NOTE: This is an automatically-generated file! (generated by the # Open MPI/SHMEM RPM). Any changes made here will be lost if the RPM is # uninstalled or upgraded. # PATH if test -z "\`echo \$PATH | grep %{_bindir}\`"; then PATH=%{_bindir}:\${PATH} export PATH fi # LD_LIBRARY_PATH if test -z "\`echo \$LD_LIBRARY_PATH | grep %{_libdir}\`"; then LD_LIBRARY_PATH=%{_libdir}\${LD_LIBRARY_PATH:+:}\${LD_LIBRARY_PATH} export LD_LIBRARY_PATH fi # MANPATH if test -z "\`echo \$MANPATH | grep %{_mandir}\`"; then MANPATH=%{_mandir}:\${MANPATH} export MANPATH fi # MPI_ROOT MPI_ROOT=%{_prefix} export MPI_ROOT EOF cat < $RPM_BUILD_ROOT/%{shell_scripts_path}/%{shell_scripts_basename}.csh # NOTE: This is an automatically-generated file! (generated by the # Open MPI/SHMEM RPM). Any changes made here will be lost if the RPM is # uninstalled or upgraded. # path if ("" == "\`echo \$path | grep %{_bindir}\`") then set path=(%{_bindir} \$path) endif # LD_LIBRARY_PATH if ("1" == "\$?LD_LIBRARY_PATH") then if ("\$LD_LIBRARY_PATH" !~ *%{_libdir}*) then setenv LD_LIBRARY_PATH %{_libdir}:\${LD_LIBRARY_PATH} endif else setenv LD_LIBRARY_PATH %{_libdir} endif # MANPATH if ("1" == "\$?MANPATH") then if ("\$MANPATH" !~ *%{_mandir}*) then setenv MANPATH %{_mandir}:\${MANPATH} endif else setenv MANPATH %{_mandir}: endif # MPI_ROOT setenv MPI_ROOT %{_prefix} EOF %endif # End of shell_scripts if %if !%{build_all_in_one_rpm} # Build lists of files that are specific to each package that are not # easily identifiable by a single directory (e.g., the different # libraries). In a somewhat lame move, we can't just pipe everything # together because if the user, for example, did --disable-shared # --enable-static, the "grep" for .so files will not find anything and # therefore return a non-zero exit status. This will cause RPM to # barf. So be super lame and dump the egrep through /bin/true -- this # always gives a 0 exit status. # First, find all the files rm -f all.files runtime.files remaining.files devel.files docs.files find $RPM_BUILD_ROOT -type f -o -type l | \ sed -e "s@$RPM_BUILD_ROOT@@" \ > all.files | /bin/true # Runtime files. This should generally be library files and some # executables (no man pages, no doc files, no header files). Do *not* # include wrapper compilers. Note that the VT files are variable; if # they're there, then take them (e.g., VT build may have been disabled # via a configure option). cat all.files | egrep '/lib/|/lib64/|/lib32/|/bin/|/etc/|/help-' > tmp.files | /bin/true # Snip out a bunch of executables (e.g., wrapper compilers, pkgconfig # files, .la and .a files) egrep -vi 'mpic|mpif|ortec|vtc|vtfort|f77|f90|pkgconfig|\.la$|\.a$' tmp.files > runtime.files | /bin/true rm -f tmp.files # Now take the runtime files out of all.files so that we don't get # duplicates. grep -v -f runtime.files all.files > remaining.files # Devel files, potentially including VT files. Basically -- just # exclude the man pages and doc files. cat remaining.files | \ egrep -v '/man/|/doc/' \ > devel.files | /bin/true # Now take those files out of reaming.files so that we don't get # duplicates. grep -v -f devel.files remaining.files > docs.files ################################################# # Now that we have a final list of files for each of the runtime, # devel, and docs RPMs, snip even a few more files out of those lists # because for directories that are wholly in only one RPM, we just # list that directory in the file lists below, and RPM will pick up # all files in that tree. We therefore don't want to list any files # in those trees in our *.files file lists. Additionally, the man # pages may get compressed by rpmbuild after this "install" step, so we # might not even have their final filenames, anyway. # runtime sub package %if !%{sysconfdir_in_prefix} grep -v %{_sysconfdir} runtime.files > tmp.files mv tmp.files runtime.files %endif grep -v %{_pkgdatadir} runtime.files > tmp.files mv tmp.files runtime.files # devel sub package grep -v %{_includedir} devel.files > tmp.files mv tmp.files devel.files # docs sub package grep -v %{_mandir} docs.files > tmp.files mv tmp.files docs.files %endif # End of build_all_in_one_rpm ############################################################################# # # Clean Section # ############################################################################# %clean # We may be in the directory that we're about to remove, so cd out of # there before we remove it cd /tmp # Remove installed driver after rpm build finished rm -rf $RPM_BUILD_DIR/%{name}-%{version} test "x$RPM_BUILD_ROOT" != "x" && rm -rf $RPM_BUILD_ROOT ############################################################################# # # Post Install Section # ############################################################################# %if %{use_mpi_selector} %post %{mpi_selector} \ --register %{name}-%{version} \ --source-dir %{shell_scripts_path} \ --yes %endif ############################################################################# # # Pre Uninstall Section # ############################################################################# %if %{use_mpi_selector} %preun %{mpi_selector} --unregister %{name}-%{version} --yes || \ /bin/true > /dev/null 2> /dev/null %endif ############################################################################# # # Files Section # ############################################################################# %if %{build_all_in_one_rpm} # # All in one RPM # # Easy; just list the prefix and then specifically call out the doc # files. # %files %defattr(-, root, root, -) %{_prefix} # If the sysconfdir is not under the prefix, then list it explicitly. %if !%{sysconfdir_in_prefix} %{_sysconfdir} %endif # If %{install_in_opt}, then we're instaling OMPI to # /opt/openmpi/. But be sure to also explicitly mention # /opt/openmpi so that it can be removed by RPM when everything under # there is also removed. %if %{install_in_opt} %dir /opt/%{name} %endif # If we're installing the modulefile, get that, too %if %{install_modulefile} %{modulefile_path} %endif # If we're installing the shell scripts, get those, too %if %{install_shell_scripts} %{shell_scripts_path}/%{shell_scripts_basename}.sh %{shell_scripts_path}/%{shell_scripts_basename}.csh %endif %doc README INSTALL LICENSE %else # # Sub-package RPMs # # Harder than all-in-one. We list the directories specifically so # that if the RPM creates directories when it is installed, we will # remove them when the RPM is uninstalled. We also have to use # specific file lists. # %files runtime -f runtime.files %defattr(-, root, root, -) %dir %{_prefix} # If the sysconfdir is not under the prefix, then list it explicitly. %if !%{sysconfdir_in_prefix} %{_sysconfdir} %endif # If %{install_in_opt}, then we're instaling OMPI to # /opt/openmpi/. But be sure to also explicitly mention # /opt/openmpi so that it can be removed by RPM when everything under # there is also removed. Also list /opt/openmpi//share so # that it can be removed as well. %if %{install_in_opt} %dir /opt/%{name} %dir /opt/%{name}/%{version}/share %endif # If we're installing the modulefile, get that, too %if %{install_modulefile} %{modulefile_path} %endif # If we're installing the shell scripts, get those, too %if %{install_shell_scripts} %{shell_scripts_path}/%{shell_scripts_basename}.sh %{shell_scripts_path}/%{shell_scripts_basename}.csh %endif %dir %{_bindir} %dir %{_libdir} %dir %{_libdir}/openmpi %doc README INSTALL LICENSE %{_pkgdatadir} %files devel -f devel.files %defattr(-, root, root, -) %{_includedir} # Note that we list the mandir specifically here, because we want all # files found in that tree, because rpmbuild may have compressed them # (e.g., foo.1.gz or foo.1.bz2) -- and we therefore don't know the # exact filenames. %files docs -f docs.files %defattr(-, root, root, -) %{_mandir} %endif ############################################################################# # # Changelog # ############################################################################# %changelog * Mon Jun 24 2013 Igor Ivanov - Add Open SHMEM parallel programming library as part of Open MPI * Tue Dec 11 2012 Jeff Squyres - Re-release 1.6.0-1.6.3 SRPMs (with new SRPM Release numbers) with patch for VampirTrace's configure script to make it install the private "libtool" script in the right location (the script is used to build user VT applications). - Update the regexps/methodology used to generate the lists of files in the multi-RPM sub-packages; it's been broken for a little while. - No longer explicitly list the bin dir executables in the multi-RPM sub-packages - Per https://svn.open-mpi.org/trac/ompi/ticket/3382, remove all files named "config.log" from the install tree so that we can use this spec file to re-release all OMPI v1.6.x SRPMs. * Wed Jun 27 2012 Jeff Squyres - Remove the "ofed" and "munge_build_into_install" options, because OFED no longer distributes MPI implementations. Yay! * Mon Jun 04 2012 Jeff Squyres - Didn't change the specfile, but changed the script that generates the SRPM to force the use of MD5 checksums (vs. SHA1 checksums) so that the SRPM is friendly to older versions of RPM, such as that on RHEL 5.x. * Fri Feb 17 2012 Jeff Squyres - Removed OSCAR defines. - If use_mpi_selector==1, then also set install_shell_scripts to 1. - Change modules default RPM name and modulefiles path to the defaults on RHEL6. * Mon Dec 14 2009 Jeff Squyres - Add missing executables to specfile (ompi-server, etc.) - Fix: pull in VT files when building multiple RPMs (reported by Jim Kusznir). - Add allow_fortify_source option to let users selectively disable _FORTIFY_SOURCE processing on platforms where it just doesn't work (even with gcc; also reported by Jim Kusznir). * Thu Sep 8 2009 Jeff Squyres - Change shell_scripts_basename to not include version number to accomodate what mpi-selector expects. * Mon Feb 4 2008 Jeff Squyres - OFED 1.3 has a much better installer; remove all the leave_build_root kludge nastyness. W00t! * Fri Jan 18 2008 Jeff Squyres - Remove the hard-coded "openmpi" name from two Requires statements and use %{name} instead (FWIW, %{_name} caused rpmbuild to barf). * Wed Jan 2 2008 Jeff Squyres - Remove duplicate %{_sysconfdir} in the % files sections when building the sub-packages. - When building the sub-packages, ensure that devel.files also picks up the F90 module. - Hard-code the directory name "openmpi" into _pkglibdir (vs. using %{name}) because the OMPI code base has it hard-coded as well. Thanks to Jim Kusznir for noticing the problem. * Tue Dec 4 2007 Jeff Squyres - Added define option for disabling the use of rpmbuild's auto-dependency generation stuff. This is necessary for some compilers that allow themselves to be installed via tarball (not RPM), such as the Portland Group compiler. * Thu Jul 12 2007 Jeff Squyres - Change default doc location when using install_in_opt. Thanks to Alex Tumanov for pointing this out and to Doug Ledford for suggestions where to put docdir in this case. * Thu May 3 2007 Jeff Squyres - Ensure to move out of $RPM_BUILD_ROOT before deleting it in % clean. - Remove a debugging "echo" that somehow got left in there * Thu Apr 12 2007 Jeff Squyres - Ensure that _pkglibdir is always defined, suggested by Greg Kurtzer. * Wed Apr 4 2007 Jeff Squyres - Fix several mistakes in the generated profile.d scripts - Fix several bugs with identifying non-GNU compilers, stripping of FORTIFY_SOURCE, -mtune, etc. * Fri Feb 9 2007 Jeff Squyres - Revamp to make profile.d scripts more general: default to making the shell script files be %{_bindir}/mpivars.{sh|csh} - Add %{munge_build_into_install} option for OFED 1.2 installer on SLES - Change shell script files and modulefile to *pre*pend all the OMPI paths - Make shell script and modulefile installation indepdendent of %{install_in_opt} (they're really separate issues) - Add more "ofed" shortcut qualifiers - Slightly better test for basename CC in the fortify source section - Fix some problems in the csh shell script * Fri Oct 6 2006 Jeff Squyres - Remove LANL section; they don't want it - Add some help for OFED building - Remove some outdated "rm -f" lines for executables that we no longer ship * Wed Apr 26 2006 Jeff Squyres - Revamp files listings to ensure that rpm -e will remove directories if rpm -i created them. - Simplify options for making modulefiles and profile.d scripts. - Add oscar define. - Ensure to remove the previous installation root during prep. - Cleanup the modulefile specification and installation; also ensure that the profile.d scripts get installed if selected. - Ensure to list sysconfdir in the files list if it's outside of the prefix. * Wed Mar 30 2006 Jeff Squyres - Lots of bit rot updates - Reorganize and rename the subpackages - Add / formalize a variety of rpmbuild --define options - Comment out the docs subpackage for the moment (until we have some documentation -- coming in v1.1!) * Wed May 03 2005 Jeff Squyres - Added some defines for LANL defaults - Added more defines for granulatirty of installation location for modulefile - Differentiate between installing in /opt and whether we want to install environment script files - Filled in files for man and mca-general subpackages * Thu Apr 07 2005 Greg Kurtzer - Added opt building - Added profile.d/modulefile logic and creation - Minor cleanups * Fri Apr 01 2005 Greg Kurtzer - Added comments - Split package into subpackages - Cleaned things up a bit - Sold the code to Microsoft, and now I am retiring. Thanks guys! * Wed Mar 23 2005 Mezzanine - Specfile auto-generated by Mezzanine