#
# Marc E. Fiuczynski <mef@cs.princeton.edu>
# Copyright (C) 2007 The Trustees of Princeton University
+# Thierry Parmentelat <thierry.parmentelat@inria.fr> INRIA
#
-# supported distros f8, f10, f12, centos5
+# supported distros f8, f10, f12, f14, f16, centos5, sl6
#
# for locating pkgs.py
export PATH=.:$PATH
return 0
}
-# on fedora 8 or above, we use libnl from the stock repos
-# on centos5 we build it locally
-function pl_getKexcludes () {
- distroname=$1; shift
- case $distroname in
- # when using k27, we need our own flavour of iproute
- # for now we build only for k32, regardless of fcdistro
- f8)
- echo 'kernel* util-vserver* iptables iptables-ipv6 drupal' ;;
- f*)
- echo 'kernel* util-vserver* iptables iptables-ipv6 drupal' ;;
- centos5)
- echo 'kernel kernel-vserver kernel-devel kernel-headers kernel-debuginfo util-vserver* iptables drupal inotify-tools* libnl' ;;
- sl*)
- echo 'kernel kernel-debug kernel-debug-devel kernel-devel kernel-doc kernel-firmware kernel-headers iptables' ;;
- *)
- echo "pl_DISTRO_NAME=$pl_DISTRO_NAME not supported in getexcludes.sh" ; exit 1 ;;
- esac
+# yum exclusions are now defined in yumexclude.pkgs
+# so they can now depend both on the linux distro and the pl distro
+function pl_yumexclude () {
+ keyword=$1; shift
+ fcdistro=$1; shift
+ pldistro=$1; shift
+ # search for file "yumexclude.pkgs"
+ yumexclude_file=$(pl_locateDistroFile ../build/ $pldistro "yumexclude.pkgs")
+ # parse it
+ pl_parsePkgs keyword $fcdistro $pldistro $yumexclude_file || \
+ { echo pl_yumexclude failed with fcdistro=$fcdistro and pldistro=$pldistro; return 1 ; }
}
+# node side : use the 'nodeyumexclude' keywork in yumexclude.pkgs
+function pl_nodeyumexclude () { pl_yumexclude 'nodeyumexclude' "$@" ; }
+function pl_plcyumexclude () { pl_yumexclude 'plcyumexclude' "$@" ; }
+
+
# figure out which redhat distro we are using (fedora, centos, redhat)
pl_DISTRO=$(pl_getDistro)
# select basearch of the host devel environment - protected for macos for local tests
-pl_DISTRO_ARCH=$(uname -i 2>/dev/null|| echo unknownarch)
+# try arch for testing stuff on a mac
+pl_DISTRO_ARCH=$(uname -i 2>/dev/null || arch 2> /dev/null || echo unknownarch)
# the release number (plain number)
pl_DISTRO_RELEASE=$(pl_getRelease)
# the release name - for vserver build ...
pl_DISTRO_NAME=$(pl_getReleaseName $pl_DISTRO $pl_DISTRO_RELEASE)
-# the packages to exclude
-pl_KEXCLUDES=$(pl_getKexcludes $pl_DISTRO_NAME)
-
# get path to appropriate yumgroups.xml file
# Thierry: quick & dirty improvement
# this file is updated by the toplevel build, from the .pkgs files
pkgs_precious=$(pl_parsePkgs precious $fcdistro $pldistro $pkgsfile)
# formerly related to mkfedora -k : packages to take from our own build
# and thus need be excluded frem the stock repos
- pkgs_kexcludes=$(pl_parsePkgs kexclude $fcdistro $pldistro $pkgsfile | sed -e s,@KEXCLUDE@,"$pl_KEXCLUDES",)
+ SUBST_NODEYUMEXCLUDE=$(pl_nodeyumexclude $fcdistro $pldistro)
+ pkgs_yumexcludes=$(pl_parsePkgs yumexclude $fcdistro $pldistro $pkgsfile | sed -e s,@NODEYUMEXCLUDE@,"$SUBST_NODEYUMEXCLUDE",)
# get mirrors if not specified with -l
if [ -z "$mirrors" ] ; then
mirrorsfile=$(pl_locateDistroFile ../build/ $pldistro "$pldistro.mirrors")
mirrors=$(pl_parsePkgs mirror $fcdistro $pldistro $mirrorsfile)
fi
- kexclude_line=""
- [ -n "$pkgs_kexcludes" ] && kexclude_line="exclude=$pkgs_kexcludes"
+ yumexclude_line=""
+ [ -n "$pkgs_yumexcludes" ] && yumexclude_line="exclude=$pkgs_yumexcludes"
echo "$0: candidate mirrors"
for mirror in $mirrors ; do
# the repo part of the final yum.conf
yum_conf_repos=$vroot/xxxmkfedora-repos.confxxx
- if ! yumconf_mirrors $yum_conf_repos ../build/ $fcdistro "$kexclude_line" $mirrors ; then
+ if ! yumconf_mirrors $yum_conf_repos ../build/ $fcdistro "$yumexclude_line" $mirrors ; then
echo xxx -- error ; return 1
fi
dest_yumconf=$1; shift
builddir=$1; shift
fcdistro=$1; shift
- kexclude_line="$1" ; shift
+ yumexclude_line="$1" ; shift
mirrors="$@"
template=$builddir/mirroring/$fcdistro/yum.repos.d/building.repo.in
fi
for mirror in $mirrors; do
- if yumconf_mirror $dest_yumconf $template "$kexclude_line" $mirror; then
+ if yumconf_mirror $dest_yumconf $template "$yumexclude_line" $mirror; then
return 0
fi
done
function yumconf_mirror () {
dest_yumconf=$1; shift
template=$1; shift
- kexclude_line="$1" ; shift
+ yumexclude_line="$1" ; shift
mirror=$1; shift
sed -e "s,@MIRRORURL@,$mirror,g" \
-e "/baseurl=/i\\
-$kexclude_line" $template > $dest_yumconf
+$yumexclude_line" $template > $dest_yumconf
# capture all lines defining baseurl
baseurl_defs=$(grep '^baseurl=' $dest_yumconf)
# patches a yum conf to insert an exclude line in each declared repo
function yumconf_exclude () {
repo=$1; shift
- kexclude_line="$1" ; shift
+ yumexclude_line="$1" ; shift
sed -i -e "/#baseurl=.*$/i\\
-$kexclude_line" $repo
+$yumexclude_line" $repo
}
groupname: PlanetLab
groupdesc: PlanetLab Node Root
# packages to exclude from stock repositories
-kexclude: @KEXCLUDE@
+yumexclude: @NODEYUMEXCLUDE@
# fedora-release or centos-release are pulled from deps
# define packages
package: kernel
groupname: PlanetLabSlice
groupdesc: PlanetLab Slice Reference Image
# packages to exclude from stock repositories
-kexclude: @KEXCLUDE@
+yumexclude: @NODEYUMEXCLUDE@
# define packages
package: bash
package: coreutils
groupname: PlanetLabBootcd
groupdesc: PlanetLab BootCD
# packages to exclude from stock repositories
-kexclude: @KEXCLUDE@
+yumexclude: @NODEYUMEXCLUDE@
# define packages
package: filesystem
package: udev
groupname: PlanetLab
groupdesc: PlanetLab Node Root
# packages to exclude from stock repositories
-kexclude: @KEXCLUDE@
+yumexclude: @NODEYUMEXCLUDE@
# fedora-release or centos-release are pulled from deps
# define packages
package: kernel
groupname: PlanetLabSlice
groupdesc: PlanetLab Slice Reference Image
# packages to exclude from stock repositories
-kexclude: @KEXCLUDE@
+yumexclude: @NODEYUMEXCLUDE@
# define packages
package: bash
package: coreutils
--- /dev/null
+## feb. 2012 -- this used to be hard-wired in build.common
+
+# plexclude: to exclude on the myplc side - typially drupal
+plcyumexclude: drupal
+
+# excludes on the node side
+nodeyumexclude=f8: kernel* util-vserver* iptables iptables-ipv6
+nodeyumexclude>=f12: kernel* util-vserver* iptables iptables-ipv6
+nodeyumexclude=centos5: kernel kernel-vserver kernel-devel kernel-headers kernel-debuginfo util-vserver* iptables inotify-tools* libnl
+nodeyumexclude=sl6: kernel kernel-debug kernel-debug-devel kernel-devel kernel-doc kernel-firmware kernel-headers iptables
+++ /dev/null
-#!/bin/bash
-
-COMMAND=$(basename $0)
-. $(dirname $0)/build.common
-
-function usage () {
- echo "Usage: $COMMAND [-f fcdistro]"
- echo "outputs the list of packages to exclude from the stock repositories"
- echo "this is set in build.common, and needs to fit the set of packages"
- echo "that we override in the planetlab build"
- exit 1
-}
-
-while getopts "f:" opt ; do
- case $opt in
- f) FCDISTRO=$OPTARG ;;
- h|*) usage ;;
- esac
-done
-
-toshift=$(($OPTIND - 1))
-shift $toshift
-
-[[ -n "$@" ]] && usage
-
-# if the fcdistro is passed in argument
-if [ -n "$FCDISTRO" ] ; then
- pl_getKexcludes "$FCDISTRO"
-# otherwise use the value for the current system
-else
- echo "$pl_KEXCLUDES"
-fi
--- /dev/null
+#!/bin/bash
+
+COMMAND=$(basename $0)
+. $(dirname $0)/build.common
+
+function usage () {
+ echo "Usage: $COMMAND fcdistro pldistro"
+ echo "outputs the list of packages to exclude from the stock repo"
+ echo "this is set in yumexclude.pkgs, and needs to match the set of packages"
+ echo "that are produced by the planetlab build and meant to replace the stock ones"
+ exit 1
+}
+
+[[ -z "$@" ]] && usage
+FCDISTRO=$1; shift
+[[ -z "$@" ]] && usage
+PLDISTRO=$1; shift
+[[ -n "$@" ]] && usage
+
+pl_nodeyumexclude "$FCDISTRO" "$PLDISTRO"
madwifi-GITPATH := git://git.onelab.eu/madwifi.git@madwifi-4132-5
iptables-GITPATH := git://git.onelab.eu/iptables.git@iptables-1.4.10-5
# we use the stock iproute2 with 2.6.32, since our gre patch is not needed anymore with that kernel
-# note that this should be consistently reflected in pl_getKexcludes in build.common
+# note that this should be consistently reflected in nodeyumexclude
ALL := $(filter-out iproute,$(ALL))
###
ipfw-GITPATH := git://git.onelab.eu/ipfw.git@ipfw-0.9-23
pyplnet-GITPATH := git://git.onelab.eu/pyplnet.git@pyplnet-4.3-11
bootcd-GITPATH := git://git.onelab.eu/bootcd.git@bootcd-5.0-11
vserver-reference-GITPATH := git://git.onelab.eu/vserver-reference.git@vserver-reference-5.0-6
-bootstrapfs-GITPATH := git://git.onelab.eu/bootstrapfs.git@bootstrapfs-2.0-13
+bootstrapfs-GITPATH := git://git.onelab.eu/bootstrapfs.git@master
myplc-GITPATH := git://git.onelab.eu/myplc.git@myplc-5.0-19
DistributedRateLimiting-SVNPATH := http://svn.planet-lab.org/svn/DistributedRateLimiting/tags/DistributedRateLimiting-0.1-1
#
# libnl - local import
# we need either 1.1 or at least 1.0.pre6
-# rebuild this on centos5 - see kexcludes in build.common
+# rebuild this on centos5 - see yumexclude
#
local_libnl=false
ifeq "$(DISTRONAME)" "centos5"
#
# inotify-tools - local import
-# rebuild this on centos5 (not found) - see kexcludes in build.common
+# rebuild this on centos5 (not found) - see yumexclude
#
local_inotify_tools=false
ifeq "$(DISTRONAME)" "centos5"
known_fcdistros = [ 'centos5','centos6','f8', 'f9','f10','f11','f12', 'f13', 'f14', 'f16', 'sl6']
default_pldistro='onelab'
-known_keywords=['groupname', 'groupdesc', 'kexclude', 'package', 'group', 'precious', 'junk', 'mirror', ]
+known_keywords=['groupname', 'groupdesc',
+ 'nodeyumexclude', 'plcyumexclude',
+ 'yumexclude', 'package', 'group', 'precious', 'junk', 'mirror', ]
m_fcdistro_cutter = re.compile('([a-z]+)([0-9]+)')
madwifi-GITPATH := git://git.planet-lab.org/madwifi.git@madwifi-4132-5
iptables-GITPATH := git://git.planet-lab.org/iptables.git@iptables-1.4.10-5
# we use the stock iproute2 with 2.6.32, since our gre patch is not needed anymore with that kernel
-# note that this should be consistently reflected in pl_getKexcludes in build.common
+# note that this should be consistently reflected in yumexclude
ALL := $(filter-out iproute,$(ALL))
util-vserver-GITPATH := git://git.planet-lab.org/util-vserver.git@util-vserver-0.30.216-19
libnl-GITPATH := git://git.planet-lab.org/libnl.git@libnl-1.1-2
#
# libnl - local import
# we need either 1.1 or at least 1.0.pre6
-# rebuild this on centos5 - see kexcludes in build.common
+# rebuild this on centos5 - see yumexclude
#
local_libnl=false
ifeq "$(DISTRONAME)" "centos5"
#
# inotify-tools - local import
-# rebuild this on centos5 (not found) - see kexcludes in build.common
+# rebuild this on centos5 (not found) - see yumexclude
#
local_inotify_tools=false
ifeq "$(DISTRONAME)" "centos5"
vserver=$1; shift
fcdistro=$1; shift
+ pldistro=$1; shift
templates=/etc/vservers/.distributions/${fcdistro}
if [ -f ${templates}/yum/yum.conf ] ; then
echo "WARNING : cannot create myplc repo"
else
# exclude kernel from fedora repos
+ yumexclude=$(pl_plcyumexclude $fcdistro $pldistro)
for repo in /vservers/$vserver/etc/yum.repos.d/* ; do
- [ -f $repo ] && yumconf_exclude $repo "exclude=$pl_KEXCLUDES"
+ [ -f $repo ] && yumconf_exclude $repo "exclude=$yumexclude"
done
# the build repo is not signed at this stage
cat > /vservers/$vserver/etc/yum.repos.d/myplc.repo <<EOF
vserver=$1; shift
fcdistro=$1; shift
+ pldistro=$1; shift
personality=$1; shift
# check that this is a new one - see above
fi
# minimal config in the vserver for yum to work
- [ "$pkg_method" = "yum" ] && configure_yum_in_vserver $vserver $fcdistro
+ [ "$pkg_method" = "yum" ] && configure_yum_in_vserver $vserver $fcdistro $pldistro
# set up resolv.conf
cp /etc/resolv.conf /vservers/$vserver/etc/resolv.conf
[ -z "$pldistro" ] && pldistro=$DEFAULT_PLDISTRO
[ -z "$personality" ] && personality=$DEFAULT_PERSONALITY
- setup_vserver $vserver $fcdistro $personality
+ setup_vserver $vserver $fcdistro $pldistro $personality
devel_or_vtest_tools $vserver $fcdistro $pldistro $personality
post_install $vserver $personality