openvswitch-1.11.0 added

This commit is contained in:
Kolan Sh 2013-09-13 20:59:59 +04:00
parent bf1ddfa480
commit a046f1df68
8 changed files with 258 additions and 0 deletions

View File

@ -0,0 +1 @@
DIST openvswitch-1.11.0.tar.gz 2551510 SHA256 007d7d3f2deabe5a3845d1045d23b6b1de174497a8e436091541221dd71833da SHA512 9c338a9e376c845ae5f273030263dbae52fa268350d943e65987d6840d9647194f715e36517c829be32200f1064e13a585bd5b2acb9fa2a7f32199bd4be31459 WHIRLPOOL fa7bc71f0f17f789ed0dc1dce953e1399f56c7529d13a10761f90a3b40a210e511722dda99a502fa2ef8f74ccc6ea5e8c3392c408bf00a85b5824bfa96fc7f24

View File

@ -0,0 +1,23 @@
#!/sbin/runscript
# Copyright 1999-2013 Gentoo Foundation
# Distributed under the terms of the GNU General Public License v2
# $Header: /var/cvsroot/gentoo-x86/net-misc/openvswitch/files/ovs-controller-r1,v 1.1 2013/04/08 19:37:58 dev-zero Exp $
description="Open vSwitch OpenFlow controller"
command="/usr/bin/ovs-controller"
command_args="
--pidfile
--detach
--monitor
${OPTIONS} ${METHODS}"
pidfile="/var/run/openvswitch/ovs-controller.pid"
depend() {
need net
use logger
}
start_pre() {
checkpath -d "/var/run/openvswitch" -m 0750
}

View File

@ -0,0 +1,7 @@
# Space separated list of methods to listen for OpenFlow connections from switches
# The default ist "ptcp:" which starts ovs-controller listening on port 6633 on all interfaces.
METHODS="ptcp:"
# Additional options
# OPTIONS=""

View File

@ -0,0 +1,22 @@
#!/sbin/runscript
# Copyright 1999-2013 Gentoo Foundation
# Distributed under the terms of the GNU General Public License v2
# $Header: /var/cvsroot/gentoo-x86/net-misc/openvswitch/files/ovs-vswitchd-r1,v 1.1 2013/04/08 19:37:58 dev-zero Exp $
description="Open vSwitch virtual switch"
command="/usr/sbin/ovs-vswitchd"
command_args="
--pidfile
--detach
--monitor
${OPTIONS} ${DATABASE}"
pidfile="/var/run/openvswitch/ovs-vswitchd.pid"
depend() {
use ovsdb-server logger
}
start_pre() {
checkpath -d "/var/run/openvswitch" -m 0750
}

View File

@ -0,0 +1,6 @@
# Connection string for the configuration database (usually a unix socket)
DATABASE="unix:/var/run/openvswitch/db.sock"
# Additional options
OPTIONS="--mlockall"

View File

@ -0,0 +1,35 @@
#!/sbin/runscript
# Copyright 1999-2013 Gentoo Foundation
# Distributed under the terms of the GNU General Public License v2
# $Header: /var/cvsroot/gentoo-x86/net-misc/openvswitch/files/ovsdb-server-r1,v 1.1 2013/04/08 19:37:58 dev-zero Exp $
description="Open vSwitch database server"
remote_punix=${DB_SOCKET:+"--remote=punix:${DB_SOCKET}"}
remote_db=${REMOTE_DB:+"--remote=${REMOTE_DB}"}
private_key=${PRIVATE_KEY:+"--private-key=${PRIVATE_KEY}"}
certificate=${CERTIFICATE:+"--certificate=${CERTIFICATE}"}
bootstrap_ca_cert=${BOOTSTRAP_CA_CERT:+"--bootstrap-ca-cert=${BOOTSTRAP_CA_CERT}"}
command="/usr/sbin/ovsdb-server"
command_args="
--pidfile
--detach
--monitor
${remote_punix}
${remote_db}
${private_key}
${certificate}
${bootstrap_ca_cert}
${DATABASE}
${OPTIONS}"
pidfile="/var/run/openvswitch/ovsdb-server.pid"
depend() {
need localmount
use logger
}
start_pre() {
checkpath -d "/var/run/openvswitch" -m 0750
}

View File

@ -0,0 +1,16 @@
# Socket for bringing the server up
DB_SOCKET="/var/run/openvswitch/db.sock"
# Remote sockets are defined in the database by default
REMOTE_DB="db:Open_vSwitch,manager_options"
# All certificates and keys are stored in the database (if any)
PRIVATE_KEY="db:SSL,private_key"
CERTIFICATE="db:SSL,certificate"
BOOTSTRAP_CA_CERT="db:SSL,ca_cert"
# Alternative path for the database (default is /etc/openvswitch/conf.db)
# DATABASE="/etc/openvswitch/conf.db"
# Additional options
# OPTIONS=""

View File

