X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=INSTALL.RHEL;h=eaa2e7c7323052bec5a386163f9cb9ca7104ce9a;hb=e018053f14beb09ac7f634687c48ac2a214208f2;hp=35589484026a57f2dd95c7f6fa51f7529e9d87b3;hpb=c434706a374bd44d1274e7bdbee40067a6620b61;p=sliver-openvswitch.git diff --git a/INSTALL.RHEL b/INSTALL.RHEL index 355894840..eaa2e7c73 100644 --- a/INSTALL.RHEL +++ b/INSTALL.RHEL @@ -3,7 +3,7 @@ This document describes how to build and install Open vSwitch on a Red Hat Enterprise Linux (RHEL) host. If you want to install Open vSwitch -on a generic Linux host, see INSTALL.Linux instead. +on a generic Linux host, see INSTALL instead. We have tested these instructions with RHEL 5.6 and RHEL 6.0. @@ -17,22 +17,58 @@ Before you begin, note the RPM source directory on your version of RHEL. On RHEL 5, the default RPM source directory is /usr/src/redhat/SOURCES. On RHEL 6, it is $HOME/rpmbuild/SOURCES. -1. If you are building from an Open vSwitch Git tree, then you will +1. Install build prerequisites: + + yum install gcc make python-devel openssl-devel kernel-devel \ + kernel-debug-devel + +2. Some versions of the RHEL 6 kernel-devel package contain a broken + "build" symlink. If you are using such a version, you must fix + the problem before continuing. + + To find out whether you are affected, run: + + cd /lib/modules/ + ls -l build/ + + where is the version number of the RHEL 6 kernel. (The + trailing slash in the final command is important. Be sure to include + it.) If the "ls" command produces a directory listing, your + kernel-devel package is OK. If it produces a "No such file or + directory" error, your kernel-devel package is buggy. + + If your kernel-devel package is buggy, then you can fix it with: + + cd /lib/modules/ + rm build + ln -s /usr/src/kernels/ build + + where is the name of an existing directory under + /usr/src/kernels, whose name should be similar to but may + contain some extra parts. Once you have done this, verify the fix with + the same procedure you used above to check for the problem. + +3. If you are building from an Open vSwitch Git tree, then you will need to first create a distribution tarball by running "./boot.sh; ./configure; make dist" in the Git tree. -2. Copy the distribution tarball into the RPM source directory. +4. Copy the distribution tarball into the RPM source directory. -3. Unpack the distribution tarball into a temporary directory and "cd" +5. Unpack the distribution tarball into a temporary directory and "cd" into the root of the distribution tarball. -4. To build Open vSwitch userspace, run: +6. To build Open vSwitch userspace, run: rpmbuild -bb rhel/openvswitch.spec This produces two RPMs: "openvswitch" and "openvswitch-debuginfo". -5a. On RHEL 5, to build the Open vSwitch kernel module, copy + If the build fails with "configure: error: source dir + /lib/modules/2.6.32-279.el6.x86_64/build doesn't exist" or similar, + then the kernel-devel package is missing or buggy. Go back to step + 1 or 2 and fix the problem. + +7a. On RHEL 5, to build the Open vSwitch kernel module, copy rhel/kmodtool-openvswitch-el5.sh into the RPM source directory and run: @@ -49,11 +85,29 @@ RHEL. On RHEL 5, the default RPM source directory is which is usually: "kmod-openvswitch", "kmod-openvswitch-xen", and "kmod-openvswitch-PAE". -5b. On RHEL 6, to build the Open vSwitch kernel module, run: +7b. On RHEL 6, to build the Open vSwitch kernel module, copy + rhel/openvswitch-kmod.files into the RPM source directory and run: rpmbuild -bb rhel/openvswitch-kmod-rhel6.spec - This produces an "kmod-openvswitch" RPM. + You might have to specify a kernel version and/or variants, e.g.: + + rpmbuild -bb \ + -D "kversion 2.6.32-131.6.1.el6.x86_64" \ + -D "kflavors default debug kdump" \ + rhel/openvswitch-kmod-rhel6.spec + + This produces an "kmod-openvswitch" RPM for each kernel variant, + in this example: "kmod-openvswitch", "kmod-openvswitch-debug", and + "kmod-openvswitch-kdump". + +Red Hat Network Scripts Integration +----------------------------------- + +Simple integration with Red Hat network scripts has been implemented. +Please read rhel/README.RHEL in the source tree or +/usr/share/doc/openvswitch/README.RHEL in the installed openvswitch +package for details. Reporting Bugs --------------