@ -0,0 +1,148 @@
# Copyright 1999-2013 Gentoo Foundation
# Distributed under the terms of the GNU General Public License v2
# $Header: /var/cvsroot/gentoo-x86/net-misc/openvswitch/openvswitch-1.11.0.ebuild,v 1.1 2013/09/12 06:41:28 prometheanfire Exp $
EAPI=5
PYTHON_COMPAT=( python2_7 )
inherit eutils linux-info linux-mod python-single-r1
DESCRIPTION="Production quality, multilayer virtual switch."
HOMEPAGE="http://openvswitch.org"
SRC_URI="http://openvswitch.org/releases/${P}.tar.gz"
LICENSE="Apache-2.0 GPL-2"
SLOT="0"
KEYWORDS="~amd64 ~x86"
IUSE="debug modules monitor +pyside +ssl"
RDEPEND=">=sys-apps/openrc-0.10.5
ssl? ( dev-libs/openssl )
monitor? (
${PYTHON_DEPS}
dev-python/twisted-core[${PYTHON_USEDEP}]
dev-python/twisted-conch[${PYTHON_USEDEP}]
dev-python/twisted-web[${PYTHON_USEDEP}]
pyside? ( dev-python/pyside[${PYTHON_USEDEP}] )
!pyside? ( dev-python/PyQt4[${PYTHON_USEDEP}] )
net-zope/zope-interface[${PYTHON_USEDEP}] )
debug? ( dev-lang/perl )"
DEPEND="${RDEPEND}
virtual/pkgconfig"
CONFIG_CHECK="~NET_CLS_ACT ~NET_CLS_U32 ~NET_SCH_INGRESS ~NET_ACT_POLICE ~IPV6 ~TUN"
MODULE_NAMES="brcompat(net:${S}/datapath/linux) openvswitch(net:${S}/datapath/linux)"
BUILD_TARGETS="all"
pkg_setup() {
if use modules ; then
CONFIG_CHECK+=" ~!OPENVSWITCH"
linux-mod_pkg_setup
else
CONFIG_CHECK+=" ~OPENVSWITCH"
linux-info_pkg_setup
fi
kernel_is ge 2 6 18 || die "Linux >=2.6.18 and <3.2.9 required"
kernel_is lt 3 12 || die "Linux >=2.6.18 and <3.12 required"
use monitor && python-single-r1_pkg_setup
}
src_prepare() {
# Never build kernelmodules, doing this manually
sed -i \
-e '/^SUBDIRS/d' \
datapath/Makefile.in || die "sed failed"
}
src_configure() {
set_arch_to_kernel
use monitor || export ovs_cv_python="no"
use pyside || export ovs_cv_pyuic4="no"
local linux_config
use modules && linux_config="--with-linux=${KERNEL_DIR}"
econf ${linux_config} \
--with-rundir=/var/run/openvswitch \
--with-logdir=/var/log/openvswitch \
--with-pkidir=/etc/ssl/openvswitch \
--with-dbdir=/var/lib/openvswitch \
$(use_enable ssl) \
$(use_enable !debug ndebug)
}
src_compile() {
default
use monitor && python_fix_shebang \
utilities/ovs-{pcap,tcpundump,test,vlan-test} \
utilities/bugtool/ovs-bugtool \
ovsdb/ovsdbmonitor/ovsdbmonitor
use modules && linux-mod_src_compile
}
src_install() {
default
if use monitor ; then
python_domodule "${ED}"/usr/share/openvswitch/python/*
rm -r "${ED}/usr/share/openvswitch/python"
python_optimize "${ED}/usr/share/ovsdbmonitor"
fi
# not working without the brcompat_mod kernel module which did not get
# included in the kernel and we can't build it anymore
rm "${D}/usr/sbin/ovs-brcompatd" "${D}/usr/share/man/man8/ovs-brcompatd.8"
keepdir /var/{lib,log}/openvswitch
keepdir /etc/ssl/openvswitch
fperms 0750 /etc/ssl/openvswitch
rm -rf "${ED}/var/run"
use monitor || rmdir "${ED}/usr/share/ovsdbmonitor"
use debug || rm "${ED}/usr/bin/ovs-parse-leaks"
newconfd "${FILESDIR}/ovsdb-server_conf" ovsdb-server
newconfd "${FILESDIR}/ovs-vswitchd_conf" ovs-vswitchd
newconfd "${FILESDIR}/ovs-controller_conf" ovs-controller
newinitd "${FILESDIR}/ovsdb-server-r1" ovsdb-server
newinitd "${FILESDIR}/ovs-vswitchd-r1" ovs-vswitchd
newinitd "${FILESDIR}/ovs-controller-r1" ovs-controller
insinto /etc/logrotate.d
newins rhel/etc_logrotate.d_openvswitch openvswitch
use modules && linux-mod_src_install
}
pkg_postinst() {
use modules && linux-mod_pkg_postinst
for pv in ${REPLACING_VERSIONS}; do
if ! version_is_at_least 1.9.0 ${pv} ; then
ewarn "The configuration database for Open vSwitch got moved in version 1.9.0 from"
ewarn " /etc/openvswitch"
ewarn "to"
ewarn " /var/lib/openvswitch"
ewarn "Please copy/move the database manually before running the schema upgrade."
ewarn "The PKI files are now supposed to go to /etc/ssl/openvswitch"
fi
done
elog "Use the following command to create an initial database for ovsdb-server:"
elog " emerge --config =${CATEGORY}/${PF}"
elog "(will create a database in /var/lib/openvswitch/conf.db)"
elog "or to convert the database to the current schema after upgrading."
}
pkg_config() {
local db="${EPREFIX}/var/lib/openvswitch/conf.db"
if [ -e "${db}" ] ; then
einfo "Database '${db}' already exists, doing schema migration..."
einfo "(if the migration fails, make sure that ovsdb-server is not running)"
"${EPREFIX}/usr/bin/ovsdb-tool" convert "${db}" "${EPREFIX}/usr/share/openvswitch/vswitch.ovsschema" || die "converting database failed"
else
einfo "Creating new database '${db}'..."
"${EPREFIX}/usr/bin/ovsdb-tool" create "${db}" "${EPREFIX}/usr/share/openvswitch/vswitch.ovsschema" || die "creating database failed"
fi
}